/* ============================================================
   SiDo IT Consulting — Website  ·  PREMIUM EDITION
   Dark plum, burgundy→coral signature. Refined, modern, edel.
   All JS hooks preserved (.reveal/.in, .jv-*, .marquee, .stat .num,
   .nav.scrolled, [data-ico], .lang-*, #cform, .form-done …).
   ============================================================ */
:root{
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-soft:cubic-bezier(.4,0,.2,1);
  --maxw:1200px;
  /* refined elevation */
  --sh-card:0 2px 4px rgba(0,0,0,.2),0 12px 32px -12px rgba(0,0,0,.55);
  --sh-pop:0 8px 18px -6px rgba(0,0,0,.5),0 30px 60px -18px rgba(0,0,0,.7);
  --hair:rgba(255,255,255,.08);
  --hair-2:rgba(255,255,255,.14);
  --card:linear-gradient(180deg,rgba(42,24,34,.55),rgba(25,13,19,.55));
  --card-solid:linear-gradient(180deg,#241420,#1b0e15);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:
    radial-gradient(120% 70% at 50% -8%, rgba(230,60,88,.10), transparent 55%),
    radial-gradient(90% 50% at 92% 8%, rgba(109,31,55,.22), transparent 60%),
    var(--ink-900);
  color:var(--fg-1);
  font-family:var(--font-body);font-weight:300;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--brand-coral);color:#fff}

/* ---- custom brand scrollbar (desktop) ---- */
html{scrollbar-width:thin;scrollbar-color:#7a2440 transparent}
@media(min-width:820px){
  ::-webkit-scrollbar{width:13px;height:13px}
  ::-webkit-scrollbar-track{background:rgba(255,255,255,.03)}
  ::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#6D1F37,#E63C58);border-radius:999px;
    border:3px solid var(--ink-900);background-clip:padding-box;min-height:60px}
  ::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#E63C58,#EC6D82);border:3px solid var(--ink-900);background-clip:padding-box}
}

/* ---- hero aurora (subtle drifting light) ---- */
.aurora{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.aurora span{position:absolute;border-radius:50%;filter:blur(72px);mix-blend-mode:screen;will-change:transform}
.aurora span:nth-child(1){width:540px;height:540px;top:-150px;left:4%;background:radial-gradient(circle,rgba(230,60,88,.42),transparent 70%);animation:aur1 19s ease-in-out infinite}
.aurora span:nth-child(2){width:480px;height:480px;top:10px;right:-2%;background:radial-gradient(circle,rgba(109,31,55,.6),transparent 70%);animation:aur2 23s ease-in-out infinite}
.aurora span:nth-child(3){width:400px;height:400px;bottom:-170px;left:40%;background:radial-gradient(circle,rgba(236,109,130,.26),transparent 70%);animation:aur3 27s ease-in-out infinite}
@keyframes aur1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(46px,34px) scale(1.08)}}
@keyframes aur2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-40px,28px) scale(1.06)}}
@keyframes aur3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(30px,-30px) scale(1.1)}}
@media (prefers-reduced-motion:reduce){.aurora span{animation:none}}

/* fixed grain overlay (added in HTML) */
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  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='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---- circular scroll-progress / back-to-top ---- */
.to-top{position:fixed;right:28px;bottom:28px;width:54px;height:54px;z-index:200;border:none;cursor:pointer;
  background:rgba(20,11,16,.6);backdrop-filter:blur(14px) saturate(140%);border-radius:50%;
  box-shadow:0 10px 30px -8px rgba(0,0,0,.6),inset 0 0 0 1px var(--hair-2);
  display:flex;align-items:center;justify-content:center;padding:0;
  opacity:0;visibility:hidden;transform:translateY(16px) scale(.85);transition:opacity .4s var(--ease),transform .4s var(--ease),box-shadow .3s}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:hover{box-shadow:0 16px 40px -8px rgba(230,60,88,.5),inset 0 0 0 1px rgba(230,60,88,.4)}
