/* ============================================================================
   APS 2027 — 30th American Peptide Symposium · Boston
   Enhanced stylesheet (drop-in replacement for aps2027.css)
   Layered on Bootstrap 5.3.2. Loads the Adobe Typekit kit (houschka-pro +
   hello-bloomie-script). Every class from the original file is preserved.
   ----------------------------------------------------------------------------
   Contents
     1.  Tokens (color, type, space, radius, shadow)
     2.  Base elements (body, links, paragraphs, headings)
     3.  Display & section headings (accent-bar motif)
     4.  Intro / lead copy & people typography
     5.  Layout, sections & rhythm utilities
     6.  Hero banner
     7.  Dividers
     8.  Images & avatars
     9.  Cards (co-chair, pharma-box, generic)
     10. Venue gallery
     11. Buttons
     12. Navbar (forward-looking)
     13. Schedule / program components
     14. Footer
     15. Misc utilities, motion & print
   ========================================================================== */

@import url("https://use.typekit.net/pct0eai.css");

/* ============================================================================
   1. TOKENS
   ========================================================================== */
:root {
    /* Brand — Boston palette */
    --aps-red:        #CB3B2D;   /* primary headline accent */
    --aps-blue:       #3A53A4;   /* links, secondary accent */
    --aps-blue-dark:  #2C4080;   /* link visited / hover-dark */
    --harbor-navy:    #1A2E4C;   /* primary dark — headers, footer */
    --brass-gold:     #C9A227;   /* metallic accent, rules, bars */
    --brass-deep:     #A8851A;   /* gold hover */
    --brick-warm:     #A45A3D;   /* warm secondary accent */
    --teal:           #007777;   /* co-chairs, slogan script */
    --teal-deep:      #005C5C;

    /* Neutrals */
    --ink:            #2B303A;   /* body text */
    --ink-soft:       #4C5562;   /* secondary text */
    --muted:          #6B7480;   /* captions / meta */
    --line:           #DCE3EC;   /* hairlines */
    --line-soft:      #EAEEF4;
    --fog-gray:       #E8ECF2;   /* cool section bg */
    --parchment:      #F7F4EF;   /* warm section bg */
    --cloud:          #F4F7FB;   /* lightest cool */
    --paper:          #FFFFFF;
    --text-dark:      #2B303A;   /* legacy alias */

    /* Typography */
    --font-body:   houschka-pro, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --font-script: "hello-bloomie-script", "Brush Script MT", cursive;

    /* Spacing scale (rhythm: 8) */
    --space-1: .5rem;    /* 8  */
    --space-2: 1rem;     /* 16 */
    --space-3: 1.5rem;   /* 24 */
    --space-4: 2rem;     /* 32 */
    --space-5: 3rem;     /* 48 */
    --space-6: 4.5rem;   /* 72 */

    /* Radius */
    --radius-sm: 6px;
    --radius:    10px;
    --radius-lg: 16px;
    --radius-pill: 999px;

    /* Shadows — warm navy-tinted */
    --shadow-sm: 0 1px 3px rgba(26, 46, 76, .08);
    --shadow-md: 0 6px 22px rgba(26, 46, 76, .10);
    --shadow-lg: 0 16px 44px rgba(26, 46, 76, .16);

    /* Motion */
    --ease: cubic-bezier(.2, .6, .2, 1);
    --t-fast: .18s var(--ease);
    --t: .26s var(--ease);

    /* Layout */
    --container-max: 1300px;
}

/* ============================================================================
   2. BASE
   ========================================================================== */
* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
    font-family: var(--font-body);
    color: var(--ink);
    background: var(--paper);
    line-height: 1.65;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Wider gutters than Bootstrap default; cap at a comfortable measure */
@media (min-width: 1400px) {
    .container { max-width: var(--container-max); }
}
@media (min-width: 1679px) {
    .container { width: var(--container-max); padding-left: var(--space-3); padding-right: var(--space-3); }
}

/* Links */
a {
    color: var(--aps-blue);
    text-decoration: none;
    transition: color var(--t-fast);
}
a:link    { color: var(--aps-blue); }
a:visited { color: var(--aps-blue-dark); }
a:hover   { color: var(--aps-red); }
a:active  { color: var(--brass-gold); }

/* Give in-copy links a refined underline without touching nav/button links */
.intro a,
.rich-text a,
p a {
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
    text-decoration-color: color-mix(in srgb, currentColor 35%, transparent);
    text-decoration-line: underline;
}
.intro a:hover,
.rich-text a:hover,
p a:hover { text-decoration-color: currentColor; }

