/* ========================================================= *
   *  2S-MEDIA SÉNÉGAL — AFRICAN LUXE EDITORIAL · V2
   * ========================================================= */

  :root{
    --night:#0E0E0C;
    --ink:#1A1A17;
    --char:#2A2925;
    --cream:#F5EFE3;
    --paper:#EDE4D0;
    --paper-2:#E3D7BC;
    --gold:#C9A961;
    --gold-deep:#A8873F;
    --amber:#B8752E;
    --terra:#B4472A;
    --terra-dk:#8a351d;
    --sage:#5C6A50;
    --line:rgba(245,239,227,.14);
    --line-ink:rgba(14,14,12,.12);

    --display:'Fraunces', ui-serif, Georgia, serif;
    --body:'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    --mono:'JetBrains Mono', ui-monospace, monospace;

    --container:1320px;
    --gutter: clamp(20px, 4vw, 56px);

    --ease-out: cubic-bezier(.22, 1, .36, 1);
    --ease-in-out: cubic-bezier(.65, 0, .35, 1);
  }

  *,*::before,*::after{box-sizing:border-box}
  html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
  body{
    margin:0;
    font-family:var(--body);
    background:var(--cream);
    color:var(--night);
    font-weight:400; line-height:1.55; font-size:17px;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  }
  img{max-width:100%; display:block}
  a{color:inherit; text-decoration:none}
  button{font-family:inherit; cursor:pointer; border:0; background:none; color:inherit; padding:0}
  ::selection{background:var(--gold); color:var(--night)}

  /* grain overlay */
  body::before{
    content:""; position:fixed; inset:0;
    pointer-events:none; z-index:1;
    opacity:.055; mix-blend-mode:multiply;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='200' height='200' filter='url(%23n)' opacity='.6'/></svg>");
  }

  h1,h2,h3,h4{margin:0; font-family:var(--display); font-weight:400; letter-spacing:-.015em; line-height:1.05}
  p{margin:0 0 1em}

  .eyebrow{
    font-family:var(--mono);
    font-size:11px; letter-spacing:.24em; text-transform:uppercase;
    color:var(--amber);
    display:inline-flex; align-items:center; gap:10px;
  }
  .eyebrow::before{content:""; width:28px; height:1px; background:currentColor}
  .italic{font-style:italic; font-variation-settings:"opsz" 144; font-weight:300}

  .wrap{max-width:var(--container); margin:0 auto; padding:0 var(--gutter); position:relative; z-index:2}

  /* ===================================================================
   *  NAV
   * =================================================================== */
  .nav{
    position:fixed; top:0; left:0; right:0; z-index:50;
    padding:20px 0;
    transition: background .35s var(--ease-out), padding .35s var(--ease-out), box-shadow .3s var(--ease-out);
  }
  .nav.scrolled{
    background:rgba(14,14,12,.9);
    backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
    padding:12px 0;
    box-shadow:0 1px 0 var(--line);
  }
  .nav-inner{display:flex; align-items:center; justify-content:space-between; gap:24px}

  /* LOGO (SVG wordmark) */
  .logo{display:inline-flex; align-items:center; gap:0; color:var(--night); transition:color .3s var(--ease-out)}
  .nav.scrolled .logo{color:var(--cream)}
  .logo svg{height:34px; width:auto; display:block}
  .logo:hover{opacity:.8}

  .nav-links{display:flex; gap:32px; align-items:center}
  .nav-links a{
    font-size:14px; font-weight:500;
    color:var(--night); opacity:.7;
    transition:opacity .2s, color .3s var(--ease-out);
    position:relative;
  }
  .nav.scrolled .nav-links a{color:var(--cream); opacity:.8}
  .nav-links a::after{
    content:""; position:absolute; left:0; right:0; bottom:-6px;
    height:1px; background:currentColor;
    transform:scaleX(0); transform-origin:left center;
    transition:transform .3s var(--ease-out);
  }
  .nav-links a:hover{opacity:1}
  .nav-links a:hover::after{transform:scaleX(1)}

  .nav-cta{
    padding:11px 22px;
    background:var(--night) !important;
    color:var(--cream) !important;
    border-radius:100px;
    font-weight:600;
    opacity:1 !important;
    transition: transform .2s, background .25s;
  }
  .nav.scrolled .nav-cta{background:var(--gold) !important; color:var(--night) !important}
  .nav-cta::after{display:none !important}
  .nav-cta:hover{transform:translateY(-1px); background:var(--terra) !important; color:var(--cream) !important}
  .nav.scrolled .nav-cta:hover{background:var(--cream) !important; color:var(--night) !important}

  .burger{display:none; width:32px; height:32px; position:relative; color:var(--night)}
  .nav.scrolled .burger{color:var(--cream)}
  .burger span{position:absolute; left:4px; right:4px; height:2px; background:currentColor; transition:transform .3s var(--ease-out), top .3s var(--ease-out), opacity .2s}
  .burger span:nth-child(1){top:10px} .burger span:nth-child(2){top:16px} .burger span:nth-child(3){top:22px}
  .burger.open span:nth-child(1){top:16px; transform:rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){top:16px; transform:rotate(-45deg)}

  @media(max-width:960px){
    .nav-links{
      position:fixed; top:0; right:0; bottom:0; width:min(86vw, 380px);
      background:var(--night); color:var(--cream);
      flex-direction:column; align-items:flex-start;
      padding:110px 40px 40px;
      gap:26px;
      transform:translateX(100%);
      transition:transform .4s var(--ease-in-out);
      box-shadow:-30px 0 60px rgba(0,0,0,.2);
    }
    .nav-links.open{transform:translateX(0)}
    .nav-links a{color:var(--cream) !important; font-size:22px; font-family:var(--display); opacity:1}
    .nav-cta{align-self:stretch; text-align:center; padding:14px; font-size:16px !important; font-family:var(--body) !important}
    .burger{display:block}
  }

  /* ===================================================================
   *  HERO — editorial, photo-driven
   * =================================================================== */
  .hero{
    position:relative;
    padding:130px 0 80px;
    background:var(--cream);
    overflow:hidden;
  }
  .hero::after{
    /* soft terracotta glow in the background */
    content:""; position:absolute;
    top:-200px; right:-200px;
    width:700px; height:700px;
    background:radial-gradient(circle, rgba(180,71,42,.08), transparent 70%);
    pointer-events:none;
  }

  .hero-grid{
    display:grid;
    grid-template-columns: 1.05fr .95fr;
    gap:clamp(40px, 6vw, 90px);
    align-items:center;
    min-height: 78svh;
  }
  @media(max-width:960px){ .hero-grid{grid-template-columns:1fr; gap:50px; min-height:unset} }

  .hero h1{
    font-size: clamp(52px, 8.4vw, 128px);
    line-height:.9;
    letter-spacing:-.038em;
    margin: 22px 0 28px;
  }
  .hero h1 .line{display:block; overflow:hidden; padding-right:.1em}
  .hero h1 .line > span{display:inline-block; transform:translateY(110%); animation: heroReveal 1.1s var(--ease-out) forwards}
  .hero h1 .line:nth-child(2) > span{animation-delay:.1s}
  .hero h1 .line:nth-child(3) > span{animation-delay:.2s}
  @keyframes heroReveal{to{transform:none}}

  .hero h1 .gold{color:var(--amber)}
  .hero h1 em{font-style:italic; font-weight:300; color:var(--terra); font-variation-settings:"opsz" 144}

  .hero-sub{
    max-width:520px; font-size:18px;
    color:var(--char); opacity:.85;
    margin-bottom:40px;
    opacity:0; animation: fadein .8s var(--ease-out) .5s forwards;
  }
  @keyframes fadein{from{opacity:0; transform:translateY(14px)}to{opacity:.85; transform:none}}

  .hero-ctas{
    display:flex; gap:14px; flex-wrap:wrap; margin-bottom:54px;
    opacity:0; animation:fadein .8s var(--ease-out) .65s forwards;
  }

  .btn{
    display:inline-flex; align-items:center; gap:10px;
    padding:16px 26px;
    border-radius:100px;
    font-weight:600; font-size:15px;
    transition:transform .25s var(--ease-out), background .25s, color .25s, box-shadow .3s;
    white-space:nowrap;
    position:relative; overflow:hidden;
  }
  .btn-primary{background:var(--night); color:var(--cream)}
  .btn-primary:hover{background:var(--terra); transform:translateY(-2px); box-shadow:0 20px 40px -20px rgba(180,71,42,.6)}
  .btn-ghost{background:transparent; color:var(--night); border:1.5px solid var(--night)}
  .btn-ghost:hover{background:var(--night); color:var(--cream)}
  .btn svg{width:18px; height:18px; transition:transform .25s var(--ease-out)}
  .btn:hover svg{transform:translateX(4px)}

  .hero-meta{
    display:grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap:clamp(16px, 3vw, 40px);
    padding-top:36px;
    border-top:1px solid var(--line-ink);
    opacity:0; animation:fadein .8s var(--ease-out) .85s forwards;
    align-items:start;
  }
  .hero-meta .stat{display:flex; flex-direction:column; gap:6px; min-width:0}
  .hero-meta .num{font-family:var(--display); font-size:clamp(32px, 3.5vw, 44px); font-weight:500; color:var(--terra); line-height:1; letter-spacing:-.02em}
  .hero-meta .lab{font-family:var(--mono); font-size:10.5px; letter-spacing:.2em; text-transform:uppercase; opacity:.7; line-height:1.3}
  @media(max-width:560px){
    .hero-meta{grid-template-columns: repeat(2, 1fr); row-gap:24px}
  }

  /* hero visual — layered photo collage */
  .hero-visual{
    position:relative;
    width:100%;
    aspect-ratio: 4/5;
    max-width:560px;
    margin:0 auto;
    opacity:0; animation:fadein 1.1s var(--ease-out) .3s forwards;
  }
  .hv-main{
    position:absolute;
    inset:0 0 0 0;
    width:82%; height:88%;
    border-radius:6px;
    overflow:hidden;
    box-shadow:0 40px 80px -30px rgba(14,14,12,.4);
  }
  .hv-main img{
    width:100%; height:100%;
    object-fit:cover; object-position:center 30%;
    filter:contrast(1.04) saturate(.95);
  }
  .hv-main::after{
    /* subtle warm overlay */
    content:""; position:absolute; inset:0;
    background:linear-gradient(135deg, rgba(180,71,42,.08), transparent 60%);
    pointer-events:none;
  }

  .hv-badge{
    position:absolute;
    right:0; top:18%;
    background:var(--night); color:var(--cream);
    padding:22px 26px;
    border-radius:6px;
    max-width:220px;
    transform:rotate(3deg);
    box-shadow:0 30px 60px -20px rgba(14,14,12,.35);
  }
  .hv-badge .mono{font-family:var(--mono); font-size:10px; letter-spacing:.2em; color:var(--gold); text-transform:uppercase; margin-bottom:10px}
  .hv-badge .q{
    font-family:var(--display); font-style:italic; font-weight:300;
    font-size:22px; line-height:1.15; color:var(--cream);
  }
  .hv-badge .q::before{content:"«"; color:var(--terra); margin-right:4px; font-style:normal; font-weight:600}
  .hv-badge .q::after{content:"»"; color:var(--terra); margin-left:4px; font-style:normal; font-weight:600}

  .hv-circle{
    position:absolute;
    bottom:-10px; left:-20px;
    width:40%; aspect-ratio:1;
    background:var(--gold);
    border-radius:50%;
    display:grid; place-items:center;
    color:var(--night);
    font-family:var(--display); font-style:italic; font-weight:500;
    text-align:center;
    padding:18px;
    box-shadow:0 24px 40px -10px rgba(201,169,97,.5);
    animation: float 6s ease-in-out infinite;
  }
  .hv-circle .txt{font-size:clamp(13px, 1.5vw, 17px); line-height:1.2}
  @keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

  .hv-tag{
    position:absolute;
    top:-12px; left:10%;
    background:var(--cream); color:var(--night);
    padding:10px 18px;
    border-radius:100px;
    font-family:var(--mono); font-size:10.5px; letter-spacing:.18em;
    text-transform:uppercase;
    border:1px solid var(--line-ink);
    display:inline-flex; align-items:center; gap:8px;
  }
  .hv-tag .dot{width:8px; height:8px; border-radius:50%; background:#2E9C5A; box-shadow:0 0 0 4px rgba(46,156,90,.25); animation:pulseDot 2s ease-in-out infinite}
  @keyframes pulseDot{50%{box-shadow:0 0 0 8px rgba(46,156,90,0)}}

  /* ===================================================================
   *  MARQUEE
   * =================================================================== */
  .marquee{
    background:var(--night); color:var(--cream);
    padding:24px 0; overflow:hidden;
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
  }
  .marquee-track{
    display:flex; gap:60px;
    animation: scroll 45s linear infinite;
    white-space:nowrap;
    width:max-content;
  }
  .marquee-item{
    font-family:var(--display); font-style:italic; font-weight:300;
    font-size:28px; display:flex; align-items:center; gap:60px;
    color:var(--cream);
  }
  .marquee-item::after{content:"✦"; color:var(--gold); font-style:normal}
  @keyframes scroll{to{transform:translateX(-50%)}}

  /* ===================================================================
   *  TRUST STRIP
   * =================================================================== */
  .trust{
    background:var(--cream);
    padding:38px 0;
    border-bottom:1px solid var(--line-ink);
  }
  .trust-inner{
    display:flex; justify-content:space-between; align-items:center;
    flex-wrap:wrap; gap:28px;
  }
  .trust-label{
    font-family:var(--mono); font-size:11px; letter-spacing:.22em;
    text-transform:uppercase; opacity:.55;
  }
  .trust-logos{
    display:flex; gap:clamp(24px, 4vw, 48px); flex-wrap:wrap; align-items:center;
  }
  .trust-logo{
    font-family:var(--display);
    font-size:20px;
    font-weight:500;
    opacity:.4;
    transition:opacity .25s;
    letter-spacing:-.01em;
  }
  .trust-logo:hover{opacity:.9}
  .trust-logo.mono{font-family:var(--mono); font-size:13px; letter-spacing:.04em; text-transform:uppercase}

  /* ===================================================================
   *  SECTION CHROME
   * =================================================================== */
  section{position:relative}
  .section{padding: clamp(90px, 13vw, 160px) 0}
  .section-dark{background:var(--night); color:var(--cream)}
  .section-dark .eyebrow{color:var(--gold)}

  .section-title{
    font-size: clamp(40px, 6.2vw, 82px);
    letter-spacing:-.035em;
    line-height:.98;
    max-width:900px;
    margin-bottom:28px;
  }
  .section-intro{max-width:620px; font-size:18px; opacity:.8; margin-bottom:60px}

  .section-head{
    display:grid;
    grid-template-columns: 1fr auto;
    align-items:end;
    gap:40px;
    margin-bottom:72px;
  }
  @media(max-width:780px){.section-head{grid-template-columns:1fr}}

  .section-num{
    font-family:var(--display); font-style:italic; font-weight:300;
    font-size: clamp(80px, 12vw, 170px);
    line-height:.8;
    color:var(--terra); opacity:.9;
    margin-left:auto;
    white-space:nowrap;
  }

  /* ===================================================================
   *  SERVICES (8 items, 4x2 grid)
   * =================================================================== */
  .services-grid{
    display:grid;
    grid-template-columns: repeat(4, 1fr);
    gap:2px;
    background:var(--line-ink);
    border-top:1px solid var(--line-ink);
    border-bottom:1px solid var(--line-ink);
  }
  @media(max-width:1100px){.services-grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:560px){.services-grid{grid-template-columns:1fr}}

  .service{
    background:var(--cream);
    padding:40px 28px 36px;
    display:grid;
    grid-template-rows: auto auto 56px 96px 1fr auto;
    row-gap:14px;
    align-content: start;
    position:relative;
    transition:background .35s var(--ease-out), color .35s var(--ease-out);
    min-height:340px;
    overflow:hidden;
  }
  .service::before{
    /* subtle decorative corner accent */
    content:""; position:absolute;
    top:0; right:0;
    width:40px; height:40px;
    background:linear-gradient(225deg, rgba(201,169,97,.12), transparent 50%);
    pointer-events:none;
  }
  .service:hover{background:var(--night); color:var(--cream)}
  .service:hover .s-num{color:var(--gold)}
  .service:hover .s-link{color:var(--gold); border-color:var(--gold)}
  .service:hover .s-icon{background:var(--terra); color:var(--cream); transform:rotate(-6deg) scale(1.06)}
  .service:hover::before{background:linear-gradient(225deg, rgba(201,169,97,.22), transparent 50%)}

  .s-num{font-family:var(--mono); font-size:11px; letter-spacing:.22em; color:var(--terra); font-weight:500; transition:color .3s}
  .s-icon{
    width:54px; height:54px; border-radius:50%;
    background:var(--paper);
    display:grid; place-items:center;
    color:var(--night);
    transition:all .35s var(--ease-out);
  }
  .s-icon svg{width:26px; height:26px; stroke-width:1.6}
  .s-title{font-family:var(--display); font-size:24px; font-weight:500; letter-spacing:-.018em; line-height:1.15; align-self:start; min-height: 0}
  .s-desc{font-size:14.5px; opacity:.8; line-height:1.5; text-align:justify; hyphens:auto; min-height:0}
  .s-list{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:5px}
  .s-list li{font-size:12.5px; opacity:.75; padding-left:14px; position:relative}
  .s-list li::before{content:"→"; position:absolute; left:0; color:var(--terra); font-weight:700}
  .service:hover .s-list li::before{color:var(--gold)}
  .s-link{
    font-family:var(--mono); font-size:10.5px; letter-spacing:.22em; text-transform:uppercase;
    padding-bottom:3px; border-bottom:1px solid currentColor;
    justify-self:start; align-self:end;
    transition:all .25s;
  }

  /* ===================================================================
   *  APPROCHE
   * =================================================================== */
  .approach{background:var(--paper)}
  .proc-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:44px}
  @media(max-width:920px){.proc-grid{grid-template-columns:repeat(2,1fr); gap:36px}}
  @media(max-width:520px){.proc-grid{grid-template-columns:1fr}}
  .step{position:relative; padding-top:30px; border-top:1px solid var(--night)}
  .step .n{font-family:var(--display); font-style:italic; font-weight:300; font-size:68px; line-height:1; color:var(--terra)}
  .step h3{font-size:24px; margin:14px 0 10px; font-weight:500}
  .step p{font-size:14px; opacity:.75; margin:0}

  /* ===================================================================
   *  PORTFOLIO — real screenshot grid (mshots)
   * =================================================================== */
  .portfolio{background:var(--night); color:var(--cream); overflow:hidden}
  .port-grid{
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap:24px;
  }
  @media(max-width:960px){.port-grid{grid-template-columns:repeat(2,1fr); gap:20px}}
  @media(max-width:560px){.port-grid{grid-template-columns:1fr; gap:16px}}

  .pcard{
    position:relative;
    display:block;
    aspect-ratio: 4/3;
    border-radius:8px;
    overflow:hidden;
    background:var(--ink);
    border:1px solid var(--line);
    transition: transform .5s var(--ease-out);
    isolation:isolate;
  }
  .pcard:hover{transform:translateY(-4px)}
  .pcard .shot{
    position:absolute; inset:0;
    width:100%; height:100%;
    object-fit:cover; object-position: top center;
    transition: transform .9s var(--ease-out), filter .5s;
    filter:grayscale(15%) contrast(1.05);
  }
  .pcard:hover .shot{transform:scale(1.06); filter:grayscale(0) contrast(1.05)}

  .pcard::before{
    content:""; position:absolute; inset:0; z-index:1;
    background:linear-gradient(180deg, rgba(14,14,12,0) 40%, rgba(14,14,12,.88) 100%);
    transition: background .5s;
  }
  .pcard:hover::before{background:linear-gradient(180deg, rgba(14,14,12,.1) 0%, rgba(14,14,12,.9) 100%)}

  .pcard .meta{
    position:absolute; inset:auto 0 0 0; z-index:2;
    padding:20px 22px;
    display:flex; justify-content:space-between; align-items:flex-end;
    gap:12px;
    transform:translateY(4px);
    transition:transform .5s var(--ease-out);
  }
  .pcard:hover .meta{transform:translateY(0)}
  .pcard .info{display:flex; flex-direction:column; gap:4px}
  .pcard .cat{
    font-family:var(--mono); font-size:10px; letter-spacing:.22em;
    color:var(--gold); text-transform:uppercase;
  }
  .pcard h4{
    font-family:var(--display); font-size:22px; font-weight:500;
    color:var(--cream); letter-spacing:-.01em;
  }
  .pcard h4 em{font-style:italic; font-weight:300}
  .pcard .arrow{
    flex-shrink:0;
    width:40px; height:40px; border-radius:50%;
    background:rgba(245,239,227,.1);
    border:1px solid rgba(245,239,227,.2);
    display:grid; place-items:center;
    color:var(--cream);
    transition: all .4s var(--ease-out);
  }
  .pcard:hover .arrow{background:var(--gold); border-color:var(--gold); color:var(--night); transform:rotate(-45deg)}
  .pcard .arrow svg{width:16px; height:16px}

  .pcard .num{
    position:absolute; top:18px; left:18px; z-index:2;
    font-family:var(--mono); font-size:11px; letter-spacing:.18em;
    color:var(--cream); opacity:.75;
    background:rgba(14,14,12,.55);
    padding:5px 10px; border-radius:100px;
    backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px);
  }

  .pcard .loader{
    position:absolute; inset:0; z-index:0;
    display:grid; place-items:center;
    background:var(--ink);
    color:var(--gold);
    font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase;
    opacity:.4;
  }

  /* ===================================================================
   *  TESTIMONIAL
   * =================================================================== */
  .testimonial{background:var(--paper-2); overflow:hidden}
  .testi-grid{
    display:grid;
    grid-template-columns: .9fr 1.1fr;
    gap:clamp(40px, 6vw, 90px);
    align-items:center;
  }
  @media(max-width:860px){.testi-grid{grid-template-columns:1fr}}
  .testi-photo{
    position:relative;
    aspect-ratio:4/5;
    border-radius:8px;
    overflow:hidden;
    max-width:460px;
    box-shadow:0 30px 60px -20px rgba(14,14,12,.25);
  }
  .testi-photo img{width:100%; height:100%; object-fit:cover; object-position:center}
  .testi-photo::after{
    content:""; position:absolute; inset:0;
    background:linear-gradient(135deg, rgba(201,169,97,.06), transparent);
  }
  .testi-photo .badge{
    position:absolute;
    bottom:18px; left:18px; right:18px;
    padding:16px 20px;
    background:rgba(14,14,12,.82);
    backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
    border-radius:6px;
    color:var(--cream);
    display:flex; justify-content:space-between; align-items:center;
  }
  .testi-photo .badge .name{font-family:var(--display); font-size:18px; font-weight:500}
  .testi-photo .badge .role{font-family:var(--mono); font-size:10px; letter-spacing:.18em; color:var(--gold); text-transform:uppercase; margin-top:2px}
  .testi-photo .badge .stars{color:var(--gold); font-size:15px; letter-spacing:2px}

  .testi-quote{
    font-family:var(--display); font-style:italic; font-weight:300;
    font-size: clamp(26px, 3.4vw, 42px);
    line-height:1.2;
    color:var(--night);
    letter-spacing:-.015em;
    position:relative;
    padding-left:24px;
  }
  .testi-quote::before{
    content:"“"; position:absolute; left:-20px; top:-30px;
    font-size:140px; line-height:1;
    color:var(--terra); opacity:.35;
    font-style:normal; font-weight:500;
  }
  .testi-attribution{
    margin-top:32px;
    padding-top:24px;
    border-top:1px solid var(--line-ink);
    display:flex; justify-content:space-between; align-items:center;
    flex-wrap:wrap; gap:16px;
  }
  .testi-attribution .who strong{font-size:16px; font-weight:600; display:block}
  .testi-attribution .who span{font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; opacity:.65}
  .testi-attribution .logo-client{font-family:var(--display); font-size:24px; font-weight:500; opacity:.4}

  /* ===================================================================
   *  PRICING
   * =================================================================== */
  .pricing{background:var(--cream)}
  .tariffs-nav{
    display:flex; gap:8px; flex-wrap:wrap; margin-bottom:48px;
    padding:6px;
    background:var(--paper);
    border-radius:100px;
    width:max-content; max-width:100%;
    overflow-x:auto;
  }
  .tab-btn{
    padding:10px 20px; border-radius:100px;
    font-size:13px; font-weight:600;
    color:var(--char); white-space:nowrap;
    transition:background .3s var(--ease-out), color .3s var(--ease-out);
  }
  .tab-btn:hover{background:rgba(255,255,255,.5)}
  .tab-btn.active{background:var(--night); color:var(--cream)}
  .tab-panel{display:none}
  .tab-panel.active{display:block; animation: fadein2 .45s var(--ease-out) both}
  @keyframes fadein2{from{opacity:0; transform:translateY(12px)}to{opacity:1; transform:none}}

  .plans{display:grid; grid-template-columns:repeat(3,1fr); gap:24px}
  @media(max-width:980px){.plans{grid-template-columns:1fr}}

  .plan{
    position:relative;
    background:var(--paper);
    border-radius:20px;
    padding:36px 32px 32px;
    display:flex; flex-direction:column;
    transition: transform .35s var(--ease-out), box-shadow .35s;
    border:1px solid transparent;
  }
  .plan:hover{transform:translateY(-6px); box-shadow:0 30px 60px -30px rgba(14,14,12,.25)}
  .plan.featured{background:var(--night); color:var(--cream); border-color:var(--gold)}
  .plan.featured .p-price, .plan.featured .p-name{color:var(--gold)}
  .plan-flag{
    position:absolute; top:-12px; right:24px;
    background:var(--terra); color:var(--cream);
    font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase;
    padding:6px 14px; border-radius:100px;
  }
  .p-name{font-family:var(--display); font-size:28px; font-weight:500; margin-bottom:6px; color:var(--terra)}
  .p-pitch{font-size:14px; opacity:.72; margin-bottom:24px}
  .p-price{font-family:var(--display); font-size:44px; font-weight:500; letter-spacing:-.02em; color:var(--terra); line-height:1}
  .p-price small{font-family:var(--body); font-size:13px; font-weight:500; opacity:.7; margin-left:6px}
  .p-currency{font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; opacity:.7; margin-top:6px; margin-bottom:28px}
  .p-feats{list-style:none; padding:0; margin:0 0 32px; display:flex; flex-direction:column; gap:12px; flex:1}
  .p-feats li{font-size:14px; padding-left:24px; position:relative; line-height:1.5}
  .p-feats li::before{
    content:""; position:absolute; left:0; top:8px;
    width:10px; height:6px;
    border-left:1.5px solid var(--terra); border-bottom:1.5px solid var(--terra);
    transform:rotate(-45deg);
  }
  .plan.featured .p-feats li::before{border-color:var(--gold)}
  .plan .btn{justify-content:center; width:100%}
  .plan.featured .btn-primary{background:var(--gold); color:var(--night)}
  .plan.featured .btn-primary:hover{background:var(--cream)}
  .price-note{margin-top:28px; font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; opacity:.6}

  /* ===================================================================
   *  ABOUT
   * =================================================================== */
  .about{background:var(--paper-2)}
  .about-grid{
    display:grid;
    grid-template-columns: 1.1fr .9fr;
    gap:80px;
    align-items:start;
  }
  @media(max-width:960px){.about-grid{grid-template-columns:1fr; gap:48px}}
  .about-copy p{font-size:17px; line-height:1.7; color:var(--char)}
  .about-copy p + p{margin-top:1em}
  .about-copy .pull{
    font-family:var(--display); font-style:italic; font-weight:300;
    font-size: clamp(28px, 3.2vw, 40px); line-height:1.2;
    color:var(--night);
    border-left:2px solid var(--terra);
    padding-left:24px;
    margin:40px 0;
  }
  .about-photo{
    position:relative; aspect-ratio:4/5;
    border-radius:8px; overflow:hidden;
    box-shadow:0 30px 60px -20px rgba(14,14,12,.25);
  }
  .about-photo img{width:100%; height:100%; object-fit:cover}
  .about-blocks{margin-top:24px; display:flex; flex-direction:column; gap:14px}
  .about-blocks .block{
    background:var(--night); color:var(--cream);
    padding:28px 32px; border-radius:14px;
  }
  .about-blocks .block h4{font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:16px; font-weight:500}
  .about-blocks ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:12px}
  .about-blocks li{display:flex; gap:14px; align-items:flex-start; font-size:14.5px}
  .about-blocks li .dot{flex-shrink:0; width:8px; height:8px; border-radius:50%; background:var(--gold); margin-top:8px}

  /* ===================================================================
   *  FAQ
   * =================================================================== */
  .faq{background:var(--cream)}
  .faq-list{max-width:860px; margin:0 auto}
  .faq-item{border-top:1px solid var(--line-ink); padding:24px 0}
  .faq-item:last-child{border-bottom:1px solid var(--line-ink)}
  .faq-q{
    display:flex; justify-content:space-between; align-items:center;
    gap:24px; width:100%; text-align:left;
    font-family:var(--display); font-size: clamp(20px, 2.4vw, 26px);
    font-weight:500; letter-spacing:-.01em; color:var(--night);
  }
  .faq-q .plus{
    flex-shrink:0; width:36px; height:36px; border-radius:50%;
    border:1px solid var(--night);
    display:grid; place-items:center;
    position:relative;
    transition:background .25s, color .25s, transform .35s var(--ease-in-out);
  }
  .faq-q .plus::before, .faq-q .plus::after{content:""; position:absolute; background:var(--night); border-radius:1px; transition: transform .35s, background .25s}
  .faq-q .plus::before{width:12px; height:1.5px}
  .faq-q .plus::after{width:1.5px; height:12px}
  .faq-item.open .plus{background:var(--terra); border-color:var(--terra); transform:rotate(180deg)}
  .faq-item.open .plus::before, .faq-item.open .plus::after{background:var(--cream)}
  .faq-item.open .plus::after{transform:scaleY(0)}
  .faq-a{max-height:0; overflow:hidden; transition:max-height .4s var(--ease-in-out), margin .4s var(--ease-in-out)}
  .faq-item.open .faq-a{max-height:500px; margin-top:18px}
  .faq-a p{font-size:16px; color:var(--char); opacity:.85; margin:0 0 10px}

  /* ===================================================================
   *  CONTACT
   * =================================================================== */
  .contact{background:var(--night); color:var(--cream); overflow:hidden; position:relative}
  .contact::before{
    content:""; position:absolute;
    top:-250px; left:-200px;
    width:600px; height:600px;
    background:radial-gradient(circle, rgba(201,169,97,.1), transparent 70%);
    pointer-events:none;
  }
  .contact-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:80px}
  @media(max-width:960px){.contact-grid{grid-template-columns:1fr; gap:48px}}
  .contact h2{font-size: clamp(48px, 8vw, 96px); letter-spacing:-.035em}
  .contact h2 .accent{color:var(--terra); font-style:italic; font-weight:300}
  .contact-sub{font-size:18px; opacity:.8; max-width:480px; margin:24px 0 40px}

  .contact-card{
    background:var(--ink);
    border:1px solid var(--line);
    border-radius:20px;
    padding:32px;
    margin-bottom:16px;
  }
  .contact-card h4{font-family:var(--mono); font-size:11px; letter-spacing:.2em; color:var(--gold); text-transform:uppercase; margin-bottom:20px; font-weight:500}
  .contact-rows{display:flex; flex-direction:column; gap:16px}
  .contact-row{display:flex; align-items:center; gap:16px}
  .contact-row .ico{
    width:44px; height:44px; border-radius:50%;
    background:rgba(201,169,97,.1); color:var(--gold);
    display:grid; place-items:center; flex-shrink:0;
  }
  .contact-row .ico svg{width:20px; height:20px}
  .contact-row .txt{display:flex; flex-direction:column}
  .contact-row .txt small{font-size:10.5px; opacity:.6; letter-spacing:.16em; text-transform:uppercase; font-family:var(--mono)}
  .contact-row .txt a, .contact-row .txt span{font-size:17px; font-weight:500; color:var(--cream)}

  form{display:flex; flex-direction:column; gap:16px}
  form .row{display:grid; grid-template-columns:1fr 1fr; gap:16px}
  @media(max-width:560px){form .row{grid-template-columns:1fr}}
  form label{display:flex; flex-direction:column; gap:6px; font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold)}
  form input, form select, form textarea{
    background:var(--ink);
    border:1px solid var(--line);
    color:var(--cream);
    padding:14px 16px;
    font-family:var(--body); font-size:15px;
    border-radius:10px;
    transition:border-color .25s, background .25s;
  }
  form input:focus, form select:focus, form textarea:focus{outline:none; border-color:var(--gold); background:var(--night)}
  form textarea{resize:vertical; min-height:120px; font-family:var(--body)}
  form .btn{justify-content:center; margin-top:8px}
  form .btn-primary{background:var(--gold); color:var(--night)}
  form .btn-primary:hover{background:var(--cream); color:var(--night)}
  .form-note{font-size:12px; opacity:.6; margin-top:10px; text-align:center}

  /* ===================================================================
   *  FOOTER
   * =================================================================== */
  footer{background:#060605; color:var(--cream); padding:80px 0 30px; position:relative}
  .foot-grid{display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:60px}
  @media(max-width:960px){.foot-grid{grid-template-columns:1fr 1fr; gap:40px}}
  @media(max-width:500px){.foot-grid{grid-template-columns:1fr}}
  .foot-brand{max-width:340px}
  .foot-brand .logo svg{color:var(--cream)}
  .foot-brand p{font-size:14px; opacity:.65; margin-top:20px; line-height:1.6}
  footer h5{font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:20px; font-weight:500}
  .foot-list{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px}
  .foot-list a{font-size:14px; opacity:.75; transition:opacity .25s, color .25s}
  .foot-list a:hover{opacity:1; color:var(--gold)}
  .foot-bar{padding-top:30px; border-top:1px solid var(--line); display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap; font-size:12px; opacity:.55}
  .foot-tag{font-family:var(--display); font-style:italic; font-weight:300}

  /* ===================================================================
   *  FLOATING WHATSAPP
   * =================================================================== */
  .wa-float{
    position:fixed; bottom:24px; right:24px; z-index:40;
    display:flex; align-items:center; gap:12px;
    padding:12px 20px 12px 12px;
    background:#25D366; color:#fff;
    border-radius:100px;
    box-shadow:0 20px 40px -10px rgba(37,211,102,.45);
    font-weight:600; font-size:14px;
    transition:transform .25s, box-shadow .25s;
  }
  .wa-float:hover{transform:scale(1.05); box-shadow:0 28px 50px -10px rgba(37,211,102,.55)}
  .wa-float .circle{width:40px; height:40px; border-radius:50%; background:#fff; color:#25D366; display:grid; place-items:center}
  .wa-float svg{width:22px; height:22px}
  .wa-float .label{display:none}
  @media(min-width:700px){.wa-float .label{display:inline}}

  /* ===================================================================
   *  REVEAL ANIM
   * =================================================================== */
  .rv{opacity:0; transform:translateY(24px); transition:opacity .8s var(--ease-out), transform .8s var(--ease-out)}
  .rv.show{opacity:1; transform:none}
  .rv.d1{transition-delay:.08s} .rv.d2{transition-delay:.16s}
  .rv.d3{transition-delay:.24s} .rv.d4{transition-delay:.32s}
  .rv.d5{transition-delay:.40s} .rv.d6{transition-delay:.48s}
  @media (prefers-reduced-motion:reduce){
    .rv, .hero h1 .line > span, .hero-sub, .hero-ctas, .hero-meta, .hero-visual{
      opacity:1 !important; transform:none !important; animation:none !important;
    }
  }
/* =================================================================== *
 *  LANDING PAGES — page-hero, deep-dive sections, sticky CTA
 * =================================================================== */

/* Sub-page hero (shorter than home hero, focused on one service) */
.page-hero{
  position:relative;
  padding: 160px 0 90px;
  background: var(--cream);
  overflow:hidden;
}
.page-hero::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(circle at 85% 25%, rgba(180,71,42,.08), transparent 50%),
    radial-gradient(circle at 15% 80%, rgba(201,169,97,.08), transparent 50%);
  pointer-events:none;
}
.page-hero.dark{background:var(--night); color:var(--cream)}
.page-hero.dark::before{
  background:
    radial-gradient(circle at 85% 25%, rgba(180,71,42,.18), transparent 50%),
    radial-gradient(circle at 15% 80%, rgba(201,169,97,.12), transparent 50%);
}

.breadcrumb{
  display:flex; gap:10px; align-items:center; flex-wrap:wrap;
  font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--char); opacity:.6;
  margin-bottom:30px;
}
.page-hero.dark .breadcrumb{color:var(--cream); opacity:.6}
.breadcrumb a{color:inherit; transition:opacity .2s, color .2s}
.breadcrumb a:hover{color:var(--terra); opacity:1}
.breadcrumb .sep{opacity:.4}

