/* =====================================================================
   GermanDocBot — Main Stylesheet  v5.0  Modern Civic SaaS 2025
   Font: Inter (Google Fonts)
   ===================================================================== */

/* ───── RESET ───── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ───── DESIGN TOKENS ───── */
:root{
  --blue:        #2563eb;
  --blue-dark:   #1d4ed8;
  --blue-light:  #eff6ff;
  --blue-mid:    #bfdbfe;
  --indigo:      #4f46e5;
  --indigo-dark: #3730a3;
  --indigo-light:#eef2ff;

  /* backward-compat aliases */
  --violet:      #4f46e5;
  --violet-light:#f5f3ff;

  --green:       #059669;
  --green-dark:  #047857;
  --green-light: #ecfdf5;

  --amber:       #f59e0b;
  --amber-light: #fffbeb;

  --text:        #0f172a;
  --text-2:      #334155;
  --muted:       #64748b;
  --border:      #e2e8f0;
  --bg:          #ffffff;
  --bg-subtle:   #f8fafc;
  --bg-gray:     #f1f5f9;

  --radius:      20px;
  --radius-sm:   12px;
  --radius-xs:   8px;

  --shadow-xs:   0 1px 2px rgba(0,0,0,.05);
  --shadow:      0 1px 4px rgba(0,0,0,.06),0 2px 12px rgba(0,0,0,.05);
  --shadow-md:   0 4px 16px rgba(0,0,0,.08),0 1px 4px rgba(0,0,0,.05);
  --shadow-lg:   0 8px 32px rgba(0,0,0,.10),0 2px 8px rgba(0,0,0,.06);
  --shadow-glow: 0 0 0 3px rgba(37,99,235,.18);

  --grad-primary: linear-gradient(135deg,#2563eb 0%,#4f46e5 100%);
  --grad-green:   linear-gradient(135deg,#059669 0%,#0d9488 100%);
  --grad-hero:    linear-gradient(160deg,#1e3a8a 0%,#1e40af 55%,#2563eb 100%);
  --grad-card:    linear-gradient(135deg,#eff6ff 0%,#f5f3ff 100%);

  --t:           all .2s cubic-bezier(.4,0,.2,1);
}

/* ───── BASE ───── */
html{scroll-behavior:smooth}
body{
  font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  color:var(--text);background:var(--bg);line-height:1.65;
  font-size:16px;-webkit-font-smoothing:antialiased
}
[dir="rtl"]{font-family:"Inter","Segoe UI",Tahoma,Arial,sans-serif}

/* ───── SCROLLBAR ───── */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg-subtle)}
::-webkit-scrollbar-thumb{background:var(--blue-mid);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--blue)}

/* ═══════════════════════════════════════════════
   LANG BAR
═══════════════════════════════════════════════ */
.lang-bar{
  background:var(--bg-subtle);border-bottom:1px solid var(--border);
  padding:5px 24px;display:flex;justify-content:flex-end;gap:3px;flex-wrap:wrap
}
.lang-btn{
  background:none;border:1px solid transparent;border-radius:6px;
  padding:3px 10px;cursor:pointer;font-size:11px;font-weight:600;
  color:var(--muted);transition:var(--t);letter-spacing:.5px;
  text-transform:uppercase;font-family:inherit
}
.lang-btn:hover,.lang-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}

/* ═══════════════════════════════════════════════
   NAVIGATION
═══════════════════════════════════════════════ */
nav{
  background:#fff;border-bottom:1px solid var(--border);
  padding:0 32px;display:flex;align-items:center;
  justify-content:space-between;height:64px;
  position:sticky;top:0;z-index:200;
  box-shadow:0 1px 0 var(--border)
}
.nav-logo{
  font-weight:800;font-size:16px;color:var(--blue);text-decoration:none;
  letter-spacing:-.3px;display:flex;align-items:center;gap:7px;
  transition:opacity .15s;flex-shrink:0
}
.nav-logo:hover{opacity:.82}

.nav-links{
  display:flex;gap:2px;list-style:none;align-items:center;height:100%;
  margin:0 auto 0 32px
}
.nav-links>li{position:relative;height:100%;display:flex;align-items:center}
.nav-links>li>a{
  color:var(--text-2);text-decoration:none;font-size:14px;font-weight:500;
  padding:0 12px;height:100%;display:flex;align-items:center;gap:4px;
  transition:color .15s;white-space:nowrap
}
.nav-links>li>a:hover{color:var(--blue)}
.nav-links>li>a.active{color:var(--blue);font-weight:600}
.nav-links>li>a.has-dropdown::after{
  content:"";display:inline-block;width:0;height:0;
  border-left:4px solid transparent;border-right:4px solid transparent;
  border-top:4px solid currentColor;margin-top:1px;transition:transform .2s;opacity:.5
}
.nav-links>li:hover>a.has-dropdown::after{transform:rotate(180deg)}

.nav-dropdown{
  display:none;position:absolute;top:calc(100% + 4px);left:0;
  background:#fff;border:1px solid var(--border);border-radius:14px;
  box-shadow:0 16px 48px rgba(15,23,42,.12),0 3px 10px rgba(15,23,42,.06);
  min-width:210px;padding:8px;z-index:300;
  animation:dropIn .16s cubic-bezier(.4,0,.2,1)
}
@keyframes dropIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.nav-links>li:hover .nav-dropdown{display:block}
.nav-dropdown a{
  display:flex;align-items:center;gap:8px;padding:9px 12px;font-size:14px;
  color:var(--text-2);text-decoration:none;transition:background .12s,color .12s;border-radius:8px
}
.nav-dropdown a:hover{background:var(--bg-subtle);color:var(--blue)}
.nav-dropdown .dropdown-divider{height:1px;background:var(--border);margin:5px 0}

/* Nav right-side CTA */
.nav-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-cta-btn{
  background:var(--blue);color:#fff;padding:8px 18px;border-radius:9px;
  font-size:13px;font-weight:700;text-decoration:none;transition:var(--t);
  letter-spacing:-.1px;white-space:nowrap
}
.nav-cta-btn:hover{background:var(--blue-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}

/* Mobile nav button */
.nav-mobile-btn{
  display:none;background:none;border:none;cursor:pointer;padding:8px;
  color:var(--text);font-size:22px;line-height:1;border-radius:8px;transition:background .15s
}
.nav-mobile-btn:hover{background:var(--bg-subtle)}

.nav-mobile-open .nav-links{
  display:flex;flex-direction:column;align-items:flex-start;gap:0;
  position:fixed;top:64px;left:0;right:0;background:#fff;
  border-bottom:1px solid var(--border);padding:12px 0 20px;
  z-index:199;box-shadow:0 16px 40px rgba(15,23,42,.10);height:auto
}
.nav-mobile-open .nav-links>li{height:auto;width:100%}
.nav-mobile-open .nav-links>li>a{padding:10px 24px}
.nav-mobile-open .nav-dropdown{position:static;box-shadow:none;border:none;padding:0 0 0 16px;border-radius:0;animation:none}
.nav-mobile-open .nav-links>li:hover .nav-dropdown,
.nav-mobile-open .nav-links>li.mob-open .nav-dropdown{display:block}

/* ═══════════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════════ */
.cta-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--blue);color:#fff!important;text-decoration:none;
  padding:12px 24px;border-radius:10px;font-weight:600;font-size:15px;
  transition:var(--t);cursor:pointer;border:none;
  box-shadow:0 1px 3px rgba(37,99,235,.25);font-family:inherit;letter-spacing:-.1px
}
.cta-btn:hover{background:var(--blue-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(37,99,235,.30)}
.cta-btn:active{transform:translateY(0);box-shadow:none}
.cta-btn.large{padding:15px 32px;font-size:16px;border-radius:11px}
.cta-btn.green{background:var(--green);box-shadow:0 1px 3px rgba(5,150,105,.25)}
.cta-btn.green:hover{background:var(--green-dark);box-shadow:0 4px 16px rgba(5,150,105,.30)}
.cta-btn.outline{
  background:transparent;border:1.5px solid rgba(255,255,255,.5);
  color:#fff!important;box-shadow:none
}
.cta-btn.outline:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.8)}
.cta-btn.outline-dark{
  background:transparent;border:1.5px solid var(--border);
  color:var(--text-2)!important;box-shadow:none
}
.cta-btn.outline-dark:hover{border-color:var(--blue);color:var(--blue)!important;background:var(--blue-light)}
.cta-btn.ghost{
  background:transparent;color:var(--blue)!important;box-shadow:none;border:1.5px solid var(--blue-mid)
}
.cta-btn.ghost:hover{background:var(--blue-light);border-color:var(--blue)}

