/* ============================================================
   FCGX — Case study template · shared styles
   Used by all case-*.html pages. Page content is markup-only.
   ============================================================ */

body.case{line-height:1.55}
.case .wrap{max-width:1180px}

/* HERO */
.c-hero{padding-top:clamp(28px,4.5vw,58px)}
.c-hero .tophead-grid{margin-bottom:clamp(40px,6vw,72px)}
.kicker{margin-bottom:30px}
.c-title{font-size:calc(clamp(2.7rem,9.6vw,8.6rem) * var(--display-scale,1));margin-bottom:30px}
.c-sub{max-width:700px;font-size:clamp(1.18rem,2vw,1.55rem);font-weight:500;line-height:1.38;margin-bottom:50px}
.facts{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:26px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:28px 0;margin-bottom:56px}
.facts dt{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:9px}
.facts dd{font-size:15px;font-weight:600;line-height:1.35}
.hero-fig{width:100%;aspect-ratio:16/9}

/* SECTIONS */
.case section{padding-top:84px}
.grid2{display:grid;grid-template-columns:320px 1fr;gap:60px;align-items:start}
.s-idx b{display:block;font-size:clamp(1.45rem,2.4vw,2.05rem);font-weight:800;letter-spacing:-.02em;color:var(--ink);text-transform:none;margin-top:18px;line-height:1.05;text-wrap:pretty}
.s-body p{font-size:clamp(1.05rem,1.5vw,1.28rem);line-height:1.58;margin-bottom:20px;max-width:660px}
.s-body p b{color:var(--accent)}
.pull{font-size:clamp(1.45rem,2.6vw,2.1rem);font-weight:800;letter-spacing:-.02em;line-height:1.16;max-width:760px;margin:10px 0 0}
.note{font-size:12.5px;font-weight:700;letter-spacing:.05em;color:var(--accent);text-transform:uppercase;margin-top:20px;display:inline-flex;gap:12px;align-items:center}
.note::before{content:"";width:30px;height:1.5px;background:var(--accent)}

/* FIGURES */
figure{margin:36px 0 0}
figure.full{margin-top:42px}
.cap{font-size:12.5px;font-weight:600;letter-spacing:.02em;color:var(--ink-soft);margin-top:14px;padding-left:2px;max-width:760px}
.fig-16x9{aspect-ratio:16/9}
.fig-4x3{aspect-ratio:4/3}
.fig-3x4{aspect-ratio:3/4}
.fig-sq{aspect-ratio:1/1}
/* natural — full image, no crop */
.fig-natural img{width:100%;height:auto;display:block}
.two-up{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:42px;align-items:start}
.three-up{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:42px;align-items:start}
.carousel3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.carousel3 img{width:100%;height:auto;aspect-ratio:1;object-fit:cover;display:block;border:1px solid var(--line);border-radius:3px;background:var(--paper-2)}
/* contain card — for boards / marks that must not crop */
.contain-card{background:#fff;border:1px solid var(--line);border-radius:3px;display:flex;align-items:center;justify-content:center;padding:8%}
.contain-card img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block}

/* NEXT — inverted band */
.next-band{background:var(--ink);color:var(--paper);margin-top:110px}
.next-band a{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:clamp(44px,6vw,72px) 0;color:inherit}
.next-band .lbl{margin-bottom:16px;color:rgba(242,239,230,.6)}
.next-band .ttl{font-size:calc(clamp(2rem,6.5vw,4.8rem) * var(--display-scale,1));font-weight:900;letter-spacing:var(--disp-track);text-transform:uppercase;line-height:.9;transition:color .22s}
.next-band a:hover .ttl{color:var(--accent)}
.next-band .ar{font-size:clamp(34px,4.5vw,56px);font-weight:800;color:var(--accent);transition:transform .3s cubic-bezier(.2,.7,.2,1)}
.next-band a:hover .ar{transform:translateX(10px)}

.c-foot{padding:44px 0 64px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px;font-size:14px;font-weight:600}
.c-foot a:hover{color:var(--accent)}

@media(max-width:820px){
  .grid2{grid-template-columns:1fr;gap:24px}
  .facts{grid-template-columns:1fr 1fr;gap:24px}
  .two-up{grid-template-columns:1fr}
  .three-up{grid-template-columns:1fr 1fr}
}
