@font-face {
    font-family: 'Anta';
    src: url('/fonts/Anta-Regular.ttf') format('truetype');
    font-weight: 360;
    font-style: normal;
}

@font-face {
    font-family: 'Fjalla One';
    src: url('/fonts/FjallaOne-Regular.ttf') format('truetype');
    font-weight: 300;
    font-style: normal;
}

:root {
  --bg: #dddddd;
  --bg-2: #f5f5f5;
  --surface: #ffffff;
  --surface-strong: #ffffff;
  --text: #181818;
  --text-2: #2a2a2a;
  --muted: #666;
  --border: rgba(0,0,0,.08);
  --accent: #f28c28;
  --accent-2: #ffad57;
  --accent-dark: #b8600d;
  --shadow: none;
  --shadow-soft: none;
  --radius: 26px;
  --radius-sm: 18px;
  --container: 1240px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: 'Fjalla One', -apple-system, "Segoe UI", sans-serif;
  color: var(--text);
  background: #efefef;
}

a { color: inherit; text-decoration: none; }
h1, h2, h3 { font-family: Anta, sans-serif; }
button, input, textarea, select { font: inherit; }
img { max-width: 100%; display: block; }

.container { width: min(var(--container), calc(100% - 32px)); margin: 0 auto; }
.section { padding: 36px 0; }
.section-sm { padding: 24px 0; }
.page-hero { padding: 42px 0 16px; }

.display { font-size: clamp(2.7rem, 6vw, 3.6rem); line-height: .94; letter-spacing: -.05em; margin: 14px 0 18px; }
.h1 { font-family: Anta, sans-serif; font-size: clamp(2rem, 4vw, 3.0rem); line-height: .98; letter-spacing: -.04em; margin: 0 0 14px; }
.h2 { font-family: Anta, sans-serif; font-size: clamp(1.55rem, 2.4vw, 2.1rem); line-height: 1.05; letter-spacing: -.03em; margin: 0 0 14px; }
.h3 { font-family: Anta, sans-serif; font-size: 1.1rem; letter-spacing: -.02em; margin: 0 0 10px; }

.lead { font-size: 1.08rem; line-height: 1.75; color: var(--muted); max-width: 760px; }
.muted { color: var(--muted); }
.center { text-align: center; }

.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 12px; text-transform: uppercase; letter-spacing: .16em;
  color: var(--accent-dark); font-weight: 800;
}

.eyebrow::before {
  content: "";
  width: 26px;
  height: 2px;
  border-radius: 999px;
  background: var(--accent);
}

.grid { display: grid; gap: 24px; }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: none;
  backdrop-filter: none;
}

.card-pad { padding: 28px; }
.panel { padding: 32px; }

.pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 14px; border-radius: 999px;
  background: rgba(242,140,40,.12); color: var(--accent-dark);
  font-size: 13px; font-weight: 800;
}

.meta-chip {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 8px 10px; border-radius: 999px; font-size: 12px; font-weight: 800;
  background: rgba(0,0,0,.04); color: #444;
}

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  min-height: 48px; padding: 12px 18px; border-radius: 999px;
  border: 1px solid transparent; cursor: pointer; font-weight: 800;
  transition: transform .2s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.btn:hover { transform: translateY(-1px); }
.btn-accent { background: var(--accent); color: #fff; box-shadow: none; }
.btn-accent:hover { background: var(--accent-dark); }
.btn-outline { background: rgba(255,255,255,.55); border-color: var(--border); }
.btn-outline:hover { background: rgba(255,255,255,.92); }
.btn-dark { background: #222; color: #fff; }
.btn-block { width: 100%; }

.cta-row { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 28px; }

.nav-wrap { position: sticky; top: 0; z-index: 1000; padding: 14px 0; }

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 14px 18px;
  border-radius: 999px;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(0,0,0,.07);
  backdrop-filter: none;
  transition: .25s ease;
  min-height: 76px;
}

.nav.scrolled { box-shadow: none; background: rgba(255,255,255,.96); }

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 900;
  letter-spacing: -.03em;
  min-width: 0;
  flex: 1 1 auto;
}

.brand-logo {
  width: 46px;
  height: 46px;
  object-fit: contain;
  flex: 0 0 auto;
  filter: none;
}

