/* ============================================================
   YẾN NHI & HỮU PHÚC — Wedding site shared design system
   ============================================================ */
:root{
  --ivory:#FBF8F3; --cream:#F3ECE1; --wine:#7B2D3B; --wine-dark:#5E1F2B;
  --gold:#C9A24B; --gold-soft:#E4CE97; --ink:#2A2622; --muted:#7A7066;
  --line:#E6DCCC; --white:#FFFFFF; --sage:#8A9A7B;
  --navy:#26384B; --navy-soft:#3C5168;
  --shadow:0 18px 50px -22px rgba(94,31,43,.35); --radius:18px; --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Be Vietnam Pro',system-ui,sans-serif;color:var(--ink);background:var(--ivory);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,.serif{font-family:'Playfair Display',serif;font-weight:600;line-height:1.18}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.accent{color:var(--wine)}
.script{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--gold);font-weight:500}
.eyebrow{font-size:13px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:14px}
.section{padding:96px 0}
.section-head{text-align:center;max-width:720px;margin:0 auto 56px}
.section-head h2{font-size:clamp(28px,4vw,44px);margin-bottom:14px}
.section-head p{color:var(--muted)}
.divider{width:64px;height:2px;background:var(--gold);margin:18px auto;position:relative}
.divider::before,.divider::after{content:"";position:absolute;top:50%;width:6px;height:6px;border-radius:50%;background:var(--gold);transform:translateY(-50%)}
.divider::before{left:-14px}.divider::after{right:-14px}