/* Legacy .btn compat */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:11px 22px;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;border:none;transition:var(--t);width:100%;font-family:inherit}
.btn-p{background:var(--blue);color:#fff;box-shadow:0 1px 3px rgba(37,99,235,.25)}
.btn-p:hover{background:var(--blue-dark);transform:translateY(-1px);box-shadow:0 4px 14px rgba(37,99,235,.30)}
.btn-p:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}
.btn-s{background:var(--bg-subtle);color:var(--blue);border:1.5px solid var(--border);margin-top:8px}
.btn-s:hover{border-color:var(--blue);background:var(--blue-light)}
.btn-group{display:flex;gap:12px;align-items:center;justify-content:center;flex-wrap:wrap}

/* ═══════════════════════════════════════════════
   LAYOUT UTILS
═══════════════════════════════════════════════ */
.container{max-width:1100px;margin:0 auto;padding:0 28px}

/* ═══════════════════════════════════════════════
   TYPOGRAPHY ACCENT
═══════════════════════════════════════════════ */
.grad-text{
  background:var(--grad-primary);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text
}
.section-label{
  display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--blue);background:var(--blue-light);
  padding:4px 12px;border-radius:20px;margin-bottom:12px
}
.section-title{
  font-size:clamp(22px,3vw,34px);font-weight:800;margin-bottom:10px;
  text-align:center;letter-spacing:-.4px;color:var(--text)
}
.section-sub{
  color:var(--muted);text-align:center;font-size:16px;
  max-width:540px;margin:0 auto;line-height:1.65
}
.section-hdr{text-align:center;margin-bottom:48px}

/* ═══════════════════════════════════════════════
   HERO — LIGHT SPLIT LAYOUT
═══════════════════════════════════════════════ */
.hero{
  background:linear-gradient(160deg,#f8fafc 0%,#eff6ff 55%,#f0fdf4 100%);
  padding:80px 28px 72px;
  position:relative;
  overflow:hidden
}
/* subtle geometric accent */
.hero::before{
  content:"";position:absolute;top:-120px;right:-80px;
  width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(37,99,235,.07) 0%,transparent 70%);
  pointer-events:none
}
.hero::after{
  content:"";position:absolute;bottom:-80px;left:-60px;
  width:320px;height:320px;border-radius:50%;
  background:radial-gradient(circle,rgba(79,70,229,.06) 0%,transparent 70%);
  pointer-events:none
}
/* dot grid */
.hero-dots{
  position:absolute;inset:0;
  background-image:radial-gradient(rgba(37,99,235,.06) 1px,transparent 1px);
  background-size:28px 28px;pointer-events:none
}

/* Split layout inside hero */
.hero-split-layout{
  display:grid;
  grid-template-columns:1fr 380px;
  gap:52px;
  max-width:1060px;
  margin:0 auto;
  align-items:center;
  position:relative;z-index:2
}

/* Left column */
.hero-left{text-align:left}
.hero-badge{
  display:inline-flex;align-items:center;gap:7px;
  background:#fff;border:1px solid var(--blue-mid);
  color:var(--blue);font-size:12px;font-weight:600;
  padding:5px 14px;border-radius:20px;margin-bottom:24px;
  letter-spacing:.2px;box-shadow:var(--shadow-xs)
}
.hero-badge::before{content:"🇩🇪";font-size:14px}

.hero-left h1{
  font-size:clamp(32px,5vw,54px);font-weight:800;line-height:1.1;
  letter-spacing:-.7px;color:var(--text);margin-bottom:18px
}
.hero-left p{
  font-size:clamp(15px,1.8vw,17px);color:var(--muted);
  max-width:500px;margin-bottom:32px;line-height:1.7
}
.hero-disclaimer{
  margin-top:20px;font-size:12px;color:var(--muted);
  max-width:480px;line-height:1.6;
  padding:10px 14px;background:rgba(37,99,235,.05);
  border-left:3px solid var(--blue-mid);border-radius:0 8px 8px 0
}

/* ── Hero product mockup (right column) ─────────────────────── */
.hero-mockup{
  background:#fff;border:1px solid var(--border);
  border-radius:20px;overflow:hidden;
  box-shadow:0 12px 48px rgba(37,99,235,.10),0 3px 12px rgba(0,0,0,.06);
  user-select:none;flex-shrink:0;
  transition:box-shadow .25s
}
.hero-mockup:hover{
  box-shadow:0 16px 56px rgba(37,99,235,.13),0 4px 16px rgba(0,0,0,.07)
}