/* Body copy — readable measure, softened from the old 1.3em/letter-spacing .5px */
p {
    font-size: 1.0625rem;   /* ~17px */
    font-weight: 400;
    line-height: 1.7;
    letter-spacing: 0;
    color: var(--ink);
    margin-bottom: 1.1rem;
}
p:last-child { margin-bottom: 0; }

strong, b { font-weight: 700; color: var(--harbor-navy); }

/* Constrain long prose for readability (opt-in, doesn't affect grid columns) */
.prose { max-width: 68ch; }
.prose p + p { margin-top: 0; }

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-body);
    text-transform: none;
    color: var(--harbor-navy);
    line-height: 1.15;
    letter-spacing: -0.01em;
}

/* Small eyebrow / kicker label — handy for section intros */
.kicker {
    display: inline-block;
    font-size: .8rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--brass-deep);
    margin-bottom: .6rem;
}

/* ============================================================================
   3. DISPLAY & SECTION HEADINGS
   ========================================================================== */

/* The big red hero title — now fluid and tighter */
h1.primary-header,
.primary-header {
    font-weight: 300;
    color: var(--aps-red);
    font-size: clamp(2.6rem, 6vw, 5rem);
    line-height: 1.02;
    letter-spacing: -0.02em;
    padding-top: 0;
    margin-top: var(--space-5);
    margin-bottom: var(--space-2);
}

/* Script slogan — teal, fluid */
.slogan-header {
    font-style: normal;
    font-family: var(--font-script);
    font-weight: 400;
    color: var(--teal);
    font-size: clamp(1.5rem, 2.3vw, 2.2rem);
    line-height: 1.1;
    margin-bottom: var(--space-3);
}

/* Keep the script slogan on a single line on large screens */
@media (min-width: 992px) {
    .slogan-header { white-space: nowrap; }
}

/* Section header — the APS signature: navy text with a brass accent bar.
   This is the core visual upgrade and ties 2027 to the APS family. */
.secondary-header {
    position: relative;
    font-weight: 600;
    color: var(--harbor-navy);
    font-size: clamp(1.8rem, 3.2vw, 2.6rem);
    line-height: 1.1;
    letter-spacing: -0.015em;
    padding-left: 1rem;
    border-left: 6px solid var(--brass-gold);
    margin-bottom: var(--space-3);
}

/* Person / sub-section heading — teal */
.co-chair-header {
    font-weight: 600;
    color: var(--teal);
    font-size: clamp(1.35rem, 2vw, 1.7rem);
    line-height: 1.2;
    letter-spacing: -0.01em;
    margin-top: var(--space-2);
    margin-bottom: .35rem;
}

/* Tertiary — warm brick, sits well on parchment/white */
.tertiary-header {
    font-weight: 600;
    color: var(--brick-warm);
    font-size: clamp(1.35rem, 1.8vw, 1.7rem);
    line-height: 1.2;
    margin-bottom: var(--space-2);
}

.co-chair-header.is-blue,
.secondary-header.is-blue { color: var(--aps-blue); }
.secondary-header.is-blue { border-left-color: var(--aps-blue); }

.slider-header {
    font-weight: 400;
    color: var(--aps-blue);
    margin-bottom: var(--space-1) !important;
    font-size: clamp(1.2rem, 1vw + .7em, 3rem);
    line-height: 1.1;
}

/* ============================================================================
   4. INTRO / LEAD & PEOPLE TYPOGRAPHY
   ========================================================================== */
.intro {
    font-size: clamp(1.1rem, 1.4vw, 1.4rem);
    font-weight: 400;
    line-height: 1.55;
    letter-spacing: 0;
    color: var(--ink-soft);
    max-width: 75ch;
}
.intro b, .intro strong { color: var(--harbor-navy); font-weight: 600; }

