/* ============================================================
   GoLynk Landing — Design System v2.0
   Shared stylesheet for all public-facing pages
   ============================================================ */

/* ── Reset ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

/* ── Design Tokens ── */
:root{
  /* Brand */
  --blue:#2563EB;--blue-dark:#1D4ED8;--blue-mid:#3B82F6;
  --blue-light:#DBEAFE;--blue-xlight:#EFF6FF;
  --indigo:#4F46E5;--indigo-light:#EEF2FF;--indigo-border:#C7D2FE;
  --emerald:#059669;--emerald-light:#D1FAE5;--emerald-xlight:#ECFDF5;
  --amber:#D97706;--amber-light:#FEF3C7;--amber-border:#FDE68A;
  --red:#DC2626;--red-light:#FEE2E2;
  /* Neutrals */
  --white:#fff;--gray-50:#F8FAFC;--gray-100:#F1F5F9;--gray-200:#E2E8F0;
  --gray-300:#CBD5E1;--gray-400:#94A3B8;--gray-500:#64748B;
  --gray-600:#475569;--gray-700:#334155;--gray-800:#1E293B;--gray-900:#0F172A;
  /* Semantic */
  --text:var(--gray-900);--text-soft:var(--gray-600);--text-muted:var(--gray-400);
  --bg:var(--white);--bg-soft:var(--gray-50);--bg-subtle:var(--gray-100);
  --border:var(--gray-200);--border-light:var(--gray-100);
  /* Gradients */
  --grad-hero:linear-gradient(140deg,#EFF6FF 0%,#EEF2FF 55%,#ECFDF5 100%);
  --grad-primary:linear-gradient(135deg,#2563EB 0%,#4F46E5 100%);
  --grad-dark:linear-gradient(135deg,#0F172A 0%,#1E293B 100%);
  /* Misc */
  --font:'Outfit',system-ui,-apple-system,sans-serif;
  --max-w:1200px;--ease:cubic-bezier(.16,1,.3,1);
  --shadow-sm:0 1px 3px rgba(15,23,42,.06),0 1px 2px rgba(15,23,42,.04);
  --shadow:0 4px 16px rgba(15,23,42,.08),0 1px 3px rgba(15,23,42,.04);
  --shadow-lg:0 12px 40px rgba(15,23,42,.1),0 2px 6px rgba(15,23,42,.04);
  --shadow-xl:0 24px 60px rgba(15,23,42,.12);
  --radius:12px;--radius-lg:18px;--radius-xl:24px;
}

/* ── Base ── */
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--text);background:var(--bg);
  -webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
button,input,textarea,select{font-family:var(--font)}

/* ── Layout ── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 40px}
.container-sm{max-width:800px;margin:0 auto;padding:0 40px}
.container-xs{max-width:640px;margin:0 auto;padding:0 40px}

/* ── Section spacing ── */
.section{padding:96px 40px}
.section-sm{padding:72px 40px}
.section-lg{padding:120px 40px}
.section-xl{padding:148px 40px}

/* ── Background helpers ── */
.bg-white{background:var(--white)}
.bg-soft{background:var(--bg-soft)}
.bg-subtle{background:var(--bg-subtle)}
.bg-dark{background:var(--gray-900);color:var(--white)}
.bg-grad-hero{background:var(--grad-hero)}
.bg-grad-primary{background:var(--grad-primary);color:var(--white)}
.bg-blue-xlight{background:var(--blue-xlight)}

/* ── Typography ── */
.section-tag{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.75rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;margin-bottom:14px
}
.tag-blue{background:var(--blue-xlight);color:var(--blue);border:1px solid var(--blue-light)}
.tag-indigo{background:var(--indigo-light);color:var(--indigo);border:1px solid var(--indigo-border)}
.tag-emerald{background:var(--emerald-xlight);color:var(--emerald);border:1px solid var(--emerald-light)}
.tag-amber{background:var(--amber-light);color:var(--amber);border:1px solid var(--amber-border)}
.tag-white{background:rgba(255,255,255,.12);color:#CBD5E1;border:1px solid rgba(255,255,255,.15)}
.tag-dark{background:rgba(255,255,255,.06);color:#94A3B8;border:1px solid rgba(255,255,255,.08)}

.section-title{font-size:clamp(1.875rem,3.5vw,2.75rem);font-weight:800;letter-spacing:-.04em;line-height:1.1}
.section-title-xl{font-size:clamp(2.25rem,4.5vw,3.25rem);font-weight:800;letter-spacing:-.04em;line-height:1.08}
.section-sub{font-size:1.0625rem;color:var(--text-soft);line-height:1.65;margin-top:12px;max-width:520px}
.section-sub.wide{max-width:680px}
.text-center{text-align:center}
.text-center .section-sub{margin-left:auto;margin-right:auto}
.text-white{color:var(--white)!important}
.text-muted-white{color:rgba(255,255,255,.65)!important}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:10px 20px;border-radius:10px;font-size:.9375rem;font-weight:600;
  text-decoration:none;transition:all .25s var(--ease);cursor:pointer;border:none;
  font-family:var(--font);letter-spacing:-.01em;white-space:nowrap;line-height:1.4
}
.btn-sm{padding:7px 14px;font-size:.8rem;border-radius:8px}
.btn-lg{padding:13px 26px;font-size:1rem;border-radius:12px}
.btn-xl{padding:16px 32px;font-size:1.0625rem;border-radius:14px}
.btn-full{width:100%;justify-content:center}

.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-1px);
  box-shadow:0 8px 24px rgba(37,99,235,.25)}

.btn-gradient{background:var(--grad-primary);color:#fff}
.btn-gradient:hover{opacity:.9;transform:translateY(-1px);
  box-shadow:0 10px 30px rgba(37,99,235,.3)}

.btn-dark{background:var(--gray-900);color:#fff}
.btn-dark:hover{background:var(--gray-800);transform:translateY(-1px);
  box-shadow:0 8px 24px rgba(15,23,42,.2)}

.btn-secondary{background:var(--white);color:var(--text);border:1.5px solid var(--border)}
.btn-secondary:hover{border-color:var(--gray-400);background:var(--gray-50)}

.btn-ghost{background:transparent;color:var(--text-soft)}
.btn-ghost:hover{background:var(--gray-100);color:var(--text)}

.btn-white{background:#fff;color:var(--blue-dark);font-weight:700}
.btn-white:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(15,23,42,.15)}

.btn-white-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.3)}
.btn-white-outline:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.6)}