/* browser chrome */
.hmock-chrome{
  background:var(--bg-subtle);border-bottom:1px solid var(--border);
  padding:10px 14px;display:flex;align-items:center;gap:7px
}
.hmock-dot{
  width:10px;height:10px;border-radius:50%;flex-shrink:0
}
.hmock-dot-r{background:#fc5c57}
.hmock-dot-y{background:#fdbc2c}
.hmock-dot-g{background:#34c749}
.hmock-chrome-url{
  flex:1;background:#fff;border:1px solid var(--border);
  border-radius:6px;padding:3px 10px;
  font-size:11px;color:var(--muted);font-family:ui-monospace,monospace;
  overflow:hidden;white-space:nowrap;text-overflow:ellipsis
}

/* document selector pills */
.hmock-pills{
  display:flex;gap:6px;padding:12px 14px 10px;
  overflow:hidden
}
.hmock-pill{
  background:var(--bg-subtle);border:1px solid var(--border);
  border-radius:20px;padding:4px 11px;font-size:11px;font-weight:600;
  color:var(--text-2);white-space:nowrap;flex-shrink:0
}
.hmock-pill-active{
  background:var(--blue-light);border-color:var(--blue-mid);color:var(--blue)
}

/* 2-col body */
.hmock-body{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 14px 10px
}

/* section card */
.hmock-section{
  background:var(--bg-subtle);border:1px solid var(--border);
  border-radius:12px;padding:11px 10px
}
.hmock-section-label{
  display:flex;align-items:center;gap:5px;
  font-size:10px;font-weight:700;color:var(--text-2);
  text-transform:uppercase;letter-spacing:.5px;margin-bottom:9px
}
.hmock-s-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.hmock-s-blue{background:var(--blue)}
.hmock-s-indigo{background:var(--indigo)}

/* fake form fields */
.hmock-fields{display:flex;flex-direction:column;gap:7px}
.hmock-frow{display:flex;flex-direction:column;gap:3px}
.hmock-flbl{height:5px;background:var(--border);border-radius:3px;width:55%}
.hmock-finp{
  height:19px;background:#fff;border:1px solid var(--border);border-radius:5px
}
.hmock-finp.valid{border-color:var(--green);background:var(--green-light)}
.hmock-frow2{display:flex;gap:6px}
.hmock-frow2 .hmock-finp{flex:1}

/* PDF preview sheet */
.hmock-pdf-sheet{display:flex;flex-direction:column;gap:5px;margin-top:2px}
.hmock-pline{height:5px;background:var(--border);border-radius:3px}
.hmock-pline.w-full{width:100%}
.hmock-pline.w-3q{width:75%}
.hmock-pline.w-half{width:50%}
.hmock-pdf-dl{
  background:var(--indigo);color:#fff;
  font-size:10px;font-weight:700;padding:5px 8px;border-radius:6px;
  text-align:center;margin-top:5px;letter-spacing:.2px
}

/* Termin status strip */
.hmock-termin{
  margin:0 14px 12px;
  background:var(--green-light);border:1px solid #a7f3d0;
  border-radius:10px;padding:8px 12px;
  display:flex;align-items:center;gap:8px;
  font-size:12px;font-weight:600;color:var(--green-dark)
}
.hmock-pulse{
  width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0;
  box-shadow:0 0 0 3px rgba(5,150,105,.2);
  animation:hmock-pulse 2s ease-in-out infinite
}
@keyframes hmock-pulse{
  0%,100%{box-shadow:0 0 0 3px rgba(5,150,105,.20)}
  50%{box-shadow:0 0 0 5px rgba(5,150,105,.10)}
}
.hmock-termin-city{flex:1;font-size:12px;font-weight:600;color:var(--green-dark)}
.hmock-live{
  font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;
  background:var(--green);color:#fff;padding:2px 7px;border-radius:10px
}

/* Language flags row */
.hmock-langs{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 16px 14px;border-top:1px solid var(--border)
}
.hmock-langs span{
  font-size:18px;opacity:.8;transition:opacity .15s,transform .15s;cursor:default
}
.hmock-langs span:hover{opacity:1;transform:scale(1.15)}

/* Hero centered fallback */
.hero.hero-centered{padding:88px 28px 72px}
.hero.hero-centered .hero-inner{position:relative;z-index:2;text-align:center;max-width:700px;margin:0 auto}

/* ═══════════════════════════════════════════════
   PAGE HERO (inner pages)
═══════════════════════════════════════════════ */
.page-hero{
  background:var(--grad-hero);padding:64px 28px 52px;
  text-align:center;position:relative;overflow:hidden
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 50% 50%,rgba(96,165,250,.12) 0%,transparent 70%);
  pointer-events:none
}
.page-hero::after{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:28px 28px;pointer-events:none
}
.page-hero h1{
  position:relative;z-index:1;font-size:clamp(24px,3.8vw,40px);
  font-weight:800;margin-bottom:12px;color:#fff;letter-spacing:-.4px
}
.page-hero p{
  position:relative;z-index:1;font-size:17px;color:rgba(255,255,255,.7);
  max-width:540px;margin:0 auto 24px
}
.page-hero .cta-btn{position:relative;z-index:1}
.page-hero.termin-hero{background:linear-gradient(160deg,#022c22 0%,#065f46 55%,#059669 100%)}

/* ═══════════════════════════════════════════════
   SECTIONS
═══════════════════════════════════════════════ */
section{padding:72px 28px}
section.alt-bg{background:var(--bg-subtle)}
section.section-compact{padding:40px 28px}

/* ═══════════════════════════════════════════════
   BENTO GRID — ASYMMETRIC
═══════════════════════════════════════════════ */
.bento-asymm{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  grid-template-rows:220px 200px;
  gap:16px;
  max-width:960px;
  margin:0 auto
}
.bento-card{
  background:#fff;border:1px solid var(--border);
  border-radius:20px;padding:28px 26px;
  box-shadow:var(--shadow);
  transition:transform .22s,box-shadow .22s,border-color .22s;
  display:flex;flex-direction:column;gap:14px;
  position:relative;overflow:hidden
}
.bento-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--blue-mid)}
/* Card 1: col 1, rows 1–2 (tall) */
.bento-card-1{grid-column:1;grid-row:1/3}
/* Card 2: col 2, row 1 */
.bento-card-2{grid-column:2;grid-row:1}
/* Card 3: col 3, row 1 */
.bento-card-3{grid-column:3;grid-row:1}
/* Card 4: cols 2–3, row 2 (wide) */
.bento-card-4{grid-column:2/4;grid-row:2;flex-direction:row;align-items:center;gap:24px}

.bento-icon{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;font-size:24px;
  flex-shrink:0
}
.bento-icon-blue{background:var(--blue-light)}
.bento-icon-green{background:var(--green-light)}
.bento-icon-indigo{background:var(--indigo-light)}
.bento-icon-amber{background:var(--amber-light)}

.bento-card h3{font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.2px}
.bento-card p{font-size:14px;color:var(--muted);line-height:1.6;flex:1}
.bento-card-1 h3{font-size:20px}
.bento-card-4 .bento-text{flex:1}
.bento-badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:600;color:var(--blue);
  background:var(--blue-light);padding:4px 10px;border-radius:16px;
  margin-top:auto;align-self:flex-start
}
.bento-badge-green{color:var(--green);background:var(--green-light)}

/* ═══════════════════════════════════════════════
   STEPS — NUMBERED HORIZONTAL
═══════════════════════════════════════════════ */
.steps-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  max-width:900px;
  margin:0 auto;
  position:relative
}
.steps-row::before{
  content:"";position:absolute;
  top:32px;left:12%;right:12%;height:2px;
  background:linear-gradient(90deg,var(--blue-mid),var(--indigo-light));
  z-index:0
}
.step-item{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;padding:0 16px;position:relative;z-index:1
}
.step-number{
  width:64px;height:64px;border-radius:50%;
  background:#fff;border:2px solid var(--blue-mid);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;font-weight:800;color:var(--blue);
  margin-bottom:18px;
  box-shadow:0 0 0 6px var(--bg-subtle);
  transition:var(--t);position:relative
}
.step-item:hover .step-number{
  background:var(--blue);color:#fff;border-color:var(--blue);
  box-shadow:0 0 0 6px var(--blue-light)
}
.step-item--green .step-number{color:var(--green);border-color:#a7f3d0}
.step-item--green:hover .step-number{background:var(--green);color:#fff;border-color:var(--green)}
.step-emoji{position:absolute;top:-10px;right:-8px;font-size:18px}
.step-item h3{font-size:14px;font-weight:700;margin-bottom:6px;color:var(--text)}
.step-item p{font-size:13px;color:var(--muted);line-height:1.5}

/* Legacy .step (document pages) */
.steps{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:16px;max-width:960px;margin:0 auto
}
.step{
  background:#fff;border:1px solid var(--border);border-radius:16px;
  padding:28px 22px 24px;text-align:center;box-shadow:var(--shadow);
  transition:transform .2s,box-shadow .2s,border-color .2s
}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--blue-mid)}
.step--green:hover{border-color:#a7f3d0}
.step-icon{font-size:30px;margin-bottom:14px;line-height:1}
.step-num{
  width:40px;height:40px;background:var(--blue);color:#fff;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:17px;margin:0 auto 14px;
  box-shadow:0 2px 8px rgba(37,99,235,.25)
}
.step-num--green{background:var(--green);box-shadow:0 2px 8px rgba(5,150,105,.25)}
.step h3{font-size:14px;font-weight:700;margin-bottom:7px;color:var(--text)}
.step p{font-size:13px;color:var(--muted);line-height:1.55}

/* How tabs */
.how-tabs{
  display:flex;gap:6px;justify-content:center;background:var(--bg-subtle);
  padding:5px;border-radius:12px;max-width:360px;margin:0 auto 32px;
  border:1px solid var(--border)
}
.how-tab{
  flex:1;background:none;border:none;padding:9px 18px;font-size:14px;
  font-weight:600;color:var(--muted);border-radius:8px;cursor:pointer;
  transition:var(--t);font-family:inherit
}
.how-tab.active{background:#fff;color:var(--blue);box-shadow:var(--shadow)}
.how-panel{display:none}
.how-panel.active{display:block}
.how-panel-cta{text-align:center;margin-top:24px}
.how-panel-cta a{
  font-size:14px;font-weight:600;color:var(--blue);text-decoration:none;
  display:inline-flex;align-items:center;gap:6px;transition:gap .2s
}
.how-panel-cta a:hover{gap:10px}

/* ═══════════════════════════════════════════════
   STATS BAR
═══════════════════════════════════════════════ */
.stats-bar{
  display:flex;justify-content:center;gap:0;flex-wrap:wrap;
  background:var(--blue);position:relative;overflow:hidden
}
.stats-bar::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:20px 20px
}
.stat-item{
  text-align:center;padding:28px 44px;position:relative;z-index:1;
  flex:1;min-width:130px
}
.stat-item+.stat-item::before{
  content:"";position:absolute;left:0;top:20%;bottom:20%;
  width:1px;background:rgba(255,255,255,.15)
}
.stat-item strong{display:block;font-size:30px;font-weight:800;color:#fff;letter-spacing:-.4px;line-height:1.1}
.stat-item span{font-size:13px;color:rgba(255,255,255,.65);letter-spacing:.1px}

/* ═══════════════════════════════════════════════
   DOCS GRID
═══════════════════════════════════════════════ */
.docs-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:12px;max-width:980px;margin:0 auto 36px
}
.doc-card{
  background:#fff;border:1px solid var(--border);border-radius:14px;
  padding:22px 14px 18px;text-align:center;text-decoration:none;color:var(--text);
  transition:transform .2s,box-shadow .2s,border-color .2s,background .15s;
  display:flex;flex-direction:column;align-items:center;gap:7px;
  box-shadow:var(--shadow)
}
.doc-card:hover{border-color:var(--blue);box-shadow:var(--shadow-md);transform:translateY(-3px);background:var(--blue-light)}
.doc-card .doc-icon{font-size:28px;line-height:1}
.doc-card h3{font-size:13px;font-weight:700}
.doc-card p{font-size:12px;color:var(--muted)}
.doc-card .doc-cta{margin-top:4px;font-size:11px;font-weight:600;color:var(--blue);opacity:0;transition:opacity .15s}
.doc-card:hover .doc-cta{opacity:1}

/* ═══════════════════════════════════════════════
   PRODUCT SPLIT (used on some pages)
═══════════════════════════════════════════════ */
.product-split{
  display:grid;grid-template-columns:1fr 1fr;
  gap:20px;max-width:840px;margin:0 auto
}
.product-card{
  background:#fff;border-radius:18px;padding:32px 28px;
  border:1px solid var(--border);box-shadow:var(--shadow);
  transition:transform .2s,box-shadow .2s,border-color .2s;
  position:relative;overflow:hidden;display:flex;flex-direction:column;gap:0
}
.product-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--blue);border-radius:18px 18px 0 0
}
.product-card--termin::before{background:var(--green)}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--blue-mid)}
.product-card--termin:hover{border-color:#a7f3d0}
.product-card-badge{
  position:absolute;top:14px;right:14px;background:var(--green);color:#fff;
  font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;letter-spacing:.3px
}
.product-card-icon{
  font-size:36px;line-height:1;margin-bottom:16px;
  display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;background:var(--blue-light);border-radius:14px
}
.product-card--termin .product-card-icon{background:var(--green-light)}
.product-card h3{font-size:20px;font-weight:800;margin-bottom:8px;color:var(--text);letter-spacing:-.3px}
.product-card>p{font-size:14px;color:var(--muted);margin-bottom:16px;line-height:1.6}
.product-card-price{
  font-size:14px;font-weight:700;color:var(--blue);margin-bottom:18px;
  padding:7px 12px;background:var(--blue-light);border-radius:8px;display:inline-block
}
.product-card--termin .product-card-price{color:var(--green);background:var(--green-light)}
.product-card-features{list-style:none;padding:0;margin:0 0 24px;display:flex;flex-direction:column;gap:9px;flex:1}
.product-card-features li{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text-2)}
.product-card-features li::before{
  content:"✓";color:#fff;background:var(--blue);width:18px;height:18px;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:9px;font-weight:800;flex-shrink:0
}
.product-card--termin .product-card-features li::before{background:var(--green)}

