/* ============================================================
   GET UP NOW — Benedikt Heizmann
   v2 · "Strength Editorial" — fotografie-getrieben, roh, premium
   ============================================================ */

:root{
  --ink:        oklch(0.135 0.004 60);   /* deeper, more neutral black */
  --ink-2:      oklch(0.166 0.005 62);
  --ink-deep:   oklch(0.100 0.003 60);   /* near-true-black for depth stages */
  --panel:      oklch(0.198 0.006 64);
  --panel-2:    oklch(0.244 0.008 66);
  --line:       oklch(0.43 0.008 70 / 0.42);
  --line-soft:  oklch(0.43 0.008 70 / 0.20);

  --bone:       oklch(0.948 0.006 86);
  --bone-2:     oklch(0.908 0.009 86);
  --on-bone:    oklch(0.195 0.010 70);
  --on-bone-mut:oklch(0.44 0.010 72);

  --text:  oklch(0.972 0.003 88);
  --muted: oklch(0.74 0.009 84);
  --faint: oklch(0.56 0.009 84);

  /* refined warm amber — drawn from the orange bar in the hero shot, toned to premium */
  --accent:      oklch(0.78 0.125 52);
  --accent-deep: oklch(0.67 0.150 46);
  --accent-soft: oklch(0.78 0.125 52 / 0.11);
  --accent-line: oklch(0.78 0.125 52 / 0.32);

  --ff-display: "Anton", "Archivo", sans-serif;
  --ff-alt: "Archivo", system-ui, sans-serif;
  --ff-body: "Manrope", system-ui, sans-serif;
  --ff-serif: "Instrument Serif", Georgia, serif;
  --ff-mono: "Space Mono", ui-monospace, monospace;

  --maxw: 1320px;
  --gutter: clamp(22px, 5.2vw, 76px);
  --ease: cubic-bezier(0.22, 1, 0.36, 1);

  --shadow-card:  0 2px 5px oklch(0 0 0 / 0.22), 0 22px 48px -28px oklch(0 0 0 / 0.72);
  --shadow-float: 0 40px 90px -44px oklch(0 0 0 / 0.85);
}

*,*::before,*::after{ box-sizing:border-box; min-width:0; }
*{ margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

html{ overflow-x:hidden; }
body{
  font-family:var(--ff-body);
  background:var(--ink);
  color:var(--text);
  line-height:1.62;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* film grain — echoes the grunge logo, kills flat-digital feel */
body::after{
  content:""; position:fixed; inset:0; z-index:9998; pointer-events:none; opacity:.038; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; background:none; border:none; }
ul{ list-style:none; }
::selection{ background:var(--accent); color:oklch(0.18 0.02 70); }

/* keyboard focus visibility (a11y) */
:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; border-radius:2px; }
:focus:not(:focus-visible){ outline:none; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(72px,10vw,150px); position:relative; }
.section--bone{ background:var(--bone); color:var(--on-bone); }
.section--tight{ padding-block:clamp(56px,7vw,104px); }

/* ---------- Kicker / editorial section head ---------- */
.kicker{ display:flex; align-items:center; gap:16px; font-family:var(--ff-mono); font-size:12px; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); }
.section--bone .kicker{ color:var(--on-bone-mut); }
.kicker .idx{ color:var(--accent); }
.kicker .rule{ flex:1; height:1px; background:var(--line); max-width:120px; }
.section--bone .kicker .rule{ background:oklch(0.205 0.012 70 / 0.25); }

.display{ font-family:var(--ff-display); font-weight:400; line-height:0.94; letter-spacing:0.005em; text-transform:uppercase; }
.title{ font-family:var(--ff-display); font-weight:400; text-transform:uppercase; line-height:0.95; letter-spacing:0.006em; font-size:clamp(38px,6vw,82px); margin-top:24px; }
.title em,
.hero h1 em,
.cta h2 em,
.band h2 em,
.rev__video-copy h3 em{
  font-family:var(--ff-serif); font-style:italic; font-weight:400;
  text-transform:none; color:var(--accent);
  letter-spacing:-0.005em; font-size:1.08em; line-height:0.86;
  padding-right:0.04em;
}
.lead{ font-size:clamp(17px,1.55vw,20px); color:var(--muted); max-width:58ch; margin-top:24px; line-height:1.6; }
.section--bone .lead{ color:var(--on-bone-mut); }
.accent{ color:var(--accent); }

/* ---------- Buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:12px; padding:16px 28px; border-radius:5px; font-family:var(--ff-alt); font-weight:700; font-size:15px; letter-spacing:0.01em; transition:transform .25s var(--ease), background .25s, color .25s, border-color .25s; white-space:nowrap; }
.btn svg{ width:16px; height:16px; }
.btn--accent{ background:var(--accent); color:oklch(0.19 0.02 70); }
.btn--accent:hover{ transform:translateY(-2px); background:oklch(0.85 0.135 82); }
.btn--solid{ background:var(--text); color:var(--ink); }
.btn--solid:hover{ transform:translateY(-2px); background:#fff; }
.btn--ghost{ border:1px solid var(--line); color:var(--text); }
.btn--ghost:hover{ border-color:var(--accent-line); color:var(--accent); transform:translateY(-2px); }
.section--bone .btn--ghost{ border-color:oklch(0.2 0.01 70 / 0.25); color:var(--on-bone); }
.section--bone .btn--ghost:hover{ border-color:var(--accent-deep); color:var(--accent-deep); }
.btn--lg{ padding:19px 36px; font-size:16px; }

/* arrow link */
.alink{ display:inline-flex; align-items:center; gap:10px; font-family:var(--ff-alt); font-weight:700; font-size:14px; letter-spacing:0.02em; color:var(--text); border-bottom:2px solid var(--accent-line); padding-bottom:5px; transition:gap .25s var(--ease), border-color .25s; text-transform:uppercase; }
.alink:hover{ gap:16px; border-color:var(--accent); }
.alink svg{ width:15px; height:15px; color:var(--accent); }

