*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg: #f7f8fc;
  --white: #fff;
  --w:#ffffff;
  --cream:#fdfcf8;
  --ink:#0c0b14;
  --ink2:#3a3952;
  --dim:#9997b8;
  --blue:#1844f5;
  --blue2:#4d72ff;
  --sky:#e8eeff;
  --yellow:#ffda00;
  --yellow2:#fff4a0;
  --coral:#ff4d6d;
  --mint:#00d9a3;
  --mint2:#ccf7ee;
  --border:#eae7f0;
  --fh:'Cabinet Grotesk',sans-serif;
  --fs:'Instrument Serif',serif;
  --fb:'DM Sans',sans-serif;
  --r:22px;
  --purple: #7c3aed;
  --purple-lt: #ede9fe;
  --teal: #0ea882;
  --teal-lt: #e0f5f1;
  --orange: #ff7a2f;
  --orange-lt: #fff1e8;

  
    --bg3:          #f4fef4;
    --bg4:          #1a1a1a;

    --off:          #e8e8e8;
    --muted:        #666666;
    --muted2:       #888888;
    --border:       rgba(0,0,0,0.07);
    --border-h:     rgba(0,0,0,0.13);
    --blue-glow:    rgba(59,130,246,0.20);
    --blue-dim:     rgba(59,130,246,0.08);
    --blue-mid:     rgba(59,130,246,0.14);
    --purple:       #8b5cf6;
    --purple-dim:   rgba(139,92,246,0.10);

    --grad:         linear-gradient(135deg, var(--blue), var(--purple));
    
}


html{scroll-behavior:smooth}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:var(--fb);
  overflow-x:hidden;
}

