/* ============================================================
   THEPRINT.NINJA — Shared apparel-page CSS
   Used by every garment page in /apparel/
   Pattern reference: APP-166 (HOODIE-R2-V06)
   Sections: description → weight → use → portfolio → FAQ
   Variant: V06 — left-accent rule on every section.
   Pairs with the locked SP-034 left rail (loaded via section-page.css).
============================================================ */

/* === Sticky stack: locked header → chip bar → rail ===
   .h1517-header is made sticky in section-page.css.
   --header-h and --chip-bar-h are set live by apparel-page.js. */
:root{--header-h:112px}
.pillar-rail{top:calc(var(--header-h, 112px) + var(--chip-bar-h, 70px) + 8px) !important;max-height:calc(100vh - var(--header-h, 112px) - var(--chip-bar-h, 70px) - 16px) !important}

/* === Hero === */
.pillar-hero{padding:80px 56px 56px;max-width:1280px;margin:0 auto;background:#fff}
.pillar-hero .eye{display:inline-flex;align-items:center;gap:10px;font-size:11.5px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);font-family:'Inter',sans-serif;background:none;padding:0;border:0;margin:0 0 22px}
.pillar-hero .eye::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--accent)}
.pillar-hero h1{font-family:'Inter',sans-serif;font-size:clamp(42px,6.4vw,84px);line-height:.98;font-weight:800;letter-spacing:-.04em;color:var(--ink);margin:0 0 24px}
.pillar-hero h1 em{color:var(--accent);font-style:italic;font-weight:800}
.pillar-hero p{font-size:18px;color:var(--muted);max-width:620px;margin:0;line-height:1.65}
.pillar-hero .hero-acts{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-top:32px}
.pillar-hero .btn-ph{display:inline-flex;align-items:center;gap:10px;padding:15px 28px;border-radius:999px;font-size:15px;font-weight:700;text-decoration:none;border:none;cursor:pointer;letter-spacing:-.01em;transition:all .25s;line-height:1}
.pillar-hero .btn-ph svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;transition:transform .25s}
.pillar-hero .btn-ph:hover svg{transform:translateX(3px)}
.pillar-hero .btn-ph.fill{background:var(--ink);color:#fff}.pillar-hero .btn-ph.fill:hover{background:#2a2a2c}
.pillar-hero .btn-ph.ghost{background:transparent;color:var(--ink)}.pillar-hero .btn-ph.ghost:hover{color:var(--accent)}

/* === Section base · V06 left-accent rule === */
.section{padding:96px 56px;background:#fff;border-top:1px solid var(--hair);scroll-margin-top:140px}
.section.alt{background:var(--surface)}
.section-inner{max-width:980px;margin:0 auto;border-left:3px solid var(--accent);padding-left:32px}
@media(max-width:760px){.section-inner{padding-left:18px}.section{padding:64px 24px}.pillar-hero{padding:48px 24px}}
.section-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:11.5px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);font-family:'Inter',sans-serif;margin:0 0 22px}
.section-eyebrow::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--accent)}
.section-h{font-family:'Inter',sans-serif;font-size:clamp(34px,4.6vw,56px);font-weight:800;letter-spacing:-.035em;line-height:1.05;color:var(--ink);margin:0 0 22px;max-width:780px}
.section-h em{color:var(--accent);font-style:italic;font-weight:800}
.section-lead{font-size:17.5px;color:var(--muted);max-width:640px;line-height:1.65;margin:0 0 32px}

/* === DESCRIPTION block === */
.desc-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:start}
@media(max-width:860px){.desc-grid{grid-template-columns:1fr}}
.desc-img{aspect-ratio:1;background:linear-gradient(135deg,#fff,var(--accent-soft));border:1px solid var(--hair);border-radius:18px;display:flex;align-items:center;justify-content:center;color:var(--accent);font-weight:800;font-size:48px;letter-spacing:-.04em;position:relative;overflow:hidden}
.desc-img::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 70% 30%, rgba(255,122,0,0.12) 0%, transparent 70%)}
.desc-img span{position:relative;z-index:2;font-size:64px}
.desc-body p{font-size:17px;color:var(--muted);line-height:1.7;margin-bottom:18px}
.desc-body p strong{color:var(--ink);font-weight:700}
.desc-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.desc-meta span{font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:7px 13px;border-radius:999px;background:var(--surface);border:1px solid var(--hair);color:var(--muted-2)}
.desc-meta span.accent{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-ink)}