.to-top svg{position:absolute;inset:0;width:100%;height:100%;transform:rotate(-90deg);overflow:visible}
.to-top .tt-bg{fill:none;stroke:rgba(255,255,255,.1);stroke-width:2.5}
.to-top .tt-prog{fill:none;stroke:url(#ttgrad,#E63C58);stroke:var(--brand-coral);stroke-width:2.5;stroke-linecap:round;
  stroke-dasharray:125.66;stroke-dashoffset:125.66;filter:drop-shadow(0 0 5px rgba(230,60,88,.8));transition:stroke-dashoffset .12s linear}
.to-top .tt-ico{position:relative;z-index:2;color:var(--fg-1);display:flex;transition:transform .3s var(--ease),color .3s}
.to-top:hover .tt-ico{transform:translateY(-2px);color:var(--brand-coral-light)}
.to-top .tt-ico svg{position:static;width:18px;height:18px;transform:none;stroke:currentColor}

/* ---- language toast ---- */
.lang-toast{position:fixed;top:22px;left:50%;transform:translate(-50%,-24px);z-index:400;
  display:flex;align-items:center;gap:11px;padding:11px 20px;border-radius:999px;
  background:rgba(20,11,16,.82);backdrop-filter:blur(18px) saturate(140%);border:1px solid var(--hair-2);
  box-shadow:var(--sh-pop);font-family:var(--font-display);font-weight:700;font-size:13.5px;letter-spacing:.02em;color:var(--fg-1);
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .35s var(--ease),transform .35s var(--ease)}
.lang-toast.show{opacity:1;visibility:visible;transform:translate(-50%,0)}
.lt-spin{width:15px;height:15px;border-radius:50%;border:2px solid rgba(230,60,88,.25);border-top-color:var(--brand-coral);animation:ltspin .7s linear infinite}
@keyframes ltspin{to{transform:rotate(360deg)}}
/* content fade during language swap */
.hero,.section,.footer{transition:opacity .3s var(--ease-soft)}
body.lang-fading .hero,body.lang-fading .section,body.lang-fading .footer{opacity:.32}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.section{position:relative;padding:clamp(80px,11vw,156px) 0;z-index:2}

/* hairline section divider */
.section + .section::before,.divider{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:min(var(--maxw),calc(100% - 64px));height:1px;
  background:linear-gradient(90deg,transparent,var(--hair),transparent)}

/* ---------- shared atoms ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  letter-spacing:.2em;font-size:12px;color:var(--brand-coral-light);
  padding:8px 16px 8px 14px;border:1px solid rgba(230,60,88,.26);
  border-radius:999px;background:linear-gradient(180deg,rgba(230,60,88,.14),rgba(230,60,88,.05));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);backdrop-filter:blur(6px)}
.eyebrow svg{width:15px;height:15px}

.h-xl{font-family:var(--font-display);font-weight:700;letter-spacing:-.03em;line-height:.96;font-size:clamp(42px,6vw,82px)}
.h-lg{font-family:var(--font-display);font-weight:700;letter-spacing:-.025em;line-height:1.02;font-size:clamp(33px,4.6vw,60px)}
.h-md{font-family:var(--font-display);font-weight:700;letter-spacing:-.01em;font-size:clamp(22px,2.4vw,30px)}
.lead{font-weight:300;font-size:clamp(17px,1.35vw,20px);line-height:1.62;color:var(--fg-2)}
.body{font-weight:300;font-size:16px;line-height:1.65;color:var(--fg-2)}
.gtext{background:linear-gradient(105deg,#EC6D82 0%,#E63C58 45%,#B23048 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.ital{font-style:italic}
.muted{color:var(--fg-3)}

/* ---------- buttons ---------- */
.btn{position:relative;font-family:var(--font-display);font-weight:700;font-size:15px;border-radius:999px;
  padding:15px 30px;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:10px;
  letter-spacing:.01em;transition:transform .25s var(--ease),box-shadow .25s,background .25s,border-color .25s;white-space:nowrap;overflow:hidden;isolation:isolate}
.btn svg{width:18px;height:18px;transition:transform .25s var(--ease)}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--grad-brand);color:#fff;box-shadow:0 6px 20px -6px rgba(230,60,88,.6),inset 0 1px 0 rgba(255,255,255,.22)}
.btn-primary::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(255,255,255,.25),transparent 45%);opacity:.7}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 42px -8px rgba(230,60,88,.7),inset 0 1px 0 rgba(255,255,255,.25)}
.btn-primary:hover svg{transform:translateX(3px)}
.btn-ghost{background:rgba(255,255,255,.02);color:var(--fg-1);border:1px solid var(--hair-2);backdrop-filter:blur(6px)}
.btn-ghost:hover{border-color:var(--brand-coral);background:rgba(230,60,88,.1);transform:translateY(-2px)}