.page-hero h1{
  font-size: clamp(46px, 7.2vw, 100px);
  line-height:.95;
  letter-spacing:-.035em;
  margin: 14px 0 28px;
  max-width: 920px;
}
.page-hero h1 em{font-style:italic; font-weight:300; color:var(--terra)}
.page-hero.dark h1 em{color:var(--gold)}
.page-hero .lead{
  max-width:640px;
  font-size:19px;
  line-height:1.55;
  opacity:.85;
  margin-bottom:36px;
}
.page-hero .ctas{display:flex; gap:14px; flex-wrap:wrap}

/* Sticky CTA bar (appears on scroll on landing pages) */
.sticky-cta{
  position:fixed;
  bottom: -100px; left:0; right:0;
  z-index:30;
  background:rgba(14,14,12,.95);
  color:var(--cream);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-top:1px solid var(--line);
  padding:14px 0;
  transition: bottom .4s var(--ease-out);
}
.sticky-cta.visible{bottom:0}
.sticky-cta-inner{
  display:flex; justify-content:space-between; align-items:center;
  gap:20px; flex-wrap:wrap;
}
.sticky-cta .pitch{font-family:var(--display); font-size:17px; font-weight:500; letter-spacing:-.005em}
.sticky-cta .pitch em{font-style:italic; color:var(--gold); font-weight:300}
.sticky-cta .actions{display:flex; gap:10px; align-items:center}
.sticky-cta .btn{padding:12px 22px; font-size:14px}
@media(max-width:640px){
  .sticky-cta{bottom:-200px; padding:12px 0}
  .sticky-cta.visible{bottom:0}
  .sticky-cta-inner{justify-content:center; text-align:center}
  .sticky-cta .pitch{display:none}
}

