@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/assets/fonts/plus-jakarta-sans-v12-latin-700.woff2') format('woff2');
}

/* ═══════════════════════════════════════════════════════════════
   BEWISE — HOME.CSS
   Homepage-specifieke stijlen (NL + EN homepage)
   Geladen door: / en /en/
═══════════════════════════════════════════════════════════════ */

:root {
  --bg: #f8f9fc;
  --white: #ffffff;
  --surface: #f1f4f9;
  --surface2: #e8edf5;
  --border: #e2e6ef;
  --border2: #c8d0e0;
  --blue: #1a56db;
  --blue-dark: #1240a8;
  --blue-light: #eff4ff;
  --blue-mid: #dbe8ff;
  --text: #1a2030;
  --text2: #3d4a5c;
  --muted: #6b7a90;
  --muted2: #98a4b4;
  --green: #0d9f6e;
  --amber: #d97706;
  --red: #dc2626;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Plus Jakarta Sans',sans-serif;
  overflow-x:hidden;
  line-height:1.6;
  font-size:15px;
  padding-top:64px;
}

/* ── HERO ── */
.hero{
  padding:120px 48px 80px;
  max-width:1400px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
  position:relative;z-index:1;
}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--blue-light);border:1px solid var(--blue-mid);
  border-radius:100px;padding:5px 14px;
  font-size:12px;font-weight:600;color:var(--blue);
  letter-spacing:.04em;text-transform:uppercase;
  margin-bottom:24px;
  animation:fadeUp .6s ease both;
}

h1{
  font-family:'Instrument Serif',serif;
  font-size:clamp(36px,4.5vw,58px);
  line-height:1.1;color:var(--text);
  letter-spacing:-.5px;margin-bottom:20px;
  animation:fadeUp .6s .08s ease both;
}
h1 em{
  font-style:italic;color:var(--blue);
}

.hero-sub{
  font-size:17px;color:var(--text2);line-height:1.8;
  margin-bottom:36px;font-weight:400;
  animation:fadeUp .6s .16s ease both;
}

.hero-cta-row{
  display:flex;gap:12px;flex-wrap:wrap;
  margin-bottom:16px;
  animation:fadeUp .6s .22s ease both;
}
.btn-primary{
  background:var(--blue);color:#fff;border:none;
  border-radius:7px;font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:600;font-size:14px;padding:13px 28px;
  cursor:pointer;transition:all .2s;text-decoration:none;
  display:inline-block;
}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(26,86,219,.25);}
.btn-outline{
  background:var(--white);color:var(--text);
  border:1.5px solid var(--border2);border-radius:7px;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:500;font-size:14px;padding:12px 24px;
  cursor:pointer;transition:all .2s;text-decoration:none;
  display:inline-flex;align-items:center;gap:8px;
}
.btn-outline:hover{border-color:var(--blue);color:var(--blue);}
.hero-note{
  font-size:12px;color:var(--muted);
  animation:fadeUp .6s .28s ease both;
}

/* ── HERO ARCHITECTURE DIAGRAM ── */
.hero-right{animation:fadeUp .6s .18s ease both;}

.arch-diagram{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 8px 40px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.08);
}
.arch-header{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  padding:14px 20px;
  display:flex;align-items:center;justify-content:space-between;
}
.arch-title{
  font-size:12px;font-weight:600;color:var(--text2);
  text-transform:uppercase;letter-spacing:.06em;
  display:flex;align-items:center;gap:8px;
}
.status-pill{
  display:inline-flex;align-items:center;gap:5px;
  background:#dcfce7;border:1px solid #bbf7d0;
  border-radius:100px;padding:3px 10px;
  font-size:11px;font-weight:600;color:var(--green);
}
.status-dot{width:5px;height:5px;background:var(--green);border-radius:50%;animation:pulse 2s infinite;}

.arch-body{padding:24px 20px;}

.arch-layer{
  display:flex;align-items:center;gap:12px;
  margin-bottom:8px;
}
.arch-systems{
  display:flex;flex-direction:column;gap:6px;flex:1;
}
.arch-chip{
  display:flex;align-items:center;gap:8px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:7px;padding:8px 12px;
  font-size:12px;font-weight:500;color:var(--text2);
  transition:all .2s;
}
.arch-chip:hover{border-color:var(--blue);background:var(--blue-light);}
.arch-chip .chip-icon{font-size:15px;flex-shrink:0;}