/* ---------- NAV ---------- */
header.nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(251,248,243,.82);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:.3s}
header.nav.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 24px -18px rgba(0,0,0,.4)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:10px;font-family:'Playfair Display',serif;font-weight:700;font-size:20px}
.brand .heart{color:var(--wine)}
.crumb{font-size:13px;color:var(--muted);font-weight:500}
.crumb a{color:var(--wine)}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--ink);position:relative;padding:4px 0;transition:.2s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--gold);transition:.25s}
.nav-links a:hover{color:var(--wine)}
.nav-links a:hover::after{width:100%}
.btn{display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;padding:13px 26px;border-radius:40px;font-family:inherit;font-size:14.5px;font-weight:600;transition:.25s;letter-spacing:.01em}
.btn-primary{background:var(--wine);color:#fff;box-shadow:0 10px 24px -12px var(--wine)}
.btn-primary:hover{background:var(--wine-dark);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--wine);border:1.5px solid var(--gold-soft)}
.btn-ghost:hover{background:var(--cream);border-color:var(--gold)}
.nav-toggle{display:none;background:none;border:none;font-size:26px;color:var(--wine);cursor:pointer}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:120px 24px 80px;overflow:hidden;background:radial-gradient(circle at 18% 22%, rgba(201,162,75,.14), transparent 42%),radial-gradient(circle at 82% 78%, rgba(123,45,59,.12), transparent 45%),linear-gradient(180deg,var(--ivory),var(--cream))}
.hero .ring{position:absolute;border-radius:50%;border:1px solid var(--gold-soft);opacity:.5}
.hero .ring.r1{width:520px;height:520px;top:-160px;right:-140px}
.hero .ring.r2{width:360px;height:360px;bottom:-120px;left:-120px;border-color:var(--wine);opacity:.18}
.hero-content{position:relative;z-index:2;max-width:860px}
.hero .save{font-size:14px;letter-spacing:.34em;text-transform:uppercase;color:var(--wine);font-weight:600;margin-bottom:22px}
.hero h1{font-size:clamp(46px,9vw,104px);line-height:1.02;color:var(--ink);font-weight:700}
.hero h1 .amp{display:block;font-style:italic;font-size:.42em;color:var(--gold);font-weight:500;margin:6px 0}
.hero .tag{margin:26px auto 0;max-width:560px;color:var(--muted);font-size:17px}
.hero .datechip{display:inline-flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px;margin-top:30px;padding:14px 28px;background:rgba(255,255,255,.7);border:1px solid var(--line);border-radius:50px;box-shadow:var(--shadow);font-weight:600;color:var(--wine)}
.hero .datechip span{display:flex;align-items:center;gap:8px}
.hero .datechip .dot{width:5px;height:5px;border-radius:50%;background:var(--gold)}
.hero-cta{margin-top:34px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- COUNTDOWN ---------- */
.countdown{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:40px}
.cd-box{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px 8px;min-width:96px;box-shadow:0 14px 30px -22px rgba(94,31,43,.4)}
.cd-box .num{font-family:'Playfair Display',serif;font-size:40px;font-weight:700;color:var(--wine);line-height:1}
.cd-box .lbl{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:8px}

/* ---------- STATS ---------- */
.stats{background:var(--wine);color:#fff}
.stats.navy{background:var(--navy)}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:54px 0}
.stat{text-align:center}
.stat .n{font-family:'Playfair Display',serif;font-size:clamp(34px,5vw,48px);font-weight:700;color:var(--gold-soft)}
.stat .t{font-size:14px;letter-spacing:.08em;opacity:.9;margin-top:4px}
.stat + .stat{border-left:1px solid rgba(255,255,255,.16)}

/* ---------- STORY ---------- */
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.story-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:40px;box-shadow:var(--shadow);position:relative}
.story-card::before{content:"\201C";position:absolute;top:-22px;left:30px;font-family:'Playfair Display',serif;font-size:90px;color:var(--gold-soft);line-height:1}
.story-card p{color:var(--muted);font-size:16.5px;margin-top:6px}
.story-card .sign{margin-top:20px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:24px;color:var(--wine)}
.couple{display:flex;flex-direction:column;gap:22px}
.person{display:flex;gap:18px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:0 12px 30px -24px rgba(0,0,0,.5)}
.person .av{flex:0 0 64px;height:64px;border-radius:50%;display:grid;place-items:center;font-family:'Playfair Display',serif;font-size:24px;font-weight:700;color:#fff}
.person.bride .av{background:linear-gradient(135deg,var(--wine),var(--wine-dark))}
.person.groom .av{background:linear-gradient(135deg,var(--gold),#b08a30)}
.person h4{font-family:'Playfair Display',serif;font-size:22px}
.person .role{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:600}
.person p{font-size:14.5px;color:var(--muted);margin-top:6px}
.person .parents{font-size:13.5px;color:var(--ink);margin-top:8px;line-height:1.5}
.person .parents b{font-weight:600;color:var(--wine)}

/* ---------- EVENTS ---------- */
.events{background:var(--cream)}
.ev-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.ev-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:.3s}
.ev-card:hover{transform:translateY(-6px)}
.ev-top{padding:30px 32px;color:#fff;position:relative}
.ev-card.giatien .ev-top{background:linear-gradient(135deg,var(--wine),var(--wine-dark))}
.ev-card.tiec .ev-top{background:linear-gradient(135deg,#9a7a2e,var(--gold))}
.ev-card.navy .ev-top{background:linear-gradient(135deg,var(--navy),var(--navy-soft))}
.ev-top .kind{font-size:12.5px;letter-spacing:.2em;text-transform:uppercase;opacity:.85;font-weight:600}
.ev-top h3{font-size:28px;margin-top:8px}
.ev-top .when{margin-top:10px;font-size:15px;opacity:.95;display:flex;align-items:center;gap:8px}
.ev-body{padding:26px 32px 30px;display:flex;flex-direction:column;gap:16px;flex:1}
.ev-row{display:flex;gap:12px;align-items:flex-start;font-size:15px}
.ev-row .ico{flex:0 0 22px;color:var(--wine);font-size:17px;margin-top:1px}
.ev-row b{font-weight:600}
.ev-row span{color:var(--muted)}
.ev-body .btn{margin-top:auto;align-self:flex-start}

/* ---------- TIMELINE ---------- */
.tl-tabs{display:flex;gap:10px;justify-content:center;margin-bottom:46px;flex-wrap:wrap}
.tl-tab{padding:12px 26px;border-radius:40px;border:1.5px solid var(--line);background:#fff;cursor:pointer;font-family:inherit;font-weight:600;font-size:15px;color:var(--muted);transition:.25s}
.tl-tab.active{background:var(--wine);color:#fff;border-color:var(--wine)}
.tl-panel{display:none}
.tl-panel.active{display:block;animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.tl-loc{text-align:center;font-family:'Playfair Display',serif;font-size:20px;color:var(--wine);margin:8px 0 30px;padding:10px;background:var(--cream);border-radius:12px}
.timeline{position:relative;max-width:860px;margin:0 auto;padding-left:8px}
.timeline::before{content:"";position:absolute;left:14px;top:6px;bottom:6px;width:2px;background:linear-gradient(var(--gold-soft),var(--line))}
.tl-item{position:relative;padding:0 0 30px 52px}
.tl-item::before{content:"";position:absolute;left:7px;top:5px;width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid var(--gold);box-shadow:0 0 0 4px var(--ivory);z-index:1}
.tl-item.key::before{background:var(--wine);border-color:var(--wine)}
.tl-time{font-family:'Playfair Display',serif;font-weight:700;color:var(--wine);font-size:16px}
.tl-item h4{font-size:17px;margin:2px 0 4px;font-family:'Be Vietnam Pro';font-weight:600}
.tl-item p{color:var(--muted);font-size:14.5px}
.tl-item .dur{display:inline-block;font-size:12px;color:var(--gold);font-weight:600;letter-spacing:.06em;margin-left:8px}
.tl-item .who{display:inline-flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.tl-item .who .chip{font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:20px;background:var(--cream);color:var(--wine);border:1px solid var(--line)}
.tl-item .note{margin-top:8px;font-size:13.5px;color:var(--navy-soft);background:rgba(38,56,75,.06);border-left:3px solid var(--gold);padding:8px 12px;border-radius:0 8px 8px 0}
.tl-item .note b{color:var(--wine)}
.phase-label{max-width:860px;margin:8px auto 18px;display:flex;align-items:center;gap:12px;font-family:'Playfair Display',serif;font-weight:700;color:var(--navy);font-size:19px}
.phase-label .pl-ic{flex:0 0 36px;height:36px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-size:16px}

/* ---------- ROLE CARDS (phân công theo người) ---------- */
.roles{background:var(--cream)}
.role-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.role-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:0 14px 34px -28px rgba(0,0,0,.5);border-top:4px solid var(--gold);transition:.25s}
.role-card:hover{transform:translateY(-5px)}
.role-card .rc-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.role-card .rc-av{flex:0 0 50px;height:50px;border-radius:14px;display:grid;place-items:center;font-size:24px;background:var(--cream)}
.role-card h4{font-family:'Playfair Display',serif;font-size:20px}
.role-card .rc-sub{font-size:12.5px;color:var(--gold);font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.role-card ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.role-card li{position:relative;padding-left:22px;font-size:14.5px;color:var(--ink)}
.role-card li::before{content:"\2713";position:absolute;left:0;top:1px;color:var(--sage);font-weight:700}

/* ---------- GIFTS ---------- */
.gifts{background:var(--cream)}
.gift-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.gift{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px 18px;text-align:center;transition:.25s;box-shadow:0 12px 28px -24px rgba(0,0,0,.5)}
.gift:hover{transform:translateY(-5px);border-color:var(--gold-soft)}
.gift .ico{font-size:34px;margin-bottom:10px}
.gift .no{font-size:12px;letter-spacing:.14em;color:var(--gold);font-weight:700}
.gift h4{font-family:'Be Vietnam Pro';font-weight:600;font-size:16px;margin-top:4px}
.gift p{font-size:13px;color:var(--muted);margin-top:4px}
.sinhle{margin-top:42px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow)}
.sinhle h3{text-align:center;font-size:24px;margin-bottom:8px}
.sinhle .sub{text-align:center;color:var(--muted);margin-bottom:24px;font-size:15px}
.sinhle-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.sl{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px;border:1px dashed var(--gold-soft);border-radius:14px;text-align:center}
.sl .ico{font-size:26px}
.sl b{font-size:15px}

/* ---------- CHECKLIST ---------- */
.cl-head{display:flex;flex-wrap:wrap;gap:20px;align-items:center;justify-content:space-between;margin-bottom:30px}
.cl-progress{flex:1;min-width:260px}
.cl-progress .bar{height:14px;background:var(--cream);border-radius:20px;overflow:hidden;border:1px solid var(--line)}
.cl-progress .fill{height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--wine));border-radius:20px;transition:width .5s ease}
.cl-progress .meta{display:flex;justify-content:space-between;margin-top:8px;font-size:14px;color:var(--muted)}
.cl-progress .meta b{color:var(--wine)}
.cl-reset{font-size:13px;color:var(--muted);background:none;border:1px solid var(--line);padding:9px 16px;border-radius:30px;cursor:pointer;transition:.2s;font-family:inherit}
.cl-reset:hover{border-color:var(--wine);color:var(--wine)}
.cl-groups{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.cl-group{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:0 14px 34px -28px rgba(0,0,0,.5)}
.cl-group h3{font-size:19px;display:flex;align-items:center;gap:10px;margin-bottom:6px}
.cl-group h3 .pill{font-family:'Be Vietnam Pro';font-size:11px;font-weight:600;letter-spacing:.08em;color:#fff;background:var(--gold);padding:3px 10px;border-radius:20px;text-transform:uppercase}
.cl-group .gsub{font-size:13px;color:var(--muted);margin-bottom:16px}
.cl-list{list-style:none;display:flex;flex-direction:column;gap:4px}
.cl-item{display:flex;align-items:flex-start;gap:12px;padding:10px 8px;border-radius:10px;cursor:pointer;transition:.18s;position:relative}
.cl-item:hover{background:var(--ivory)}
.cl-item input{display:none}
.cl-item .box{flex:0 0 22px;height:22px;border-radius:7px;border:2px solid var(--gold-soft);margin-top:1px;display:grid;place-items:center;transition:.2s;background:#fff}
.cl-item .box::after{content:"\2713";font-size:14px;color:#fff;opacity:0;transform:scale(.4);transition:.2s}
.cl-item.done .box{background:var(--sage);border-color:var(--sage)}
.cl-item.done .box::after{opacity:1;transform:scale(1)}
.cl-item .txt{font-size:15px;transition:.2s}
.cl-item.done .txt{color:var(--muted);text-decoration:line-through}
.cl-item .del{margin-left:auto;border:none;background:none;color:var(--line);font-size:18px;cursor:pointer;opacity:0;transition:.2s;padding:0 4px}
.cl-item:hover .del{opacity:1;color:var(--wine)}
.cl-add{display:flex;gap:8px;margin-top:12px}
.cl-add input{flex:1;border:1px solid var(--line);border-radius:10px;padding:9px 12px;font-family:inherit;font-size:14px;background:var(--ivory)}
.cl-add input:focus{outline:none;border-color:var(--gold)}
.cl-add button{border:none;background:var(--cream);color:var(--wine);border-radius:10px;padding:0 14px;font-size:20px;cursor:pointer;font-weight:600;transition:.2s}
.cl-add button:hover{background:var(--gold-soft)}
.cl-note{margin-top:26px;text-align:center;font-size:14px;color:var(--muted)}
.cl-note b{color:var(--wine)}

/* ---------- RSVP ---------- */
.rsvp{background:linear-gradient(160deg,var(--wine),var(--wine-dark));color:#fff}
.rsvp.navy{background:linear-gradient(160deg,var(--navy),#1b2836)}
.rsvp .section-head h2{color:#fff}
.rsvp .section-head p{color:rgba(255,255,255,.8)}
.rsvp .divider{background:var(--gold-soft)}
.rsvp .divider::before,.rsvp .divider::after{background:var(--gold-soft)}
.rsvp-card{max-width:640px;margin:0 auto;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:var(--radius);padding:36px;backdrop-filter:blur(6px)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13.5px;margin-bottom:7px;color:var(--gold-soft);font-weight:500}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border-radius:12px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);color:#fff;font-family:inherit;font-size:15px}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.5)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.field select option{color:#2A2622}
.rsvp .btn-primary{background:var(--gold);color:var(--wine-dark);width:100%;justify-content:center;margin-top:6px;font-size:16px}
.rsvp .btn-primary:hover{background:var(--gold-soft)}
.rsvp-ok{display:none;text-align:center;padding:20px;background:rgba(255,255,255,.1);border-radius:12px;margin-top:18px}
.rsvp-ok.show{display:block;animation:fade .4s}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);color:rgba(255,255,255,.7);text-align:center;padding:60px 24px 40px}
footer .names{font-family:'Playfair Display',serif;font-size:30px;color:#fff;margin-bottom:8px}
footer .names .amp{color:var(--gold);font-style:italic}
footer .tagf{color:var(--gold-soft);font-style:italic;font-family:'Cormorant Garamond',serif;font-size:20px;margin-bottom:20px}
footer .meta{font-size:13.5px;line-height:2}
footer .planner{margin-top:18px;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.45)}

.reveal{opacity:0;transform:translateY(28px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   LANDING (chọn cổng Nhà Trai / Nhà Gái)
   ============================================================ */
.choose{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 24px;position:relative;overflow:hidden;background:radial-gradient(circle at 20% 20%, rgba(201,162,75,.16), transparent 45%),radial-gradient(circle at 80% 80%, rgba(123,45,59,.14), transparent 48%),linear-gradient(180deg,var(--ivory),var(--cream))}
.choose .save{font-size:13px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:18px}
.choose h1{font-size:clamp(40px,8vw,86px);color:var(--ink);font-weight:700;line-height:1.04}
.choose h1 .amp{font-style:italic;color:var(--gold);font-weight:500}
.choose .when{margin-top:18px;color:var(--wine);font-weight:600;letter-spacing:.04em}
.choose .lead{margin:14px auto 0;max-width:560px;color:var(--muted)}
.doors{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:54px;width:100%;max-width:900px}
.door{position:relative;display:block;padding:46px 34px;border-radius:24px;color:#fff;overflow:hidden;text-align:left;box-shadow:var(--shadow);transition:.35s;border:1px solid rgba(255,255,255,.2)}
.door:hover{transform:translateY(-8px) scale(1.01)}
.door.trai{background:linear-gradient(150deg,var(--navy),#16222f)}
.door.gai{background:linear-gradient(150deg,var(--wine),var(--wine-dark))}
.door .ring{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.18);width:240px;height:240px;top:-90px;right:-70px}
.door .dlabel{font-size:12.5px;letter-spacing:.24em;text-transform:uppercase;opacity:.8;font-weight:600}
.door h3{font-family:'Playfair Display',serif;font-size:34px;margin:6px 0 4px}
.door .who2{font-size:15px;opacity:.92}
.door .dmeta{margin-top:20px;font-size:13.5px;opacity:.85;line-height:1.7}
.door .enter{margin-top:26px;display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:15px;background:rgba(255,255,255,.15);padding:11px 22px;border-radius:40px;transition:.25s}
.door:hover .enter{background:rgba(255,255,255,.28);gap:14px}
.choose .foot{margin-top:46px;font-size:13px;color:var(--muted)}
.choose .foot b{color:var(--wine)}

/* ============================================================
   LIVE DAY DASHBOARD — "Bạn đang ở bước nào?"
   ============================================================ */
.liveday{background:linear-gradient(180deg,var(--navy),#1b2836);color:#fff}
.ld-card{max-width:820px;margin:0 auto;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.ld-top{padding:14px 24px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;border-bottom:1px solid rgba(255,255,255,.12)}
.ld-top .lbl{display:flex;align-items:center;gap:9px;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-soft);font-weight:600}
.ld-top .lbl .live{width:9px;height:9px;border-radius:50%;background:#ff5a5a;box-shadow:0 0 0 0 rgba(255,90,90,.7);animation:pulse 1.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,90,90,.6)}70%{box-shadow:0 0 0 9px rgba(255,90,90,0)}100%{box-shadow:0 0 0 0 rgba(255,90,90,0)}}
.ld-top .prog{font-size:13.5px;color:rgba(255,255,255,.85);font-weight:600}
.ld-now{padding:26px 28px 22px}
.ld-now .ph{display:inline-block;font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--navy);background:var(--gold-soft);padding:4px 12px;border-radius:30px}
.ld-now .tm{font-family:'Playfair Display',serif;font-size:34px;font-weight:700;color:var(--gold-soft);margin-top:14px;line-height:1}
.ld-now .ti{font-size:24px;font-weight:600;margin-top:6px;line-height:1.25}
.ld-now .wh{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}
.ld-now .wh .chip{font-size:12.5px;font-weight:600;padding:4px 12px;border-radius:20px;background:rgba(255,255,255,.14);color:#fff}
.ld-now .nt{margin-top:14px;font-size:14.5px;color:#fff;background:rgba(201,162,75,.18);border-left:3px solid var(--gold);padding:10px 14px;border-radius:0 8px 8px 0}
.ld-next{display:flex;align-items:center;gap:12px;padding:16px 28px;background:rgba(255,255,255,.05);border-top:1px dashed rgba(255,255,255,.18);font-size:15px}
.ld-next .arr{flex:0 0 auto;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-soft);font-weight:700}
.ld-next b{color:#fff;font-weight:600}
.ld-next .nx-tm{color:var(--gold-soft);font-weight:700;font-family:'Playfair Display',serif}
.ld-done-msg{padding:24px 28px;text-align:center;font-size:18px;color:var(--gold-soft);font-family:'Playfair Display',serif}
.ld-ctrl{display:grid;grid-template-columns:auto 1fr auto;gap:10px;padding:16px 24px 22px}
.ld-btn{border:none;cursor:pointer;font-family:inherit;font-weight:600;border-radius:40px;padding:13px 18px;font-size:15px;transition:.2s;display:flex;align-items:center;justify-content:center;gap:7px}
.ld-btn.prev{background:rgba(255,255,255,.12);color:#fff}
.ld-btn.prev:hover{background:rgba(255,255,255,.2)}
.ld-btn.next{background:var(--gold);color:var(--navy);box-shadow:0 10px 22px -12px var(--gold)}
.ld-btn.next:hover{background:var(--gold-soft)}
.ld-btn.clock{background:transparent;color:var(--gold-soft);border:1.5px solid rgba(255,255,255,.22)}
.ld-btn.clock:hover{border-color:var(--gold-soft)}
.ld-btn:disabled{opacity:.4;cursor:not-allowed}
.ld-hint{text-align:center;color:rgba(255,255,255,.7);font-size:13px;margin-top:16px}

/* condensed timeline list (data-driven) */
.steplist{max-width:860px;margin:0 auto}
.step-phase{margin:26px 0 12px;display:flex;align-items:center;gap:12px;font-family:'Playfair Display',serif;font-weight:700;color:var(--navy);font-size:18px}
.step-phase .pn{flex:0 0 32px;height:32px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-size:14px}
.step-row{display:flex;gap:14px;align-items:flex-start;padding:12px 14px;border:1px solid var(--line);border-radius:12px;margin-bottom:8px;background:#fff;cursor:pointer;transition:.18s}
.step-row:hover{border-color:var(--gold-soft);background:var(--ivory)}
.step-row .st-tm{flex:0 0 76px;font-family:'Playfair Display',serif;font-weight:700;color:var(--wine);font-size:15px;padding-top:1px}
.step-row .st-main{flex:1}
.step-row .st-ti{font-size:15.5px;font-weight:600}
.step-row .st-wh{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.step-row .st-wh .chip{font-size:11px;font-weight:600;padding:2px 9px;border-radius:20px;background:var(--cream);color:var(--wine);border:1px solid var(--line)}
.step-row .st-nt{font-size:13px;color:var(--muted);margin-top:5px}
.step-row .st-ic{flex:0 0 26px;height:26px;border-radius:50%;border:2px solid var(--line);display:grid;place-items:center;font-size:13px;color:transparent;transition:.2s;margin-top:1px}
.step-row.done{opacity:.62}
.step-row.done .st-ic{background:var(--sage);border-color:var(--sage);color:#fff}
.step-row.done .st-ti{text-decoration:line-through;color:var(--muted)}
.step-row.cur{border-color:var(--navy);background:#fff;box-shadow:0 0 0 2px var(--navy), 0 14px 30px -20px rgba(38,56,75,.5)}
.step-row.cur .st-ic{border-color:var(--navy);color:var(--navy);font-weight:700}
.step-row.cur .st-ti{color:var(--navy)}

@media(max-width:560px){
  .ld-now .tm{font-size:28px}.ld-now .ti{font-size:20px}
  .ld-ctrl{grid-template-columns:1fr 1fr;gap:8px}
  .ld-btn.clock{grid-column:1 / -1}
  .step-row .st-tm{flex-basis:60px;font-size:13.5px}
}

/* ---------- RESPONSIVE ---------- */
@media(max-width:900px){
  .nav-links{position:fixed;top:72px;right:0;left:0;background:var(--ivory);flex-direction:column;gap:0;padding:10px 0;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:.35s;box-shadow:0 20px 30px -20px rgba(0,0,0,.3)}
  .nav-links.open{transform:none}
  .nav-links a{padding:14px 24px;width:100%}
  .nav-links .btn{margin:10px 24px;justify-content:center}
  .nav-toggle{display:block}
  .story-grid,.ev-grid,.cl-groups,.doors{grid-template-columns:1fr;gap:30px}
  .role-grid{grid-template-columns:1fr 1fr}
  .stats .grid{grid-template-columns:1fr 1fr;gap:30px}
  .stat + .stat{border-left:none}
  .gift-grid{grid-template-columns:1fr 1fr}
  .sinhle-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .section{padding:70px 0}
  .form-row{grid-template-columns:1fr}
  .gift-grid,.sinhle-grid,.role-grid{grid-template-columns:1fr}
  .cd-box{min-width:72px;padding:14px 4px}
  .cd-box .num{font-size:30px}
}
