/* ── Fonts ─────────────────────────────────────────── */
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url("fonts/jbm-cyrillic-ext.woff2") format('woff2');unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url("fonts/jbm-cyrillic.woff2") format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url("fonts/jbm-greek.woff2") format('woff2');unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url("fonts/jbm-vietnamese.woff2") format('woff2');unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url("fonts/jbm-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}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url("fonts/jbm-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+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-weight:500;font-display:swap;src:url("fonts/jbm-latin.woff2") format('woff2');unicode-range:U+0000-00FF}
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:400;font-display:swap;src:url("fonts/pjs-cyrillic-ext.woff2") format('woff2');unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:400;font-display:swap;src:url("fonts/pjs-vietnamese.woff2") format('woff2');unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:400;font-display:swap;src:url("fonts/pjs-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}
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:400;font-display:swap;src:url("fonts/pjs-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+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:500;font-display:swap;src:url("fonts/pjs-latin.woff2") format('woff2');unicode-range:U+0000-00FF}
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:600;font-display:swap;src:url("fonts/pjs-latin.woff2") format('woff2');unicode-range:U+0000-00FF}
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:700;font-display:swap;src:url("fonts/pjs-latin.woff2") format('woff2');unicode-range:U+0000-00FF}
@font-face{font-family:'Plus Jakarta Sans';font-style:normal;font-weight:800;font-display:swap;src:url("fonts/pjs-latin.woff2") format('woff2');unicode-range:U+0000-00FF}

/* ── Theme ─────────────────────────────────────────── */
:root{
  --bg:#06070a;--bg-soft:#0c0d12;--bg-2:#11131a;--bg-3:#171a23;
  --primary:#06070a;--primary-2:#0c0d12;
  --blue:#7c5cff;--blue-2:#a78bfa;--blue-light:rgba(124,92,255,0.10);
  --accent:#34e0c8;
  --text:#f0f1f5;--text-2:#a3a8b7;--text-3:#6a7080;
  --border:rgba(255,255,255,0.08);--border-2:rgba(255,255,255,0.14);
  --green:#34e0c8;--amber:#fbbf24;
  --shadow-sm:0 1px 2px rgba(0,0,0,0.4);
  --shadow:0 4px 12px -2px rgba(0,0,0,0.4);
  --shadow-lg:0 24px 48px -12px rgba(0,0,0,0.5);
  --shadow-xl:0 40px 80px -20px rgba(124,92,255,0.4);
  --r-sm:8px;--r:14px;--r-lg:20px;--r-xl:28px;
  --font:"Plus Jakarta Sans",system-ui,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,monospace;
  --glow-intensity:0.18;--glow-intensity-2:0.08;--backdrop-opacity:0.5;
  --border-width:1px;--anim-delay:0.1s;
}

body::before{content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;background:radial-gradient(ellipse 60% 50% at 80% -10%,rgba(124,92,255,calc(var(--glow-intensity) * 1.5)),transparent 60%),radial-gradient(ellipse 70% 60% at 10% 30%,rgba(52,224,200,var(--glow-intensity-2)),transparent 60%),radial-gradient(ellipse 90% 80% at 50% 110%,rgba(124,92,255,var(--glow-intensity)),transparent 50%),var(--bg)}
body::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:var(--backdrop-opacity);mix-blend-mode:overlay;background-color:rgba(60,50,80,0.15)}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;overflow-x:hidden;font-feature-settings:"ss01"}
a{color:inherit}
.container{max-width:1280px;margin:0 auto;padding:0 32px}

/* ── Magnetic cursor ─────────────────────────────── */
.cursor,.cursor-ring{position:fixed;pointer-events:none;z-index:1000;transform:translate(-50%,-50%)}
.cursor{width:10px;height:10px;border-radius:50%;background:var(--blue);transition:width 0.2s,height 0.2s,background 0.2s;box-shadow:0 0 16px rgba(124,92,255,0.6)}
.cursor.big{width:50px;height:50px;background:rgba(124,92,255,0.4);box-shadow:0 0 32px rgba(124,92,255,0.8)}
.cursor-ring{width:36px;height:36px;border:1.5px solid rgba(124,92,255,0.5);border-radius:50%;transition:transform 0.3s ease-out,width 0.25s,height 0.25s,opacity 0.2s;z-index:999}
.cursor-ring.big{width:70px;height:70px;opacity:0.3}
@media(max-width:1024px){.cursor,.cursor-ring{display:none}}

/* ── Pre-launch banner ───────────────────────────── */
.prelaunch{background:linear-gradient(90deg,rgba(124,92,255,0.08),rgba(251,191,36,0.10) 50%,rgba(124,92,255,0.08));text-align:center;padding:10px 16px;font-size:13px;font-weight:500;border-bottom:1px solid var(--border);color:var(--text-2)}
.prelaunch b{font-weight:700;color:var(--text)}
.prelaunch .pulse{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--amber);margin-right:8px;vertical-align:middle;animation:pa 2s infinite}
@keyframes pa{0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,0.6)}50%{box-shadow:0 0 0 6px rgba(245,158,11,0)}}

/* ── Nav ─────────────────────────────────────────── */
nav.top{position:sticky;top:0;z-index:50;background:rgba(6,7,10,0.65);backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);border-bottom:1px solid var(--border)}
nav.top .row{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text)}
.brand-mark{width:40px;height:40px;flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center}
.brand-mark::before{content:"";position:absolute;inset:-4px;background:radial-gradient(circle,rgba(124,92,255,0.45),transparent 70%);filter:blur(8px);z-index:0;pointer-events:none}
.brand-mark svg,.brand-mark img{width:100%;height:100%;display:block;object-fit:contain;border-radius:9px;z-index:1;position:relative;filter:drop-shadow(0 4px 12px rgba(124,92,255,0.35))}
.brand-name{font-weight:700;font-size:17px;letter-spacing:-0.015em;line-height:1;color:var(--text)}
.brand-name small{display:block;font-family:var(--font-mono);font-size:10px;font-weight:500;color:var(--text-3);letter-spacing:0.12em;text-transform:uppercase;margin-top:3px}
.nav-links{display:flex;gap:4px;align-items:center;background:rgba(255,255,255,0.03);border:var(--border-width) solid var(--border);padding:5px;border-radius:999px}
.nav-links a{color:var(--text-2);text-decoration:none;font-size:13.5px;font-weight:500;padding:8px 14px;border-radius:999px;transition:0.2s}
.nav-links a:hover,.nav-links a.active{color:var(--text);background:rgba(255,255,255,0.05)}
.nav-toggle{display:none;align-items:center;gap:8px;padding:9px 13px;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:10px;color:var(--text);font:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:0.2s}
.nav-toggle:hover{border-color:rgba(124,92,255,0.40);background:rgba(124,92,255,0.10)}