/* ---------- Nav ---------- */
.nav{ position:fixed; inset:0 0 auto 0; z-index:100; transition:background .35s var(--ease), border-color .35s, backdrop-filter .35s; border-bottom:1px solid transparent; }
.nav::before{ content:""; position:absolute; inset:0 0 auto 0; height:150px; background:linear-gradient(180deg, oklch(0.10 0.006 62 / 0.6), transparent); pointer-events:none; transition:opacity .35s; z-index:-1; }
.nav.scrolled::before{ opacity:0; }
.nav.scrolled{ background:oklch(0.150 0.006 62 / 0.78); backdrop-filter:blur(18px) saturate(1.2); border-bottom-color:var(--line-soft); }
.nav__inner{ display:flex; align-items:center; justify-content:space-between; height:78px; }
.brand{ display:flex; align-items:center; gap:13px; }
.brand__logo{ height:44px; width:auto; filter:invert(1); }
.brand__wm{ font-family:var(--ff-alt); font-weight:800; font-size:17px; letter-spacing:0.02em; line-height:1; }
.brand__wm small{ display:block; font-family:var(--ff-mono); font-weight:400; font-size:9.5px; letter-spacing:0.16em; color:var(--accent); margin-top:4px; }
.nav__links{ display:flex; align-items:center; gap:30px; }
.nav__links a{ font-family:var(--ff-alt); font-weight:600; font-size:13.5px; letter-spacing:0.02em; text-transform:uppercase; color:var(--muted); transition:color .2s; position:relative; }
.nav__links a:hover{ color:var(--text); }
.nav__links a.active{ color:var(--text); }
.nav__links a.active::after{ content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px; background:var(--accent); }
.nav__cta{ display:flex; align-items:center; gap:14px; }
.nav__burger{ display:none; width:44px; height:44px; border:1px solid var(--line); border-radius:6px; place-items:center; }
.nav__burger span, .nav__burger span::before, .nav__burger span::after{ content:""; display:block; width:18px; height:2px; background:var(--text); position:relative; }
.nav__burger span::before{ position:absolute; top:-6px; }
.nav__burger span::after{ position:absolute; top:6px; }
@media (max-width:1040px){ .nav__links{ display:none; } .nav__cta .btn--ghost{ display:none; } .nav__burger{ display:grid; } .brand__wm{ display:none; } }

.mobile-menu{ position:fixed; inset:78px 0 auto 0; z-index:99; background:oklch(0.150 0.006 62 / 0.97); backdrop-filter:blur(16px); border-bottom:1px solid var(--line); padding:16px var(--gutter) 28px; display:none; flex-direction:column; transform:translateY(-10px); opacity:0; pointer-events:none; transition:opacity .3s var(--ease), transform .3s var(--ease); }
.mobile-menu.open{ display:flex; opacity:1; transform:none; pointer-events:auto; }
.mobile-menu a{ padding:15px 2px; font-family:var(--ff-display); text-transform:uppercase; font-size:24px; border-bottom:1px solid var(--line-soft); }
.mobile-menu .btn{ margin-top:20px; justify-content:center; }

/* ---------- Hero ---------- */
.hero{ position:relative; min-height:100svh; display:grid; grid-template-columns:1.08fr 0.92fr; }
.hero__text{ display:flex; flex-direction:column; justify-content:center; padding:120px var(--gutter) 150px; max-width:760px; margin-left:auto; width:100%; }
.hero__tag{ display:inline-flex; align-items:center; gap:11px; font-family:var(--ff-mono); font-size:12px; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted); margin-bottom:30px; }
.hero__tag b{ color:var(--accent); }
.hero__tag .dot{ width:7px; height:7px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 4px var(--accent-soft); }
.hero h1{ font-family:var(--ff-display); font-weight:400; text-transform:uppercase; font-size:clamp(40px,5.6vw,96px); line-height:0.9; letter-spacing:0.004em; }

.hero__sub{ margin-top:26px; color:var(--muted); font-size:clamp(15.5px,1.4vw,17.5px); max-width:46ch; list-style:none; padding:0; display:flex; flex-direction:column; gap:10px; }
.hero__sub li{ display:flex; align-items:baseline; gap:10px; }
.hero__sub li::before{ content:""; display:inline-block; flex:none; width:5px; height:5px; border-radius:50%; background:var(--accent); margin-top:0.5em; }
.hero__note{ margin-top:18px; color:var(--muted); font-size:clamp(14px,1.2vw,15.5px); max-width:46ch; }
.hero__note b{ color:var(--text); font-weight:600; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:38px; }
.hero__photo{ position:relative; overflow:hidden; background:var(--ink-2); }
.hero__photo .hero__bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:50% 22%; }
.hero__photo::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg, var(--ink) 0%, transparent 26%), linear-gradient(0deg, var(--ink) 1%, transparent 22%); }
.hero__stamp{ position:absolute; right:clamp(20px,3vw,46px); top:clamp(98px,12vh,150px); width:clamp(64px,7vw,104px); height:auto; filter:invert(1); opacity:.85; z-index:2; }


@media (max-width:980px){
  .hero{ grid-template-columns:1fr; min-height:auto; }
  .hero__photo{ height:62svh; order:-1; }
  .hero__photo img{ object-position:50% 12%; }
  .hero__photo::after{ background:linear-gradient(0deg, var(--ink) 2%, transparent 50%); }
  .hero__stamp{ top:96px; }
  .hero__text{ padding:48px var(--gutter) 56px; margin:0; }
}

/* ---------- Marquee ---------- */
.ticker{ border-block:1px solid var(--line); background:var(--ink-2); padding:18px 0; overflow:hidden; }
.ticker__track{ display:flex; gap:0; width:max-content; animation:tick 36s linear infinite; }
@media (prefers-reduced-motion: reduce){ .ticker__track{ animation:none; } }
.ticker__item{ display:inline-flex; align-items:center; gap:34px; padding-right:34px; font-family:var(--ff-display); text-transform:uppercase; font-size:19px; letter-spacing:0.02em; color:var(--text); white-space:nowrap; }
.ticker__item .sep{ color:var(--accent); font-family:var(--ff-body); }
@keyframes tick{ to{ transform:translateX(-50%); } }

