*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
  :root{
    --bg:#ffffff;--bg2:#f8f9fa;--ink:#0a0a0a;--ink2:#111827;
    --muted:#6b7280;--line:#e5e7eb;--blue:#111111;--blue-lt:#f0f0f0;
    --card:#ffffff;--spring:cubic-bezier(.32,.72,0,1);
  }
  [data-theme="dark"]{
    --bg:#0a0a0a;--bg2:#111111;--ink:#f9fafb;--ink2:#e5e7eb;
    --muted:#9ca3af;--line:#1f2937;--blue:#ffffff;--blue-lt:rgba(255,255,255,.07);
    --card:#141414;
  }
  html{scroll-behavior:smooth;}
  body{font-family:'Manrope',system-ui,sans-serif;background:var(--bg);color:var(--ink);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .3s,color .3s;}
  h1,h2,h3,.serif{font-family:'DM Serif Display',serif;}
  a{color:inherit;text-decoration:none;}
  img{max-width:100%;display:block;background:var(--bg2);}
  .wrap{max-width:1160px;margin:0 auto;padding:0 24px;}
  section{padding:clamp(72px,10vw,130px) 0;}
  .eyebrow{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--blue);font-weight:600;margin-bottom:14px;display:block;}
  .h2{font-size:clamp(36px,5.5vw,58px);line-height:1.05;margin-bottom:18px;}
  .lead{color:var(--muted);font-size:17px;max-width:560px;line-height:1.7;}
  .center{text-align:center;}.center .lead{margin-inline:auto;}

  .reveal{opacity:0;transform:translateY(34px);filter:blur(8px);transition:opacity .9s var(--spring),transform .9s var(--spring),filter .9s;}
  .reveal.in{opacity:1;transform:none;filter:none;}

  header{position:fixed;top:0;left:0;right:0;width:100%;z-index:100;background:var(--bg);border-bottom:1px solid var(--line);transition:background .3s,border-color .3s;}
  header.scrolled{background:var(--bg);}
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;}
  header .wrap{max-width:100%;padding:0 clamp(16px,3vw,48px);}
  .logo{font-family:'DM Serif Display',serif;font-size:22px;letter-spacing:-.01em;display:block;line-height:0;flex:none;}
  .logo span{color:var(--blue);}
  .logo img{width:auto;height:42px;max-width:160px;object-fit:contain;display:block;background:none;}
  [data-theme="dark"] .logo img{filter:invert(1);}
  .nav-links{display:flex;gap:28px;list-style:none;font-size:14px;font-weight:500;}
  .nav-links a{color:var(--muted);transition:color .25s;} .nav-links a:hover{color:var(--ink);}
  .nav-right{display:flex;align-items:center;gap:12px;}
  .lang-btn{font-size:12px;font-weight:600;letter-spacing:.08em;padding:7px 14px;border:1px solid var(--line);border-radius:999px;cursor:pointer;background:transparent;color:var(--muted);font-family:'Manrope';transition:.25s;}
  .lang-btn:hover,.lang-btn.active{border-color:var(--blue);color:var(--blue);}
  .theme-btn{width:38px;height:38px;border-radius:999px;border:1px solid var(--line);background:transparent;cursor:pointer;display:grid;place-items:center;transition:.25s;color:var(--muted);}
  .theme-btn:hover{border-color:var(--blue);color:var(--blue);}
  .nav-cta{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:999px;background:var(--blue);color:#fff;font-size:13px;font-weight:600;transition:.25s;}
  .nav-cta:hover{background:#000000;transform:translateY(-1px);}
  @media(max-width:980px){.nav-cta{display:none;}}
  .burger{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:10px;background:transparent;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px;}
  .burger span{width:20px;height:1.5px;background:var(--ink);transition:.4s var(--spring);border-radius:2px;}
  @media(max-width:860px){.nav-links{display:none;}.burger{display:flex;}}

  .overlay{position:fixed;inset:0;z-index:99;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;opacity:0;pointer-events:none;transition:opacity .4s var(--spring);}
  body.menu-open .overlay{opacity:1;pointer-events:auto;}
  .overlay a{font-family:'DM Serif Display',serif;font-size:38px;color:var(--ink);opacity:0;transform:translateY(20px);transition:opacity .5s var(--spring),transform .5s var(--spring);}
  body.menu-open .overlay a{opacity:1;transform:none;}
  body.menu-open .overlay a:nth-child(1){transition-delay:.06s;}
  body.menu-open .overlay a:nth-child(2){transition-delay:.12s;}
  body.menu-open .overlay a:nth-child(3){transition-delay:.18s;}
  body.menu-open .overlay a:nth-child(4){transition-delay:.24s;}
  body.menu-open .overlay a:nth-child(5){transition-delay:.30s;}
  body.menu-open .overlay a:nth-child(6){transition-delay:.36s;}
  body.menu-open .burger span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
  body.menu-open .burger span:nth-child(2){opacity:0;}
  body.menu-open .burger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

  .btn{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;border-radius:999px;font-weight:600;font-size:15px;cursor:pointer;border:none;transition:transform .4s var(--spring),background .3s,box-shadow .3s;text-align:center;}
  .btn:active{transform:scale(.97);}
  .btn-blue{background:var(--blue);color:#fff;}
  .btn-blue:hover{background:#000000;box-shadow:0 8px 28px rgba(0,0,0,.22);transform:translateY(-1px);}
  .btn-outline{border:1.5px solid var(--line);background:transparent;color:var(--ink);}
  .btn-outline:hover{border-color:var(--blue);color:var(--blue);}

  .hero{min-height:100dvh;display:flex;align-items:flex-start;padding-top:clamp(110px,14vw,150px);position:relative;overflow:hidden;}
  .hero-glow{position:absolute;top:-10%;right:-5%;width:50vw;height:50vw;max-width:680px;max-height:680px;background:radial-gradient(circle,var(--blue-lt),transparent 65%);opacity:.7;pointer-events:none;filter:blur(10px);}
  .hero-inner{max-width:880px;position:relative;z-index:2;}
  .hero h1{font-size:clamp(46px,8vw,98px);line-height:.96;letter-spacing:-.02em;margin:18px 0 24px;}
  .hero h1 em{font-style:italic;color:var(--blue);}
  .hero p{font-size:clamp(17px,2.2vw,21px);color:var(--muted);max-width:52ch;margin-bottom:36px;}
  .hero-actions{display:flex;gap:14px;flex-wrap:wrap;}
  .hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--blue-lt);color:var(--blue);padding:8px 16px;border-radius:999px;font-size:13px;font-weight:600;}
  .hero-badge::before{content:"";width:7px;height:7px;background:var(--blue);border-radius:50%;animation:pulse 2s infinite;}
  @keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.5;transform:scale(1.4);}}
  .hero-trust{display:flex;gap:22px;flex-wrap:wrap;margin-top:34px;color:var(--muted);font-size:13px;}
  .hero-trust span{display:inline-flex;align-items:center;gap:7px;}
  .hero-trust svg{color:var(--blue);}

  .about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
  .about-placeholder{height:460px;background:linear-gradient(135deg,var(--blue-lt),var(--bg2));border-radius:20px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);}
  .about-placeholder .initials{font-family:'DM Serif Display',serif;font-size:80px;color:var(--blue);opacity:.45;}
  .tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;}
  .tag{background:var(--bg2);border:1px solid var(--line);color:var(--muted);padding:6px 14px;border-radius:999px;font-size:13px;}
  @media(max-width:820px){.about-grid{grid-template-columns:1fr;}.about-placeholder{height:300px;}}

  .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:50px;}
  .svc-card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:32px;transition:transform .4s var(--spring),box-shadow .4s,border-color .3s;}
  .svc-card:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.10);border-color:var(--blue);}
  .svc-icon{width:48px;height:48px;background:var(--blue-lt);border-radius:12px;display:grid;place-items:center;margin-bottom:20px;color:var(--blue);}
  .svc-card h3{font-size:22px;margin-bottom:10px;}
  .svc-card p{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:16px;}
  .svc-price{font-size:13px;font-weight:700;color:var(--blue);}
  @media(max-width:820px){.svc-grid{grid-template-columns:1fr;}}

  .why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:50px;}
  .why-item{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:26px;display:flex;gap:14px;align-items:flex-start;transition:.3s;}
  .why-item:hover{border-color:var(--blue);}
  .why-num{font-family:'DM Serif Display',serif;font-size:28px;color:var(--blue);line-height:1;min-width:32px;}
  .why-item h4{font-size:16px;margin-bottom:4px;font-weight:600;}
  .why-item p{font-size:13px;color:var(--muted);}
  @media(max-width:820px){.why-grid{grid-template-columns:1fr 1fr;}} @media(max-width:520px){.why-grid{grid-template-columns:1fr;}}

  /* Process timeline */
  .steps{margin-top:50px;display:grid;gap:14px;max-width:760px;margin-inline:auto;}
  .step{display:flex;gap:20px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px 26px;transition:.3s;}
  .step:hover{border-color:var(--blue);transform:translateX(4px);}
  .step-n{width:42px;height:42px;flex-shrink:0;border-radius:999px;background:var(--blue);color:#fff;display:grid;place-items:center;font-family:'DM Serif Display',serif;font-size:20px;}
  .step h4{font-size:18px;margin-bottom:3px;}
  .step p{font-size:14px;color:var(--muted);}

  /* Demo offer band */
  .demo-band{background:linear-gradient(135deg,#111111,#2a2a2a);border-radius:28px;padding:clamp(36px,6vw,64px);color:#fff;position:relative;overflow:hidden;}
  .demo-band::after{content:"";position:absolute;right:-60px;top:-60px;width:260px;height:260px;background:rgba(255,255,255,.12);border-radius:50%;}
  .demo-band h2{font-size:clamp(30px,4.5vw,46px);line-height:1.05;margin-bottom:16px;position:relative;}
  .demo-band p{color:rgba(255,255,255,.9);font-size:17px;max-width:60ch;margin-bottom:24px;position:relative;}
  .demo-points{display:flex;gap:22px;flex-wrap:wrap;margin-bottom:30px;position:relative;}
  .demo-points li{list-style:none;display:flex;align-items:center;gap:9px;font-size:14px;font-weight:500;}
  .demo-points .c{width:22px;height:22px;border-radius:999px;background:rgba(255,255,255,.2);display:grid;place-items:center;font-size:13px;}
  .demo-band .btn{background:#fff;color:var(--blue);position:relative;}
  .demo-band .btn:hover{box-shadow:0 10px 30px rgba(0,0,0,.25);transform:translateY(-1px);}

  /* Benefit lists */
  .benefit-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:40px;}
  .benefit{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px;display:flex;gap:14px;align-items:flex-start;transition:.3s;}
  .benefit:hover{border-color:var(--blue);}
  .benefit .bi{width:40px;height:40px;border-radius:10px;background:var(--blue-lt);display:grid;place-items:center;flex-shrink:0;color:var(--blue);}
  .benefit h4{font-size:16px;margin-bottom:3px;font-weight:600;}
  .benefit p{font-size:13px;color:var(--muted);}
  @media(max-width:640px){.benefit-grid{grid-template-columns:1fr;}}

  .port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:50px;}
  .port-card{border-radius:20px;overflow:hidden;border:1px solid var(--line);transition:transform .5s var(--spring),box-shadow .4s;}
  .port-card:hover{transform:translateY(-7px);box-shadow:0 28px 60px rgba(0,0,0,.12);}
  .port-preview{height:220px;display:flex;align-items:center;justify-content:center;padding:28px;position:relative;}
  .port-demo-badge{position:absolute;top:14px;left:14px;background:rgba(0,0,0,.6);color:#fff;font-size:10px;font-weight:700;letter-spacing:.14em;padding:5px 11px;border-radius:999px;backdrop-filter:blur(4px);}
  .port-card .port-body{padding:20px 22px;background:var(--card);}
  .port-card h3{font-size:20px;margin-bottom:4px;}
  .port-card p{font-size:13px;color:var(--muted);margin-bottom:12px;}
  .port-link{font-size:12px;font-weight:600;color:var(--blue);letter-spacing:.04em;text-transform:uppercase;}
  @media(max-width:820px){.port-grid{grid-template-columns:1fr;}}

  .price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:50px;align-items:start;}
  .price-card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:32px;position:relative;transition:transform .4s var(--spring),box-shadow .4s;}
  .price-card:hover{transform:translateY(-5px);box-shadow:0 24px 60px rgba(0,0,0,.10);}
  .price-card.featured{border-color:var(--blue);background:var(--blue);color:#fff;box-shadow:0 24px 60px rgba(0,0,0,.18);}
  .price-card.featured .pc-muted{color:rgba(255,255,255,.7);}
  .price-card.featured .pc-feature{color:rgba(255,255,255,.9);}
  .price-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:#fff;color:var(--blue);font-size:11px;font-weight:700;letter-spacing:.08em;padding:5px 14px;border-radius:999px;border:1px solid var(--blue);white-space:nowrap;}
  .price-card h3{font-size:26px;margin-bottom:6px;}
  .pc-price{font-family:'DM Serif Display',serif;font-size:48px;margin:14px 0 6px;line-height:1;}
  .pc-muted{font-size:13px;color:var(--muted);margin-bottom:22px;}
  .pc-features{list-style:none;margin-bottom:28px;}
  .pc-feature{font-size:14px;padding:7px 0;border-bottom:1px solid var(--line);display:flex;gap:8px;align-items:center;color:var(--muted);}
  .price-card.featured .pc-feature{border-bottom-color:rgba(255,255,255,.2);}
  .pc-check{color:var(--blue);font-weight:700;font-size:15px;min-width:16px;}
  .price-card.featured .pc-check{color:#fff;}
  @media(max-width:860px){.price-grid{grid-template-columns:1fr;max-width:420px;margin-inline:auto;}}

  /* FAQ */
  .faq-wrap{max-width:820px;margin:50px auto 0;}
  .faq-item{border-bottom:1px solid var(--line);}
  .faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:22px 0;display:flex;justify-content:space-between;gap:18px;align-items:center;font-family:'DM Serif Display',serif;font-size:clamp(18px,2.4vw,22px);color:var(--ink);}
  .faq-q .pm{width:26px;height:26px;flex-shrink:0;position:relative;}
  .faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--blue);transition:.35s var(--spring);}
  .faq-q .pm::before{top:12px;left:3px;right:3px;height:2px;}
  .faq-q .pm::after{left:12px;top:3px;bottom:3px;width:2px;}
  .faq-item.open .pm::after{transform:rotate(90deg);opacity:0;}
  .faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--spring);}
  .faq-a p{padding:0 0 22px;color:var(--muted);font-size:15px;max-width:70ch;}

  /* Reviews placeholder */
  .rev-empty{margin-top:50px;border:1.5px dashed var(--line);border-radius:20px;padding:56px 28px;text-align:center;background:var(--card);}
  .rev-empty .stars{color:#F59E0B;letter-spacing:4px;font-size:22px;margin-bottom:16px;}
  .rev-empty h3{font-size:clamp(22px,3vw,30px);margin-bottom:10px;}
  .rev-empty p{color:var(--muted);font-size:15px;max-width:48ch;margin:0 auto;}

  /* Final CTA */
  .final-cta{text-align:center;}
  .final-cta .box{background:var(--ink);color:#fff;border-radius:28px;padding:clamp(44px,7vw,84px);position:relative;overflow:hidden;}
  [data-theme="dark"] .final-cta .box{background:#141414;border:1px solid var(--line);}
  .final-cta h2{font-size:clamp(32px,5vw,56px);line-height:1.04;margin-bottom:16px;}
  .final-cta p{color:rgba(255,255,255,.75);font-size:18px;max-width:54ch;margin:0 auto 30px;}
  .final-cta .hero-actions{justify-content:center;}

  /* Contact */
  .contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:52px;align-items:start;}
  .form-field{margin-bottom:18px;}
  .form-field label{display:block;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;}
  .form-field input,.form-field select,.form-field textarea{width:100%;padding:14px 16px;border:1.5px solid var(--line);border-radius:12px;background:var(--bg2);color:var(--ink);font-family:'Manrope';font-size:15px;outline:none;transition:border-color .25s;}
  .form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--blue);}
  .form-field select option{background:var(--bg);}
  .form-note{font-size:12px;color:var(--muted);margin-top:6px;}
  .form-msg{display:none;border-radius:12px;padding:16px 18px;font-size:14px;margin-top:8px;}
  .form-msg.ok{display:block;background:var(--blue-lt);color:var(--blue);border:1px solid var(--blue);}
  .form-msg.err{display:block;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;}
  @media(max-width:820px){.contact-grid{grid-template-columns:1fr;}}

  footer{background:var(--ink);color:rgba(255,255,255,.65);padding:48px 0 24px;}
  [data-theme="dark"] footer{background:#050505;}
  .foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:32px;margin-bottom:40px;}
  footer h4{color:#fff;font-size:16px;margin-bottom:12px;font-family:'DM Serif Display',serif;}
  footer a{transition:color .25s;} footer a:hover{color:#fff;}
  .foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:12px;}
  @media(max-width:720px){.foot-grid{grid-template-columns:1fr;}}

  .fab{position:fixed;bottom:24px;right:24px;z-index:80;width:56px;height:56px;border-radius:999px;display:grid;place-items:center;box-shadow:0 8px 28px rgba(37,211,102,.4);transition:transform .3s;}
  .fab:hover{transform:scale(1.08);}
  #toTop{position:fixed;bottom:24px;left:24px;z-index:80;width:46px;height:46px;border-radius:999px;background:var(--blue);color:#fff;border:none;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .3s;font-size:18px;display:grid;place-items:center;}
  #toTop.show{opacity:1;pointer-events:auto;}
  ::-webkit-scrollbar{width:4px;} ::-webkit-scrollbar-track{background:var(--bg);} ::-webkit-scrollbar-thumb{background:var(--blue);border-radius:4px;}
  @media(max-width:600px){section{padding:60px 0;}.wrap{padding:0 18px;}.hero-actions{width:100%;}.hero-actions .btn{flex:1;justify-content:center;}}

/* ===== multi-page additions ===== */
.nav-links a.active{color:var(--blue);}
.overlay a.active{color:var(--blue);}
/* keep first section clear of the fixed header on subpages */
body[data-page]:not([data-page="home"]) main > section:first-child{padding-top:clamp(112px,16vh,150px);}

/* ===== schwarzweiß: dark-mode fixes =====
   In dark mode --blue becomes #fff (white accent).
   Any element with background:var(--blue) + color:#fff
   (= white bg + white text) needs text flipped to #000.
 ========================================== */
[data-theme="dark"] .nav-cta{color:#000;}
[data-theme="dark"] .step-n{color:#000;}
[data-theme="dark"] #toTop{color:#000;}
[data-theme="dark"] .btn-blue{color:#000;}
[data-theme="dark"] .demo-band{background:linear-gradient(135deg,#181818,#282828);}
[data-theme="dark"] .demo-band .btn{color:#000;}
[data-theme="dark"] .price-card.featured{
  background:#151515;border-color:#ffffff;
  box-shadow:0 24px 60px rgba(255,255,255,.05);
}
[data-theme="dark"] .price-card.featured h3,
[data-theme="dark"] .price-card.featured .pc-price,
[data-theme="dark"] .price-card.featured .pc-muted,
[data-theme="dark"] .price-card.featured li{color:#fff;}
[data-theme="dark"] .price-card.featured .btn{color:#000!important;}
[data-theme="dark"] .price-badge{background:#0c0c0c;color:#fff;border-color:#fff;}

[data-theme="dark"] .nav-cta:hover{background:#e2e2e2;}
[data-theme="dark"] .btn-blue:hover{background:#e2e2e2;box-shadow:0 8px 28px rgba(255,255,255,.10);}

/* ===== Special Offer section ===== */
.offer{padding:56px 0 8px;}
.offer-card{position:relative;max-width:880px;margin:0 auto;background:var(--card);
  border:1.5px solid var(--blue);border-radius:26px;padding:46px 40px;text-align:center;
  box-shadow:0 30px 80px rgba(0,0,0,.10);}
.offer-badge{display:inline-flex;align-items:center;gap:8px;background:var(--blue);color:#fff;
  padding:9px 18px;border-radius:999px;font-size:13px;font-weight:700;letter-spacing:.01em;}
[data-theme="dark"] .offer-badge{color:#000;}
.offer-card h2{font-size:clamp(26px,4vw,40px);line-height:1.1;margin:22px 0 8px;}
.offer-price{display:flex;gap:14px;align-items:baseline;justify-content:center;margin:6px 0 2px;}
.offer-price .old{font-size:22px;color:var(--muted);text-decoration:line-through;font-weight:600;}
.offer-price .new{font-size:clamp(42px,8vw,66px);font-weight:400;line-height:1;color:var(--blue);}
.offer-sub{color:var(--muted);max-width:540px;margin:10px auto 28px;font-size:16px;}
.offer-benefits{list-style:none;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));
  gap:13px 30px;max-width:600px;margin:0 auto 30px;text-align:left;padding:0;}
.offer-benefits li{display:flex;gap:11px;align-items:flex-start;font-size:15px;font-weight:500;}
.offer-benefits svg{flex:none;margin-top:2px;color:var(--blue);}
.offer-cta{padding:16px 38px;font-size:16px;}
.offer-scarcity{display:inline-flex;align-items:center;gap:9px;margin:22px auto 0;
  background:var(--bg2);border:1px solid var(--line);color:var(--text);
  padding:9px 18px;border-radius:999px;font-size:14px;font-weight:600;}
.offer-dot{width:9px;height:9px;border-radius:50%;background:#e0245e;animation:pulse 1.8s infinite;}
.offer-trust{display:flex;align-items:center;justify-content:center;gap:8px;
  color:var(--muted);font-size:14px;margin:16px auto 0;}
.offer-trust svg{color:var(--blue);}
@media(max-width:600px){
  .offer{padding:40px 0 4px;}
  .offer-card{padding:34px 20px;border-radius:22px;}
  .offer-benefits{grid-template-columns:1fr;gap:11px;max-width:320px;}
  .offer-cta{width:100%;justify-content:center;}
}

/* ===== accessibility: skip link ===== */
.skip-link{position:absolute;left:-9999px;top:0;z-index:100000;background:var(--blue);color:#fff;
  padding:11px 18px;border-radius:0 0 10px 0;font-weight:600;font-size:14px;text-decoration:none;}
.skip-link:focus{left:0;}
[data-theme="dark"] .skip-link{color:#000;}
:focus-visible{outline:2px solid var(--blue);outline-offset:2px;}

/* ===== Promo-Leiste (Sonderangebot, oben fixiert) ===== */
:root{--promo-h:42px;}
body{padding-top:var(--promo-h);}
#header{top:var(--promo-h);}
.promobar{position:fixed;top:0;left:0;right:0;height:var(--promo-h);z-index:95;
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:#111111;color:#fff;text-decoration:none;font-size:14px;font-weight:600;
  letter-spacing:.01em;padding:0 18px;white-space:nowrap;overflow:hidden;
  transition:background .25s ease;}
.promobar:hover{background:#000;}
.promobar .arrow{font-size:16px;line-height:1;transition:transform .25s ease;}
.promobar:hover .arrow{transform:translateX(4px);}
.promobar .promo-short{display:none;}
@media(max-width:680px){
  .promobar{font-size:12.5px;gap:8px;padding:0 12px;}
  .promobar .promo-full{display:none;}
  .promobar .promo-short{display:inline;}
}

/* ===== about: logo image fills placeholder ===== */
.about-placeholder{overflow:hidden;}
.about-placeholder img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block;}

/* ===== Mobile: kompakter, mehr passt auf den Schirm ===== */
@media(max-width:600px){
  section{padding:34px 0;}
  .wrap{padding:0 16px;}
  .hero{min-height:auto;padding-top:74px;padding-bottom:6px;}
  .hero h1{font-size:33px;line-height:1.02;margin:11px 0 14px;}
  .hero p{font-size:15px;line-height:1.6;margin-bottom:20px;}
  .hero-badge{font-size:12px;padding:6px 13px;}
  .hero-actions{gap:10px;}
  .hero-trust{margin-top:18px;gap:12px 16px;font-size:12.5px;}
  .h2{font-size:25px;margin-bottom:11px;}
  .lead{font-size:15px;line-height:1.6;}
  .eyebrow{font-size:11.5px;}
  .btn{padding:12px 20px;font-size:14px;}
  .tag{font-size:12px;padding:5px 11px;}
  .about-placeholder{height:185px;}
  .offer{padding:24px 0 2px;}
  .offer-card{padding:26px 16px;border-radius:18px;}
  .offer-badge{font-size:12px;padding:7px 14px;}
  .offer-card h2{font-size:21px;margin:13px 0 5px;}
  .offer-price .new{font-size:36px;}
  .offer-price .old{font-size:18px;}
  .offer-sub{font-size:14px;margin:7px auto 18px;}
  .offer-benefits{gap:9px;margin-bottom:22px;}
  .offer-benefits li{font-size:14px;}
  .offer-cta{padding:14px 28px;font-size:15px;}
}
@media(max-width:380px){
  .hero h1{font-size:29px;}
  .h2{font-size:23px;}
  section{padding:28px 0;}
  .hero p,.lead{font-size:14.5px;}
}

/* =========================================================================
   2026 REDESIGN LAYER — conversion, trust & motion (KJC Digital)
   Self-contained additions. Overrides earlier rules where needed.
   ========================================================================= */

/* ---- Accessibility: respect reduced motion ---- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important;}
  .reveal{opacity:1!important;transform:none!important;filter:none!important;}
}

/* ---- Glass navigation (modern agency feel) ---- */
@supports (backdrop-filter:blur(12px)){
  #header{background:color-mix(in srgb,var(--bg) 78%,transparent);backdrop-filter:saturate(180%) blur(14px);}
  #header.scrolled{background:color-mix(in srgb,var(--bg) 82%,transparent);}
}
#header{transition:background .3s,border-color .3s,box-shadow .3s;}
#header.scrolled{box-shadow:0 1px 0 var(--line),0 10px 30px -24px rgba(0,0,0,.5);}

/* ---- Hero: two-column with product mockup ---- */
.hero{align-items:center;}
.hero-inner{max-width:1160px;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;}
.hero-copy{max-width:600px;}
.hero-visual{position:relative;}
.browser-frame{border-radius:16px;overflow:hidden;border:1px solid var(--line);
  background:var(--card);box-shadow:0 40px 90px -40px rgba(0,0,0,.45),0 8px 24px -16px rgba(0,0,0,.3);
  transform:perspective(1400px) rotateY(-6deg) rotateX(2deg);transition:transform .6s var(--spring);}
.hero-visual:hover .browser-frame{transform:perspective(1400px) rotateY(-2deg) rotateX(1deg);}
.browser-bar{display:flex;align-items:center;gap:7px;padding:11px 14px;background:var(--bg2);border-bottom:1px solid var(--line);}
.browser-bar .bdot{width:10px;height:10px;border-radius:50%;background:var(--line);}
.browser-bar .bdot:nth-child(1){background:#ff5f57;}.browser-bar .bdot:nth-child(2){background:#febc2e;}.browser-bar .bdot:nth-child(3){background:#28c840;}
.browser-url{margin-left:10px;flex:1;background:var(--bg);border:1px solid var(--line);border-radius:7px;
  font-size:11px;color:var(--muted);padding:5px 12px;text-align:center;letter-spacing:.02em;}
.browser-frame img{width:100%;height:auto;aspect-ratio:900/620;object-fit:cover;object-position:top center;display:block;}
.hero-float{position:absolute;display:flex;align-items:center;gap:11px;background:var(--card);
  border:1px solid var(--line);border-radius:14px;padding:12px 16px;
  box-shadow:0 20px 50px -24px rgba(0,0,0,.5);animation:floaty 5s ease-in-out infinite;}
.hero-float .hf-ic{font-size:20px;line-height:1;}
.hero-float strong{display:block;font-size:14px;font-weight:700;}
.hero-float small{display:block;font-size:11.5px;color:var(--muted);}
.hero-float-a{top:14%;left:-26px;animation-delay:.2s;}
.hero-float-b{bottom:12%;right:-20px;animation-delay:1.4s;}
@keyframes floaty{0%,100%{transform:translateY(0);}50%{transform:translateY(-9px);}}
@media(max-width:920px){
  .hero-inner{grid-template-columns:1fr;gap:34px;}
  .hero-copy{max-width:none;}
  .browser-frame{transform:none;}
  .hero-float-a{left:8px;}.hero-float-b{right:8px;}
}
@media(max-width:600px){
  .hero-visual{margin-top:6px;}
  .hero-float{padding:9px 12px;border-radius:11px;}
  .hero-float .hf-ic{font-size:16px;}
  .hero-float strong{font-size:12.5px;}.hero-float small{font-size:10.5px;}
  .hero-float-a{top:8px;left:6px;}.hero-float-b{bottom:8px;right:6px;}
}

/* ---- Proof / stats band ---- */
.proofbar{padding:0;}
.proof-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:30px 0;}
.proof-item{text-align:center;display:flex;flex-direction:column;gap:5px;position:relative;}
.proof-item:not(:last-child)::after{content:"";position:absolute;right:-9px;top:50%;transform:translateY(-50%);
  width:1px;height:42px;background:var(--line);}
.proof-num{font-family:'DM Serif Display',serif;font-size:clamp(30px,4.4vw,46px);line-height:1;color:var(--ink);
  font-variant-numeric:tabular-nums;}
.proof-label{font-size:12.5px;color:var(--muted);line-height:1.4;max-width:22ch;margin:0 auto;}
@media(max-width:680px){
  .proof-grid{grid-template-columns:1fr 1fr;gap:24px 12px;padding:26px 0;}
  .proof-item:nth-child(2)::after{display:none;}
  .proof-label{font-size:11.5px;}
}

/* ---- Guarantee / risk-reversal ---- */
.guarantee-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:50px;}
.guarantee-card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:30px;
  transition:transform .4s var(--spring),box-shadow .4s,border-color .3s;}
.guarantee-card:hover{transform:translateY(-5px);border-color:var(--blue);box-shadow:0 24px 60px -28px rgba(0,0,0,.4);}
.g-ic{width:50px;height:50px;border-radius:14px;background:var(--blue);color:#fff;display:grid;place-items:center;margin-bottom:18px;}
[data-theme="dark"] .g-ic{color:#000;}
.guarantee-card h3{font-size:21px;margin-bottom:9px;}
.guarantee-card p{font-size:14.5px;color:var(--muted);line-height:1.65;}
@media(max-width:820px){.guarantee-grid{grid-template-columns:1fr;}}

/* ---- Founder trust card ---- */
.founder-card{display:flex;gap:26px;align-items:center;margin-top:22px;background:var(--bg2);
  border:1px solid var(--line);border-radius:24px;padding:32px 36px;}
.founder-avatar{flex:none;width:96px;height:96px;border-radius:50%;object-fit:cover;object-position:center 28%;display:block;background:var(--bg2);border:1px solid var(--line);}
.founder-quote{font-size:clamp(17px,2.2vw,22px);line-height:1.5;margin-bottom:14px;font-style:italic;}
.founder-meta strong{display:block;font-size:15px;}
.founder-meta span{display:block;font-size:13px;color:var(--muted);margin-top:2px;}
.founder-cta{display:inline-block;margin-top:14px;font-size:14px;font-weight:600;color:var(--blue);}
.founder-cta:hover{text-decoration:underline;}
@media(max-width:640px){
  .founder-card{flex-direction:column;text-align:center;padding:28px 22px;gap:18px;}
  .founder-meta span{margin-inline:auto;}
}

/* ---- Industries strip ---- */
.industries{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:820px;margin:44px auto 0;}
.ind-chip{background:var(--card);border:1px solid var(--line);border-radius:999px;padding:11px 20px;
  font-size:14.5px;font-weight:500;color:var(--ink);transition:.3s var(--spring);cursor:default;}
.ind-chip:hover{border-color:var(--blue);transform:translateY(-2px);color:var(--blue);}

/* ---- Sticky mobile CTA bar ---- */
.mobile-cta{display:none;}
@media(max-width:860px){
  .mobile-cta{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:90;gap:9px;padding:10px 12px;
    padding-bottom:calc(10px + env(safe-area-inset-bottom));
    background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:saturate(180%) blur(12px);
    border-top:1px solid var(--line);box-shadow:0 -8px 30px -20px rgba(0,0,0,.5);}
  .mcta{height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;}
  .mcta-primary{flex:1;background:var(--blue);color:#fff;}
  [data-theme="dark"] .mcta-primary{color:#000;}
  .mcta-wa{width:52px;flex:none;background:#25D366;color:#fff;}
  .mcta-call{width:52px;flex:none;background:var(--card);border:1px solid var(--line);color:var(--ink);}
  /* lift floating buttons above the bar so they don't overlap (only on pages that have the bar) */
  body:has(.mobile-cta) .fab{bottom:78px;}
  body:has(.mobile-cta) #toTop{bottom:78px;}
  body:has(.mobile-cta){padding-bottom:70px;}
}

/* ---- Buttons: subtle premium shine ---- */
.btn-blue{position:relative;overflow:hidden;}
.btn-blue::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.28),transparent);transform:skewX(-18deg);transition:left .6s var(--spring);}
.btn-blue:hover::after{left:140%;}
[data-theme="dark"] .btn-blue::after{background:linear-gradient(100deg,transparent,rgba(0,0,0,.18),transparent);}

/* ---- Fix: primary CTA contrast on the dark final-cta box (brand --blue is #111) ---- */
.final-cta .box .btn-blue{background:#fff;color:#111;}
.final-cta .box .btn-blue:hover{background:#ededed;color:#000;box-shadow:0 12px 32px rgba(0,0,0,.35);}
.final-cta .box .btn-blue::after{background:linear-gradient(100deg,transparent,rgba(0,0,0,.10),transparent);}
[data-theme="dark"] .final-cta .box .btn-blue{background:#fff;color:#111;}

/* ---- Reveal motion variant: gentle scale for cards ---- */
.reveal{will-change:opacity,transform;}

/* ---- Contact: next-steps + trust badges (friction reduction) ---- */
.next-steps{list-style:none;margin:30px 0 26px;padding:0;display:grid;gap:14px;}
.next-steps li{display:flex;gap:14px;align-items:flex-start;}
.next-steps .ns-n{flex:none;width:30px;height:30px;border-radius:50%;background:var(--blue);color:#fff;
  display:grid;place-items:center;font-size:14px;font-weight:700;}
[data-theme="dark"] .next-steps .ns-n{color:#000;}
.next-steps strong{display:block;font-size:15px;margin-bottom:1px;}
.next-steps span{font-size:13.5px;color:var(--muted);line-height:1.55;}
.response-promise{display:inline-flex;align-items:center;gap:9px;background:var(--blue-lt);color:var(--blue);
  border-radius:999px;padding:9px 16px;font-size:13.5px;font-weight:600;margin-bottom:6px;}
.response-promise .rp-dot{width:8px;height:8px;border-radius:50%;background:#28c840;box-shadow:0 0 0 3px rgba(40,200,64,.2);}
.trust-badges{display:flex;flex-wrap:wrap;gap:10px 18px;margin-top:22px;padding-top:22px;border-top:1px solid var(--line);}
.trust-badges span{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--muted);}
.trust-badges svg{color:var(--blue);flex:none;}

/* ---- Portfolio: case-study + demo link row ---- */
.port-links{display:flex;gap:18px;flex-wrap:wrap;align-items:center;}
.port-link-alt{color:var(--muted);}
.port-link:hover{text-decoration:underline;}

/* ---- Case study pages ---- */
.cs-hero{padding:140px 0 56px;}
.cs-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:36px;}
.cs-meta>div{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px 20px;}
.cs-meta b{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:5px;font-weight:600;}
.cs-meta span{font-size:15px;font-weight:600;}
@media(max-width:680px){.cs-meta{grid-template-columns:1fr;}}
.cs-section{padding:56px 0;}
.cs-section+.cs-section{border-top:1px solid var(--line);}
.cs-grid2{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;}
@media(max-width:820px){.cs-grid2{grid-template-columns:1fr;}}
.cs-body{color:var(--muted);line-height:1.75;font-size:16px;display:flex;flex-direction:column;gap:14px;max-width:62ch;}
.cs-list{list-style:none;margin:0;padding:0;display:grid;gap:12px;}
.cs-list li{display:flex;gap:12px;align-items:flex-start;font-size:15px;color:var(--ink);}
.cs-list .ck{flex:none;width:22px;height:22px;border-radius:50%;background:var(--blue-lt);color:var(--blue);
  display:grid;place-items:center;font-size:12px;font-weight:700;margin-top:1px;}
.cs-results{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:36px;}
.cs-results>div{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px;text-align:center;}
.cs-results .n{font-family:'DM Serif Display',serif;font-size:clamp(28px,3.6vw,40px);color:var(--blue);line-height:1.1;}
.cs-results p{font-size:13.5px;color:var(--muted);margin-top:6px;}
@media(max-width:680px){.cs-results{grid-template-columns:1fr;}}
.cs-shot{border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:0 30px 70px -30px rgba(0,0,0,.3);}
.cs-shot img{width:100%;height:auto;display:block;}
.cs-preview-block{border-radius:18px;border:1px solid var(--line);min-height:300px;display:flex;align-items:center;justify-content:center;text-align:center;padding:40px;}

/* ---- Featured flagship project (homepage) ---- */
.featured-card{display:grid;grid-template-columns:1.05fr .95fr;background:var(--card);border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:0 34px 80px -44px rgba(0,0,0,.34);}
.featured-media{position:relative;display:block;min-height:360px;overflow:hidden;background:#0a0a0a;}
.featured-media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--spring);}
.featured-media:hover img{transform:scale(1.045);}
.featured-badge{position:absolute;top:16px;left:16px;display:inline-flex;align-items:center;gap:8px;background:rgba(0,0,0,.66);color:#fff;border-radius:999px;padding:7px 14px;font-size:12px;font-weight:600;backdrop-filter:blur(6px);}
.featured-badge .fb-dot{width:8px;height:8px;border-radius:50%;background:#28c840;box-shadow:0 0 0 3px rgba(40,200,64,.3);}
.featured-url{position:absolute;bottom:16px;right:16px;background:#fff;color:#111;border-radius:999px;padding:7px 14px;font-size:12px;font-weight:700;letter-spacing:.01em;}
.featured-body{padding:clamp(26px,3.6vw,46px);display:flex;flex-direction:column;align-items:flex-start;justify-content:center;}
.featured-body h3{font-size:clamp(28px,4vw,42px);margin:10px 0 14px;}
.featured-body>p{color:var(--muted);font-size:15.5px;line-height:1.7;margin-bottom:22px;max-width:50ch;}
.featured-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px;}
.featured-tags span{font-size:12.5px;font-weight:600;color:var(--ink);background:var(--bg2);border:1px solid var(--line);border-radius:999px;padding:6px 13px;}
.featured-highlights{list-style:none;margin:0 0 28px;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:11px 20px;width:100%;}
.featured-highlights li{display:flex;gap:9px;align-items:flex-start;font-size:14px;color:var(--ink);line-height:1.45;}
.featured-highlights li::before{content:"✓";color:var(--blue);font-weight:800;flex:none;}
.featured-cta{display:flex;gap:12px;flex-wrap:wrap;}
@media(max-width:860px){.featured-card{grid-template-columns:1fr;}.featured-media{min-height:240px;aspect-ratio:16/10;}.featured-highlights{grid-template-columns:1fr;}}

/* ---- Case study photo gallery ---- */
.cs-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:36px;}
.cs-gallery figure{margin:0;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:var(--bg2);aspect-ratio:4/5;}
.cs-gallery img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--spring);}
.cs-gallery figure:hover img{transform:scale(1.05);}
.cs-gallery .wide{grid-column:span 2;aspect-ratio:16/10;}
@media(max-width:760px){.cs-gallery{grid-template-columns:1fr 1fr;}.cs-gallery .wide{grid-column:span 2;}}
@media(max-width:480px){.cs-gallery{grid-template-columns:1fr;}.cs-gallery .wide{grid-column:span 1;}}

/* ---- Footer NAP (local SEO: visible Name/Address/Phone) ---- */
.foot-nap{font-style:normal;margin-top:16px;display:flex;flex-direction:column;gap:7px;font-size:14px;}
.foot-nap a{color:rgba(255,255,255,.72);}
.foot-nap a:hover{color:#fff;}

/* =========================================================================
   CRAFT LAYER — creative-director refinement pass (KJC Digital)
   Linear / Vercel / Stripe-grade typography, motion & interaction polish.
   Appended last so it refines earlier rules through the cascade.
   ========================================================================= */

/* ---- Global text rendering & rhythm ---- */
body{line-height:1.6;text-rendering:optimizeLegibility;-moz-osx-font-smoothing:grayscale;
  font-feature-settings:"kern","liga","calt";}
h1,h2,h3,.h2,.serif{text-wrap:balance;}
p,.lead,.hero p,.cs-body,footer p{text-wrap:pretty;}
.h2{letter-spacing:-.018em;}
.hero h1{line-height:.94;}
.pc-price,.offer-price .new,.offer-price .old,.proof-num,.cs-results .n{font-variant-numeric:tabular-nums;}

/* ---- Anchor scroll-offset (in-page links clear the fixed header + promo bar) ---- */
section[id],[id]:target{scroll-margin-top:calc(var(--promo-h) + 84px);}

/* ---- Theme-aware monochrome selection + scrollbar ---- */
::selection{background:var(--ink);color:var(--bg);}
::-webkit-scrollbar{width:10px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--ink) 26%,transparent);
  border-radius:8px;border:3px solid var(--bg);}
::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--ink) 44%,transparent);}
html{scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--ink) 30%,transparent) transparent;}

/* ---- Refined reveal: crisp fade + rise (drops heavy blur, faster) ---- */
.reveal{transform:translateY(20px);filter:none;
  transition:opacity .7s var(--spring),transform .7s var(--spring);}
.reveal.in{transform:none;filter:none;}

/* ---- Focus-visible: refined ring ---- */
:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:6px;}

/* ---- Navigation: animated underline indicator + crisper hovers ---- */
.nav-links{gap:32px;}
.nav-links a{position:relative;color:var(--muted);font-weight:500;
  transition:color .25s var(--spring);}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-7px;height:2px;border-radius:2px;
  background:currentColor;transform:scaleX(0);transform-origin:left center;
  transition:transform .35s var(--spring);}
.nav-links a:hover{color:var(--ink);}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);}
.nav-links a.active{color:var(--blue);}
.lang-btn,.theme-btn{transition:border-color .25s,color .25s,background .25s,transform .2s var(--spring);}
.lang-btn:hover,.theme-btn:hover{background:var(--blue-lt);transform:translateY(-1px);}
.lang-btn:active,.theme-btn:active{transform:scale(.95);}

/* ---- Buttons: snappier, more tactile ---- */
.btn{transition:transform .25s var(--spring),background .25s,box-shadow .35s,border-color .25s;}
.btn-blue:hover{transform:translateY(-2px);}
.btn-outline:hover{background:var(--blue-lt);border-color:var(--blue);transform:translateY(-2px);}

/* ---- Hero: cleaner glow + premium status floats (SVG icon chips) ---- */
.hero-glow{filter:none;opacity:.85;width:56vw;height:56vw;}
.hero-float{border-radius:15px;box-shadow:0 22px 55px -26px rgba(0,0,0,.55);}
@supports (backdrop-filter:blur(4px)){
  .hero-float{background:color-mix(in srgb,var(--card) 82%,transparent);backdrop-filter:blur(8px) saturate(160%);}
}
.hf-ic{width:34px;height:34px;border-radius:10px;background:var(--blue-lt);color:var(--blue);
  display:grid;place-items:center;flex:none;}
.hf-ic svg{width:18px;height:18px;}

/* ---- Cards: unified premium depth on hover ---- */
.svc-card,.guarantee-card,.why-item,.benefit,.step,.port-card,.price-card{will-change:transform;}
.svc-card:hover,.guarantee-card:hover{box-shadow:0 30px 70px -34px rgba(0,0,0,.45);}

/* ---- Portfolio cards: subtle image zoom on hover ---- */
.port-card{isolation:isolate;}
.port-preview{transition:transform .6s var(--spring);}
.port-card:hover .port-preview{transform:scale(1.035);}
.port-demo-badge{z-index:2;}

/* ---- Contact inputs: soft focus halo (reduces form friction) ---- */
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  box-shadow:0 0 0 4px var(--blue-lt);}

/* ---- Footer links: subtle underline reveal ---- */
.foot-grid a:not(.foot-nap a){background-image:linear-gradient(currentColor,currentColor);
  background-size:0% 1px;background-repeat:no-repeat;background-position:0 100%;
  transition:background-size .3s var(--spring),color .25s;}
.foot-grid a:not(.foot-nap a):hover{background-size:100% 1px;}

/* =========================================================================
   CRAFT LAYER II — design-engineer polish (KJC Digital)
   Signature pointer interactions, technical hero texture, systematic depth.
   Reference register: Linear / Vercel / Emil Kowalski / Rauno Freiberg.
   ========================================================================= */

/* ---- Elevation + radius tokens (unify ad-hoc shadows) ---- */
:root{--r-lg:24px;--r-md:16px;--r-sm:12px;
  --e2:0 14px 36px -16px rgba(0,0,0,.20);
  --e3:0 34px 80px -38px rgba(0,0,0,.45);}
[data-theme="dark"]{
  --e2:0 14px 36px -16px rgba(0,0,0,.70);
  --e3:0 40px 90px -44px rgba(0,0,0,.85);}

/* ---- Hero: fading dot-grid texture (technical, design-focused first impression) ---- */
.hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:radial-gradient(circle at 1px 1px,var(--line) 1px,transparent 0);
  background-size:32px 32px;opacity:.6;
  -webkit-mask:radial-gradient(125% 85% at 50% 0%,#000 28%,transparent 72%);
          mask:radial-gradient(125% 85% at 50% 0%,#000 28%,transparent 72%);}
.hero-glow{z-index:1;}

/* ---- Hero emphasis: refined gradient ink (with safe fallback) ---- */
.hero h1 em{color:var(--blue);}
@supports ((-webkit-background-clip:text) or (background-clip:text)){
  .hero h1 em{background:linear-gradient(118deg,var(--blue),color-mix(in srgb,var(--blue) 58%,var(--muted)));
    -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;}
}

/* ---- Pointer-aware spotlight ring on cards (the signature DE interaction) ---- */
.svc-card,.guarantee-card,.price-card,.port-card,.benefit,.why-item{position:relative;}
@media (hover:hover) and (pointer:fine){
  .svc-card::after,.guarantee-card::after,.price-card::after,
  .port-card::after,.benefit::after,.why-item::after{
    content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;z-index:3;
    background:radial-gradient(340px circle at var(--mx,50%) var(--my,-40%),
      color-mix(in srgb,var(--blue) 55%,transparent),transparent 45%);
    -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
            mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
    -webkit-mask-composite:xor;mask-composite:exclude;
    opacity:0;transition:opacity .4s ease;}
  .svc-card:hover::after,.guarantee-card:hover::after,.price-card:hover::after,
  .port-card:hover::after,.benefit:hover::after,.why-item:hover::after{opacity:1;}
}

/* ---- Portfolio preview: depth scrim on hover (paired with image zoom) ---- */
.port-preview::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent 56%,rgba(0,0,0,.32));
  opacity:0;transition:opacity .45s var(--spring);}
.port-card:hover .port-preview::after{opacity:1;}

/* ---- Unify hover elevation through tokens ---- */
.svc-card:hover,.guarantee-card:hover,.price-card:hover,.featured-card:hover,.port-card:hover{box-shadow:var(--e3);}

/* ---- Scroll reading progress (rests on the header's bottom edge) ---- */
#kjcProgress{position:fixed;left:0;top:calc(var(--promo-h) + 70px);height:2px;width:0;z-index:101;
  background:var(--blue);box-shadow:0 0 12px color-mix(in srgb,var(--blue) 55%,transparent);
  transition:width .08s linear;pointer-events:none;}

/* ---- Tablet density: 2-up grids between phone and desktop ---- */
@media(min-width:620px) and (max-width:980px){
  .svc-grid,.guarantee-grid{grid-template-columns:1fr 1fr;}
}
