/* ===========================================================
   KONOPY — shared design system
   Apple-fresh: white canvas, logo cyan→blue accent, big rounded,
   soft layered shadows, generous space. Fully responsive.
   To restyle the whole site, edit THIS file once.
   =========================================================== */
:root{
  /* surfaces */
  --bg:#FFFFFF;
  --bg-soft:#F4F7FB;
  --bg-soft2:#EAF1FC;
  --glass:rgba(255,255,255,.7);
  /* ink */
  --ink:#0A0E1A;
  --ink-soft:#39414F;
  --muted:#6B7488;
  --muted-2:#9AA2B1;
  --line:rgba(10,14,26,.10);
  --line-d:rgba(255,255,255,.14);
  /* brand blue (from logo) */
  --blue-1:#2CC4F6;
  --blue-2:#1E72EE;
  --blue-deep:#1558D6;
  --grad:linear-gradient(118deg,#2CC4F6 0%,#1E72EE 100%);
  --grad-soft:linear-gradient(118deg,#E7F6FE 0%,#E9F0FE 100%);
  /* dark sections */
  --dark:#0A0E1A;
  --dark-2:#121A2E;
  --dark-3:#1B243B;
  /* radii + shadow */
  --r:16px; --r-lg:28px; --r-xl:34px;
  --shadow-s:0 6px 20px rgba(20,60,120,.08);
  --shadow:0 22px 54px rgba(20,60,120,.14);
  --shadow-blue:0 18px 44px rgba(30,114,238,.32);
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);color:var(--ink);
  font-family:"Plus Jakarta Sans",system-ui,sans-serif;
  font-size:17px;line-height:1.62;letter-spacing:-.011em;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.narrow{max-width:820px;margin-left:auto;margin-right:auto}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* type */
h1,h2,h3,h4{font-weight:700;line-height:1.06;letter-spacing:-.03em}
h1{font-size:clamp(2.4rem,6vw,4.5rem);font-weight:800}
h2{font-size:clamp(1.9rem,4.2vw,3.05rem)}
h3{font-size:1.3rem;letter-spacing:-.02em}
p{color:var(--muted);max-width:64ch}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.kicker{font-family:"JetBrains Mono",monospace;font-size:12px;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;color:var(--blue-2);
  display:inline-flex;align-items:center;gap:9px}
.kicker::before{content:"";width:7px;height:7px;border-radius:50%;
  background:var(--grad);box-shadow:0 0 0 4px rgba(44,196,246,.18)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:15.5px;
  padding:14px 26px;border-radius:100px;transition:.22s ease;cursor:pointer;border:1px solid transparent;white-space:nowrap}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--shadow-blue)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 24px 54px rgba(30,114,238,.42)}
.btn-primary .arr{transition:transform .22s}
.btn-primary:hover .arr{transform:translate(3px,-3px)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--blue-2);color:var(--blue-2);transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--ink)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 20px 44px rgba(0,0,0,.25)}

/* ---------- NAV ---------- */
header{position:sticky;top:0;z-index:60;backdrop-filter:saturate(180%) blur(16px);
  background:rgba(255,255,255,.78);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px;gap:18px}
.logo{font-weight:800;font-size:1.5rem;letter-spacing:-.04em;display:flex;align-items:center;gap:9px}
.logo .dot{width:11px;height:11px;border-radius:50%;background:var(--grad);box-shadow:0 0 0 4px rgba(44,196,246,.2)}
.nav-links{display:flex;align-items:center;gap:30px;font-size:15px;font-weight:500}
.nav-links a{color:var(--ink-soft);transition:.2s;position:relative}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-7px;height:2px;background:var(--grad);border-radius:2px}
.nav-right{display:flex;align-items:center;gap:14px}
/* language toggle */
.lang{display:inline-flex;border:1px solid var(--line);border-radius:100px;overflow:hidden;font-family:"JetBrains Mono",monospace;font-size:12px;font-weight:500}
.lang button{background:transparent;border:none;padding:7px 12px;cursor:pointer;color:var(--muted);transition:.2s;letter-spacing:.04em}
.lang button.on{background:var(--grad);color:#fff}
.burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.25s}
.burger.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile drawer */
.drawer{position:fixed;inset:70px 0 0;background:rgba(255,255,255,.98);backdrop-filter:blur(20px);
  z-index:55;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);
  padding:30px 26px;display:flex;flex-direction:column;gap:8px;overflow-y:auto}
.drawer.open{transform:none}
.drawer a{font-size:1.4rem;font-weight:700;letter-spacing:-.02em;padding:14px 0;border-bottom:1px solid var(--line);color:var(--ink)}
.drawer .btn{margin-top:20px;justify-content:center}

/* ---------- layout helpers ---------- */
section{padding:94px 0}
.sec-head{max-width:60ch;margin-bottom:50px}
.sec-head h2{margin:16px 0 16px}
.center{text-align:center;margin-left:auto;margin-right:auto}
.center .kicker{justify-content:center;display:inline-flex}