.phone-stack{position:relative;display:flex;justify-content:center;align-items:flex-start;padding-top:12px;gap:0}
.phone{width:180px;height:360px;border-radius:32px;border:3px solid rgba(255,255,255,.9);box-shadow:0 32px 80px rgba(0,0,0,.18),0 8px 24px rgba(0,0,0,.1);position:relative;overflow:hidden;flex-shrink:0}
.phone-1{background:linear-gradient(160deg,#0c0b14 0%,#1a1830 100%);transform:rotate(-6deg) translateX(20px);z-index:1;margin-top:30px}
.phone-2{background:linear-gradient(160deg,#1844f5 0%,#4d72ff 100%);z-index:3;transform:translateY(-10px)}
.phone-3{background:linear-gradient(160deg,#0c0b14 0%,#1a1830 100%);transform:rotate(6deg) translateX(-20px);z-index:1;margin-top:30px}
.phone-screen{position:absolute;inset:10px;border-radius:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;gap:10px}
.phone-1 .phone-screen{background:rgba(255,255,255,.04)}
.phone-2 .phone-screen{background:rgba(255,255,255,.15)}
.phone-3 .phone-screen{background:rgba(255,255,255,.04)}
.phone-dot{width:6px;height:6px;background:rgba(255,255,255,.4);border-radius:50%;position:absolute;top:14px;left:50%;transform:translateX(-50%)}
.phone-icon{font-size:36px;line-height:1}
.phone-bar{width:100%;height:8px;border-radius:4px;background:rgba(255,255,255,.15);margin-top:4px}
.phone-bar.short{width:65%}
.phone-bar.shorter{width:80%}
.phone-label{font-family:var(--fh);font-size:10px;font-weight:800;color:rgba(255,255,255,.5);letter-spacing:.1em;text-transform:uppercase;margin-top:8px}
.phone-stat{font-family:var(--fh);font-size:22px;font-weight:900;color:#fff;line-height:1}
.phone-sublabel{font-family:var(--fh);font-size:9px;font-weight:700;color:rgba(255,255,255,.5);letter-spacing:.1em;text-transform:uppercase}


.techapproach{position:relative;z-index:1;padding:100px 0 90px}
.ta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ta-card{background: #fff; border-radius:var(--r);overflow:hidden;border:2px solid var(--border);position:relative;transition:transform .3s cubic-bezier(.34,1.2,.64,1),box-shadow .3s}
.ta-card:hover{transform:translateY(-10px);box-shadow:0 32px 72px rgba(0,0,0,.12)}
.ta-head{padding:40px 36px 32px;position:relative}
.ta-head::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity .3s}
.ta-card:hover .ta-head::before{opacity:1}
.ta-card.flutter .ta-head{background:linear-gradient(140deg,#054a80 0%,#0468b0 100%)}
.ta-card.native .ta-head{background:linear-gradient(140deg,#1a1a2e 0%,#16213e 100%)}
.ta-card.pwa .ta-head{background:linear-gradient(140deg,#064e3b 0%,#065f46 100%)}
.ta-badge{display:inline-flex;align-items:center;gap:7px;font-family:var(--fh);font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:5px 12px;border-radius:100px;margin-bottom:18px}
.flutter .ta-badge{background:rgba(0,180,255,.2);color:#7dd3fc;border:1px solid rgba(0,180,255,.2)}
.native .ta-badge{background:rgba(255,255,255,.1);color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.15)}
.pwa .ta-badge{background:rgba(52,211,153,.2);color:#6ee7b7;border:1px solid rgba(52,211,153,.2)}
.ta-head h3{font-family:var(--fh);font-size:26px;font-weight:900;letter-spacing:-.03em;color:#fff;margin-bottom:8px}
.ta-head p{font-size:14px;color:rgba(255,255,255,.6);line-height:1.7}
.ta-body{background:rgba(255,255,255,.9);backdrop-filter:blur(10px);padding:28px 32px}
.ta-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.ta-list li{font-size:13px;font-weight:500;color:var(--ink2);display:flex;align-items:center;gap:9px;line-height:1.5}
.ta-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.flutter .ta-dot{background:#0ea5e9}
.native .ta-dot{background:var(--blue)}
.pwa .ta-dot{background:var(--mint)}
.ta-link{font-family:var(--fh);font-size:13px;font-weight:800;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:gap .2s}
.ta-link:hover{gap:11px}.ta-link::after{content:'→'}
.flutter .ta-link{color:#0ea5e9}
.native .ta-link{color:var(--blue)}
.pwa .ta-link{color:var(--mint)}
.ta-best{font-family:var(--fh);font-size:11px;font-weight:700;color:var(--dim);margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}


.prozess-dark{position:relative;z-index:1;padding:0 5% 100px}
.prozess-inner{background:var(--ink);border-radius:32px;padding:72px 64px;position:relative;overflow:hidden}
.prozess-inner::before{content:'';position:absolute;top:-80px;left:-80px;width:300px;height:300px;background:radial-gradient(circle,var(--teal) 0%,transparent 70%);opacity:.2;pointer-events:none}
.prozess-inner::after{content:'';position:absolute;bottom:-60px;right:-60px;width:220px;height:220px;background:radial-gradient(circle,var(--blue) 0%,transparent 70%);opacity:.28;pointer-events:none}
.prozess-header{margin-bottom:52px;position:relative;z-index:1}
.prozess-header .section-kicker{color:var(--yellow)}
.prozess-header .kicker-line{background:var(--yellow)}
.prozess-header h2{font-family:var(--fh);font-size:clamp(30px,4vw,52px);font-weight:900;letter-spacing:-.04em;line-height:1.05;color:#fff;margin-bottom:16px}
.prozess-header h2 i{font-family:var(--fs);font-style:italic;font-weight:400;color:var(--yellow)}
.prozess-header p{font-size:16px;color:rgba(255,255,255,.55);max-width:560px;line-height:1.8}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:rgba(255,255,255,.06);border-radius:18px;overflow:hidden;position:relative;z-index:1}
.step{background:rgba(255,255,255,.04);padding:32px 28px;transition:background .2s}
.step:hover{background:rgba(255,255,255,.08)}
.step-num{font-family:var(--fh);font-size:11px;font-weight:900;color:var(--yellow);letter-spacing:.1em;margin-bottom:14px}
.step h3{font-family:var(--fh);font-size:17px;font-weight:900;color:#fff;margin-bottom:10px;letter-spacing:-.02em}
.step p{font-size:13px;color:rgba(255,255,255,.55);line-height:1.65}
.step-tag{display:inline-block;margin-top:12px;font-family:var(--fh);font-size:11px;font-weight:700;color:var(--yellow);letter-spacing:.06em;background:rgba(255,218,0,.1);padding:4px 10px;border-radius:6px}


.deep{position:relative;z-index:1;padding:0 0 100px}
.deep-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.deep-text h2{font-family:var(--fh);font-size:clamp(28px,3.5vw,44px);font-weight:900;letter-spacing:-.04em;line-height:1.1;margin-bottom:20px}
.deep-text h2 i{font-family:var(--fs);font-style:italic;font-weight:400;color:var(--blue)}
.deep-text p{font-size:15px;color:var(--ink2);line-height:1.85;margin-bottom:16px}
.deep-text p:last-of-type{margin-bottom:28px}
.deep-card{border-radius:var(--r);padding:40px 36px;position:relative;overflow:hidden}
.deep-card.dark{background:var(--ink)}
.deep-card.dark::before{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;background:radial-gradient(circle,var(--purple) 0%,transparent 70%);opacity:.3}
.deep-card.yellow{background:var(--yellow)}
.deep-card.yellow::before{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;background:radial-gradient(circle,var(--coral) 0%,transparent 70%);opacity:.18}
.deep-card.mint{background:var(--mint2);border:2px solid rgba(0,217,163,.2)}
.deep-card.mint::before{content:'';position:absolute;top:-60px;right:-60px;width:180px;height:180px;background:radial-gradient(circle,var(--mint) 0%,transparent 70%);opacity:.3}
.dc-label{font-family:var(--fh);font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;margin-bottom:14px;position:relative;z-index:1}
.dark .dc-label{color:rgba(255,255,255,.4)}.yellow .dc-label,.mint .dc-label{color:var(--ink2)}
.dc-title{font-family:var(--fh);font-size:21px;font-weight:900;letter-spacing:-.03em;margin-bottom:16px;position:relative;z-index:1}
.dark .dc-title{color:#fff}.yellow .dc-title,.mint .dc-title{color:var(--ink)}
.dc-list{list-style:none;display:flex;flex-direction:column;gap:11px;position:relative;z-index:1}
.dc-list li{font-size:13px;font-weight:500;display:flex;align-items:center;gap:10px;line-height:1.55}
.dark .dc-list li{color:rgba(255,255,255,.75)}.yellow .dc-list li,.mint .dc-list li{color:var(--ink2)}
.dc-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.dark .dc-dot{background:var(--yellow)}.yellow .dc-dot{background:var(--ink)}.mint .dc-dot{background:var(--mint)}


.stat-strip{display:flex;flex-direction:column;gap:12px}
.stat-card{background:rgba(255,255,255,.9);backdrop-filter:blur(10px);border-radius:16px;padding:20px 22px;border:2px solid var(--border);display:flex;align-items:center;gap:18px;transition:border-color .25s,transform .25s,box-shadow .25s}
.stat-card:hover{border-color:var(--blue);transform:translateX(6px);box-shadow:0 8px 28px rgba(24,68,245,.1)}
.stat-emoji{font-size:28px;flex-shrink:0;line-height:1}
.stat-card h3{font-family:var(--fh);font-size:15px;font-weight:900;letter-spacing:-.02em;margin-bottom:3px}
.stat-card p{font-size:12px;color:var(--ink2);line-height:1.5}
.stat-badge{margin-left:auto;font-family:var(--fh);font-size:11px;font-weight:800;padding:4px 10px;border-radius:100px;flex-shrink:0;white-space:nowrap}
.badge-green{background:var(--mint2);color:#007a5a}
.badge-blue{background:var(--sky);color:var(--blue)}
.badge-yellow{background:var(--yellow2);color:#8a6800}
.badge-purple{background:var(--purple2);color:var(--purple)}

.workflow{position:relative;z-index:1;padding:0 5% 100px}
.workflow-inner{background:var(--ink);border-radius:32px;padding:72px 64px;position:relative;overflow:hidden}
.workflow-inner::before{content:'';position:absolute;top:-80px;left:-80px;width:300px;height:300px;background:radial-gradient(circle,var(--purple) 0%,transparent 70%);opacity:.25;pointer-events:none}
.workflow-inner::after{content:'';position:absolute;bottom:-60px;right:-60px;width:220px;height:220px;background:radial-gradient(circle,var(--blue) 0%,transparent 70%);opacity:.3;pointer-events:none}
.workflow-header{margin-bottom:52px;position:relative;z-index:1}
.workflow-header .section-kicker{color:var(--yellow)}
.workflow-header .kicker-line{background:var(--yellow)}
.workflow-header h2{font-family:var(--fh);font-size:clamp(30px,4vw,52px);font-weight:900;letter-spacing:-.04em;line-height:1.05;color:#fff;margin-bottom:16px}
.workflow-header h2 i{font-family:var(--fs);font-style:italic;font-weight:400;color:var(--yellow)}
.workflow-header p{font-size:16px;color:rgba(255,255,255,.6);max-width:560px;line-height:1.8}
.wf-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;position:relative;z-index:1}
.wf-step{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:28px 28px;display:flex;gap:20px;align-items:flex-start;transition:background .2s,border-color .2s}
.wf-step:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2)}
.wf-num{font-family:var(--fh);font-size:12px;font-weight:900;color:var(--yellow);letter-spacing:.08em;flex-shrink:0;margin-top:3px;min-width:28px}
.wf-step h3{font-family:var(--fh);font-size:16px;font-weight:900;color:#fff;margin-bottom:7px;letter-spacing:-.02em}
.wf-step p{font-size:13px;color:rgba(255,255,255,.6);line-height:1.65}
.wf-example{margin-top:10px;font-size:12px;font-weight:600;font-family:var(--fh);color:var(--yellow);letter-spacing:.04em}


.praesenz{position:relative;z-index:1;padding:0 5% 100px}
.praesenz-inner{background:var(--ink);border-radius:32px;padding:72px 64px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;position:relative;overflow:hidden}
.praesenz-inner::before{content:'';position:absolute;top:-80px;left:-80px;width:300px;height:300px;background:radial-gradient(circle,var(--blue) 0%,transparent 70%);opacity:.3;pointer-events:none}
.praesenz-inner::after{content:'';position:absolute;bottom:-60px;right:-60px;width:220px;height:220px;background:radial-gradient(circle,var(--coral) 0%,transparent 70%);opacity:.18;pointer-events:none}
.praesenz-left{position:relative;z-index:1}
.praesenz-left .section-kicker{color:var(--yellow)}
.praesenz-left .kicker-line{background:var(--yellow)}
.praesenz-left h2{font-family:var(--fh);font-size:clamp(28px,3.5vw,46px);font-weight:900;letter-spacing:-.04em;line-height:1.08;color:#fff;margin-bottom:24px}
.praesenz-left h2 i{font-family:var(--fs);font-style:italic;font-weight:400;color:var(--yellow)}
.praesenz-left p{font-size:15px;color:rgba(255,255,255,.7);line-height:1.85;margin-bottom:16px}
.praesenz-left p strong{color:#fff}
.praesenz-left p:last-of-type{margin-bottom:32px}
.praesenz-right{position:relative;z-index:1;display:flex;flex-direction:column;gap:14px}
.pr-item{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:22px 24px;display:flex;gap:16px;align-items:flex-start;transition:background .2s,border-color .2s}
.pr-item:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2)}
.pr-num{font-family:var(--fh);font-size:13px;font-weight:900;color:var(--yellow);flex-shrink:0;margin-top:2px;letter-spacing:.05em}
.pr-item h3{font-family:var(--fh);font-size:15px;font-weight:900;color:#fff;margin-bottom:5px}
.pr-item p{font-size:13px;color:rgba(255,255,255,.6);line-height:1.6}


.faq-section{position:relative;z-index:1;padding:0 5% 100px}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.faq-left>p{font-size:16px;color:var(--ink2);line-height:1.8;max-width:400px}
.faq-list.reveal{display:flex;flex-direction:column}
.faq-item{border-bottom:2px solid var(--border)}
.faq-item:first-child{border-top:2px solid var(--border)}
.faq-q{width:100%;text-align:left;background:none;border:none;padding:22px 0;font-family:var(--fh);font-weight:900;font-size:16px;letter-spacing:-.02em;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;color:var(--ink);transition:color .2s}
.faq-q:hover{color:var(--blue)}
.faq-icon{width:32px;height:32px;border-radius:50%;background:var(--sky);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900;color:var(--blue);flex-shrink:0;transition:transform .3s,background .2s;line-height:1;font-family:var(--fh)}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--blue);color:#fff}
.faq-a{display:none;padding-bottom:22px;font-size:14px;color:var(--ink2);line-height:1.8}
.faq-a a{color:var(--blue);text-decoration:none;font-weight:700}
.faq-item.open .faq-a{display:block}

/*  vergleich */
/* VERGLEICH – 3-way */
.vergleich{position:relative;z-index:1;padding:0 0 100px}
.vergleich-intro{font-size:16px;color:var(--ink2);max-width:620px;line-height:1.8;margin-bottom:52px;margin-top:-36px}
.vergleich-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:48px}
.vg-card{border-radius:var(--r);padding:36px 30px;border:2px solid rgba(234,231,240,.9);background:rgba(255,255,255,.85);backdrop-filter:blur(10px);position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s}
.vg-card:hover{transform:translateY(-6px);box-shadow:0 20px 56px rgba(24,68,245,.1)}
.vg-card.highlight{background:var(--ink);border-color:var(--ink);box-shadow:0 16px 56px rgba(24,68,245,.3)}
.vg-card.highlight:hover{transform:translateY(-8px);box-shadow:0 28px 72px rgba(24,68,245,.42)}
.vg-card.highlight::before{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;background:radial-gradient(circle,var(--blue) 0%,transparent 70%);opacity:.4;pointer-events:none}
.vg-card.highlight::after{content:'';position:absolute;bottom:-40px;left:-40px;width:150px;height:150px;background:radial-gradient(circle,var(--coral) 0%,transparent 70%);opacity:.15;pointer-events:none}
.vg-badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--fh);font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px;padding:5px 12px;border-radius:100px}
.vg-card.highlight .vg-badge{background:var(--yellow);color:var(--ink)}
.vg-card:not(.highlight) .vg-badge{background:var(--border);color:var(--dim)}
.vg-card h3{font-family:var(--fh);font-size:24px;font-weight:900;letter-spacing:-.03em;margin-bottom:8px;position:relative;z-index:1}
.vg-card.highlight h3{color:#fff}
.vg-subtitle{font-size:12px;color:var(--dim);font-family:var(--fh);font-weight:600;margin-bottom:20px;position:relative;z-index:1}
.vg-card.highlight .vg-subtitle{color:rgba(255,255,255,.45)}
.vg-list{list-style:none;display:flex;flex-direction:column;gap:10px;position:relative;z-index:1}
.vg-list li{font-size:13px;display:flex;align-items:flex-start;gap:9px;line-height:1.55}
.vg-card.highlight .vg-list li{color:rgba(255,255,255,.8)}
.vg-card:not(.highlight) .vg-list li{color:var(--ink2)}
.vg-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:900;flex-shrink:0;margin-top:1px;font-family:var(--fh)}
.vg-card.highlight .vg-icon.yes{background:var(--yellow);color:var(--ink)}
.vg-card.highlight .vg-icon.no{background:rgba(255,255,255,.12);color:rgba(255,255,255,.35)}
.vg-card.highlight .vg-icon.mid{background:rgba(255,218,0,.2);color:var(--yellow)}
.vg-card:not(.highlight) .vg-icon.yes{background:var(--mint2);color:#007a5a}
.vg-card:not(.highlight) .vg-icon.no{background:#ffe8ed;color:var(--coral)}
.vg-card:not(.highlight) .vg-icon.mid{background:var(--yellow2);color:#8a6800}


/* ── INTRO SPLIT ── */
.intro-split{position:relative;z-index:1;padding:100px 0 0;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.intro-sec h2,
.intro-left h2{font-family:var(--fh);font-size:clamp(30px,3.8vw,48px);font-weight:900;letter-spacing:-.04em;line-height:1.08;margin-bottom:28px}
.intro-sec h2 i,
.intro-left h2 i{font-family:var(--fs);font-style:italic;font-weight:400;color:var(--blue)}
.intro-left p{font-size:16px;color:var(--ink2);line-height:1.85;margin-bottom:16px}
.intro-left p strong{color:var(--ink);font-weight:700}
.intro-left p:last-of-type{margin-bottom:32px}
.intro-right{display:flex;flex-direction:column;gap:16px;padding-top:8px}
.ir-card{background:rgba(255,255,255,.85);backdrop-filter:blur(10px);border-radius:18px;padding:24px 26px;border:2px solid var(--border);display:flex;gap:16px;align-items:flex-start;transition:border-color .25s,transform .25s,box-shadow .25s}
.ir-card:hover{border-color:var(--blue);transform:translateX(6px);box-shadow:0 8px 32px rgba(24,68,245,.1)}
.ir-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.ic-b{background:var(--sky)}.ic-y{background:var(--yellow2)}.ic-m{background:var(--mint2)}.ic-r{background:#ffe8ed}
.ir-card h3{font-family:var(--fh);font-size:15px;font-weight:900;letter-spacing:-.02em;margin-bottom:4px}
.ir-card p{font-size:13px;color:var(--ink2);line-height:1.6}


 .intro-sec { background: var(--bg2); }
    .intro-grid {
      display: grid; grid-template-columns: 1fr 1fr;
      gap: 5rem; align-items: center; margin-top: 4rem;
    }
    .intro-text p {font-size:16px;color:var(--ink2);line-height:1.85;margin-bottom:16px}
    .intro-text strong{color:var(--ink);font-weight:700}


        /* browser mockup */
    .browser {
      background: var(--bg3); border: 1px solid var(--border-h);
      border-radius: 16px; overflow: hidden;
      box-shadow: 0 32px 80px rgba(0,0,0,0.55);
    }
    .browser-bar {
      background: rgba(0,0,0,0.04); border-bottom: 1px solid var(--border);
      padding: 0.75rem 1rem; display: flex; align-items: center; gap: 0.8rem;
    }
    .br-dots { display: flex; gap: 5px; }
    .br-dot { width: 10px; height: 10px; border-radius: 50%; background: rgba(0,0,0,0.12); }
    .br-dot:nth-child(1) { background: #ff5f57; }
    .br-dot:nth-child(2) { background: #febc2e; }
    .br-dot:nth-child(3) { background: #28c840; }
    .br-url {
      flex: 1; background: rgba(255,255,255,0.05); border-radius: 6px;
      padding: 0.3rem 0.8rem; font-size: 0.72rem; color: var(--muted); font-family: monospace;
    }
    .br-url span { color: var(--blue2); }
    .browser-content { padding: 1.8rem; }

        /* mini website preview inside browser */
    .mini-hero {
      background: var(--grad);
      border-radius: 8px; height: 90px;
      display: flex; align-items: center; justify-content: center;
      margin-bottom: 1rem; position: relative; overflow: hidden;
    }
    .mini-hero::before {
      content: ''; position: absolute; inset: 0;
      background: linear-gradient(135deg, rgba(0,0,0,0.25), transparent);
    }
    .mini-hero-text {
      font-family: 'Outfit', sans-serif; font-weight: 800; font-size: 1rem;
      color: #fff; position: relative; letter-spacing: -0.02em;
    }
    .mini-cards { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0.5rem; margin-bottom: 0.8rem; }
    .mini-card {
      background: rgba(0,0,0,0.04); border-radius: 6px; height: 44px;
      border: 1px solid var(--border);
    }
    .mini-bar { height: 8px; background: rgba(0,0,0,0.06); border-radius: 4px; margin-bottom: 0.4rem; }
    .mini-bar.w60 { width: 60%; }
    .mini-bar.w80 { width: 80%; }
    .mini-bar.w40 { width: 40%; }

 /* score badges */
    .score-row { display: flex; gap: 0.6rem; margin-top: 1rem; flex-wrap: wrap; }
    .score-badge {
      display: flex; align-items: center; gap: 0.4rem;
      background: rgba(255,255,255,0.04); border: 1px solid var(--border);
      border-radius: 8px; padding: 0.45rem 0.7rem;
    }
    .score-num {
      font-family: 'Outfit', sans-serif; font-weight: 800; font-size: 1rem;
      line-height: 1;
    }
    .score-num.green { color: #34d399; }
    .score-num.blue  { color: var(--blue2); }
    .score-lbl { font-size: 0.68rem; color: var(--muted); line-height: 1.2; }


.btn-primary {
    background: var(--blue);
    color: #fff;
    padding: 0.9rem 2rem;
    border-radius: 99px;
    text-decoration: none;
    font-weight: 700;
    font-size: 0.9rem;
    transition: background .2s, transform .2s;
}

.btn-ghost {
    background: transparent;
    color: var(--ink);
    padding: 0.9rem 2rem;
    border-radius: 99px;
    text-decoration: none;
    font-weight: 700;
    font-size: 0.9rem;
    border: 1.5px solid rgba(26, 26, 24, 0.3);
    transition: border-color .2s, transform .2s;
}

  .btn-ghost:hover { border-color: var(--ink); transform: translateY(-2px); }

  @keyframes fadeUp {
    from { opacity: 0; transform: translateY(28px); }
    to   { opacity: 1; transform: translateY(0); }
  }

.hero-cta-row {
    margin-top: 2.5rem;
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    opacity: 0;
    animation: fadeUp 0.7s 0.65s forwards;
}

.hero-badge {
    position: absolute;
    right: 5vw;
    bottom: 6rem;
    background: var(--ink);
    color: var(--cream);
    border-radius: 20px;
    padding: 1.5rem 2rem;
    min-width: 180px;
    opacity: 0;
    animation: fadeUp 0.8s 0.9s forwards;
}

  .hero-badge-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    opacity: 0.5;
    margin-bottom: 0.4rem;
  }
  .hero-badge-rank {
    font-size: 3.2rem;
    font-weight: 900;
    letter-spacing: -0.04em;
    line-height: 1;
    color: var(--yellow);
  }
  .hero-badge-sub {
    font-size: 0.78rem;
    opacity: 0.55;
    margin-top: 0.3rem
  }

/* 2x2 big cards → now 2-col with last 3 spanning into 3-col row */
.big-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
/* last 3 cards form a 3-column row */
.big-card:nth-child(5),
.big-card:nth-child(6) {
  /* stays in 2-col naturally; override below for wide screens */
}
@media (min-width: 1025px) {
  .big-cards {
    grid-template-columns: 1fr 1fr 1fr;
  }
  .big-card:nth-child(1) { grid-column: span 1; }
  .big-card:nth-child(2) { grid-column: span 1; }
  .big-card:nth-child(3) { grid-column: span 1; }
  .big-card:nth-child(4) { grid-column: span 1; }
  .big-card:nth-child(5) { grid-column: span 1; }
  .big-card:nth-child(6) { grid-column: span 1; }
  /* first row: web + app span half each → keep 3-col, rows auto */
}

.big-card {
  background: rgba(255,255,255,0.58);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 2.5rem;
  backdrop-filter: blur(10px);
  position: relative; overflow: hidden;
  text-decoration: none; color: var(--ink);
  display: flex; flex-direction: column;
  transition: transform .25s, box-shadow .25s;
  opacity: 0; transform: translateY(30px);
}
.big-card.visible {
  opacity: 1; transform: translateY(0);
  transition: opacity 0.6s ease, transform 0.6s ease, box-shadow .25s;
}
.big-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 60px rgba(26,26,24,0.12);
}

/* accent stripe top */
.big-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--yellow);
  transform: scaleX(0); transform-origin: left;
  transition: transform .3s ease;
}
.big-card:hover::before { transform: scaleX(1); }

.bc-icon {
  width: 52px; height: 52px; border-radius: 14px;
  background: var(--yellow);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem; margin-bottom: 1.5rem; flex-shrink: 0;
}

.bc-number {
  position: absolute;
  top: 2rem; right: 2rem;
  font-size: 4rem; font-weight: 900;
  letter-spacing: -0.06em; line-height: 1;
  color: rgba(26,26,24,0.05);
}

.big-card h2 {
  font-size: clamp(1.3rem, 2vw, 1.6rem);
  font-weight: 900; letter-spacing: -0.025em;
  margin-bottom: 0.8rem; line-height: 1.15;
}

.big-card p {
  font-size: 0.92rem; line-height: 1.7; color: var(--muted);
  flex: 1;
}

.bc-tags {
  display: flex; flex-wrap: wrap; gap: 0.4rem;
  margin-top: 1.5rem;
}
.bc-tag {
  background: rgba(26,26,24,0.06);
  border-radius: 99px; padding: 0.25rem 0.75rem;
  font-size: 0.72rem; font-weight: 700; letter-spacing: 0.04em;
  text-transform: uppercase;
}

.bc-link {
  display: inline-flex; align-items: center; gap: 0.4rem;
  margin-top: 1.5rem;
  font-size: 0.85rem; font-weight: 700;
  color: var(--blue); text-decoration: none;
  letter-spacing: -0.01em;
}
.bc-link:hover { text-decoration: underline; }

/* highlight card (Shopware) */
.big-card.highlight {
  background: var(--ink); color: var(--cream); border-color: transparent;
}
.big-card.highlight p { color: rgba(245,242,235,0.65); }
.big-card.highlight .bc-tag { background: rgba(245,242,235,0.1); color: rgba(245,242,235,0.8); }
.big-card.highlight .bc-number { color: rgba(245,242,235,0.1); }
.big-card.highlight .bc-link { color: var(--yellow); }
.big-card.highlight::before { background: var(--yellow); }

/* game card */
.big-card.highlight-game {
  background: #1e0a38; color: var(--cream); border-color: transparent;
}
.big-card.highlight-game p { color: rgba(245,242,235,0.65); }
.big-card.highlight-game .bc-tag { background: rgba(124,58,237,0.25); color: #d8b4fe; }
.big-card.highlight-game .bc-number { color: rgba(124,58,237,0.1); }
.big-card.highlight-game::before { background: #7c3aed; }

/* AI card */
.big-card.highlight-ai {
  background: #0a1628; color: var(--cream); border-color: transparent;
}
.big-card.highlight-ai p { color: rgba(245,242,235,0.65); }
.big-card.highlight-ai .bc-tag { background: rgba(245,230,66,0.12); color: rgba(245,230,66,0.9); }
.big-card.highlight-ai .bc-number { color: rgba(245,230,66,0.06); }
.big-card.highlight-ai .bc-link { color: var(--yellow); }
.big-card.highlight-ai::before { background: var(--yellow); }





/* ============================================================ REGION BAND */
.region-band {
  background: var(--yellow);
  padding: 4rem 0;
  position: relative;
}
.region-inner {
  display: flex; align-items: center;
  justify-content: space-between; gap: 3rem; flex-wrap: wrap;
}
.region-text h2 {
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  font-weight: 900; letter-spacing: -0.04em;
  line-height: 1.05;
}
.region-text h2 em {
  font-family: 'Instrument Serif', serif;
  font-style: italic; font-weight: 400;
}
.region-text p {
  font-size: 1rem; line-height: 1.7;
  color: rgba(26,26,24,0.72); margin-top: 0.8rem;
  max-width: 42ch;
}
.region-stats {
  display: flex; gap: 3rem; flex-wrap: wrap;
}
.rstat-num {
  font-size: 2.8rem; font-weight: 900;
  letter-spacing: -0.05em; line-height: 1;
}
.rstat-label {
  font-size: 0.8rem; color: rgba(26,26,24,0.6);
  margin-top: 0.2rem; max-width: 120px; line-height: 1.35;
}

/* ============================================================ PROZESS */
.prozess-section { padding: 7rem 0; position: relative; }
.prozess-header { margin-bottom: 4rem; }

.prozess-section-home .prozess-header p{
  color: var(--muted);
}

.prozess-section-home .kicker-line{
 background: var(--blue);
}

.prozess-section-home p.section-label{
    color: var(--blue);
        font-size: 12px;
}

.prozess-section-home .prozess-header h2{
    color: var(--ink);
}

.prozess-header-inner {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 3rem; align-items: end;
}
.prozess-header-text {
  font-size: 1.05rem; line-height: 1.78; color: var(--muted);
}

.prozess-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0; position: relative;
}
.prozess-grid::before {
  content: '';
  position: absolute; top: 23px;
  left: 8%; right: 8%;
  height: 1px; background: rgba(26,26,24,0.1); z-index: 0;
}
.pstep {
  position: relative; z-index: 1;
  padding: 0 1.5rem;
  opacity: 0; transform: translateY(20px);
}
.pstep.visible {
  opacity: 1; transform: translateY(0);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.pstep-num {
  width: 46px; height: 46px; border-radius: 50%;
  background: var(--ink); color: var(--cream);
  display: flex; align-items: center; justify-content: center;
  font-weight: 900; font-size: 0.9rem;
  margin-bottom: 1.5rem;
}
.pstep h3 { font-size: 1rem; font-weight: 700; margin-bottom: 0.5rem; }
.pstep p  { font-size: 0.875rem; line-height: 1.65; color: var(--muted); }



/* ============================================================ SHARED */
section { position: relative; z-index: 2; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 2.5rem; }

.section-label {
  font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--coral); margin-bottom: 0.7rem;
}
.section-hl {
  font-weight: 900;
  font-size: clamp(2rem, 4vw, 3.5rem);
  letter-spacing: -0.035em; line-height: 1.03;
}
.section-hl em {
  font-family: 'Instrument Serif', serif;
  font-style: italic; font-weight: 400;
}


/* ============================================================ TECH STACK */
.tech-section {
  padding: 6rem 0;
  background: rgba(26,26,24,0.025);
  position: relative;
}
.tech-header { margin-bottom: 3rem; }
.tech-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1rem;
}
.tech-pill {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 0.5rem;
  background: rgba(255,255,255,0.65);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 1.2rem 0.75rem;
  backdrop-filter: blur(6px);
  font-size: 0.78rem; font-weight: 700;
  text-align: center; letter-spacing: 0.01em;
  opacity: 0; transform: scale(0.94);
}
.tech-pill.visible {
  opacity: 1; transform: scale(1);
  transition: opacity 0.4s ease, transform 0.4s ease;
}
.tech-pill-icon { font-size: 1.5rem; }


.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 2.5rem;
}



/* ============================================================ ABOUT / SEO TEXT */
.about-section { padding: 7rem 0; position: relative; }
.about-grid {
  display: grid; grid-template-columns: 1fr 2fr;
  gap: 5rem; align-items: start;
}
.about-sticky {
  position: sticky; top: 8rem;
}
.about-sticky h2 {
  font-size: clamp(1.6rem, 2.8vw, 2.5rem);
  font-weight: 900; letter-spacing: -0.03em; line-height: 1.1;
}
.about-sticky h2 em {
  font-family: 'Instrument Serif', serif;
  font-style: italic; font-weight: 400;
}
.about-body section {
  margin-bottom: 3rem; padding-bottom: 3rem;
  border-bottom: 1px solid var(--border);
}
.about-body section:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.about-body h3 {
  font-size: 1.25rem; font-weight: 700;
  margin-bottom: 0.75rem; letter-spacing: -0.02em;
}
.about-body p {
  font-size: 1rem; line-height: 1.82;
  color: rgba(26,26,24,0.76); margin-bottom: 1em;
}
.about-body p:last-child { margin-bottom: 0; }
.hl { background: var(--yellow); padding: 0 0.2em; border-radius: 3px; font-weight: 600; }









/* ─── CANVAS BG ─── */
#bg-canvas{
  position:fixed;
  top:0;left:0;
  width:100%;height:100%;
  z-index:0;
  pointer-events:none;
}

/* ─── NAV ─── */
nav{
  position:sticky;top:0;z-index:200;
  background:rgba(253,252,248,0.82);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border-bottom:2px solid rgba(234,231,240,0.8);
  padding:0 5%;
  display:flex;align-items:center;justify-content:space-between;
  height:70px;
}
.nav-logo{
  font-family:var(--fh);
  font-size:22px;font-weight:900;
  color:var(--ink);text-decoration:none;
  letter-spacing:-.04em;
  display:flex;align-items:center;gap:5px;
}
.logo-box{
  background:var(--blue);color:#fff;
  padding:3px 9px;border-radius:8px;
  font-size:20px;line-height:1.2;
}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{
  font-family:var(--fh);font-size:15px;font-weight:700;
  color:var(--ink2);text-decoration:none;
  transition:color .2s;position:relative;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-3px;left:0;right:0;
  height:2px;background:var(--blue);border-radius:2px;
  transform:scaleX(0);transform-origin:left;transition:transform .25s;
}
.nav-links a:hover{color:var(--blue)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{
  background:var(--ink);color:#fff;
  font-family:var(--fh);font-size:14px;font-weight:800;
  padding:11px 26px;border-radius:100px;
  text-decoration:none;
  display:flex;align-items:center;gap:8px;
  box-shadow:0 4px 20px rgba(15,14,23,.22);
  transition:transform .2s,background .2s,box-shadow .2s;
}
.nav-cta::after{content:'→'}
.nav-cta:hover{
  background:var(--blue);transform:translateY(-2px);
  box-shadow:0 8px 28px rgba(24,68,245,.38);
}

/* ─── HERO ─── */
.hero{
  position:relative;z-index:1;
  padding:88px 5% 0;
  min-height:95vh;
  display:flex;flex-direction:column;justify-content:center;
}
.hero-pill{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--yellow);color:var(--ink);
  font-family:var(--fh);font-size:13px;font-weight:800;
  padding:7px 16px;border-radius:100px;
  margin-bottom:34px;width:fit-content;
  opacity:0;animation:popIn .6s .15s cubic-bezier(.34,1.56,.64,1) forwards;
  box-shadow:0 4px 20px rgba(255,218,0,.4);
}
.pill-dot{
  width:8px;height:8px;background:var(--coral);
  border-radius:50%;animation:pulse 2s infinite;
}

.hero-h1{
  font-family:var(--fh);
  font-size:clamp(52px,8vw,120px);
  font-weight:900;
  line-height:.93;
  letter-spacing:-.045em;
  opacity:0;animation:fadeUp .9s .25s forwards;
}
.hero-h1 .row2{
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  margin-top:6px;
}
.h1-serif{
  font-family:var(--fs);
  font-style:italic;font-weight:400;
  color:var(--blue);
  font-size:clamp(54px,8.4vw,124px);
}
.h1-tag{
  display:inline-flex;align-items:center;
  background:var(--yellow);color:var(--ink);
  padding:4px 22px 6px;border-radius:14px;
  transform:rotate(-2deg);
  font-family:var(--fh);font-style:normal;font-weight:900;
  font-size:clamp(36px,5.2vw,80px);
  box-shadow:4px 4px 0 rgba(15,14,23,.15);
  flex-shrink:0;
}

.hero-bottom{
  display:flex;align-items:flex-end;justify-content:space-between;
  padding:52px 0 80px;gap:40px;flex-wrap:wrap;
  opacity:0;animation:fadeUp .85s .45s forwards;
}
.hero-desc{
  font-size:17px;color:var(--ink2);
  line-height:1.72;max-width:420px;
}
.hero-actions{
  display:flex;align-items:center;gap:14px;
  flex-wrap:wrap;flex-shrink:0;
}
.btn-hero{
  background:var(--blue);color:#fff;
  font-family:var(--fh);font-size:16px;font-weight:800;
  padding:16px 34px;border-radius:100px;
  text-decoration:none;
  display:inline-flex;align-items:center;gap:10px;
  box-shadow:0 8px 32px rgba(24,68,245,.4);
  transition:transform .2s,box-shadow .2s;
}
.btn-hero::after{content:'→';font-size:18px}
.btn-hero:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 18px 48px rgba(24,68,245,.48)}
.btn-ghost{
  font-family:var(--fh);font-size:15px;font-weight:700;
  color:var(--ink2);text-decoration:none;
  padding:16px 26px;
  border:2px solid rgba(58,57,82,.2);border-radius:100px;
  transition:border-color .2s,color .2s;
}
.btn-ghost:hover{border-color:var(--ink);color:var(--ink)}

.scroll-hint{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:7px;
  font-family:var(--fh);font-size:10px;font-weight:800;
  color:var(--dim);letter-spacing:.12em;text-transform:uppercase;
  opacity:0;animation:fadeIn 1s 1.4s forwards;
}
.scroll-mouse{
  width:22px;height:34px;
  border:2px solid var(--dim);border-radius:12px;
  display:flex;justify-content:center;padding-top:6px;
}
.scroll-wheel{
  width:4px;height:8px;background:var(--blue);
  border-radius:2px;
  animation:wheelScroll 1.6s ease-in-out infinite;
}
@keyframes wheelScroll{0%{transform:translateY(0);opacity:1}100%{transform:translateY(10px);opacity:0}}

/* ─── MARQUEE ─── */
.marquee-section{
  position:relative;z-index:1;
  margin-top:60px;
  overflow: hidden;
}
.marquee-band{
  background:var(--ink);
  padding:18px 0;
  overflow:hidden;
  transform:rotate(-1.3deg) scaleX(1.06);
}
.marquee-inner{
  display:flex;
  animation:ticker 22s linear infinite;
  white-space:nowrap;
}
.m-item{
  font-family:var(--fh);font-size:14px;font-weight:800;
  color:#fff;padding:0 20px;
  display:flex;align-items:center;gap:12px;
  text-transform:uppercase;letter-spacing:.03em;
}
.m-star{color:var(--yellow);font-size:15px}

/* ─── NUMBERS ─── */
.numbers{
  position:relative;z-index:1;
  margin:80px 5% 0;
  background:var(--yellow);
  border-radius:28px;
  padding:52px 60px;
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;overflow:hidden;
}
.numbers::after{
  content:'';position:absolute;
  top:-70px;right:-70px;
  width:260px;height:260px;
  background:var(--coral);border-radius:50%;opacity:.18;
}
.n-item{
  text-align:center;
  padding:0 16px;
  border-right:2px solid rgba(15,14,23,.1);
  position:relative;z-index:1;
}
.n-item:last-child{border-right:none}
.n-num{
  font-family:var(--fh);
  font-size:clamp(42px,5vw,70px);
  font-weight:900;letter-spacing:-.04em;
  color:var(--ink);line-height:1;
}
.n-label{
  font-family:var(--fh);font-size:14px;font-weight:700;
  color:var(--ink2);margin-top:6px;
}

/* ─── SERVICES ─── */
.services{
  position:relative;z-index:1;
  padding:110px 5% 90px;
}
.section-kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--fh);font-size:12px;font-weight:800;
  color:var(--blue);letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:16px;
}
.kicker-line{width:26px;height:3px;background:var(--blue);border-radius:2px}
.section-h2{
  font-family:var(--fh);
  font-size:clamp(34px,4.5vw,50px);
  font-weight:900;letter-spacing:-.04em;
  line-height:1.05;margin-bottom:60px;
}
.section-h2 i{
  font-family:var(--fs);font-style:italic;font-weight:400;color:var(--blue);
}

.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

.sc{
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(12px);
  border-radius:var(--r);
  padding:40px 34px 36px;
  border:2px solid rgba(234,231,240,.9);
  position:relative;overflow:hidden;
  transition:transform .3s cubic-bezier(.34,1.2,.64,1),box-shadow .3s;
  cursor:default;
}
.sc::before{
  content:'';
  position:absolute;inset:0;border-radius:var(--r);
  background:linear-gradient(135deg,rgba(255,255,255,.6),rgba(255,255,255,0));
  pointer-events:none;
}
.sc:hover{transform:translateY(-10px) rotate(.4deg);box-shadow:0 28px 72px rgba(24,68,245,.14)}

.sc-accent{
  position:absolute;top:-50px;right:-50px;
  width:160px;height:160px;border-radius:50%;
  opacity:0;filter:blur(35px);
  transition:opacity .4s;
}
.sc:hover .sc-accent{opacity:.9}
.c-b .sc-accent{background:var(--blue)}
.c-y .sc-accent{background:var(--yellow)}
.c-m .sc-accent{background:var(--mint)}

.sc.featured{
  background:var(--blue);
  border-color:var(--blue);
  box-shadow:0 16px 56px rgba(24,68,245,.35);
}
.sc.featured::before{
  background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(255,255,255,0));
}
.sc.featured:hover{transform:translateY(-10px) rotate(-.4deg);box-shadow:0 32px 80px rgba(24,68,245,.5)}
.sc.featured h2,
.sc.featured p,
.sc.featured .sc-list li,
.sc.featured .sc-num{color:#fff}
.sc.featured .sc-list li .dot{background:rgba(255,255,255,.45)}
.sc.featured .sc-link{color:var(--yellow)}
.sc.featured .sc-icon-wrap{background:rgba(255,255,255,.15)}

.sc-num{
  font-family:var(--fh);font-size:11px;font-weight:800;
  letter-spacing:.15em;color:var(--dim);
  text-transform:uppercase;margin-bottom:18px;
}
.sc-icon-wrap{
  width:58px;height:58px;border-radius:17px;
  display:flex;align-items:center;justify-content:center;
  font-size:27px;margin-bottom:26px;
}
.ic-b{background:var(--sky)}
.ic-y{background:var(--yellow2)}
.ic-m{background:var(--mint2)}

.sc h2{font-family:var(--fh);font-size:25px;font-weight:900;letter-spacing:-.03em;margin-bottom:12px}
.sc p{font-size:14px;color:var(--ink2);line-height:1.75;margin-bottom:24px}
.sc-list{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:0;margin-top:12px}
.sc-list li{
  font-size:13px;font-weight:500;color:var(--ink2);
  display:flex;align-items:center;gap:9px;
}

.big-card.highlight-game .sc-list li,
.big-card.highlight .sc-list li{
color:rgba(245,242,235,0.65);
}

.sc-list li .dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.c-b .dot{background:var(--blue)}
.c-y .dot{background:#c9a800}
.c-m .dot{background:var(--mint)}

.sc-link{
  font-family:var(--fh);font-size:14px;font-weight:800;
  text-decoration:none;
  display:inline-flex;align-items:center;gap:7px;
  transition:gap .2s;
}
.sc-link:hover{gap:13px}
.sc-link::after{content:'→'}
.c-b .sc-link{color:var(--blue)}
.c-y .sc-link{color:#a07e00}
.c-m .sc-link{color:#009e78}

/* ─── WHY ─── */
.why{
  position:relative;z-index:1;
  padding:0 0% 100px;
  display:grid;grid-template-columns:1fr 1fr;
  gap:64px;align-items:start;
}
.why-left > p{
  font-size:16px;color:var(--ink2);
  line-height:1.8;max-width:440px;margin-bottom:36px;
}
.why-grid{display:flex;flex-direction:column;gap:14px}
.wi{
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(10px);
  border-radius:18px;
  padding:26px 28px;
  border:2px solid rgba(234,231,240,.9);
  display:grid;grid-template-columns:50px 1fr;gap:18px;align-items:start;
  transition:transform .3s,border-color .3s,box-shadow .3s;
}
.wi:hover{transform:translateX(8px);border-color:var(--blue);box-shadow:0 8px 32px rgba(24,68,245,.1)}
.wi-num{
  width:44px;height:44px;border-radius:12px;
  background:var(--sky);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fh);font-size:15px;font-weight:900;color:var(--blue);
}
.wi h3{font-family:var(--fh);font-size:16px;font-weight:900;letter-spacing:-.02em;margin-bottom:5px}
.wi p{font-size:13px;color:var(--ink2);line-height:1.65}

/* ─── TECH ─── */
.tech{position:relative;z-index:1;padding:0 5% 100px}
.tech-card{
  background:var(--ink);border-radius:var(--r);
  padding:46px 52px;
  display:flex;flex-wrap:wrap;align-items:center;
  gap:28px;justify-content:space-between;
  position:relative;overflow:hidden;
}
.tech-card::before{
  content:'';position:absolute;
  top:-80px;left:-80px;
  width:280px;height:280px;
  background:radial-gradient(circle,var(--blue) 0%,transparent 70%);
  opacity:.3;
}
.tech-card::after{
  content:'';position:absolute;
  bottom:-60px;right:-60px;
  width:200px;height:200px;
  background:radial-gradient(circle,var(--coral) 0%,transparent 70%);
  opacity:.2;
}
.tech-label{
  font-family:var(--fh);font-size:11px;font-weight:800;
  color:rgba(255,255,255,.4);
  letter-spacing:.12em;text-transform:uppercase;flex-shrink:0;
}
.tech-tags{display:flex;flex-wrap:wrap;gap:9px;position:relative;z-index:1}
.tt{
  font-family:var(--fh);font-size:13px;font-weight:700;
  color:#fff;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.13);
  border-radius:100px;padding:7px 18px;
  transition:background .2s,color .2s,border-color .2s,transform .2s;
}
.tt:hover{background:var(--yellow);color:var(--ink);border-color:var(--yellow);transform:translateY(-2px)}

/* ─── CTA ─── */
.cta-section{position:relative;z-index:1;padding:0 5% 120px}
.cta-inner{
  border-radius:32px;padding:100px 60px;
  text-align:center;position:relative;overflow:hidden;
  border:3px solid var(--ink);
  background:var(--cream);
}
.cta-shape{
  position:absolute;pointer-events:none;
  border-radius:40% 60% 55% 45% / 40% 45% 55% 60%;
}
.cs1{
  width:380px;height:380px;
  background:var(--yellow);
  top:-120px;left:-80px;opacity:.55;
  animation:morph 18s ease-in-out infinite;
}
.cs2{
  width:280px;height:280px;
  background:var(--sky);
  bottom:-70px;right:-50px;opacity:.7;
  animation:morph 22s ease-in-out infinite reverse;
}
.cs3{
  width:200px;height:200px;
  background:var(--mint2);
  top:50%;right:15%;transform:translateY(-50%);opacity:.5;
  animation:morph 15s ease-in-out infinite 3s;
}
@keyframes morph{
  0%,100%{border-radius:40% 60% 55% 45%/40% 45% 55% 60%;transform:rotate(0deg)}
  33%{border-radius:60% 40% 45% 55%/55% 60% 40% 45%;transform:rotate(120deg)}
  66%{border-radius:45% 55% 60% 40%/60% 40% 55% 45%;transform:rotate(240deg)}
}
.cta-inner h2{
  font-family:var(--fh);
  font-size:clamp(36px,5.5vw,76px);
  font-weight:900;letter-spacing:-.04em;
  line-height:1.02;margin-bottom:18px;position:relative;
}
.cta-inner h2 i{
  font-family:var(--fs);font-style:italic;font-weight:400;color:var(--blue);
}
.cta-inner p{
  font-size:16px;color:var(--ink2);
  max-width:460px;margin:0 auto 48px;line-height:1.75;position:relative;
}
.btn-cta{
  background:var(--ink);color:#fff;
  font-family:var(--fh);font-size:17px;font-weight:900;
  padding:20px 46px;border-radius:100px;
  text-decoration:none;
  display:inline-flex;align-items:center;gap:10px;
  box-shadow:0 8px 32px rgba(15,14,23,.22);
  transition:transform .2s,box-shadow .2s,background .2s;
  position:relative;
}
.btn-cta::after{content:'→';font-size:20px}
.btn-cta:hover{
  background:var(--blue);transform:translateY(-5px) scale(1.02);
  box-shadow:0 20px 56px rgba(24,68,245,.42);
}

/* ─── FOOTER ─── */
footer{
  background:var(--ink);padding:44px 5%;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:24px;
  position:relative;
}
.footer-logo{
  font-family:var(--fh);font-size:20px;font-weight:900;
  text-decoration:none;display:flex;align-items:center;gap:6px;
}
.flb{background:var(--yellow);color:var(--ink);padding:2px 8px;border-radius:6px;font-size:18px}
.flt{color:#fff}
.footer-links{display:flex;gap:26px;list-style:none;flex-wrap:wrap}
.footer-links a{
  font-family:var(--fh);font-size:13px;font-weight:700;
  color:rgba(255,255,255,.4);text-decoration:none;transition:color .2s;
}
.footer-links a:hover{color:#fff}
.footer-copy{font-family:var(--fh);font-size:13px;font-weight:700;color:rgba(255,255,255,.25)}

/* ─── ANIMATIONS ─── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(32px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes popIn{
  from{opacity:0;transform:scale(.7) translateY(10px)}
  to{opacity:1;transform:scale(1) translateY(0)}
}
@keyframes ticker{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
@keyframes pulse{
  0%,100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.4);opacity:.5}
}

.reveal{opacity:0;transform:translateY(40px);transition:opacity .75s,transform .75s}
.reveal.visible{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.22s}
.d3{transition-delay:.34s}.d4{transition-delay:.46s}


.problem-section { padding: 7rem 0 5rem; }
  .problem-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: start;
  }
  .problem-text {
    font-size: 1.1rem;
    line-height: 1.78;
    color: rgba(26,26,24,0.78);
  }
  .problem-text p + p { margin-top: 1.2em; }
  .problem-text strong { color: var(--ink); }

  .problem-checklist {
    list-style: none;
    margin-top: 2rem;
  }
  .problem-checklist li {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    font-size: 1rem;
    line-height: 1.6;
    color: rgba(26,26,24,0.75);
    padding: 1rem 0;
    border-bottom: 1px solid rgba(26,26,24,0.08);
  }
  .problem-checklist li:first-child { border-top: 1px solid rgba(26,26,24,0.08); }
  .check-icon {
    width: 22px; height: 22px;
    border-radius: 50%;
    background: var(--yellow);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    font-weight: 900;
    flex-shrink: 0;
    margin-top: 2px;
  }


/* ============================================================ LOKAL BAND */
  .lokal-band {
    background: var(--ink);
    color: var(--cream);
    padding: 5rem 0;
  }
  .lokal-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
    align-items: center;
  }
  .lokal-text h2 {
    font-size: clamp(2rem, 3.5vw, 3rem);
    font-weight: 900;
    letter-spacing: -0.04em;
    line-height: 1.05;
    margin-bottom: 1.5rem;
  }
  .lokal-text h2 em {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
  }
  .lokal-text p {
    font-size: 1rem;
    line-height: 1.78;
    opacity: 0.72;
    margin-bottom: 1em;
  }
  .lokal-text p:last-child { margin-bottom: 0; }

  .lokal-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
  }
  .lokal-stat {
    border: 2px solid rgba(10,13,20,0.1);
    border-radius: 14px;
    padding: 1.5rem;
  }
  .lokal-stat-num {
    font-size: 2.6rem;
    font-weight: 900;
    letter-spacing: -0.04em;
    color: var(--ink);
    line-height: 1;
    margin-bottom: 0.3rem;
  }
  .lokal-stat-label {
    font-size: 0.82rem;
    opacity: 0.55;
    line-height: 1.4;
  }

  /* ─── FAQ ─── */
.faq-section{position:relative;z-index:1;padding:0 0% 100px}
.faq-list{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.faq-card{background:var(--white);border-radius:18px;padding:28px;border:1.5px solid var(--border);box-shadow:var(--shadow);transition:transform .25s,box-shadow .25s}
.faq-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
details{cursor:pointer}
summary{font-family:var(--fh);font-size:15px;font-weight:800;list-style:none;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;color:var(--ink);letter-spacing:-.02em}
summary::-webkit-details-marker{display:none}
.sum-icon{color:var(--blue);font-size:1.3rem;flex-shrink:0;transition:transform .2s;line-height:1.3}
details[open] .sum-icon{transform:rotate(45deg)}
details p{font-size:13.5px;color:var(--ink2);line-height:1.75;margin-top:14px}

.faq-section{
  padding-top: 4rem;
}
.section-title {
    font-family: var(--blue);
    font-size: clamp(32px, 4.2vw, 56px);
    font-weight: 900;
    letter-spacing: -.04em;
    line-height: 1.05;
    margin-bottom: 56px;
}

.section-label {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--fh);
    font-size: 11px;
    font-weight: 800;
    color: var(--blue);
    letter-spacing: .14em;
    text-transform: uppercase;
    margin-bottom: 14px;
}

.sl-dash {
    width: 24px;
    height: 2.5px;
    background: var(--blue);
    border-radius: 2px;
}

.reveal{opacity:0;transform:translateY(36px);transition:opacity .75s,transform .75s}
.reveal.visible{opacity:1;transform:translateY(0)}
.d1{transition-delay:.12s}.d2{transition-delay:.24s}.d3{transition-delay:.36s}


  /* ============================================================ LEISTUNGEN GRID */
  .leistungen-section { padding: 5rem 0 6rem; }
  .leistungen-header { margin-bottom: 3.5rem; }

  .leistungen-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
  }

  #leistungen .big-cards{
    .big-cards {
        grid-template-columns: 1fr 1fr;
    }
  }

  .leistung-card {
    background: rgba(255,255,255,0.55);
    border: 1px solid rgba(26,26,24,0.1);
    border-radius: 16px;
    padding: 2rem;
    backdrop-filter: blur(8px);
    transition: transform .25s, box-shadow .25s;
    opacity: 0;
    transform: translateY(30px);
  }
  .leistung-card.visible {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s ease, transform 0.6s ease, box-shadow .25s;
  }
  .leistung-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 20px 50px rgba(26,26,24,0.1);
  }

  .leistung-card-icon {
    width: 44px; height: 44px;
    border-radius: 12px;
    background: var(--yellow);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    margin-bottom: 1.2rem;
  }
  .leistung-card h3 {
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: 0.6rem;
    letter-spacing: -0.01em;
  }
  .leistung-card p {
    font-size: 0.9rem;
    line-height: 1.65;
    color: rgba(26,26,24,0.68);
  }
  .leistung-card.wide { grid-column: span 2; }


.seo-leistungen .leistungen-grid{
    grid-template-columns: 1fr 1fr 1fr;
}

@media (min-width: 1025px) {
   #leistungen .big-cards {
    grid-template-columns: 1fr 1fr;
  }
}

@media (min-width: 1240px) {
  .container {
      max-width: 1200px;
      padding: 0 ;
  }

}


@media (max-width: 900px) {
    .container {
        padding: 0 1.5rem;
        max-width: 100%;
        overflow: hidden;
    }
    .big-cards {
        grid-template-columns: 1fr !important;
    }
    .nav-links {
        display: none;
    }
}

@media (max-width: 680px) {

  .intro-phone .intro-right{
        margin-bottom: 4rem;
  }

  .phone{
        width: 115px;
      height: 230px;
          border-radius: 18px;
  }

  .phone-screen{
border-radius: 12px;
  }
    

    .lokal-stats {
     
          grid-template-columns: 1fr;
    }

  .about-section{
        padding: 3rem 0;
  }

    .about-sticky{
        position: static;
    }

    .tech-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .prozess-dark .steps-grid,
    .deep-grid,
    .ta-grid,
    .praesenz-inner,
    .intro-split,
    .faq-grid,
    .faq-list,
    .lokal-inner,
    .about-grid,
    .prozess-header-inner,
    .why{
          grid-template-columns: 1fr;
    }

    .numbers{
            padding: 30px 0px;
    }

    .numbers .n-item{
        padding: 0 12px
    }

    .numbers .n-item:nth-child(3){
        display: none;
    }

    .hero-actions{
        flex-direction: column;
        align-items: flex-start;
    }

    .prozess-grid {
        grid-template-columns: repeat(1, 1fr);
        gap: 2rem;
    }

    .hero-badge,
    .nav-links {
        display: none;
    }
}


.cc-window{opacity:1;transition:opacity 1s ease}.cc-window.cc-invisible{opacity:0}.cc-animate.cc-revoke{transition:transform 1s ease}.cc-animate.cc-revoke.cc-top{transform:translateY(-2em)}.cc-animate.cc-revoke.cc-bottom{transform:translateY(2em)}.cc-animate.cc-revoke.cc-active.cc-bottom,.cc-animate.cc-revoke.cc-active.cc-top,.cc-revoke:hover{transform:translateY(0)}.cc-grower{max-height:0;overflow:hidden;transition:max-height 1s}
.cc-link,.cc-revoke:hover{text-decoration:underline}.cc-revoke,.cc-window{position:fixed;overflow:hidden;box-sizing:border-box;font-family:Helvetica,Calibri,Arial,sans-serif;font-size:16px;line-height:1.5em;display:-ms-flexbox;display:flex;-ms-flex-wrap:nowrap;flex-wrap:nowrap;z-index:9999}.cc-window.cc-static{position:static}.cc-window.cc-floating{padding:2em;max-width:24em;-ms-flex-direction:column;flex-direction:column}.cc-window.cc-banner{padding:1em 1.8em;width:100%;-ms-flex-direction:row;flex-direction:row}.cc-revoke{padding:.5em}.cc-header{font-size:18px;font-weight:700}.cc-btn,.cc-close,.cc-link,.cc-revoke{cursor:pointer}.cc-link{opacity:.8;display:inline-block;padding:.2em}.cc-link:hover{opacity:1}.cc-link:active,.cc-link:visited{color:initial}.cc-btn{display:block;padding:.4em .8em;font-size:.9em;font-weight:700;border-width:2px;border-style:solid;text-align:center;white-space:nowrap}.cc-banner .cc-btn:last-child{min-width:140px}.cc-highlight .cc-btn:first-child{background-color:transparent;border-color:transparent}.cc-highlight .cc-btn:first-child:focus,.cc-highlight .cc-btn:first-child:hover{background-color:transparent;text-decoration:underline}.cc-close{display:block;position:absolute;top:.5em;right:.5em;font-size:1.6em;opacity:.9;line-height:.75}.cc-close:focus,.cc-close:hover{opacity:1}
.cc-revoke.cc-top{top:0;left:3em;border-bottom-left-radius:.5em;border-bottom-right-radius:.5em}.cc-revoke.cc-bottom{bottom:0;left:3em;border-top-left-radius:.5em;border-top-right-radius:.5em}.cc-revoke.cc-left{left:3em;right:unset}.cc-revoke.cc-right{right:3em;left:unset}.cc-top{top:1em}.cc-left{left:1em}.cc-right{right:1em}.cc-bottom{bottom:1em}.cc-floating>.cc-link{margin-bottom:1em}.cc-floating .cc-message{display:block;margin-bottom:1em}.cc-window.cc-floating .cc-compliance{-ms-flex:1;flex:1}.cc-window.cc-banner{-ms-flex-align:center;align-items:center}.cc-banner.cc-top{left:0;right:0;top:0}.cc-banner.cc-bottom{left:0;right:0;bottom:0}.cc-banner .cc-message{-ms-flex:1;flex:1}.cc-compliance{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-line-pack:justify;align-content:space-between}.cc-compliance>.cc-btn{-ms-flex:1;flex:1}.cc-btn+.cc-btn{margin-left:.5em}
@media print{.cc-revoke,.cc-window{display:none}}@media screen and (max-width:900px){.cc-btn{white-space:normal}}@media screen and (max-width:414px) and (orientation:portrait),screen and (max-width:736px) and (orientation:landscape){.cc-window.cc-top{top:0}.cc-window.cc-bottom{bottom:0}.cc-window.cc-banner,.cc-window.cc-left,.cc-window.cc-right{left:0;right:0}.cc-window.cc-banner{-ms-flex-direction:column;flex-direction:column}.cc-window.cc-banner .cc-compliance{-ms-flex:1;flex:1}.cc-window.cc-floating{max-width:none}.cc-window .cc-message{margin-bottom:1em}.cc-window.cc-banner{-ms-flex-align:unset;align-items:unset}}
.cc-floating.cc-theme-classic{padding:1.2em;border-radius:5px}.cc-floating.cc-type-info.cc-theme-classic .cc-compliance{text-align:center;display:inline;-ms-flex:none;flex:none}.cc-theme-classic .cc-btn{border-radius:5px}.cc-theme-classic .cc-btn:last-child{min-width:140px}.cc-floating.cc-type-info.cc-theme-classic .cc-btn{display:inline-block}
.cc-theme-edgeless.cc-window{padding:0}.cc-floating.cc-theme-edgeless .cc-message{margin:2em 2em 1.5em}.cc-banner.cc-theme-edgeless .cc-btn{margin:0;padding:.8em 1.8em;height:100%}.cc-banner.cc-theme-edgeless .cc-message{margin-left:1em}.cc-floating.cc-theme-edgeless .cc-btn+.cc-btn{margin-left:0}