.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:10px;font-size:14px;font-weight:600;text-decoration:none;border:1px solid transparent;transition:0.2s;cursor:pointer;font-family:inherit}
.btn-primary{color:#06070a;background:linear-gradient(135deg,#34e0c8,#7c5cff);box-shadow:0 8px 20px -4px rgba(124,92,255,0.45),inset 0 1px 0 rgba(255,255,255,0.3)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 14px 32px -4px rgba(124,92,255,0.6),inset 0 1px 0 rgba(255,255,255,0.4)}
.btn-ghost{color:var(--text);background:rgba(255,255,255,0.04);border-color:var(--border-2)}
.btn-ghost:hover{border-color:rgba(255,255,255,0.22);background:rgba(255,255,255,0.07)}
.btn .arr{transition:transform 0.2s}
.btn:hover .arr{transform:translateX(3px)}

/* ── Hero ────────────────────────────────────────── */
.hero{padding:64px 0 100px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle 800px at var(--mx,50%) var(--my,30%),rgba(124,92,255,0.18),transparent 50%),radial-gradient(ellipse 60% 40% at 90% 10%,rgba(52,224,200,0.10),transparent 60%);transition:background 0.3s;pointer-events:none}
.hero::after{content:"";position:absolute;inset:0;background-image:linear-gradient(to right,rgba(255,255,255,0.025) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,0.025) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,#000 30%,transparent 80%);pointer-events:none}
.hero-grid{max-width:1280px;width:100%;margin:0 auto;padding:0 32px;display:grid;grid-template-columns:1fr 1.05fr;gap:56px;align-items:center;position:relative;z-index:1}

.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:7px 13px;border-radius:999px;background:rgba(124,92,255,0.10);border:var(--border-width) solid rgba(124,92,255,0.25);font-size:12px;font-weight:600;color:var(--blue-2);animation:fU 0.6s calc(var(--anim-delay) * 1) both}
.eyebrow .pulse-g{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pg 2s infinite}
@keyframes pg{0%,100%{box-shadow:0 0 0 0 rgba(16,185,129,0.6)}50%{box-shadow:0 0 0 6px rgba(16,185,129,0)}}

