/* ============================================================
   COLYNK — shared design system
   Bricolage Grotesque (display) · Hanken Grotesk (body) · JetBrains Mono (labels)
   ============================================================ */

/* ---------- SELF-HOSTED FONTS ---------- */
@font-face{font-family:"Bricolage Grotesque";font-style:normal;font-display:optional;font-weight:200 800;src:url('/fonts/bricolage-grotesque-latin-ext-opsz-normal.woff2') format('woff2-variations');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Bricolage Grotesque";font-style:normal;font-display:optional;font-weight:200 800;src:url('/fonts/bricolage-grotesque-latin-opsz-normal.woff2') format('woff2-variations');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Hanken Grotesk";font-style:normal;font-display:optional;font-weight:100 900;src:url('/fonts/hanken-grotesk-latin-ext-wght-normal.woff2') format('woff2-variations');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"Hanken Grotesk";font-style:normal;font-display:optional;font-weight:100 900;src:url('/fonts/hanken-grotesk-latin-wght-normal.woff2') format('woff2-variations');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"JetBrains Mono";font-style:normal;font-display:optional;font-weight:500;src:url('/fonts/jetbrains-mono-latin-ext-500-normal.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:"JetBrains Mono";font-style:normal;font-display:optional;font-weight:500;src:url('/fonts/jetbrains-mono-latin-500-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
/* fallback metrics — approximates web font metrics to minimise layout shift */
@font-face{font-family:"Bricolage Grotesque Fallback";src:local("Arial");size-adjust:103%;ascent-override:92%;descent-override:22%;line-gap-override:0%;}
@font-face{font-family:"Hanken Grotesk Fallback";src:local("Arial");size-adjust:101%;ascent-override:90%;descent-override:23%;line-gap-override:0%;}

:root{
  --bg:#FCFBF9;
  --ink:#101114;
  --ink-60:#54565C;
  --ink-40:#8B8D93;
  --line:#E6E3DC;
  --line-2:#D8D4C9;
  --blue:#2A6FDB;
  --blue-2:#1B4FB0;
  --blue-deep:#0E1C3D;
  --cream:#F1EEE7;
  --maxw:1340px;
  --gutter:40px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);color:var(--ink);
  font-family:"Hanken Grotesk","Hanken Grotesk Fallback",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-size:18px;line-height:1.5;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.disp{font-family:"Bricolage Grotesque","Bricolage Grotesque Fallback",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-weight:700;letter-spacing:-.02em;line-height:.95;}
.mono{font-family:"JetBrains Mono","SFMono-Regular",Consolas,monospace;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);}
.tag{font-family:"JetBrains Mono","SFMono-Regular",Consolas,monospace;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-40);}

