/* Kollagerie — landing page styles (dark, collage palette). No inline styles (strict CSP). */

/* ---- Fonts (latin + latin-ext subsets shipped in /assets/fonts) ---- */
@font-face{font-family:"IBM Plex Sans";font-style:normal;font-weight:400;font-display:swap;src:url(/assets/fonts/ibm-plex-sans-latin-400-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+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:"IBM Plex Sans";font-style:normal;font-weight:400;font-display:swap;src:url(/assets/fonts/ibm-plex-sans-latin-ext-400-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:"IBM Plex Sans";font-style:normal;font-weight:600;font-display:swap;src:url(/assets/fonts/ibm-plex-sans-latin-600-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+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:"IBM Plex Sans";font-style:normal;font-weight:600;font-display:swap;src:url(/assets/fonts/ibm-plex-sans-latin-ext-600-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:"IBM Plex Mono";font-style:normal;font-weight:500;font-display:swap;src:url(/assets/fonts/ibm-plex-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+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

:root{
  --bg:#1e1e2e; --bg-2:#23233a; --card:#2a2a42; --card-2:#30304c;
  --ink:#f5f5fa; --ink-soft:#c8c8d8; --ink-muted:#9494ac;
  --line:rgba(255,255,255,.10); --line-2:rgba(255,255,255,.16);
  --red:#e8634a; --teal:#1a9e8f; --yellow:#f5b731; --blue:#4a90d9; --purple:#7a52c0; --green:#66bb6a;
  --accent:#4a90d9; --accent-ink:#fff;
  --sans:"IBM Plex Sans",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --maxw:1080px;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}*,*::before,*::after{transition:none!important;animation:none!important;}}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);
  line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--ink);text-decoration:none;}
:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:4px;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 1.25rem;}
.skip-link{position:absolute;top:-100%;left:0;z-index:100;padding:.5rem 1rem;background:var(--blue);color:#fff;}
.skip-link:focus{top:0;}

/* ---- Header ---- */
.site-header{position:sticky;top:0;z-index:30;background:rgba(30,30,46,.88);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line);}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:64px;}
.brand{display:flex;align-items:center;gap:.65rem;font-weight:600;font-size:1.15rem;letter-spacing:-.01em;}
.brand img{width:34px;height:34px;border-radius:8px;}
.nav{display:flex;align-items:center;gap:1.4rem;}
.nav a{color:var(--ink-soft);font-size:.95rem;}
.nav a:hover{color:var(--ink);}
@media (max-width:640px){.nav a:not(.btn){display:none;}}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.95rem;padding:.6rem 1.15rem;border-radius:.7rem;border:1px solid transparent;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease;}
.btn-primary{background:var(--blue);color:var(--accent-ink);}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 26px -10px rgba(74,144,217,.6);}
.btn-ghost{background:transparent;border-color:var(--line-2);color:var(--ink);}
.btn-ghost:hover{background:var(--card);}
.btn[aria-disabled="true"]{opacity:.85;cursor:default;pointer-events:none;}