/* Big-feature grid (2-col) — for "what we cover" sections */
.feat-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:2px;
  background:var(--line-ink);
  border-top:1px solid var(--line-ink);
  border-bottom:1px solid var(--line-ink);
  margin-bottom:60px;
}
@media(max-width:780px){.feat-grid{grid-template-columns:1fr}}
.feat{
  background:var(--cream);
  padding:44px 36px;
  display:flex; flex-direction:column; gap:14px;
  transition:background .3s var(--ease-out);
}
.feat:hover{background:var(--paper)}
.feat .feat-num{
  font-family:var(--mono); font-size:11px; letter-spacing:.22em;
  color:var(--terra); font-weight:500;
}
.feat h3{
  font-family:var(--display); font-size:30px; font-weight:500;
  letter-spacing:-.02em; line-height:1.1;
}
.feat p{font-size:15.5px; line-height:1.6; opacity:.82; margin:0}
.feat ul{list-style:none; padding:0; margin:8px 0 0; display:flex; flex-direction:column; gap:8px}
.feat li{
  font-size:14px; opacity:.78; padding-left:20px; position:relative;
}
.feat li::before{
  content:""; position:absolute; left:0; top:7px;
  width:10px; height:6px;
  border-left:1.5px solid var(--terra); border-bottom:1.5px solid var(--terra);
  transform:rotate(-45deg);
}