/* ambient decorative glows */
.glow{position:absolute;border-radius:50%;pointer-events:none;z-index:0;filter:blur(8px)}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;inset:0 0 auto 0;z-index:200;transition:all .35s var(--ease-soft);border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(15,8,11,.72);backdrop-filter:blur(20px) saturate(140%);border-bottom:1px solid var(--hair)}
.nav-inner{display:flex;align-items:center;height:104px;gap:30px;transition:height .35s var(--ease-soft)}
.nav.scrolled .nav-inner{height:78px}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:56px;display:block;transition:height .35s var(--ease-soft)}
.nav.scrolled .nav-logo img{height:42px}
.nav-links{display:flex;gap:2px}
.nav-links a{position:relative;padding:10px 16px;font-size:14.5px;color:var(--fg-2);border-radius:10px;transition:color .25s;white-space:nowrap}
.nav-links a::after{content:"";position:absolute;left:16px;right:16px;bottom:6px;height:1.5px;background:var(--grad-coral);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--fg-1)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-actions{display:flex;align-items:center;gap:14px;margin-left:auto}
.lang-switch{position:relative;display:flex;align-items:center;gap:3px;padding:4px;border:1px solid var(--hair-2);border-radius:999px;background:rgba(255,255,255,.04)}
.lang-switch::before{content:"";position:absolute;top:4px;left:4px;width:34px;height:28px;border-radius:999px;
  background:linear-gradient(180deg,rgba(230,60,88,.32),rgba(230,60,88,.16));box-shadow:inset 0 0 0 1px rgba(230,60,88,.4);
  transition:transform .4s var(--ease)}
.lang-switch[data-active="en"]::before{transform:translateX(37px)}
.lang-btn{position:relative;z-index:2;width:34px;height:28px;border:none;background:transparent;border-radius:999px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.45;transition:opacity .25s;padding:0}
.lang-btn:hover{opacity:.8}
.lang-btn.active{opacity:1}
.lang-flag{width:22px;height:16px;border-radius:3px;overflow:hidden;display:block;box-shadow:0 0 0 1px rgba(0,0,0,.25)}
.nav-burger{display:none;width:46px;height:46px;border-radius:13px;border:1px solid var(--hair-2);background:rgba(255,255,255,.03);color:#fff;align-items:center;justify-content:center;cursor:pointer;flex:none}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;padding-top:210px;padding-bottom:110px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:radial-gradient(110% 80% at 50% 0,#000,transparent 72%);mask-image:radial-gradient(110% 80% at 50% 0,#000,transparent 72%)}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.12fr .88fr;gap:60px;align-items:center}
.hero h1{margin:24px 0 0}
.hero .lead{margin-top:28px;max-width:47ch}
.hero-cta{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap}
.hero-trust{display:flex;gap:12px 26px;flex-wrap:wrap;align-items:center;margin-top:58px;color:var(--fg-3);
  padding-top:28px;border-top:1px solid var(--hair)}
.hero-trust .lbl{font-family:var(--font-display);font-weight:700;font-size:11.5px;letter-spacing:.18em;text-transform:uppercase}
.hero-trust b{color:var(--fg-2);font-weight:300;font-size:16px;display:inline-flex;align-items:center;gap:26px}
.hero-trust b::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--brand-coral);box-shadow:0 0 8px var(--brand-coral)}

/* hero visual: clean branded panel with floating glass cards */
.hero-visual{position:relative;height:496px}
.fc-big{position:absolute;inset:34px 8px;border-radius:30px;overflow:hidden;display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(130% 120% at 28% 18%,rgba(230,60,88,.26),transparent 52%),
    linear-gradient(165deg,rgba(48,27,39,.92),rgba(18,10,15,.94));
  border:1px solid var(--hair-2);box-shadow:var(--sh-pop),inset 0 1px 0 rgba(255,255,255,.07)}