/* ---- Hero ---- */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);
  background:
    radial-gradient(900px 500px at 78% -10%,rgba(74,144,217,.16),transparent 60%),
    radial-gradient(700px 460px at 0% 110%,rgba(122,82,192,.16),transparent 60%),
    var(--bg);
}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center;padding-top:4.5rem;padding-bottom:4.5rem;}
.kicker{font-family:var(--mono);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);display:flex;align-items:center;gap:.6rem;margin-bottom:1.1rem;}
.kicker .dot{width:10px;height:10px;border-radius:3px;background:var(--red);box-shadow:14px 0 0 var(--yellow),28px 0 0 var(--teal),42px 0 0 var(--blue);}
h1{font-size:clamp(2.1rem,5vw,3.3rem);line-height:1.05;letter-spacing:-.02em;font-weight:600;margin:.2rem 0 1rem;}
.hero p.lead{font-size:1.15rem;color:var(--ink-soft);max-width:34ch;margin:0 0 1.6rem;}
.hero .cta{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center;}
.hero .pkg{font-family:var(--mono);font-size:.8rem;color:var(--ink-muted);margin-top:1.1rem;}
.hero-art{justify-self:center;width:100%;}
/* Phone mockup: caps the bitmap at/below its native width so it never upscales (stays crisp). */
.phone{width:min(300px,80%);margin:0 auto;padding:10px;background:#0e0e16;border:1px solid var(--line-2);border-radius:30px;box-shadow:0 30px 70px -30px rgba(0,0,0,.72),inset 0 0 0 1px rgba(255,255,255,.04);}
.phone img{width:100%;height:auto;aspect-ratio:9/16;object-fit:cover;border-radius:21px;}

@media (max-width:860px){
  .hero .wrap{grid-template-columns:1fr;gap:2.2rem;padding-top:3rem;padding-bottom:3rem;}
  .hero-art{order:-1;}
}

/* ---- Sections ---- */
section{padding:4rem 0;border-bottom:1px solid var(--line);}
.section-head{max-width:62ch;margin:0 auto 2.5rem;text-align:center;}
h2{font-size:clamp(1.6rem,3.2vw,2.1rem);line-height:1.15;letter-spacing:-.015em;font-weight:600;margin:0 0 .6rem;}
.section-head p{color:var(--ink-soft);font-size:1.05rem;margin:0;}

/* Features grid */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;}
@media (max-width:860px){.features{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.features{grid-template-columns:1fr;}}
.feature{background:var(--card);border:1px solid var(--line);border-radius:1rem;padding:1.4rem;}
.feature .tag{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;margin-bottom:1rem;}
.feature .tag svg{width:22px;height:22px;}
.feature h3{font-size:1.1rem;font-weight:600;margin:0 0 .4rem;}
.feature p{margin:0;color:var(--ink-soft);font-size:.96rem;}
.c-red{background:rgba(232,99,74,.16);color:var(--red);}
.c-teal{background:rgba(26,158,143,.16);color:var(--teal);}
.c-yellow{background:rgba(245,183,49,.18);color:var(--yellow);}
.c-blue{background:rgba(74,144,217,.16);color:var(--blue);}
.c-purple{background:rgba(122,82,192,.18);color:#b69ae6;}
.c-green{background:rgba(102,187,106,.16);color:var(--green);}

/* Screenshot gallery */
.shots{background:var(--bg-2);}
.shot-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;}
@media (max-width:860px){.shot-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:480px){.shot-grid{grid-template-columns:1fr;max-width:320px;margin:0 auto;}}
.shot figure{margin:0;}
.shot img{width:100%;height:auto;aspect-ratio:9/16;object-fit:cover;border-radius:14px;border:1px solid var(--line-2);background:#fff;}
.shot figcaption{margin-top:.6rem;font-size:.85rem;color:var(--ink-muted);text-align:center;}

/* Privacy band */
.privacy{background:linear-gradient(180deg,var(--card-2),var(--card));}
.privacy .pills{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center;margin-top:1.6rem;}
.pill{display:inline-flex;align-items:center;gap:.55rem;background:var(--bg-2);border:1px solid var(--line-2);border-radius:999px;padding:.55rem 1.1rem;font-size:.95rem;color:var(--ink);}
.pill svg{width:18px;height:18px;color:var(--green);}

/* Download */
.download{text-align:center;}
.download .pkg{font-family:var(--mono);font-size:.82rem;color:var(--ink-muted);margin-top:1rem;}
.badge-soon{display:inline-flex;align-items:center;gap:.6rem;background:var(--card);border:1px solid var(--line-2);border-radius:.8rem;padding:.8rem 1.3rem;font-weight:600;}
.badge-soon .play{width:22px;height:22px;}

/* ---- Footer ---- */
.site-footer{background:var(--bg);padding:2.6rem 0;border:0;}
.site-footer .wrap{display:flex;flex-wrap:wrap;gap:1.2rem;justify-content:space-between;align-items:center;}
.footer-links{display:flex;flex-wrap:wrap;gap:1.1rem;}
.footer-links a{color:var(--ink-soft);font-size:.92rem;}
.footer-links a:hover{color:var(--ink);}
.site-footer small{color:var(--ink-muted);font-size:.88rem;}

/* ---- Utilities (avoid inline styles under strict CSP) ---- */
.section--plain{border:0;}
.kicker--center{justify-content:center;}
.mt-lg{margin-top:1.6rem;}