/* "Stats strip" — used on landing pages to lend credibility */
.stats-strip{
  background:var(--night);
  color:var(--cream);
  padding: clamp(60px, 8vw, 100px) 0;
}
.stats-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:50px;
}
@media(max-width:860px){.stats-grid{grid-template-columns:repeat(2,1fr); gap:40px}}
@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}
.stat-block{
  display:flex; flex-direction:column; gap:6px;
  border-left:1px solid var(--line);
  padding-left:24px;
}
.stat-block .big{
  font-family:var(--display); font-size:clamp(46px, 5vw, 68px); font-weight:500;
  letter-spacing:-.025em; line-height:1; color:var(--gold);
}
.stat-block .lab{
  font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; opacity:.65; margin-top:4px;
}
.stat-block p{font-size:14px; opacity:.7; margin:8px 0 0; line-height:1.5}

/* "Quote callout" — between sections */
.quote-callout{
  background:var(--paper-2);
  padding: clamp(70px, 10vw, 120px) 0;
  text-align:center;
}
.quote-callout blockquote{
  margin:0;
  max-width:920px;
  margin-inline:auto;
  font-family:var(--display); font-style:italic; font-weight:300;
  font-size: clamp(28px, 3.6vw, 48px);
  line-height:1.2;
  letter-spacing:-.015em;
  color:var(--night);
}
.quote-callout blockquote::before, .quote-callout blockquote::after{
  color:var(--terra); font-style:normal; font-weight:600; opacity:.7;
}
.quote-callout blockquote::before{content:"« "}
.quote-callout blockquote::after{content:" »"}
.quote-callout cite{
  display:block; margin-top:24px;
  font-family:var(--mono); font-size:11px; letter-spacing:.22em;
  text-transform:uppercase; font-style:normal;
  color:var(--terra);
}