.banner-top {
    font-size: clamp(2rem, 2.3vw, 2.3rem);
    font-weight: 200;
    color: #fff;
    line-height: 1.2;
}
.banner-top a:link,
.banner-top a:visited { color: #fff; }
.banner-top a:hover  { color: var(--brass-gold); }

.display-name {
    font-size: clamp(1.6rem, 1.9vw, 1.9rem);
    font-weight: 600;
    line-height: 1.25;
    letter-spacing: 0;
    color: var(--aps-blue);
    margin-bottom: .5rem;
}
.speaker-name-awardee {
    font-size: clamp(1.8rem, 2.3vw, 2.3rem);
    font-weight: 600;
    line-height: 1.25;
    letter-spacing: 0;
    color: var(--harbor-navy);
    margin: 0;
}
.invited-speaker {
    margin: 0;
    color: var(--aps-blue);
    font-size: clamp(1rem, 1vw, 1.15rem);
    font-weight: 600;
    line-height: 1.3;
}
.speaker-description { font-size: clamp(1rem, 1.1vw, 1.1rem); }
.affiliation { font-style: italic; color: var(--muted); }
.authors { font-size: clamp(.85rem, 1.3vw, 1.05rem); font-weight: 600; color: var(--ink-soft); }
.award-text {
    font-size: clamp(1rem, 1.3vw, 1.3rem);
    color: var(--aps-red) !important;
    font-weight: 500 !important;
}

/* ============================================================================
   5. LAYOUT, SECTIONS & RHYTHM
   ========================================================================== */
section { padding: var(--space-6) 0; }

/* Keep the original auto-alternation, but warmer + intentional helpers */
section:nth-child(even) { background-color: var(--cloud); }

.section-parchment { background-color: var(--parchment); }
.section-fog       { background-color: var(--fog-gray); }
.section-cloud     { background-color: var(--cloud); }
.section-white     { background-color: var(--paper); }
.section-navy      { background-color: var(--harbor-navy); color: #E8EDF5; }
.section-navy .secondary-header { color: #fff; }
.section-navy p { color: #C7D2E2; }

/* A tidy section intro block */
.section-head { margin-bottom: var(--space-4); }

/* ============================================================================
   6. HERO BANNER
   ========================================================================== */
.hero-banner { width: 100%; line-height: 0; background: var(--harbor-navy); }
.hero-banner img {
    width: 100%;
    height: auto;
    display: block;
    max-height: 460px;
    object-fit: cover;
    object-position: center;
}

/* ============================================================================
   7. DIVIDERS
   ========================================================================== */
hr.border27 {
    border: 0;
    border-top: 2px solid var(--teal);
    opacity: 1;
    margin-top: var(--space-5);
    margin-bottom: var(--space-4);
}
.underline {
    width: 64px;
    height: 0;
    border: 0;
    border-top: 3px solid var(--brass-gold);
    border-radius: 3px;
    margin-top: .5rem;
    margin-bottom: var(--space-3);
    opacity: 1;
}
.table-divider {
    margin-top: var(--space-5);
    margin-bottom: var(--space-3);
    border: 0;
    border-top: 1px solid var(--line);
    opacity: 1;
}

/* ============================================================================
   8. IMAGES & AVATARS
   ========================================================================== */
.img-responsive { border-radius: var(--radius-sm); }

/* Photos that carry the .rounded utility get a soft card treatment */
img.rounded {
    border-radius: var(--radius) !important;
    box-shadow: var(--shadow-sm);
}

.profile-image {
    width: 200px;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    overflow: hidden;
    display: inline-block;
    box-shadow: var(--shadow-md);
}
.profile-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
}

.headshot-circle {
    width: 55px;
    height: 55px;
    flex: 0 0 55px;
    box-shadow: var(--shadow-sm);
    border-radius: 50%;
    object-fit: cover;
    object-position: top center;
    display: inline-block;
    margin-right: 15px;
    border: 2px solid #fff;
    outline: 1px solid var(--line);
}

/* ============================================================================
   9. CARDS
   ========================================================================== */

/* Co-chair / speaker portrait blocks */
.co-chair-img {
    width: 100%;
    max-width: 400px;
    height: auto;
    object-fit: cover;
    border-radius: var(--radius);
    box-shadow: var(--shadow-md);
    transition: transform var(--t), box-shadow var(--t);
}
.co-chair-img:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }

.co-chair-card h3 { margin-top: var(--space-2); font-size: 1.25rem; }
.co-chair-card .title { font-style: italic; color: var(--muted); margin-bottom: var(--space-2); }

/* Highlighted box (sponsors / notices) — refined parchment panel */
.pharma-box {
    padding: var(--space-4) var(--space-4) var(--space-2);
    border: 1px solid color-mix(in srgb, var(--brass-gold) 55%, transparent);
    border-left: 5px solid var(--brass-gold);
    border-radius: var(--radius);
    background-color: var(--parchment);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--space-4);
}

/* Generic reusable content card for future pages */
.aps-card {
    background: var(--paper);
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    box-shadow: var(--shadow-sm);
    padding: var(--space-4);
    transition: transform var(--t), box-shadow var(--t);
}
.aps-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.aps-card--feature { border-top: 4px solid var(--brass-gold); }

/* ============================================================================
   10. VENUE GALLERY
   ========================================================================== */
.venue-gallery .col-md-4 { margin-bottom: var(--space-3); }
.venue-gallery img,
.venue-gallery .img-fluid {
    width: 100%;
    height: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: var(--radius);
    box-shadow: var(--shadow-sm);
    transition: transform var(--t), box-shadow var(--t);
}
.venue-gallery a,
.venue-gallery .col-md-4 { overflow: hidden; border-radius: var(--radius); display: block; }
.venue-gallery img:hover {
    transform: translateY(-4px) scale(1.02);
    box-shadow: var(--shadow-md);
}

/* ============================================================================
   11. BUTTONS
   ========================================================================== */
.btn {
    --bs-btn-font-family: var(--font-body);
    font-weight: 600;
    letter-spacing: .01em;
    border-radius: var(--radius-sm);
    padding: .7rem 1.5rem;
    transition: transform var(--t-fast), box-shadow var(--t-fast),
                background-color var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.btn:active { transform: translateY(1px); }

.btn-aps,
.btn-primary {
    background-color: var(--aps-blue);
    border: 1px solid var(--aps-blue);
    color: #fff;
}
.btn-aps:hover,
.btn-primary:hover {
    background-color: var(--harbor-navy);
    border-color: var(--harbor-navy);
    color: #fff;
    box-shadow: var(--shadow-md);
}

.btn-accent {
    background-color: var(--brass-gold);
    border: 1px solid var(--brass-gold);
    color: var(--harbor-navy);
}
.btn-accent:hover {
    background-color: var(--brass-deep);
    border-color: var(--brass-deep);
    color: #fff;
    box-shadow: var(--shadow-md);
}

.btn-outline-aps {
    background: transparent;
    border: 2px solid var(--aps-blue);
    color: var(--aps-blue);
}
.btn-outline-aps:hover {
    background: var(--aps-blue);
    color: #fff;
}

/* ============================================================================
   12. MAIN NAVBAR — sits under the hero banner, right-aligned
   ----------------------------------------------------------------------------
   Markup:
     <nav class="aps-navbar">
       <div class="container">
         <ul class="aps-nav">
           <li><a href="/" class="active">Home</a></li>
           <li><a href="/sponsors-exhibitors/">Sponsors &amp; Exhibitors</a></li>
         </ul>
       </div>
     </nav>
   Add the modifier class .aps-navbar--sticky if you want it to pin on scroll.
   ========================================================================== */
.aps-navbar {
    background: #fff;
    border-bottom: 1px solid var(--line);
    box-shadow: var(--shadow-sm);
}
.aps-navbar--sticky { position: sticky; top: 0; z-index: 1020; }

.aps-navbar .container {
    display: flex;
    justify-content: flex-end;   /* right-aligned */
    align-items: center;
}

.aps-nav {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: .25rem;
    margin: 0;
    padding: 0;
}
.aps-nav > li { margin: 0; }
.aps-nav a {
    display: block;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: .82rem;
    line-height: 1;
    color: var(--ink-soft);
    padding: 1.15rem 1.1rem;
    border-bottom: 3px solid transparent;
    transition: color var(--t-fast), border-color var(--t-fast);
}
.aps-nav a:link,
.aps-nav a:visited { color: var(--ink-soft); }
.aps-nav a:hover { color: var(--aps-red); }
.aps-nav a.active,
.aps-nav a[aria-current="page"] {
    color: var(--harbor-navy);
    border-bottom-color: var(--brass-gold);
}

@media (max-width: 575.98px) {
    .aps-navbar .container { justify-content: center; }
    .aps-nav { justify-content: center; }
    .aps-nav a { padding: .9rem .8rem; font-size: .76rem; letter-spacing: .05em; }
}

/* Back-compat: also style a Bootstrap <nav class="navbar aps-navbar"> if used */
.aps-navbar .navbar-brand { font-weight: 700; color: var(--harbor-navy); letter-spacing: .01em; }
.aps-navbar .nav-link {
    font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
    font-size: .82rem; color: var(--ink-soft); padding: 1.15rem 1.1rem;
    border-bottom: 3px solid transparent; transition: color var(--t-fast), border-color var(--t-fast);
}
.aps-navbar .nav-link:hover  { color: var(--aps-red); }
.aps-navbar .nav-link.active { color: var(--harbor-navy); border-bottom-color: var(--brass-gold); }

/* ============================================================================
   13. SCHEDULE / PROGRAM COMPONENTS
   ========================================================================== */
.aps27-table { border: 0 !important; }
.aps-table { padding-left: 9px; margin-bottom: .7em; }

.schedule-item-wrapper { display: flex; align-items: center; gap: 1rem; flex-wrap: nowrap; }

.schedule-date {
    font-size: clamp(2rem, 2.5vw, 3.5rem);
    font-family: var(--font-body);
    font-weight: 300;
    letter-spacing: -0.01em;
    margin: var(--space-3) 0 .25rem;
    color: var(--harbor-navy);
}

.schedule-session-header {
    line-height: 1.25;
    font-size: clamp(1.7rem, 3vw, 2.6rem);
    margin-bottom: var(--space-2);
    padding-bottom: .4rem;
    font-weight: 600;
    color: var(--harbor-navy);
    border-bottom: 2px solid var(--brass-gold);
    text-shadow: none;
}

.schedule-event {
    line-height: 1.25;
    font-size: clamp(1.4rem, 2.5vw, 2.1rem);
    margin-bottom: .5rem;
    color: var(--aps-blue);
    font-weight: 600;
}
.schedule-item { margin: 0 0 .3rem; line-height: 1.35; font-size: clamp(1.15rem, 2vw, 1.55rem); font-weight: 400; }
.schedule-talk-title {
    font-style: italic;
    line-height: 1.4;
    font-size: clamp(1.1rem, 2vw, 1.5rem);
    margin-top: var(--space-3) !important;
    font-weight: 400;
    color: var(--ink);
}
.schedule-time { line-height: 1.3; font-size: clamp(1rem, 1vw, 1.1rem); margin-bottom: .3rem; font-weight: 600; color: var(--brick-warm); }
.schedule-location { line-height: 1.3; font-size: clamp(.9rem, 1vw, 1rem); margin-bottom: .3rem; font-weight: 400; color: var(--muted); }

.schedule-item a { font-size: clamp(1.15rem, 2vw, 1.55rem); color: var(--aps-blue); font-weight: 600; transition: color var(--t-fast); }
.schedule-item a:hover,
.sched-link:hover { color: var(--aps-red); }

.lecture-indicator { font-size: 1.1rem; font-weight: 700; color: var(--brass-gold); display: inline-block; line-height: 1.4; letter-spacing: .04em; }

.table-text {
    font-weight: 600; color: var(--harbor-navy); font-size: 1rem; line-height: 1.3;
    margin-top: var(--space-2); letter-spacing: .02em; padding-left: 9px;
}
.table-text-large {
    font-weight: 600; color: #fff; font-size: 1.35rem; line-height: 1.3;
    margin-top: .75rem; letter-spacing: .02em; padding-left: 9px;
}
.topic-box { width: 60%; }

/* ============================================================================
   14. FOOTER — Symposium Leadership
   ========================================================================== */
.apsfooter{
  background:var(--harbor-navy);
  border-top:4px solid var(--brass-gold);
  color:#B9C6DA;
  font-size:.98rem;line-height:1.7;
}
.apsfooter h1,.apsfooter h2,.apsfooter h3,.apsfooter h4,.apsfooter h5{color:#fff;}
.apsfooter a:link,.apsfooter a:visited{color:#E4EAF3;transition:color var(--t-fast);}
.apsfooter a:hover{color:var(--brass-gold);}
.footer-inner{padding:var(--space-5) var(--space-3) 0;}

/* shared brass label */
.apsfooter .label{
  font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brass-gold);
}

/* co-chairs strip */
.footer-cochairs{
  display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap;
  padding-bottom:var(--space-4);border-bottom:1px solid rgba(255,255,255,.12);
}
.footer-cochairs .label{width:120px;line-height:1.4;flex:0 0 auto;}
.footer-cochair{display:flex;align-items:center;gap:16px;}
.footer-cochair img{
  width:76px;height:76px;border-radius:50%;object-fit:cover;object-position:center top;
  border:2px solid var(--brass-gold);flex:0 0 auto;
}
.footer-cochair .name{font-size:1rem;font-weight:700;color:#fff;white-space:nowrap;line-height:1.3;}
.footer-cochair .affil{font-size:.85rem;color:#8EA0BC;margin-top:3px;}

/* identity + contact columns */
.footer-main{
  display:grid;grid-template-columns:1.6fr 1.3fr 1.3fr;gap:var(--space-4);
  padding-top:var(--space-4);
}
.footer-logo{height:58px;width:auto;display:block;margin-bottom:18px;}
.footer-mission{margin:0;font-size:.95rem;line-height:1.65;color:#B9C6DA;max-width:340px;}
.footer-col .label{display:block;margin-bottom:16px;}
.footer-col .c-name{font-size:1rem;font-weight:700;color:#fff;margin-bottom:2px;white-space:nowrap;}
.footer-col .c-role{font-size:.9rem;color:#8EA0BC;margin-bottom:14px;}
.footer-col .c-line{display:flex;align-items:center;gap:9px;margin-bottom:9px;
  font-size:.95rem;color:#E4EAF3;text-decoration:none;}
.footer-col .c-line i{color:var(--brass-gold);}

/* bottom bar */
.footer-bottom{
  margin-top:var(--space-4);padding:var(--space-3) 0;
  border-top:1px solid rgba(255,255,255,.12);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
}
.footer-bottom .copy{color:#8EA0BC;font-size:.82rem;letter-spacing:.03em;}
.footer-bottom .footer-slogan{
  font-family:var(--font-script);font-weight:400;
  color:#2BB3B3;                 /* brightened teal — reads on navy */
  font-size:clamp(1.05rem,1.8vw,1.45rem);line-height:1.1;
}

@media(max-width:768px){
  .footer-main{grid-template-columns:1fr;}
  .footer-cochairs .label{width:100%;}
}

/* ---- Sponsor CTA (parchment) ---- */
.sponsor-cta{
  background:var(--parchment);
  border-radius:var(--radius);
  padding:var(--space-5);
  display:flex;align-items:center;justify-content:space-between;
  gap:var(--space-4);flex-wrap:wrap;
}
.sponsor-cta .cta-text{border-left:6px solid var(--brass-gold);padding-left:14px;}
.sponsor-cta h2{margin:0 0 6px;font-weight:600;font-size:clamp(1.5rem,2.5vw,1.9rem);
  letter-spacing:-0.01em;color:var(--harbor-navy);}
.sponsor-cta p{margin:0;color:var(--ink-soft);font-size:1.05rem;line-height:1.5;}

/* ============================================================================
   15. MISC, MOTION & PRINT
   ========================================================================== */
.nopad { padding: 0; }
.speaker { margin-bottom: var(--space-2); }
.small {
    font-size: .85rem; font-weight: 400; line-height: 1.5;
    letter-spacing: .02em; margin-bottom: 0; color: var(--muted);
}

.wiggle:hover { animation: wiggle .3s ease-in-out infinite; }
@keyframes wiggle {
    0%   { transform: rotate(0deg); }
    25%  { transform: rotate(2deg); }
    50%  { transform: rotate(-2deg); }
    75%  { transform: rotate(2deg); }
    100% { transform: rotate(0deg); }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .001ms !important;
    }
    .co-chair-img:hover,
    .venue-gallery img:hover,
    .aps-card:hover { transform: none; }
}

@media print {
    body { color: #000; background: #fff; }
    .hero-banner, .apsfooter { box-shadow: none; }
    a { color: #000; text-decoration: underline; }
    section:nth-child(even), .section-fog, .section-parchment, .section-cloud { background: #fff !important; }
}

/* ============================================================================
   16. SPONSORS & EXHIBITORS PAGE
   ========================================================================== */

/* Tier pills */
.tier-pill {
    display: inline-block;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    color: #fff;
    padding: .32rem .8rem;
    border-radius: var(--radius-sm);
    line-height: 1;
}
.tier-pill--platinum { background: var(--harbor-navy); }
.tier-pill--gold     { background: var(--brass-gold); }
.tier-pill--silver   { background: #8A9099; }
.tier-pill--bronze   { background: var(--brick-warm); }
.tier-pill--harbor   { background: var(--teal); }

.price { font-weight: 600; color: var(--harbor-navy); white-space: nowrap; }

/* Levels & exhibition tables — quiet hairline style matching the prospectus */
.sponsor-table { width: 100%; border-collapse: collapse; }
.sponsor-table thead th {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--muted);
    text-align: left;
    padding: 0 .75rem .65rem 0;
    border-bottom: 2px solid var(--line);
}
.sponsor-table tbody td {
    padding: .95rem .75rem;
    border-bottom: 1px solid var(--line-soft);
    vertical-align: middle;
    font-size: .98rem;
    line-height: 1.45;
    color: var(--ink-soft);
}
.sponsor-table tbody td:first-child { padding-left: 0; }
.sponsor-table .num   { text-align: center; }
.sponsor-table .limit { color: var(--muted); }
.table-footnote { font-size: .85rem; color: var(--muted); font-style: italic; margin-top: .75rem; }

/* À-la-carte cards */
.alc-label {
    font-size: .8rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
    color: var(--teal);
    margin-bottom: .5rem;
}
.alc-price {
    font-size: 1.9rem;
    font-weight: 600;
    color: var(--harbor-navy);
    line-height: 1;
    margin-bottom: .65rem;
}

/* Added-benefit cards (tier pill + sentence) */
.benefit-card { display: flex; flex-direction: column; gap: .9rem; height: 100%; }
.benefit-card .tier-pill { align-self: flex-start; }

/* Priority-booth callout */
.priority-callout {
    background: var(--parchment);
    border-radius: var(--radius);
    padding: 1.25rem 1.5rem;
    display: flex;
    align-items: center;
    gap: 1rem;
}
.priority-callout .star { font-size: 1.7rem; line-height: 1; color: var(--brass-gold); }
.priority-callout p { margin: 0; font-size: 1rem; color: var(--ink-soft); }

/* Comparison matrix */
.benefits-matrix { width: 100%; border-collapse: collapse; }
.benefits-matrix th,
.benefits-matrix td { padding: .7rem .5rem; border-bottom: 1px solid var(--line-soft); }
.benefits-matrix thead th {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
    text-align: center;
    vertical-align: bottom;
    border-bottom: 2px solid var(--line);
}
.benefits-matrix thead th .bar { height: 3px; border-radius: 2px; margin-bottom: .4rem; }
.benefits-matrix tbody td:first-child { text-align: left; font-size: .82rem; color: #555; }
.benefits-matrix td.cell { text-align: center; }
.benefits-matrix .yes { color: var(--harbor-navy); font-weight: 700; }
.benefits-matrix .no  { color: #D8D8D8; }
.benefits-matrix .val { color: #444; font-weight: 600; font-size: .8rem; }
.benefits-matrix tr.investment { background: var(--parchment); }
.benefits-matrix tr.investment td { font-weight: 700; color: var(--harbor-navy); text-transform: uppercase; font-size: .8rem; letter-spacing: .04em; }
.benefits-matrix tr.investment td:first-child { color: var(--harbor-navy); }

/* Per-tier header bar colors */
.bar--platinum { background: var(--harbor-navy); }
.bar--gold     { background: var(--brass-gold); }
.bar--silver   { background: #8A9099; }
.bar--bronze   { background: var(--brick-warm); }
.bar--harbor   { background: var(--teal); }

@media (max-width: 768px) {
    .benefits-matrix-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .benefits-matrix { min-width: 640px; }
}

/* ---- Sponsors & Exhibitors: page layout rhythm ---- */
.sp-page .sp-band { padding: var(--space-5) 0; }
.sp-page .sp-band--tight { padding: var(--space-4) 0; }
.sp-page .sp-header { padding: var(--space-5) 0 var(--space-4); }
.sp-page .sp-sublabel { color: var(--muted); font-size: .95rem; margin: -.5rem 0 1.6rem; max-width: 72ch; }
.sp-page .sp-lead { margin-bottom: 1.4rem; }
.sp-page h1.sp-title {
    font-weight: 300;
    color: var(--harbor-navy);
    font-size: clamp(2.1rem, 5vw, 3.2rem);
    line-height: 1.05;
    letter-spacing: -0.01em;
    border-left: 8px solid var(--brass-gold);
    padding-left: 1rem;
    margin: 0 0 1rem;
}

/* ---- Countdown clock in the main nav ---- */
.aps-navbar .container { justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.aps-countdown {
    display: flex;
    flex-direction: column;
    justify-content: center;
    line-height: 1.12;
    background: transparent;
}
.aps-countdown__label {
    font-size: .58rem;
    font-weight: 700;
    letter-spacing: .13em;
    text-transform: uppercase;
    color: var(--brass-deep);
    margin-bottom: .15rem;
}
.aps-countdown__time {
    font-size: .98rem;
    font-weight: 700;
    letter-spacing: .02em;
    color: var(--harbor-navy);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}
.aps-countdown__time .unit { color: var(--muted); font-weight: 600; font-size: .8em; }

@media (max-width: 575.98px) {
    .aps-countdown__time { font-size: .9rem; }
}

/* ---- Mobile nav: hamburger toggle ---- */
.aps-nav-toggle {
    display: none;
    background: transparent;
    border: 0;
    cursor: pointer;
    color: var(--harbor-navy);
    font-size: 1.7rem;
    line-height: 1;
    padding: .2rem .35rem;
}
.aps-nav-toggle:focus-visible { outline: 2px solid var(--brass-gold); outline-offset: 2px; }

@media (max-width: 768px) {
    .aps-navbar .container { justify-content: space-between; gap: .5rem; flex-wrap: wrap; }
    .aps-nav-toggle { display: inline-flex; align-items: center; }
    .aps-countdown { margin-top: 10px; align-items: flex-start; text-align: left; }

    .aps-nav {
        display: none;
        flex-basis: 100%;
        flex-direction: column;
        gap: 0;
        margin-top: .4rem;
        border-top: 1px solid var(--line);
    }
    .aps-nav.is-open { display: flex; }
    .aps-nav > li { width: 100%; }
    .aps-nav a {
        padding: .95rem .35rem;
        border-bottom: 1px solid var(--line);
        border-left: 3px solid transparent;
    }
    .aps-nav a.active,
    .aps-nav a[aria-current="page"] {
        border-bottom-color: var(--line);
        border-left-color: var(--brass-gold);
    }
}

/* ============================================================================
   VENUE / DESTINATION PAGES
   ========================================================================== */
.v-sec{padding:var(--space-6) 0;}
.v-sec--cloud{background:var(--cloud);border-top:1px solid #e7edf5;border-bottom:1px solid #e7edf5;}
.v-sec--parchment{background:var(--parchment);border-top:1px solid #ece6da;border-bottom:1px solid #ece6da;}

.v-eyebrow{font-size:.75rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--brass-deep);margin-bottom:12px;}
.v-title{margin:0 0 8px;font-weight:300;font-size:clamp(2.4rem,5vw,3.6rem);
  letter-spacing:-.02em;line-height:1.02;color:var(--harbor-navy);}
.v-location{display:flex;align-items:center;gap:8px;font-size:1rem;color:var(--muted);margin-bottom:34px;}
.v-location i{color:var(--brass-gold);}

/* sub-label that sits under a .secondary-header */
.v-lead{margin:0 0 32px 17px;font-size:.95rem;letter-spacing:.01em;color:#8a909a;}

.v-figure{margin:0 0 24px;}
.v-figure img{width:100%;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow-md);display:block;}
.v-figure.is-hero img{height:clamp(280px,42vw,520px);box-shadow:var(--shadow-lg);}
.v-figure.is-feature img{height:clamp(280px,40vw,480px);}
.v-figcap{font-size:.85rem;color:#8a909a;margin-top:.5rem;letter-spacing:.01em;}
.v-prose{max-width:760px;}
.v-prose p{font-size:1.0625rem;line-height:1.75;color:#3f4754;margin:0 0 1.1rem;}
.v-prose p:last-child{margin-bottom:0;}

.v-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px;}
.v-grid-2 .v-figure{margin:0;}
.v-grid-2 .v-figure img{height:280px;}

/* Getting Here card */
.gh-card{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:#e3e9f1;
  border:1px solid #e3e9f1;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-md);}
.gh-cell{background:#fff;padding:30px 32px;}
.gh-head{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.gh-head i{color:var(--brass-gold);font-size:1.1rem;}
.gh-head span{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brass-deep);}
.gh-cell p{margin:0;font-size:1rem;line-height:1.6;color:var(--ink-soft);}
.gh-cell.is-address p{font-size:1.05rem;color:var(--ink);font-weight:600;}

/* Exploring highlights */
.v-highlights{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin:30px 0 38px;}
.v-highlight i{color:var(--teal);font-size:1.5rem;}
.v-highlight img{width:100%;height:130px;object-fit:cover;border-radius:var(--radius);
  box-shadow:var(--shadow-md);display:block;}
.v-highlight .h-name{font-size:1rem;font-weight:600;color:var(--harbor-navy);margin-top:10px;}
.v-highlight .h-desc{font-size:.9rem;color:var(--muted);line-height:1.45;margin-top:4px;}

/* Reservations placeholder */
.v-reserve{background:var(--parchment);border:1px solid rgba(201,162,39,.55);
  border-left:5px solid var(--brass-gold);border-radius:var(--radius);padding:34px 36px;
  display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;}
.v-reserve .v-reserve-text{max-width:640px;}
.badge-soon{display:inline-flex;align-items:center;gap:8px;background:#ece3cb;color:#8a7340;
  font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:5px 12px;border-radius:20px;margin-bottom:14px;}
.v-reserve p{margin:0;font-size:1.05rem;line-height:1.6;color:var(--ink-soft);}
.btn-disabled{background:#d8d3c7;color:#fff;font-weight:700;font-size:.95rem;
  padding:13px 28px;border-radius:6px;border:0;cursor:not-allowed;}

@media(max-width:768px){
  .gh-card,.v-grid-2{grid-template-columns:1fr;}
  .v-highlights{grid-template-columns:1fr 1fr;}
}