h1.hero-title{font-size:clamp(40px,5.6vw,76px);font-weight:800;line-height:1.0;letter-spacing:-0.04em;margin:24px 0 24px;animation:fU 0.7s calc(var(--anim-delay) * 2) both}
h1.hero-title .word{display:inline-block;background:linear-gradient(135deg,#f0f1f5,#a3a8b7);-webkit-background-clip:text;background-clip:text;color:transparent}
h1.hero-title .accent{display:inline-block;background:linear-gradient(110deg,#34e0c8,#7c5cff 55%,#a78bfa);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shim 4s linear infinite}
/* Extend the gradient box downward so glyph descenders (g, j, p…) aren't clipped by background-clip:text; negative margin keeps line spacing unchanged. */
h1.hero-title .word,h1.hero-title .accent{padding-bottom:.16em;margin-bottom:-.16em}
@keyframes shim{to{background-position:-200% 0}}
@keyframes fU{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

.hero-sub{font-size:18px;line-height:1.6;color:var(--text-2);max-width:520px;margin:0 0 28px;animation:fU 0.7s 0.35s both}
.hero-bullets{list-style:none;padding:0;margin:0 0 32px;display:flex;flex-direction:column;gap:10px;animation:fU 0.7s 0.45s both}
.hero-bullets li{display:flex;align-items:center;gap:10px;color:var(--text);font-size:15px;font-weight:500}
.hero-bullets .check{width:22px;height:22px;border-radius:50%;background:var(--blue-light);color:var(--blue);display:grid;place-items:center;flex-shrink:0}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;animation:fU 0.7s 0.55s both}

.perf{margin-top:36px;display:flex;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:18px 0;animation:fU 0.7s 0.7s both}
.perf .item{flex:1;padding:0 24px;border-right:1px solid var(--border)}
.perf .item:last-child{border-right:none}
.perf .item:first-child{padding-left:0}
.perf .num{font-size:24px;font-weight:800;letter-spacing:-0.02em;font-feature-settings:"tnum";display:flex;align-items:baseline;gap:4px}
.perf .num small{font-size:13px;color:var(--green);font-weight:600}
.perf .lbl{font-family:var(--font-mono);font-size:10px;color:var(--text-2);letter-spacing:0.06em;text-transform:uppercase;margin-top:4px}

/* Cinematic dashboard */
.scene{position:relative;perspective:2000px;animation:fU 0.9s 0.4s both}
.stage{position:relative;transform-style:preserve-3d;transition:transform 0.2s ease-out}

/* ── Hero — centered variant (skill-focused) ────── */
.hero-center{padding:28px 0 72px;text-align:center;overflow:visible}
.hero-center .container{max-width:880px;position:relative;z-index:2;pointer-events:none}
.hero-center .container a,
.hero-center .container button,
.hero-center .container .btn,
.hero-center .container .eyebrow{pointer-events:auto}
.hero-center .eyebrow{margin:0 auto}
.hero-center h1.hero-title{margin:24px 0 22px}
.hero-center .hero-sub{margin:0 auto 32px}
.hero-center .hero-cta{justify-content:center}
.hero-center .perf{margin:48px auto 0;max-width:720px}

/* ── Rubik Cube ──────────────────────────────────── */
.cube-stage{
  --cube-size:220px;
  --half-size:110px;
  position:absolute;
  top:50%;right:6%;
  width:var(--cube-size);height:var(--cube-size);
  transform:translateY(-50%);
  perspective:1400px;
  z-index:1;
  user-select:none;
  -webkit-user-select:none;
  touch-action:none;
  animation:fU 0.9s 0.5s both;
}
.cube-stage::before{
  content:"";position:absolute;inset:-40px;
  background:radial-gradient(circle,rgba(124,92,255,0.18),transparent 65%);
  filter:blur(20px);
  pointer-events:none;
  z-index:-1;
}
.cube-tools{
  position:absolute;
  top:-114px;right:-26px;
  display:flex;gap:6px;
  z-index:3;
}
.cube-grip,.cube-reset{
  height:22px;
  display:grid;place-items:center;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  border-radius:6px;
  color:var(--text-3);
  transition:0.2s;
  padding:0;
  font:inherit;
}
.cube-grip{width:26px;cursor:grab}
.cube-reset{width:26px;cursor:pointer}
.cube-grip:hover,.cube-reset:hover{
  color:var(--blue-2);
  border-color:rgba(124,92,255,0.40);
  background:rgba(124,92,255,0.10);
  box-shadow:0 4px 16px rgba(124,92,255,0.25);
}
.cube-grip:active,.cube-grip.dragging{cursor:grabbing}
.cube-reset:active{transform:scale(0.92)}

.cube{
  --cubie-size:calc(var(--cube-size) / 3);
  --half-cube:calc(var(--cube-size) / 2);
  --half-cubie:calc(var(--cube-size) / 6);
  width:100%;height:100%;
  position:relative;
  transform-style:preserve-3d;
  transform:rotateX(-24deg) rotateY(-32deg);
  cursor:grab;
  transition:transform 0.08s linear;
}
.cube.dragging{cursor:grabbing;transition:none}
.cube.busy{cursor:wait}

/* A cubie = small cube body. Positioned at 50%/50% then translated by grid coord. */
.cubie{
  position:absolute;
  top:50%;left:50%;
  width:var(--cubie-size);height:var(--cubie-size);
  transform-style:preserve-3d;
  will-change:transform;
}
.cubie.flash .sticker{
  animation:stkflash 0.55s ease-out;
}
@keyframes stkflash{
  0%{filter:brightness(1.5) saturate(1.4)}
  100%{filter:none}
}

/* Pivot used for slice rotation animation */
.cube .pivot{
  position:absolute;
  top:50%;left:50%;
  width:0;height:0;
  transform-style:preserve-3d;
  transform:translate(-50%,-50%);
}
.cube .pivot .cubie{
  /* When in pivot, cubies are positioned relative to the pivot's origin (cube center). */
}

/* A sticker = one face of a cubie */
.sticker{
  position:absolute;
  top:0;left:0;
  width:var(--cubie-size);height:var(--cubie-size);
  background:#0a0c11;
  border:1px solid rgba(255,255,255,0.05);
  border-radius:5px;
  box-sizing:border-box;
  backface-visibility:hidden;
}
.sticker.outer{
  background:linear-gradient(135deg,rgba(124,92,255,0.12),rgba(52,224,200,0.04));
  border-color:rgba(255,255,255,0.10);
  display:grid;place-items:center;
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:500;
  color:var(--text-2);
  text-shadow:0 0 6px rgba(124,92,255,0.45);
  letter-spacing:-0.02em;
  line-height:1;
  overflow:hidden;
  box-shadow:inset 0 0 14px rgba(124,92,255,0.10);
}
.sticker.outer[data-theme="code"] {color:#cdb8ff;text-shadow:0 0 6px rgba(124,92,255,0.50)}
.sticker.outer[data-theme="ai"]   {color:#c4b5fd;text-shadow:0 0 8px rgba(167,139,250,0.55);box-shadow:inset 0 0 14px rgba(167,139,250,0.14)}
.sticker.outer[data-theme="auto"] {color:#7ce8d4;text-shadow:0 0 6px rgba(52,224,200,0.50);box-shadow:inset 0 0 14px rgba(52,224,200,0.12)}
.sticker.outer[data-theme="calc"] {color:#fcd34d;text-shadow:0 0 6px rgba(251,191,36,0.40);box-shadow:inset 0 0 14px rgba(251,191,36,0.10)}
.sticker.outer[data-theme="stack"]{color:#a7f3d8;text-shadow:0 0 5px rgba(52,224,200,0.35);box-shadow:inset 0 0 14px rgba(52,224,200,0.10)}
.sticker.outer[data-theme="api"]  {color:#a78bfa;text-shadow:0 0 6px rgba(124,92,255,0.45);box-shadow:inset 0 0 14px rgba(124,92,255,0.12)}

.sticker .lbl{display:block;line-height:1;will-change:transform}
.sticker.px{transform:rotateY( 90deg) translateZ(var(--half-cubie))}
.sticker.nx{transform:rotateY(-90deg) translateZ(var(--half-cubie))}
.sticker.py{transform:rotateX(-90deg) translateZ(var(--half-cubie))}
.sticker.ny{transform:rotateX( 90deg) translateZ(var(--half-cubie))}
.sticker.pz{transform:rotateY(  0deg) translateZ(var(--half-cubie))}
.sticker.nz{transform:rotateY(180deg) translateZ(var(--half-cubie))}

@media(max-width:1279px){
  .cube-stage{--cube-size:180px;--half-size:90px;right:3%}
  .sticker.outer{font-size:10px}
}
@media(max-width:1023px){
  .cube-stage{display:none}
}
@media(max-width:768px){
  .cube-stage{
    display:block;
    position:relative;
    top:auto;right:auto;left:auto;
    transform:none;
    margin:72px auto 16px;
    --cube-size:160px;--half-size:80px;
  }
  .cube-grip{display:none}            /* drag-to-move is desktop only */
  .cube-tools{top:-38px;right:0}      /* keep just the reset button, above-right */
}
@media(prefers-reduced-motion:reduce){
  .cube-stage{animation:none}
  .cube{transition:none}
}

/* ── Skill cards ──────────────────────────────────── */
.skill-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.skill-card{
  background:linear-gradient(180deg,rgba(255,255,255,0.025),rgba(255,255,255,0.005));
  border:1px solid var(--border);
  border-radius:16px;
  padding:24px;
  transition:0.25s;
}
.skill-card:hover{
  border-color:rgba(124,92,255,0.35);
  transform:translateY(-2px);
  box-shadow:0 12px 30px -10px rgba(124,92,255,0.4);
  background:linear-gradient(180deg,rgba(124,92,255,0.04),rgba(255,255,255,0.005));
}
.sk-h{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.sk-ic{
  width:38px;height:38px;border-radius:10px;
  background:linear-gradient(135deg,rgba(52,224,200,0.18),rgba(124,92,255,0.18));
  color:#a78bfa;
  display:grid;place-items:center;
  border:1px solid rgba(124,92,255,0.20);
}
.skill-card h4{
  font-size:17px;font-weight:700;
  letter-spacing:-0.01em;color:var(--text);
}
.skill-card ul{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:8px;
}
.skill-card li{
  font-size:14px;color:var(--text-2);
  padding-left:16px;position:relative;
  font-feature-settings:"ss01";
}
.skill-card li::before{
  content:"";position:absolute;left:0;top:8px;
  width:6px;height:6px;border-radius:50%;
  background:linear-gradient(135deg,#34e0c8,#7c5cff);
}

/* ── Why grid ─────────────────────────────────────── */
.why-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.why-card{
  background:#11131a;
  border:1px solid var(--border);
  border-radius:18px;
  padding:32px 28px;
  transition:0.25s;
}
.why-card:hover{
  border-color:rgba(124,92,255,0.35);
  transform:translateY(-2px);
}
.why-num{
  font-family:var(--font-mono);
  font-size:28px;font-weight:700;
  background:linear-gradient(110deg,#34e0c8,#7c5cff);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin-bottom:14px;letter-spacing:-0.02em;
}
.why-card h4{
  font-size:19px;font-weight:700;
  letter-spacing:-0.015em;
  color:var(--text);margin:0 0 10px;
}
.why-card p{
  font-size:14.5px;line-height:1.6;
  color:var(--text-2);margin:0;
}

/* services-compact: when used as <a> inside index */
a.sc-card{text-decoration:none;color:inherit}

@media(max-width:1024px){
  .skill-grid,.why-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .skill-grid,.why-grid{grid-template-columns:1fr}
}

/* ── Mini Kalkulator on the screen ────────────────── */
.mk{width:100%;height:100%;background:#06070a;display:flex;flex-direction:column;font-family:var(--font);color:var(--text);position:relative}
.mk-bar{height:22px;background:#0c0d12;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 10px;gap:10px;flex-shrink:0;font-size:9px}
.mk-dots{display:flex;gap:4px}
.mk-dots i{width:7px;height:7px;border-radius:50%;background:#ff5f57}
.mk-dots i:nth-child(2){background:#febc2e}
.mk-dots i:nth-child(3){background:#28c840}
.mk-url{flex:1;text-align:center;font-family:var(--font-mono);color:var(--text-3);letter-spacing:0.04em;font-size:8.5px}
.mk-status{font-family:var(--font-mono);color:var(--accent);font-size:8px;letter-spacing:0.06em}

.mk-app{flex:1;display:grid;grid-template-columns:32px 1fr;min-height:0}
.mk-aside{background:#0a0b10;border-right:1px solid var(--border);padding:8px 6px;display:flex;flex-direction:column;gap:5px}
.mk-logo{width:18px;height:18px;border-radius:4px;background:linear-gradient(135deg,#34e0c8,#7c5cff);box-shadow:0 2px 8px -2px rgba(124,92,255,0.5);margin-bottom:4px}
.mk-nav{height:18px;border-radius:4px;background:rgba(255,255,255,0.04)}
.mk-nav.on{background:linear-gradient(135deg,rgba(124,92,255,0.4),rgba(124,92,255,0.15));box-shadow:0 2px 6px -2px rgba(124,92,255,0.4)}

.mk-main{padding:10px 12px;background:#06070a;display:flex;flex-direction:column;gap:8px;overflow:hidden;min-height:0}
.mk-head{display:flex;justify-content:space-between;align-items:flex-start}
.mk-tag{font-family:var(--font-mono);font-size:7.5px;color:var(--accent);letter-spacing:0.08em;text-transform:uppercase;margin-bottom:2px}
.mk-title{font-size:13px;font-weight:800;letter-spacing:-0.02em;color:var(--text)}
.mk-pill{height:14px;padding:0 8px;background:linear-gradient(135deg,#34e0c8,#7c5cff);color:#06070a;border-radius:999px;font-size:7px;font-weight:700;display:flex;align-items:center;letter-spacing:0.04em}

.mk-types{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
.mk-chip{padding:6px;border:1px solid var(--border);border-radius:6px;background:#11131a;font-size:7px;color:var(--text-2);text-align:left}
.mk-chip b{display:block;color:var(--text);font-size:8px;font-weight:700;margin-bottom:1px}
.mk-chip span{font-family:var(--font-mono);font-size:6.5px;opacity:0.7}
.mk-chip.on{background:linear-gradient(135deg,rgba(124,92,255,0.18),rgba(52,224,200,0.08));border-color:var(--blue);box-shadow:0 4px 8px -2px rgba(124,92,255,0.3)}

.mk-row{display:flex;justify-content:space-between;align-items:center;font-size:8px;font-weight:600;color:var(--text);margin-top:2px}
.mk-val{font-family:var(--font-mono);font-size:7.5px;color:var(--accent);background:rgba(52,224,200,0.10);padding:2px 6px;border-radius:4px;border:1px solid rgba(52,224,200,0.2)}

.mk-slider{position:relative;height:4px;background:rgba(255,255,255,0.08);border-radius:2px;margin:2px 0}
.mk-fill{position:absolute;left:0;top:0;height:100%;width:35%;background:linear-gradient(90deg,#34e0c8,#7c5cff);border-radius:2px}
.mk-thumb{position:absolute;left:35%;top:50%;transform:translate(-50%,-50%);width:9px;height:9px;border-radius:50%;background:linear-gradient(135deg,#34e0c8,#7c5cff);box-shadow:0 2px 6px -1px rgba(124,92,255,0.6),0 0 0 2px #06070a}

.mk-result{margin-top:auto;background:linear-gradient(135deg,#171a23,#0c0d12);border:1px solid var(--border-2);border-radius:8px;padding:8px 10px;position:relative;overflow:hidden}
.mk-result::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 100% 0%,rgba(124,92,255,0.35),transparent 60%);pointer-events:none}
.mk-result>*{position:relative;z-index:1}
.mk-rh{font-family:var(--font-mono);font-size:6.5px;color:rgba(255,255,255,0.5);letter-spacing:0.06em;text-transform:uppercase;margin-bottom:3px}
.mk-rn{font-size:18px;font-weight:800;letter-spacing:-0.03em;line-height:1;font-feature-settings:"tnum";background:linear-gradient(110deg,#34e0c8,#a78bfa);-webkit-background-clip:text;background-clip:text;color:transparent;display:flex;align-items:baseline;gap:4px}
.mk-rn small{font-size:9px;color:rgba(255,255,255,0.5);font-weight:600;-webkit-text-fill-color:rgba(255,255,255,0.5);margin-left:4px}
.mk-bar2{height:3px;background:rgba(255,255,255,0.1);border-radius:2px;margin:6px 0 4px}
.mk-bar2-fill{height:100%;width:42%;background:linear-gradient(90deg,#34e0c8,#7c5cff);border-radius:2px;transform-origin:left;animation:bar 2s ease-out 0.8s both}
.mk-rb{font-family:var(--font-mono);font-size:6.5px;color:rgba(255,255,255,0.45)}
.laptop{background:linear-gradient(180deg,#1a1d28,#06070a);border-radius:16px;padding:14px;box-shadow:0 50px 100px -20px rgba(0,0,0,0.6),inset 0 1px 0 rgba(255,255,255,0.08),0 0 0 1px rgba(255,255,255,0.06);position:relative}
.laptop::before{content:"";position:absolute;inset:0;border-radius:16px;background:radial-gradient(ellipse 60% 50% at 50% 0%,rgba(124,92,255,0.25),transparent 60%);pointer-events:none}
.screen{background:#0c0d12;border-radius:8px;overflow:hidden;aspect-ratio:16/10;display:grid;grid-template-columns:64px 1fr}
.side{background:#06070a;padding:14px 10px;display:flex;flex-direction:column;gap:8px}
.side .lg{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#34e0c8,#7c5cff);margin-bottom:6px;box-shadow:0 4px 12px -2px rgba(124,92,255,0.5)}
.side .ni{height:28px;border-radius:6px;background:rgba(255,255,255,0.04);display:flex;align-items:center;padding:0 8px;gap:8px}
.side .ni.on{background:linear-gradient(135deg,#7c5cff,#5a3fd9);box-shadow:0 4px 12px -2px rgba(124,92,255,0.5)}
.side .ni .ic{width:10px;height:10px;border-radius:3px;background:rgba(255,255,255,0.5)}
.side .ni .lb{height:5px;border-radius:3px;background:rgba(255,255,255,0.18);flex:1}
.side .ni.on .lb{background:rgba(255,255,255,0.95)}
.main-d{padding:16px;background:#0c0d12;display:flex;flex-direction:column;gap:12px;overflow:hidden}
.top-d{display:flex;align-items:center;justify-content:space-between}
.h1b{height:12px;width:140px;background:rgba(255,255,255,0.7);border-radius:4px}
.pill{height:24px;padding:0 12px;background:linear-gradient(135deg,#34e0c8,#7c5cff);color:#06070a;border-radius:999px;font-size:9px;font-weight:700;display:flex;align-items:center;gap:4px}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.kpi{background:#11131a;border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}
.kpi::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#7c5cff,transparent);transform:scaleX(0);transform-origin:left;animation:bar 2s ease-out 0.8s forwards}
@keyframes bar{to{transform:scaleX(1)}}
.kpi .lb-bar{height:4px;width:50%;background:rgba(255,255,255,0.15);border-radius:2px}
.kpi .num-d{font-weight:800;font-size:18px;letter-spacing:-0.02em;color:#f0f1f5;font-feature-settings:"tnum"}
.kpi .num-d small{color:#34e0c8;font-weight:600;font-size:10px;margin-left:4px}
.charts{display:grid;grid-template-columns:1.4fr 1fr;gap:8px;flex:1}
.ch{background:#11131a;border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:8px}
.ch .ch-h{height:6px;width:60%;background:rgba(255,255,255,0.6);border-radius:3px}
.ch svg{width:100%;height:auto}
.ch .line{stroke-dasharray:300;stroke-dashoffset:300;animation:draw 2s ease-out 1s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.lst-d{display:flex;flex-direction:column;gap:0}
.row-d{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border)}
.row-d:last-child{border-bottom:none}
.row-d .av{width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,#34e0c8,#7c5cff)}
.row-d .av.v2{background:linear-gradient(135deg,#a78bfa,#7c5cff)}
.row-d .av.v3{background:linear-gradient(135deg,#fbbf24,#f59e0b)}
.row-d .lb{height:5px;flex:1;background:rgba(255,255,255,0.1);border-radius:3px}
.row-d .vl{font-size:10px;font-weight:700;color:#f0f1f5}
.base-l{height:14px;background:linear-gradient(180deg,#2a2e38,#171a23);border-radius:0 0 20px 20px;margin:0 -16px;position:relative}
.base-l::before{content:"";position:absolute;left:50%;top:0;transform:translateX(-50%);width:100px;height:6px;background:#0c0d12;border-radius:0 0 8px 8px}

.float{position:absolute;background:rgba(17,19,26,0.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-radius:14px;padding:12px 14px;border:1px solid var(--border-2);box-shadow:0 24px 48px -16px rgba(0,0,0,0.6);display:flex;align-items:center;gap:10px;z-index:3;animation:fl 6s ease-in-out infinite}
@keyframes fl{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.float .ix{width:32px;height:32px;border-radius:9px;background:rgba(124,92,255,0.18);color:#a78bfa;display:grid;place-items:center;flex-shrink:0}
.float .t{font-size:12px;font-weight:700;color:#f0f1f5;line-height:1.2}
.float .s{font-size:10px;color:#a3a8b7;font-family:var(--font-mono);margin-top:2px}
.f1{top:-12px;left:-30px;animation-delay:0s}
.f2{top:40%;right:-40px;animation-delay:1s}
.f3{bottom:20px;left:10%;animation-delay:2s}
.f3 .ix{background:rgba(251,191,36,0.18);color:#fbbf24}

/* ── Section base ────────────────────────────────── */
section{padding:96px 0;position:relative}
section.alt{background:rgba(255,255,255,0.015)}
.section-head{text-align:center;max-width:720px;margin:0 auto 56px}
.section-tag{display:inline-block;font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--accent);letter-spacing:0.12em;text-transform:uppercase;padding:5px 12px;border-radius:999px;background:rgba(52,224,200,0.10);border:1px solid rgba(52,224,200,0.2);margin-bottom:16px}
h2.section-title{font-size:clamp(32px,4vw,52px);font-weight:800;letter-spacing:-0.03em;line-height:1.1;margin:0 0 16px;color:var(--text)}
h2.section-title .accent{background:linear-gradient(110deg,#34e0c8,#7c5cff);-webkit-background-clip:text;background-clip:text;color:transparent}
.section-lede{font-size:17px;color:var(--text-2);line-height:1.6;margin:0 auto;max-width:600px}

/* ── AI Demo Section ─────────────────────────────── */
.ai-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.ai-feature h3{font-size:36px;font-weight:800;letter-spacing:-0.025em;line-height:1.1;margin:0 0 20px;color:var(--text)}
.ai-feature h3 .accent{background:linear-gradient(110deg,#34e0c8,#7c5cff);-webkit-background-clip:text;background-clip:text;color:transparent}
.ai-feature p{font-size:17px;line-height:1.6;color:var(--text-2);margin:0 0 24px}
.ai-feature .feats{list-style:none;padding:0;margin:0 0 28px;display:grid;gap:12px}
.ai-feature .feats li{display:flex;gap:12px;align-items:flex-start;font-size:15px;color:var(--text-2)}
.ai-feature .feats .ck{width:24px;height:24px;border-radius:7px;background:rgba(52,224,200,0.15);color:var(--accent);display:grid;place-items:center;flex-shrink:0;margin-top:2px}
.ai-feature .feats b{font-weight:700;display:block;color:var(--text);margin-bottom:2px}
.ai-feature .feats span{color:var(--text-2);font-size:14px}

.chat-preview{background:#11131a;border-radius:24px;border:1px solid var(--border-2);box-shadow:var(--shadow-xl);overflow:hidden;display:flex;flex-direction:column;height:560px}
.chat-head{background:linear-gradient(135deg,#171a23,#0c0d12);color:#fff;padding:18px 22px;display:flex;align-items:center;gap:12px;position:relative;overflow:hidden;flex-shrink:0;border-bottom:1px solid var(--border)}
.chat-head::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 100% at 100% 0%,rgba(124,92,255,0.4),transparent 60%)}
.chat-head>*{position:relative;z-index:1}
.bot-av{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,#34e0c8,#7c5cff);display:grid;place-items:center;flex-shrink:0;box-shadow:0 8px 16px -4px rgba(124,92,255,0.5);position:relative}
.bot-av::after{content:"";position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;border-radius:50%;background:var(--green);border:2.5px solid #11131a}
.chat-head h4{margin:0;font-size:15px;font-weight:700;color:var(--text)}
.chat-head .sub{font-family:var(--font-mono);font-size:10.5px;color:var(--text-3);letter-spacing:0.06em;margin-top:1px}
.chat-body{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:14px;background:#06070a;min-height:0}
.msg{display:flex;gap:10px;align-items:flex-end;animation:slI 0.3s ease-out}
@keyframes slI{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.msg.user{flex-direction:row-reverse}
.msg .av-sm{width:26px;height:26px;border-radius:7px;flex-shrink:0;display:grid;place-items:center;font-size:10px;font-weight:700;color:#06070a}
.msg.bot .av-sm{background:linear-gradient(135deg,#34e0c8,#7c5cff)}
.msg.user .av-sm{background:linear-gradient(135deg,#a3a8b7,#6a7080);color:#06070a}
.bubble{max-width:78%;padding:11px 15px;border-radius:14px;font-size:13.5px;line-height:1.5}
.msg.bot .bubble{background:#11131a;border:1px solid var(--border);border-bottom-left-radius:4px;color:var(--text)}
.msg.user .bubble{background:linear-gradient(135deg,#7c5cff,#5a3fd9);color:#fff;border-bottom-right-radius:4px;box-shadow:0 4px 12px -2px rgba(124,92,255,0.4)}
.typing{display:flex;gap:4px;padding:6px 0}
.typing span{width:6px;height:6px;border-radius:50%;background:var(--text-2);opacity:0.5;animation:bn 1.2s infinite}
.typing span:nth-child(2){animation-delay:0.15s}
.typing span:nth-child(3){animation-delay:0.3s}
@keyframes bn{0%,60%,100%{transform:translateY(0);opacity:0.4}30%{transform:translateY(-5px);opacity:1}}
.chips{display:flex;gap:6px;flex-wrap:wrap;padding:0 20px 12px;background:#06070a}
.chip{padding:7px 12px;border-radius:999px;background:#11131a;border:1px solid var(--border);font-size:12px;color:var(--text-2);cursor:pointer;transition:0.2s;font-family:inherit}
.chip:hover{border-color:var(--blue);background:rgba(124,92,255,0.10);color:var(--text)}
.chat-input{padding:14px 18px;background:#11131a;border-top:1px solid var(--border);display:flex;gap:8px;align-items:center;flex-shrink:0}
.chat-input input{flex:1;padding:11px 14px;border:1px solid var(--border);border-radius:10px;font:inherit;font-size:13.5px;background:#06070a;outline:none;transition:0.2s;color:var(--text)}
.chat-input input::placeholder{color:var(--text-3)}
.chat-input input:focus{border-color:var(--blue);background:#0c0d12;box-shadow:0 0 0 4px rgba(124,92,255,0.15)}
.chat-input button{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#34e0c8,#7c5cff);border:none;color:#06070a;cursor:pointer;display:grid;place-items:center;transition:0.2s;flex-shrink:0}
.chat-input button:hover:not(:disabled){transform:scale(1.05)}
.chat-input button:disabled{opacity:0.4;cursor:not-allowed}

/* ── Markttest notice (Konfigurator) ──────────────── */
.markttest-notice{
  display:flex;align-items:flex-start;gap:14px;
  padding:18px 22px;
  background:linear-gradient(135deg,rgba(251,191,36,0.10),rgba(124,92,255,0.06));
  border:1px solid rgba(251,191,36,0.30);
  border-radius:14px;
  margin:0 0 48px;
  color:var(--text);
}
.markttest-notice .mn-ic{flex-shrink:0;color:var(--amber);margin-top:2px;width:22px;height:22px}
.markttest-notice b{color:var(--amber);font-weight:700}
.markttest-notice p{margin:0;font-size:14px;line-height:1.55;color:var(--text-2)}
.markttest-notice strong{color:var(--text);font-weight:700}

/* ── Calculator section ──────────────────────────── */
.calc-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:24px;align-items:start}
.calc-card{background:#11131a;border:1px solid var(--border);border-radius:20px;padding:32px;box-shadow:var(--shadow-lg)}
.calc-card h3{margin:0 0 6px;font-size:20px;font-weight:700;letter-spacing:-0.02em;color:var(--text)}
.calc-card .sub-c{color:var(--text-2);font-size:14px;margin:0 0 24px}
.step{margin-bottom:24px}
.step-label{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600;color:var(--text);margin-bottom:10px}
.step-label .val{font-family:var(--font-mono);font-size:12px;color:var(--accent);background:rgba(52,224,200,0.10);padding:4px 10px;border-radius:6px}
.opts{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.opt{padding:13px;border:1.5px solid var(--border);border-radius:11px;background:#0c0d12;cursor:pointer;transition:0.2s;font:inherit;text-align:left;font-size:13px;color:var(--text-2)}
.opt:hover{border-color:var(--blue);background:rgba(124,92,255,0.08);color:var(--text)}
.opt.active{border-color:var(--blue);background:linear-gradient(135deg,rgba(124,92,255,0.20),rgba(52,224,200,0.10));color:var(--text);box-shadow:0 8px 16px -4px rgba(124,92,255,0.35)}
.opt b{display:block;font-size:13.5px;font-weight:700;margin-bottom:2px;color:var(--text)}
.opt span{font-size:11px;opacity:0.7}
input[type=range]{width:100%;height:6px;-webkit-appearance:none;appearance:none;background:rgba(255,255,255,0.08);border-radius:3px;outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#34e0c8,#7c5cff);box-shadow:0 4px 12px -2px rgba(124,92,255,0.5),0 0 0 4px #11131a;cursor:pointer;transition:0.15s}
input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}
input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#34e0c8,#7c5cff);border:4px solid #11131a;box-shadow:0 4px 12px -2px rgba(124,92,255,0.5);cursor:pointer}
.toggles{display:flex;flex-direction:column;gap:8px}
.tg{display:flex;align-items:center;justify-content:space-between;padding:13px 15px;background:#0c0d12;border:1px solid var(--border);border-radius:11px;cursor:pointer;transition:0.2s;text-align:left;font-family:inherit;color:var(--text);width:100%}
.tg:hover{border-color:var(--blue)}
.tg.on{background:linear-gradient(135deg,rgba(124,92,255,0.15),rgba(52,224,200,0.06));border-color:var(--blue)}
.tg b{font-size:13.5px;font-weight:600;color:var(--text)}
.tg small{display:block;color:var(--text-3);font-size:11px;font-family:var(--font-mono);margin-top:2px}
.switch{width:36px;height:20px;background:rgba(255,255,255,0.12);border-radius:999px;position:relative;transition:0.2s;flex-shrink:0;margin-left:12px}
.switch::after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:0.2s;box-shadow:0 2px 4px rgba(0,0,0,0.3)}
.tg.on .switch{background:linear-gradient(135deg,#34e0c8,#7c5cff)}
.tg.on .switch::after{transform:translateX(16px)}
.result-card{position:sticky;top:96px;background:linear-gradient(135deg,#171a23,#0c0d12);color:#fff;border-radius:20px;padding:28px;box-shadow:var(--shadow-xl);overflow:hidden;border:1px solid var(--border-2)}
.result-card::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 100% 0%,rgba(124,92,255,0.4),transparent 60%);pointer-events:none}
.result-card>*{position:relative;z-index:1}
.result-card h3{margin:0 0 4px;color:#fff;font-size:16px;font-weight:700}
.sub-r{color:rgba(255,255,255,0.6);font-size:11px;font-family:var(--font-mono);margin-bottom:20px;letter-spacing:0.04em}
.est{text-align:center;padding:20px 0;border-top:1px solid rgba(255,255,255,0.1);border-bottom:1px solid rgba(255,255,255,0.1);margin-bottom:20px}
.est-label{font-family:var(--font-mono);font-size:10px;color:rgba(255,255,255,0.5);letter-spacing:0.08em;text-transform:uppercase;margin-bottom:8px}
.est-num{font-size:38px;font-weight:800;letter-spacing:-0.03em;line-height:1;font-feature-settings:"tnum";background:linear-gradient(110deg,#34e0c8,#a78bfa);-webkit-background-clip:text;background-clip:text;color:transparent}
.est-num span{font-size:22px;color:rgba(255,255,255,0.5);margin:0 8px;background:none;-webkit-text-fill-color:rgba(255,255,255,0.5)}
.est-meta{font-size:11px;color:rgba(255,255,255,0.5);margin-top:8px;font-family:var(--font-mono)}
.breakdown{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;font-size:13px}
.br-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px dashed rgba(255,255,255,0.1)}
.br-row span{color:rgba(255,255,255,0.7)}
.br-row b{font-family:var(--font-mono);font-size:11.5px;color:#fff}
.timeline-bar{margin-bottom:18px}
.timeline-bar .lbl-t{display:flex;justify-content:space-between;font-size:10px;color:rgba(255,255,255,0.6);font-family:var(--font-mono);margin-bottom:6px;letter-spacing:0.04em}
.timeline-bar .track{height:7px;background:rgba(255,255,255,0.1);border-radius:4px}
.timeline-bar .fill{height:100%;background:linear-gradient(90deg,#34e0c8,#7c5cff);border-radius:4px;transition:0.4s cubic-bezier(0.34,1.56,0.64,1)}
.btn-w{display:flex;width:100%;align-items:center;justify-content:center;gap:8px;padding:13px;border-radius:11px;background:linear-gradient(135deg,#34e0c8,#7c5cff);color:#06070a;font-weight:700;font-size:14px;border:none;cursor:pointer;font-family:inherit;transition:0.2s}
.btn-w:hover{transform:translateY(-1px);box-shadow:0 14px 32px -8px rgba(124,92,255,0.6)}
.disclaim-c{font-size:10.5px;color:rgba(255,255,255,0.5);text-align:center;margin-top:12px;line-height:1.5}

/* ── Services compact ────────────────────────────── */
.services-compact{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:64px}
.sc-card{background:#11131a;border:1px solid var(--border);border-radius:14px;padding:24px;transition:0.25s;position:relative;display:flex;flex-direction:column}
.sc-card:hover{border-color:rgba(124,92,255,0.45);box-shadow:var(--shadow-lg);transform:translateY(-3px);background:#171a23}
.sc-card .ix-c{width:40px;height:40px;border-radius:10px;background:rgba(124,92,255,0.15);color:#a78bfa;display:grid;place-items:center;margin-bottom:16px;transition:0.25s}
.sc-card:hover .ix-c{background:rgba(124,92,255,0.25);color:#fff}
.sc-card h5{margin:0 0 8px;font-size:16px;font-weight:700;letter-spacing:-0.015em;color:var(--text)}
.sc-card p{margin:0;font-size:13.5px;line-height:1.55;color:var(--text-2)}

.sc-points{
  list-style:none;
  padding:14px 0 0;
  margin:14px 0 0;
  border-top:1px solid var(--border);
  display:flex;flex-direction:column;
  gap:8px;
}
.sc-points li{
  font-size:11.5px;
  color:var(--text-2);
  font-family:var(--font-mono);
  padding-left:14px;
  position:relative;
  line-height:1.4;
  letter-spacing:0.02em;
}
.sc-points li::before{
  content:"";
  position:absolute;
  left:0;top:7px;
  width:7px;height:1px;
  background:linear-gradient(90deg,#34e0c8,#7c5cff);
}

.sc-card-highlight{
  background:linear-gradient(180deg,rgba(124,92,255,0.07),#11131a 70%);
  border-color:rgba(124,92,255,0.30);
}
.sc-card-highlight:hover{
  background:linear-gradient(180deg,rgba(124,92,255,0.11),#171a23 70%);
  border-color:rgba(124,92,255,0.55);
  box-shadow:0 16px 36px -10px rgba(124,92,255,0.45);
}
.sc-card-highlight .ix-c{
  background:linear-gradient(135deg,rgba(52,224,200,0.20),rgba(124,92,255,0.25));
  color:#fff;
}
.sc-card-highlight .sc-points li::before{
  background:linear-gradient(90deg,#34e0c8,#a78bfa);
  width:9px;
}

.sc-badge{
  position:absolute;
  top:-1px;right:18px;
  font-family:var(--font-mono);
  font-size:9.5px;
  font-weight:700;
  letter-spacing:0.10em;
  text-transform:uppercase;
  padding:5px 10px;
  background:linear-gradient(135deg,#34e0c8,#7c5cff);
  color:#06070a;
  border-radius:0 0 6px 6px;
  box-shadow:0 4px 12px -2px rgba(124,92,255,0.4);
}

.leistungen-cta{text-align:center;margin-top:56px}
.leistungen-cta-sub{font-size:13px;color:var(--text-3);margin:14px 0 0;font-family:var(--font-mono);letter-spacing:0.02em}

/* ── Services outro (homepage) ────────────────────── */
.services-outro{
  text-align:center;margin-top:48px;
  font-size:14px;color:var(--text-2);
  font-family:var(--font-mono);letter-spacing:0.02em;
}
.services-outro a{
  color:var(--accent);text-decoration:none;
  border-bottom:1px solid rgba(52,224,200,0.35);
  padding-bottom:1px;transition:0.2s;
}
.services-outro a:hover{color:var(--text);border-bottom-color:var(--accent)}

/* ── CTA Strip (closing section) ──────────────────── */
.cta-strip{
  background:linear-gradient(135deg,rgba(124,92,255,0.10),rgba(52,224,200,0.05));
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  text-align:center;padding:96px 0;position:relative;overflow:hidden;
}
.cta-strip::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 60% 80% at 50% 100%,rgba(124,92,255,0.18),transparent 60%);
}
.cta-strip>*{position:relative;z-index:1}
.cta-strip .section-tag{margin-bottom:18px}
.cta-strip h2{
  font-size:clamp(32px,4vw,52px);
  font-weight:800;letter-spacing:-0.03em;line-height:1.1;
  margin:0 0 16px;color:var(--text);
}
.cta-strip p{
  font-size:17px;line-height:1.6;color:var(--text-2);
  max-width:560px;margin:0 auto 32px;
}
.cta-strip .hero-cta{justify-content:center}

/* ── About ───────────────────────────────────────── */
.about-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:64px;align-items:center}
.about-portrait{aspect-ratio:1/1.1;border-radius:24px;background:linear-gradient(135deg,rgba(124,92,255,0.18),rgba(52,224,200,0.08));position:relative;overflow:hidden;display:grid;place-items:center;border:1px solid var(--border-2);padding:8px}
.about-portrait::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 50% 0%,rgba(124,92,255,0.20),transparent 60%),radial-gradient(ellipse 60% 50% at 50% 100%,rgba(52,224,200,0.12),transparent 60%);pointer-events:none}
.about-illustration{position:relative;z-index:1;width:100%;height:100%;display:block;filter:drop-shadow(0 24px 48px rgba(124,92,255,0.25))}
.ph-label{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:11px;color:var(--text-2);letter-spacing:0.08em;background:rgba(17,19,26,0.85);padding:5px 10px;border-radius:999px;backdrop-filter:blur(8px);border:1px solid var(--border)}
.about h2{font-size:clamp(32px,3.5vw,44px);font-weight:800;letter-spacing:-0.03em;line-height:1.15;margin:18px 0 18px;color:var(--text)}
.about h2 .accent{background:linear-gradient(110deg,#34e0c8,#7c5cff);-webkit-background-clip:text;background-clip:text;color:transparent}
.about p{font-size:16px;line-height:1.65;color:var(--text-2);margin:0 0 14px}
.about-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:22px;padding-top:22px;border-top:1px solid var(--border)}
.about-meta div{display:flex;flex-direction:column;gap:2px}
.about-meta b{font-family:var(--font-mono);font-size:10.5px;font-weight:600;color:var(--text-3);letter-spacing:0.08em;text-transform:uppercase}
.about-meta span{font-size:14px;color:var(--text);font-weight:500}

/* ── Process ─────────────────────────────────────── */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--border);border-radius:20px;background:#11131a;overflow:hidden;box-shadow:var(--shadow-lg)}
.process-step{padding:32px 24px;border-right:1px solid var(--border);background:transparent;transition:0.2s}
.process-step:hover{background:rgba(124,92,255,0.04)}
.process-step:last-child{border-right:none}
.process-step .ix{font-family:var(--font-mono);font-size:12px;font-weight:700;color:var(--accent);background:rgba(52,224,200,0.10);padding:5px 10px;border-radius:8px;display:inline-block;margin-bottom:14px;border:1px solid rgba(52,224,200,0.2)}
.process-step h4{font-size:18px;font-weight:700;letter-spacing:-0.015em;margin:0 0 8px;color:var(--text)}
.process-step p{font-size:13.5px;line-height:1.55;color:var(--text-2);margin:0}

/* ── Contact ─────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
.contact-info h2{font-size:clamp(32px,3.5vw,44px);font-weight:800;letter-spacing:-0.03em;line-height:1.15;margin:16px 0 18px;color:var(--text)}
.contact-info h2 .accent{background:linear-gradient(110deg,#34e0c8,#7c5cff);-webkit-background-clip:text;background-clip:text;color:transparent}
.contact-info p{font-size:16px;line-height:1.6;color:var(--text-2);margin:0 0 24px}
.contact-list{display:flex;flex-direction:column;gap:14px;padding-top:24px;border-top:1px solid var(--border)}
.cli{display:flex;gap:14px;align-items:flex-start}
.cli .icx{width:38px;height:38px;border-radius:10px;background:rgba(124,92,255,0.15);color:#a78bfa;display:grid;place-items:center;flex-shrink:0}
.cli b{display:block;font-size:11px;font-family:var(--font-mono);color:var(--text-3);letter-spacing:0.08em;text-transform:uppercase;margin-bottom:2px}
.cli span{font-size:14px;color:var(--text);font-weight:500}
.contact-card{background:#11131a;border:1px solid var(--border);border-radius:20px;padding:32px;box-shadow:var(--shadow-lg)}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field>span{font-size:12px;font-weight:600;color:var(--text-2);font-family:var(--font-mono);letter-spacing:0.04em}
.field input,.field textarea,.field select{padding:11px 13px;border:1px solid var(--border);border-radius:10px;font:inherit;font-size:14px;background:#06070a;outline:none;transition:0.2s;color:var(--text);font-family:inherit}
.field input::placeholder,.field textarea::placeholder{color:var(--text-3)}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--blue);background:#0c0d12;box-shadow:0 0 0 4px rgba(124,92,255,0.15)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.consent{display:flex;gap:10px;align-items:flex-start;margin:8px 0 6px;padding:14px;background:#06070a;border-radius:10px;border:1px solid var(--border);font-size:12px;line-height:1.55;color:var(--text-2);cursor:pointer}
.consent input{margin-top:2px;flex-shrink:0;accent-color:var(--blue)}
.form-success{display:none;align-items:center;gap:14px;padding:16px;background:linear-gradient(135deg,rgba(52,224,200,0.15),rgba(124,92,255,0.10));border:1px solid rgba(52,224,200,0.3);border-radius:11px;animation:fU 0.4s}
.form-success.show{display:flex}
.form-success .ok{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#06070a;display:grid;place-items:center;flex-shrink:0}
.form-success b{display:block;font-size:14px;color:var(--accent);margin-bottom:2px}
.form-success span{font-size:12.5px;color:var(--text-2)}

/* ── FAB ─────────────────────────────────────────── */
.chat-fab{position:fixed;bottom:24px;right:24px;z-index:100;width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#34e0c8,#7c5cff);color:#06070a;border:none;cursor:pointer;display:grid;place-items:center;box-shadow:0 16px 32px -8px rgba(124,92,255,0.6);transition:0.2s;animation:fb 0.5s 1s both;text-decoration:none}
@keyframes fb{from{opacity:0;transform:scale(0.5)}to{opacity:1;transform:scale(1)}}
.chat-fab:hover{transform:scale(1.08);box-shadow:0 20px 40px -8px rgba(124,92,255,0.8)}
.chat-fab .badge{position:absolute;top:-2px;right:-2px;background:var(--accent);color:#06070a;font-size:10px;font-weight:700;padding:3px 6px;border-radius:999px;border:2px solid #06070a;font-family:var(--font-mono);letter-spacing:0.04em}
.chat-fab .badge::before{content:"";position:absolute;inset:-2px;border-radius:999px;background:var(--accent);opacity:0.5;animation:rg 1.5s infinite;z-index:-1}
@keyframes rg{0%{transform:scale(1);opacity:0.6}100%{transform:scale(1.6);opacity:0}}

/* ── Footer ──────────────────────────────────────── */
footer{background:#06070a;color:#fff;padding:64px 0 32px;position:relative;overflow:hidden;border-top:1px solid var(--border)}
footer::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 80% 100%,rgba(124,92,255,0.18),transparent 60%);pointer-events:none}
footer>*{position:relative;z-index:1}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:48px;margin-bottom:48px}
.footer-brand .brand{color:var(--text)}
.footer-brand .brand-name{color:var(--text)}
.footer-brand .brand-name small{color:var(--text-3)}
.footer-brand p{color:var(--text-2);font-size:14px;line-height:1.6;margin:18px 0 18px;max-width:340px}
.footer-status{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;color:var(--text);padding:6px 12px;border-radius:999px;background:rgba(251,191,36,0.10);border:1px solid rgba(251,191,36,0.25);letter-spacing:0.04em}
.footer-status .dot{width:6px;height:6px;border-radius:50%;background:var(--amber);box-shadow:0 0 8px var(--amber)}
.footer-col h6{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:0.1em;margin:0 0 16px}
.footer-col a{display:block;color:var(--text-2);text-decoration:none;font-size:14px;margin-bottom:10px;transition:0.2s}
.footer-col a:hover{color:var(--text)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--border);font-family:var(--font-mono);font-size:11px;color:var(--text-3);letter-spacing:0.04em}

/* ── Legal pages ─────────────────────────────────── */
.legal-page{padding:80px 0 96px;max-width:820px;margin:0 auto}
.legal-page h1{font-size:clamp(34px,4.5vw,52px);font-weight:800;letter-spacing:-0.03em;margin:24px 0 14px}
.legal-page h1 .accent{background:linear-gradient(110deg,#34e0c8,#7c5cff);-webkit-background-clip:text;background-clip:text;color:transparent}
.legal-page .lede{font-size:17px;color:var(--text-2);line-height:1.6;margin:0 0 36px}
.legal-block{background:#11131a;border:1px solid var(--border);border-radius:14px;padding:24px 28px;margin-bottom:18px}
.legal-block h2{font-size:18px;font-weight:700;margin:0 0 10px;color:var(--text);letter-spacing:-0.01em}
.legal-block p,.legal-block address{color:var(--text-2);font-size:15px;line-height:1.65;margin:0 0 8px;font-style:normal}
.legal-block p:last-child{margin-bottom:0}
.legal-block a{color:var(--text);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--blue)}

/* ── Responsive ──────────────────────────────────── */
@media(max-width:1024px){
  .hero-grid,.ai-grid,.calc-grid,.about-grid,.contact-grid{grid-template-columns:1fr;gap:48px}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .process-step:nth-child(2){border-right:none}
  .process-step:nth-child(1),.process-step:nth-child(2){border-bottom:1px solid var(--border)}
  .services-compact{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .nav-toggle{display:inline-flex}
  nav.top .btn-primary{display:none}        /* CTA reachable via the menu (Kontakt) */
  .nav-links{display:none}
  .nav-links.open{
    display:flex;flex-direction:column;align-items:stretch;
    position:absolute;top:66px;left:0;right:0;margin:0 20px;
    background:rgba(10,12,17,0.98);
    backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);
    border:1px solid var(--border);border-radius:14px;
    padding:8px;gap:2px;
    box-shadow:0 16px 40px rgba(0,0,0,0.55);
  }
  .nav-links.open a{padding:13px 16px;border-radius:10px;font-size:15px}
  .result-card{position:relative;top:0}
  .float{display:none}
}
@media(max-width:640px){
  .container{padding:0 20px}
  .services-compact{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .perf{flex-wrap:wrap;gap:16px}
  .perf .item{flex:1 1 40%;border-right:none;padding:0;border-bottom:1px solid var(--border);padding-bottom:12px}
  .opts{grid-template-columns:1fr}
}