.fc-big::before{content:"";position:absolute;inset:0;
  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:40px 40px;-webkit-mask-image:radial-gradient(80% 80% at 50% 40%,#000,transparent 75%);mask-image:radial-gradient(80% 80% at 50% 40%,#000,transparent 75%)}
.fc-big::after{content:"";position:absolute;inset:0;background:conic-gradient(from 130deg at 72% 26%,transparent,rgba(230,60,88,.14),transparent 38%);animation:spin 22s linear infinite}
.fc-big img{width:42%;opacity:.95;position:relative;z-index:2;filter:drop-shadow(0 10px 34px rgba(0,0,0,.55))}
@keyframes spin{to{transform:rotate(360deg)}}
.float-card{position:absolute;width:228px;background:linear-gradient(180deg,rgba(46,27,38,.86),rgba(24,13,19,.86));
  border:1px solid var(--hair-2);border-radius:18px;padding:17px 19px;box-shadow:var(--sh-pop);backdrop-filter:blur(16px) saturate(135%);z-index:3}
.float-card .ico{width:42px;height:42px;border-radius:12px;background:var(--grad-brand);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px -4px rgba(230,60,88,.6),inset 0 1px 0 rgba(255,255,255,.25)}
.float-card .ico svg{width:21px;height:21px;stroke:#fff}
.fc-1{top:0;left:-14px;animation:floaty 6.5s ease-in-out infinite}
.fc-2{top:196px;right:-20px;animation:floaty 7.5s ease-in-out infinite .9s}
.fc-3{bottom:2px;left:24px;animation:floaty 7s ease-in-out infinite .45s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-11px)}}
@media (prefers-reduced-motion:reduce){.float-card,.fc-big::after{animation:none}}

/* ============================================================
   generic card  ·  gradient hairline + glass
   ============================================================ */
.card{position:relative;background:var(--card-solid);border:1px solid var(--hair);border-radius:20px;padding:28px;overflow:hidden;
  transition:transform .3s var(--ease),border-color .3s,box-shadow .3s;box-shadow:0 1px 2px rgba(0,0,0,.25)}
.card::after{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;
  background:linear-gradient(140deg,rgba(230,60,88,.55),rgba(255,255,255,.06) 40%,transparent 70%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .3s}
.card:hover{transform:translateY(-6px);box-shadow:var(--sh-card)}
.card:hover::after{opacity:1}
.card .sheen{position:absolute;inset:0;background:radial-gradient(80% 60% at 50% 0,rgba(230,60,88,.1),transparent 70%);opacity:0;transition:opacity .3s;pointer-events:none}
.card:hover .sheen{opacity:1}
.ico-tile{position:relative;width:54px;height:54px;border-radius:15px;background:var(--grad-brand);display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 22px -6px rgba(230,60,88,.55),inset 0 1px 0 rgba(255,255,255,.28);margin-bottom:22px}
.ico-tile svg{width:26px;height:26px;stroke:#fff}

/* ---------- section intro ---------- */
.sec-head{max-width:660px;margin-bottom:64px}
.sec-head h2{margin-top:18px}
.sec-head .lead{margin-top:20px}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* ============================================================
   SERVICES  ·  4-col, ghost index numbers
   ============================================================ */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:svc}
.svc{counter-increment:svc;display:flex;flex-direction:column}
.svc::before{content:counter(svc,decimal-leading-zero);position:absolute;top:18px;right:22px;
  font-family:var(--font-display);font-weight:700;font-size:34px;letter-spacing:-.02em;line-height:1;
  color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.1);transition:-webkit-text-stroke .3s,color .3s}
.svc:hover::before{-webkit-text-stroke:1px rgba(230,60,88,.45)}
.svc h3{font-family:var(--font-display);font-weight:700;font-size:19px;letter-spacing:-.01em;margin-bottom:9px}
.svc p{font-size:14px;line-height:1.58;color:var(--fg-3)}

/* ============================================================
   STATS  ·  airy, gradient numbers, hairline cells
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hair);border:1px solid var(--hair);border-radius:24px;overflow:hidden}
.stat{padding:40px 30px;background:linear-gradient(180deg,rgba(32,18,26,.6),rgba(18,10,15,.6));text-align:center;position:relative;transition:background .3s}
.stat::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:0;height:2px;background:var(--grad-coral);transition:width .4s var(--ease)}
.stat:hover{background:linear-gradient(180deg,rgba(42,24,34,.7),rgba(25,13,19,.7))}
.stat:hover::before{width:46px}
.stat .num{font-family:var(--font-display);font-weight:700;font-size:clamp(40px,4.8vw,60px);letter-spacing:-.03em;line-height:1;color:#fff}
.stat .lbl{margin-top:14px;font-size:13.5px;color:var(--fg-3);line-height:1.45}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease-soft),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============================================================
   PARTNER MARQUEE
   ============================================================ */
.partners-sec{padding-top:72px;padding-bottom:72px}
.partners-kicker{text-align:center;font-family:var(--font-display);font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-3);margin-bottom:40px}
.marquee{position:relative;overflow:hidden;touch-action:pan-y;-webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent)}
.marquee-track{display:flex;align-items:center;gap:clamp(44px,6vw,88px);width:max-content;will-change:transform}
.plogo{display:flex;align-items:center;justify-content:center;height:46px;opacity:.55;transition:opacity .3s,transform .3s,filter .3s;flex:none;cursor:pointer;filter:grayscale(.2)}
.plogo:hover{opacity:1;transform:translateY(-3px);filter:none}
.plogo img{max-height:100%;max-width:172px;width:auto;object-fit:contain;pointer-events:none;-webkit-user-drag:none;user-select:none}