/* Use-case mini-cards (case studies) */
.cases-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:24px;
}
@media(max-width:920px){.cases-grid{grid-template-columns:1fr}}
.case{
  background:var(--paper);
  border-radius:16px;
  padding:32px;
  display:flex; flex-direction:column; gap:14px;
  transition: transform .35s var(--ease-out), box-shadow .35s;
}
.case:hover{transform:translateY(-4px); box-shadow:0 30px 60px -30px rgba(14,14,12,.2)}
.case .sector{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--terra);
}
.case h4{font-family:var(--display); font-size:22px; font-weight:500; letter-spacing:-.01em; line-height:1.2}
.case p{font-size:14.5px; line-height:1.55; opacity:.8; margin:0}
.case .result{
  margin-top:auto;
  padding-top:18px;
  border-top:1px solid var(--line-ink);
  font-family:var(--mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--night); font-weight:500;
}
.case .result strong{color:var(--terra); font-size:16px; font-weight:700; letter-spacing:-.01em; text-transform:none; font-family:var(--display)}

/* Final CTA section */
.final-cta{
  background:var(--night);
  color:var(--cream);
  padding: clamp(80px, 12vw, 140px) 0;
  text-align:center;
  overflow:hidden;
  position:relative;
}
.final-cta::before{
  content:""; position:absolute;
  top:50%; left:50%;
  width:800px; height:800px;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(180,71,42,.1), transparent 60%);
  pointer-events:none;
}
.final-cta .wrap{position:relative; z-index:2}
.final-cta h2{
  font-size:clamp(40px, 6.4vw, 88px);
  letter-spacing:-.035em; line-height:.98;
  margin-bottom:28px; max-width:880px;
  margin-inline:auto;
}
.final-cta h2 em{font-style:italic; font-weight:300; color:var(--gold)}
.final-cta p{font-size:18px; opacity:.8; max-width:580px; margin:0 auto 40px}
.final-cta .ctas{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}