.brand-text {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.brand-mark {
  width: 42px; height: 42px; border-radius: 14px; display: grid; place-items: center;
  background: var(--accent); color: white; font-weight: 900;
  box-shadow: none;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 24px;
  flex: 0 1 auto;
}

.nav-links a, .drawer a { color: var(--muted); font-weight: 700; }
.nav-links a:hover, .nav-links a.active, .drawer a.active { color: var(--text); }

.nav-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
  margin-left: auto;
}

.lang-switcher { position: relative; }
.lang-btn { min-width: 142px; }

.lang-menu {
  position: absolute; right: 0; top: calc(100% + 10px); min-width: 192px;
  background: rgba(255,255,255,.98); border: 1px solid var(--border);
  border-radius: 18px; box-shadow: none; padding: 8px; display: none;
}

.lang-switcher.open .lang-menu { display: block; }

.lang-option {
  width: 100%;
  text-align: left;
  border: 0;
  background: transparent;
  cursor: pointer;
  padding: 10px 12px;
  border-radius: 12px;
}

.lang-option:hover, .lang-option.selected {
  background: rgba(242,140,40,.12);
  color: var(--accent-dark);
}

.caret { opacity: .6; font-size: 12px; }

.hamburger {
  display: none;
  width: 44px;
  height: 44px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.96);
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 4px;
  flex: 0 0 44px;
}

.hamburger span {
  display: block;
  width: 18px;
  height: 2px;
  margin: 0;
  background: #222;
  border-radius: 999px;
}

.drawer {
  display: none;
  margin-top: 12px;
  padding: 12px;
  border-radius: 24px;
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: none;
  width: 100%;
}

.drawer.open { display: block; }

.drawer a, .drawer .drawer-actions a {
  display: block;
  padding: 12px 14px;
  border-radius: 14px;
}

.drawer a:hover, .drawer .drawer-actions a:hover { background: rgba(0,0,0,.04); }

.drawer-actions { display: grid; gap: 12px; margin-top: 12px; }

.mobile-lang-group {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 8px;
}

.mobile-lang-group .lang-option {
  text-align: center;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.95);
}

.hero { padding: 38px 0 22px; }
.hero-grid { display: grid; grid-template-columns: 1.04fr .96fr; gap: 28px; align-items: stretch; }
.hero-copy { padding: 34px; }
.hero-copy .lead { max-width: 680px; }

.hero-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 14px;
  margin-top: 28px;
}

.stat {
  padding: 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.95);
  border: 1px solid var(--border);
}

.stat strong { display: block; font-size: 1.4rem; margin-bottom: 5px; }

.hero-visual {
  min-height: 580px;
  position: relative;
  overflow: hidden;
  background: #f3f3f3;
}

.glow { position:absolute; inset:auto; border-radius: 999px; filter: none; opacity: 1; }
.glow.one { width: 220px; height: 220px; right: -32px; top: -20px; background: rgba(242,140,40,.08); }
.glow.two { width: 180px; height: 180px; left: -30px; bottom: 90px; background: rgba(0,0,0,.03); }

.dashboard {
  position: absolute; inset: 28px; border-radius: 28px; overflow: hidden;
  border: 1px solid var(--border); background: rgba(255,255,255,.96); box-shadow: none;
}