/* ============================================================
   FOUNDER / ÜBER UNS
   ============================================================ */
.founder{display:grid;grid-template-columns:380px 1fr;gap:clamp(40px,5.5vw,80px);align-items:center}
.founder-photo{position:relative}
.founder-photo::before{content:"";position:absolute;inset:-1px;border-radius:26px;padding:1px;
  background:linear-gradient(160deg,rgba(230,60,88,.6),transparent 50%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.founder-photo::after{content:"";position:absolute;right:-22px;bottom:-22px;width:140px;height:140px;border-radius:50%;
  background:radial-gradient(circle,rgba(230,60,88,.4),transparent 70%);filter:blur(10px);z-index:-1}
.founder-photo img{width:100%;border-radius:25px;border:1px solid var(--hair);box-shadow:var(--sh-pop);display:block}
.founder-text .founder-sign{display:flex;align-items:center;gap:16px;margin-top:28px;padding-top:24px;border-top:1px solid var(--hair)}
.founder-name{font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-.01em}
.founder-role{font-size:14px;color:var(--brand-coral-light);margin-top:3px}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:34px}
.value{display:flex;gap:13px;align-items:flex-start}
.value .v-ico{width:42px;height:42px;border-radius:12px;flex:none;background:linear-gradient(180deg,rgba(230,60,88,.18),rgba(230,60,88,.07));border:1px solid rgba(230,60,88,.28);display:flex;align-items:center;justify-content:center;color:var(--brand-coral-light)}
.value b{display:block;font-family:var(--font-display);font-weight:700;font-size:15px;margin-bottom:3px}
.value span{font-size:13px;color:var(--fg-3);line-height:1.5}

/* ---- Über uns — open on the page background, no enclosing box ---- */
.founder-panel{position:relative;padding:0;background:none;border:none;box-shadow:none;border-radius:0}
.founder-panel::before{content:none}
.founder-panel::after{content:none}
.founder-panel .founder{position:relative;z-index:2}
.founder-panel .founder-photo img{box-shadow:0 34px 70px -26px rgba(0,0,0,.7)}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-panel{position:relative;overflow:hidden;border-radius:32px;
  background:linear-gradient(140deg,#7a2240 0%,#6D1F37 40%,#5a1a2e 100%);
  padding:clamp(40px,5vw,76px);display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5vw,68px);align-items:center;
  box-shadow:var(--sh-pop),inset 0 1px 0 rgba(255,255,255,.12)}
.contact-panel::before{content:"";position:absolute;top:-40%;right:-10%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(230,60,88,.5),transparent 60%);pointer-events:none}
.contact-panel .wm{position:absolute;right:-50px;bottom:-60px;width:340px;opacity:.1;transform:rotate(-6deg)}
.contact-info{position:relative;z-index:2}
.contact-info h2{color:#fff;margin-top:16px}
.contact-info .rows{display:flex;flex-direction:column;gap:6px;margin-top:32px}
.contact-info .rows a,.contact-info .rows span{display:flex;align-items:center;gap:14px;color:#fff;font-size:16px;padding:9px 0;transition:gap .25s}
.contact-info .rows a:hover{gap:18px}
.contact-info .rows svg{width:19px;height:19px;stroke:rgba(255,255,255,.85);flex:none}
.form{position:relative;z-index:2;background:rgba(15,8,11,.42);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.18);border-radius:22px;padding:32px;box-shadow:inset 0 1px 0 rgba(255,255,255,.1)}
.form label{display:block;margin-bottom:15px}
.form label span{display:block;font-size:12px;color:rgba(255,255,255,.72);margin-bottom:7px;letter-spacing:.02em}
.form input,.form textarea{width:100%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.18);color:#fff;
  border-radius:12px;padding:13px 15px;font-family:var(--font-body);font-weight:300;font-size:14.5px;outline:none;transition:border-color .25s,background .25s,box-shadow .25s}