/* ---------- HERO ---------- */
.hero{position:relative;padding:84px 0 92px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:-1;
  background:
   radial-gradient(50% 50% at 80% 0%,rgba(44,196,246,.22),transparent 70%),
   radial-gradient(45% 55% at 12% 12%,rgba(30,114,238,.16),transparent 70%)}
.hero-grid{display:grid;grid-template-columns:1.12fr .88fr;gap:52px;align-items:center}
.hero h1{margin:22px 0 24px}
.hero .lead{font-size:1.2rem;color:var(--ink-soft);margin-bottom:32px;max-width:54ch}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap;align-items:center}
.hero-micro{font-size:13.5px;color:var(--muted-2);margin-top:18px;max-width:46ch}
.hero-center{text-align:center}
.hero-center .lead{margin-left:auto;margin-right:auto}
.hero-center .hero-cta{justify-content:center}
.hero-center .hero-micro{margin-left:auto;margin-right:auto}

/* node visual */
.visual{position:relative;aspect-ratio:1/1;width:100%;max-width:430px;margin-left:auto;
  border-radius:var(--r-xl);overflow:hidden;background:radial-gradient(120% 120% at 70% 15%,#0A0E1A,#15203a 70%);
  border:1px solid var(--line);box-shadow:var(--shadow)}
.visual svg{position:absolute;inset:0;width:100%;height:100%}
.visual .tag{position:absolute;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.03em;
  color:#eaf4ff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
  padding:6px 11px;border-radius:100px;backdrop-filter:blur(4px)}
.visual .tag.hi{background:var(--grad);color:#fff;border:none;font-weight:600}

/* ---------- cards / leaks ---------- */
.leaks{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.leak{background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:26px 24px;transition:.25s}
.leak:hover{transform:translateY(-3px);box-shadow:var(--shadow-s);border-color:rgba(30,114,238,.3)}
.leak .n{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--blue-2);font-weight:500}
.leak h3{font-size:1.06rem;margin:13px 0 7px}
.leak p{font-size:14.5px}

.soft{background:var(--bg-soft)}
.pillars{display:flex;flex-wrap:wrap;gap:11px;margin-top:34px}
.pill{background:#fff;border:1px solid var(--line);border-radius:100px;padding:11px 19px;font-weight:600;font-size:14.5px;display:flex;align-items:center;gap:9px;box-shadow:var(--shadow-s)}
.pill::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--grad)}

/* growth OS (dark) */
.os{background:var(--dark);color:#fff;position:relative;overflow:hidden}
.os .kicker{color:#7fd6ff}.os h2{color:#fff}.os p{color:#9aa6bd}
.os::before{content:"";position:absolute;inset:0;opacity:.6;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:56px 56px;mask-image:radial-gradient(80% 70% at 50% 30%,#000 30%,transparent 100%)}
.modules{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin-top:46px;position:relative}
.mod{background:var(--dark-2);border:1px solid var(--line-d);border-radius:var(--r);padding:24px 22px;transition:.25s}
.mod:hover{transform:translateY(-4px);border-color:rgba(44,196,246,.45);background:var(--dark-3)}
.mod .mn{font-family:"JetBrains Mono",monospace;font-size:11px;color:#5cc8f5;letter-spacing:.05em}
.mod h3{color:#fff;font-size:1.1rem;margin:14px 0 8px}
.mod p{font-size:13.5px;color:#9aa6bd}
.mod.cta{background:var(--grad);border:none}
.mod.cta .mn{color:rgba(255,255,255,.85)}.mod.cta h3{color:#fff}.mod.cta p{color:rgba(255,255,255,.9)}
.modules .span2{grid-column:span 2}

/* services cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 28px;transition:.25s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:rgba(30,114,238,.25)}
.card .ic{width:46px;height:46px;border-radius:13px;background:var(--grad-soft);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.card .ic svg{width:23px;height:23px;stroke:var(--blue-2)}
.card .tag{font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2)}
.card h3{margin:8px 0 14px}
.card .row{font-size:14px;margin-bottom:8px;display:flex;gap:9px}
.card .row b{color:var(--ink);font-weight:700;min-width:60px;flex-shrink:0}
.card .row span{color:var(--muted)}
.card .clink{margin-top:auto;padding-top:18px;font-weight:600;font-size:14.5px;color:var(--blue-2);display:inline-flex;align-items:center;gap:7px}
.card .clink .arr{transition:transform .2s}.card:hover .clink .arr{transform:translateX(4px)}

/* process steps */
.steps{display:flex;flex-wrap:wrap;gap:10px;margin-top:42px;counter-reset:s}
.step{flex:1 1 120px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px 18px;box-shadow:var(--shadow-s)}
.step::before{counter-increment:s;content:"0" counter(s);font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--blue-2);font-weight:500}
.step h3{font-size:1.02rem;margin-top:11px}

/* stats / proof */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:12px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px 26px;box-shadow:var(--shadow-s)}
.stat .big{font-size:2.9rem;font-weight:800;letter-spacing:-.04em;line-height:1}
.stat .lab{font-size:14px;color:var(--muted);margin-top:8px}
.note{margin-top:22px;font-size:14.5px;color:var(--muted-2);max-width:60ch}

/* final CTA */
.final{position:relative;overflow:hidden;background:var(--dark);color:#fff;text-align:center}
.final h2{color:#fff;max-width:20ch;margin:0 auto 28px}
.final::before{content:"";position:absolute;inset:0;
  background:radial-gradient(50% 60% at 50% 0%,rgba(30,114,238,.5),transparent 70%)}
.final .wrap{position:relative}

/* ---------- generic content (about/legal) ---------- */
.prose{max-width:760px}
.prose h2{margin:42px 0 14px}
.prose h3{margin:28px 0 10px}
.prose p{margin-bottom:16px;color:var(--ink-soft)}
.prose ul{margin:0 0 16px 20px;color:var(--ink-soft)}
.prose li{margin-bottom:8px}
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:14px}
.value{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r);padding:26px 24px}
.value h3{font-size:1.1rem;margin-bottom:8px}.value p{font-size:14.5px}

/* ---------- forms ---------- */
.form-sec{background:var(--dark);color:#fff}
.form-sec .kicker{color:#7fd6ff}.form-sec h2{color:#fff}.form-sec>.wrap>p{color:#9aa6bd}
.form-card{background:var(--dark-2);border:1px solid var(--line-d);border-radius:var(--r-lg);padding:40px 38px;margin-top:32px;max-width:780px}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:17px}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:17px}
.field.full{grid-column:span 2}
.field label{font-size:13.5px;font-weight:600;color:#fff}
.field input,.field select,.field textarea{background:#0A0E1A;border:1px solid var(--line-d);border-radius:12px;padding:13px 15px;color:#fff;font-family:inherit;font-size:15px;transition:.2s}
.field input::placeholder,.field textarea::placeholder{color:#566077}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue-1);box-shadow:0 0 0 3px rgba(44,196,246,.18)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%232CC4F6' stroke-width='1.6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center}
.form-foot{margin-top:8px;display:flex;flex-direction:column;gap:14px;align-items:flex-start}
.form-note{font-size:13px;color:#9aa6bd}
.form-msg{display:none;background:rgba(44,196,246,.12);border:1px solid var(--blue-1);border-radius:12px;padding:16px 18px;color:#fff;font-size:15px;margin-top:10px}

/* contact tiles */
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:14px}
.ctile{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px 26px;box-shadow:var(--shadow-s)}
.ctile .ic{width:44px;height:44px;border-radius:12px;background:var(--grad-soft);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.ctile .ic svg{width:22px;height:22px;stroke:var(--blue-2)}
.ctile h3{font-size:1.08rem;margin-bottom:6px}
.ctile a{color:var(--blue-2);font-weight:600;font-size:15px}

/* ---------- FAQ ---------- */
.faq{max-width:780px;margin:0 auto}
details{border:1px solid var(--line);border-radius:var(--r);padding:2px 24px;margin-bottom:12px;background:#fff}
details summary{cursor:pointer;list-style:none;padding:20px 0;font-weight:700;font-size:1.02rem;display:flex;justify-content:space-between;align-items:center;gap:18px}
details summary::-webkit-details-marker{display:none}
details summary::after{content:"+";font-family:"JetBrains Mono",monospace;font-size:1.3rem;color:var(--blue-2);transition:.2s}
details[open] summary::after{transform:rotate(45deg)}
details p{padding:0 0 22px;font-size:15px}

/* ---------- FOOTER ---------- */
footer{background:var(--dark);color:#9aa6bd;padding:64px 0 40px;font-size:14.5px}
.foot{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:34px}
footer .flogo img{height:78px;width:auto;margin-bottom:16px}
footer p{color:#9aa6bd;max-width:34ch}
.foot-col h4{color:#fff;font-size:12px;text-transform:uppercase;letter-spacing:.12em;margin-bottom:15px;font-weight:700}
.foot-col a{display:block;margin-bottom:10px;color:#9aa6bd;transition:.2s}
.foot-col a:hover{color:var(--blue-1)}
.foot-base{margin-top:48px;padding-top:24px;border-top:1px solid var(--line-d);display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:13px;color:#6b7488}
.foot-base a{color:#6b7488}.foot-base a:hover{color:#fff}

/* ---------- reveal ---------- */
.js .reveal{opacity:0;transform:translateY(22px)}
.js .reveal.in{opacity:1;transform:none;transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .modules{grid-template-columns:repeat(2,1fr)}.modules .span2{grid-column:span 1}
  .cards{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:860px){
  .nav-links{display:none}
  .nav-right .lang{display:none}
  .nav-right .btn:not(.always){display:none}
  .burger{display:flex}
  .hero-grid{grid-template-columns:1fr;gap:38px}
  .visual{max-width:360px;margin:0 auto}
  .leaks{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .value-grid{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}.field.full{grid-column:span 1}
  .foot{grid-template-columns:1fr 1fr;gap:28px}
  section{padding:64px 0}
  .form-card{padding:28px 22px}
}
@media(max-width:520px){
  .foot{grid-template-columns:1fr}
  h1{font-size:2.3rem}
  .hero{padding:54px 0 64px}
}
