/* ============================================================
   nomuri — design system (premium, light only)
   No + Muri = zéro surcharge. Lean au service des personnes.
   ============================================================ */

:root {
  /* Type scale (fluid) */
  --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.82rem);
  --text-sm: clamp(0.875rem, 0.82rem + 0.3vw, 0.95rem);
  --text-base: clamp(1rem, 0.96rem + 0.2vw, 1.075rem);
  --text-lg: clamp(1.15rem, 1.05rem + 0.5vw, 1.4rem);
  --text-xl: clamp(1.5rem, 1.2rem + 1.2vw, 2.1rem);
  --text-2xl: clamp(2rem, 1.3rem + 2.6vw, 3.4rem);
  --text-3xl: clamp(2.6rem, 1.4rem + 4.2vw, 4.8rem);

  /* Spacing (4px base) */
  --space-1: 0.25rem;  --space-2: 0.5rem;  --space-3: 0.75rem;
  --space-4: 1rem;     --space-5: 1.25rem; --space-6: 1.5rem;
  --space-8: 2rem;     --space-10: 2.5rem; --space-12: 3rem;
  --space-16: 4rem;    --space-20: 5rem;   --space-24: 6rem;
  --space-32: 8rem;

  /* Surfaces — warm ivory, whitish premium */
  --bg: #FAF8F4;
  --surface: #FFFFFF;
  --surface-2: #F4F1EA;
  --surface-3: #EFEBE2;
  --border: #E6E1D6;
  --border-strong: #D8D2C4;

  /* Text — warm near-black ink */
  --ink: #20211D;
  --ink-soft: #4A4B45;
  --muted: #7C7C73;
  --faint: #A9A89F;

  /* Brand accents */
  --sage: #7E9A7C;          /* equilibrium / nature / health */
  --sage-deep: #5E7A5C;
  --terra: #C97B5A;         /* andon signal / human warmth */
  --terra-deep: #B06343;
  --ink-accent: #2C3530;    /* deep institutional green-ink */

  /* Per-solution accents */
  --kareko: #3B7B7E;        /* teal — health planner */
  --eneme: #8C6A4A;         /* warm bronze — watchmaking */
  --sensei: #6E5A8C;        /* muted plum — AI coaching */

  --radius-sm: 0.4rem;
  --radius-md: 0.65rem;
  --radius-lg: 1rem;
  --radius-xl: 1.5rem;
  --radius-full: 9999px;

  --shadow-xs: 0 1px 2px rgba(32,33,29,.04);
  --shadow-sm: 0 2px 8px rgba(32,33,29,.05);
  --shadow-md: 0 10px 30px rgba(32,33,29,.07);
  --shadow-lg: 0 24px 60px rgba(32,33,29,.10);

  --content: 1140px;
  --content-narrow: 760px;

  --ease: cubic-bezier(.16,1,.3,1);
  --t: 220ms var(--ease);

  --font-body: 'Inter', system-ui, sans-serif;
  --font-display: 'Fraunces', Georgia, serif;
  --font-mono: 'JetBrains Mono', monospace;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;scroll-behavior:smooth;
  scroll-padding-top:6rem;
}
body{
  min-height:100dvh;line-height:1.65;font-family:var(--font-body);
  font-size:var(--text-base);color:var(--ink);background:var(--bg);
}
img,svg,picture,video{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
ul[role=list]{list-style:none;}
h1,h2,h3,h4{text-wrap:balance;line-height:1.1;font-family:var(--font-display);font-weight:480;letter-spacing:-0.01em;}
p{text-wrap:pretty;}
button{cursor:pointer;background:none;border:none;font:inherit;color:inherit;}
::selection{background:rgba(126,154,124,.28);}
:focus-visible{outline:2px solid var(--sage-deep);outline-offset:3px;border-radius:var(--radius-sm);}
a,button{transition:color var(--t),background var(--t),border-color var(--t),box-shadow var(--t),transform var(--t),opacity var(--t);}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important;}
}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--content);margin-inline:auto;padding-inline:var(--space-6);}
.narrow{max-width:var(--content-narrow);margin-inline:auto;}
.section{padding-block:clamp(var(--space-16),9vw,var(--space-32));}
.section-sm{padding-block:clamp(var(--space-12),6vw,var(--space-20));}
.center{text-align:center;}