/* ---------- About ---------- */
.about__grid{ display:grid; grid-template-columns:0.96fr 1.04fr; gap:clamp(34px,5vw,78px); align-items:center; }
.about__media{ position:relative; }
.about__media img{ width:100%; border:1px solid var(--line); }
.about__media .cap{ position:absolute; left:0; bottom:-1px; background:var(--ink); border:1px solid var(--line); border-left:none; border-bottom:none; padding:11px 18px; font-family:var(--ff-mono); font-size:11px; letter-spacing:0.06em; text-transform:uppercase; color:var(--muted); }
.about__big{ display:flex; align-items:baseline; gap:18px; margin:34px 0; padding-bottom:30px; border-bottom:1px solid var(--line); }
.about__big .num{ font-family:var(--ff-display); font-size:clamp(64px,9vw,120px); line-height:0.8; color:var(--accent); }
.about__big .txt{ font-family:var(--ff-alt); font-weight:700; font-size:clamp(16px,1.6vw,19px); text-transform:uppercase; letter-spacing:0.02em; line-height:1.25; }
.about__big .txt span{ display:block; color:var(--muted); font-weight:500; text-transform:none; letter-spacing:0; font-size:0.85em; margin-top:4px; }
.about p + p{ margin-top:16px; }

/* credentials inline row */
.creds{ display:flex; flex-wrap:wrap; gap:10px; margin-top:30px; }
.creds span{ font-family:var(--ff-mono); font-size:11.5px; letter-spacing:0.04em; text-transform:uppercase; color:var(--muted); border:1px solid var(--line); padding:9px 14px; border-radius:100px; }
.creds span b{ color:var(--accent); font-weight:400; }

/* ---------- GCL band ---------- */
.gcl{ margin-top:clamp(60px,8vw,110px); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.gcl__inner{ display:grid; grid-template-columns:auto repeat(3,1fr); }
.gcl__lead{ padding:34px clamp(24px,3vw,44px) 34px 0; display:flex; flex-direction:column; justify-content:center; max-width:340px; border-right:1px solid var(--line); }
.gcl__lead .tag{ font-family:var(--ff-mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--accent); }
.gcl__lead h3{ font-family:var(--ff-display); text-transform:uppercase; font-size:clamp(24px,2.4vw,34px); line-height:0.96; margin-top:12px; }
.gcl__cell{ padding:34px clamp(18px,2.4vw,40px); border-right:1px solid var(--line); display:flex; flex-direction:column; justify-content:center; }
.gcl__cell:last-child{ border-right:none; }
.gcl__cell .n{ font-family:var(--ff-display); font-size:clamp(44px,5.5vw,76px); line-height:0.85; color:var(--text); font-variant-numeric:tabular-nums; }
.gcl__cell .l{ font-family:var(--ff-mono); font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--muted); margin-top:12px; }
@media (max-width:860px){
  .gcl__inner{ grid-template-columns:1fr 1fr; }
  .gcl__lead{ grid-column:1/-1; max-width:none; border-right:none; border-bottom:1px solid var(--line); padding-right:0; }
  .gcl__cell:nth-child(2){ border-right:1px solid var(--line); }
  .gcl__cell:nth-child(3){ border-right:none; }
  .gcl__cell:nth-child(-n+3){ }
  .gcl__cell{ border-bottom:1px solid var(--line); }
}

/* ---------- Method (editorial list) ---------- */
.method__head{ display:grid; grid-template-columns:1fr 1fr; gap:30px; align-items:end; }
.steps{ margin-top:clamp(40px,5vw,68px); border-top:1px solid var(--line); }
.step{ display:grid; grid-template-columns:120px 1fr 1.3fr; gap:clamp(16px,3vw,48px); align-items:baseline; padding:clamp(26px,3.2vw,40px) 0; border-bottom:1px solid var(--line); transition:padding-left .35s var(--ease); }
.step:hover{ padding-left:14px; }
.step__n{ font-family:var(--ff-display); font-size:clamp(34px,4vw,58px); color:var(--accent); line-height:0.8; }
.step__t{ font-family:var(--ff-display); text-transform:uppercase; font-size:clamp(22px,2.2vw,32px); line-height:0.96; }
.step__d{ color:var(--muted); font-size:clamp(16px,1.6vw,18.5px); line-height:1.62; }
@media (max-width:760px){ .step{ grid-template-columns:64px 1fr; } .step__d{ grid-column:1/-1; } }

/* ---------- Services (menu list) ---------- */
.svc__list{ margin-top:clamp(40px,5vw,68px); border-top:1px solid var(--line); }
.svc{ position:relative; display:grid; grid-template-columns:auto 1fr auto; gap:clamp(16px,3vw,44px); align-items:center; padding:clamp(26px,3.4vw,42px) 0; border-bottom:1px solid var(--line); transition:padding-left .4s var(--ease); }
.svc:hover{ padding-left:16px; }
.svc__idx{ font-family:var(--ff-mono); font-size:13px; color:var(--accent); align-self:start; padding-top:10px; }
.svc__main{ display:flex; flex-direction:column; gap:10px; }
.svc h3{ font-family:var(--ff-display); text-transform:uppercase; font-size:clamp(26px,3.4vw,48px); line-height:0.92; }
.svc__main p{ color:var(--muted); font-size:15.5px; max-width:60ch; }
.svc__tag{ font-family:var(--ff-mono); font-size:10.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--accent); border:1px solid var(--accent-line); padding:6px 12px; border-radius:100px; white-space:nowrap; }
.svc__arrow{ width:46px; height:46px; border-radius:50%; border:1px solid var(--line); display:grid; place-items:center; color:var(--text); transition:background .3s, color .3s, border-color .3s, transform .3s var(--ease); }
.svc__arrow svg{ width:18px; height:18px; }
.svc:hover .svc__arrow{ background:var(--accent); color:var(--ink); border-color:var(--accent); transform:rotate(-45deg); }
@media (max-width:760px){ .svc{ grid-template-columns:auto 1fr; } .svc__arrow{ display:none; } .svc__tag{ align-self:start; } }

/* ---------- Full-bleed photo band ---------- */
.band{ position:relative; min-height:clamp(360px,52vw,620px); display:flex; align-items:flex-end; overflow:hidden; }
.band img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:50% 38%; }
.band::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg, oklch(0.12 0.006 62 / 0.86) 0%, oklch(0.12 0.006 62 / 0.30) 55%, transparent 100%), linear-gradient(0deg, oklch(0.12 0.006 62 / 0.7), transparent 50%); }
.band__inner{ position:relative; z-index:2; padding:clamp(40px,6vw,90px) var(--gutter); width:100%; max-width:var(--maxw); margin-inline:auto; }
.band h2{ font-family:var(--ff-display); text-transform:uppercase; font-size:clamp(30px,4.6vw,68px); line-height:0.94; max-width:18ch; }
.band p{ color:var(--muted); margin-top:18px; max-width:48ch; font-size:clamp(16px,1.5vw,19px); }
.band .accent{ color:var(--accent); }

