/* ============================================================
   KRM by Kapsule — Landing (maquette haute-fidélité)
   Design system : « Horlogerie Suisse » — précision, luxe discret.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --ink:#171717;
  --ink-soft:#3a3a3a;
  --accent:#e63946;
  --accent-ink:#c32b38;
  --canvas:#faf9f8;
  --surface:#ffffff;
  --surface-2:#f4f3f1;
  --border:#eaeaea;
  --border-strong:#dcdcda;
  --muted:#8c8c8c;
  --muted-2:#b4b3b1;

  --font-sans:"Geist", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-mono:"Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* density: piloté par les Tweaks (0.82 → 1.18) */
  --space-scale:1;
  /* corner radius scale + shadow depth: pilotés par les Tweaks */
  --radius-scale:1;
  --shadow-alpha:0.05;

  --r-card:calc(20px * var(--radius-scale));
  --r-btn:calc(14px * var(--radius-scale));
  --r-sm:calc(10px * var(--radius-scale));
  --r-pill:999px;

  --shadow-card:0 8px 30px rgba(23,23,23,var(--shadow-alpha));
  --shadow-card-lg:0 24px 70px rgba(23,23,23,calc(var(--shadow-alpha) * 2.1));
  --shadow-float:0 2px 8px rgba(23,23,23,calc(var(--shadow-alpha) * 1.1));

  --maxw:1200px;
  --gutter:clamp(20px, 5vw, 64px);
  --sec-pad:calc(120px * var(--space-scale));
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-sans);
  background:var(--canvas);
  color:var(--ink);
  line-height:1.5;
  font-weight:400;
  letter-spacing:-0.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img{max-width:100%;display:block}
::selection{background:var(--accent);color:#fff}

/* ---------- Type helpers ---------- */
.label{
  font-family:var(--font-mono);
  font-size:11px;
  font-weight:500;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--muted);
}
.display{
  font-weight:300;
  letter-spacing:-0.035em;
  line-height:0.98;
  text-wrap:balance;
}
.eyebrow-accent{color:var(--accent-ink)}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);width:100%}
section{position:relative}
.section{padding:var(--sec-pad) 0}
.section-head{max-width:760px;margin:0 auto calc(64px * var(--space-scale));text-align:center}
.section-head.left{margin-left:0;text-align:left}
.section-head .label{margin-bottom:20px;display:inline-block}
.section-head h2{
  font-weight:300;letter-spacing:-0.03em;line-height:1.04;
  font-size:clamp(34px, 4.6vw, 56px);
}
.section-head p{
  margin-top:22px;color:var(--muted);font-size:clamp(17px,1.4vw,19px);
  line-height:1.55;max-width:600px;
}
.section-head.center p{margin-left:auto;margin-right:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  height:52px;padding:0 26px;border-radius:var(--r-btn);
  font-size:15px;font-weight:500;letter-spacing:-0.01em;
  transition:transform .25s cubic-bezier(.2,.8,.3,1), box-shadow .25s, background .2s, color .2s;
  white-space:nowrap;
}
.btn .arr{transition:transform .25s cubic-bezier(.2,.8,.3,1)}
.btn:hover .arr{transform:translateX(3px)}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 8px 24px rgba(230,57,70,.28)}
.btn-accent:hover{background:var(--accent-ink);transform:translateY(-2px);box-shadow:0 14px 34px rgba(230,57,70,.34)}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{transform:translateY(-2px);box-shadow:var(--shadow-card-lg)}
.btn-ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1px var(--border-strong)}
.btn-ghost:hover{box-shadow:inset 0 0 0 1px var(--ink);transform:translateY(-2px)}
.btn-sm{height:42px;padding:0 18px;font-size:14px}
.btn-block{width:100%;justify-content:center}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background .3s, box-shadow .3s, backdrop-filter .3s;
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;
}
.nav.scrolled{
  background:rgba(250,249,248,.72);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  backdrop-filter:blur(20px) saturate(160%);
  box-shadow:0 1px 0 var(--border);
}
.brand{display:flex;align-items:baseline;gap:8px;letter-spacing:-0.02em}
.brand .krm{font-size:21px;font-weight:600;letter-spacing:-0.04em}
.brand .by{font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);font-weight:500}
.nav-links{display:flex;align-items:center;gap:38px}
.nav-links a{font-size:14.5px;color:var(--ink-soft);font-weight:400;transition:color .2s;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-5px;height:1.5px;background:var(--ink);transition:right .25s ease}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{right:0}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-burger{display:none;width:42px;height:42px;border-radius:var(--r-sm);align-items:center;justify-content:center;flex-direction:column;gap:4px}
.nav-burger span{width:18px;height:1.5px;background:var(--ink)}