.eyebrow{
  font-family:var(--font-mono);font-size:var(--text-xs);
  text-transform:uppercase;letter-spacing:.18em;color:var(--terra-deep);
  display:inline-flex;align-items:center;gap:.55rem;
}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--terra);}
.eyebrow.sage{color:var(--sage-deep);}
.eyebrow.sage::before{background:var(--sage);}

.lead{font-size:var(--text-lg);color:var(--ink-soft);line-height:1.6;max-width:62ch;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;font-size:var(--text-sm);
  font-weight:500;padding:.8rem 1.4rem;border-radius:var(--radius-full);
  border:1px solid transparent;
}
.btn-primary{background:var(--ink-accent);color:#F7F5EF;box-shadow:var(--shadow-sm);}
.btn-primary:hover{background:#1d231f;transform:translateY(-1px);box-shadow:var(--shadow-md);}
.btn-ghost{border-color:var(--border-strong);color:var(--ink);background:var(--surface);}
.btn-ghost:hover{border-color:var(--sage);color:var(--sage-deep);}
.btn-text{color:var(--ink-soft);text-decoration:underline;text-underline-offset:4px;text-decoration-color:var(--border-strong);}
.btn-text:hover{color:var(--ink);text-decoration-color:var(--terra);}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(250,248,244,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color var(--t),box-shadow var(--t);
}
.site-header.scrolled{border-color:var(--border);box-shadow:var(--shadow-xs);}
.nav{display:flex;align-items:center;justify-content:space-between;height:4.5rem;}
.brand{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-display);font-weight:520;font-size:1.3rem;letter-spacing:-0.02em;}
.brand .dot{color:var(--terra);}
.nav-links{display:flex;align-items:center;gap:var(--space-8);}
.nav-links a{font-size:var(--text-sm);color:var(--ink-soft);position:relative;}
.nav-links a:hover{color:var(--ink);}
.nav-links a.active{color:var(--ink);}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--terra);border-radius:2px;}
.nav-cta{display:flex;align-items:center;gap:var(--space-4);}
.menu-btn{display:none;}

@media (max-width:860px){
  .nav-links{
    position:fixed;inset:4.5rem 0 auto 0;flex-direction:column;align-items:flex-start;
    gap:0;background:var(--surface);border-bottom:1px solid var(--border);
    padding:var(--space-2) var(--space-6) var(--space-6);
    transform:translateY(-120%);transition:transform .35s var(--ease);box-shadow:var(--shadow-md);
  }
  .nav-links.open{transform:translateY(0);}
  .nav-links a{padding:var(--space-4) 0;width:100%;border-bottom:1px solid var(--border);font-size:var(--text-base);}
  .menu-btn{display:inline-flex;}
  .nav-cta a.btn-ghost{display:none;}
}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:var(--space-16);align-items:center;
  padding-block:clamp(var(--space-16),8vw,var(--space-24));}
.hero h1{font-size:var(--text-3xl);font-weight:440;line-height:1.04;}
.hero h1 em{font-style:italic;color:var(--terra-deep);}
.hero-visual img{border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid var(--border);}
@media (max-width:860px){.hero-grid{grid-template-columns:1fr;gap:var(--space-10);}}

/* ---------- Cards ---------- */
.card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:var(--space-6);box-shadow:var(--shadow-xs);transition:transform var(--t),box-shadow var(--t),border-color var(--t);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.card-icon{
  width:2.6rem;height:2.6rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;
  background:var(--surface-2);color:var(--sage-deep);margin-bottom:var(--space-4);
}
.card h3{font-size:var(--text-lg);margin-bottom:var(--space-2);color:var(--ink);}
.card p{font-size:var(--text-sm);color:var(--ink-soft);}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5);}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6);}
@media (max-width:860px){.grid-3{grid-template-columns:1fr;}.grid-2{grid-template-columns:1fr;}}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5);}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-6);}
.stat .num{font-family:var(--font-display);font-size:var(--text-xl);font-weight:520;letter-spacing:-0.02em;}
.stat .lbl{font-size:var(--text-xs);color:var(--muted);margin-top:.35rem;}
@media (max-width:680px){.stats{grid-template-columns:1fr 1fr;}}