/* ---------- App ---------- */
.app__grid{ display:grid; grid-template-columns:1fr 0.8fr; gap:clamp(34px,5vw,80px); align-items:center; }
.app__feats{ display:grid; gap:24px; margin-top:34px; border-top:1px solid var(--line); padding-top:30px; }
.app__feat{ display:grid; grid-template-columns:auto 1fr; gap:18px; align-items:start; }
.app__feat .fn{ font-family:var(--ff-mono); font-size:12px; color:var(--accent); padding-top:4px; }
.app__feat h4{ font-family:var(--ff-alt); font-weight:700; font-size:17px; }
.app__feat p{ color:var(--muted); font-size:14.5px; margin-top:4px; }
.phone{ width:264px; max-width:74vw; aspect-ratio:9/19.5; margin-inline:auto; border-radius:38px; border:1px solid var(--line-soft); background:oklch(0.12 0.005 64); padding:11px; box-shadow:0 50px 90px -45px oklch(0 0 0 / 0.85), inset 0 0 0 7px oklch(0.10 0.004 64); position:relative; }
.phone::before{ content:""; position:absolute; top:16px; left:50%; transform:translateX(-50%); width:84px; height:21px; background:oklch(0.10 0.004 64); border-radius:100px; z-index:4; }
.phone__screen{ width:100%; height:100%; border-radius:29px; overflow:hidden; position:relative; }

/* placeholder */
.ph{ position:relative; width:100%; height:100%; min-height:120px; background:repeating-linear-gradient(135deg, oklch(0.20 0.006 66) 0 2px, transparent 2px 12px), linear-gradient(160deg, oklch(0.22 0.007 66), oklch(0.17 0.006 64)); display:grid; place-items:center; text-align:center; }
.ph__label{ font-family:var(--ff-mono); font-size:11px; letter-spacing:0.06em; text-transform:uppercase; color:var(--muted); padding:8px 14px; border:1px dashed var(--line); border-radius:100px; background:oklch(0.15 0.005 64 / 0.8); max-width:80%; }

/* in-app mock screen */
.appui{ position:absolute; inset:0; background:linear-gradient(180deg, var(--ink-2), var(--ink)); padding:40px 15px 13px; display:flex; flex-direction:column; gap:11px; font-family:var(--ff-body); color:var(--text); }
.appui__top{ display:flex; justify-content:space-between; align-items:center; }
.appui__hi{ font-family:var(--ff-alt); font-weight:800; font-size:14.5px; line-height:1; }
.appui__date{ font-family:var(--ff-mono); font-size:9px; letter-spacing:0.05em; color:var(--accent); text-transform:uppercase; margin-top:5px; }
.appui__ring{ width:40px; height:40px; border-radius:50%; display:grid; place-items:center; position:relative; background:conic-gradient(var(--accent) 78%, oklch(0.30 0.01 70) 0); flex:none; }
.appui__ring::before{ content:""; position:absolute; inset:4px; border-radius:50%; background:var(--ink-2); }
.appui__ring span{ position:relative; z-index:1; font-family:var(--ff-alt); font-weight:800; font-size:10px; }
.appui__card{ background:var(--panel); border:1px solid var(--line); border-radius:13px; padding:12px 13px; }
.appui__card-h{ display:flex; justify-content:space-between; font-family:var(--ff-mono); font-size:8.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.appui__ex{ display:flex; gap:9px; align-items:center; padding:6.5px 0; border-top:1px solid var(--line-soft); }
.appui__ex:first-of-type{ border-top:none; }
.appui__ex .d{ width:17px; height:17px; border-radius:50%; border:1px solid var(--line); display:grid; place-items:center; font-size:9px; color:var(--faint); flex:none; }
.appui__ex .d.done{ background:var(--accent); border-color:var(--accent); color:var(--ink); }
.appui__ex .d.now{ border-color:var(--accent); color:var(--accent); }
.appui__ex .t b{ font-size:11.5px; font-weight:700; display:block; line-height:1.2; }
.appui__ex .t small{ font-size:9px; color:var(--muted); }
.appui__row{ display:grid; grid-template-columns:1fr 1fr; gap:7px; }
.appui__mini{ background:var(--panel); border:1px solid var(--line); border-radius:10px; padding:9px 10px; }
.appui__mini .n{ font-family:var(--ff-alt); font-weight:800; font-size:14px; line-height:1; }
.appui__mini .n.accent{ color:var(--accent); }
.appui__mini .l{ font-size:8.5px; color:var(--muted); text-transform:uppercase; letter-spacing:0.05em; margin-top:4px; }
.appui__chat{ display:flex; gap:7px; align-items:flex-end; }
.appui__chat .av{ width:24px; height:24px; border-radius:50%; background:var(--accent); color:var(--ink); display:grid; place-items:center; font-family:var(--ff-alt); font-weight:800; font-size:10px; flex:none; }
.appui__chat .bubble{ background:var(--panel); border:1px solid var(--line); border-radius:11px; border-bottom-left-radius:3px; padding:7px 10px; font-size:10px; color:var(--text); line-height:1.4; }
.appui__nav{ margin-top:auto; display:flex; justify-content:space-between; padding-top:10px; border-top:1px solid var(--line); }
.appui__nav span{ font-family:var(--ff-mono); font-size:8px; letter-spacing:0.03em; text-transform:uppercase; color:var(--faint); }
.appui__nav span.on{ color:var(--accent); }

/* in-app screenshot slider */
.phone--app::before{ display:none; }
.appslider{ position:absolute; inset:0; overflow:hidden; border-radius:29px; background:#0e1116; }
.appslider__track{ display:flex; height:100%; transition:transform .55s var(--ease); }
.appslider__track img{ min-width:100%; width:100%; height:100%; object-fit:cover; object-position:top center; }
.appslider__dots{ position:absolute; bottom:9px; left:0; right:0; display:flex; gap:6px; justify-content:center; z-index:3; }
.appslider__dots button{ width:7px; height:7px; border-radius:50%; background:oklch(1 0 0 / 0.45); transition:background .3s var(--ease), width .3s var(--ease); }
.appslider__dots button.on{ background:var(--accent); width:18px; border-radius:4px; }

/* ---------- Transformations ---------- */
.trans__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,26px); margin-top:clamp(40px,5vw,64px); }
.trans figure{ border:1px solid var(--line); background:var(--ink-2); }
.trans__img{ position:relative; aspect-ratio:4/5; overflow:hidden; }
.trans__img img{ width:100%; height:100%; object-fit:cover; object-position:center top; transition:transform .7s var(--ease); }
.trans figure:hover .trans__img img{ transform:scale(1.04); }
.trans__ba{ position:absolute; top:12px; left:12px; z-index:2; font-family:var(--ff-mono); font-size:10px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink); background:var(--accent); padding:5px 9px; border-radius:3px; }
.trans figcaption{ padding:20px 22px; }
.trans figcaption .trans__cat{ font-family:var(--ff-mono); font-size:10.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--accent); }
.trans figcaption .st{ color:var(--accent); font-size:13px; letter-spacing:1px; }
.trans figcaption p{ font-size:15px; color:var(--text); margin-top:10px; line-height:1.55; }
.trans figcaption .who{ font-family:var(--ff-mono); font-size:11.5px; letter-spacing:0.04em; text-transform:uppercase; color:var(--faint); margin-top:14px; }
@media (max-width:820px){ .trans__grid{ grid-template-columns:1fr 1fr; } .trans__img{ aspect-ratio:3/4; } }
@media (max-width:560px){ .trans__grid{ grid-template-columns:1fr; } .trans__img{ aspect-ratio:auto; max-height:none; } .trans__img img{ height:auto; position:relative; object-fit:contain; object-position:center; max-width:100%; } }

