/* outfit-curator / assets / lookbook.css
   Shared design system for trip-lookbook HTML artifacts.
   Sections: tokens · base · nav · hero · sections · day cards · slot cards · alts ·
             birthday picker · compare · on-trip · footer · modal · day-thumbs · feedback · responsive
*/

:root{
  --mustard:#d4a017; --mustard-dark:#b48512;
  --cream:#faf3e0; --cream-soft:#f5ecd2;
  --terracotta:#c87553; --terracotta-deep:#a85d3e;
  --emerald:#2c6e5c; --emerald-deep:#1f5546;
  --maroon:#7a2d3a; --maroon-deep:#5c1f29;
  --hot-pink:#e91e63; --hot-pink-deep:#b8154d; --pink-soft:#fde7ef;
  --chambray:#9bb5d6; --chambray-deep:#7895bb;
  --gold-metallic:#c9a227;
  --charcoal:#2b2b2b; --ink:#1a1a1a;
  --soft-white:#fafafa; --paper:#fdfaf3;
  --line:rgba(43,43,43,0.12); --line-strong:rgba(43,43,43,0.25);
  --muted:#6b6357;
  --shadow-card:0 4px 14px rgba(43,43,43,0.06),0 1px 3px rgba(43,43,43,0.04);
  --shadow-hover:0 14px 32px rgba(43,43,43,0.12),0 4px 10px rgba(43,43,43,0.06);
  --shadow-hero:0 24px 60px rgba(122,45,58,0.18),0 8px 24px rgba(43,43,43,0.08);
  --shadow-pink:0 14px 36px rgba(233,30,99,0.22),0 4px 14px rgba(184,21,77,0.12);
  --r-sm:6px; --r-md:12px; --r-lg:20px; --r-xl:28px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;font-size:16px;line-height:1.6;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{display:block;max-width:100%}
h1,h2,h3,h4,.display{font-family:'Playfair Display',Georgia,serif;font-weight:700;letter-spacing:-0.01em}
.eyebrow{font-family:'Inter',sans-serif;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.18em;color:var(--terracotta-deep)}

/* NAV */
.nav{position:sticky;top:0;z-index:100;background:rgba(253,250,243,0.94);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:14px 28px;gap:16px}
.nav-brand{font-family:'Playfair Display',serif;font-weight:700;font-size:17px;color:var(--ink);white-space:nowrap;display:flex;align-items:center;gap:10px}
.nav-brand .accent{color:var(--hot-pink-deep);font-style:italic;font-weight:400}
.v2-badge{display:inline-flex;align-items:center;gap:4px;background:linear-gradient(135deg,var(--hot-pink),var(--maroon));color:#fff;font-family:'Inter',sans-serif;font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:0.12em;padding:4px 9px;border-radius:99px;box-shadow:0 2px 8px rgba(233,30,99,0.3)}
.nav-links{display:flex;gap:6px;align-items:center;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.nav-links::-webkit-scrollbar{display:none}
.nav-links a{font-family:'Inter',sans-serif;font-size:13px;font-weight:500;color:var(--charcoal);text-decoration:none;padding:8px 14px;border-radius:99px;white-space:nowrap;transition:background .2s,color .2s}
.nav-links a:hover,.nav-links a.active{background:var(--charcoal);color:#fff}
.nav-links a.v1-link{border:1px solid var(--line-strong);color:var(--muted)}
.nav-links a.v1-link:hover{background:var(--cream-soft);color:var(--charcoal)}

/* HERO */
.hero{padding:80px 28px 64px;text-align:center;background:linear-gradient(180deg,var(--paper) 0%,var(--cream) 100%);position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 0%,rgba(233,30,99,0.10) 0%,transparent 55%),radial-gradient(ellipse at 70% 100%,rgba(212,160,23,0.10) 0%,transparent 55%);pointer-events:none}
.hero-inner{max-width:980px;margin:0 auto;position:relative;z-index:1}
.hero .eyebrow{display:inline-block;margin-bottom:18px;background:#fff;padding:7px 15px;border-radius:99px;box-shadow:var(--shadow-card)}
.hero h1{font-size:clamp(38px,6.6vw,84px);line-height:1.04;margin-bottom:18px;color:var(--ink)}
.hero h1 .display-mustard{color:var(--mustard-dark);font-style:italic}
.hero h1 .display-pink{color:var(--hot-pink-deep);font-style:italic}
.hero-sub{font-size:18px;color:var(--muted);max-width:660px;margin:0 auto 26px;line-height:1.6}
.hero-meta{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-top:22px}
.hero-meta-item{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--charcoal);background:#fff;padding:9px 16px;border-radius:99px;box-shadow:var(--shadow-card)}
.hero-meta-item strong{color:var(--maroon);font-weight:700}

/* SECTION FRAMES */
.section{padding:72px 28px;max-width:1280px;margin:0 auto}
.section-tight{padding:48px 28px;max-width:1280px;margin:0 auto}
.section-header{margin-bottom:36px;text-align:center}
.section-header .eyebrow{margin-bottom:10px}
.section-header h2{font-size:clamp(28px,4vw,44px);line-height:1.15;color:var(--ink);margin-bottom:10px}
.section-header p{font-size:16px;color:var(--muted);max-width:680px;margin:0 auto}

/* V2 CALLOUT */
.v2-callout{max-width:1080px;margin:36px auto 0;background:linear-gradient(135deg,#fff 0%,var(--pink-soft) 100%);border-radius:var(--r-xl);padding:28px 32px;box-shadow:var(--shadow-card);border:1px solid rgba(233,30,99,0.12)}
.v2-callout h3{font-size:20px;color:var(--ink);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.v2-callout h3::before{content:"";width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--hot-pink),var(--maroon));display:inline-block;flex-shrink:0;box-shadow:0 2px 8px rgba(233,30,99,0.3)}
.v2-callout ul{list-style:none;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:10px 24px}
.v2-callout ul li{font-size:14px;color:var(--charcoal);padding-left:22px;position:relative;line-height:1.5}
.v2-callout ul li::before{content:"→";position:absolute;left:0;color:var(--hot-pink);font-weight:700}
.v2-callout ul li strong{color:var(--maroon-deep);font-weight:600}

/* DESIGN THESIS */
.thesis{background:linear-gradient(135deg,var(--cream) 0%,var(--cream-soft) 100%);padding:64px 28px}
.thesis-inner{max-width:880px;margin:0 auto;text-align:center}
.thesis-quote{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(22px,3vw,30px);line-height:1.45;color:var(--maroon-deep);margin:24px 0;position:relative;padding:0 24px}
.thesis-quote::before,.thesis-quote::after{font-size:60px;color:var(--hot-pink);opacity:0.4;line-height:1;position:absolute;font-family:'Playfair Display',serif}
.thesis-quote::before{content:"\201C";left:-12px;top:-8px}
.thesis-quote::after{content:"\201D";right:-12px;bottom:-32px}
.thesis-rules{margin-top:32px;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px}
.thesis-rule{background:#fff;padding:18px 20px;border-radius:var(--r-md);text-align:left;box-shadow:var(--shadow-card)}
.thesis-rule .num{font-family:'Playfair Display',serif;font-size:32px;font-weight:700;color:var(--hot-pink);line-height:1;margin-bottom:6px}
.thesis-rule p{font-size:13px;color:var(--charcoal);line-height:1.5}
.thesis-rule strong{color:var(--ink);font-weight:600}

/* HERO DAYS */
.heroes{background:var(--paper)}
.hero-day{margin-bottom:48px;background:#fff;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-hero)}
.hero-day.p1{border-top:6px solid var(--mustard)}
.hero-day.p2{border-top:6px solid var(--hot-pink)}
.hero-day.p3{border-top:6px solid var(--emerald)}
.hero-day.p4{border-top:6px solid var(--maroon)}
.hero-day-head{display:grid;grid-template-columns:1fr 280px;gap:24px;padding:32px 36px 24px;align-items:start;border-bottom:1px solid var(--line)}
@media (max-width:780px){.hero-day-head{grid-template-columns:1fr;padding:24px}}
.hero-day-head h3{font-size:clamp(24px,3.4vw,34px);line-height:1.15;margin-bottom:8px}
.hero-day-head h3 .day-num{display:inline-block;background:var(--charcoal);color:var(--cream);font-family:'Inter',sans-serif;font-size:12px;font-weight:700;letter-spacing:0.1em;padding:5px 11px;border-radius:6px;vertical-align:middle;margin-right:12px}
.hero-day.p2 .hero-day-head h3 .day-num{background:var(--hot-pink-deep);color:#fff}
.hero-day-head .why{font-size:15px;color:var(--muted);line-height:1.6;margin-top:10px}
.hero-day-head .why strong{color:var(--charcoal)}
.palette{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;align-items:flex-start}
@media (max-width:780px){.palette{justify-content:flex-start}}
.swatch{display:flex;flex-direction:column;align-items:center;gap:5px;min-width:62px}
.swatch-chip{width:48px;height:48px;border-radius:50%;box-shadow:inset 0 2px 6px rgba(0,0,0,0.08),0 2px 8px rgba(0,0,0,0.06);border:2px solid #fff}
.swatch-label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em;text-align:center;line-height:1.2;font-weight:600}
.outfit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:var(--line)}
@media (max-width:780px){.outfit-grid{grid-template-columns:1fr}}
.outfit-slot{background:#fff;padding:24px 22px;display:flex;flex-direction:column;gap:14px}
.outfit-slot h4{font-family:'Inter',sans-serif;font-size:11px;text-transform:uppercase;letter-spacing:0.14em;color:var(--muted);font-weight:700;margin-bottom:2px}
.outfit-slot h4 .person{color:var(--maroon);font-weight:700}
.outfit-slot ul{list-style:none;padding:0;font-size:13.5px;line-height:1.6;color:var(--charcoal)}
.outfit-slot ul li{padding:4px 0;border-bottom:1px dashed var(--line)}
.outfit-slot ul li:last-child{border-bottom:none}
.outfit-slot ul li strong{color:var(--ink);font-weight:600}
.outfit-slot ul li .swap{display:inline-block;font-size:10px;color:var(--hot-pink-deep);font-weight:600;background:var(--pink-soft);padding:2px 7px;border-radius:99px;margin-left:6px;cursor:pointer;border:none}

/* PER-DAY TABLE */
.daytable-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -8px;padding:0 8px}
.daytable{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;background:#fff;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-card);min-width:880px}
.daytable thead th{background:var(--charcoal);color:var(--cream);font-family:'Inter',sans-serif;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:0.1em;padding:14px 12px;text-align:left;position:sticky;top:0}
.daytable td{padding:14px 12px;border-bottom:1px solid var(--line);vertical-align:top;line-height:1.5}
.daytable tr.is-hero td{background:linear-gradient(90deg,rgba(233,30,99,0.05) 0%,rgba(212,160,23,0.04) 100%)}
.daytable tr.is-hero.p1 td{background:rgba(212,160,23,0.08)}
.daytable tr.is-hero.p2 td{background:rgba(233,30,99,0.08)}
.daytable tr.is-hero.p3 td{background:rgba(44,110,92,0.08)}
.daytable tr.is-hero.p4 td{background:rgba(122,45,58,0.08)}
.daytable td.day{font-family:'Playfair Display',serif;font-weight:700;color:var(--ink);font-size:15px}
.daytable td.day .hero-tag{display:block;font-family:'Inter',sans-serif;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--hot-pink-deep);margin-top:2px}
.daytable .person-col{font-size:12.5px;color:var(--charcoal)}
.daytable .kit-col{font-size:12px;color:var(--muted);font-style:italic}

/* ITEM CARDS */
.person-section{margin-top:48px}
.person-section h3{font-size:28px;color:var(--ink);margin-bottom:6px;display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.person-section h3 .count{font-family:'Inter',sans-serif;font-size:13px;font-weight:500;color:var(--muted);text-transform:none;letter-spacing:0}
.person-section .desc{font-size:14px;color:var(--muted);margin-bottom:24px}
.item-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}
.item-card{background:#fff;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-card);display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s;position:relative;cursor:pointer}
.item-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.item-card .imgbox{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--cream-soft)}
.item-card .imgbox img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.item-card:hover .imgbox img{transform:scale(1.04)}
.item-card .imgbox .img-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;text-align:center;padding:20px;font-family:'Playfair Display',serif;font-style:italic;font-size:13px;line-height:1.5}
.item-card .imgbox.no-img{background:linear-gradient(135deg,var(--cream) 0%,var(--cream-soft) 100%)}
.item-card .imgbox.no-img::after{content:attr(data-fallback-text);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:20px;font-family:'Playfair Display',serif;font-style:italic;color:var(--muted);font-size:13px}
.item-card .imgbox .badge{position:absolute;top:10px;left:10px;font-family:'Inter',sans-serif;font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;padding:5px 10px;border-radius:99px;box-shadow:0 2px 6px rgba(0,0,0,0.15);z-index:2}
.item-card .imgbox .badge.new{background:#fff;color:var(--maroon)}
.item-card .imgbox .badge.keep{background:var(--emerald);color:#fff}
.item-card .imgbox .badge.curator-choice{top:auto;bottom:10px;left:10px;background:linear-gradient(135deg,var(--hot-pink),var(--maroon));color:#fff;display:flex;align-items:center;gap:4px}
.item-card .imgbox .badge.curator-choice::before{content:"\2605";font-size:11px}
.item-card .imgbox .badge.urgent{right:10px;left:auto;background:var(--maroon);color:#fff;animation:pulse 2.5s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
.item-card .meta{padding:14px 16px 16px;display:flex;flex-direction:column;gap:4px;flex:1}
.item-card .item-slot{font-family:'Inter',sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--terracotta-deep)}
.item-card .item-name{font-family:'Playfair Display',serif;font-size:15px;font-weight:600;color:var(--ink);line-height:1.3;margin-top:2px}
.item-card .item-brand{font-size:12px;color:var(--muted);font-weight:500}
.item-card .item-color{font-size:11px;color:var(--charcoal);font-style:italic}
.item-card .item-price{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;color:var(--maroon);margin-top:6px}
.item-card .item-buy{display:inline-flex;align-items:center;justify-content:center;gap:6px;margin-top:10px;background:var(--charcoal);color:#fff;text-decoration:none;font-family:'Inter',sans-serif;font-size:12px;font-weight:600;padding:12px 16px;border-radius:8px;min-height:44px;transition:background .2s;text-align:center}
.item-card .item-buy:hover{background:var(--hot-pink-deep)}
.item-card .show-alts{margin-top:8px;background:transparent;border:1px solid var(--line-strong);color:var(--charcoal);font-family:'Inter',sans-serif;font-size:11px;font-weight:600;padding:10px 14px;border-radius:8px;min-height:44px;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:0.06em}
.item-card .show-alts:hover{background:var(--cream-soft);border-color:var(--charcoal)}
.item-card.item-keep{border:2px solid var(--emerald)}
.item-card.item-keep .item-price{color:var(--emerald-deep);font-size:13px;font-style:italic;font-family:'Inter',sans-serif;font-weight:500}
.item-card.item-keep .item-price::before{content:"\2713 "}

.alts-carousel{margin-top:14px;margin-bottom:8px;background:linear-gradient(180deg,var(--cream-soft) 0%,var(--cream) 100%);border-radius:var(--r-md);padding:16px 14px;grid-column:1/-1}
.alts-carousel-label{font-family:'Inter',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--terracotta-deep);margin-bottom:10px;padding:0 4px}
.alts-track{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:4px 4px 8px;scrollbar-width:thin;scrollbar-color:var(--line-strong) transparent}
.alts-track::-webkit-scrollbar{height:6px}
.alts-track::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:99px}
.alts-track .item-card{min-width:200px;width:200px;scroll-snap-align:start;flex-shrink:0}
.alts-track .item-card .meta{padding:10px 12px 12px}
.alts-track .item-card .item-name{font-size:13px}
.alts-track .item-card .item-price{font-size:14px}
.alts-track .item-card .item-buy{font-size:11px;padding:10px 12px}

/* BIRTHDAY GALLERY */
.birthday-section{background:linear-gradient(135deg,var(--pink-soft) 0%,#fff 60%,var(--cream-soft) 100%);padding:72px 28px;position:relative;overflow:hidden}
.birthday-section::before{content:"";position:absolute;top:-100px;right:-100px;width:300px;height:300px;background:radial-gradient(circle,rgba(233,30,99,0.15) 0%,transparent 70%);pointer-events:none}
.birthday-section::after{content:"";position:absolute;bottom:-100px;left:-100px;width:300px;height:300px;background:radial-gradient(circle,rgba(212,160,23,0.12) 0%,transparent 70%);pointer-events:none}
.birthday-inner{max-width:1280px;margin:0 auto;position:relative;z-index:1}
.birthday-banner{text-align:center;margin-bottom:36px}
.birthday-banner .eyebrow{color:var(--hot-pink-deep);margin-bottom:10px;display:inline-block;background:#fff;padding:7px 15px;border-radius:99px;box-shadow:0 2px 8px rgba(233,30,99,0.15)}
.birthday-banner h2{font-size:clamp(32px,5vw,56px);color:var(--maroon-deep);margin-bottom:12px}
.birthday-banner h2 .pink{color:var(--hot-pink-deep);font-style:italic}
.birthday-banner p{font-size:15px;color:var(--charcoal);max-width:640px;margin:0 auto}
.k01-pick-instructions{background:#fff;border:2px dashed var(--hot-pink);border-radius:var(--r-md);padding:16px 22px;max-width:720px;margin:24px auto 36px;text-align:center;font-size:13px;color:var(--maroon-deep);line-height:1.5}
.k01-pick-instructions strong{color:var(--hot-pink-deep);font-weight:700}
.k01-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:48px}
.k01-card{background:#fff;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-card);position:relative;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s;cursor:pointer}
.k01-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-pink)}
.k01-card input[type="radio"]{position:absolute;opacity:0;pointer-events:none}
.k01-card.selected{outline:3px solid var(--hot-pink);outline-offset:2px;box-shadow:var(--shadow-pink)}
.k01-card.selected .k01-pick{background:linear-gradient(135deg,var(--hot-pink),var(--maroon));color:#fff}
.k01-card.selected .k01-pick::before{content:"\2713 "}
.k01-card .imgbox{aspect-ratio:1/1;background:var(--cream-soft);overflow:hidden;position:relative}
.k01-card .imgbox img{width:100%;height:100%;object-fit:cover}
.k01-card .imgbox .k01-letter{position:absolute;top:10px;left:10px;background:var(--hot-pink);color:#fff;font-family:'Playfair Display',serif;font-weight:700;font-size:14px;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(233,30,99,0.3);z-index:2}
.k01-card .meta{padding:14px 16px;display:flex;flex-direction:column;gap:4px;flex:1}
.k01-card .k01-concept{font-family:'Inter',sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--terracotta-deep)}
.k01-card .item-name{font-family:'Playfair Display',serif;font-size:14px;font-weight:600;color:var(--ink);line-height:1.3}
.k01-card .item-brand{font-size:11.5px;color:var(--muted)}
.k01-card .item-price{font-family:'Playfair Display',serif;font-size:16px;font-weight:700;color:var(--maroon);margin-top:4px}
.k01-card .item-buy{margin-top:8px;background:var(--charcoal);color:#fff;font-size:11px;padding:10px 14px;border-radius:8px;text-decoration:none;text-align:center;font-weight:600;min-height:44px;display:flex;align-items:center;justify-content:center}
.k01-card .k01-pick{margin-top:8px;background:#fff;border:2px solid var(--hot-pink);color:var(--hot-pink-deep);font-family:'Inter',sans-serif;font-size:11px;font-weight:700;padding:10px 14px;border-radius:8px;min-height:44px;cursor:pointer;text-transform:uppercase;letter-spacing:0.08em;transition:all .2s}
.k01-card .k01-pick:hover{background:var(--hot-pink);color:#fff}
.k01-extras-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-top:24px}
.k01-extras-label{text-align:center;font-family:'Playfair Display',serif;font-style:italic;font-size:20px;color:var(--maroon-deep);margin:32px 0 14px}

/* COMPARE FOOTER */
.compare-section{background:var(--charcoal);color:var(--cream);padding:64px 28px}
.compare-inner{max-width:1080px;margin:0 auto}
.compare-section h2{color:#fff;text-align:center;margin-bottom:8px}
.compare-section .eyebrow{color:var(--mustard);text-align:center;display:block;margin-bottom:10px}
.compare-section p{text-align:center;color:rgba(250,243,224,0.7);margin-bottom:32px}
.compare-table{width:100%;background:rgba(255,255,255,0.04);border-radius:var(--r-md);overflow:hidden;border-collapse:collapse}
.compare-table th,.compare-table td{padding:14px 18px;text-align:left;font-size:14px;border-bottom:1px solid rgba(255,255,255,0.08)}
.compare-table thead th{background:rgba(255,255,255,0.06);font-family:'Inter',sans-serif;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:0.1em;color:var(--mustard)}
.compare-table td.v1-col{color:rgba(250,243,224,0.6)}
.compare-table td.v2-col{color:var(--cream);font-weight:600}
.compare-table td.delta-col{color:var(--hot-pink);font-weight:700;font-family:'Playfair Display',serif;font-style:italic}
.compare-cta{text-align:center;margin-top:28px}
.compare-cta a{display:inline-block;background:#fff;color:var(--charcoal);font-family:'Inter',sans-serif;font-weight:600;font-size:14px;padding:14px 26px;border-radius:99px;text-decoration:none;margin:0 6px 10px;transition:transform .2s,box-shadow .2s;min-height:44px;display:inline-flex;align-items:center}
.compare-cta a:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,0.3)}
.compare-cta a.outline{background:transparent;color:#fff;border:1px solid rgba(255,255,255,0.4)}
.compare-cta a.outline:hover{background:rgba(255,255,255,0.1)}

/* ON-TRIP / FOOTER */
.on-trip{background:linear-gradient(135deg,var(--cream) 0%,var(--cream-soft) 100%);padding:56px 28px}
.on-trip-inner{max-width:1080px;margin:0 auto}
.on-trip h2{text-align:center;margin-bottom:8px;color:var(--maroon-deep)}
.on-trip .eyebrow{text-align:center;display:block;margin-bottom:8px}
.on-trip-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:32px}
.on-trip-card{background:#fff;border-radius:var(--r-md);padding:22px 24px;box-shadow:var(--shadow-card);border-left:4px solid var(--mustard)}
.on-trip-card h4{font-size:16px;color:var(--ink);margin-bottom:8px}
.on-trip-card .slot{font-family:'Inter',sans-serif;font-size:10px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--terracotta-deep);margin-bottom:6px}
.on-trip-card p{font-size:13px;color:var(--muted);line-height:1.6}
.on-trip-card .price{font-family:'Playfair Display',serif;font-weight:700;color:var(--maroon);margin-top:8px;font-size:14px}

.footer{background:var(--ink);color:rgba(250,243,224,0.75);padding:48px 28px 32px;text-align:center;font-size:13px}
.footer-links{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;margin-bottom:24px}
.footer-links a{color:var(--mustard);text-decoration:none;font-family:'Inter',sans-serif;font-weight:600;font-size:14px;padding:10px 14px;min-height:44px;display:inline-flex;align-items:center;border:1px solid rgba(212,160,23,0.3);border-radius:99px;transition:all .2s}
.footer-links a:hover{background:var(--mustard);color:var(--ink)}
.footer-meta{font-size:12px;color:rgba(250,243,224,0.5);line-height:1.6}

/* ============ MODAL ============ */
.modal-backdrop{position:fixed;inset:0;background:rgba(26,26,26,0.78);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:fadeIn .18s ease-out}
.modal-backdrop[hidden]{display:none}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-panel{background:var(--paper);border-radius:var(--r-lg);max-width:920px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,0.5);position:relative;animation:popIn .22s cubic-bezier(.2,.9,.3,1.2)}
@keyframes popIn{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}
.modal-header{display:grid;grid-template-columns:48px 1fr 48px 48px;align-items:center;gap:8px;padding:14px 18px;border-bottom:1px solid var(--line);background:#fff}
.modal-title{font-family:'Playfair Display',serif;font-size:18px;color:var(--ink);font-weight:600;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.modal-prev,.modal-next,.modal-close{width:44px;height:44px;border-radius:50%;border:none;background:var(--cream-soft);color:var(--charcoal);cursor:pointer;font-size:22px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .15s}
.modal-prev:hover,.modal-next:hover,.modal-close:hover{background:var(--hot-pink);color:#fff}
.modal-close{font-size:24px;font-weight:300}
.modal-body{display:grid;grid-template-columns:1fr 1fr;gap:0;flex:1;overflow:hidden}
@media (max-width:720px){.modal-body{grid-template-columns:1fr;overflow-y:auto}}
.modal-image{background:var(--cream-soft);display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:280px}
.modal-image img{width:100%;height:100%;object-fit:contain;max-height:60vh}
.modal-image.no-img{background:linear-gradient(135deg,var(--cream),var(--cream-soft))}
.modal-image .modal-img-fallback{padding:30px;text-align:center;font-family:'Playfair Display',serif;font-style:italic;color:var(--muted);font-size:14px}
.modal-detail{padding:22px 26px;overflow-y:auto;display:flex;flex-direction:column;gap:6px;font-size:13.5px;color:var(--charcoal);line-height:1.5}
.modal-slot-id{font-family:'Inter',sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--terracotta-deep)}
.modal-brand{font-size:13px;color:var(--muted);font-weight:500}
.modal-name{font-family:'Playfair Display',serif;font-size:20px;color:var(--ink);font-weight:600;line-height:1.25;margin:2px 0 4px}
.modal-color{font-size:12px;font-style:italic}
.modal-price{font-family:'Playfair Display',serif;font-size:24px;color:var(--maroon);font-weight:700;margin:8px 0}
.modal-buy{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--charcoal);color:#fff;text-decoration:none;font-family:'Inter',sans-serif;font-size:13px;font-weight:600;padding:12px 18px;border-radius:8px;min-height:44px;transition:background .2s;margin:4px 0}
.modal-buy:hover{background:var(--hot-pink-deep)}
.modal-buy.disabled{background:var(--muted);pointer-events:none;cursor:not-allowed}
.modal-description{margin-top:6px;font-size:12.5px;color:var(--muted);line-height:1.55}
.modal-alts{list-style:none;padding:0;margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}
.modal-alts li{font-size:11px;background:var(--cream-soft);padding:5px 10px;border-radius:99px;color:var(--charcoal)}
.modal-alts li a{color:var(--maroon);text-decoration:none;font-weight:600}
.modal-footer{border-top:1px solid var(--line);padding:14px 22px;background:#fff;display:flex;flex-direction:column;gap:6px}
.modal-footer label{font-family:'Inter',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--terracotta-deep)}
.modal-fb{width:100%;min-height:60px;border:1px solid var(--line-strong);border-radius:8px;padding:10px 12px;font-family:inherit;font-size:13px;color:var(--ink);resize:vertical;background:var(--paper)}
.modal-fb:focus{outline:none;border-color:var(--hot-pink);box-shadow:0 0 0 3px rgba(233,30,99,0.1)}

/* ============ MODAL — CROSS-DAY USAGE ============ */
.modal-usage-section{margin-top:20px;padding-top:14px;border-top:1px solid var(--line)}
.modal-usage-section[hidden]{display:none}
.modal-usage-header{font-family:'Inter',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--terracotta-deep);margin-bottom:10px}
.modal-usage-header strong{color:var(--maroon);font-weight:700;letter-spacing:0.04em}
.modal-usage-carousel{display:flex;align-items:stretch;gap:8px}
.usage-nav{flex-shrink:0;width:32px;height:32px;border-radius:50%;border:1px solid var(--line-strong);background:var(--cream-soft);color:var(--charcoal);cursor:pointer;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;align-self:center;transition:background .15s,color .15s,transform .15s}
.usage-nav:hover{background:var(--hot-pink);color:#fff;border-color:var(--hot-pink);transform:scale(1.08)}
.usage-scroll{flex:1;display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:4px 2px 8px;scrollbar-width:thin;scrollbar-color:var(--line-strong) transparent}
.usage-scroll::-webkit-scrollbar{height:6px}
.usage-scroll::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:99px}
.usage-day-card{flex:0 0 240px;scroll-snap-align:start;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:10px 12px;box-shadow:0 1px 4px rgba(43,43,43,0.04)}
.usage-day-label{font-family:'Playfair Display',serif;font-weight:700;font-size:14px;color:var(--maroon)}
.usage-day-activity{font-size:11px;color:var(--muted);margin-top:2px;line-height:1.4}
.usage-day-partners{font-size:11px;color:var(--charcoal);margin-top:8px;line-height:1.6}
.usage-day-partners em{color:var(--muted);font-style:italic}
.usage-partner-chip{display:inline-block;padding:2px 7px;margin:2px 3px 2px 0;background:var(--cream-soft);border:1px solid var(--line-strong);border-radius:99px;font-family:'Inter',sans-serif;font-size:10px;font-weight:600;color:var(--charcoal);cursor:pointer;transition:background .15s,color .15s,border-color .15s;user-select:none}
.usage-partner-chip:hover{background:var(--hot-pink);color:#fff;border-color:var(--hot-pink)}
@media (max-width:720px){
  .usage-day-card{flex:0 0 200px}
  .modal-usage-section{margin-top:14px;padding-top:10px}
}

/* ============ DAY THUMBS (per-cell, per-person) ============ */
.day-thumbs{margin-top:8px;display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.day-cell{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px;align-items:flex-start}
.daytable td.person-col,.daytable td.kit-col{vertical-align:top}
.day-thumb{width:40px;height:40px;border-radius:8px;overflow:hidden;background:var(--cream-soft);border:2px solid transparent;cursor:pointer;padding:0;flex-shrink:0;position:relative;transition:transform .15s,border-color .15s}
.day-thumb:hover{transform:scale(1.08);border-color:var(--hot-pink)}
.day-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.day-thumb.no-img{background:linear-gradient(135deg,var(--cream),var(--cream-soft))}
.day-thumb-label{position:absolute;bottom:-2px;left:0;right:0;font-size:7px;text-align:center;background:rgba(0,0,0,0.6);color:#fff;font-weight:700;letter-spacing:0.05em;padding:1px 0;line-height:1}
.daytable td.day-thumbs-cell{padding-top:8px}

/* ============ KITS SUB-HEADER (per-person utilities) ============ */
.kits-subheader{font-family:'Playfair Display',Georgia,serif;font-size:20px;font-weight:600;color:var(--maroon-deep);margin:36px 0 18px;padding-top:24px;border-top:1px dashed var(--line-strong);display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.kits-subheader::before{content:"\1F392";font-family:inherit;font-size:18px;line-height:1}
.kits-subheader .kits-count{font-family:'Inter',sans-serif;font-size:12px;font-weight:500;color:var(--muted);text-transform:none;letter-spacing:0}

/* ============ PER-DAY FEEDBACK (in daytable) ============ */
.daytable th.day-fb-th{width:48px;text-align:center}
.daytable td.day-fb-cell{width:48px;padding:8px 6px;text-align:center;vertical-align:top}
.fb-day{display:inline-block;position:relative}
.fb-day>summary{list-style:none;cursor:pointer;width:32px;height:32px;border-radius:50%;background:var(--cream-soft);display:inline-flex;align-items:center;justify-content:center;font-size:16px;line-height:1;transition:background .15s,transform .15s;user-select:none}
.fb-day>summary::-webkit-details-marker{display:none}
.fb-day>summary:hover{background:var(--hot-pink);transform:scale(1.1)}
.fb-day.has-note>summary{background:var(--mustard);box-shadow:0 0 0 2px rgba(212,160,23,0.3)}
.fb-day[open]>summary{background:var(--hot-pink);color:#fff}
.fb-day[open]{position:absolute;right:6px;z-index:30;background:#fff;border:1px solid var(--line-strong);border-radius:10px;padding:10px;box-shadow:0 8px 24px rgba(0,0,0,0.12);width:280px}
.fb-day[open]>summary{position:absolute;top:-12px;right:-12px;width:28px;height:28px;font-size:14px;border:2px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,0.2)}
.fb-day textarea.fb-textarea{width:100%;min-height:80px;border:1px solid var(--line-strong);border-radius:6px;padding:8px 10px;font-family:inherit;font-size:12px;color:var(--ink);background:var(--paper);resize:vertical;margin-top:6px}
.fb-day textarea.fb-textarea:focus{outline:none;border-color:var(--hot-pink);box-shadow:0 0 0 2px rgba(233,30,99,0.1)}

/* ============ FEEDBACK LAYER ============ */
.fb-btn{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--line-strong);color:var(--charcoal);font-family:'Inter',sans-serif;font-size:10px;font-weight:600;padding:4px 8px;border-radius:99px;cursor:pointer;margin-top:6px;letter-spacing:0.04em;text-transform:uppercase;transition:all .15s;min-height:28px;line-height:1}
.fb-btn:hover{background:var(--hot-pink);color:#fff;border-color:var(--hot-pink)}
.fb-btn.has-note{background:var(--mustard);color:var(--ink);border-color:var(--mustard)}
.fb-btn.has-note::before{content:"\270E ";margin-right:4px}
.item-card .meta .fb-btn{align-self:flex-start}

.fb-section-block{margin:20px auto 0;max-width:880px;background:linear-gradient(135deg,var(--cream-soft) 0%,#fff 100%);border:1px solid var(--line);border-radius:var(--r-md);padding:16px 22px}
.fb-section-block label{font-family:'Inter',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--terracotta-deep);display:block;margin-bottom:8px}
.fb-section-input{width:100%;min-height:54px;border:1px solid var(--line-strong);border-radius:8px;padding:10px 12px;font-family:inherit;font-size:13px;color:var(--ink);background:#fff;resize:vertical}
.fb-section-input:focus{outline:none;border-color:var(--hot-pink);box-shadow:0 0 0 3px rgba(233,30,99,0.1)}

.fb-overall{margin:48px auto 24px;max-width:880px;background:linear-gradient(135deg,#fff 0%,var(--pink-soft) 100%);border:2px solid var(--hot-pink);border-radius:var(--r-md);padding:22px 26px;box-shadow:var(--shadow-card)}
.fb-overall h3{font-family:'Playfair Display',serif;font-size:20px;color:var(--maroon-deep);margin-bottom:10px}
.fb-overall p{font-size:13px;color:var(--charcoal);margin-bottom:12px}
.fb-overall textarea{width:100%;min-height:100px;border:1px solid var(--line-strong);border-radius:8px;padding:12px 14px;font-family:inherit;font-size:14px;color:var(--ink);background:#fff;resize:vertical}
.fb-overall textarea:focus{outline:none;border-color:var(--hot-pink);box-shadow:0 0 0 3px rgba(233,30,99,0.15)}

.fb-actions{position:fixed;bottom:24px;right:24px;z-index:90;display:flex;align-items:center;gap:8px}
.fb-actions .fb-save-btn{position:static}
.fb-save-btn{position:fixed;bottom:24px;right:24px;background:linear-gradient(135deg,var(--hot-pink),var(--maroon));color:#fff;border:none;font-family:'Inter',sans-serif;font-weight:700;font-size:13px;padding:14px 22px;border-radius:99px;cursor:pointer;box-shadow:0 10px 28px rgba(233,30,99,0.4),0 4px 10px rgba(184,21,77,0.3);z-index:90;display:flex;align-items:center;gap:8px;letter-spacing:0.04em;text-transform:uppercase;min-height:48px;transition:transform .2s,box-shadow .2s}
.fb-save-btn:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(233,30,99,0.5),0 6px 14px rgba(184,21,77,0.35)}
.fb-save-btn::before{content:"\270E";font-size:16px}
.fb-save-btn .fb-count{background:rgba(255,255,255,0.25);padding:2px 8px;border-radius:99px;font-size:11px}
.fb-reset-btn{width:44px;height:44px;min-width:44px;border-radius:50%;background:#fff;color:var(--muted);border:1px solid var(--line-strong);cursor:pointer;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(43,43,43,0.10);opacity:0;transform:translateX(8px) scale(.9);pointer-events:none;transition:opacity .18s,transform .18s,background .15s,color .15s,border-color .15s}
.fb-actions:hover .fb-reset-btn,.fb-actions:focus-within .fb-reset-btn,.fb-reset-btn:focus{opacity:1;transform:translateX(0) scale(1);pointer-events:auto}
.fb-reset-btn:hover{background:var(--maroon);color:#fff;border-color:var(--maroon)}
@media (max-width:720px){
  .fb-actions{bottom:16px;right:16px;gap:6px}
  .fb-reset-btn{opacity:1;transform:none;pointer-events:auto;width:44px;height:44px;font-size:18px}
}

.fb-toast{position:fixed;bottom:90px;right:24px;background:var(--emerald);color:#fff;padding:14px 20px;border-radius:10px;font-size:13px;font-weight:600;box-shadow:0 10px 24px rgba(0,0,0,0.25);z-index:1100;animation:slideUp .3s ease-out;max-width:340px;line-height:1.45}
.fb-toast[hidden]{display:none}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.fb-toast a{color:#fff;text-decoration:underline}

/* ============ MOBILE ============ */
@media (max-width:720px){
  .section,.section-tight{padding:48px 18px}
  .hero{padding:56px 18px 42px}
  .nav-inner{padding:12px 16px}
  .hero-day-head{padding:24px 22px 18px}
  .outfit-slot{padding:18px 16px}
  .alts-track .item-card{min-width:170px;width:170px}
  .v2-callout{padding:22px 22px}
  .modal-panel{max-height:96vh;border-radius:var(--r-md)}
  .modal-detail{padding:18px 20px}
  .fb-save-btn{bottom:16px;right:16px;padding:12px 18px;font-size:12px}
  .day-thumb{width:32px;height:32px}
  .day-cell{gap:4px;margin-bottom:6px}
}
@media (max-width:540px){
  .outfit-grid{grid-template-columns:1fr}
  .item-grid{grid-template-columns:repeat(2,1fr)}
  .item-card .meta{padding:10px 12px 12px}
  .item-card .item-name{font-size:13px}
  .item-card .item-price{font-size:15px}
  .item-card .item-buy{font-size:11px;padding:11px 12px}
  .k01-gallery{grid-template-columns:repeat(2,1fr)}
  .hero-meta{gap:8px}
  .hero-meta-item{font-size:11px;padding:7px 11px}
}
