/* Apex Lab — legal pages stylesheet (self-hosted fonts, new design system) */

@font-face { font-family:'Satoshi'; font-style:normal; font-weight:400; font-display:swap; src:url('/fonts/satoshi/satoshi-400.woff2') format('woff2'); }
@font-face { font-family:'Satoshi'; font-style:normal; font-weight:500; font-display:swap; src:url('/fonts/satoshi/satoshi-500.woff2') format('woff2'); }
@font-face { font-family:'Satoshi'; font-style:normal; font-weight:600 700; font-display:swap; src:url('/fonts/satoshi/satoshi-700.woff2') format('woff2'); }
@font-face { font-family:'Inter'; font-style:normal; font-weight:300 700; font-display:swap; src:url('/fonts/inter/inter-latin.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+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:300 700; font-display:swap; src:url('/fonts/inter/inter-latin-ext.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; }

:root {
  --bg:#EDEDED; --surface:#FFFFFF;
  --ink:#161616; --ink-2:#4a4a4a; --ink-3:#6b6b6b;
  --border:rgba(22,22,22,0.08); --border-strong:rgba(22,22,22,0.18);
  --accent:rgb(255,126,93);
  --font-sans:'Inter',system-ui,sans-serif;
  --font-display:'Satoshi','Inter',system-ui,sans-serif;
  --radius-card:20px; --radius-lg:28px;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html,body { background:var(--bg); color:var(--ink); font-family:var(--font-sans); font-size:16px; line-height:1.5; -webkit-font-smoothing:antialiased; }
body { overflow-x:hidden; }
a { color:inherit; text-decoration:none; }
img { display:block; max-width:100%; }
:focus-visible { outline:2px solid #161616; outline-offset:2px; }
.container { width:100%; max-width:1080px; margin:0 auto; padding:0 40px; }

/* Header */
.topnav { display:flex; align-items:center; justify-content:space-between; gap:16px; padding:28px 56px; border-bottom:1px solid var(--border); }
.topnav-group { display:flex; align-items:center; gap:4px; }
.topnav-logo { display:inline-flex; align-items:center; height:22px; margin-right:20px; }
.topnav-logo img { height:100%; width:auto; }
.topnav a.nav-link { padding:7px 12px; border-radius:25px; font-family:var(--font-display); font-size:14px; color:var(--ink-2); transition:opacity .2s; }
.topnav a.nav-link:hover { opacity:.6; }
.lang-switch { display:inline-flex; align-items:center; gap:6px; margin-right:8px; font-family:var(--font-display); font-size:12px; color:var(--ink-3); letter-spacing:.04em; }
.lang-switch a { padding:4px 6px; border-radius:4px; color:var(--ink-3); transition:color .2s, background .2s; }
.lang-switch a[aria-current="true"] { color:var(--ink); background:rgba(22,22,22,0.06); }
.lang-switch a:hover { color:var(--ink); }
.lang-switch .sep { color:rgba(22,22,22,0.25); }
.btn-pill { display:inline-flex; align-items:center; gap:8px; background:rgb(17,17,17); color:#fff; padding:12px 24px; border-radius:9999px; font-family:var(--font-display); font-size:13px; transition:opacity .2s, transform .2s; }
.btn-pill:hover { opacity:.85; }

/* Legal content */
.legal-page { padding:72px 0 96px; }
.legal-content { max-width:760px; margin:0 auto; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); padding:56px 64px; }
.legal-content h1 { font-family:var(--font-display); font-weight:600; font-size:clamp(30px,4vw,44px); line-height:1.12; letter-spacing:-0.02em; margin-bottom:10px; }
.legal-content .last-updated { font-family:var(--font-display); font-size:13px; color:var(--ink-3); margin-bottom:36px; }
.legal-content h2 { font-family:var(--font-display); font-weight:600; font-size:21px; line-height:1.3; margin:40px 0 14px; }
.legal-content h3 { font-family:var(--font-display); font-weight:600; font-size:16px; color:var(--ink-2); margin:24px 0 8px; }
.legal-content p, .legal-content li { font-size:16px; line-height:1.72; color:var(--ink-2); margin-bottom:14px; }
.legal-content ul { padding-left:22px; margin-bottom:16px; }
.legal-content li { margin-bottom:8px; }
.legal-content strong { color:var(--ink); font-weight:600; }
.legal-content a { color:var(--ink); text-decoration:underline; text-underline-offset:2px; }
.legal-content a:hover { color:var(--accent); }
.legal-content .intro { font-size:17px; color:var(--ink-2); margin-bottom:8px; }

/* Footer */
footer { padding:16px; }
.footer-inner { background:rgb(22,22,22); color:rgb(211,216,218); border-radius:var(--radius-lg); padding:56px 56px 40px; }
.footer-cols { display:grid; grid-template-columns:repeat(4,minmax(120px,1fr)); gap:40px; }
.footer-col h3 { font-family:var(--font-display); font-size:13px; text-transform:uppercase; letter-spacing:.06em; opacity:.6; margin-bottom:16px; }
.footer-col a { display:block; font-family:var(--font-display); font-size:14px; line-height:1.5; padding:4px 0; color:rgb(211,216,218); }
.footer-col a:hover { opacity:.7; }
.footer-meta { display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; margin-top:40px; padding-top:24px; border-top:1px solid rgba(211,216,218,0.12); font-family:var(--font-display); font-size:13px; color:rgba(211,216,218,0.5); }
footer a:focus-visible, .topnav a:focus-visible { outline-color:#161616; }
.footer-inner a:focus-visible { outline-color:#fff; }

@media (max-width:860px){
  .topnav { padding:20px 24px; flex-wrap:wrap; }
  .container { padding:0 20px; }
  .legal-content { padding:32px 24px; }
  .footer-cols { grid-template-columns:repeat(2,1fr); gap:28px; }
}

/* ---------- News & insights — index ---------- */
.news-hero { display:grid; grid-template-columns:1.4fr 1fr; align-items:end; gap:32px; padding:96px 0 56px; }
.news-hero h1 { font-family:var(--font-display); font-weight:600; font-size:clamp(40px,6vw,72px); line-height:1.02; letter-spacing:-0.035em; color:var(--ink); }
.news-hero h1 .accent { color:var(--ink-3); }
.news-hero-aside { display:flex; flex-direction:column; align-items:flex-end; gap:14px; }
.news-hero-cluster { display:flex; align-items:center; }
.news-hero-cluster .av { width:44px; height:44px; border-radius:999px; background-size:cover; background-position:center; border:2px solid var(--bg); margin-left:-10px; box-shadow:0 2px 6px rgba(22,22,22,0.08); }
.news-hero-cluster .av:first-child { margin-left:0; }
.news-hero-caption { font-family:var(--font-display); font-size:13px; color:var(--ink-3); line-height:1.5; max-width:240px; text-align:right; }
.news-sub { font-family:var(--font-display); font-size:14px; color:var(--ink-3); padding-bottom:28px; border-bottom:1px solid var(--border); margin-bottom:32px; }
.news-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; padding-bottom:120px; }
.news-card { position:relative; display:flex; flex-direction:column; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-card); overflow:hidden; transition:transform .35s cubic-bezier(0.22,1,0.36,1), border-color .2s; }
.news-card:hover { transform:translateY(-2px); border-color:var(--border-strong); }
.news-card .media-wrap { position:relative; overflow:hidden; aspect-ratio:16/10; }
.news-card .media { width:100%; height:100%; background-size:cover; background-position:center; transition:transform .6s cubic-bezier(0.22,1,0.36,1); }
.news-card:hover .media { transform:scale(1.04); }
.news-card .arrow { position:absolute; top:14px; right:14px; width:36px; height:36px; border-radius:999px; background:rgba(255,255,255,0.92); color:var(--ink); display:inline-flex; align-items:center; justify-content:center; opacity:0; transform:translate(6px,-6px) rotate(-45deg); transition:opacity .25s ease, transform .35s cubic-bezier(0.22,1,0.36,1); }
.news-card:hover .arrow { opacity:1; transform:translate(0,0) rotate(0deg); }
.news-card .arrow svg { width:14px; height:14px; }
.news-card .body { padding:20px 22px 26px; }
.news-card h3 { font-family:var(--font-display); font-weight:600; font-size:19px; line-height:1.25; letter-spacing:-0.01em; color:var(--ink); margin-bottom:8px; }
.news-card p { font-size:14px; line-height:1.55; color:var(--ink-3); }

/* ---------- Article — dark hero + body ---------- */
.article-hero { position:relative; height:clamp(420px,62vh,640px); margin:16px 16px 0; border-radius:var(--radius-lg); overflow:hidden; isolation:isolate; color:#fff; }
.article-hero .hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; z-index:0; }
.article-hero .hero-scrim { position:absolute; inset:0; background:linear-gradient(180deg, rgba(22,22,22,0.35) 0%, rgba(22,22,22,0.55) 60%, rgba(22,22,22,0.78) 100%); z-index:1; }
.article-hero .hero-content { position:relative; z-index:2; height:100%; display:flex; flex-direction:column; justify-content:flex-end; padding:48px clamp(28px,6vw,72px); max-width:1080px; margin:0 auto; }
.article-hero .hero-date { font-family:var(--font-display); font-size:13px; letter-spacing:0.04em; color:rgba(255,255,255,0.85); margin-bottom:14px; }
.article-hero h1 { font-family:var(--font-display); font-weight:600; font-size:clamp(32px,5vw,56px); line-height:1.05; letter-spacing:-0.025em; max-width:800px; }
.article-hero .hero-meta { display:inline-flex; align-items:center; gap:8px; margin-top:24px; padding:6px 12px; border:1px solid rgba(255,255,255,0.3); border-radius:999px; font-family:var(--font-display); font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:rgba(255,255,255,0.9); width:max-content; }

.article-body { max-width:720px; margin:0 auto; padding:80px 24px 96px; }
.article-body p { font-family:var(--font-sans); font-size:17px; line-height:1.72; color:var(--ink-2); margin-bottom:22px; }
.article-body h2 { font-family:var(--font-display); font-weight:600; font-size:24px; line-height:1.3; letter-spacing:-0.015em; color:var(--ink); margin:40px 0 14px; }
.article-body .lead { font-size:19px; line-height:1.6; color:var(--ink-2); margin-bottom:32px; }
.article-body strong { color:var(--ink); font-weight:600; }
.article-body a { color:var(--ink); text-decoration:underline; text-underline-offset:2px; }
.article-body a:hover { color:var(--accent); }

/* ---------- Article — related strip ---------- */
.related { padding:8px 16px 96px; }
.related-inner { max-width:1080px; margin:0 auto; }
.related-head { display:flex; align-items:baseline; justify-content:space-between; margin:0 0 24px; }
.related-head h2 { font-family:var(--font-display); font-weight:600; font-size:14px; color:var(--ink-3); text-transform:uppercase; letter-spacing:0.12em; }
.related-head .view-all { font-family:var(--font-display); font-size:13px; color:var(--ink); text-decoration:underline; text-underline-offset:3px; }
.related-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.related-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-card); overflow:hidden; transition:border-color .2s, transform .35s cubic-bezier(0.22,1,0.36,1); }
.related-card:hover { transform:translateY(-2px); border-color:var(--border-strong); }
.related-card .media-wrap { position:relative; overflow:hidden; aspect-ratio:16/10; }
.related-card .media { width:100%; height:100%; background-size:cover; background-position:center; transition:transform .6s cubic-bezier(0.22,1,0.36,1); }
.related-card:hover .media { transform:scale(1.04); }
.related-card .body { padding:18px 20px 22px; }
.related-card h3 { font-family:var(--font-display); font-weight:600; font-size:16px; line-height:1.3; letter-spacing:-0.01em; color:var(--ink); margin-bottom:6px; }
.related-card p { font-size:13px; line-height:1.55; color:var(--ink-3); }

@media (max-width:860px){
  .news-hero { grid-template-columns:1fr; padding:56px 0 32px; gap:24px; }
  .news-hero-aside { align-items:flex-start; }
  .news-hero-caption { text-align:left; }
  .news-grid { grid-template-columns:1fr; }
  .article-hero { margin:8px; height:54vh; }
  .article-hero .hero-content { padding:28px 24px; }
  .article-body { padding:48px 20px 64px; }
  .related-grid { grid-template-columns:1fr; }
}

/* ---------- View Transitions (Chromium) — shared morph + directional slide ---------- */
@view-transition { navigation: auto; }

::view-transition-group(hero-your-calendar),
::view-transition-group(hero-your-calendar-title),
::view-transition-group(hero-plan-breaks),
::view-transition-group(hero-plan-breaks-title),
::view-transition-group(hero-weekends),
::view-transition-group(hero-weekends-title) {
  animation-duration: 500ms;
  animation-timing-function: cubic-bezier(0.22, 1, 0.36, 1);
}

::view-transition-old(root),
::view-transition-new(root) {
  animation-duration: 500ms;
  animation-timing-function: cubic-bezier(0.22, 1, 0.36, 1);
  mix-blend-mode: normal;
}

:root:active-view-transition-type(forward) {
  &::view-transition-old(root) { animation: vt-fade-out 250ms forwards; }
  &::view-transition-new(root) { animation: vt-slide-up-in 500ms cubic-bezier(0.22, 1, 0.36, 1) forwards; }
}
:root:active-view-transition-type(back) {
  &::view-transition-old(root) { animation: vt-slide-down-out 500ms cubic-bezier(0.22, 1, 0.36, 1) forwards; }
  &::view-transition-new(root) { animation: vt-fade-in 350ms 100ms forwards both; }
}

@keyframes vt-slide-up-in   { from { transform: translateY(100%); } to { transform: translateY(0); } }
@keyframes vt-slide-down-out{ from { transform: translateY(0); }    to { transform: translateY(100%); } }
@keyframes vt-fade-in       { from { opacity: 0; } to { opacity: 1; } }
@keyframes vt-fade-out      { from { opacity: 1; } to { opacity: 0; } }

@media (prefers-reduced-motion: reduce) {
  ::view-transition-group(*),
  ::view-transition-old(*),
  ::view-transition-new(*) { animation: none !important; }
}

/* Legacy classes kept for back-compat (old article body wrapper still uses .legal-content) */
.article-eyebrow { font-family:var(--font-display); font-size:11px; font-weight:500; text-transform:uppercase; letter-spacing:.14em; color:var(--accent); margin-bottom:18px; }
.article-meta { font-family:var(--font-display); font-size:13px; color:var(--ink-3); margin:0 0 36px; }
.article-lead { font-size:19px; line-height:1.6; color:var(--ink-2); margin-bottom:8px; }
.article-back { display:inline-block; margin-top:40px; font-family:var(--font-display); font-size:14px; color:var(--ink); text-decoration:underline; text-underline-offset:2px; }
.article-back:hover { color:var(--accent); }