/* ═══════════════════════════════════════════════
   WHY / FEATURES
═══════════════════════════════════════════════ */
.why-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:16px;max-width:960px;margin:0 auto
}
.why-card{
  background:#fff;border:1px solid var(--border);border-radius:16px;
  padding:26px 22px;display:flex;gap:14px;align-items:flex-start;
  box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s,border-color .2s
}
.why-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--blue-mid)}
.why-icon{
  font-size:22px;line-height:1;flex-shrink:0;padding:10px;
  background:var(--blue-light);border-radius:10px;display:flex;align-items:center
}
.why-card h3{font-size:14px;font-weight:700;margin-bottom:5px}
.why-card p{font-size:13px;color:var(--muted);line-height:1.55}

/* ═══════════════════════════════════════════════
   TRUST / DISCLAIMER BLOCK
═══════════════════════════════════════════════ */
.trust-block{
  background:var(--bg-subtle);border:1px solid var(--border);
  border-radius:20px;padding:36px;max-width:860px;margin:0 auto
}
.trust-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:20px;margin-top:20px
}
.trust-item{
  display:flex;align-items:flex-start;gap:12px;
  font-size:14px;color:var(--text-2);line-height:1.55
}
.trust-item-icon{
  font-size:20px;flex-shrink:0;width:40px;height:40px;
  background:#fff;border:1px solid var(--border);border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-xs)
}
.trust-title{font-size:14px;font-weight:700;margin-bottom:2px;color:var(--text)}

/* Trust notices — disc-row */
.disc-row{
  display:flex;flex-wrap:wrap;gap:16px;
  justify-content:center;max-width:900px;margin:0 auto
}
.trust-notice{
  flex:1;min-width:240px;background:#fff;border:1px solid var(--border);
  border-radius:12px;padding:20px 18px;display:flex;align-items:flex-start;
  gap:12px;box-shadow:var(--shadow);font-size:14px;color:var(--text-2);line-height:1.55
}
.trust-notice-icon{
  font-size:22px;flex-shrink:0;line-height:1;padding:8px;
  background:var(--blue-light);border-radius:9px
}

/* ═══════════════════════════════════════════════
   CONTENT CARD (legal pages)
═══════════════════════════════════════════════ */
.content-card{
  background:#fff;border:1px solid var(--border);border-radius:18px;
  padding:44px 48px;max-width:820px;margin:0 auto;box-shadow:var(--shadow)
}
.content-card h2{
  font-size:20px;font-weight:700;margin:32px 0 12px;color:var(--text);
  display:flex;align-items:center;gap:10px
}
.content-card h2:first-child{margin-top:0}
.content-card p,.content-card li{color:var(--text-2);line-height:1.75;margin-bottom:10px;font-size:15px}
.content-card ul,.content-card ol{padding-left:22px;margin-bottom:16px}
.content-card li{margin-bottom:7px}
.content-card .warning{
  background:var(--amber-light);border-left:4px solid var(--amber);
  padding:14px 18px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  margin:18px 0;font-size:14px;line-height:1.65
}
[dir="rtl"] .content-card .warning{border-left:none;border-right:4px solid var(--amber)}