/* =================================================================== *
 *  LOGO IMAGES — adaptive dark/light based on background
 * =================================================================== */

/* Reset .logo svg-specific rules (the image-based logo doesn't need them) */
.logo{
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:inherit;
  position:relative;
  height:auto;
}
.logo svg{display:none} /* hide any leftover svg fallback */

.logo-img{
  display:block;
  height:32px;
  width:auto;
  transition: opacity .35s var(--ease-out, ease);
}

/* In the header, both variants are stacked. Toggle visibility based on .scrolled */
.nav .logo{position:relative; height:32px}
.nav .logo .logo-img{
  position:absolute;
  top:50%;
  left:0;
  transform:translateY(-50%);
}
.nav .logo .logo-img:first-of-type{position:relative; transform:none; top:auto}

/* Default state (top of page, light/cream background): show dark-text variant */
.nav .logo .logo-light{opacity:0; pointer-events:none}
.nav .logo .logo-dark {opacity:1}

/* Scrolled state (nav bg becomes night): show light-text variant */
.nav.scrolled .logo .logo-dark {opacity:0; pointer-events:none}
.nav.scrolled .logo .logo-light{opacity:1}

/* Footer logo: always light variant on dark bg */
.logo-footer{height:32px}
.logo-footer img{height:32px; width:auto; display:block}