/* === GSM WEIGHT SCALE === */
.weight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
@media(max-width:760px){.weight-grid{grid-template-columns:1fr}}
.weight-card{padding:28px 24px;border:1.5px solid var(--hair);border-radius:14px;background:#fff;cursor:pointer;transition:all .3s ease;position:relative}
.weight-card:hover{transform:translateY(-3px);border-color:var(--accent)}
.weight-card.active{background:var(--accent-soft);border-color:var(--accent);box-shadow:0 8px 30px rgba(255,122,0,.18)}
.weight-card .num{display:block;font-size:48px;font-weight:800;letter-spacing:-.045em;color:var(--ink);line-height:1}
.weight-card .num em{color:var(--accent);font-style:normal;font-size:.5em;vertical-align:0.4em;font-weight:700}
.weight-card .lbl{display:block;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);margin-top:8px}
.weight-card.active .lbl{color:var(--accent-ink)}
.weight-card .d{display:block;font-size:14px;color:var(--muted);line-height:1.55;margin-top:14px}
.weight-card.active .d{color:var(--ink)}
.weight-scale{margin-top:32px;padding:0 12px;grid-column:1/-1}
.weight-scale .track{height:6px;background:linear-gradient(90deg,#fdebd6 0%,var(--accent-soft) 30%,var(--accent-2,#ff9533) 65%,var(--accent) 100%);border-radius:999px;position:relative}
.weight-scale .knob{position:absolute;top:-7px;left:50%;width:20px;height:20px;border-radius:50%;background:var(--accent);border:3px solid #fff;box-shadow:0 4px 14px rgba(255,122,0,.45);transform:translateX(-50%);transition:left .5s cubic-bezier(.22,1,.36,1)}
.weight-scale .markers{display:flex;justify-content:space-between;margin-top:16px;font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}

/* === RECOMMENDED FOR === */
.use-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:8px}
@media(max-width:760px){.use-grid{grid-template-columns:1fr}}
.use-row{display:flex;align-items:center;gap:14px;padding:18px 22px;background:#fff;border:1.5px solid var(--hair);border-radius:12px;font-size:16px;font-weight:600;transition:all .25s ease;cursor:pointer}
.use-row:hover{transform:translateY(-2px);border-color:var(--accent)}
.use-row.recommended{background:var(--accent-soft);border-color:var(--accent)}
.use-row.no{opacity:.55}
.use-row .check{width:24px;height:24px;border-radius:6px;border:2px solid var(--hair);flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#fff;font-size:14px;font-weight:800;color:transparent;transition:all .25s}
.use-row.recommended .check{background:var(--accent);border-color:var(--accent);color:#fff}
.use-row.recommended .check::after{content:'✓'}
.use-row .lbl{flex:1;color:var(--ink);letter-spacing:-.005em}
.use-row .meta{font-size:10.5px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);background:var(--surface);padding:6px 11px;border-radius:999px;border:1px solid var(--hair)}
.use-row.recommended .meta{color:var(--accent);background:#fff;border-color:var(--accent)}

/* === DECORATION RECOMMENDATION MATRIX === */
.dec-grid{margin-top:8px;border:1px solid var(--hair);border-radius:12px;overflow:hidden}
.dec-grid table{width:100%;border-collapse:collapse;font-size:14px}
.dec-grid th, .dec-grid td{padding:12px 16px;border-right:1px solid var(--hair);border-bottom:1px solid var(--hair);text-align:center}
.dec-grid th{background:var(--surface);font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-size:11px}
.dec-grid td.row{background:var(--surface);font-weight:800;text-align:left;color:var(--ink)}
.dec-grid tr:last-child td{border-bottom:0}
.dec-grid td:last-child, .dec-grid th:last-child{border-right:0}
.dec-grid .pill{padding:5px 12px;font-size:10px;font-weight:800;border-radius:999px;letter-spacing:.1em;text-transform:uppercase;display:inline-block;line-height:1.2}
.dec-grid .pill.best{background:var(--green,#10b981);color:#fff}
.dec-grid .pill.good{background:var(--accent);color:#fff}
.dec-grid .pill.ok{background:#fff;color:var(--muted);border:1px solid var(--hair)}
.dec-grid .pill.no{background:#fff;color:var(--muted-2);border:1px solid var(--hair);opacity:.5}

/* === INTERACTIVE PORTFOLIO === */
.gal-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:20px;margin-top:8px}
@media(max-width:860px){.gal-grid{grid-template-columns:1fr}}
.gal-feat{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:1.3;background:linear-gradient(135deg,var(--accent),#ff9b3c);display:flex;align-items:flex-end;padding:24px;transition:background .35s ease}
.gal-feat::before{content:attr(data-label);position:absolute;left:50%;top:42%;transform:translate(-50%,-50%);color:#fff;font-size:64px;font-weight:800;letter-spacing:-.04em;opacity:.65}
.gal-feat .cap{position:relative;z-index:2;color:#fff;font-size:13px;font-weight:700;background:rgba(0,0,0,.4);padding:9px 14px;border-radius:8px;letter-spacing:-.005em;backdrop-filter:blur(6px)}
.gal-thumbs{display:grid;grid-template-rows:repeat(3,1fr);gap:14px}
.gal-thumb{border-radius:14px;background:linear-gradient(135deg,#fff,var(--accent-soft));border:2px solid var(--hair);position:relative;cursor:pointer;transition:all .25s ease;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;color:var(--accent);overflow:hidden}
.gal-thumb:hover{transform:scale(1.03);border-color:var(--accent)}
.gal-thumb.active{border-color:var(--accent);box-shadow:0 0 0 3px rgba(255,122,0,.22)}
.gal-nav{display:flex;align-items:center;gap:12px;margin-top:24px;font-size:11px;font-weight:800;color:var(--muted);letter-spacing:.16em;text-transform:uppercase}
.gal-dots{display:flex;gap:6px}
.gal-dots span{width:8px;height:8px;border-radius:50%;background:var(--hair);cursor:pointer;transition:all .3s}
.gal-dots span.active{background:var(--accent);width:24px;border-radius:999px}
.gal-ct{margin-left:auto;color:var(--accent)}
.gal-prev, .gal-next{width:34px;height:34px;border-radius:50%;background:var(--surface);border:1px solid var(--hair);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s;color:var(--ink)}
.gal-prev:hover, .gal-next:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.gal-prev svg, .gal-next svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}

/* === Per-section CTA · CTA-031 (P04-V1) — pill with arrow circle === */
.section-cta-line{margin-top:40px;display:flex;justify-content:flex-start}
.p04-btn{
  display:inline-flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 14px 14px 26px;border-radius:999px;
  background:var(--ink);color:#fff;
  font-size:15px;font-weight:800;letter-spacing:-.01em;
  text-decoration:none;border:0;cursor:pointer;font-family:inherit;
  transition:background .25s ease;
}
.p04-btn:hover{background:#2a2a2c}
.p04-btn .a{
  width:34px;height:34px;border-radius:50%;
  background:var(--accent);
  display:flex;align-items:center;justify-content:center;color:#fff;
  transition:transform .35s cubic-bezier(.22,1,.36,1);
}
.p04-btn:hover .a{transform:rotate(-45deg);background:var(--accent-deep)}
.p04-btn svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}

/* === CTA Band === */
.section-cta{padding:80px 56px;background:var(--ink);color:#fff}
@media(max-width:760px){.section-cta{padding:60px 24px}}
.section-cta-inner{max-width:1180px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.section-cta h3{font-size:clamp(24px,3vw,36px);font-weight:800;letter-spacing:-.03em;line-height:1.1;color:#fff;max-width:640px}
.section-cta h3 em{color:var(--accent);font-style:italic}
.section-cta .acts{display:flex;gap:12px;flex-wrap:wrap}
.section-cta .btn-cta{padding:15px 28px;border-radius:999px;font-size:15px;font-weight:700;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:10px;text-decoration:none}
.section-cta .btn-cta.fill{background:var(--accent);color:#fff}
.section-cta .btn-cta.out{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.section-cta .btn-cta svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}

/* === Final FAQ === */
.section-faq{padding:120px 56px;background:#fff;border-top:1px solid var(--hair)}
@media(max-width:760px){.section-faq{padding:80px 24px}}
.faq-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1fr 1.5fr;gap:80px;align-items:start}
@media(max-width:960px){.faq-grid{grid-template-columns:1fr;gap:48px}}
.faq-left h2{font-size:clamp(32px,4.4vw,52px);font-weight:800;letter-spacing:-.035em;line-height:1.05;color:var(--ink);margin-bottom:18px}
.faq-left h2 em{color:var(--accent);font-style:italic}
.faq-left p{font-size:16px;color:var(--muted);line-height:1.65;max-width:380px;margin-bottom:24px}
.faq-left a{color:var(--accent);font-weight:600}
.faq-list{border-top:1px solid var(--hair)}
.faq-item{border-bottom:1px solid var(--hair)}
.faq-q{width:100%;text-align:left;cursor:pointer;padding:24px 0;display:flex;align-items:center;justify-content:space-between;gap:24px;font-size:17px;font-weight:700;letter-spacing:-.015em;color:var(--ink);background:transparent;border:0;font-family:inherit;line-height:1.4;transition:color .2s}
.faq-q:hover{color:var(--accent)}
.faq-toggle{width:36px;height:36px;border-radius:50%;background:var(--surface);color:var(--ink);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s,transform .25s}
.faq-q[aria-expanded="true"] .faq-toggle{background:var(--accent);color:#fff;transform:rotate(45deg)}
.faq-toggle svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a-inner{padding:0 0 24px}
.faq-a p{font-size:15.5px;color:var(--muted);line-height:1.65;max-width:60ch}

/* === P03 — Cross / tick swap (locked option style) === */
.garment-chips{
  position:sticky;top:var(--header-h, 112px);z-index:40;
  background:#fff;
  border-bottom:1px solid var(--hair);
  padding:14px 32px;
  transition:box-shadow .3s ease, padding .25s ease, background .25s ease;
}
.garment-chips.stuck{
  box-shadow:0 6px 22px rgba(15,15,16,.08);
  padding:10px 32px;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(12px);
}
.garment-chips-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.garment-chips .lbl{font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);flex-shrink:0}
.garment-chip-group{display:flex;flex-wrap:wrap;gap:8px}
.garment-chip{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px 8px 10px;
  background:#fff;border:1.5px solid var(--hair);
  border-radius:999px;cursor:pointer;
  font-size:13.5px;font-weight:700;color:var(--muted);
  transition:all .25s ease;
  font-family:inherit;line-height:1;letter-spacing:-.005em;
}
.garment-chip:hover{border-color:var(--accent);color:var(--ink)}
.garment-chip.on{color:var(--ink);border-color:var(--ink)}
.garment-chip .dot{
  width:18px;height:18px;border-radius:50%;
  border:2px solid var(--hair);background:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;color:var(--muted-2);
  transition:all .25s ease;flex-shrink:0;
}
.garment-chip .dot::after{content:'×'}
.garment-chip.on .dot{background:var(--accent);border-color:var(--accent);color:#fff}
.garment-chip.on .dot::after{content:'✓'}
.garment-chips .chip-actions{margin-left:auto;display:flex;gap:5px;align-items:center;flex-shrink:0}
.garment-chips .clear, .garment-chips .reset{
  font-size:9.5px;font-weight:800;color:var(--muted);
  background:transparent;border:1px solid var(--hair);cursor:pointer;
  font-family:inherit;letter-spacing:.12em;text-transform:uppercase;
  padding:5px 9px;border-radius:6px;transition:all .2s;line-height:1;
}
.garment-chips .clear:hover, .garment-chips .reset:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}
/* Sections still hide when toggled off — content shouldn't appear when filtered. */
section[data-garment].hidden{display:none}
/* Rail items STAY visible when toggled off — just dimmed and non-clickable.
   This way the user can always see the full menu structure and toggle anything
   back on by clicking the matching chip at the top. */
.pillar-rail a[data-target].dim{
  opacity:.42;
  text-decoration:line-through;
  text-decoration-thickness:1.5px;
  text-decoration-color:var(--muted-2);
  pointer-events:none;
}
.pillar-rail a[data-target].dim::before{opacity:.3}
/* Rail groups stay visible regardless of how many items are off. */