/* ---------- Section bands ---------- */
.band{background:var(--surface-2);border-block:1px solid var(--border);}
.band-ink{background:var(--ink-accent);color:#E9E7DF;border-block:1px solid var(--ink-accent);}
.band-ink h2,.band-ink h3{color:#F5F3EC;}
.band-ink .lead,.band-ink p{color:#C9CCC4;}
.band-ink .eyebrow{color:#D9A98D;}
.band-ink .eyebrow::before{background:var(--terra);}

/* ---------- Pull quote ---------- */
.pull{
  font-family:var(--font-display);font-size:var(--text-xl);font-weight:400;line-height:1.35;
  color:var(--ink);border-left:3px solid var(--terra);padding-left:var(--space-6);max-width:50ch;
}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink-accent);color:#C9CCC4;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:var(--space-8);padding-block:var(--space-16);}
.site-footer h4{color:#F5F3EC;font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.16em;font-weight:500;margin-bottom:var(--space-4);}
.site-footer a{color:#C9CCC4;font-size:var(--text-sm);}
.site-footer a:hover{color:#fff;}
.site-footer .brand{color:#F5F3EC;}
.footer-links{display:flex;flex-direction:column;gap:var(--space-2);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-block:var(--space-5);display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--space-3);font-size:var(--text-xs);color:#9A9D94;}
@media (max-width:860px){.footer-top{grid-template-columns:1fr 1fr;gap:var(--space-8);}}
@media (max-width:520px){.footer-top{grid-template-columns:1fr;}}

/* ---------- Reveal animation (progressive enhancement) ---------- */
/* Hidden only when JS is active; without JS, content is always visible */
html.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
html.js .reveal.in{opacity:1;transform:none;}

/* ---------- Solution sections ---------- */
.sol{scroll-margin-top:6rem;}
.sol-head{display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap;}
.sol-badge{width:3.2rem;height:3.2rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-display);font-weight:600;font-size:1.4rem;flex-shrink:0;}
.feature-list{list-style:none;display:grid;gap:var(--space-3);margin-top:var(--space-6);}
.feature-list li{display:flex;gap:.7rem;align-items:flex-start;font-size:var(--text-sm);color:var(--ink-soft);}
.feature-list li svg{flex-shrink:0;margin-top:.15rem;}
.mock{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-md);}
.mock-head{display:flex;justify-content:space-between;font-size:var(--text-xs);color:var(--muted);font-family:var(--font-mono);margin-bottom:var(--space-3);}
.mock-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;}
.cell{height:2.1rem;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.62rem;font-family:var(--font-mono);font-weight:500;}
.demo-row{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--border);}
.lock-note{display:inline-flex;align-items:center;gap:.4rem;font-size:var(--text-xs);color:var(--muted);}

/* ---------- Demo modal ---------- */
.demo-modal{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;
  background:rgba(32,33,29,.42);backdrop-filter:blur(4px);padding:var(--space-6);}
.demo-modal.open{display:flex;}
.demo-box{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
  max-width:420px;width:100%;padding:var(--space-8);border:1px solid var(--border);}
.demo-box h3{font-size:var(--text-lg);}
.demo-box .lock-ic{width:2.6rem;height:2.6rem;border-radius:var(--radius-md);background:var(--surface-2);display:flex;align-items:center;justify-content:center;color:var(--terra-deep);margin-bottom:var(--space-4);}
.demo-box input{width:100%;padding:.8rem 1rem;border:1px solid var(--border-strong);border-radius:var(--radius-md);background:var(--bg);font-size:var(--text-base);margin-top:var(--space-4);}
.demo-box input:focus{outline:none;border-color:var(--sage);}
.demo-err{display:none;color:var(--terra-deep);font-size:var(--text-sm);margin-top:var(--space-3);}
.demo-actions{display:flex;gap:var(--space-3);margin-top:var(--space-6);}

/* ---------- Misc ---------- */
.tag{display:inline-flex;align-items:center;gap:.4rem;font-size:var(--text-xs);font-family:var(--font-mono);
  padding:.3rem .7rem;border-radius:var(--radius-full);background:var(--surface-2);border:1px solid var(--border);color:var(--muted);}
.divider{height:1px;background:var(--border);border:0;}
.mt-2{margin-top:var(--space-2);} .mt-4{margin-top:var(--space-4);} .mt-6{margin-top:var(--space-6);}
.mt-8{margin-top:var(--space-8);} .mt-10{margin-top:var(--space-10);} .mt-12{margin-top:var(--space-12);}