.arch-connector{
  display:flex;flex-direction:column;align-items:center;
  gap:4px;flex-shrink:0;width:80px;
}
.conn-track{
  width:64px;height:20px;position:relative;
}
.conn-line{
  position:absolute;width:100%;height:1.5px;
  background:linear-gradient(90deg,var(--border2),var(--blue),var(--border2));
  top:50%;transform:translateY(-50%);border-radius:2px;
}
.conn-dot{
  position:absolute;width:6px;height:6px;border-radius:50%;
  background:var(--blue);top:50%;transform:translateY(-50%);
  animation:slideAcross 2s ease-in-out infinite;
  box-shadow:0 0 6px rgba(26,86,219,.4);
}
.conn-dot.rev{animation:slideAcrossRev 2s 1s ease-in-out infinite;}
.conn-label{font-size:10px;color:var(--muted);font-weight:500;letter-spacing:.04em;}

.bewise-core{
  background:var(--blue);border-radius:10px;
  padding:16px 14px;text-align:center;margin:12px 0;
  box-shadow:0 4px 16px rgba(26,86,219,.2);
}
.bewise-core-name{
  font-family:'Instrument Serif',serif;
  font-size:16px;color:#fff;letter-spacing:-.2px;margin-bottom:4px;
}
.bewise-core-tag{font-size:10px;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.08em;}

/* Event feed */
.event-feed{
  border-top:1px solid var(--border);
  margin-top:16px;padding-top:14px;
}
.feed-header{
  font-size:10px;font-weight:600;text-transform:uppercase;
  letter-spacing:.08em;color:var(--muted);margin-bottom:8px;
  display:flex;align-items:center;gap:6px;
}
.feed-header::before{
  content:'';width:5px;height:5px;
  background:var(--green);border-radius:50%;
  animation:pulse 2s infinite;
}
.feed-row{
  display:flex;align-items:center;gap:8px;
  padding:5px 0;font-size:11px;color:var(--muted);
  border-bottom:1px solid var(--border);
}
.feed-row:last-child{border-bottom:none;}
.feed-ts{color:var(--blue);font-size:10px;font-weight:500;flex-shrink:0;width:50px;}
.feed-badge{
  flex-shrink:0;padding:2px 7px;border-radius:4px;
  font-size:10px;font-weight:600;
}
.fb-order{background:#dbeafe;color:#1e40af;}
.fb-stock{background:#dcfce7;color:#166534;}
.fb-doc{background:#fef3c7;color:#92400e;}
.feed-val{margin-left:auto;font-size:10px;font-weight:600;color:var(--text2);}

/* ── LOGO WALL ── */
.logo-wall{
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:var(--white);
  padding:28px 48px;
}
.logo-wall-inner{
  max-width:1400px;margin:0 auto;
  display:flex;align-items:center;gap:0;
}
.lw-label{
  font-size:11px;font-weight:600;text-transform:uppercase;
  letter-spacing:.08em;color:var(--muted2);
  white-space:nowrap;margin-right:40px;min-width:120px;
}
.lw-logos{
  display:flex;align-items:center;gap:0;flex:1;
}
.lw-item{
  flex:1;display:flex;align-items:center;justify-content:center;gap:7px;
  padding:12px 16px;border-left:1px solid var(--border);
  font-size:13px;font-weight:600;color:var(--muted);
  transition:color .2s;cursor:default;
}
.lw-item:hover{color:var(--text2);}
.lw-item:first-child{border-left:none;}

/* ── SECTION COMMONS ── */
section{position:relative;z-index:1;}
.section-inner{max-width:1400px;margin:0 auto;padding:88px 48px;}
.section-tag{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--blue);margin-bottom:12px;
}
h2{
  font-family:'Instrument Serif',serif;
  font-size:clamp(28px,3.5vw,44px);
  color:var(--text);line-height:1.15;
  letter-spacing:-.3px;margin-bottom:14px;
}
h2 em{font-style:italic;color:var(--blue);}
.section-sub{
  color:var(--text2);font-size:16px;
  max-width:520px;line-height:1.8;
}

/* ── ARCHITECTURE SECTION ── */
.arch-section{background:var(--white);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}

.platform-matrix{
  display:grid;grid-template-columns:1fr 200px 1fr;
  gap:32px;align-items:start;margin-top:56px;
}
.pm-col h4{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--muted);margin-bottom:14px;
}
.pm-list{display:flex;flex-direction:column;gap:8px;}
.pm-item{
  display:flex;align-items:center;gap:10px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:8px;padding:12px 14px;
  font-size:13px;font-weight:500;color:var(--text2);
  transition:all .2s;
}
.pm-item:hover{border-color:var(--blue);background:var(--blue-light);color:var(--blue);}
.pm-item .tag{
  margin-left:auto;font-size:10px;font-weight:600;
  background:var(--blue-mid);color:var(--blue);
  border-radius:4px;padding:2px 7px;
}

.pm-center{
  display:flex;flex-direction:column;align-items:center;
  gap:8px;padding-top:32px;
}
.pm-core{
  background:var(--blue);border-radius:12px;
  padding:20px 16px;text-align:center;width:100%;
  box-shadow:0 8px 24px rgba(26,86,219,.2);
}
.pm-core-name{
  font-family:'Instrument Serif',serif;
  font-size:18px;color:#fff;margin-bottom:4px;
}
.pm-core-sub{font-size:10px;color:rgba(255,255,255,.65);text-transform:uppercase;letter-spacing:.06em;}
.pm-feature{
  font-size:11px;font-weight:500;color:var(--muted);
  background:var(--surface);border:1px solid var(--border);
  border-radius:6px;padding:5px 12px;text-align:center;width:100%;
}
.pm-arrows{display:flex;flex-direction:column;gap:3px;align-items:center;}
.pm-arrow{color:var(--blue-mid);font-size:18px;}

/* ── FEATURES ── */
.features-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:14px;
  overflow:hidden;margin-top:56px;
}
.feat-card{
  background:var(--white);padding:32px 28px;
  transition:background .25s;
}
.feat-card:hover{background:var(--blue-light);}
.feat-icon{
  width:40px;height:40px;border-radius:9px;
  background:var(--blue-light);border:1px solid var(--blue-mid);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;margin-bottom:18px;
}
.feat-card h3{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:15px;font-weight:700;color:var(--text);margin-bottom:8px;
}
.feat-card p{font-size:13px;color:var(--muted);line-height:1.8;}
.feat-tag{
  display:inline-flex;margin-top:10px;
  font-size:10px;font-weight:600;color:var(--blue);
  background:var(--blue-light);border:1px solid var(--blue-mid);
  border-radius:4px;padding:2px 8px;
}