/* Geographic suffix tag: small uppercase mono "Sénégal" next to the logo image */
.logo-tag{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--terra);
  padding: 4px 8px;
  border: 1px solid var(--terra);
  border-radius: 4px;
  margin-left: 4px;
  white-space: nowrap;
  line-height: 1;
}
.logo-footer .logo-tag{
  color: var(--gold);
  border-color: var(--gold);
  opacity: .9;
}
.nav.scrolled .logo .logo-tag{
  color: var(--gold);
  border-color: var(--gold);
}
@media (max-width: 640px){
  .logo-tag{display:none}
  .logo-img{height:28px}
}


/* =================================================================== *
 *  LEGAL PAGES — clean editorial reading layout
 * =================================================================== */

.legal-page{
  background: var(--cream);
  padding: 140px 0 80px;
}
.legal-wrap{
  max-width: 820px;
  margin-inline: auto;
  padding: 0 clamp(20px, 5vw, 40px);
}
.legal-page .breadcrumb{ margin-bottom: 30px }
.legal-page h1{
  font-size: clamp(40px, 5.5vw, 64px);
  letter-spacing:-.025em;
  line-height: 1;
  margin: 12px 0 24px;
  font-weight: 500;
}
.legal-page h1 em{font-style:italic; font-weight:300; color:var(--terra)}
.legal-page .lead{
  font-size: 18px;
  line-height: 1.6;
  opacity: .8;
  margin-bottom: 50px;
  padding-bottom: 30px;
  border-bottom: 1px solid var(--line-ink);
  max-width: 640px;
}
.legal-page h2{
  font-size: 26px;
  font-weight: 500;
  letter-spacing:-.015em;
  margin: 50px 0 16px;
  padding-top: 20px;
  border-top: 1px solid var(--line-ink);
  color: var(--night);
}
.legal-page h2:first-of-type{border-top:none; padding-top:0; margin-top:0}
.legal-page h3{
  font-size: 18px;
  font-weight: 600;
  margin: 30px 0 10px;
  color: var(--night);
}
.legal-page p, .legal-page li{
  font-size: 15.5px;
  line-height: 1.7;
  color: var(--char);
  margin: 0 0 14px;
}
.legal-page ul{padding-left: 22px; margin-bottom: 20px}
.legal-page li{margin-bottom: 6px}
.legal-page strong{color: var(--night); font-weight: 600}
.legal-page a{color: var(--terra); text-decoration: underline; text-underline-offset: 3px}
.legal-page a:hover{color: var(--terra-dk)}
.legal-page .legal-meta{
  background: var(--paper);
  padding: 24px 28px;
  border-left: 3px solid var(--terra);
  margin: 24px 0;
  font-size: 14.5px;
  line-height: 1.6;
}
.legal-page .legal-meta strong{display: block; margin-bottom: 4px}
.legal-page .last-updated{
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: .15em;
  text-transform: uppercase;
  opacity: .6;
  margin-top: 60px;
  padding-top: 24px;
  border-top: 1px solid var(--line-ink);
}