/* ---------- Gallery (masonry) ---------- */
.gallery{ columns:3; column-gap:14px; margin-top:clamp(40px,5vw,64px); }
.gallery figure{ break-inside:avoid; margin:0 0 14px; border:1px solid var(--line); overflow:hidden; background:var(--ink-2); position:relative; }
.gallery img{ width:100%; display:block; transition:transform .8s var(--ease); }
.gallery figure:hover img{ transform:scale(1.05); }
@media (max-width:900px){ .gallery{ columns:2; } }
@media (max-width:560px){ .gallery{ columns:1; } }

/* ---------- Reviews ---------- */
.rev__top{ display:grid; grid-template-columns:1fr auto; gap:34px; align-items:end; }
.rev__score{ text-align:right; }
.rev__score .big{ font-family:var(--ff-display); font-size:clamp(56px,7vw,92px); line-height:0.8; color:var(--accent); }
.rev__score .stars{ color:var(--accent); font-size:18px; letter-spacing:2px; margin-top:8px; }
.rev__score .sub{ font-family:var(--ff-mono); font-size:11.5px; letter-spacing:0.04em; text-transform:uppercase; color:var(--on-bone-mut); margin-top:8px; }
.stars{ color:var(--accent); letter-spacing:1px; }
.rev__quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,24px); margin-top:clamp(36px,4vw,56px); }
.quote{ border-top:2px solid var(--on-bone); padding-top:22px; display:flex; flex-direction:column; }
.quote .stars{ font-size:15px; }
.quote p{ margin-top:14px; font-size:15.5px; color:var(--on-bone); line-height:1.6; flex:1; }
.quote .who{ font-family:var(--ff-mono); font-size:11.5px; letter-spacing:0.03em; text-transform:uppercase; color:var(--on-bone-mut); margin-top:20px; }
@media (max-width:820px){ .rev__quotes{ grid-template-columns:1fr; } .rev__top{ grid-template-columns:1fr; } .rev__score{ text-align:left; } }