/* ── DOCUMENT IMPORT ── */
.doc-section{background:var(--white);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.doc-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-top:56px;}
.doc-visual{
  background:var(--surface);border:1px solid var(--border);
  border-radius:14px;overflow:hidden;
}
.doc-vis-header{
  background:var(--white);border-bottom:1px solid var(--border);
  padding:12px 18px;display:flex;align-items:center;gap:10px;
  font-size:12px;font-weight:600;color:var(--text2);
}
.doc-vis-body{padding:20px;}
.doc-file{
  display:flex;align-items:center;gap:12px;
  background:var(--white);border:1px solid var(--border);
  border-radius:8px;padding:12px 14px;margin-bottom:10px;
}
.doc-file-icon{font-size:20px;flex-shrink:0;}
.doc-file-name{font-size:12px;font-weight:600;color:var(--text);}
.doc-file-sub{font-size:10px;color:var(--muted);}
.doc-file-status{
  margin-left:auto;font-size:10px;font-weight:600;
  padding:3px 8px;border-radius:4px;
}
.ds-done{background:#dcfce7;color:var(--green);}
.ds-proc{background:#dbeafe;color:var(--blue);}
.ds-wait{background:var(--surface2);color:var(--muted);}

.doc-arrow{
  text-align:center;padding:8px 0;
  font-size:11px;color:var(--muted);
  display:flex;align-items:center;justify-content:center;gap:8px;
}

.doc-result{
  background:var(--white);border:1px solid var(--border);
  border-radius:8px;padding:12px 14px;
  font-size:11px;color:var(--text2);
}
.doc-result-title{font-weight:700;font-size:12px;color:var(--text);margin-bottom:6px;}
.doc-result-row{
  display:flex;justify-content:space-between;
  padding:4px 0;border-bottom:1px solid var(--border);
  color:var(--muted);
}
.doc-result-row:last-child{border-bottom:none;}
.doc-result-row strong{color:var(--text);}

.doc-features{display:flex;flex-direction:column;gap:18px;}
.doc-feat{display:flex;align-items:flex-start;gap:14px;}
.doc-feat-icon{
  width:36px;height:36px;border-radius:8px;flex-shrink:0;
  background:var(--blue-light);border:1px solid var(--blue-mid);
  display:flex;align-items:center;justify-content:center;font-size:16px;
}
.doc-feat h4{font-size:14px;font-weight:700;color:var(--text);margin-bottom:4px;}
.doc-feat p{font-size:13px;color:var(--muted);line-height:1.75;}

/* ── PRICING ── */
.pricing-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:16px;margin-top:56px;
}
.price-card{
  background:var(--white);border:1.5px solid var(--border);
  border-radius:14px;padding:28px 24px;
  transition:all .25s;position:relative;
}
.price-card:hover{border-color:var(--blue);box-shadow:0 8px 32px rgba(26,86,219,.1);}
.price-card.featured{
  border-color:var(--blue);
  box-shadow:0 8px 40px rgba(26,86,219,.15);
  background:linear-gradient(160deg,var(--blue-light) 0%,var(--white) 60%);
}
.feat-badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--blue);color:#fff;
  font-size:11px;font-weight:700;padding:4px 14px;
  border-radius:100px;white-space:nowrap;letter-spacing:.02em;
}
.price-tier{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--muted);margin-bottom:14px;
}
.price-amount{
  font-family:'Instrument Serif',serif;
  font-size:40px;color:var(--text);line-height:1;
  margin-bottom:4px;display:flex;align-items:flex-start;gap:3px;
}
.price-amount sup{font-size:18px;margin-top:7px;color:var(--muted);font-family:'Plus Jakarta Sans',sans-serif;font-weight:400;}
.price-amount sub{font-size:14px;color:var(--muted);align-self:flex-end;margin-bottom:3px;font-family:'Plus Jakarta Sans',sans-serif;font-weight:400;}
.price-desc{font-size:12px;color:var(--muted);margin-bottom:22px;line-height:1.6;}
.price-divider{height:1px;background:var(--border);margin-bottom:18px;}
.price-feats{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:24px;}
.price-feats li{
  display:flex;align-items:flex-start;gap:8px;
  font-size:12px;color:var(--text2);
}
.price-feats li::before{
  content:'✓';color:var(--green);font-weight:700;flex-shrink:0;margin-top:1px;
}
.price-feats li.off{color:var(--muted2);}
.price-feats li.off::before{content:'–';color:var(--muted2);}
.btn-price-primary{
  width:100%;padding:11px;border-radius:7px;
  background:var(--blue);color:#fff;border:none;
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;
  font-size:13px;cursor:pointer;transition:all .2s;
}
.btn-price-primary:hover{background:var(--blue-dark);box-shadow:0 4px 14px rgba(26,86,219,.25);}
.btn-price-outline{
  width:100%;padding:10px;border-radius:7px;
  background:transparent;color:var(--text2);
  border:1.5px solid var(--border2);
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:500;
  font-size:13px;cursor:pointer;transition:all .2s;
}
.btn-price-outline:hover{border-color:var(--blue);color:var(--blue);}
.price-note{
  text-align:center;font-size:12px;color:var(--muted);
  margin-top:20px;
}