/* =================================================================== *
 *  RESPONSIVE SHOWCASE — visual proof of mobile-first design
 * =================================================================== */

.responsive-showcase{
  background: linear-gradient(180deg, var(--paper-2) 0%, var(--cream) 100%);
}

.rs-stage{
  display: grid;
  grid-template-columns: 1.7fr 1fr 0.5fr;
  gap: clamp(20px, 3vw, 40px);
  align-items: end;
  margin: 30px 0 80px;
  padding: 60px clamp(20px, 4vw, 50px) 40px;
  background: var(--cream);
  border-radius: 8px;
  border: 1px solid var(--line-ink);
  position: relative;
  overflow: hidden;
}
.rs-stage::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(circle at 70% 30%, rgba(180,71,42,.04), transparent 60%),
    radial-gradient(circle at 20% 80%, rgba(201,169,97,.05), transparent 50%);
  pointer-events:none;
}
@media(max-width: 920px){
  .rs-stage{
    grid-template-columns: 1fr 1fr;
    grid-template-areas: "desktop desktop" "tablet phone";
    gap: 30px;
  }
  .rs-desktop{grid-area: desktop}
  .rs-tablet{grid-area: tablet}
  .rs-phone{grid-area: phone}
}
@media(max-width: 560px){
  .rs-stage{
    grid-template-columns: 1fr;
    grid-template-areas: "desktop" "tablet" "phone";
    padding: 40px 16px 30px;
  }
}

.rs-device{
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 1;
}
.rs-device figcaption{
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  text-align: center;
}
.rs-label{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--terra);
}
.rs-w{
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .15em;
  color: var(--char);
  opacity: .5;
}

/* Frame styling — Apple-style rendering */
.rs-frame{
  background: #1a1a18;
  position: relative;
  box-shadow:
    0 30px 60px -20px rgba(14,14,12,0.35),
    0 10px 25px -10px rgba(14,14,12,0.2),
    inset 0 0 0 1px rgba(255,255,255,0.08);
}
.rs-screen{
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
}
.rs-screen svg{display:block; width:100%; height:100%}

/* Desktop = laptop with stand */
.rs-desktop .rs-frame{
  width: 100%;
  aspect-ratio: 16/10;
  border-radius: 8px 8px 2px 2px;
  padding: 16px 14px 14px;
}
.rs-desktop .rs-screen{border-radius: 2px}
.rs-stand{
  width: 50%;
  height: 12px;
  margin: 0 auto;
  background: linear-gradient(180deg, #2a2a26 0%, #1a1a18 60%);
  border-radius: 0 0 12px 12px;
  position: relative;
}
.rs-stand::after{
  content:"";
  position: absolute;
  bottom: -3px; left: -10%;
  width: 120%;
  height: 3px;
  background: #14140f;
  border-radius: 0 0 6px 6px;
}

/* Tablet */
.rs-tablet .rs-frame{
  width: 100%;
  max-width: 220px;
  aspect-ratio: 200/260;
  border-radius: 18px;
  padding: 14px 11px;
}
.rs-tablet .rs-screen{border-radius: 6px}

/* Phone — with notch */
.rs-phone .rs-frame{
  width: 100%;
  max-width: 130px;
  aspect-ratio: 130/260;
  border-radius: 22px;
  padding: 9px 7px 14px;
}
.rs-phone .rs-screen{border-radius: 14px}
.rs-notch{
  position: absolute;
  top: 9px; left: 50%;
  transform: translateX(-50%);
  width: 38%;
  height: 7px;
  background: #0a0a08;
  border-radius: 0 0 6px 6px;
  z-index: 2;
}
.rs-home{
  position: absolute;
  bottom: 5px; left: 50%;
  transform: translateX(-50%);
  width: 30%;
  height: 2px;
  background: #444;
  border-radius: 1px;
}

/* Features grid below the stage */
.rs-features{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 30px;
}
@media(max-width: 780px){
  .rs-features{grid-template-columns: 1fr; gap: 14px}
}
.rs-feat{
  background: var(--cream);
  padding: 28px 24px;
  border-left: 2px solid var(--terra);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.rs-feat-num{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .22em;
  color: var(--terra);
}
.rs-feat h4{
  font-family: var(--display);
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -.01em;
  line-height: 1.2;
  margin: 0;
}
.rs-feat p{
  font-size: 14px;
  line-height: 1.55;
  opacity: .8;
  margin: 0;
}