/* ═══════════════════════════════════════════════
   FAQ  — MODERN ACCORDION
═══════════════════════════════════════════════ */
.faq-list{max-width:820px;margin:0 auto}
.faq-item{
  border:1px solid var(--border);border-radius:14px;margin-bottom:8px;
  overflow:hidden;background:#fff;transition:border-color .2s,box-shadow .2s
}
.faq-item:hover{border-color:var(--blue-mid);box-shadow:var(--shadow)}
.faq-q{
  width:100%;background:transparent;border:none;padding:18px 22px;
  text-align:left;font-size:15px;font-weight:600;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  transition:background .15s;font-family:inherit;color:var(--text);line-height:1.4
}
.faq-q:hover{background:var(--bg-subtle)}
[dir="rtl"] .faq-q{text-align:right}
.faq-q-icon{
  width:28px;height:28px;border-radius:50%;background:var(--blue-light);
  color:var(--blue);display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:400;flex-shrink:0;transition:transform .25s,background .2s
}
.faq-q.open .faq-q-icon{transform:rotate(45deg);background:var(--blue);color:#fff}
.faq-a{
  display:none;padding:0 22px 18px;font-size:14px;color:var(--text-2);line-height:1.7;
  animation:fadeIn .2s ease
}
.faq-a.open{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
/* fallback for old faq-q::after usage */
.faq-q::after{display:none}

/* ═══════════════════════════════════════════════
   CTA BANNER
═══════════════════════════════════════════════ */
.cta-banner{
  background:var(--grad-hero);color:#fff;padding:72px 28px;
  text-align:center;position:relative;overflow:hidden
}
.cta-banner::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:24px 24px;pointer-events:none
}
.cta-banner::after{
  content:"";position:absolute;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(96,165,250,.12) 0%,transparent 70%);
  top:-100px;right:-60px;pointer-events:none
}
.cta-banner h2{
  position:relative;z-index:1;font-size:clamp(22px,3.2vw,36px);
  font-weight:800;margin-bottom:12px;letter-spacing:-.4px
}
.cta-banner p{position:relative;z-index:1;opacity:.78;margin-bottom:30px;font-size:17px}
.cta-banner .cta-btn{
  position:relative;z-index:1;background:#fff;color:var(--blue)!important;
  font-weight:700;box-shadow:0 4px 18px rgba(0,0,0,.18)
}
.cta-banner .cta-btn:hover{background:var(--blue-light);box-shadow:0 8px 28px rgba(0,0,0,.22)}
.cta-banner .cta-btn.outline{background:transparent;border:1.5px solid rgba(255,255,255,.4);color:#fff!important;box-shadow:none}
.cta-banner .cta-btn.outline:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.7)}
.cta-banner .btn-group{position:relative;z-index:1}
.cta-banner-disclaimer{
  position:relative;z-index:1;margin-top:18px;
  font-size:12px;color:rgba(255,255,255,.4);max-width:540px;margin-left:auto;margin-right:auto
}