/* ── REVIEWS ── */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:56px;}
.review-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:12px;padding:28px;
}
.stars{color:#f59e0b;font-size:14px;letter-spacing:1px;margin-bottom:14px;}
.review-text{
  font-size:14px;color:var(--text2);line-height:1.8;
  margin-bottom:20px;
  font-style:italic;
}
.reviewer{display:flex;align-items:center;gap:10px;}
.reviewer-avatar{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),#60a5fa);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:13px;color:#fff;flex-shrink:0;
}
.reviewer-info strong{display:block;font-size:13px;font-weight:700;color:var(--text);}
.reviewer-info small{font-size:11px;color:var(--muted);}

/* ── FAQ ── */
.faq-section{background:var(--white);border-top:1px solid var(--border);}
.faq-grid{display:grid;grid-template-columns:1fr 2fr;gap:64px;margin-top:56px;}
.faq-aside h3{
  font-family:'Instrument Serif',serif;
  font-size:28px;color:var(--text);margin-bottom:12px;
}
.faq-aside p{font-size:14px;color:var(--muted);line-height:1.8;margin-bottom:24px;}
.faq-list{display:flex;flex-direction:column;gap:8px;}
.faq-item{
  border:1px solid var(--border);border-radius:9px;
  overflow:hidden;background:var(--white);
}
.faq-q{
  width:100%;background:none;border:none;
  color:var(--text);font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:600;font-size:14px;text-align:left;
  padding:18px 20px;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;
  gap:12px;transition:color .2s;
}
.faq-q:hover{color:var(--blue);}
.faq-ico{
  flex-shrink:0;width:22px;height:22px;
  border:1.5px solid var(--border2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;color:var(--muted);transition:all .2s;
}
.faq-item.open .faq-ico{
  background:var(--blue);border-color:var(--blue);
  color:#fff;transform:rotate(45deg);
}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;}
.faq-item.open .faq-a{max-height:220px;}
.faq-a-in{
  padding:0 20px 18px;font-size:13px;
  color:var(--muted);line-height:1.85;
}