.btn-emerald{background:var(--emerald);color:#fff}
.btn-emerald:hover{background:#047857;transform:translateY(-1px);
  box-shadow:0 8px 24px rgba(5,150,105,.25)}

/* ── NAVBAR ── */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background .35s var(--ease),border-color .35s,box-shadow .35s;
  border-bottom:1px solid transparent
}
.navbar.scrolled{
  background:rgba(255,255,255,.93);
  backdrop-filter:blur(20px) saturate(1.8);
  -webkit-backdrop-filter:blur(20px) saturate(1.8);
  border-bottom-color:var(--border);
  box-shadow:0 1px 20px rgba(15,23,42,.06)
}
.navbar.mob-open{
  background:rgba(255,255,255,.97)!important;
  backdrop-filter:blur(20px)!important;
  -webkit-backdrop-filter:blur(20px)!important;
  border-bottom-color:var(--border)!important;
  box-shadow:0 1px 20px rgba(15,23,42,.06)!important
}
.navbar-inner{
  max-width:var(--max-w);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 40px;height:72px
}
.nav-brand{
  display:flex;align-items:center;gap:10px;
  font-weight:800;font-size:21px;letter-spacing:-.04em;
  color:var(--text);text-decoration:none;flex-shrink:0
}
.nav-brand img{height:28px}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{
  font-size:.875rem;font-weight:500;color:var(--text-soft);
  text-decoration:none;padding:7px 13px;border-radius:8px;
  transition:color .15s,background .15s;letter-spacing:-.01em
}
.nav-links a:hover,.nav-links a.active{color:var(--text);background:var(--gray-100)}
.nav-right{display:flex;align-items:center;gap:8px}

/* Language selector */
.lang-sel{
  display:flex;align-items:center;gap:1px;
  background:var(--gray-100);border-radius:8px;
  padding:2px;border:1px solid var(--border)
}
.lang-sel a{
  font-size:.6875rem;font-weight:700;padding:4px 8px;border-radius:6px;
  color:var(--text-muted);text-decoration:none;
  transition:all .15s;letter-spacing:.03em;text-transform:uppercase
}
.lang-sel a.active{background:var(--white);color:var(--text);
  box-shadow:0 1px 3px rgba(15,23,42,.1)}
.lang-sel a:not(.active):hover{color:var(--text)}

/* ── Hamburger ── */
.hamburger{
  display:none;background:none;border:none;cursor:pointer;
  width:40px;height:40px;position:relative;flex-shrink:0
}
.hamburger span{
  display:block;width:22px;height:1.5px;background:var(--text);
  position:absolute;left:9px;transition:all .35s var(--ease);border-radius:2px
}
.hamburger span:nth-child(1){top:13px}
.hamburger span:nth-child(2){top:19.5px}
.hamburger span:nth-child(3){top:26px}
.hamburger.open span:nth-child(1){top:19.5px;transform:rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){top:19.5px;transform:rotate(-45deg)}