.dash-top { display:flex; justify-content:space-between; align-items:center; padding: 18px 20px; border-bottom:1px solid var(--border); }
.dash-dots { display:flex; gap:8px; }
.dash-dots span { width:10px; height:10px; border-radius:50%; background:#d9d9d9; }

.dash-grid { display:grid; grid-template-columns: 1.1fr .9fr; gap: 18px; padding: 18px; }
.dash-card, .dash-side, .chart-box, .list-box { border:1px solid var(--border); border-radius:22px; background: rgba(255,255,255,.96); }
.dash-card, .dash-side { padding: 18px; }

.spark { height: 120px; display:flex; align-items:flex-end; gap:10px; margin-top:14px; }
.spark span { flex:1; border-radius:999px 999px 12px 12px; background: var(--accent); }
.spark span:nth-child(1){height:42%;}
.spark span:nth-child(2){height:68%;}
.spark span:nth-child(3){height:56%;}
.spark span:nth-child(4){height:86%;}
.spark span:nth-child(5){height:74%;}
.spark span:nth-child(6){height:98%;}

.mini-metrics { display:grid; grid-template-columns: repeat(2, 1fr); gap:12px; margin-top:14px; }
.metric-box { padding:16px; border-radius:18px; background: rgba(0,0,0,.03); }
.metric-box strong { display:block; font-size:1.2rem; }

.side-list { display:grid; gap:12px; }
.side-item { padding:14px; border-radius:16px; background: rgba(0,0,0,.03); }

.float-card {
  position:absolute; padding:16px 18px; border-radius:22px; background: rgba(255,255,255,.98);
  border:1px solid var(--border); box-shadow: none; max-width: 220px;
}

.float-1 { top: 52px; left: 26px; }
.float-2 { bottom: 24px; left: 34px; }
.float-3 { top: 92px; right: 24px; }

.icon-bullet {
  width: 40px; height:40px; display:grid; place-items:center;
  border-radius:14px; background: rgba(242,140,40,.12);
  color: var(--accent-dark); font-weight: 900;
}

.feature-card:hover, .paper-card:hover, .price-card:hover { transform: translateY(-2px); }
.feature-card, .paper-card, .price-card, .step-card, .mini-card { transition: transform .2s ease; }

.section-head { display:flex; justify-content:space-between; align-items:end; gap:24px; margin-bottom: 28px; }

.logos-row { display:grid; grid-template-columns: repeat(5,1fr); gap: 16px; margin-top: 24px; }
.logo-pill {
  padding: 16px; text-align:center; border-radius:18px;
  background: rgba(255,255,255,.95); border:1px solid var(--border);
  color:#5d5d5d; font-weight:800;
}

.check-list { display:grid; gap: 12px; margin: 18px 0 0; padding:0; list-style:none; }
.check-list li { position:relative; padding-left: 28px; color: var(--text-2); }
.check-list li::before { content:"✓"; position:absolute; left:0; top:0; color: var(--accent-dark); font-weight:900; }

.split-panel { display:grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: stretch; }
.diagram { padding: 28px; min-height: 360px; position:relative; overflow:hidden; }
.diagram-grid { display:grid; grid-template-columns: repeat(2,1fr); gap: 14px; margin-top: 18px; }
.diagram-node { padding: 18px; border-radius: 20px; background: rgba(255,255,255,.95); border:1px solid var(--border); }

.timeline { display:grid; gap: 14px; }
.timeline-item { display:grid; grid-template-columns: 56px 1fr; gap: 14px; }
.timeline-no {
  width: 56px; height:56px; border-radius:18px;
  background: rgba(242,140,40,.13); color: var(--accent-dark);
  display:grid; place-items:center; font-weight:900;
}

.paper-meta { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:14px; }
.pricing { display:grid; grid-template-columns: repeat(3,1fr); gap:24px; }
.price-card { padding: 28px; position:relative; }
.price-card.featured { background: #ffffff; border-color: rgba(242,140,40,.28); }
.price-badge { position:absolute; right:18px; top:18px; }
.price { display:flex; align-items:end; gap:8px; margin: 14px 0 4px; }
.price strong { font-size: 2.3rem; line-height:1; }

.form-grid { display:grid; gap:16px; }
.field { display:grid; gap:8px; }
.field label { font-size:.95rem; font-weight:700; }

.field input, .field textarea, .field select {
  width: 100%;
  background: rgba(255,255,255,.98);
  border:1px solid var(--border);
  color: var(--text);
  border-radius: 16px;
  padding: 14px 16px;
}

.field textarea { min-height: 150px; resize: vertical; }

.meta-row { display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; }
.cta-row { display:flex; flex-wrap:wrap; gap:12px; margin-top:18px; }
.btn-block { width:100%; justify-content:center; }
.spacer-16 { height:16px; }

.success-box {
  display:none; margin-top:16px; padding:14px 16px; border-radius:16px;
  background: rgba(34,197,94,.12); color:#166534; border:1px solid rgba(34,197,94,.18);
}

.success-box.show { display:block; }

.login-shell { min-height: calc(100vh - 140px); display:grid; place-items:center; padding: 24px 0 60px; }
.login-card { width: min(500px, 100%); }
.login-top { margin-bottom: 18px; }
.inline-note { font-size: .95rem; color: var(--muted); }

.footer { padding: 28px 0 44px; }

.footer-inner {
  display:flex; align-items:center; justify-content:space-between; gap:16px; padding: 22px 28px;
  border:1px solid var(--border); border-radius: 24px; background: rgba(255,255,255,.96);
}

.reveal { opacity: 0; transform: translateY(20px); transition: opacity .55s ease, transform .55s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

.desktop-only { display: flex; }
.mobile-only { display: none; }

@media (max-width: 1080px) {
  .hero-grid, .split-panel, .pricing, .grid-4, .grid-3, .grid-2 { grid-template-columns: 1fr 1fr; }
  .hero-kpis { grid-template-columns: 1fr 1fr; }
  .logos-row { grid-template-columns: repeat(3,1fr); }
}

@media (max-width: 760px) {
  .desktop-only { display:none !important; }
  .mobile-only { display:inline-flex !important; }

  .nav {
    gap: 12px;
    padding: 12px 14px;
    min-height: 68px;
  }

  .brand {
    min-width: 0;
    max-width: calc(100% - 56px);
    gap: 10px;
  }

  .brand-logo {
    width: 40px;
    height: 40px;
  }

  .brand-text {
    font-size: .96rem;
  }

  .nav-links,
  .nav-actions .desktop-only {
    display: none !important;
  }

  .nav-actions {
    margin-left: auto;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex: 0 0 auto;
  }

  .hamburger.mobile-only {
    display: inline-flex !important;
  }

  .drawer {
    border-radius: 20px;
  }

  .mobile-lang-group {
    grid-template-columns: repeat(2, 1fr);
  }

  .hero-grid, .split-panel, .pricing, .grid-4, .grid-3, .grid-2, .dash-grid, .hero-kpis, .logos-row {
    grid-template-columns: 1fr;
  }

  .hero-copy, .panel { padding: 24px; }
  .dashboard { position: relative; inset: auto; margin: 22px; min-height: 420px; }
  .hero-visual { min-height: auto; }
  .float-card { position: relative; inset: auto !important; margin: 0 22px 14px; max-width:none; }
  .section, .section-sm { padding: 30px 0; }
  .section-head, .footer-inner { flex-direction: column; align-items: flex-start; }
  .footer-inner { padding: 20px; }
}

@media (max-width: 420px) {
  .brand {
    max-width: calc(100% - 52px);
  }

  .brand-text {
    font-size: .88rem;
  }

  .mobile-lang-group {
    grid-template-columns: 1fr 1fr;
  }
}

/* v3 additions */
.hero-v3 { padding-top: 26px; }
.hero-v3 .hero-copy { background: #ffffff; }
.stack-row { display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; }
.kpi-strip { display:grid; grid-template-columns: repeat(4,1fr); gap:16px; margin-top:20px; }
.kpi-tile { padding:18px; border-radius:20px; background: rgba(255,255,255,.95); border:1px solid var(--border); }
.kpi-tile strong { display:block; font-size:1.5rem; margin-bottom:6px; }
.product-tabs { display:flex; flex-wrap:wrap; gap:10px; margin: 18px 0 0; }
.product-tabs .pill { background: rgba(0,0,0,.04); color: #444; }
.enterprise-band { padding: 24px 0 8px; }
.enterprise-grid { display:grid; grid-template-columns: 1.2fr .8fr; gap:24px; }
.board { padding: 28px; min-height: 520px; position:relative; overflow:hidden; }
.board::after { content:''; position:absolute; inset:auto -50px -60px auto; width:190px; height:190px; border-radius:50%; background: rgba(242,140,40,.06); filter: none; }
.board-grid { display:grid; grid-template-columns: 1.15fr .85fr; gap:16px; margin-top:18px; }
.board-panel, .board-side, .mini-stat, .queue-item, .timeline-card, .doc-row, .feature-strip { background: rgba(255,255,255,.96); border:1px solid var(--border); border-radius:22px; }
.board-panel, .board-side { padding:18px; }
.metric-row { display:grid; grid-template-columns: repeat(3,1fr); gap:12px; margin-top:16px; }
.mini-stat { padding:14px; }
.mini-stat strong { display:block; font-size:1.15rem; }
.queue { display:grid; gap:12px; margin-top:14px; }
.queue-item { padding:14px; }
.queue-item small { display:block; color: var(--muted); margin-top:4px; }
.timeline-lane { display:grid; gap:14px; margin-top:18px; }
.timeline-card { padding:18px; display:grid; grid-template-columns: auto 1fr; gap:14px; align-items:flex-start; }
.timeline-dot { width:14px; height:14px; border-radius:50%; background: var(--accent); box-shadow: none; margin-top:4px; }
.integration-grid { display:grid; grid-template-columns: repeat(4,1fr); gap:16px; }
.integration-card { padding:20px; }
.feature-strip { padding:18px; }
.mock-browser { padding:22px; }
.mock-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:16px; }
.mock-top .dots { display:flex; gap:8px; }
.mock-top .dots span { width:10px; height:10px; border-radius:50%; background:#d4d4d4; }
.gantt { display:grid; gap:10px; }
.gantt-row { display:grid; grid-template-columns: 160px 1fr; gap:12px; align-items:center; }
.gantt-bar { height:18px; border-radius:999px; background: var(--accent); }
.gantt-bar.alt { width:72%; }
.gantt-bar.mid { width:56%; }
.gantt-bar.short { width:34%; }
.gantt-bar.long { width:88%; }
.matrix { display:grid; grid-template-columns: repeat(3,1fr); gap:14px; }
.matrix-card { padding:20px; }
.docs-table { display:grid; gap:12px; margin-top:18px; }
.doc-row { padding:16px 18px; display:grid; grid-template-columns: 1.4fr .8fr .8fr auto; gap:12px; align-items:center; }
.cta-banner { padding: 34px; display:grid; grid-template-columns: 1.1fr auto; gap:18px; align-items:center; }
.back-link { display:inline-flex; margin-bottom:14px; }
.login-grid { display:grid; grid-template-columns: .92fr 1.08fr; overflow:hidden; }
.login-side { padding:32px; background: #1c1c1c; color:#fff; min-height: 100%; }
.login-form { padding:32px; }
.info-box { margin-top:18px; padding:14px 16px; border-radius:16px; background: rgba(242,140,40,.12); color: var(--accent-dark); border:1px solid rgba(242,140,40,.2); }

@media (max-width: 1080px) {
  .enterprise-grid, .board-grid, .cta-banner, .integration-grid, .matrix { grid-template-columns: 1fr 1fr; }
  .doc-row { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 760px) {
  .enterprise-grid, .board-grid, .cta-banner, .integration-grid, .matrix, .login-grid, .kpi-strip { grid-template-columns: 1fr; }
  .gantt-row, .doc-row { grid-template-columns: 1fr; }
  .login-side, .login-form { padding:24px; }
}

.footer-links { display:flex; gap:18px; flex-wrap:wrap; align-items:center; }
.footer-links a { color:var(--muted); font-weight:700; transition:.2s ease; }
.footer-links a:hover { color:var(--text); }
.legal-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:24px; }
.legal-card { min-height:230px; }
.legal-hero .lead { max-width:900px; }
.btn-block { width:100%; }

@media (max-width:980px) {
  .legal-grid { grid-template-columns:1fr; }
}

/* V5 additions */
.cookie-banner {
  position: fixed;
  left: 24px;
  right: 24px;
  bottom: 24px;
  z-index: 1200;
  max-width: 980px;
  margin: 0 auto;
  background: rgba(24,24,24,.96);
  color: #f5f5f5;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 24px;
  box-shadow: none;
  padding: 18px 18px 16px;
  transform: translateY(120%);
  opacity: 0;
  transition: transform .35s ease, opacity .35s ease;
}

.cookie-banner.show { transform: translateY(0); opacity: 1; }
.cookie-inner { display: grid; grid-template-columns: 1.5fr auto; gap: 16px; align-items: center; }
.cookie-copy strong { display:block; margin-bottom: 6px; font-size: 1.02rem; }
.cookie-copy p { margin: 0; color: rgba(255,255,255,.82); line-height: 1.55; }
.cookie-actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.btn-light { background: #fff; color: #181818; border: 1px solid rgba(255,255,255,.18); }
.btn-ghost-dark { background: transparent; color: #fff; border: 1px solid rgba(255,255,255,.22); }
.seo-note { font-size: .92rem; color: var(--muted); margin-top: 8px; }

@media (max-width: 860px) {
  .cookie-banner { left: 14px; right: 14px; bottom: 14px; }
  .cookie-inner { grid-template-columns: 1fr; }
  .cookie-actions { justify-content: stretch; }
  .cookie-actions .btn { width: 100%; }
}

.cookie-modal {
  position: fixed;
  inset: 0;
  z-index: 1250;
  background: rgba(0,0,0,.45);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.cookie-modal.open { display: flex; }

.cookie-modal-card {
  width: min(720px, 100%);
  background: rgba(255,255,255,.98);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 26px;
  box-shadow: none;
  padding: 28px;
}

.cookie-modal-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
}

.cookie-modal-title { margin: 0 0 6px; font-size: 1.35rem; }

.cookie-modal-close {
  border: 1px solid var(--border);
  background: rgba(0,0,0,.04);
  color: var(--text);
  width: 42px;
  height: 42px;
  border-radius: 999px;
  cursor: pointer;
  font-size: 1.1rem;
}

.cookie-option-list { display: grid; gap: 14px; margin: 18px 0 24px; }

.cookie-option {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 16px;
  align-items: center;
  padding: 16px 18px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: rgba(0,0,0,.02);
}

.cookie-option strong { display: block; margin-bottom: 4px; }
.cookie-option p { margin: 0; color: var(--muted); line-height: 1.5; }

.cookie-switch {
  width: 52px;
  height: 30px;
  border-radius: 999px;
  background: rgba(0,0,0,.14);
  position: relative;
  transition: .2s ease;
}

.cookie-switch::after {
  content: "";
  position: absolute;
  top: 4px;
  left: 4px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #fff;
  transition: .2s ease;
  box-shadow: none;
}

.cookie-switch.active { background: var(--accent); }
.cookie-switch.active::after { left: 26px; }
.cookie-switch.disabled { background: rgba(0,0,0,.2); opacity: .8; }

.cookie-modal-actions { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; }

@media (max-width: 860px) {
  .cookie-option { grid-template-columns: 1fr; }
  .cookie-modal-actions .btn { width: 100%; }
}

/* Shared auth, client and admin pages */
.auth-page, .client-page, .admin-page { min-height: 100vh; }
.auth-page body, .client-page body, .admin-page body { min-height: 100vh; }

.auth-page h1, .auth-page h2, .auth-page h3,
.client-page h1, .client-page h2, .client-page h3,
.admin-page h1, .admin-page h2, .admin-page h3 {
  font-family: Anta, -apple-system, "Segoe UI", sans-serif;
}

.auth-page .nav, .client-page .nav, .admin-page .nav {
  width: min(var(--container), calc(100% - 32px));
  margin: 14px auto 0;
  position: sticky;
  top: 14px;
  z-index: 30;
}

.auth-page .nav-inner, .client-page .nav-inner, .admin-page .nav-inner {
  display:flex; align-items:center; justify-content:space-between; gap:18px;
  padding:14px 18px; border-radius:999px;
  background:rgba(255,255,255,.96); border:1px solid rgba(0,0,0,.07);
  backdrop-filter: none; box-shadow: none;
}

.auth-page .wrap, .auth-page .auth-wrap {
  flex:1; display:grid; place-items:center; padding:32px 20px 48px;
}

.auth-page .card, .client-page .card, .admin-page .card {
  background: var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  box-shadow: none; backdrop-filter: none;
}

.auth-page .card { width:100%; max-width:560px; padding:34px 28px; }

.auth-page .badge, .auth-badge {
  display:inline-flex; align-items:center; gap:8px; padding:9px 14px; border-radius:999px;
  background:rgba(242,140,40,.12); color:var(--accent-dark); font-size:13px; font-weight:800; margin-bottom:18px;
}

.auth-page .sub, .auth-sub, .client-page .sub, .admin-page .sub,
.client-page .subtitle, .admin-page .subtitle {
  margin:0 0 22px; color:var(--muted); font-size:14px; line-height:1.8;
}

.auth-page .field, .client-page .field, .admin-page .field { margin-bottom:14px; }
.auth-page label, .client-page label, .admin-page label { display:block; font-size:13px; margin-bottom:8px; }

.auth-page input, .auth-page select, .auth-page textarea,
.client-page input, .client-page select, .client-page textarea,
.admin-page input, .admin-page select, .admin-page textarea {
  width:100%; border:1px solid rgba(0,0,0,.08); border-radius:16px; padding:14px 16px;
  background:rgba(255,255,255,.98); color:var(--text);
}

.auth-page input, .client-page input, .admin-page input, .admin-page select, .client-page select { min-height:50px; }

.auth-page input:focus, .auth-page select:focus, .auth-page textarea:focus,
.client-page input:focus, .client-page select:focus, .client-page textarea:focus,
.admin-page input:focus, .admin-page select:focus, .admin-page textarea:focus {
  outline:none; border-color:rgba(242,140,40,.45); box-shadow: none;
}

.auth-page button:not(.hamburger):not(.lang-option),
.client-page button:not(.hamburger):not(.lang-option),
.admin-page button:not(.hamburger):not(.lang-option) { font: inherit; }

.auth-page button, .client-page button, .admin-page button,
.client-page .chip, .admin-page .chip, .auth-page .nav-link {
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  min-height:48px; padding:12px 18px; border-radius:999px; border:1px solid transparent;
  cursor:pointer; font-weight:800; transition:transform .2s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease; text-decoration:none;
}

.auth-page button:hover, .client-page button:hover, .admin-page button:hover,
.client-page .chip:hover, .admin-page .chip:hover, .auth-page .nav-link:hover {
  transform:translateY(-1px);
}

.auth-page button, .client-page button, .admin-page .btn, .client-page .btn {
  background:var(--accent); color:#fff; box-shadow:none;
}

.auth-page button:hover, .client-page button:hover, .admin-page .btn:hover, .client-page .btn:hover {
  background:var(--accent-dark);
}

.client-page .chip, .admin-page .chip, .auth-page .nav-link,
.admin-page .small:not(.approve):not(.reject):not(.suspend) {
  background:rgba(255,255,255,.95); border-color:var(--border); color:var(--text); box-shadow:none;
}

.client-page .chip:hover, .admin-page .chip:hover, .auth-page .nav-link:hover,
.admin-page .small:not(.approve):not(.reject):not(.suspend):hover {
  background:rgba(255,255,255,.98);
}

.auth-page .helper-links {
  margin-top:16px; display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap; font-size:14px;
}

.auth-page .helper-links a, .auth-page .top-link, .client-page .top-link, .admin-page .top-link {
  color:#1f1f1f; text-decoration:none;
}

.auth-page .helper-links a { color:#b45309; }

.auth-page .msg, .client-page .msg, .admin-page .msg, .form-status {
  margin-top:18px; border-radius:16px; padding:16px 18px; display:none; white-space:pre-line; font-size:14px; line-height:1.7;
}

.auth-page .msg.success, .client-page .success, .admin-page .success, .form-status.ok, .verify-box.ok {
  display:block; background:#ecfdf5; color:#166534; border:1px solid #86efac;
}

.auth-page .msg.error, .client-page .error, .admin-page .error, .form-status.err, .verify-box.err {
  display:block; background:#fef2f2; color:#991b1b; border:1px solid #fca5a5;
}

.form-status.show, .msg.show, .verify-box.loading, .verify-box.ok, .verify-box.err { display:block; }

.field-hidden-trap {
  position:absolute; left:-9999px; opacity:0; pointer-events:none; width:1px; height:1px; overflow:hidden;
}

.client-page .nav-actions, .admin-page .nav-actions { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.client-page .page, .admin-page .page { width:min(var(--container), calc(100% - 32px)); margin:0 auto; padding:28px 0 48px; }
.client-page .hero, .admin-page .top { display:grid; grid-template-columns:1.1fr .9fr; gap:24px; align-items:stretch; margin-bottom:24px; }
.client-page .grid, .admin-page .grid-panels { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.client-page .card, .admin-page .page .card, .admin-page .top .card { padding:28px; }
.client-page .readonly { background:rgba(0,0,0,.03); color:#666; }
.client-page .title, .admin-page .title { font-family:Anta, sans-serif; font-size:clamp(2rem,4vw,3rem); line-height:.98; letter-spacing:-.04em; margin:0 0 14px; }
.client-page .m0, .admin-page .m0 { margin:0; }
.client-page .metric-grid { display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:14px; }

.client-page .metric, .admin-page .stat {
  padding:18px; border-radius:22px; border:1px solid var(--border); background:rgba(255,255,255,.95);
}

.client-page .metric .label, .admin-page .stat .label {
  font-size:12px; color:var(--muted); margin-bottom:8px; text-transform:uppercase; letter-spacing:.08em;
}

.client-page .metric .value, .admin-page .stat .value {
  font-family:Anta, sans-serif; font-size:1.5rem; line-height:1.05;
}

.client-page dl { margin:0; display:grid; grid-template-columns:150px 1fr; gap:10px 14px; }
.client-page dd, .admin-page dd { margin:0; }

.client-page .api-box {
  padding:18px; border:1px solid var(--border); border-radius:22px; background:rgba(255,255,255,.95);
}

.client-page .api-code {
  display:block; margin-top:14px; padding:14px 16px; border-radius:16px; background:rgba(0,0,0,.04); border:1px solid var(--border); word-break:break-word;
}

.client-page .steps, .client-page .step-list { display:grid; gap:12px; }

.client-page .step {
  display:grid; grid-template-columns:auto 1fr; gap:12px; align-items:flex-start; padding:16px;
  border-radius:20px; border:1px solid var(--border); background:rgba(255,255,255,.95);
}

.client-page .step-icon {
  width:34px; height:34px; border-radius:999px; display:grid; place-items:center; font-weight:900; background:rgba(0,0,0,.06);
}

.client-page .step.ok .step-icon { background:rgba(34,197,94,.12); color:#166534; }
.client-page .step.wait .step-icon { background:rgba(245,158,11,.16); color:#92400e; }
.client-page .step.info .step-icon { background:rgba(59,130,246,.12); color:#1d4ed8; }

.client-page .step-title { margin:0 0 4px; font-weight:700; }
.client-page .step-text { margin:0; color:var(--muted); }

.client-page .status-badge, .admin-page .badge {
  display:inline-flex; align-items:center; justify-content:center; border-radius:999px; padding:7px 11px;
  font-size:12px; border:1px solid transparent; white-space:nowrap; margin:0; font-weight:800;
}

.client-page .status-badge.pending_email, .admin-page .badge.pending_email { background:#fff7ed; color:#9a3412; border-color:#fed7aa; }
.client-page .status-badge.pending_review, .admin-page .badge.pending_review { background:#eff6ff; color:#1d4ed8; border-color:#bfdbfe; }
.client-page .status-badge.approved, .admin-page .badge.approved { background:#ecfdf5; color:#166534; border-color:#bbf7d0; }
.client-page .status-badge.rejected, .admin-page .badge.rejected { background:#fef2f2; color:#991b1b; border-color:#fecaca; }
.client-page .status-badge.suspended, .admin-page .badge.suspended { background:#f5f3ff; color:#5b21b6; border-color:#ddd6fe; }

.admin-page { color:var(--text); }
.admin-page .top { grid-template-columns:1.2fr .8fr; }
.admin-page .stats { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.admin-page .filters { display:grid; grid-template-columns:1fr 160px 170px 170px 120px; gap:12px; align-items:end; }
.admin-page .table-card { overflow:hidden; }
.admin-page .table-wrap { overflow:auto; }
.admin-page table { width:100%; border-collapse:collapse; }
.admin-page th, .admin-page td { text-align:left; padding:14px; border-bottom:1px solid rgba(0,0,0,.06); font-size:13px; vertical-align:top; }
.admin-page th { font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:.08em; }
.admin-page tbody tr:hover { background:rgba(255,255,255,.38); }
.admin-page .text-muted { color:var(--muted); }
.admin-page .actions { display:flex; flex-wrap:wrap; gap:8px; }
.admin-page .small { height:40px; padding:0 14px; border:none; cursor:pointer; }
.admin-page .approve { background:#ecfdf5; color:#166534; border:1px solid #bbf7d0; }
.admin-page .reject { background:#fef2f2; color:#991b1b; border:1px solid #fecaca; }
.admin-page .suspend { background:#fff7ed; color:#92400e; border:1px solid #fed7aa; }
.admin-page .details { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.admin-page .details .box { border:1px solid var(--border); border-radius:22px; padding:20px; background:rgba(255,255,255,.95); }
.admin-page .details dl { margin:0; display:grid; grid-template-columns:140px 1fr; gap:8px 12px; font-size:13px; }
.admin-page .detail-actions { display:flex; gap:10px; flex-wrap:wrap; margin-top:16px; }
.admin-page .hidden { display:none; }

.mb-20 { margin-bottom:20px; }
.w-full { width:100%; }
.spacer-12 { height:12px; }

@media (max-width:1050px) {
  .admin-page .top, .client-page .hero, .client-page .grid, .admin-page .grid-panels, .admin-page .details { grid-template-columns:1fr; }
  .admin-page .filters { grid-template-columns:1fr 1fr; }
}

@media (max-width:700px) {
  .admin-page .filters, .admin-page .stats, .client-page .metric-grid { grid-template-columns:1fr; }
  .auth-page .nav-inner, .client-page .nav-inner, .admin-page .nav-inner { border-radius:26px; align-items:flex-start; }
  .auth-page .nav-inner, .client-page .nav-inner, .admin-page .nav-inner, .client-page .nav-actions, .admin-page .nav-actions { flex-direction:column; align-items:stretch; }
  .client-page dl, .admin-page .details dl { grid-template-columns:1fr; }
}