/* ===== zalabak.design — shared system (indigo / light brand) ===== */
:root{
  --bg:#f6f6fc;            /* near-white lavender */
  --bg2:#ffffff;           /* cards */
  --panel:#ececfb;         /* lavender side panels */
  --panel-2:#e3e3fa;
  --ink:#16162a;           /* near-black slate */
  --ink-soft:#3b3b54;
  --mut:#7b7b95;           /* muted */
  --line:#1616270f;
  --line-2:#16162714;
  --indigo:#5854f2;        /* brand primary */
  --indigo-d:#403cd0;      /* hover */
  --indigo-l:#a9a7f8;
  --lav:#ebebfe;           /* tag / chip bg */
  --sans:'Plus Jakarta Sans',system-ui,sans-serif;
  --mono:'JetBrains Mono',monospace;
  --pad:clamp(20px,4vw,60px);
  --ease:cubic-bezier(.16,1,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--indigo);color:#fff}

/* grain */
.grain{position:fixed;inset:-50%;width:200%;height:200%;z-index:9998;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grainmove 6s steps(4) infinite}
@keyframes grainmove{0%{transform:translate(0,0)}25%{transform:translate(-3%,2%)}50%{transform:translate(2%,-2%)}75%{transform:translate(-2%,-3%)}100%{transform:translate(0,0)}}

/* custom cursor (indigo, light theme) */
.dot{position:fixed;top:0;left:0;width:7px;height:7px;background:var(--indigo);border-radius:50%;z-index:9999;pointer-events:none;transform:translate(-50%,-50%)}
.ring{position:fixed;top:0;left:0;width:34px;height:34px;border:1.5px solid var(--indigo);border-radius:50%;z-index:9999;pointer-events:none;transform:translate(-50%,-50%);transition:width .3s,height .3s,background .3s,opacity .3s}
.ring.lg{width:76px;height:76px;background:#5854f218}
.ring.hide{opacity:0}
@media (hover:none){.dot,.ring{display:none}}

/* scroll progress */
.prog{position:fixed;top:0;left:0;height:3px;background:var(--indigo);width:0;z-index:300;border-radius:0 3px 3px 0}

/* nav */
.nav{position:fixed;top:0;left:0;width:100%;z-index:200;display:flex;justify-content:space-between;align-items:center;
  padding:18px var(--pad);transition:padding .4s var(--ease),background .4s}
.nav.solid{background:#f6f6fcdd;backdrop-filter:blur(14px);padding:13px var(--pad);box-shadow:0 1px 0 var(--line)}
.nav .logo{display:flex;align-items:center;gap:11px;font-weight:800;font-size:19px;letter-spacing:-.02em;color:var(--ink)}
.nav .logo svg{width:28px;height:28px}
.nav .menu{display:flex;gap:8px;align-items:center}
.nav .menu a{position:relative;font-size:14px;font-weight:500;color:var(--ink-soft);padding:8px 14px;border-radius:100px;transition:color .3s,background .3s;white-space:nowrap}
.nav .menu a:hover{color:var(--indigo);background:var(--lav)}
.nav .menu a.cta{background:var(--indigo);color:#fff}
.nav .menu a.cta:hover{background:var(--indigo-d)}
@media (max-width:720px){.nav .menu a:not(.cta){display:none}}

/* footer */
.foot{background:var(--ink);color:#ececfb;border-radius:36px 36px 0 0;margin-top:40px;padding:clamp(50px,8vw,90px) var(--pad) 36px}
.foot .big{font-weight:800;font-size:clamp(34px,7vw,92px);line-height:1.02;letter-spacing:-.03em;margin-bottom:50px;text-wrap:balance}
.foot .big a{color:var(--indigo-l);position:relative;white-space:nowrap}
.foot .big a:hover{color:#fff}
.foot .cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:30px}
.foot .col h4{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:#8a8ab0;margin-bottom:16px}
.foot .col a,.foot .col p{display:block;font-size:15px;color:#d6d6ef;margin-bottom:10px}
.foot .col a{transition:color .3s}.foot .col a:hover{color:var(--indigo-l)}
.foot .legal{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-top:46px;padding-top:24px;border-top:1px solid #ffffff1a;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#8a8ab0}
.foot .legal a:hover{color:#fff}
@media (max-width:720px){.foot .cols{grid-template-columns:1fr 1fr}}

/* eyebrow label */
.lbl{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--indigo)}
.lbl::before{content:'';width:7px;height:7px;background:var(--indigo);border-radius:50%}

/* two-tone heading helper */
.tt{font-weight:800;letter-spacing:-.03em;line-height:1}
.tt .i{color:var(--indigo)}

/* tag pills */
.tags{display:flex;flex-wrap:wrap;gap:8px}
.tags span{font-size:12px;font-weight:600;background:var(--lav);color:var(--indigo);padding:7px 13px;border-radius:100px;white-space:nowrap}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--indigo);color:#fff;border-radius:100px;padding:15px 26px;font-size:15px;font-weight:600;transition:background .35s,transform .35s var(--ease)}
.btn:hover{background:var(--indigo-d)}
.btn .ar{transition:transform .4s var(--ease)}
.btn:hover .ar{transform:translate(3px,-3px)}
.btn.ghost{background:var(--lav);color:var(--indigo)}
.btn.ghost:hover{background:var(--panel-2)}

/* reveal */
.reveal{transition:opacity .9s ease,transform .9s var(--ease)}
.js .reveal{opacity:0;transform:translateY(34px)}
.reveal.vis{opacity:1;transform:none}
.r2{transition-delay:.09s}.r3{transition-delay:.18s}.r4{transition-delay:.27s}

/* image slots — light theme placeholder */
image-slot{background:var(--panel);box-shadow:inset 0 0 0 1px var(--line-2);border-radius:18px;overflow:hidden;position:relative}
image-slot::after{content:'';position:absolute;inset:0;pointer-events:none;transition:opacity .3s;background:
  linear-gradient(135deg,transparent 46%,#5854f220 50%,transparent 54%);background-size:14px 14px;opacity:.5}
image-slot:hover::after,image-slot[data-filled]::after{opacity:0}

@media (prefers-reduced-motion:reduce){
  .grain{animation:none}
  .reveal{opacity:1!important;transform:none!important}
  *{scroll-behavior:auto}
}