/* PersonalFitness widget panel */
.pf-panel{ margin-top:clamp(36px,4vw,56px); background:#fff; border:1px solid var(--bone-2); border-radius:10px; padding:clamp(20px,3vw,36px); box-shadow:0 30px 60px -40px oklch(0.2 0.01 70 / 0.4); }
.pf-panel__head{ display:flex; align-items:center; gap:12px; font-family:var(--ff-mono); font-size:11.5px; letter-spacing:0.08em; text-transform:uppercase; color:var(--on-bone-mut); margin-bottom:20px; }
.pf-panel__head .dot{ width:7px; height:7px; border-radius:50%; background:oklch(0.62 0.17 145); box-shadow:0 0 0 4px oklch(0.62 0.17 145 / 0.18); }

/* video testimonial block */
.rev__video{ display:grid; grid-template-columns:1fr 1fr 1.15fr; gap:clamp(20px,2.8vw,44px); align-items:center; margin-top:clamp(40px,5vw,64px); padding-top:clamp(40px,5vw,60px); border-top:1px solid oklch(0.205 0.012 70 / 0.18); }
.rev__player{ position:relative; aspect-ratio:9/16; max-width:340px; width:100%; border-radius:14px; overflow:hidden; border:1px solid var(--bone-2); background:#000; box-shadow:0 40px 70px -40px oklch(0.2 0.01 70 / 0.5); }
.rev__player iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.rev__player video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.rev__playbtn{ position:absolute; inset:0; z-index:2; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:16px; background:linear-gradient(0deg, oklch(0.12 0.006 62 / 0.55), oklch(0.12 0.006 62 / 0.15)); transition:opacity .3s, background .3s; }
.rev__playbtn:hover{ background:linear-gradient(0deg, oklch(0.12 0.006 62 / 0.45), oklch(0.12 0.006 62 / 0.1)); }
.rev__playbtn.hidden{ opacity:0; pointer-events:none; }
.rev__playicon{ width:68px; height:68px; border-radius:50%; background:var(--accent); display:grid; place-items:center; box-shadow:0 16px 40px -12px oklch(0 0 0 / 0.6); transition:transform .3s var(--ease); }
.rev__playbtn:hover .rev__playicon{ transform:scale(1.08); }
.rev__playicon::before{ content:""; border-left:20px solid oklch(0.18 0.02 70); border-block:12px solid transparent; margin-left:5px; }
.rev__playlabel{ font-family:var(--ff-mono); font-size:11.5px; letter-spacing:0.08em; text-transform:uppercase; color:#fff; }
.rev__video-copy .vk{ font-family:var(--ff-mono); font-size:11.5px; letter-spacing:0.12em; text-transform:uppercase; color:var(--accent-deep); }
.rev__video-copy h3{ font-family:var(--ff-display); text-transform:uppercase; font-size:clamp(28px,3.4vw,46px); line-height:0.96; margin-top:14px; color:var(--on-bone); }
.rev__video-copy p{ color:var(--on-bone-mut); font-size:16px; margin-top:16px; max-width:42ch; }
.rev__video-copy .alink{ margin-top:24px; color:var(--on-bone); border-color:oklch(0.205 0.012 70 / 0.3); }
.rev__video-copy .alink:hover{ border-color:var(--accent-deep); color:var(--accent-deep); }
@media (max-width:980px){ .rev__video{ grid-template-columns:1fr 1fr; } .rev__video-copy{ grid-column:1/-1; } }
@media (max-width:600px){ .rev__video{ grid-template-columns:1fr; } .rev__player{ margin-inline:auto; } }

/* ---------- Packages ---------- */
.pkg__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,22px); margin-top:clamp(40px,5vw,64px); align-items:stretch; }
.pkg{ border:1px solid var(--line); background:var(--ink-2); padding:clamp(28px,3vw,38px); display:flex; flex-direction:column; transition:transform .35s var(--ease), border-color .35s, background .35s; }
.pkg:hover{ transform:translateY(-6px); border-color:var(--accent-line); }
.pkg--feat{ background:linear-gradient(168deg, var(--accent-soft), transparent 50%), var(--panel); border-color:var(--accent-line); }
.pkg__flag{ align-self:flex-start; font-family:var(--ff-mono); font-size:10.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink); background:var(--accent); padding:6px 12px; border-radius:3px; margin-bottom:18px; }
.pkg__name{ font-family:var(--ff-display); text-transform:uppercase; font-size:clamp(26px,2.6vw,36px); line-height:0.92; }
.pkg__desc{ color:var(--muted); font-size:14px; margin-top:12px; min-height:40px; }
.pkg__price{ margin-top:22px; padding-top:22px; border-top:1px solid var(--line); }
.pkg__price .amt{ font-family:var(--ff-display); font-size:clamp(30px,3vw,42px); line-height:0.9; }
.pkg__price .note{ font-family:var(--ff-mono); font-size:11.5px; color:var(--faint); margin-top:8px; }
.pkg ul{ margin:24px 0 28px; display:grid; gap:12px; }
.pkg li{ display:flex; gap:11px; align-items:flex-start; font-size:14.5px; color:var(--muted); }
.pkg li svg{ flex:none; width:16px; height:16px; color:var(--accent); margin-top:4px; }
.pkg .btn{ margin-top:auto; justify-content:center; }
@media (max-width:880px){ .pkg__grid{ grid-template-columns:1fr; } }

/* ---------- FAQ ---------- */
.faq__grid{ display:grid; grid-template-columns:0.78fr 1.22fr; gap:clamp(36px,5vw,80px); align-items:start; }
.faq__list{ border-top:1px solid var(--line); }
.faq__item{ border-bottom:1px solid var(--line); }
.faq__q{ width:100%; display:grid; grid-template-columns:auto 1fr auto; gap:18px; align-items:center; padding:24px 0; text-align:left; }
.faq__q .qn{ font-family:var(--ff-mono); font-size:12px; color:var(--accent); }
.faq__q .qt{ font-family:var(--ff-alt); font-weight:700; font-size:clamp(16px,1.7vw,19px); }
.faq__q .pm{ flex:none; width:26px; height:26px; position:relative; }
.faq__q .pm::before,.faq__q .pm::after{ content:""; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); background:var(--text); transition:transform .3s, background .3s; }
.faq__q .pm::before{ width:13px; height:2px; }
.faq__q .pm::after{ width:2px; height:13px; }
.faq__item.open .pm::after{ transform:translate(-50%,-50%) scaleY(0); }
.faq__item.open .pm::before{ background:var(--accent); }
.faq__a{ max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.faq__a-inner{ padding:0 44px 26px 42px; color:var(--muted); font-size:15.5px; }
@media (max-width:860px){ .faq__grid{ grid-template-columns:1fr; } .faq__a-inner{ padding-left:0; padding-right:0; } }

/* ---------- Social ---------- */
.social__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(12px,1.5vw,18px); margin-top:clamp(36px,4vw,56px); }
.social__tile{ position:relative; aspect-ratio:1; overflow:hidden; border:1px solid var(--line); }
.social__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:32px; }
@media (max-width:620px){ .social__grid{ grid-template-columns:1fr 1fr; } }

/* ---------- Final CTA ---------- */
.cta{ position:relative; min-height:clamp(520px,68vh,760px); display:flex; align-items:center; overflow:hidden; }
.cta img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:50% 30%; }
.cta::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, oklch(0.12 0.006 62 / 0.86), oklch(0.12 0.006 62 / 0.64)); }
.cta__inner{ position:relative; z-index:2; width:100%; max-width:var(--maxw); margin-inline:auto; padding:0 var(--gutter); text-align:center; }
.cta h2{ font-family:var(--ff-display); text-transform:uppercase; font-size:clamp(40px,7vw,104px); line-height:0.9; }
.cta h2 em{ font-style:normal; color:var(--accent); }
.cta p{ color:var(--muted); font-size:clamp(16px,1.6vw,20px); max-width:50ch; margin:24px auto 0; }
.cta__actions{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; margin-top:38px; }
.cta__assure{ font-family:var(--ff-mono); font-size:12.5px; letter-spacing:0.04em; color:var(--faint); margin-top:26px; }