/* ---------- Hero ---------- */
.hero{padding-top:150px;padding-bottom:90px;overflow:hidden}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;margin-bottom:30px}
.hero-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}
.hero-grid{display:grid;gap:60px;align-items:center}

/* typo-dominant (défaut) */
.hero[data-variant="typo"] .hero-grid{grid-template-columns:1fr;text-align:center;justify-items:center}
.hero[data-variant="typo"] .hero-title{font-size:clamp(56px, 11vw, 150px)}
.hero[data-variant="typo"] .hero-sub{max-width:620px;margin-left:auto;margin-right:auto}
.hero[data-variant="typo"] .hero-actions{justify-content:center}
.hero[data-variant="typo"] .hero-eyebrow{justify-content:center}
.hero[data-variant="typo"] .hero-stage{margin-top:clamp(48px,7vw,90px);max-width:1040px}

/* produit-dominant */
.hero[data-variant="produit"] .hero-grid{grid-template-columns:0.92fr 1.08fr;text-align:left}
.hero[data-variant="produit"] .hero-title{font-size:clamp(44px,5.6vw,84px)}
.hero[data-variant="produit"] .hero-sub{max-width:480px}
.hero[data-variant="produit"] .hero-stage{margin-top:0}
@media (max-width:900px){
  .hero[data-variant="produit"] .hero-grid{grid-template-columns:1fr;text-align:center;justify-items:center}
  .hero[data-variant="produit"] .hero-sub{margin-left:auto;margin-right:auto}
  .hero[data-variant="produit"] .hero-actions{justify-content:center}
  .hero[data-variant="produit"] .hero-eyebrow{justify-content:center}
}

.hero-title{font-weight:300;letter-spacing:-0.045em;line-height:0.92}
.hero-title .it{font-style:italic;font-weight:300}
.hero-sub{margin-top:30px;font-size:clamp(18px,1.55vw,21px);color:var(--ink-soft);line-height:1.5;font-weight:400}
.hero-actions{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap}
.hero-trust{margin-top:30px;font-family:var(--font-mono);font-size:11.5px;letter-spacing:0.04em;color:var(--muted);display:flex;align-items:center;gap:8px}
.hero-trust b{color:var(--ink);font-weight:500}

/* ---------- App window mockup ---------- */
.hero-stage{position:relative;width:100%}
.tilt{transform:perspective(1800px) rotateX(7deg) rotateY(-9deg) rotate(0.5deg);transform-style:preserve-3d}
.hero[data-variant="typo"] .tilt{transform:perspective(2200px) rotateX(9deg)}

