/* outfit-curator / assets / checklist.css
   Shared styles for trip shopping-checklist HTML artifacts.
   Sections: tokens · header · urgency · filters · main · item rows · alts · footer · feedback · print · responsive
*/
:root{
  --mustard:#d4a017; --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;
  --charcoal:#2b2b2b; --ink:#1a1a1a;
  --paper:#fdfaf3; --line:rgba(43,43,43,0.12); --line-strong:rgba(43,43,43,0.25); --muted:#6b6357;
  --shadow:0 4px 14px rgba(43,43,43,0.06),0 1px 3px rgba(43,43,43,0.04);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;font-size:15px;line-height:1.55;color:var(--ink);background:var(--paper)}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:700;letter-spacing:-0.01em}

.header{background:linear-gradient(135deg,var(--charcoal) 0%,var(--maroon-deep) 100%);color:var(--cream);padding:40px 28px 32px;position:relative;overflow:hidden}
.header::after{content:"";position:absolute;top:-50px;right:-50px;width:240px;height:240px;background:radial-gradient(circle,rgba(233,30,99,0.25) 0%,transparent 70%)}
.header-inner{max-width:1080px;margin:0 auto;position:relative;z-index:1}
.header .eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:0.15em;color:var(--mustard);font-weight:600;margin-bottom:8px;display:inline-block}
.header h1{font-size:clamp(28px,4vw,40px);color:#fff;line-height:1.2}
.header h1 .v2-pill{display:inline-block;background:linear-gradient(135deg,var(--hot-pink),var(--maroon));color:#fff;font-family:'Inter',sans-serif;font-size:13px;font-weight:700;padding:5px 12px;border-radius:99px;margin-left:10px;vertical-align:middle;letter-spacing:0.08em}
.header-meta{margin-top:18px;display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.header-meta .stat{background:rgba(255,255,255,0.10);padding:9px 16px;border-radius:99px;font-size:13px;color:var(--cream)}
.header-meta .stat strong{color:#fff;font-family:'Playfair Display',serif;font-weight:700}
.header-actions{margin-top:22px;display:flex;flex-wrap:wrap;gap:10px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:'Inter',sans-serif;font-weight:600;font-size:13px;padding:11px 18px;border-radius:99px;text-decoration:none;cursor:pointer;border:none;min-height:44px;transition:all .2s}
.btn-primary{background:var(--mustard);color:var(--ink)}
.btn-primary:hover{background:#fff}
.btn-outline{background:transparent;color:#fff;border:1px solid rgba(255,255,255,0.4)}
.btn-outline:hover{background:rgba(255,255,255,0.1)}
.btn-danger{background:var(--maroon);color:#fff}
.btn-danger:hover{background:var(--hot-pink-deep)}
.progress-wrap{margin-top:18px;background:rgba(255,255,255,0.10);padding:14px 18px;border-radius:12px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.progress-bar{flex:1;min-width:200px;height:10px;background:rgba(255,255,255,0.15);border-radius:99px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--mustard),var(--hot-pink));transition:width .4s;width:0%}
.progress-text{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;color:#fff;white-space:nowrap}
.progress-text small{font-family:'Inter',sans-serif;font-size:12px;font-weight:400;color:rgba(255,255,255,0.7);margin-left:6px}

.urgent-banner{max-width:1080px;margin:24px auto 0;padding:0 28px}
.urgent-banner-inner{background:linear-gradient(135deg,#fff 0%,var(--pink-soft) 100%);border:2px solid var(--hot-pink);border-radius:14px;padding:20px 24px;box-shadow:0 6px 18px rgba(233,30,99,0.18)}
.urgent-banner h3{color:var(--hot-pink-deep);font-size:18px;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.urgent-banner h3::before{content:"!";display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--hot-pink);color:#fff;border-radius:50%;font-family:'Inter',sans-serif;font-weight:900;font-size:18px}
.urgent-list{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:8px 24px;margin-top:10px}
.urgent-list li{font-size:13px;color:var(--charcoal);padding-left:18px;position:relative;line-height:1.5}
.urgent-list li::before{content:"→";position:absolute;left:0;color:var(--hot-pink);font-weight:700}
.urgent-list li strong{color:var(--maroon-deep)}

.filters-sticky{position:sticky;top:0;z-index:10;background:rgba(253,250,243,0.96);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--line);padding:14px 28px}
.filters-inner{max-width:1080px;margin:0 auto;display:flex;flex-wrap:nowrap;overflow-x:auto;gap:8px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.filters-inner::-webkit-scrollbar{display:none}
.chip{background:#fff;border:1px solid var(--line-strong);color:var(--charcoal);font-family:'Inter',sans-serif;font-size:12px;font-weight:600;padding:9px 14px;border-radius:99px;cursor:pointer;white-space:nowrap;min-height:40px;display:inline-flex;align-items:center;gap:5px;transition:all .15s}
.chip:hover{border-color:var(--charcoal)}
.chip.active{background:var(--charcoal);color:#fff;border-color:var(--charcoal)}
.chip.urgent.active{background:var(--maroon);border-color:var(--maroon)}
.chip .count{font-weight:400;color:var(--muted);font-size:11px}
.chip.active .count{color:rgba(255,255,255,0.7)}

.main{max-width:1080px;margin:0 auto;padding:36px 28px 80px}
.retailer{margin-bottom:32px;background:#fff;border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.retailer-head{padding:18px 24px;background:linear-gradient(135deg,var(--cream) 0%,var(--cream-soft) 100%);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.retailer-head h3{font-size:20px;color:var(--ink)}
.retailer-head .meta{display:flex;gap:14px;font-size:13px;color:var(--muted);font-family:'Inter',sans-serif;font-weight:500;flex-wrap:wrap}
.retailer-head .meta .total{font-family:'Playfair Display',serif;font-weight:700;color:var(--maroon);font-size:16px}

.item-row{display:grid;grid-template-columns:44px 1fr auto;gap:14px;padding:16px 24px;border-bottom:1px solid var(--line);align-items:start;transition:background .15s}
.item-row:last-child{border-bottom:none}
.item-row:hover{background:rgba(212,160,23,0.04)}
.item-row.done{opacity:0.55;background:rgba(44,110,92,0.05)}
.item-row.done .item-name{text-decoration:line-through;color:var(--muted)}
.item-row.hidden-row{display:none}
.item-row .check-col{padding-top:2px}
.item-row input[type="checkbox"]{width:24px;height:24px;cursor:pointer;accent-color:var(--emerald)}
.item-row .info-col{min-width:0}
.item-row .item-slot{font-family:'Inter',sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--terracotta-deep);display:inline-block;margin-right:8px}
.item-row .item-slot.urgent{color:#fff;background:var(--maroon);padding:2px 8px;border-radius:99px}
.item-row .item-name{font-family:'Playfair Display',serif;font-size:15px;font-weight:600;color:var(--ink);display:inline}
.item-row .item-brand{font-size:12.5px;color:var(--muted);margin-top:4px}
.item-row .item-meta{font-size:11px;color:var(--charcoal);font-style:italic;margin-top:2px}
.item-row .item-buy{display:inline-flex;align-items:center;gap:4px;background:var(--charcoal);color:#fff;text-decoration:none;font-family:'Inter',sans-serif;font-size:11px;font-weight:600;padding:9px 14px;border-radius:8px;margin-top:8px;min-height:36px}
.item-row .item-buy:hover{background:var(--hot-pink-deep)}
.item-row .price-col{font-family:'Playfair Display',serif;font-weight:700;color:var(--maroon);font-size:17px;text-align:right;white-space:nowrap;padding-top:6px}

.show-alts-row{background:transparent;border:none;color:var(--terracotta-deep);font-family:'Inter',sans-serif;font-size:11px;font-weight:600;padding:6px 0;cursor:pointer;margin-top:6px;text-transform:uppercase;letter-spacing:0.06em}
.show-alts-row:hover{color:var(--hot-pink-deep)}
.alts-row-content{margin-top:10px;background:var(--cream-soft);border-left:3px solid var(--terracotta);border-radius:6px;padding:10px 14px}
.alts-row-content[hidden]{display:none}
.alt-row-item{font-size:12px;color:var(--charcoal);padding:6px 0;border-bottom:1px dashed rgba(43,43,43,0.12);display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:8px}
.alt-row-item:last-child{border-bottom:none}
.alt-row-item .alt-info{flex:1;min-width:180px}
.alt-row-item strong{color:var(--ink);font-weight:600}
.alt-row-item .alt-price{font-family:'Playfair Display',serif;font-weight:700;color:var(--maroon);font-size:13px}
.alt-row-item a{color:var(--charcoal);text-decoration:none;background:#fff;padding:5px 10px;border-radius:6px;font-size:11px;font-weight:600;border:1px solid var(--line-strong);min-height:32px;display:inline-flex;align-items:center}
.alt-row-item a:hover{background:var(--charcoal);color:#fff}

.naval-band .retailer-head{border-left:4px solid var(--chambray)}
.yogitha-band .retailer-head{border-left:4px solid var(--emerald)}
.yashika-band .retailer-head{border-left:4px solid var(--hot-pink)}
.kits-band .retailer-head{border-left:4px solid var(--mustard)}
.decor-band .retailer-head{border-left:4px solid var(--hot-pink-deep)}
.on-trip-band .retailer-head{border-left:4px solid var(--terracotta)}

.footer{background:var(--ink);color:rgba(250,243,224,0.75);padding:36px 28px 24px;text-align:center;font-size:12.5px;margin-top:48px}
.footer a{color:var(--mustard);text-decoration:none;font-weight:600;padding:8px 14px;min-height:44px;display:inline-flex;align-items:center;border:1px solid rgba(212,160,23,0.3);border-radius:99px;margin:4px 6px}
.footer a:hover{background:var(--mustard);color:var(--ink)}

/* ============ FEEDBACK (shared shape with lookbook) ============ */
.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-left:8px;letter-spacing:0.04em;text-transform:uppercase;transition:all .15s;min-height:24px;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}
.fb-section-block{margin:14px 0 6px;background:linear-gradient(135deg,var(--cream-soft) 0%,#fff 100%);border:1px solid var(--line);border-radius:10px;padding:12px 16px}
.fb-section-block label{font-family:'Inter',sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--terracotta-deep);display:block;margin-bottom:6px}
.fb-section-input{width:100%;min-height:44px;border:1px solid var(--line-strong);border-radius:6px;padding:8px 10px;font-family:inherit;font-size:12.5px;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{max-width:1024px;margin:32px auto 24px;background:linear-gradient(135deg,#fff 0%,var(--pink-soft) 100%);border:2px solid var(--hot-pink);border-radius:14px;padding:22px 26px;box-shadow:var(--shadow)}
.fb-overall h3{font-family:'Playfair Display',serif;font-size:20px;color:var(--maroon-deep);margin-bottom:8px}
.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-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)}
.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-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;max-width:340px;line-height:1.45}
.fb-toast[hidden]{display:none}

@media print{
  body{background:#fff;color:#000;font-size:11pt}
  .header,.urgent-banner,.filters-sticky,.footer,.header-actions,.progress-wrap,.btn,.item-buy,.show-alts-row,.alts-row-content,.fb-btn,.fb-section-block,.fb-overall,.fb-save-btn,.fb-toast{display:none !important}
  .urgent-banner-inner{display:block !important;border:1px solid #000;background:#fff;page-break-inside:avoid}
  .urgent-banner{display:block !important;margin:0 0 14pt}
  .main{padding:14pt;max-width:none}
  .retailer{box-shadow:none;border:1px solid #000;margin-bottom:14pt;page-break-inside:avoid}
  .retailer-head{background:#eee !important;color:#000;padding:8pt 12pt}
  .item-row{grid-template-columns:24px 1fr auto;padding:6pt 12pt;border-bottom:1px solid #ccc}
  .item-row input[type="checkbox"]{width:16px;height:16px}
  .item-row .item-name{font-size:11pt}
  .item-row .item-brand,.item-row .item-meta{color:#444;font-size:9pt}
  .item-row .price-col{color:#000;font-size:11pt}
  .item-row.done{opacity:1}
  .item-row.done .item-name::before{content:"\2713 "}
  h1,h2,h3,h4{color:#000}
  a{color:#000;text-decoration:none}
  .item-slot{color:#600}
}

@media (max-width:720px){
  .header{padding:32px 18px 24px}
  .main{padding:24px 16px 60px}
  .urgent-banner,.filters-sticky{padding:0 16px}
  .filters-sticky{padding:12px 16px}
  .item-row{grid-template-columns:36px 1fr;padding:14px 16px;gap:10px}
  .item-row .price-col{grid-column:1/-1;text-align:left;padding-left:46px;font-size:15px}
  .retailer-head{padding:14px 16px}
  .retailer-head .meta{font-size:11px;gap:10px}
  .item-row .item-name{font-size:14px}
  .fb-save-btn{bottom:16px;right:16px;padding:12px 18px;font-size:12px}
}