/* ---------- Footer ---------- */
.footer{ background:var(--ink-2); border-top:1px solid var(--line); padding-block:clamp(56px,7vw,90px) 40px; position:relative; overflow:hidden; }
.footer__wm{ position:absolute; right:-4%; bottom:-22%; width:min(46vw,560px); filter:invert(1); opacity:0.045; pointer-events:none; }
.footer__grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:44px; position:relative; z-index:2; }
.footer__brand .brand__logo{ height:60px; }
.footer__brand p{ color:var(--muted); font-size:14.5px; margin-top:22px; max-width:38ch; }
.footer h5{ font-family:var(--ff-mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--faint); margin-bottom:18px; }
.footer__col a, .footer__col p{ display:block; color:var(--muted); font-size:14.5px; padding:5px 0; transition:color .2s; }
.footer__col a:hover{ color:var(--accent); }
.footer__bottom{ display:flex; justify-content:space-between; align-items:center; gap:18px; flex-wrap:wrap; margin-top:52px; padding-top:26px; border-top:1px solid var(--line-soft); color:var(--faint); font-size:13px; position:relative; z-index:2; }
.footer__bottom a:hover{ color:var(--accent); }
@media (max-width:760px){ .footer__grid{ grid-template-columns:1fr 1fr; } .footer__brand{ grid-column:1/-1; } }

/* ---------- Reveal ---------- */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.07s; } .reveal.d2{ transition-delay:.14s; } .reveal.d3{ transition-delay:.21s; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* ---------- Legal ---------- */
.legal{ padding-block:140px clamp(60px,9vw,120px); min-height:70vh; }
.legal__wrap{ max-width:820px; }
.legal__back{ display:inline-flex; align-items:center; gap:8px; font-family:var(--ff-mono); font-size:13px; color:var(--muted); margin-bottom:34px; transition:color .2s; }
.legal__back:hover{ color:var(--accent); }
.legal__back svg{ width:15px; height:15px; }
.legal h1{ font-family:var(--ff-display); text-transform:uppercase; font-size:clamp(38px,6vw,64px); line-height:0.94; }
.legal__meta{ font-family:var(--ff-mono); font-size:13px; color:var(--faint); margin-top:16px; }
.legal h2{ font-family:var(--ff-alt); font-weight:800; font-size:clamp(20px,2.4vw,26px); margin-top:50px; padding-top:26px; border-top:1px solid var(--line); }
.legal h3{ font-family:var(--ff-alt); font-weight:700; font-size:17px; margin-top:26px; color:var(--text); }
.legal p,.legal li{ color:var(--muted); font-size:16px; line-height:1.7; margin-top:14px; }
.legal ul{ margin-top:14px; padding-left:22px; list-style:disc; }
.legal li{ margin-top:8px; }
.legal a{ color:var(--accent); text-decoration:underline; text-underline-offset:3px; }
.legal strong{ color:var(--text); }
.legal code{ font-family:var(--ff-mono); font-size:0.86em; color:var(--accent); }
.legal__note{ margin-top:18px; padding:18px 22px; border:1px solid var(--accent-line); background:var(--accent-soft); border-radius:8px; font-size:14.5px; color:var(--muted); }
.legal__note strong{ color:var(--accent); }
.legal address{ font-style:normal; color:var(--muted); line-height:1.8; margin-top:14px; }

/* ============================================================
   v3 · 2026 DEPTH UPGRADE — 3D hero, parallax, refined depth
   ============================================================ */

/* ---- Scroll progress hairline ---- */
.scroll-progress{ position:fixed; top:0; left:0; right:0; height:2px; z-index:200; transform:scaleX(0); transform-origin:0 50%; background:linear-gradient(90deg, var(--accent-deep), var(--accent)); box-shadow:0 0 14px var(--accent-line); pointer-events:none; }
@media (prefers-reduced-motion: reduce){ .scroll-progress{ transition:none; } }

/* ---- Layered hero with WebGL depth ---- */
.hero{ background:var(--ink-deep); isolation:isolate; }
.hero__canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:0; display:block; pointer-events:none; opacity:0; transition:opacity 1.4s var(--ease); }
.hero__canvas.ready{ opacity:1; }
.hero__glow{ position:absolute; z-index:0; left:4%; top:30%; width:46vw; max-width:660px; aspect-ratio:1; background:radial-gradient(circle at 50% 50%, var(--accent-soft) 0%, oklch(0.845 0.072 82 / 0.045) 36%, transparent 66%); filter:blur(14px); pointer-events:none; opacity:.9; }
.hero__text{ position:relative; z-index:2; }
.hero__photo{ z-index:1; }
.hero__noise{ position:absolute; inset:0; z-index:1; pointer-events:none; opacity:.4; background:
  radial-gradient(ellipse 60% 50% at 70% 18%, oklch(0.845 0.072 82 / 0.05), transparent 60%); }
@media (max-width:900px){ .hero__canvas{ display:none; } .hero__glow{ top:auto; bottom:30%; left:-6%; width:70vw; } }

/* parallax layers */
[data-parallax]{ will-change:transform; }
@media (prefers-reduced-motion: reduce){ [data-parallax]{ transform:none !important; } }

/* ---- Refined nav glass ---- */
.nav.scrolled{ background:oklch(0.135 0.004 60 / 0.72); backdrop-filter:blur(22px) saturate(1.3); }
.brand__wm small{ color:var(--accent); }

/* ---- Depth on key surfaces ---- */
.about__media img{ box-shadow:var(--shadow-float); }
.trans figure{ box-shadow:var(--shadow-card); }
.pkg{ box-shadow:var(--shadow-card); }
.pkg--feat{ box-shadow:0 2px 6px oklch(0 0 0 / 0.28), 0 36px 80px -36px oklch(0.845 0.072 82 / 0.22); }
.gallery figure{ box-shadow:var(--shadow-card); }
.band img, .cta img{ will-change:transform; }

/* magnetic primary CTAs (transform driven in JS) */
[data-magnetic]{ will-change:transform; }

