/* ============================================================
   EVENT LANDING — REUSABLE DESIGN SYSTEM
   Re-theme by editing the tokens in :root (or override them
   from a config via document.documentElement.style.setProperty).
   ============================================================ */
:root{
  /* —— Brand colors —— */
  --brand:#FF6A13;          /* primary accent / CTAs */
  --brand-d:#e85c08;        /* darker accent (hover) */
  --cream:#F3EEE8;          /* page background */
  --cream-2:#E8E3DD;        /* alt light band */
  --accent-soft:#8CAAA6;    /* sage / secondary band */
  --accent-deep:#1B2A27;    /* deep band (image overlay) */
  --ink-bg:#101110;         /* near-black sections */
  --gray-band:#D5D6D2;      /* muted light band */
  --ink:#1d1d1b;            /* body text */
  --muted:#555;             /* secondary text */
  --line:#e5e5e5;           /* hairlines */

  /* —— Typography —— */
  --font-display:'Bebas Neue', Impact, sans-serif;     /* big condensed headings */
  --font-body:'Open Sans','Poppins',Helvetica,sans-serif;
  --font-ui:'Poppins',sans-serif;                       /* subheads / labels */
  --font-accent:'Playfair Display', Georgia, serif;     /* italic flourish */

  /* —— Shape & rhythm —— */
  --radius:8px;
  --radius-lg:22px;
  --container:1080px;
  --section-y:78px;
  --shadow-card:0 14px 40px rgba(0,0,0,.06);
  --shadow-btn:0 25px 20px -20px rgba(0,0,0,.45);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}

/* —— Layout primitives —— */
.ds-wrap{max-width:var(--container);margin:0 auto;padding:0 22px}
.ds-center{text-align:center}
.ds-section{padding:var(--section-y) 0}
.ds-orange{color:var(--brand)}
.ds-display{font-family:var(--font-display);font-weight:400;line-height:.95;letter-spacing:.5px}

/* —— Buttons —— */
.btn{display:inline-block;border:none;cursor:pointer;text-decoration:none;text-align:center;color:#fff;
     background:var(--brand);border-radius:var(--radius);padding:18px 34px;box-shadow:var(--shadow-btn);
     transition:transform .15s,box-shadow .15s;position:relative;overflow:hidden}
.btn:hover{transform:translateY(-2px);box-shadow:0 28px 24px -18px rgba(0,0,0,.5)}
.btn .main{font-family:var(--font-display);font-size:30px;letter-spacing:1px;display:block;line-height:1.1}
.btn .sub{font-family:var(--font-ui);font-size:14px;font-weight:500;opacity:.92;display:block;margin-top:2px}
.btn.shine::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
     background:linear-gradient(120deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-20deg);animation:shine 3.2s infinite}
@keyframes shine{0%{left:-120%}55%{left:140%}100%{left:140%}}