/* ── Mobile menu ── */
.mob-menu{
  display:none;position:fixed;top:72px;left:0;right:0;bottom:0;
  background:var(--white);padding:8px 20px 32px;z-index:999;
  flex-direction:column;border-top:1px solid var(--border);overflow-y:auto
}
.mob-menu.open{display:flex}
.mob-menu a.mob-link{
  font-size:1.0625rem;font-weight:600;color:var(--text);
  text-decoration:none;padding:14px 0;border-bottom:1px solid var(--border-light);display:block
}
.mob-menu .mob-actions{margin-top:20px;display:flex;flex-direction:column;gap:10px}
.mob-lang{margin-top:20px;display:flex;gap:8px;flex-wrap:wrap}
.mob-lang a{
  padding:6px 14px;border-radius:8px;font-size:.8125rem;font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;text-decoration:none;
  border:1.5px solid var(--border);color:var(--text-muted);transition:all .15s
}
.mob-lang a.active{background:var(--blue);color:#fff;border-color:var(--blue)}

/* ── Page hero (inner pages) — blanc & épuré ── */
.page-hero{
  padding:128px 40px 88px;
  background:#ffffff;
  background-image:radial-gradient(circle,#dde4f0 1.5px,transparent 1.5px);
  background-size:28px 28px;
  border-bottom:1px solid #E2E8F0;
}
.page-hero-inner{max-width:800px;margin:0 auto;display:flex;flex-direction:column;align-items:center;text-align:center}

/* ── Feature grid cards ── */
.feat-grid{display:grid;gap:16px}
.feat-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.feat-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.feat-grid.cols-4{grid-template-columns:repeat(4,1fr)}

.feat-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:28px;
  transition:all .3s var(--ease)
}
.feat-card:hover{
  border-color:var(--gray-300);box-shadow:var(--shadow-lg);transform:translateY(-2px)
}
.feat-icon{
  width:44px;height:44px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;margin-bottom:16px;flex-shrink:0
}
/* All icon variants → single monochromatic blue — avoids rainbow AI-pattern */
.feat-icon.blue,.feat-icon.indigo,.feat-icon.emerald,.feat-icon.amber{background:var(--blue-xlight);color:var(--blue)}
.feat-icon.dark{background:var(--gray-100);color:var(--gray-600)}
.feat-card h3{font-size:1rem;font-weight:700;letter-spacing:-.02em;margin-bottom:6px}
.feat-card p{font-size:.875rem;color:var(--text-soft);line-height:1.6}

/* ── Check list ── */
.check-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:20px}
.check-list li{display:flex;align-items:flex-start;gap:10px;font-size:.9375rem;color:var(--text-soft)}
.check-list li .ci{
  width:20px;height:20px;border-radius:6px;flex-shrink:0;
  background:var(--emerald-xlight);border:1px solid var(--emerald-light);
  display:flex;align-items:center;justify-content:center;
  font-size:9px;color:var(--emerald);margin-top:2px
}