/* ── CTA ── */
.cta-section{
  background:var(--blue);
  position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  pointer-events:none;
}
.cta-inner{
  max-width:720px;margin:0 auto;
  text-align:center;padding:88px 48px;
  position:relative;z-index:1;
}
.cta-inner h2{
  font-family:'Instrument Serif',serif;
  font-size:clamp(28px,4vw,48px);
  color:#fff;margin-bottom:16px;letter-spacing:-.3px;
}
.cta-inner p{
  color:rgba(255,255,255,.75);font-size:16px;
  line-height:1.8;margin-bottom:36px;
}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
.btn-white{
  background:#fff;color:var(--blue);
  border:none;border-radius:7px;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;font-size:14px;padding:13px 28px;
  cursor:pointer;transition:all .2s;
}
.btn-white:hover{background:var(--blue-light);transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,.15);}
.btn-white-outline{
  background:transparent;color:#fff;
  border:1.5px solid rgba(255,255,255,.4);border-radius:7px;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:500;font-size:14px;padding:12px 24px;
  cursor:pointer;transition:all .2s;
}
.btn-white-outline:hover{border-color:rgba(255,255,255,.8);}

/* ── STATS ── */
.stats-row{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:14px;overflow:hidden;
  margin-top:56px;
}
.stat-item{background:var(--white);padding:32px 24px;text-align:center;}
.stat-num{
  font-family:'Instrument Serif',serif;
  font-size:44px;color:var(--blue);line-height:1;margin-bottom:8px;
}
.stat-desc{font-size:12px;color:var(--muted);font-weight:500;}

/* ── FOOTER ── */
/* Lang switch */
.lang-switch{
  position:fixed;bottom:24px;right:24px;z-index:300;
  background:var(--white);border:1px solid var(--border);
  border-radius:8px;padding:8px 14px;
  display:flex;gap:10px;align-items:center;
  box-shadow:0 4px 16px rgba(0,0,0,.08);font-size:12px;font-weight:600;
}
.lang-btn{
  cursor:pointer;color:var(--muted);transition:color .2s;
  background:none;border:none;font-family:'Plus Jakarta Sans',sans-serif;
  font-size:12px;font-weight:600;padding:2px 6px;border-radius:4px;
}
.lang-btn.active{background:var(--blue);color:#fff;border-radius:4px;}
.lang-btn:hover:not(.active){color:var(--blue);}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes slideAcross{0%{left:0;opacity:0}10%{opacity:1}90%{opacity:1}100%{left:calc(100% - 6px);opacity:0}}
@keyframes slideAcrossRev{0%{left:calc(100% - 6px);opacity:0}10%{opacity:1}90%{opacity:1}100%{left:0;opacity:0}}

.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease;}
.reveal.visible{opacity:1;transform:none;}
.reveal-d1{transition-delay:.08s;}
.reveal-d2{transition-delay:.16s;}