.form textarea{resize:none;overflow-y:auto;min-height:100px;max-height:100px;display:block}
.form input:focus,.form textarea:focus{border-color:rgba(255,255,255,.85);background:rgba(255,255,255,.13);box-shadow:0 0 0 4px rgba(255,255,255,.08)}
.form input::placeholder,.form textarea::placeholder{color:rgba(255,255,255,.5)}
.form .btn{width:100%;justify-content:center;background:#fff;color:var(--brand-burgundy);margin-top:6px;box-shadow:0 10px 30px -10px rgba(0,0,0,.5)}
.form .btn:hover{transform:translateY(-2px);box-shadow:0 16px 40px -10px rgba(0,0,0,.6)}
.form .btn svg{stroke:var(--brand-burgundy)}
.form-done{text-align:center;padding:34px 0}
.form-done .ico-tile{margin:0 auto 18px;background:#fff}
.form-done .ico-tile svg{stroke:var(--brand-coral)}
.form-done h3{font-family:var(--font-display);font-weight:700;font-size:23px;color:#fff;margin-bottom:8px}

/* two-column rows (collapse on narrow) */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row label{margin-bottom:15px}
/* honeypot — visually & semantically hidden, still in DOM for bots */
.form .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}
/* consent checkbox — clean aligned row (no enclosing box).
   Selectors carry .form …label.form-consent specificity to beat the generic .form label rule. */
.form label.form-consent{display:flex;align-items:flex-start;gap:11px;margin:8px 0 16px;cursor:pointer}
.form label.form-consent input{appearance:none;-webkit-appearance:none;width:20px;height:20px;flex:none;margin:0;padding:0;border-radius:6px;
  border:1.5px solid rgba(255,255,255,.4);background:rgba(255,255,255,.06);cursor:pointer;position:relative;transition:background .2s,border-color .2s;box-shadow:none}
.form label.form-consent input:checked{background:var(--grad-brand);border-color:transparent}
.form label.form-consent input:checked::after{content:"";position:absolute;left:6px;top:2px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.form label.form-consent input:focus-visible{box-shadow:0 0 0 4px rgba(255,255,255,.12);border-color:rgba(255,255,255,.7)}
.form label.form-consent span{display:block;font-size:12.5px;line-height:1.5;color:rgba(255,255,255,.74);font-weight:300;margin:0}
.form label.form-consent a{color:#fff;text-decoration:underline;text-underline-offset:2px}
.form label.form-consent a:hover{color:var(--brand-coral-light)}
/* status / error */
.form-status{display:none}
.form-status.error{display:block;margin:0 0 14px;padding:12px 15px;border-radius:12px;font-size:13px;line-height:1.5;
  background:rgba(229,72,77,.14);border:1px solid rgba(229,72,77,.4);color:#ffd9da}
/* button spinner */
.spin{width:16px;height:16px;border-radius:50%;border:2px solid rgba(109,31,55,.3);border-top-color:var(--brand-burgundy);display:inline-block;animation:spin .7s linear infinite;vertical-align:-3px}
@keyframes spin{to{transform:rotate(360deg)}}
@media(max-width:520px){.form-row{grid-template-columns:1fr;gap:0}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{position:relative;background:linear-gradient(180deg,var(--ink-900),#0c0609);border-top:1px solid var(--hair);padding:84px 0 36px;z-index:2}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1.2fr;gap:52px}
.footer-grid img{height:50px;margin-bottom:22px}
.footer-grid p{font-size:14px;line-height:1.7;color:var(--fg-3);max-width:36ch}
.footer-col .ttl{font-family:var(--font-display);font-weight:700;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-2);margin-bottom:18px}
.footer-col .links{display:flex;flex-direction:column;gap:12px}
.footer-col .links a{font-size:14px;color:var(--fg-3);transition:color .25s,transform .25s;width:fit-content}
.footer-col .links a:hover{color:var(--brand-coral-light);transform:translateX(3px)}
.footer-bottom{margin-top:60px;padding-top:26px;border-top:1px solid var(--hair);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.footer-bottom>span{font-size:13px;color:var(--fg-3)}
.footer-legal{display:flex;gap:24px;align-items:center;flex-wrap:wrap}
.footer-legal a{font-size:13px;color:var(--fg-3);transition:color .25s}
.footer-legal a:hover{color:var(--brand-coral-light)}
.footer-legal .slogan{font-family:var(--font-display);font-weight:700;font-style:italic;color:var(--brand-coral)}

/* ============================================================
   LEGAL PAGES
   ============================================================ */
.legal{padding-top:176px;padding-bottom:96px;min-height:70vh;position:relative;overflow:hidden;z-index:2}
.legal .glow{width:560px;height:560px;background:radial-gradient(circle,rgba(109,31,55,.42),transparent 66%);top:-180px;right:-160px}
.legal-inner{max-width:820px;margin:0 auto;position:relative;z-index:2}
.legal-inner h1{font-family:var(--font-display);font-weight:700;letter-spacing:-.025em;font-size:clamp(36px,5vw,60px);margin-bottom:14px}
.legal-inner .updated{color:var(--fg-3);font-size:14px;margin-bottom:44px}
.legal-block{margin-bottom:36px}
.legal-block h2{font-family:var(--font-display);font-weight:700;font-size:21px;letter-spacing:-.01em;margin-bottom:12px;color:var(--fg-1)}
.legal-block h3{font-family:var(--font-display);font-weight:700;font-size:16px;margin:18px 0 8px;color:var(--brand-coral-light)}
.legal-block p,.legal-block li{font-size:15px;line-height:1.7;color:var(--fg-2)}
.legal-block p{margin-bottom:12px}
.legal-block ul{margin:0 0 12px;padding-left:20px}
.legal-block li{margin-bottom:6px}
.legal-block a{color:var(--brand-coral-light)}
.legal-block strong{color:var(--fg-1);font-weight:600}
.legal-ph{color:var(--brand-coral-light);background:rgba(230,60,88,.1);border:1px dashed rgba(230,60,88,.4);border-radius:6px;padding:1px 8px;font-size:13.5px;font-style:normal}
.legal-card{background:var(--card-solid);border:1px solid var(--hair);border-radius:18px;padding:28px 32px;margin-bottom:36px}
/* IT-Recht-Kanzlei dynamic legal text — dark-glass "document" panel matching the brand.
   The injected text inherits colour, so we force a light-on-dark scheme (with !important
   to beat any inline colours the external snippet may bring). */
.itrk-paper{position:relative;max-width:940px;margin:0 auto;border-radius:24px;padding:clamp(26px,4vw,56px);
  background:
    radial-gradient(130% 120% at 12% 0%, rgba(230,60,88,.10), transparent 50%),
    linear-gradient(165deg, rgba(44,23,36,.92) 0%, rgba(29,15,23,.94) 60%, rgba(22,11,17,.96) 100%);
  border:1px solid var(--hair-2,rgba(255,255,255,.1));
  box-shadow:0 34px 90px -34px rgba(0,0,0,.75), inset 0 1px 0 rgba(255,255,255,.06);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow:hidden}
.itrk-paper::before{content:"";position:absolute;top:0;left:7%;right:7%;height:1.5px;background:var(--grad-coral,linear-gradient(90deg,#6D1F37,#E63C58,#EC6D82));opacity:.7;border-radius:2px}
.itrk-paper,.itrk-paper *{color:rgba(236,225,230,.9)!important}
.itrk-paper p,.itrk-paper li,.itrk-paper td,.itrk-paper dd,.itrk-paper dt,.itrk-paper span{line-height:1.7;font-size:15px}
.itrk-paper :is(h1,h2,h3,h4,h5){color:#fff!important;font-family:var(--font-display);font-weight:700;line-height:1.28;letter-spacing:-.01em}
.itrk-paper h1{font-size:clamp(25px,3.6vw,36px);margin:0 0 18px}
.itrk-paper h2{font-size:21px;margin:30px 0 10px}
.itrk-paper h3{font-size:17px;margin:22px 0 8px}
.itrk-paper a{color:var(--brand-coral-light,#EC6D82)!important;text-decoration:underline;text-underline-offset:2px}
.itrk-paper strong,.itrk-paper b{color:#fff!important;font-weight:600}
.itrk-paper ul,.itrk-paper ol{padding-left:22px;margin:0 0 14px}
.itrk-paper li{margin-bottom:7px}
.itrk-paper hr{border:none;border-top:1px solid rgba(255,255,255,.14);margin:24px 0}
.itrk-paper table{width:100%;border-collapse:collapse}
.itrk-paper th,.itrk-paper td{border:1px solid rgba(255,255,255,.16);padding:8px 10px;text-align:left}
.itrk-paper th{background:rgba(255,255,255,.04)}
.itrk-paper img{max-width:100%;height:auto}
.itrk-loading{color:rgba(255,255,255,.55)!important;font-size:14px;text-align:center;padding:30px 0}
.itrk-fallback{margin-top:22px;color:var(--fg-3);font-size:13.5px}
.itrk-fallback a{color:var(--brand-coral-light)}
.legal-toc{margin:0;padding-left:22px;columns:2;column-gap:38px}
.legal-toc li{font-size:14.5px;line-height:1.5;color:var(--fg-2);margin-bottom:9px;break-inside:avoid}
.legal-toc a{color:var(--fg-2);transition:color .2s}
.legal-toc a:hover{color:var(--brand-coral-light)}
@media(max-width:620px){.legal-toc{columns:1}}
.legal-block{scroll-margin-top:120px}
.legal-back{display:inline-flex;align-items:center;gap:8px;color:var(--fg-3);font-size:14px;margin-bottom:30px;transition:color .25s,gap .25s}
.legal-back:hover{color:var(--brand-coral-light);gap:12px}

/* ============================================================
   mobile drawer
   ============================================================ */
.drawer-bg{position:fixed;inset:0;background:rgba(10,5,8,.62);backdrop-filter:blur(8px);z-index:250;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.drawer-bg.open{opacity:1;visibility:visible}
.drawer{position:absolute;top:0;right:0;bottom:0;width:min(86vw,360px);background:linear-gradient(180deg,#20121a,#150b11);border-left:1px solid var(--hair);padding:28px;transform:translateX(100%);transition:transform .35s var(--ease);display:flex;flex-direction:column;gap:6px}
.drawer-bg.open .drawer{transform:none}
.drawer .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}
.drawer .top img{height:32px}
.drawer a.dl{padding:15px 0;font-family:var(--font-display);font-weight:700;font-size:19px;border-bottom:1px solid var(--hair);transition:color .2s,padding-left .2s}
.drawer a.dl:hover{color:var(--brand-coral-light);padding-left:6px}
.drawer .btn{margin-top:20px;justify-content:center}
.icon-btn{background:transparent;border:none;color:var(--fg-1);cursor:pointer}

/* ============================================================
   responsive
   ============================================================ */
@media(max-width:1100px){
  .svc-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:980px){
  .hero{padding-top:170px}
  .hero-grid{grid-template-columns:1fr}
  .hero-visual{display:none}
  .stats{grid-template-columns:repeat(2,1fr)}
  .founder{grid-template-columns:1fr;text-align:center}
  .founder-photo{max-width:320px;margin:0 auto}
  .founder-sign,.value{text-align:left}
  .values{grid-template-columns:1fr;max-width:380px;margin-left:auto;margin-right:auto}
  .contact-panel{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:820px){
  .nav-links{display:none}
  .nav-burger{display:flex}
  .nav-cta-desktop{display:none}
  .nav-inner,.nav.scrolled .nav-inner{height:84px}
  .nav-logo img,.nav.scrolled .nav-logo img{height:46px}
}
@media(max-width:680px){
  .wrap{padding:0 22px}
  .svc-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}