/* —— Headings —— */
.ds-kicker{font-family:var(--font-display);font-size:22px;letter-spacing:3px;color:var(--brand);text-align:center;margin-bottom:6px}
.ds-title{font-family:var(--font-display);font-size:clamp(38px,6vw,68px);color:#111;text-align:center;line-height:.95;max-width:880px;margin:0 auto 18px;letter-spacing:1px}
.ds-lead{font-family:var(--font-ui);text-align:center;color:#333;font-size:18px;max-width:720px;margin:0 auto;font-weight:500}
.ds-lead b{font-weight:700}

/* —— Header —— */
header{position:sticky;top:0;z-index:50;background:var(--cream);border-bottom:1px solid rgba(0,0,0,.06);box-shadow:0 2px 14px rgba(0,0,0,.05)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;max-width:var(--container);margin:0 auto;padding:12px 22px}
.nav .logo{height:34px}
.nav-mid{display:flex;align-items:center;gap:10px;font-family:var(--font-ui);font-weight:500;font-size:15px;color:#222;margin-left:auto;margin-right:18px}
.nav-mid .dot{width:10px;height:10px;border-radius:50%;background:#ff3b30;animation:blink 1.3s infinite}
@keyframes blink{50%{opacity:.3}}
.nav .btn{padding:11px 22px}
.nav .btn .main{font-size:17px}

/* —— Hero —— */
.hero{background:var(--cream);padding:26px 0 0;text-align:center;overflow:hidden}
.present{font-family:var(--font-ui);font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--brand);font-size:13px;margin-bottom:8px}
.wordmark{font-family:var(--font-display);font-size:clamp(44px,7.2vw,84px);line-height:.9;color:#111;letter-spacing:1px}
.wordmark .for{font-family:var(--font-accent);font-style:italic;font-size:.42em;color:var(--brand);position:relative;top:-.18em;margin:0 .06em;font-weight:400}
.wordmark .live{position:relative;color:var(--brand);display:inline-block}
.wordmark .live .brush{position:absolute;top:50%;left:50%;transform:translate(-50%,-46%);width:118%;height:auto;z-index:-1}
.hero .sub{font-family:var(--font-ui);font-weight:600;font-size:clamp(16px,2vw,21px);color:#1a1a1a;max-width:660px;margin:12px auto 6px;line-height:1.4}
.hero .sub b{font-weight:800}
.hero .date{font-family:var(--font-display);font-size:clamp(18px,2.2vw,24px);letter-spacing:1px;color:#111;margin-bottom:12px}
.hero-group{max-width:760px;margin:0 auto;position:relative;z-index:1}

/* —— Hero 2-column (split) layout — like the Meant-for-More reference —— */
.hero .ds-wrap{max-width:1160px}            /* hero breathes a bit wider than body sections, like the MFM reference */
.hero-cols{display:grid;grid-template-columns:1fr 1.06fr;gap:62px;align-items:stretch;max-width:1100px;margin:32px auto 0;text-align:left}
.hero-media{position:relative;border-radius:18px;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.18);min-height:460px;background:#22303a}
.hero-img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.18),transparent 28%,transparent 70%,rgba(0,0,0,.45));pointer-events:none}
.hero-media-top,.hero-media-bot{position:absolute;left:18px;z-index:2;font-family:var(--font-display);letter-spacing:2px;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.55)}
.hero-media-top{top:15px;font-size:16px;opacity:.92;text-transform:uppercase}
.hero-media-bot{bottom:14px;font-size:22px;text-transform:uppercase}
.hero-cols .formcard{margin:0;border-radius:var(--radius-lg);box-shadow:0 24px 60px rgba(0,0,0,.10);align-self:start}

/* —— Registration form card —— */
.formcard{background:#fff;max-width:880px;margin:-30px auto 0;border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:0 -10px 40px rgba(0,0,0,.08);padding:24px 26px 28px;text-align:center;position:relative;z-index:2}
.demand{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-weight:600;font-size:13px;color:#222;margin-bottom:6px}
.demand .pill{background:#fff;border:1.5px solid #ff3b30;color:#ff3b30;font-weight:800;font-size:12px;letter-spacing:.5px;padding:3px 12px;border-radius:50px;text-transform:uppercase}
.formcard .big{font-family:var(--font-display);font-size:clamp(32px,4vw,46px);color:#111;line-height:.95;letter-spacing:1px}
.formcard .big u{text-decoration-thickness:4px;text-underline-offset:6px}
.formcard .join{font-family:var(--font-ui);font-weight:700;font-size:clamp(13px,1.5vw,15px);color:#1a1a1a;margin:6px 0 16px}
.countdown{display:flex;justify-content:center;gap:10px;margin:0 auto 18px}
.cd{min-width:66px}
.cd .num{font-family:var(--font-display);font-size:clamp(30px,3.4vw,42px);color:#111;line-height:1}
.cd .lbl{font-family:var(--font-ui);font-weight:600;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:#888}
form.reg{max-width:560px;margin:0 auto}
.field{position:relative;margin-bottom:9px}
.field input{width:100%;padding:12px 44px 12px 15px;border:1.5px solid #d9d9d9;border-radius:var(--radius);font-size:15px;font-family:var(--font-ui)}
.field input:focus{outline:none;border-color:var(--brand)}
.field .ic{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:#bbb;font-size:18px}
form.reg .btn{width:100%;margin-top:6px}
.formcard > .btn{width:100%;margin-top:8px}   /* chế độ chỉ-nút (không ô nhập) */
.consent{font-size:10.5px;color:#999;line-height:1.45;margin-top:11px;max-width:520px;margin-left:auto;margin-right:auto}
.consent a{color:#666}

/* —— Marquee stripe —— */
.marquee{background:var(--brand);color:#fff;font-family:var(--font-display);font-size:20px;letter-spacing:2px;padding:14px 0;overflow:hidden;white-space:nowrap}
.marquee .track{display:inline-block;animation:scroll 22s linear infinite}
.marquee span{margin:0 26px}
.marquee .dot{color:rgba(255,255,255,.7)}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* —— Prose / pattern block —— */
.prose .body{max-width:680px;margin:26px auto 0;text-align:center;font-family:var(--font-ui);color:#333;font-size:17px}
.prose .body p{margin-bottom:18px}
.prose .body .lg{font-size:23px}
.prose.pattern{background:#fff url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="80" height="80" fill="none" stroke="%23000" stroke-opacity="0.05" stroke-width="3"><path d="M10 10h60v60M10 30h40v30M30 10v30h20"/></svg>');background-size:140px}

/* —— Torn edges (decorative section separators) —— */
.edge{height:26px;background-size:cover;background-position:center;background-repeat:no-repeat;line-height:0}
.edge-soft-top{background:url('./assets/edge-green.png')}
.edge-soft-bot{background:url('./assets/edge-green.png');transform:scaleY(-1)}
.edge-dark-top{background:url('./assets/edge-dark.png')}
.edge-dark-bot{background:url('./assets/edge-dark.png');transform:scaleY(-1)}

/* —— Quote band (secondary accent) —— */
.quote{background:var(--accent-soft);color:#fff;text-align:center;padding:64px 0;position:relative;overflow:hidden}
.quote .qm{font-family:Georgia,serif;font-size:240px;line-height:.4;color:rgba(255,255,255,.18);position:absolute;left:2%;top:34%}
.quote h2{font-family:var(--font-display);font-size:clamp(42px,7vw,78px);line-height:.96;color:#fff;max-width:820px;margin:0 auto;letter-spacing:1px;position:relative}
.quote h2 .dim{color:rgba(255,255,255,.55)}
.quote .caption{font-family:var(--font-ui);font-weight:600;font-size:20px;color:rgba(255,255,255,.92);margin:22px 0 28px;position:relative}

/* —— Card grid (numbered, in white container) —— */
.cards-box{background:#fff;border-radius:14px;box-shadow:var(--shadow-card);padding:44px 38px;margin-top:42px;display:grid;grid-template-columns:repeat(3,1fr);gap:34px}
.card .n{font-family:var(--font-display);font-size:64px;color:var(--accent-soft);line-height:1}
.card h3{font-family:var(--font-display);font-size:27px;color:#111;letter-spacing:.5px;margin:10px 0 12px;line-height:1}
.card p{font-family:var(--font-ui);font-size:15px;color:#444}
.card p b{font-weight:700;color:#111}
.afternote{text-align:center;margin-top:54px}
.afternote h3{font-family:var(--font-display);font-size:clamp(26px,4vw,40px);color:#111;letter-spacing:.5px}
.afternote p{font-family:var(--font-ui);color:#444;max-width:620px;margin:10px auto 0}
.afternote .em{font-weight:700;color:#111;margin-top:8px}

/* —— CTA band (deep accent + image overlay) —— */
.ctaband{background:var(--accent-deep);color:#fff;text-align:center;padding:78px 0;position:relative;background-size:auto 120%;background-position:center;background-repeat:no-repeat}
.ctaband .ds-kicker{color:var(--brand)}
.ctaband h2{font-family:var(--font-display);font-size:clamp(46px,8vw,90px);line-height:.92;letter-spacing:1px;color:#f3efe8;margin-bottom:14px}
.ctaband p{font-family:var(--font-ui);font-size:18px;color:#cfd8d4;margin-bottom:30px}

/* —— Split (image stack + text + chips) —— */
.split{display:grid;grid-template-columns:1fr 1.05fr;gap:50px;align-items:center}
.split.flip{grid-template-columns:1.05fr 1fr}
.split .stack{display:flex;flex-direction:column;gap:18px}
.split .stack img{border-radius:10px;width:100%;box-shadow:0 10px 26px rgba(0,0,0,.12)}
/* stat cards (photo + big number overlay) */
.statcard{position:relative;border-radius:12px;overflow:hidden;min-height:150px;background-size:cover;background-position:center;box-shadow:0 12px 30px rgba(0,0,0,.18)}
.statcard::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(15,30,30,.82),rgba(15,30,30,.35))}
.statcard-in{position:relative;z-index:2;padding:24px 26px}
.statcard .statnum{font-family:var(--font-display);font-size:clamp(40px,5vw,58px);line-height:1;color:var(--brand);letter-spacing:1px;text-transform:uppercase}
.statcard .statlbl{font-family:var(--font-ui);font-weight:500;color:#fff;font-size:14px;margin-top:6px;max-width:62%;line-height:1.3}
.split .txt h2{font-family:var(--font-display);font-size:clamp(40px,5.5vw,66px);color:#111;line-height:.95;margin-bottom:18px;letter-spacing:1px}
.split .txt p{font-family:var(--font-ui);font-size:16px;color:#3a3a3a;margin-bottom:16px}
.split .txt p b{font-weight:700;color:#111}
.chips{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.chip{background:#fff;border:1px solid var(--line);border-radius:100px;padding:8px 20px;font-family:var(--font-ui);font-size:14px;color:#444;font-weight:500}
.chip b{color:var(--brand);font-weight:700}

/* —— Numbered grid (2-col, light band) —— */
.band-gray{background:var(--gray-band)}
.grid-cards{display:grid;grid-template-columns:1fr 1fr;background:#fff;border-radius:var(--radius);overflow:hidden;margin-top:42px;box-shadow:0 16px 40px rgba(0,0,0,.08)}
.gc{padding:36px 38px;border-right:1px solid #eee;border-bottom:1px solid #eee}
.gc .n{font-family:var(--font-display);font-size:22px;color:var(--brand);letter-spacing:1px}
.gc h3{font-family:var(--font-display);font-size:28px;color:#111;line-height:1;margin:6px 0 12px;letter-spacing:.5px}
.gc p{font-family:var(--font-ui);font-size:15px;color:#444}
.grid-foot{text-align:center;font-family:var(--font-display);font-size:clamp(30px,5vw,48px);color:#111;margin-top:42px;letter-spacing:.5px}

/* —— Numbered list (dark, big numbers) —— */
.dark-list{background:var(--ink-bg);color:#fff;padding:80px 0}
.dark-list .ds-kicker{color:var(--brand)}
.dark-list .ds-title{color:#f3efe8}
.listwrap{max-width:760px;margin:40px auto 0}
.li-row{display:grid;grid-template-columns:auto 1fr;gap:24px;padding:26px 0;border-top:1px solid rgba(255,255,255,.12);align-items:start}
.li-row:last-of-type{border-bottom:1px solid rgba(255,255,255,.12)}
.li-row .num{font-family:var(--font-display);font-size:54px;color:var(--brand);line-height:.9;min-width:54px}
.li-row h3{font-family:var(--font-display);font-size:26px;letter-spacing:.5px;color:#fff;margin-bottom:6px}
.li-row p{font-family:var(--font-ui);font-size:15px;color:#bfbfbf}
.btnwrap{text-align:center;margin-top:44px}

/* —— Mentors —— */
.mgrid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:40px}
.mcard{background:var(--ink-bg);border-radius:10px;overflow:hidden;color:#fff}
.mcard img{width:100%;height:340px;object-fit:cover;object-position:top}
.mcard .b{padding:24px 26px}
.mcard h3{font-family:var(--font-display);font-size:30px;letter-spacing:.5px}
.mcard .role{font-family:var(--font-ui);font-weight:700;font-size:14px;color:#fff;margin-bottom:12px}
.mcard p{font-family:var(--font-ui);font-size:14px;color:#c4c4c4}
.mtext{max-width:760px;margin:36px auto 0;text-align:center;font-family:var(--font-ui);font-size:17px;color:#333}
.mtext b{font-weight:700;color:#111}
.alongside{text-align:center;font-family:var(--font-ui);font-weight:600;color:#444;margin:30px 0 22px}
.guests{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.guests img{border-radius:12px;width:100%;box-shadow:0 8px 22px rgba(0,0,0,.12)}
.pathbanner{background:var(--ink-bg);color:#fff;text-align:center;font-family:var(--font-display);font-size:clamp(24px,4vw,40px);letter-spacing:1px;padding:26px 16px}

/* —— Feature/dark split —— */
.feature{background:var(--ink-bg);color:#fff;padding:80px 0}
.feature .grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:stretch}
.feature .grid img{border-radius:12px;width:100%;height:100%;object-fit:cover;min-height:360px}
.feature-light{background:var(--cream)}
.feature-light h2{color:#111}
.feature-light p{color:#3a3a3a}
.feature-light .q{color:#1a1a1a}
.feature h2{font-family:var(--font-display);font-size:clamp(34px,5vw,56px);line-height:.96;color:#f3efe8;margin-bottom:20px;letter-spacing:.5px}
.feature p{font-family:var(--font-ui);font-size:16px;color:#c4c4c4;margin-bottom:16px}
.feature p b{color:#fff;font-weight:700}
.feature .q{font-family:var(--font-ui);font-style:italic;font-weight:600;font-size:20px;color:#fff;margin:8px 0 18px;border-left:3px solid var(--brand);padding-left:18px}

/* —— Value grid + pricing —— */
.value{background:var(--ink-bg)}
.value .vwrap{padding:70px 22px}
.value-inner{background:#fff;border-radius:26px;max-width:1000px;margin:0 auto;padding:60px 44px;box-shadow:0 30px 80px rgba(0,0,0,.4)}
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);margin-top:40px;border:1px solid #eee;border-radius:10px;overflow:hidden}
.vc{padding:30px 26px;border-right:1px solid #eee;border-bottom:1px solid #eee}
.vc h3{font-family:var(--font-display);font-size:24px;color:#111;line-height:1;margin-bottom:12px;letter-spacing:.5px}
.vc p{font-family:var(--font-ui);font-size:14px;color:#555}
.vc.total{background:var(--accent-soft);color:#fff;display:flex;flex-direction:column;justify-content:center}
.vc.total .t{font-family:var(--font-display);font-size:22px;letter-spacing:1px;line-height:1}
.vc.total .price{font-family:var(--font-display);font-size:64px;line-height:.9;margin:6px 0}
.vc.total .free{font-family:var(--font-ui);font-size:14px;opacity:.9}
.daterow{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid #eee;border-top:none;border-radius:0 0 10px 10px;overflow:hidden}
.dr{padding:24px;text-align:center;border-right:1px solid #eee}
.dr .big{font-family:var(--font-display);font-size:32px;color:var(--brand);line-height:1}
.dr .big.dark{color:#111}
.dr .sm{font-family:var(--font-ui);font-size:12px;letter-spacing:1px;color:#888;text-transform:uppercase}

/* —— Big statement —— */
.statement{background:var(--cream);text-align:center}
.statement .big{font-family:var(--font-display);font-size:clamp(56px,10vw,110px);color:var(--brand);line-height:.9;margin:26px 0;letter-spacing:1px}
.statement .body{max-width:680px;margin:0 auto;font-family:var(--font-ui);color:#333;font-size:17px}
.statement .body p{margin-bottom:16px}
.statement .body b{font-weight:700;color:#111}

/* —— Final CTA —— */
.final{background:var(--cream);text-align:center;padding:30px 0 78px}
.final h2{font-family:var(--font-display);font-size:clamp(34px,5.5vw,62px);color:#111;line-height:.96;max-width:900px;margin:0 auto 18px;letter-spacing:1px}
.infochip{display:inline-block;background:#fff;border:1px solid var(--line);border-radius:100px;padding:10px 26px;font-family:var(--font-display);font-size:19px;letter-spacing:2px;color:#333;margin-bottom:34px}
.infochip .dot{color:var(--brand);margin:0 10px}

/* —— Footer —— */
footer{background:var(--ink-bg);color:#9a9a9a;padding:54px 0 36px}
.foot{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
footer .flogo{font-family:var(--font-display);font-size:54px;line-height:.82;color:#fff}
footer .flogo .for{font-family:var(--font-accent);font-style:italic;font-size:.5em;color:var(--brand)}
footer .flogo .live{color:var(--brand)}
footer h4{font-family:var(--font-ui);font-weight:700;color:#fff;font-size:15px;margin-bottom:14px}
footer ul{list-style:none}
footer li{margin-bottom:9px}
footer a{color:#a9a9a9;text-decoration:none;font-family:var(--font-ui);font-size:14px}
footer a:hover{color:#fff}
.earn{margin-top:34px;padding-top:22px;border-top:1px solid rgba(255,255,255,.1);font-family:var(--font-ui);font-size:12px;color:#7a7a7a;font-style:italic}
.earn b{font-style:normal;color:#9a9a9a}
.copy{text-align:center;font-family:var(--font-ui);font-size:12px;color:#7a7a7a;margin-top:18px}

/* —— Form labels + validation states —— */
.field label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}  /* sr-only: kept for screen readers, hidden visually (compact like MFM) */
.form-msg{margin-top:14px;font-family:var(--font-ui);font-size:14px;font-weight:600;min-height:1px}
.form-msg.ok{color:var(--green-dark,#15824a);background:#eafaf0;border-radius:8px;padding:12px}
.form-msg.err{color:#c0392b}
.field input:invalid:not(:placeholder-shown){border-color:#e07a6b}
.btn.loading{opacity:.7;pointer-events:none}
.btn.loading .main::after{content:" …"}

/* —— Logos / trust strip —— */
.logos-strip{background:var(--cream-2);padding:30px 0;border-top:1px solid rgba(0,0,0,.05);border-bottom:1px solid rgba(0,0,0,.05)}
.logos-label{text-align:center;font-family:var(--font-ui);font-weight:700;letter-spacing:1.5px;text-transform:uppercase;font-size:12px;color:#8a8a86;margin-bottom:16px}
.logos-row{display:flex;flex-wrap:wrap;gap:18px 38px;align-items:center;justify-content:center}
.logos-row .logo-item{height:38px;width:auto;opacity:.8;filter:grayscale(1)}
.logos-row .logo-text{font-family:var(--font-display);font-size:24px;letter-spacing:1px;color:#9a9a96;text-transform:uppercase}

/* —— Testimonials —— */
.testimonials .tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:42px}
.tcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px 26px;box-shadow:var(--shadow-card);display:flex;flex-direction:column}
.tcard .stars{color:#f5a623;font-size:17px;letter-spacing:2px;margin-bottom:14px}
.tcard blockquote{font-family:var(--font-ui);font-size:15px;color:#3a3a3a;line-height:1.7;flex:1;margin:0 0 20px}
.tcard figcaption{display:flex;align-items:center;gap:12px}
.tavatar{width:46px;height:46px;border-radius:50%;object-fit:cover;flex:none}
.tavatar.tinitial{display:grid;place-items:center;background:linear-gradient(135deg,var(--brand),var(--accent-soft));color:#fff;font-family:var(--font-display);font-size:22px}
.tmeta{display:flex;flex-direction:column;line-height:1.3}
.tmeta b{font-family:var(--font-ui);font-weight:700;color:#111;font-size:15px}
.tmeta i{font-style:normal;font-size:13px;color:#888}
/* testimonial video grid (YouTube thumbnails → play) */
.tvideo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:38px}
.tvideo{position:relative;display:block;width:100%;aspect-ratio:16/9;border:none;padding:0;border-radius:12px;overflow:hidden;cursor:pointer;background:#22303a center/cover no-repeat;box-shadow:0 10px 26px rgba(0,0,0,.14)}
iframe.tvideo{aspect-ratio:16/9}
.tvideo .tplay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:56px;height:56px;border-radius:50%;background:rgba(0,0,0,.55);transition:background .15s,transform .15s}
.tvideo:hover .tplay{background:var(--brand);transform:translate(-50%,-50%) scale(1.08)}
.tvideo .tplay::after{content:"";position:absolute;top:50%;left:53%;transform:translate(-50%,-50%);border-style:solid;border-width:9px 0 9px 15px;border-color:transparent transparent transparent #fff}
/* testimonial image grid (Facebook recap screenshots) */
.timg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:22px;align-items:start}
.timg-grid img{width:100%;border-radius:12px;box-shadow:0 10px 26px rgba(0,0,0,.12)}

/* —— FAQ accordion —— */
.faq .faq-list{max-width:820px;margin:40px auto 0}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:20px 22px;display:flex;align-items:center;justify-content:space-between;gap:16px;
       font-family:var(--font-ui);font-weight:600;font-size:16px;color:#1a1a1a}
.faq-ic{flex:none;width:22px;height:22px;position:relative}
.faq-ic::before,.faq-ic::after{content:"";position:absolute;background:var(--brand);border-radius:2px;transition:transform .25s}
.faq-ic::before{top:10px;left:2px;right:2px;height:3px}
.faq-ic::after{left:10px;top:2px;bottom:2px;width:3px}
.faq-item.open .faq-ic::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-item.open .faq-a{max-height:420px}
.faq-a-in{padding:0 22px 20px;font-family:var(--font-ui);font-size:15px;color:#555;line-height:1.7}

/* —— Sticky CTA bar —— */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:60;background:var(--ink-bg);
            transform:translateY(110%);transition:transform .3s ease;box-shadow:0 -8px 28px rgba(0,0,0,.28)}
.sticky-cta.show{transform:translateY(0)}
.sticky-in{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 22px}
.sticky-logo{font-family:var(--font-display);font-size:24px;line-height:.9;color:#fff;letter-spacing:1px}
.sticky-logo .for{font-family:var(--font-accent);font-style:italic;font-size:.6em;color:var(--brand)}
.sticky-logo .live{color:var(--brand)}
.sticky-cta .btn{padding:12px 26px}
.sticky-cta .btn .main{font-size:18px}
.sticky-cta .btn .sub{display:none}

/* —— Responsive —— */
@media(max-width:820px){
  .cards-box,.vgrid,.daterow,.guests{grid-template-columns:1fr}
  .split,.split.flip,.grid-cards,.mgrid,.feature .grid,.foot,.testimonials .tgrid,.hero-cols,.timg-grid{grid-template-columns:1fr}
  .tvideo-grid{grid-template-columns:1fr 1fr}
  .hero-media{min-height:300px}
  .nav-mid{display:none}
  .vc,.dr,.gc{border-right:none}
  .quote .qm{display:none}
  .countdown{gap:6px}
  .cd{min-width:64px}
  .sticky-logo{display:none}                 /* mobile: button-only sticky bar, more compact */
  .sticky-in{justify-content:center;padding:10px 14px}
  .sticky-cta .btn{width:100%}
  body{padding-bottom:78px}                  /* clear the sticky bar (≈60px) */
}