/* ── RESPONSIVE ── */
@media(max-width:1000px){
  .hero{grid-template-columns:1fr;padding:100px 24px 60px;gap:48px;}
  .pricing-grid{grid-template-columns:repeat(2,1fr);}
  .features-grid{grid-template-columns:repeat(2,1fr);}
  .doc-grid{grid-template-columns:1fr;}
  .platform-matrix{grid-template-columns:1fr;}
  .pm-center{padding-top:0;}
  .section-inner{padding:64px 24px;}
}
@media(max-width:680px){
  .logo-wall{padding:20px 24px;}
  .logo-wall-inner{flex-direction:column;gap:12px;align-items:flex-start;}
  .lw-logos{flex-wrap:wrap;}
  .lw-item{flex:0 0 auto;}
  .pricing-grid{grid-template-columns:1fr;}
  .features-grid{grid-template-columns:1fr;}
  .reviews-grid{grid-template-columns:1fr;}
  .stats-row{grid-template-columns:repeat(2,1fr);}
  .faq-grid{grid-template-columns:1fr;}
  .cta-inner{padding:64px 24px;}
  }

/* Logo icon alignment */
.chip-icon { display:inline-flex; align-items:center; justify-content:center; width:20px; height:20px; flex-shrink:0; }
.chip-icon img { display:block; }
.lw-item { display:flex; align-items:center; gap:8px; }
.pm-item { display:flex; align-items:center; gap:8px; }
.arch-chip { display:flex; align-items:center; gap:8px; padding:8px 12px; }


/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);}
.nav-inner{max-width:1400px;margin:0 auto;padding:0 48px;height:64px;display:flex;align-items:center;justify-content:space-between;}
.nav-logo{font-family:'Instrument Serif',serif;font-size:22px;color:var(--text);text-decoration:none;letter-spacing:-.2px;}
.nav-logo em{color:var(--blue);font-style:normal;}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none;}
.nav-links a{color:var(--muted);text-decoration:none;font-size:14px;font-weight:500;transition:color .2s;}
.nav-links a:hover{color:var(--text);}
.nav-right{display:flex;align-items:center;gap:12px;}
.nav-lang{font-size:12px;color:var(--muted);cursor:pointer;border:1px solid var(--border);border-radius:5px;padding:4px 10px;background:var(--white);text-decoration:none;transition:all .2s;}
.nav-lang:hover{border-color:var(--blue);color:var(--blue);}
.nav-login{font-size:14px;color:var(--text2);font-weight:500;text-decoration:none;transition:color .2s;}
.nav-login:hover{color:var(--blue);}
.nav-cta{background:var(--blue);color:#fff;border:none;border-radius:7px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:600;padding:9px 22px;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block;white-space:nowrap;}
.nav-cta:hover{background:var(--blue-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(26,86,219,.25);}

/* ── FOOTER ── */
footer{background:var(--text);}
.footer-inner{max-width:1400px;margin:0 auto;padding:48px;display:grid;grid-template-columns:240px 1fr auto;gap:48px;align-items:start;}
.footer-brand{font-family:'Instrument Serif',serif;font-size:20px;color:#fff;margin-bottom:8px;}
.footer-brand em{color:#60a5fa;font-style:normal;}
.footer-tagline{font-size:12px;color:rgba(255,255,255,.4);line-height:1.7;max-width:200px;}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.footer-col h5{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.35);margin-bottom:14px;}
.footer-col a{display:block;font-size:13px;color:rgba(255,255,255,.6);text-decoration:none;margin-bottom:8px;transition:color .2s;}
.footer-col a:hover{color:#fff;}
.footer-legal{font-size:11px;color:rgba(255,255,255,.3);line-height:1.8;text-align:right;}

@media(max-width:1000px){
  .nav-inner{padding:0 24px;}
  .nav-links{display:none;}
  .footer-inner{grid-template-columns:1fr;gap:28px;padding:36px 24px;}
  .footer-legal{text-align:left;}
  .footer-links{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:500px){
  .footer-links{grid-template-columns:1fr;}
}

:focus-visible{outline:3px solid var(--blue);outline-offset:3px;}
button:focus-visible,a:focus-visible,input:focus-visible{outline:3px solid var(--blue);outline-offset:3px;border-radius:4px;}

.text-bold{font-weight:600;color:var(--text);}