.appwin{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:calc(16px * var(--radius-scale));
  box-shadow:var(--shadow-card-lg);
  overflow:hidden;
  position:relative;
}
.appwin-bar{
  display:flex;align-items:center;gap:14px;
  height:44px;padding:0 16px;
  border-bottom:1px solid var(--border);
  background:linear-gradient(var(--surface),var(--surface-2));
}
.dots{display:flex;gap:7px}
.dots i{width:11px;height:11px;border-radius:50%;background:var(--border-strong)}
.dots i:first-child{background:#f0a8ad}
.appwin-url{
  flex:1;height:26px;border-radius:8px;background:var(--surface-2);
  display:flex;align-items:center;padding:0 12px;
  font-family:var(--font-mono);font-size:11px;color:var(--muted);gap:7px;
}
.appwin-url .lock{width:9px;height:9px;border-radius:2px;background:var(--muted-2)}

.appwin-body{display:grid;grid-template-columns:200px 1fr}
.app-side{border-right:1px solid var(--border);padding:18px 14px;background:var(--surface);display:flex;flex-direction:column;gap:5px}
.app-side .side-brand{display:flex;align-items:baseline;gap:6px;padding:4px 8px 16px}
.app-side .side-brand .krm{font-weight:600;font-size:16px;letter-spacing:-0.03em}
.app-side .side-brand .by{font-family:var(--font-mono);font-size:8px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted)}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:9px;font-size:13px;color:var(--ink-soft)}
.nav-item .ic{width:15px;height:15px;border-radius:5px;background:var(--surface-2);box-shadow:inset 0 0 0 1px var(--border)}
.nav-item.active{background:var(--ink);color:#fff}
.nav-item.active .ic{background:rgba(255,255,255,.22);box-shadow:none}
.app-side .side-foot{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px 8px 0;border-top:1px solid var(--border)}
.avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#d9d7d3,#bcbab6);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff}
.app-side .side-foot .meta{font-size:11.5px;line-height:1.2}
.app-side .side-foot .meta b{display:block;font-weight:600;font-size:12px}
.app-side .side-foot .meta span{color:var(--muted);font-size:10px}

.app-main{padding:20px 22px;min-width:0}
.app-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.app-head .h-title{font-size:17px;font-weight:600;letter-spacing:-0.02em}
.app-head .h-title span{color:var(--muted);font-weight:400;font-size:13px;margin-left:8px}
.app-head .h-tools{display:flex;gap:8px}
.app-head .pill{height:28px;padding:0 12px;border-radius:8px;background:var(--surface-2);font-size:11.5px;display:flex;align-items:center;color:var(--ink-soft);font-weight:500}
.app-head .pill.accent{background:var(--accent);color:#fff}

/* Dashboard (hero) */
.dash-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:14px}
.kpi{background:var(--surface-2);border-radius:12px;padding:13px 14px;display:flex;flex-direction:column;gap:3px;position:relative}
.kpi-l{font-family:var(--font-mono);font-size:9.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted)}
.kpi-v{font-size:28px;font-weight:300;letter-spacing:-0.04em;line-height:1}
.kpi-v i{font-style:normal;font-size:14px;color:var(--muted);margin-left:2px;font-weight:400}
.kpi-d{font-family:var(--font-mono);font-size:10px;color:var(--muted);font-weight:500}
.kpi-d.up{color:#37a169}
.kpi.accent{background:var(--ink)}
.kpi.accent .kpi-l{color:rgba(255,255,255,.55)}
.kpi.accent .kpi-v{color:#fff}
.kpi.accent .kpi-v i{color:rgba(255,255,255,.5)}
.kpi.accent .kpi-d.up{color:#7bd6a2}
.dash-cols{display:grid;grid-template-columns:1.15fr 1fr;gap:12px}
.dash-card{background:var(--surface-2);border-radius:12px;padding:13px 14px;display:flex;flex-direction:column;gap:12px;min-width:0}
.dc-h{font-size:11.5px;font-weight:600;color:var(--ink-soft);display:flex;align-items:center;justify-content:space-between;gap:8px}
.dc-unit{font-family:var(--font-mono);font-size:8.5px;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted);background:var(--surface);padding:2px 6px;border-radius:5px}
.agenda{display:flex;flex-direction:column;gap:7px}
.ag-row{display:flex;align-items:center;gap:9px}
.ag-time{font-family:var(--font-mono);font-size:10px;color:var(--muted);width:32px;flex-shrink:0}
.ag-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}
.ag-row:nth-child(2) .ag-dot{background:var(--ink)}
.ag-row:nth-child(3) .ag-dot{background:var(--muted-2)}
.ag-t{min-width:0}
.ag-t b{display:block;font-size:11.5px;font-weight:600;letter-spacing:-0.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ag-t span{font-size:10px;color:var(--muted)}

/* Kanban */
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.kcol{background:var(--surface-2);border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:8px;min-width:0}
.kcol-h{display:flex;align-items:center;justify-content:space-between;font-size:11px;font-weight:600;color:var(--ink-soft);padding:2px 2px 4px}
.kcol-h .cnt{font-family:var(--font-mono);color:var(--muted);font-weight:500;font-size:10px}
.kcard{background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:10px;display:flex;flex-direction:column;gap:7px;box-shadow:var(--shadow-float)}
.kcard .nm{font-size:12px;font-weight:600;letter-spacing:-0.01em}
.kcard .ln{height:5px;border-radius:3px;background:var(--surface-2)}
.kcard .ln.w70{width:70%}.kcard .ln.w50{width:50%}.kcard .ln.w85{width:85%}
.kcard .foot{display:flex;align-items:center;justify-content:space-between;margin-top:2px}
.kcard .chf{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--ink)}
.kcard .tag{font-size:9px;font-family:var(--font-mono);letter-spacing:0.04em;text-transform:uppercase;padding:2px 6px;border-radius:5px;background:var(--surface-2);color:var(--muted)}
.kcard .tag.hot{background:rgba(230,57,70,.1);color:var(--accent-ink)}
.kcard .av{width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#d9d7d3,#bcbab6)}
.kcard.signed{box-shadow:0 0 0 1.5px rgba(230,57,70,.18),var(--shadow-float)}

/* ---------- Trust band ---------- */
.trust{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--surface)}
.trust-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border)}
.trust-cell{background:var(--surface);padding:30px 26px;display:flex;align-items:center;gap:16px}
.trust-mark{width:38px;height:38px;border-radius:10px;background:var(--canvas);box-shadow:inset 0 0 0 1px var(--border);flex-shrink:0;position:relative}
.swiss-cross{position:absolute;inset:0;margin:auto;width:16px;height:16px}
.swiss-cross::before,.swiss-cross::after{content:"";position:absolute;background:var(--accent);border-radius:1.5px}
.swiss-cross::before{left:6px;top:1px;width:4px;height:14px}
.swiss-cross::after{top:6px;left:1px;height:4px;width:14px}
.mark-ring{position:absolute;inset:0;margin:auto;width:15px;height:15px;border-radius:50%;border:2px solid var(--ink)}
.mark-shield{position:absolute;inset:0;margin:auto;width:14px;height:16px;background:var(--ink);border-radius:3px 3px 7px 7px;clip-path:polygon(0 0,100% 0,100% 55%,50% 100%,0 55%)}
.mark-doc{position:absolute;inset:0;margin:auto;width:13px;height:16px;background:var(--ink);border-radius:2px}
.mark-doc::after{content:"";position:absolute;inset:3px 3px auto 3px;height:2px;background:var(--surface);box-shadow:0 4px 0 var(--surface),0 8px 0 var(--surface)}
.trust-cell .t-txt b{display:block;font-size:13.5px;font-weight:600;letter-spacing:-0.01em}
.trust-cell .t-txt span{font-size:12px;color:var(--muted)}