/* ═══════════════════════════════════════════════
   PRICING  — MODERN CARDS
═══════════════════════════════════════════════ */
.pricing-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:20px;max-width:860px;margin:0 auto 28px
}
.pricing-grid--4{max-width:1060px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.pricing-card{
  background:#fff;border:1px solid var(--border);border-radius:20px;
  padding:30px 24px;text-align:center;transition:transform .2s,box-shadow .2s,border-color .2s;
  position:relative;overflow:hidden;box-shadow:var(--shadow);
  display:flex;flex-direction:column
}
.pricing-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--blue)
}
.pricing-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--blue-mid)}
/* Featured card */
.pricing-card.featured{
  border-color:var(--blue);
  box-shadow:0 0 0 2px rgba(37,99,235,.15),var(--shadow-md);
  background:linear-gradient(180deg,var(--blue-light) 0%,#fff 100%)
}
.pricing-card.featured::before{background:var(--grad-primary)}
.pricing-card.featured:hover{box-shadow:0 0 0 2px rgba(37,99,235,.2),var(--shadow-lg)}
.pricing-badge{
  position:absolute;top:14px;right:14px;background:var(--blue);color:#fff;
  font-size:10px;font-weight:700;padding:3px 9px;border-radius:16px;
  letter-spacing:.3px;text-transform:uppercase
}
.pricing-badge--best{background:linear-gradient(135deg,#059669,#0d9488)}
.pricing-badge--alt{background:var(--muted)}
.pricing-icon{font-size:34px;margin-bottom:12px;line-height:1}
.pricing-card h3{font-size:18px;font-weight:800;margin-bottom:7px;color:var(--text)}
.pricing-card .pricing-desc{font-size:13px;color:var(--muted);margin-bottom:18px;line-height:1.55;flex:0 0 auto;min-height:38px}
.pricing-amount{font-size:38px;font-weight:800;color:var(--blue);line-height:1;margin-bottom:3px}
.pricing-amount sup{font-size:18px;vertical-align:super;font-weight:700}
.pricing-note{font-size:12px;color:var(--muted);margin-bottom:20px}
.pricing-features{list-style:none;padding:0;text-align:left;margin-bottom:20px}
.pricing-features li{
  font-size:13px;color:var(--text-2);padding:6px 0;
  display:flex;align-items:center;gap:9px;
  border-bottom:1px solid var(--bg-subtle)
}
.pricing-features li:last-child{border-bottom:none}
.pricing-features li::before{
  content:"✓";color:#fff;background:var(--green);width:17px;height:17px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;flex-shrink:0
}
.pricing-cta{margin-top:auto;display:flex;justify-content:center}
.pricing-disclaimer{
  text-align:center;font-size:12px;color:var(--muted);
  max-width:540px;margin:0 auto;padding-top:8px;line-height:1.6
}

/* ═══════════════════════════════════════════════
   FEATURES GRID
═══════════════════════════════════════════════ */
.features-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:16px;max-width:1000px;margin:0 auto
}
.feature-card{
  background:#fff;border:1px solid var(--border);border-radius:14px;
  padding:24px 20px;display:flex;gap:14px;align-items:flex-start;
  transition:transform .2s,box-shadow .2s,border-color .2s;box-shadow:var(--shadow)
}
.feature-card:hover{border-color:var(--blue-mid);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.feature-icon{
  font-size:22px;line-height:1;flex-shrink:0;padding:9px;
  background:var(--blue-light);border-radius:10px;display:flex;align-items:center
}
.feature-card h3{font-size:14px;font-weight:700;margin-bottom:4px;color:var(--text)}
.feature-card p{font-size:13px;color:var(--muted);line-height:1.55}

/* ═══════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════ */
footer{background:#0c1526;color:#94a3b8;padding:52px 28px 32px;font-size:13px}
.footer-inner{
  max-width:1100px;margin:0 auto;display:grid;
  grid-template-columns:1fr 2fr;gap:44px;
  padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:24px
}
.footer-brand .nav-logo{font-size:15px;color:#e2e8f0;margin-bottom:10px;display:inline-flex}
.footer-brand p{font-size:13px;color:#475569;line-height:1.65;max-width:240px}
.footer-nav-group{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.footer-col h4{color:#e2e8f0;font-size:11px;font-weight:700;margin-bottom:12px;text-transform:uppercase;letter-spacing:1px}
.footer-col a{display:block;color:#475569;text-decoration:none;margin-bottom:9px;font-size:13px;transition:color .15s}
.footer-col a:hover{color:#e2e8f0}
.footer-bottom{
  max-width:1100px;margin:0 auto;display:flex;
  justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px
}
.footer-links{display:flex;gap:18px;flex-wrap:wrap}
.footer-links a{color:#475569;text-decoration:none;transition:color .15s}
.footer-links a:hover{color:#e2e8f0}
.footer-disclaimer{
  color:#334155;font-size:12px;text-align:center;padding-top:14px;
  max-width:680px;margin:0 auto;line-height:1.6;
  border-top:1px solid rgba(255,255,255,.04);margin-top:14px
}

/* ═══════════════════════════════════════════════
   PRODUCT SECTIONS (termin.html etc.)
═══════════════════════════════════════════════ */
.product-section{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:20px 0}
.product-block{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);padding:22px}
.product-block h3{font-size:15px;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.product-block p{font-size:14px;color:var(--muted);line-height:1.6}
.product-block.highlight{background:var(--blue-light);border-color:var(--blue-mid)}
.price-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin:18px 0}
.price-card{
  border:1px solid var(--border);border-radius:14px;padding:22px 18px;
  text-align:center;transition:var(--t);background:#fff;box-shadow:var(--shadow)
}
.price-card:hover{border-color:var(--blue);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.price-card.featured{border-color:var(--blue);background:var(--blue-light)}
.price-card .price-label{font-size:13px;color:var(--muted);margin-bottom:6px}
.price-card .price-amount{font-size:28px;font-weight:800;color:var(--blue);margin-bottom:4px}
.price-card p{font-size:13px;color:var(--muted);margin-top:8px}

/* ═══════════════════════════════════════════════
   DOCUMENT FORM PAGE SUPPORT CLASSES
═══════════════════════════════════════════════ */
.pf-layout{display:grid;grid-template-columns:1fr 320px;gap:28px;max-width:1060px;margin:0 auto;align-items:start}
.doc-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.doc-pill{
  background:var(--bg-subtle);border:1px solid var(--border);border-radius:9px;
  padding:7px 13px;cursor:pointer;font-size:13px;font-weight:600;color:var(--text-2);
  display:flex;align-items:center;gap:6px;transition:var(--t);white-space:nowrap
}
.doc-pill:hover{border-color:var(--blue);color:var(--blue)}
.doc-pill.active{border-color:var(--blue);background:var(--blue-light);color:var(--blue);box-shadow:0 0 0 2px rgba(37,99,235,.1)}
.lang-pill{
  background:var(--bg-subtle);border:1px solid var(--border);border-radius:7px;
  padding:5px 11px;cursor:pointer;font-size:12px;font-weight:700;color:var(--muted);transition:var(--t)
}
.lang-pill:hover{border-color:var(--blue);color:var(--blue)}
.lang-pill.active{border-color:var(--blue);background:var(--blue);color:#fff}
.form-section{margin-bottom:26px}
.form-section-title{
  font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;
  letter-spacing:.6px;margin-bottom:12px;padding-bottom:7px;
  border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px
}
.form-section-title::before{content:"";display:inline-block;width:3px;height:14px;background:var(--blue);border-radius:2px}
.fi-group{margin-bottom:13px}
.fi-label{display:block;font-size:12px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.4px;margin-bottom:5px}
.fi-label .req{color:var(--blue);margin-left:2px}
.fi-input,.fi-select,.fi-textarea{
  width:100%;padding:10px 13px;border:1px solid var(--border);border-radius:9px;
  font-size:14px;color:var(--text);background:#fff;transition:border-color .15s,box-shadow .15s;
  outline:none;font-family:inherit;box-sizing:border-box
}
.fi-input:focus,.fi-select:focus,.fi-textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.fi-input::placeholder{color:#b0bec5}
.fi-input.valid{border-color:var(--green);background:#f0fdf4}
.fi-input.error{border-color:#ef4444;background:#fef2f2}
.fi-hint{font-size:11px;color:var(--muted);margin-top:3px}
.fi-err{font-size:11px;color:#dc2626;margin-top:3px}
.rc-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:22px;box-shadow:var(--shadow-md);position:sticky;top:80px}
.rc-card h3{font-size:13px;font-weight:700;margin-bottom:14px;color:var(--text);display:flex;align-items:center;gap:7px}
.rc-bar-wrap{height:7px;background:#e0e7ff;border-radius:4px;overflow:hidden;margin-bottom:7px}
.rc-bar{height:100%;background:var(--blue);border-radius:4px;transition:width .4s cubic-bezier(.4,0,.2,1)}
.rc-count{font-size:12px;color:var(--muted);margin-bottom:12px;text-align:right}
.rc-list{list-style:none;padding:0;margin:0 0 14px;max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:5px}
.rc-list li{font-size:12px;padding:5px 9px;border-radius:7px;display:flex;align-items:center;gap:7px;color:var(--muted)}
.rc-list li.done{color:var(--text);background:var(--green-light)}
.rc-list li.done::before{content:"✓";color:#fff;background:var(--green);width:15px;height:15px;border-radius:50%;font-size:8px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rc-list li:not(.done)::before{content:"○";color:var(--muted);flex-shrink:0;font-size:10px}
.sub-notice{font-size:12px;color:var(--muted);margin-bottom:10px;text-align:center}
.doc-sel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(135px,1fr));gap:9px}
.doc-sel-btn{background:#fff;border:1px solid var(--border);border-radius:11px;padding:13px 11px;cursor:pointer;font-size:13px;text-align:left;display:flex;flex-direction:column;gap:4px;transition:var(--t);position:relative;font-family:inherit}
.doc-sel-btn:hover{border-color:var(--blue);background:var(--blue-light)}
.doc-sel-btn.active{border-color:var(--blue);background:var(--blue-light);box-shadow:0 0 0 2px rgba(37,99,235,.1)}
.doc-sel-icon{font-size:20px}.doc-sel-name{font-size:12px;font-weight:700;color:var(--text)}.doc-sel-price{font-size:12px;font-weight:700;color:var(--blue)}.doc-sel-sub{font-size:11px;color:var(--muted);line-height:1.3}
.doc-sel-tick{display:none}
.doc-sel-btn.active .doc-sel-tick{display:flex;position:absolute;top:7px;right:7px;width:16px;height:16px;background:var(--blue);color:#fff;border-radius:50%;font-size:9px;font-weight:800;align-items:center;justify-content:center}
.lang-sel-form{display:flex;flex-wrap:wrap;gap:9px}
.lang-sel-btn{background:var(--bg-subtle);border:1px solid var(--border);border-radius:9px;padding:8px 14px;cursor:pointer;font-size:13px;font-weight:600;color:var(--text-2);display:flex;align-items:center;gap:5px;transition:var(--t);font-family:inherit}
.lang-sel-btn:hover{border-color:var(--blue)}
.lang-sel-btn.active{border-color:var(--blue);background:var(--blue-light);color:var(--blue)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form-row:last-child{margin-bottom:0}
.form-row.cols-3{grid-template-columns:2fr 1fr 1fr}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group.full{grid-column:1/-1}
.form-label{font-size:12px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.4px}
.form-label .req{color:var(--blue);margin-left:2px}
.form-input{padding:10px 13px;border:1px solid var(--border);border-radius:9px;font-size:14px;color:var(--text);background:#fff;transition:border-color .15s,box-shadow .15s;outline:none;font-family:inherit;width:100%;box-sizing:border-box}
.form-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.form-input::placeholder{color:#b0bec5}
.doc-form-sidebar{position:sticky;top:72px}
.readiness-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:var(--shadow-md)}
.readiness-card h3{font-size:14px;font-weight:700;color:var(--text);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.readiness-doc-row{display:flex;align-items:center;gap:10px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:16px}
.readiness-doc-icon{font-size:22px;flex-shrink:0}
.readiness-doc-name{font-size:13px;font-weight:700;color:var(--text);line-height:1.2}
.readiness-doc-price{font-size:15px;font-weight:800;color:var(--blue)}
.readiness-list{list-style:none;padding:0;margin:0 0 16px;display:flex;flex-direction:column;gap:5px}
.readiness-list .check-item{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--muted);padding:7px 9px;border-radius:7px;transition:background .15s,color .15s}
.readiness-list .check-item.done{color:var(--text);background:var(--green-light)}
.check-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:9px;font-weight:800;flex-shrink:0;background:#e2e8f0;color:var(--muted);transition:background .15s,color .15s}
.check-item.done .check-icon{background:#22c55e;color:#fff}
.readiness-score-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--muted);margin-bottom:14px;padding:9px 11px;background:var(--bg-subtle);border-radius:7px}
.readiness-score-row .score-val{font-weight:800;color:var(--blue);font-size:14px}
.readiness-actions{display:flex;flex-direction:column;gap:9px;margin-bottom:12px}
.readiness-notice{font-size:12px;color:#92400e;background:var(--amber-light);border:1px solid #fde68a;border-radius:7px;padding:9px 11px;line-height:1.5;text-align:center}
.readiness-notice.success{background:var(--green-light);border-color:#86efac;color:#15803d}

/* ═══════════════════════════════════════════════
   TERMIN SETUP
═══════════════════════════════════════════════ */
.termin-setup-grid{display:grid;grid-template-columns:1fr 310px;gap:32px;max-width:940px;margin:0 auto;align-items:start}
.termin-setup-form{min-width:0}
.setup-block{margin-bottom:20px}
.setup-label{display:block;font-size:12px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.4px;margin-bottom:9px}
.setup-select{width:100%;padding:11px 38px 11px 13px;border:1px solid var(--border);border-radius:10px;font-size:14px;color:var(--text);background:#fff;cursor:pointer;outline:none;font-family:inherit;transition:border-color .15s,box-shadow .15s;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748b' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;box-sizing:border-box}
.setup-select:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(5,150,105,.12)}
.period-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.period-btn{border:1px solid var(--border);border-radius:12px;padding:14px 13px;cursor:pointer;background:#fff;text-align:left;transition:var(--t);display:flex;flex-direction:column;gap:3px;position:relative;box-shadow:var(--shadow);font-family:inherit}
.period-btn span{font-size:12px;color:var(--muted)}
.period-btn strong{font-size:20px;font-weight:800;color:var(--green)}
.period-btn:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.period-btn.active{border-color:var(--green);background:var(--green-light);box-shadow:0 0 0 2px rgba(5,150,105,.1),var(--shadow)}
.period-badge-tag{position:absolute;top:-1px;right:-1px;background:var(--green);color:#fff;font-size:10px;font-weight:700;padding:3px 7px;border-radius:0 11px 0 9px}
.notif-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.notif-btn{border:1px solid var(--border);border-radius:10px;padding:11px 13px;cursor:pointer;background:#fff;font-size:13px;font-weight:600;color:var(--text-2);display:flex;align-items:center;gap:7px;transition:var(--t);font-family:inherit}
.notif-btn:hover{border-color:var(--green)}
.notif-btn.active{border-color:var(--green);background:var(--green-light);color:var(--green-dark)}
.monitoring-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:var(--shadow-md);position:sticky;top:72px}
.monitoring-total{background:var(--green-light);border-radius:9px;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.monitoring-total .label{font-size:13px;color:var(--text-2);font-weight:600}
.monitoring-total .amount{font-size:22px;font-weight:800;color:var(--green)}
.city-card{background:var(--bg-subtle);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:10px;display:flex;align-items:center;gap:12px;font-size:14px;font-weight:600;color:var(--text);transition:var(--t)}
.city-card:hover{border-color:var(--green);transform:translateY(-2px)}
.city-card a{color:inherit;text-decoration:none}
.city-icon{font-size:22px}.city-info{flex:1}.city-name{font-weight:700}.city-status{font-size:12px;color:var(--muted);font-weight:400}
.warning-box{background:var(--amber-light);border-left:3px solid var(--amber);border-radius:0 9px 9px 0;padding:12px 16px;font-size:13px;color:#92400e;margin:16px 0;line-height:1.55}

/* ═══════════════════════════════════════════════
   SCROLL FADE-IN
═══════════════════════════════════════════════ */
.fade-up{opacity:0;transform:translateY(22px);transition:opacity .5s ease,transform .5s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* ═══════════════════════════════════════════════
   WHAT IS SECTION
═══════════════════════════════════════════════ */
.what-is-section{padding:72px 28px;background:#fff}
.what-is-inner{max-width:900px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.what-is-text h2{font-size:clamp(20px,2.8vw,30px);font-weight:800;margin-bottom:14px;letter-spacing:-.3px}
.what-is-text p{font-size:15px;color:var(--text-2);line-height:1.72;margin-bottom:20px}
.what-is-list{list-style:none;padding:0}
.what-is-list li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--text-2);padding:9px 0;border-bottom:1px solid var(--border);line-height:1.55}
.what-is-list li:last-child{border-bottom:none}
.what-is-list li::before{content:"✓";color:var(--green);font-weight:700;flex-shrink:0;margin-top:1px;font-size:15px}
.what-is-cta{background:var(--bg-subtle);border:1px solid var(--border);border-radius:16px;padding:28px 24px;display:flex;flex-direction:column;gap:14px}
.what-is-cta h3{font-size:18px;font-weight:800;margin-bottom:3px}
.what-is-cta p{font-size:14px;color:var(--muted);line-height:1.6}
.tg-badge{display:inline-flex;align-items:center;gap:8px;background:var(--blue);color:#fff;border-radius:10px;padding:12px 20px;font-weight:700;font-size:14px;text-decoration:none;transition:var(--t);box-shadow:var(--shadow)}
.tg-badge:hover{background:var(--blue-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.tg-install-section{background:var(--bg-subtle);border:1px solid var(--border);border-radius:18px;padding:36px;max-width:780px;margin:0 auto;text-align:center}
.tg-install-section h3{font-size:20px;font-weight:800;margin-bottom:7px}
.tg-install-section p{font-size:14px;color:var(--muted);margin-bottom:24px}
.tg-platforms{display:flex;flex-wrap:wrap;justify-content:center;gap:9px;margin-bottom:18px}
.tg-platform-btn{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--border);border-radius:10px;padding:9px 18px;font-size:13px;font-weight:600;color:var(--text-2);text-decoration:none;transition:var(--t);box-shadow:var(--shadow)}
.tg-platform-btn:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-1px);box-shadow:var(--shadow-md)}

/* ═══════════════════════════════════════════════
   HERO STEPS (legacy fallback)
═══════════════════════════════════════════════ */
.hero-steps{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:6px 12px;margin-top:20px;font-size:13px;color:rgba(255,255,255,.5)}
.hero-steps-sep{color:rgba(255,255,255,.2)}
.hero-inner{position:relative;z-index:2}
.hero-badge-dark{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);color:#bfdbfe;font-size:13px;font-weight:500;padding:6px 16px;border-radius:20px;margin-bottom:28px;border:1px solid rgba(191,219,254,.25);backdrop-filter:blur(8px);letter-spacing:.2px}

/* ═══════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════ */
@media(max-width:1024px){
  .hero-split-layout{grid-template-columns:1fr;max-width:600px;gap:32px}
  .hero-left{text-align:center}
  .hero-left p{margin-left:auto;margin-right:auto}
  .hero-disclaimer{margin-left:auto;margin-right:auto}
  .hero-left .btn-group{justify-content:center}
  .hero-mockup{max-width:480px;margin:0 auto}
  .bento-asymm{grid-template-columns:1fr 1fr;grid-template-rows:auto;gap:14px}
  .bento-card-1{grid-column:1;grid-row:1}
  .bento-card-2{grid-column:2;grid-row:1}
  .bento-card-3{grid-column:1;grid-row:2}
  .bento-card-4{grid-column:2;grid-row:2;flex-direction:column}
  .steps-row::before{display:none}
  .steps-row{grid-template-columns:repeat(2,1fr);gap:16px}
  .pricing-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .product-split{grid-template-columns:1fr;max-width:480px}
  .what-is-inner{grid-template-columns:1fr;gap:28px}
  .footer-inner{grid-template-columns:1fr;gap:32px}
  .footer-nav-group{grid-template-columns:repeat(2,1fr)}
  .termin-setup-grid{grid-template-columns:1fr}
  .pf-layout{grid-template-columns:1fr}
  .product-section{grid-template-columns:1fr}
}
@media(max-width:700px){
  .bento-asymm{grid-template-columns:1fr}
  .bento-card-1,.bento-card-2,.bento-card-3,.bento-card-4{grid-column:1;grid-row:auto}
  .bento-card-4{flex-direction:column}
  section{padding:52px 20px}
  .container{padding:0 20px}
  nav{padding:0 20px}
  .nav-links{display:none}
  .nav-mobile-btn{display:flex}
  .nav-actions .nav-cta-btn{display:none}
  .stat-item{padding:22px 28px;min-width:45%}
  .docs-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
  .pricing-grid{grid-template-columns:1fr;max-width:380px}
  .steps-row{grid-template-columns:1fr 1fr}
  .content-card{padding:28px 20px}
  .hero{padding:60px 20px 52px}
}
@media(max-width:480px){
  .hero-left h1{font-size:28px}
  .cta-btn.large{padding:13px 22px;font-size:15px}
  .btn-group{flex-direction:column;align-items:stretch}
  .footer-nav-group{grid-template-columns:1fr 1fr}
  .pricing-grid{max-width:100%}
  .steps-row{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════
   TERMIN ACCESS STATUS CARD
═══════════════════════════════════════════════ */
.termin-access-card{
  border-radius:var(--radius);padding:28px 30px;max-width:780px;margin:0 auto;
  border:2px solid var(--border);background:#fff;box-shadow:var(--shadow-md);
  display:flex;flex-direction:column;gap:18px;position:relative
}
.termin-access-card--active{
  border-color:#a7f3d0;
  background:linear-gradient(135deg,#f0fdf4 0%,#fff 100%)
}
.termin-access-card--expired{
  border-color:#fde68a;
  background:linear-gradient(135deg,#fffbeb 0%,#fff 100%)
}
.termin-access-card--none{
  border-color:var(--border);background:var(--bg-subtle)
}

/* header row: badge + plan pill */
.access-header{
  display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap
}
.access-badge{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:700;padding:6px 14px;border-radius:20px
}
.access-badge--active{background:#dcfce7;color:#166534}
.access-badge--expired{background:#fef9c3;color:#92400e}
.access-badge--none{background:var(--bg-gray);color:var(--muted)}
.access-badge-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.access-badge--active .access-badge-dot{
  background:#22c55e;
  box-shadow:0 0 0 3px rgba(34,197,94,.2)
}
.access-badge--expired .access-badge-dot{background:#f59e0b}
.access-badge--none .access-badge-dot{background:#cbd5e1}

.access-plan-pill{
  display:inline-flex;align-items:center;gap:5px;
  font-size:12px;font-weight:700;color:var(--blue);
  background:var(--blue-light);border:1px solid var(--blue-mid);
  padding:4px 12px;border-radius:16px
}

/* city + service row */
.access-city-row{
  display:flex;align-items:center;gap:9px;
  font-size:14px;font-weight:600;color:var(--text-2)
}
.access-city-row .city-sep{color:var(--border);font-weight:400}
.access-city-row .city-svc{font-size:13px;color:var(--muted);font-weight:400}

/* countdown header label */
.access-countdown-hdr{
  font-size:12px;font-weight:700;color:var(--green);
  text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px
}

/* countdown digits */
.access-countdown{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.countdown-unit{
  background:#fff;border:1.5px solid #a7f3d0;border-radius:14px;
  padding:14px 12px;text-align:center;min-width:68px;flex:1;
  box-shadow:0 2px 8px rgba(5,150,105,.07)
}
.countdown-val{
  display:block;font-size:28px;font-weight:800;color:#065f46;
  line-height:1;letter-spacing:-.5px;font-variant-numeric:tabular-nums
}
.countdown-lbl{
  display:block;font-size:10px;font-weight:600;color:#6ee7b7;
  text-transform:uppercase;letter-spacing:.8px;margin-top:5px
}
.countdown-sep{
  font-size:24px;font-weight:700;color:#a7f3d0;
  align-self:flex-start;padding-top:14px;flex-shrink:0
}

/* expired message box */
.access-expired-msg{
  background:#fffbeb;border:1px solid #fde68a;border-radius:10px;
  padding:14px 16px;font-size:14px;color:#92400e;line-height:1.55;
  display:flex;align-items:flex-start;gap:10px
}

/* not-purchased message */
.access-none-msg{font-size:15px;color:var(--text-2);line-height:1.65}
.access-none-msg strong{
  color:var(--text);display:block;margin-bottom:6px;font-size:16px
}

/* bottom disclaimer strip */
.access-disclaimer{
  font-size:12px;color:var(--muted);line-height:1.6;
  padding:10px 14px;
  background:rgba(37,99,235,.04);
  border-left:3px solid var(--blue-mid);border-radius:0 8px 8px 0
}

/* action buttons row */
.access-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* section label above the card (green variant) */
.access-section-label{
  display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--green);background:var(--green-light);
  padding:4px 12px;border-radius:20px;margin-bottom:12px
}

/* Notification "coming soon" tag */
.notif-soon-tag{
  font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  background:var(--muted);color:#fff;padding:2px 7px;border-radius:10px;
  margin-left:4px;vertical-align:middle
}
.notif-btn:disabled{cursor:not-allowed;opacity:.5}

/* Period grid — 3-column variant */
.period-grid--3{grid-template-columns:1fr 1fr 1fr}

/* Responsive overrides for access card + period grid */
@media(max-width:600px){
  .termin-access-card{padding:20px 18px;gap:14px}
  .period-grid--3{grid-template-columns:1fr}
  .access-countdown{gap:5px}
  .countdown-unit{min-width:52px;padding:10px 6px}
  .countdown-val{font-size:22px}
  .countdown-sep{font-size:18px;padding-top:10px}
}
@media(max-width:480px){
  .access-header{flex-direction:column;align-items:flex-start}
  .access-badge{font-size:12px;padding:5px 12px}
  .countdown-unit{min-width:44px;padding:9px 5px}
  .countdown-val{font-size:19px}
  .countdown-lbl{font-size:9px}
}

/* ═══════════════════════════════════════════════
   PREFERS REDUCED MOTION
═══════════════════════════════════════════════ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .hero::before,.hero::after{display:none}
  .fade-up{opacity:1;transform:none}
  .hmock-pulse{animation:none}
}