/* ---------- NAV ---------- */
header.nav{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--bg) 85%,transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:76px;}
.brand{font-family:"Bricolage Grotesque","Bricolage Grotesque Fallback",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-weight:800;font-size:24px;letter-spacing:-.03em;display:flex;align-items:center;gap:3px;}
.brand b{color:var(--blue);}
nav.links{display:flex;gap:32px;}
nav.links a{font-size:15px;font-weight:600;color:var(--ink-60);transition:color .2s;position:relative;}
nav.links a:hover{color:var(--ink);}
nav.links a.active{color:var(--ink);}
nav.links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--blue);border-radius:2px;}
.btn{display:inline-flex;align-items:center;gap:9px;font-size:15px;font-weight:700;padding:13px 22px;border-radius:12px;background:var(--blue);color:#fff;transition:transform .18s,background .2s;border:none;cursor:pointer;white-space:nowrap;}
.btn:hover{transform:translateY(-2px);background:var(--blue-2);}
.btn.dark{background:var(--ink);}
.btn.dark:hover{background:#000;}
.btn.out{background:transparent;color:var(--ink);border:1.5px solid var(--ink);}
.btn.out:hover{background:var(--ink);color:#fff;}

/* ---------- SECTION SHELL ---------- */
section{padding:104px 0;}
.shead{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:56px;flex-wrap:wrap;}
.shead h2{font-size:clamp(34px,5.5vw,72px);max-width:16ch;}
.shead .tag{padding-bottom:14px;}

/* ---------- PAGE HERO (inner pages) ---------- */
.phero{padding:72px 0 60px;border-bottom:1px solid var(--line);}
.phero .crumb{margin-bottom:26px;}
.phero h1{font-size:clamp(46px,8vw,108px);}
.phero h1 .blue{color:var(--blue);}
.phero .lede{font-size:clamp(18px,1.7vw,23px);color:var(--ink-60);max-width:50ch;margin-top:28px;}

/* ---------- MARQUEE ---------- */
.marq{border-top:1.5px solid var(--ink);border-bottom:1.5px solid var(--ink);overflow:hidden;background:var(--ink);color:var(--bg);}
.marq-track{display:flex;white-space:nowrap;animation:scroll 28s linear infinite;}
.marq-track span{font-family:"Bricolage Grotesque","Bricolage Grotesque Fallback",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-weight:700;font-size:clamp(28px,4vw,56px);letter-spacing:-.02em;padding:18px 34px;display:inline-flex;align-items:center;gap:34px;}
.marq-track span::after{content:"●";color:var(--blue);font-size:.4em;}
@keyframes scroll{to{transform:translateX(-50%);}}

/* ---------- SERVICES list ---------- */
.svc{border-top:1px solid var(--line);}
.svc-row{display:grid;grid-template-columns:64px 1.1fr 1.6fr auto;gap:30px;align-items:center;padding:30px 8px;border-bottom:1px solid var(--line);cursor:default;}
.svc .svc-row{transition:background .3s ease,padding-left .3s cubic-bezier(.25,.46,.45,.94);}
.svc .svc-row:hover{background:var(--cream);padding-left:22px;}
.svc-row .num{font-family:"JetBrains Mono","SFMono-Regular",Consolas,monospace;color:var(--ink-40);font-size:14px;}
.svc-row h3{font-size:clamp(22px,2.2vw,30px);letter-spacing:-.02em;font-weight:700;}
.svc-row p{color:var(--ink-60);font-size:16px;max-width:42ch;}
.svc-row .go{width:40px;height:40px;border-radius:50%;border:1px solid var(--line-2);display:grid;place-items:center;transition:.25s;flex:none;}
.svc-row:hover .go{background:var(--blue);border-color:var(--blue);color:#fff;}
.svc-row:hover .go svg{transform:translate(2px,-2px);}
.svc-row .go svg{transition:transform .25s;}

/* ---------- WORK grid ---------- */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;}
.case{display:flex;flex-direction:column;gap:16px;}
.case .frame{position:relative;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--cream);}
.case .placeholder{display:block;width:100%;height:340px;background:var(--line);}
.case .frame img{display:block;width:100%;height:340px;object-fit:cover;}
.case .meta{display:flex;justify-content:space-between;align-items:baseline;gap:16px;}
.case h3{font-size:22px;letter-spacing:-.02em;font-weight:700;}
.case .tags{display:flex;gap:8px;flex-wrap:wrap;}
.chip{font-family:"JetBrains Mono","SFMono-Regular",Consolas,monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-60);border:1px solid var(--line);border-radius:100px;padding:5px 11px;}
.case .yr{font-family:"JetBrains Mono","SFMono-Regular",Consolas,monospace;color:var(--ink-40);font-size:13px;}

/* ---------- STATEMENT (dark blue) ---------- */
.state{background:var(--blue-deep);color:#fff;border-radius:28px;padding:clamp(48px,7vw,110px) clamp(40px,6vw,90px);position:relative;overflow:hidden;}
.state .tag{color:#6f86c8;}
.state .big{font-family:"Bricolage Grotesque","Bricolage Grotesque Fallback",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-weight:700;font-size:clamp(30px,4.6vw,64px);line-height:1.05;letter-spacing:-.025em;max-width:20ch;margin:24px 0 0;text-wrap:balance;}
.state .big em{font-style:normal;color:#7ea6ff;}
.state-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:64px;border-top:1px solid rgba(255,255,255,.16);padding-top:40px;}
.state-stats .n{font-family:"Bricolage Grotesque","Bricolage Grotesque Fallback",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-weight:700;font-size:clamp(40px,5vw,68px);letter-spacing:-.02em;}
.state-stats .k{color:#9aa6c4;font-size:15px;margin-top:6px;}
.state .orb{position:absolute;right:-100px;bottom:-160px;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(42,111,219,.55),transparent 62%);pointer-events:none;}

/* ---------- PROCESS ---------- */
.proc{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.pstep{border-top:2px solid var(--ink);padding-top:22px;}
.pstep .pn{font-family:"Bricolage Grotesque","Bricolage Grotesque Fallback",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-weight:700;font-size:clamp(40px,5vw,72px);letter-spacing:-.03em;line-height:1;}
.pstep h3{font-family:"Bricolage Grotesque","Bricolage Grotesque Fallback",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-weight:700;font-size:22px;letter-spacing:-.01em;margin:18px 0 10px;}
.pstep p{color:var(--ink-60);font-size:15px;}

/* ---------- CTA ---------- */
.cta{text-align:center;padding:120px 0;}
.cta h2{font-size:clamp(44px,9vw,140px);}
.cta h2 .blue{color:var(--blue);}
.cta .sub{color:var(--ink-60);font-size:clamp(18px,1.6vw,22px);margin:28px auto 40px;max-width:46ch;}

/* ---------- VALUES list ---------- */
.val-list{border-top:1px solid var(--line);}
.val-item{padding:26px 4px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:baseline;}
.val-item .x{color:var(--blue);font-family:"JetBrains Mono","SFMono-Regular",Consolas,monospace;font-size:14px;}
.val-item h3{font-size:20px;font-weight:700;letter-spacing:-.01em;margin-bottom:5px;}
.val-item p{color:var(--ink-60);font-size:15px;}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);color:#fff;padding:84px 0 40px;}
.ftop{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px;padding-bottom:54px;border-bottom:1px solid rgba(255,255,255,.14);}
.ftop .fb{font-family:"Bricolage Grotesque","Bricolage Grotesque Fallback",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-weight:800;font-size:clamp(40px,6vw,84px);letter-spacing:-.03em;}
.ftop .fb b{color:var(--blue);}
.fcol h4{font-family:"JetBrains Mono","SFMono-Regular",Consolas,monospace;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#7d7f86;margin-bottom:16px;}
.fcol a{display:block;color:#bcbec4;padding:6px 0;font-size:15px;transition:color .2s;}
.fcol a:hover{color:#fff;}
.fbot{display:flex;justify-content:space-between;padding-top:28px;flex-wrap:wrap;gap:12px;color:#7d7f86;font-size:13px;font-family:"JetBrains Mono","SFMono-Regular",Consolas,monospace;}
.fbot a{color:#7d7f86;text-decoration:none;}.fbot a:hover{color:#fff;}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;}.marq-track{animation:none;}}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  :root{--gutter:22px;}
  nav.links{display:none;}
  .svc-row{grid-template-columns:auto 1fr;gap:6px 16px;}
  .svc-row p,.svc-row .go{display:none;}
  .work-grid{grid-template-columns:1fr;}
  .state-stats{grid-template-columns:1fr;}
  .proc{grid-template-columns:1fr 1fr;}
  .ftop{grid-template-columns:1fr 1fr;}
}