/* ── Split row ── */
.split-row{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.split-row.reverse .split-content{order:2}
.split-row.reverse .split-visual{order:1}

/* ── Visual mock block ── */
.visual-block{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-xl);
  overflow:hidden;box-shadow:var(--shadow-xl);position:relative
}
.visual-chrome{
  background:var(--gray-50);border-bottom:1px solid var(--border);
  padding:12px 16px;display:flex;align-items:center;gap:10px
}
.visual-dots{display:flex;gap:6px}
.visual-dots span{width:10px;height:10px;border-radius:50%}
.visual-dots span:nth-child(1){background:#FC5F57}
.visual-dots span:nth-child(2){background:#FEBD2F}
.visual-dots span:nth-child(3){background:#27C840}
.visual-url{
  font-size:.75rem;color:var(--text-muted);font-family:monospace;
  background:var(--white);border:1px solid var(--border);
  border-radius:6px;padding:3px 10px;
}

/* ── Stats bar ── */
.stats-bar{
  display:flex;align-items:center;justify-content:center;
  gap:48px;flex-wrap:wrap
}
.stat-item{text-align:center}
.stat-num{font-size:2rem;font-weight:800;letter-spacing:-.05em;line-height:1}
.stat-num.blue{color:var(--blue)}
.stat-num.emerald{color:var(--emerald)}
.stat-num.indigo{color:var(--indigo)}
.stat-label{font-size:.8125rem;color:var(--text-muted);margin-top:4px}
.stat-divider{width:1px;height:40px;background:var(--border)}

/* ── Pricing cards ── */
.plan-grid{display:grid;gap:20px;align-items:stretch}
.plan-grid.cols-2{grid-template-columns:repeat(2,1fr);max-width:780px;margin:0 auto}
.plan-grid.cols-3{grid-template-columns:repeat(3,1fr);max-width:980px;margin:0 auto}

.plan-card{
  background:var(--white);border:2px solid var(--border);
  border-radius:var(--radius-xl);padding:36px 32px;
  position:relative;display:flex;flex-direction:column;
  transition:all .3s var(--ease)
}
.plan-card:hover{box-shadow:var(--shadow-lg)}
.plan-card.featured{
  border-color:var(--blue);
  box-shadow:0 0 0 1px var(--blue),0 12px 40px rgba(37,99,235,.12)
}
.plan-badge{
  position:absolute;top:-13px;left:28px;
  background:var(--blue);color:#fff;
  font-size:.6875rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  padding:4px 14px;border-radius:999px
}
.plan-badge.emerald{background:var(--emerald)}
.plan-name{font-size:1.0625rem;font-weight:700;letter-spacing:-.02em}
.plan-price{
  font-size:2.875rem;font-weight:800;letter-spacing:-.05em;
  line-height:1;margin-top:10px;display:flex;align-items:baseline;gap:3px
}
.plan-price sup{font-size:1.125rem;font-weight:700;margin-bottom:.5rem;margin-right:1px}
.plan-price .period{font-size:.9375rem;font-weight:500;color:var(--text-muted)}
.plan-desc{font-size:.875rem;color:var(--text-muted);margin-top:6px;line-height:1.5}
.plan-divider{border:none;border-top:1px solid var(--border);margin:24px 0}
.plan-features{list-style:none;display:flex;flex-direction:column;gap:10px;flex:1}
.plan-features li{
  display:flex;align-items:flex-start;gap:9px;
  font-size:.875rem;color:var(--text-soft)
}
.plan-features li i{font-size:.75rem;flex-shrink:0;margin-top:3px}
.plan-features li i.fa-check{color:var(--emerald)}
.plan-features li i.fa-xmark{color:var(--gray-300)}
.plan-cta{margin-top:28px}

/* ── Pricing toggle ── */
.plan-toggle-wrap{display:flex;justify-content:center;margin-bottom:44px}
.plan-toggle{
  display:inline-flex;background:var(--gray-100);
  border-radius:999px;padding:4px;border:1px solid var(--border)
}
.ptab{
  padding:10px 28px;border-radius:999px;font-size:.9375rem;font-weight:600;
  cursor:pointer;transition:all .25s;color:var(--text-muted);
  border:none;background:transparent;font-family:var(--font);letter-spacing:-.01em
}
.ptab.active{background:var(--white);color:var(--text);
  box-shadow:0 2px 8px rgba(15,23,42,.08)}

/* ── FAQ ── */
.faq-list{
  max-width:760px;margin:0 auto;display:flex;flex-direction:column;
  border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden
}
.faq-item{border-bottom:1px solid var(--border)}
.faq-item:last-child{border-bottom:none}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;background:var(--white);border:none;cursor:pointer;
  font-family:var(--font);font-size:.9375rem;font-weight:600;
  color:var(--text);text-align:left;gap:16px;transition:background .15s
}
.faq-q:hover{background:var(--gray-50)}
.faq-chevron{
  width:26px;height:26px;border-radius:50%;border:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;color:var(--text-muted);flex-shrink:0;
  transition:all .3s var(--ease)
}
.faq-item.open .faq-chevron{background:var(--blue);border-color:var(--blue);color:#fff;transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-item.open .faq-a{max-height:360px}
.faq-a-in{padding:0 24px 22px;font-size:.9375rem;color:var(--text-soft);line-height:1.7}

/* ── Comparison table ── */
.compare-table{width:100%;border-collapse:collapse;border-radius:var(--radius-lg);overflow:hidden}
.compare-table th,.compare-table td{padding:14px 20px;font-size:.875rem;text-align:left}
.compare-table thead tr{background:var(--gray-900);color:#fff}
.compare-table thead th{font-weight:700;letter-spacing:-.01em}
.compare-table thead th:not(:first-child){text-align:center}
.compare-table tbody tr{border-bottom:1px solid var(--border);background:var(--white)}
.compare-table tbody tr:last-child{border-bottom:none}
.compare-table tbody tr:nth-child(even){background:var(--gray-50)}
.compare-table td:not(:first-child){text-align:center}
.compare-table .cat-row td{
  font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  color:var(--text-muted);padding-top:20px;padding-bottom:8px;background:var(--white)
}

/* ── Integration card ── */
.integ-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--radius);padding:20px;
  display:flex;align-items:center;gap:14px;
  transition:all .25s var(--ease)
}
.integ-card:hover{
  border-color:var(--blue-light);
  box-shadow:0 4px 16px rgba(37,99,235,.08);
  transform:translateY(-1px)
}
.integ-icon{
  width:44px;height:44px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px
}
.integ-card h4{font-size:.9375rem;font-weight:700;letter-spacing:-.01em}
.integ-card p{font-size:.8125rem;color:var(--text-muted)}

/* ── Step / how-it-works ── */
.steps{display:flex;flex-direction:column;gap:32px}
.step{display:flex;gap:20px;align-items:flex-start}
.step-num{
  width:40px;height:40px;border-radius:12px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:.875rem;font-weight:800;letter-spacing:-.02em
}
.step-num.blue{background:var(--blue);color:#fff}
.step-num.indigo{background:var(--indigo);color:#fff}
.step-num.emerald{background:var(--emerald);color:#fff}
.step h3{font-size:1rem;font-weight:700;letter-spacing:-.02em;margin-bottom:4px}
.step p{font-size:.875rem;color:var(--text-soft);line-height:1.65}

/* ── Pills / badges ── */
.pill{
  display:inline-flex;align-items:center;gap:5px;padding:4px 12px;
  border-radius:999px;font-size:.75rem;font-weight:600
}
.pill-blue{background:var(--blue-light);color:var(--blue-dark)}
.pill-emerald{background:var(--emerald-light);color:var(--emerald)}
.pill-gray{background:var(--gray-100);color:var(--gray-600)}
.pill-amber{background:var(--amber-light);color:var(--amber)}

/* ── Contact form ── */
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{font-size:.8125rem;font-weight:600;color:var(--text)}
.form-control{
  font-family:var(--font);font-size:.9375rem;padding:11px 14px;
  border-radius:10px;border:1.5px solid var(--border);
  background:var(--white);color:var(--text);
  transition:border-color .2s,box-shadow .2s;outline:none;width:100%
}
.form-control:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
textarea.form-control{min-height:130px;resize:vertical}
select.form-control{cursor:pointer}
.form-row{display:flex;gap:14px}
.form-row .form-group{flex:1}

/* ── FOOTER ── */
.footer{background:var(--gray-900);color:#94A3B8}
.footer-main{padding:72px 40px 48px}
.footer-inner{max-width:var(--max-w);margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:48px}

.footer-logo{
  display:flex;align-items:center;gap:10px;
  font-weight:800;font-size:1.25rem;letter-spacing:-.04em;
  color:#F8FAFC;text-decoration:none
}
.footer-logo img{height:26px}
.footer-desc{font-size:.875rem;line-height:1.65;max-width:260px;margin-top:12px;color:#64748B}
.footer-socials{display:flex;gap:8px;margin-top:20px}
.footer-socials a{
  width:36px;height:36px;border-radius:9px;border:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;
  color:#64748B;font-size:15px;text-decoration:none;transition:all .2s
}
.footer-socials a:hover{border-color:var(--blue);color:var(--blue)}
.footer-lang{
  display:inline-flex;border-radius:8px;overflow:hidden;
  border:1px solid rgba(255,255,255,.08);margin-top:18px
}
.footer-lang a{
  padding:6px 12px;font-size:.6875rem;font-weight:700;text-decoration:none;
  color:#64748B;transition:all .15s;letter-spacing:.04em;text-transform:uppercase
}
.footer-lang a.active{background:var(--blue);color:#fff}
.footer-lang a:not(.active):hover{background:rgba(255,255,255,.05);color:#94A3B8}

.footer-col h4{
  font-size:.6875rem;font-weight:700;color:#F8FAFC;
  text-transform:uppercase;letter-spacing:.09em;margin-bottom:16px
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer-col ul li a{font-size:.875rem;color:#64748B;text-decoration:none;transition:color .15s}
.footer-col ul li a:hover{color:#F8FAFC}

.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding:20px 40px}
.footer-bottom-inner{
  max-width:var(--max-w);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px
}
.footer-copy{font-size:.8125rem;color:#475569}
.footer-legal{display:flex;gap:20px;flex-wrap:wrap}
.footer-legal a{font-size:.8125rem;color:#475569;text-decoration:none;transition:color .15s}
.footer-legal a:hover{color:#F8FAFC}
.footer-legal button{
  font-size:.8125rem;color:#475569;background:none;border:none;cursor:pointer;
  padding:0;font-family:var(--font);transition:color .15s
}
.footer-legal button:hover{color:#F8FAFC}

/* ── CTA section ── */
.cta-section{
  padding:96px 40px;background:var(--grad-primary);color:#fff;
  text-align:center;position:relative;overflow:hidden
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 60% at 50% 100%,rgba(255,255,255,.08) 0%,transparent 70%);
  pointer-events:none
}
.cta-inner{max-width:620px;margin:0 auto;position:relative}
.cta-title{font-size:clamp(1.875rem,3.5vw,2.5rem);font-weight:800;letter-spacing:-.04em;line-height:1.1}
.cta-sub{font-size:1.0625rem;opacity:.85;line-height:1.65;margin-top:12px}
.cta-actions{margin-top:32px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ── Reveal animations ── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.reveal.visible{opacity:1;transform:none}
.rd1{transition-delay:.07s}.rd2{transition-delay:.14s}.rd3{transition-delay:.21s}.rd4{transition-delay:.28s}

/* ── Swiss flag accent ── */
.swiss-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--white);border:1px solid var(--border);
  border-radius:999px;padding:6px 14px;font-size:.8125rem;font-weight:600;
  color:var(--text-soft);box-shadow:var(--shadow-sm)
}
.swiss-badge img,.swiss-badge .flag{height:14px;border-radius:2px}

/* ── Responsive ── */
@media(max-width:1024px){
  .split-row{gap:48px}
  .footer-grid{grid-template-columns:2fr 1fr 1fr}
}

@media(max-width:768px){
  .navbar-inner{padding:0 16px 0 20px}
  .nav-links,.nav-right{display:none}
  .hamburger{display:block;margin-right:4px}
  .section,.section-sm,.section-lg,.section-xl{padding-left:20px;padding-right:20px}
  .page-hero{padding:100px 20px 60px}
  .container,.container-sm,.container-xs{padding:0 20px}
  .split-row{grid-template-columns:1fr;gap:40px}
  .split-row.reverse .split-content,.split-row.reverse .split-visual{order:unset}
  .feat-grid.cols-2,.feat-grid.cols-3,.feat-grid.cols-4{grid-template-columns:1fr}
  .plan-grid.cols-2,.plan-grid.cols-3{grid-template-columns:1fr}
  .stats-bar{gap:28px}
  .stat-divider{display:none}
  .form-row{flex-direction:column}
  .cta-section{padding:72px 20px}
  .cta-actions{flex-direction:column;align-items:center}
  .footer-main{padding:48px 20px 32px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .footer-bottom{padding:16px 20px}
  .footer-bottom-inner{flex-direction:column;align-items:flex-start;gap:10px}
  .footer-legal{gap:12px}
  .faq-list{margin:0}
}

@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .plan-grid.cols-2,.plan-grid.cols-3{grid-template-columns:1fr}
  .feat-grid.cols-2{grid-template-columns:1fr}
  /* Boutons pleine largeur sur très petit écran */
  .hero-btns .btn{width:100%;justify-content:center}
  /* Footer */
  .footer-top{padding:48px 16px 32px}
  .footer-bottom{padding:14px 16px}
  /* Sections */
  .section,.section-sm,.section-lg,.section-xl{padding-left:16px;padding-right:16px}
  .container,.container-sm,.container-xs{padding:0 16px}
  /* Contact form file inputs */
  .form-group input[type="file"]{font-size:.8125rem}
}

/* ============================================================
   EXTENSIONS v2.1 — nouvelles pages + refonte homepage
   ============================================================ */

/* ── Footer variants (nouvelles pages) ── */
.footer-top{padding:72px 40px 48px}
.footer-tagline{font-size:.875rem;line-height:1.65;max-width:280px;margin-top:12px;color:#64748B}
/* footer-brand-col hérite de footer-col sans surcharge */

/* ── Check-item (div-based, nouvelles pages) ── */
.check-item{display:flex;align-items:flex-start;gap:10px;font-size:.9375rem;color:var(--text-soft);line-height:1.55}
.check-item i{color:var(--emerald);font-size:.75rem;margin-top:4px;flex-shrink:0}
.check-item>span{flex:1}

/* ── FAQ v2 selectors (faq.html, contact.html) ── */
.faq-trigger{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;background:var(--white);border:none;cursor:pointer;
  font-family:var(--font);font-size:.9375rem;font-weight:600;
  color:var(--text);text-align:left;gap:16px;transition:background .15s
}
.faq-trigger:hover{background:var(--gray-50)}
.faq-trigger .faq-chevron{
  font-size:.75rem;color:var(--text-muted);flex-shrink:0;
  transition:transform .3s var(--ease)
}
.faq-item.open .faq-trigger .faq-chevron{transform:rotate(180deg);color:var(--blue)}
.faq-body{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.faq-item.open .faq-body{max-height:500px}
.faq-body p{padding:0 24px 22px;font-size:.9375rem;color:var(--text-soft);line-height:1.7}
.faq-body p a{color:var(--blue)}

/* ── Homepage hero (index.html) ── */
.hero-home{
  padding-top:72px;/* navbar offset */
  background:#fff;
  background-image:radial-gradient(circle,#dde4f0 1.5px,transparent 1.5px);
  background-size:28px 28px;
  position:relative;overflow:hidden
}
.hero-home::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:240px;
  background:linear-gradient(to top,#fff 30%,transparent);pointer-events:none;z-index:1
}
.hero-home-content{
  text-align:center;padding:88px 0 72px;
  display:flex;flex-direction:column;align-items:center;
  position:relative;z-index:2
}
.hero-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;border:1px solid var(--border);border-radius:999px;
  padding:6px 16px 6px 10px;font-size:.8rem;font-weight:600;color:var(--text-soft);
  box-shadow:0 1px 6px rgba(15,23,42,.07);margin-bottom:28px
}
.hero-pill .pill-dot{
  width:20px;height:20px;border-radius:50%;background:var(--emerald-xlight);
  display:flex;align-items:center;justify-content:center;font-size:.625rem;color:var(--emerald)
}
.hero-h1{
  font-size:clamp(2.75rem,6vw,4.75rem);font-weight:800;
  letter-spacing:-.055em;line-height:1.0;color:var(--gray-900);
  max-width:700px
}
.hero-desc{
  font-size:1.125rem;color:var(--text-soft);line-height:1.65;
  max-width:500px;margin-top:20px
}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:36px}
.hero-trust-row{
  display:flex;flex-wrap:wrap;gap:8px 20px;justify-content:center;
  margin-top:20px
}
.hero-trust-row span{
  display:flex;align-items:center;gap:5px;
  font-size:.8125rem;color:var(--text-muted);font-weight:500
}
.hero-trust-row span i{font-size:.5rem;color:var(--emerald)}

/* ── Hero product shot ── */
.hero-shot-wrap{position:relative;z-index:2;padding:0 40px;padding-bottom:0}
.hero-browser{
  max-width:1000px;margin:0 auto;
  background:#fff;border:1px solid var(--gray-200);
  border-radius:16px 16px 0 0;
  box-shadow:0 40px 100px rgba(15,23,42,.14),0 0 0 1px rgba(15,23,42,.04);
  overflow:hidden
}
.hb-bar{
  background:var(--gray-50);border-bottom:1px solid var(--border);
  padding:11px 16px;display:flex;align-items:center;gap:10px;flex-shrink:0
}
.hb-dots{display:flex;gap:5px}
.hb-dots span{width:10px;height:10px;border-radius:50%}
.hb-dots span:nth-child(1){background:#FC5F57}
.hb-dots span:nth-child(2){background:#FEBD2F}
.hb-dots span:nth-child(3){background:#27C840}
.hb-url{
  flex:1;max-width:280px;background:#fff;border:1px solid var(--border);
  border-radius:6px;padding:4px 12px;font-size:.6875rem;color:var(--text-muted);
  font-family:monospace
}
.hb-body{display:flex;height:380px}
.hb-sidebar{
  width:192px;background:#0F172A;flex-shrink:0;
  display:flex;flex-direction:column;overflow:hidden
}
.hb-sidebar-brand{
  padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.06);
  font-size:.9375rem;font-weight:800;color:#F8FAFC;letter-spacing:-.04em;
  display:flex;align-items:center;gap:8px
}
.hb-sidebar-brand-dot{width:22px;height:22px;border-radius:6px;background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:.625rem;color:#fff;font-weight:800}
.hb-nav-group{padding:12px 0}
.hb-nav-label{font-size:.5625rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#334155;padding:4px 18px 8px}
.hb-nav-item{
  display:flex;align-items:center;gap:9px;padding:8px 18px;
  font-size:.8125rem;font-weight:500;cursor:default;transition:background .1s
}
.hb-nav-item i{width:14px;text-align:center;font-size:.75rem;opacity:.7}
.hb-nav-item.active{background:rgba(37,99,235,.18);color:#93C5FD}
.hb-nav-item.active i{opacity:1;color:#60A5FA}
.hb-nav-item:not(.active){color:#475569}
.hb-main{flex:1;background:#F8FAFC;display:flex;flex-direction:column;overflow:hidden}
.hb-topbar{
  background:#fff;border-bottom:1px solid var(--border);
  padding:12px 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0
}
.hb-page-title{font-size:.875rem;font-weight:700;color:var(--text);letter-spacing:-.02em}
.hb-topbar-right{display:flex;align-items:center;gap:8px}
.hb-date{font-size:.6875rem;color:var(--text-muted)}
.hb-action{
  background:var(--blue);color:#fff;border:none;border-radius:7px;
  padding:5px 12px;font-size:.6875rem;font-weight:700;font-family:var(--font);cursor:default;
  display:flex;align-items:center;gap:5px
}
.hb-content{flex:1;padding:16px;display:flex;flex-direction:column;gap:12px;overflow:hidden}
.hb-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.hb-kpi{background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.hb-kpi-lbl{font-size:.5625rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}
.hb-kpi-val{font-size:.9375rem;font-weight:800;letter-spacing:-.03em;color:var(--text);margin-top:4px}
.hb-kpi-chg{font-size:.5625rem;font-weight:600;margin-top:3px;display:flex;align-items:center;gap:2px}
.hb-kpi-chg.up{color:var(--emerald)}.hb-kpi-chg.neutral{color:var(--text-muted)}.hb-kpi-chg.warn{color:var(--amber)}
.hb-bottom-row{display:grid;grid-template-columns:1fr 1.6fr;gap:10px;flex:1;min-height:0}
.hb-chart-box{background:#fff;border:1px solid var(--border);border-radius:10px;padding:14px;display:flex;flex-direction:column}
.hb-chart-title{font-size:.5625rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:10px}
.hb-bars{display:flex;align-items:flex-end;gap:4px;flex:1}
.hb-bar-el{flex:1;border-radius:3px 3px 0 0;min-width:0;background:var(--blue-light)}
.hb-bar-el.hi{background:var(--blue)}
.hb-invoice-box{background:#fff;border:1px solid var(--border);border-radius:10px;overflow:hidden}
.hb-inv-head{
  display:grid;grid-template-columns:1fr auto auto;
  padding:8px 14px;background:var(--gray-50);border-bottom:1px solid var(--border);
  font-size:.5625rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)
}
.hb-inv-row{
  display:grid;grid-template-columns:1fr auto auto;gap:8px;
  padding:8px 14px;border-bottom:1px solid var(--border-light);align-items:center
}
.hb-inv-row:last-child{border-bottom:none}
.hb-inv-name{font-size:.6875rem;font-weight:600;color:var(--text)}
.hb-inv-sub{font-size:.5625rem;color:var(--text-muted)}
.hb-inv-amt{font-size:.6875rem;font-weight:700;color:var(--text)}
.hb-badge{font-size:.5625rem;font-weight:700;padding:2px 7px;border-radius:999px}
.hb-badge.paid{background:var(--emerald-light);color:var(--emerald)}
.hb-badge.pend{background:var(--amber-light);color:var(--amber)}
.hb-badge.sent{background:var(--blue-xlight);color:var(--blue-dark)}

/* ── Bento grid ── */
.bento-grid{display:grid;grid-template-columns:1.2fr 1fr;grid-template-rows:auto auto;gap:16px}
.bento-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px;overflow:hidden;position:relative;transition:box-shadow .3s var(--ease)}
.bento-card:hover{box-shadow:var(--shadow-lg)}
.bento-card.span-2{grid-row:span 2}
.bento-card.accent-blue{background:var(--blue);border-color:transparent;color:#fff}
.bento-card.accent-dark{background:var(--gray-900);border-color:transparent;color:#fff}
.bento-card.accent-emerald{background:var(--emerald);border-color:transparent;color:#fff}
.bento-card h3{font-size:1.125rem;font-weight:700;letter-spacing:-.03em;margin-bottom:8px}
.bento-card p{font-size:.875rem;line-height:1.6;color:var(--text-soft)}
.bento-card.accent-blue p,.bento-card.accent-dark p,.bento-card.accent-emerald p{color:rgba(255,255,255,.7)}
.bento-card h3.light{color:#fff}
.bento-tag{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;opacity:.6;margin-bottom:10px;display:block}

/* ── Stats band (homepage) ── */
.stats-band{padding:64px 40px;background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.stats-band-inner{max-width:var(--max-w);margin:0 auto;display:flex;justify-content:space-evenly;align-items:center;gap:32px;flex-wrap:wrap}
.sb-stat{text-align:center}
.sb-num{font-size:2.5rem;font-weight:800;letter-spacing:-.055em;color:var(--gray-900);line-height:1}
.sb-label{font-size:.875rem;color:var(--text-muted);margin-top:6px}
.sb-div{width:1px;height:48px;background:var(--border)}

/* ── Social proof band ── */
.proof-band{padding:40px;background:var(--gray-50);border-bottom:1px solid var(--border)}
.proof-band-inner{max-width:var(--max-w);margin:0 auto;display:flex;align-items:center;gap:40px;flex-wrap:wrap}
.proof-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);flex-shrink:0;white-space:nowrap}
.proof-items{display:flex;gap:24px;flex-wrap:wrap;align-items:center}
.proof-item{font-size:.875rem;font-weight:700;color:var(--gray-400);letter-spacing:-.01em;white-space:nowrap}

/* ── Responsive additions ── */
@media(max-width:1024px){
  .feat-grid.cols-4{grid-template-columns:repeat(2,1fr)}
  .bento-grid{grid-template-columns:1fr}
  .bento-card.span-2{grid-row:auto}
  .hb-kpis{grid-template-columns:repeat(2,1fr)}
  .hb-sidebar{width:160px}
  .stats-band-inner{gap:24px}
  .sb-div{display:none}
}
@media(max-width:768px){
  .hero-home-content{padding:64px 20px 48px}
  .hero-h1{font-size:2.5rem}
  .hero-desc{font-size:1rem}
  .hero-btns{flex-direction:column;align-items:stretch;width:100%;max-width:340px}
  .hero-shot-wrap{padding:0 16px}
  .hb-sidebar{display:none}
  .hb-bottom-row{grid-template-columns:1fr}
  .hb-chart-box{display:none}
  .proof-band-inner{flex-direction:column;align-items:flex-start;gap:16px}
  .stats-band{padding:48px 20px}
  .stats-band-inner{gap:28px}
}
@media(max-width:480px){
  .hero-h1{font-size:2rem;letter-spacing:-.04em}
  .hero-trust-row{gap:8px}
  .hb-kpis{grid-template-columns:1fr 1fr}
  .hb-body{height:260px}
}