/* ---------- Problème ---------- */
.problem{background:var(--canvas)}
.problem-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:70px;align-items:center}
.problem h2{font-weight:300;letter-spacing:-0.03em;font-size:clamp(32px,4vw,50px);line-height:1.06}
.problem h2 .strike{position:relative;white-space:nowrap}
.problem h2 .strike::after{content:"";position:absolute;left:-2%;right:-2%;top:54%;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .7s cubic-bezier(.6,0,.2,1)}
.problem h2 .strike.reveal-on::after{transform:scaleX(1)}
.problem p{margin-top:24px;color:var(--muted);font-size:18px;line-height:1.6;max-width:460px}
.problem-list{margin-top:30px;display:flex;flex-direction:column;gap:14px}
.problem-list .pl-item{display:flex;align-items:center;gap:13px;font-size:15px;color:var(--ink-soft)}
.problem-list .pl-item .x{width:22px;height:22px;border-radius:7px;background:rgba(230,57,70,.1);color:var(--accent-ink);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.clutter{position:relative;height:420px}
.clutter .note{position:absolute;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow-card);font-size:13px;color:var(--ink-soft);width:200px}
.clutter .note .nh{font-family:var(--font-mono);font-size:10px;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.clutter .note .ln{height:6px;border-radius:3px;background:var(--surface-2);margin-top:6px}
.clutter .note.n1{top:0;left:0;transform:rotate(-5deg)}
.clutter .note.n2{top:60px;right:0;transform:rotate(4deg)}
.clutter .note.n3{top:170px;left:30px;transform:rotate(2deg)}
.clutter .note.n4{bottom:0;right:24px;transform:rotate(-3deg)}
.clutter .stamp{position:absolute;bottom:36px;left:0;z-index:3;background:var(--ink);color:#fff;border-radius:var(--r-pill);padding:11px 20px;font-size:13px;font-weight:500;box-shadow:var(--shadow-card-lg);display:flex;align-items:center;gap:9px}
.clutter .stamp .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}

/* ---------- Bento features ---------- */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:18px;grid-auto-rows:minmax(220px,auto)}
.fcard{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);
  padding:26px;box-shadow:var(--shadow-card);overflow:hidden;position:relative;
  display:flex;flex-direction:column;
  transition:transform .35s cubic-bezier(.2,.8,.3,1), box-shadow .35s;
}
.fcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-card-lg)}
.fcard .f-ey{font-family:var(--font-mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.fcard .f-ey .d{width:5px;height:5px;border-radius:50%;background:var(--ink)}
.fcard h3{font-size:21px;font-weight:500;letter-spacing:-0.02em;line-height:1.12}
.fcard p{margin-top:10px;color:var(--muted);font-size:14.5px;line-height:1.5}
.fcard .f-viz{margin-top:auto;padding-top:22px}
.span-3{grid-column:span 3}.span-2{grid-column:span 2}.span-4{grid-column:span 4}.span-6{grid-column:span 6}
.row-2{grid-row:span 2}

/* mini viz */
/* Feature card : badge « bientôt » + état à venir */
.fcard.soon{background:linear-gradient(180deg,var(--surface),var(--surface-2))}
.soon-badge{position:absolute;top:22px;right:22px;font-family:var(--font-mono);font-size:9px;letter-spacing:0.1em;text-transform:uppercase;background:var(--canvas);color:var(--ink-soft);box-shadow:inset 0 0 0 1px var(--border-strong);padding:4px 9px;border-radius:6px;font-weight:500}
.mini-doc.soon{opacity:.92}
.mini-doc.soon .v.ai{color:var(--muted);font-style:normal}
.mini-doc.soon .mini-field{border-style:dashed}

/* Vue 360° : éléments rattachés au client */
.mini-attach{display:flex;flex-direction:column;gap:8px}
.att-row{display:flex;align-items:center;gap:11px;padding:9px 11px;background:var(--canvas);border:1px solid var(--border);border-radius:10px}
.att-ic{width:26px;height:26px;border-radius:7px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;background:var(--surface);box-shadow:inset 0 0 0 1px var(--border);color:var(--ink-soft)}
.att-ic.sign{background:var(--accent);color:#fff;box-shadow:none}
.att-t{flex:1;min-width:0}
.att-t b{display:block;font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.att-t span{font-size:10.5px;color:var(--muted)}
.mr-tag.ok{color:#37a169;background:rgba(55,161,105,.1)}

.mini-list{display:flex;flex-direction:column;gap:8px}
.mini-row{display:flex;align-items:center;gap:11px;padding:9px 11px;background:var(--canvas);border:1px solid var(--border);border-radius:10px}
.mini-row .av{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#d9d7d3,#bcbab6);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;font-weight:600}
.mini-row .mr-t{flex:1;min-width:0}
.mini-row .mr-t b{display:block;font-size:12.5px;font-weight:600}
.mini-row .mr-t span{font-size:10.5px;color:var(--muted);font-family:var(--font-mono)}
.mini-row .mr-tag{font-size:9px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.05em;color:var(--muted);padding:3px 7px;border-radius:6px;background:var(--surface)}

.mini-doc{background:var(--canvas);border:1px solid var(--border);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:10px}
.mini-doc .md-h{display:flex;align-items:center;gap:10px}
.mini-doc .md-h .fi{width:30px;height:36px;border-radius:5px;background:var(--surface);box-shadow:inset 0 0 0 1px var(--border);position:relative;flex-shrink:0}
.mini-doc .md-h .fi::after{content:"PDF";position:absolute;bottom:4px;left:0;right:0;text-align:center;font-family:var(--font-mono);font-size:6px;color:var(--accent-ink);font-weight:700}
.mini-doc .md-h b{font-size:12.5px;font-weight:600}
.mini-doc .md-h span{font-size:10px;color:var(--muted);font-family:var(--font-mono)}
.mini-field{display:flex;align-items:center;justify-content:space-between;padding:8px 11px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-size:11.5px}
.mini-field .k{color:var(--muted)}
.mini-field .v{font-weight:600;font-family:var(--font-mono);font-size:11px}
.mini-field .v.ai{color:var(--accent-ink);display:flex;align-items:center;gap:5px}
.mini-field .v.ai .sp{width:5px;height:5px;border-radius:50%;background:var(--accent)}

.mini-chart{display:flex;align-items:flex-end;gap:9px;height:90px;padding:0 2px}
.mini-chart .bar{flex:1;background:var(--surface-2);border-radius:5px 5px 0 0;position:relative;min-width:0}
.mini-chart .bar.hl{background:var(--ink)}
.mini-chart .bar.acc{background:var(--accent)}

.mini-karnet{background:var(--ink);color:#fff;border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:12px}
.mini-karnet .mk-h{display:flex;align-items:center;justify-content:space-between}
.mini-karnet .mk-h b{font-size:13px;font-weight:600}
.mini-karnet .mk-h .timer{font-family:var(--font-mono);font-size:11px;color:#fff;background:rgba(255,255,255,.14);padding:3px 9px;border-radius:6px}
.mini-karnet .mk-bar{height:7px;border-radius:4px;background:rgba(255,255,255,.16);overflow:hidden}
.mini-karnet .mk-bar i{display:block;height:100%;width:78%;background:var(--accent);border-radius:4px}
.mini-karnet .mk-goals{display:flex;flex-direction:column;gap:8px}
.mini-karnet .mk-goal{display:flex;align-items:center;gap:9px;font-size:11.5px;color:rgba(255,255,255,.85)}
.mini-karnet .mk-goal .ck{width:16px;height:16px;border-radius:5px;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;font-size:9px}
.mini-karnet .mk-goal.done .ck{background:var(--accent)}

.mini-inbox{display:flex;flex-direction:column;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.mini-mail{background:var(--surface);padding:10px 12px;display:flex;gap:10px;align-items:flex-start}
.mini-mail.unread{background:var(--canvas)}
.mini-mail .dotr{width:6px;height:6px;border-radius:50%;background:var(--accent);margin-top:5px;flex-shrink:0;opacity:0}
.mini-mail.unread .dotr{opacity:1}
.mini-mail .mm-t{flex:1;min-width:0}
.mini-mail .mm-t b{font-size:12px;font-weight:600;display:flex;justify-content:space-between}
.mini-mail .mm-t b span{font-family:var(--font-mono);font-size:9.5px;color:var(--muted);font-weight:500}
.mini-mail .mm-t p{margin-top:3px;font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.mini-board{display:flex;flex-direction:column;gap:7px}
.mini-board .mb-row{display:flex;align-items:center;gap:11px;padding:8px 11px;border-radius:9px;background:var(--canvas);border:1px solid var(--border)}
.mini-board .mb-row.lead{background:var(--ink);border-color:var(--ink)}
.mini-board .rk{font-family:var(--font-mono);font-size:12px;font-weight:600;width:18px;color:var(--muted)}
.mini-board .mb-row.lead .rk{color:var(--accent)}
.mini-board .av{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#d9d7d3,#bcbab6);display:flex;align-items:center;justify-content:center;font-size:9px;color:#fff;font-weight:600}
.mini-board .nm{flex:1;font-size:12.5px;font-weight:600}
.mini-board .mb-row.lead .nm{color:#fff}
.mini-board .sc{font-family:var(--font-mono);font-size:12px;font-weight:600}
.mini-board .mb-row.lead .sc{color:#fff}

/* ---------- Pourquoi Kapsule ---------- */
.why{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.why-cell{padding:38px 30px 38px 0;position:relative}
.why-cell:not(:last-child){border-right:1px solid var(--border);padding-right:30px}
.why-cell:not(:first-child){padding-left:30px}
.why-num{font-family:var(--font-mono);font-size:12px;color:var(--accent-ink);letter-spacing:0.06em;margin-bottom:20px;font-weight:500}
.why-cell h3{font-size:20px;font-weight:500;letter-spacing:-0.02em;line-height:1.15}
.why-cell p{margin-top:12px;font-size:14px;color:var(--muted);line-height:1.55}

/* ---------- Tarifs ---------- */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.pcard{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);
  padding:32px 30px;display:flex;flex-direction:column;box-shadow:var(--shadow-card);
  position:relative;transition:transform .35s cubic-bezier(.2,.8,.3,1),box-shadow .35s;
}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-card-lg)}
.pcard.featured{border-color:var(--ink);box-shadow:var(--shadow-card-lg);transform:translateY(-8px)}
.pcard.featured:hover{transform:translateY(-12px)}
.pcard .p-badge{position:absolute;top:24px;right:24px;font-family:var(--font-mono);font-size:9.5px;letter-spacing:0.1em;text-transform:uppercase;background:var(--accent);color:#fff;padding:5px 10px;border-radius:7px;font-weight:500}
.pcard .p-name{font-size:14px;font-weight:600;letter-spacing:0.02em}
.pcard .p-desc{margin-top:6px;font-size:13px;color:var(--muted);min-height:38px}
.pcard .p-price{margin-top:24px;display:flex;align-items:baseline;gap:6px}
.pcard .p-price .amt{font-size:46px;font-weight:300;letter-spacing:-0.04em}
.pcard .p-price .cur{font-family:var(--font-mono);font-size:14px;color:var(--muted);font-weight:500}
.pcard .p-price .per{font-size:13px;color:var(--muted)}
.pcard .p-price.custom .amt{font-size:34px}
.pcard .p-extra{margin-top:10px;font-size:12px;color:var(--muted);font-family:var(--font-mono);letter-spacing:0.01em}
.pcard .p-trial{margin-top:18px;display:inline-flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-soft);background:var(--canvas);padding:7px 12px;border-radius:8px;align-self:flex-start;border:1px solid var(--border)}
.pcard .p-trial .dot{width:6px;height:6px;border-radius:50%;background:#37a169}
.pcard ul{list-style:none;margin:24px 0 28px;display:flex;flex-direction:column;gap:13px}
.pcard ul li{display:flex;align-items:flex-start;gap:11px;font-size:14px;color:var(--ink-soft);line-height:1.4}
.pcard ul li .ck{width:18px;height:18px;border-radius:6px;background:var(--canvas);box-shadow:inset 0 0 0 1px var(--border);display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--ink);flex-shrink:0;margin-top:1px}
.pcard.featured ul li .ck{background:var(--ink);color:#fff;box-shadow:none}
.pcard .p-cta{margin-top:auto}

/* First Love */
.firstlove{
  margin-top:24px;background:var(--ink);color:#fff;border-radius:var(--r-card);
  padding:44px;display:grid;grid-template-columns:1.15fr 0.85fr;gap:48px;align-items:center;
  position:relative;overflow:hidden;box-shadow:var(--shadow-card-lg);
}
.firstlove::before{content:"";position:absolute;top:-40%;right:-10%;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(230,57,70,.32),transparent 70%)}
.fl-l{position:relative;z-index:1}
.fl-tag{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;background:var(--accent);color:#fff;padding:7px 13px;border-radius:var(--r-pill);font-weight:500;margin-bottom:22px}
.fl-tag .star{font-size:12px}
.fl-l h3{font-size:clamp(28px,3vw,40px);font-weight:300;letter-spacing:-0.03em;line-height:1.05}
.fl-l h3 b{font-weight:500;color:var(--accent)}
.fl-l p{margin-top:18px;color:rgba(255,255,255,.7);font-size:15px;line-height:1.55;max-width:440px}
.fl-points{margin-top:24px;display:flex;flex-direction:column;gap:11px}
.fl-points .flp{display:flex;align-items:center;gap:11px;font-size:14px;color:rgba(255,255,255,.9)}
.fl-points .flp .ck{width:18px;height:18px;border-radius:6px;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;flex-shrink:0}
.fl-r{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:18px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:30px}
.fl-counter{font-family:var(--font-mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.fl-count-num{font-weight:300;letter-spacing:-0.04em;line-height:1}
.fl-count-num .now{font-size:84px;color:var(--accent)}
.fl-count-num .tot{font-size:40px;color:rgba(255,255,255,.4)}
.fl-dots{display:flex;gap:9px}
.fl-dots i{width:14px;height:14px;border-radius:50%;background:rgba(255,255,255,.15)}
.fl-dots i.taken{background:var(--accent)}
.fl-urgent{font-size:12.5px;color:rgba(255,255,255,.55)}
.fl-r .btn{margin-top:4px}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:26px 4px;text-align:left;font-size:18px;font-weight:500;letter-spacing:-0.01em;color:var(--ink)}
.faq-q .ic{width:26px;height:26px;border-radius:50%;border:1px solid var(--border-strong);flex-shrink:0;position:relative;transition:background .25s,border-color .25s}
.faq-q .ic::before,.faq-q .ic::after{content:"";position:absolute;inset:0;margin:auto;background:var(--ink);transition:transform .3s,background .25s}
.faq-q .ic::before{width:11px;height:1.5px}
.faq-q .ic::after{width:1.5px;height:11px}
.faq-item.open .faq-q .ic{background:var(--ink);border-color:var(--ink)}
.faq-item.open .faq-q .ic::before,.faq-item.open .faq-q .ic::after{background:#fff}
.faq-item.open .faq-q .ic::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1)}
.faq-a-inner{padding:0 4px 26px;color:var(--muted);font-size:15.5px;line-height:1.6;max-width:680px}

/* ---------- CTA final ---------- */
.final{text-align:center}
.final-card{
  background:var(--surface);border:1px solid var(--border);border-radius:calc(28px * var(--radius-scale));
  padding:clamp(48px,7vw,90px) var(--gutter);box-shadow:var(--shadow-card-lg);position:relative;overflow:hidden;
}
.final-card .label{margin-bottom:22px;display:inline-block}
.final-card h2{font-weight:300;letter-spacing:-0.035em;line-height:1.0;font-size:clamp(38px,6vw,72px)}
.final-card h2 .it{font-style:italic}
.final-card p{margin:24px auto 0;color:var(--muted);font-size:18px;max-width:520px;line-height:1.55}
.final-card .hero-actions{justify-content:center;margin-top:38px}
.final-watermark{position:absolute;left:0;right:0;bottom:-12%;font-weight:300;font-size:clamp(120px,22vw,300px);letter-spacing:-0.05em;color:var(--ink);opacity:0.025;pointer-events:none;text-align:center;line-height:1}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#fff;padding:70px 0 40px}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer .brand .krm{color:#fff}
.footer .brand .by{color:rgba(255,255,255,.5)}
.footer-blurb{margin-top:18px;color:rgba(255,255,255,.55);font-size:14px;line-height:1.6;max-width:280px}
.footer-col h4{font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:18px;font-weight:500}
.footer-col a{display:block;color:rgba(255,255,255,.7);font-size:14px;padding:6px 0;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:30px;gap:20px;flex-wrap:wrap}
.footer-bottom .copy{font-size:12.5px;color:rgba(255,255,255,.4);font-family:var(--font-mono);letter-spacing:0.02em}
.lang-select{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-pill);padding:5px}
.lang-select button{font-family:var(--font-mono);font-size:11px;letter-spacing:0.05em;color:rgba(255,255,255,.5);padding:5px 11px;border-radius:var(--r-pill);transition:all .2s}
.lang-select button.on{background:#fff;color:var(--ink);font-weight:600}
.lang-select button:disabled{cursor:not-allowed;opacity:.55}
.footer-note{margin-top:18px;font-size:11px;color:rgba(255,255,255,.3);font-family:var(--font-mono);letter-spacing:0.03em}

/* ---------- Annotations (zones animées) ---------- */
.anno{
  position:absolute;z-index:60;pointer-events:none;
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.06em;text-transform:uppercase;
  display:flex;align-items:center;gap:7px;
  background:var(--ink);color:#fff;padding:6px 11px;border-radius:var(--r-pill);
  box-shadow:var(--shadow-card-lg);white-space:nowrap;
  opacity:0;transform:translateY(4px);transition:opacity .3s,transform .3s;
}
.anno .pin{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 rgba(230,57,70,.5);animation:pulse 2s infinite}
body.show-anno .anno{opacity:1;transform:translateY(0)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(230,57,70,.5)}70%{box-shadow:0 0 0 7px rgba(230,57,70,0)}100%{box-shadow:0 0 0 0 rgba(230,57,70,0)}}
.anno.a-hero{top:96px;right:14px}
.anno.a-bento{top:-13px;left:26px}
.anno.a-why{top:-13px;right:26px}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.3,1),transform .7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.07s}
.reveal[data-d="2"]{transition-delay:.14s}
.reveal[data-d="3"]{transition-delay:.21s}
.reveal[data-d="4"]{transition-delay:.28s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ---------- Responsive ---------- */
@media (max-width:1000px){
  .bento{grid-template-columns:repeat(4,1fr)}
  .span-3{grid-column:span 2}.span-4{grid-column:span 4}.span-2{grid-column:span 2}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .why-cell{border-right:none !important;border-bottom:1px solid var(--border);padding:30px 0 !important}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media (max-width:820px){
  :root{--sec-pad:calc(80px * var(--space-scale))}
  .nav-links{display:none}
  .nav-burger{display:flex}
  .nav .nav-cta .btn{display:none}
  .problem-grid{grid-template-columns:1fr;gap:40px}
  .clutter{height:340px;max-width:420px}
  .trust-inner{grid-template-columns:1fr 1fr}
  .pricing-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto}
  .pcard.featured{transform:none}
  .pcard.featured:hover{transform:translateY(-5px)}
  .firstlove{grid-template-columns:1fr;gap:32px;padding:32px}
  .appwin-body{grid-template-columns:1fr}
  .app-side{display:none}
  .kanban{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
  .bento{grid-template-columns:1fr}
  .span-2,.span-3,.span-4,.span-6{grid-column:span 1}
  .why-grid{grid-template-columns:1fr}
  .trust-inner{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .kanban{grid-template-columns:1fr}
  .hero[data-variant="produit"] .hero-title,.hero[data-variant="typo"] .hero-title{font-size:clamp(44px,13vw,72px)}
}