/* ---- Section "Weiteres" — understated ---- */
.more__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(16px,2vw,24px); margin-top:clamp(40px,5vw,60px); }
.morecard{ position:relative; overflow:hidden; border:1px solid var(--line); background:linear-gradient(168deg, var(--ink-2), var(--ink)); padding:clamp(26px,3vw,40px); display:flex; flex-direction:column; transition:border-color .4s var(--ease), transform .4s var(--ease); box-shadow:var(--shadow-card); }
.morecard:hover{ border-color:var(--accent-line); transform:translateY(-5px); }
.morecard::after{ content:""; position:absolute; right:-30%; top:-40%; width:60%; aspect-ratio:1; background:radial-gradient(circle, var(--accent-soft), transparent 68%); opacity:0; transition:opacity .5s var(--ease); pointer-events:none; }
.morecard:hover::after{ opacity:1; }
.morecard__k{ display:flex; align-items:center; gap:11px; font-family:var(--ff-mono); font-size:11px; letter-spacing:0.13em; text-transform:uppercase; color:var(--accent); }
.morecard__k .badge{ font-family:var(--ff-mono); font-size:9.5px; letter-spacing:0.08em; color:var(--muted); border:1px solid var(--line); border-radius:100px; padding:3px 9px; }
.morecard h3{ font-family:var(--ff-display); text-transform:uppercase; font-size:clamp(25px,2.7vw,38px); line-height:0.94; margin-top:16px; }
.morecard h3 em{ font-family:var(--ff-serif); font-style:italic; text-transform:none; color:var(--accent); font-size:1.06em; }
.morecard p{ color:var(--muted); font-size:14.5px; margin-top:14px; max-width:46ch; line-height:1.6; }
.morecard__links{ display:flex; flex-wrap:wrap; gap:10px; margin-top:auto; padding-top:26px; }
.storebtn{ display:inline-flex; align-items:center; gap:9px; padding:11px 17px; border:1px solid var(--line); border-radius:8px; font-family:var(--ff-alt); font-weight:700; font-size:13px; letter-spacing:0.01em; color:var(--text); transition:border-color .25s, color .25s, transform .25s var(--ease), background .25s; }
.storebtn:hover{ border-color:var(--accent-line); color:var(--accent); transform:translateY(-2px); }
.storebtn small{ display:block; font-family:var(--ff-mono); font-size:8.5px; letter-spacing:0.06em; color:var(--faint); font-weight:400; }
.storebtn:hover small{ color:var(--accent-deep); }
.storebtn b{ font-size:13.5px; font-weight:700; line-height:1.05; }
.storebtn svg{ width:17px; height:17px; flex:none; }
.storebtn .col{ display:flex; flex-direction:column; line-height:1; text-align:left; }
@media (max-width:760px){ .more__grid{ grid-template-columns:1fr; } }

/* ---- Comprehensive mobile fixes ---- */
@media (max-width:760px){
  /* About — stack */
  .about__grid{ grid-template-columns:1fr; }
  .about__media{ max-width:540px; margin-inline:auto; }
  /* Method head — stack */
  .method__head{ grid-template-columns:1fr; gap:18px; }
  /* App section — stack */
  .app__grid{ grid-template-columns:1fr; }
  .phone{ order:2; max-width:260px; }
  /* Hero text bottom spacing */
  .hero__text{ padding-bottom:40px; }
  /* Hero proof — tighter */
  .hero__proof{ margin-top:24px; padding-top:18px; }
  /* CTA buttons full-width */
  .cta__actions{ flex-direction:column; align-items:center; }
  .cta__actions .btn{ width:100%; max-width:320px; justify-content:center; }
  .hero__actions .btn--lg{ width:100%; justify-content:center; }
  /* Footer bottom */
  .footer__bottom{ flex-direction:column; align-items:flex-start; gap:10px; }
}
@media (max-width:480px){
  .gcl__cell .n{ font-size:clamp(36px,11vw,54px); }
  .pkg{ padding:22px 18px; }
  .quote p{ font-size:15px; }
}

/* GCL competition photos */
.gcl-photos{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(12px,1.6vw,18px); margin-top:clamp(40px,5vw,72px); }
.gcl-photo{ position:relative; overflow:hidden; border:1px solid var(--line); background:var(--ink-2); box-shadow:var(--shadow-card); }
.gcl-photo img{ width:100%; aspect-ratio:4/5; object-fit:cover; object-position:center 22%; display:block; transition:transform .8s var(--ease); }
.gcl-photo:hover img{ transform:scale(1.04); }
.gcl-photo figcaption{ position:absolute; left:0; right:0; bottom:0; font-family:var(--ff-mono); font-size:11px; letter-spacing:0.06em; text-transform:uppercase; color:var(--text); background:linear-gradient(0deg, oklch(0.10 0.004 60 / 0.92), oklch(0.10 0.004 60 / 0.5) 55%, transparent); padding:30px 16px 14px; }
@media (max-width:760px){ .gcl-photos{ grid-template-columns:1fr; } .gcl-photo img{ aspect-ratio:3/4; object-position:center 20%; } }

/* small photo credit under the gallery */
.gallery__credit{ margin-top:18px; font-family:var(--ff-mono); font-size:11.5px; letter-spacing:0.04em; color:var(--faint); }
.gallery__credit a{ color:var(--muted); border-bottom:1px solid var(--line); padding-bottom:1px; transition:color .2s, border-color .2s; }
.gallery__credit a:hover{ color:var(--accent); border-color:var(--accent-line); }

/* hero proof row (inline credentials) + smaller depth glow */
.hero__glow{ width:34vw; max-width:520px; }
.hero__text{ padding-bottom:clamp(56px,8vh,96px); }
.hero__proof{ display:flex; flex-wrap:wrap; margin-top:clamp(34px,4vw,46px); border-top:1px solid var(--line); padding-top:26px; max-width:560px; }
.hero__proof-item{ padding-right:clamp(18px,2.6vw,34px); margin-right:clamp(18px,2.6vw,34px); border-right:1px solid var(--line-soft); }
.hero__proof-item:last-child{ border-right:none; padding-right:0; margin-right:0; }
.hp-n{ font-family:var(--ff-display); font-size:clamp(30px,3.2vw,44px); line-height:0.88; letter-spacing:0.01em; font-variant-numeric:tabular-nums; }
.hp-n .accent{ color:var(--accent); }
.hp-l{ font-family:var(--ff-mono); font-size:10.5px; letter-spacing:0.05em; text-transform:uppercase; color:var(--muted); margin-top:10px; max-width:18ch; line-height:1.35; }
@media (max-width:980px){ .hero__text{ padding-bottom:54px; } }
@media (max-width:560px){
  .hero__proof{ max-width:100%; }
  .hero__proof-item{ flex:1; min-width:0; padding-right:clamp(10px,3.5vw,16px); margin-right:clamp(10px,3.5vw,16px); }
  .hp-n{ font-size:clamp(24px,7.5vw,32px); }
  .hp-l{ font-size:8.5px; letter-spacing:0.03em; }
}
