/* ═══════════════════════════════════════════════════════════════
   SYNTHOCODE STUDIO — Editorial design system
   Loaded AFTER main.css. Overrides legacy "premium" Bootstrap styles
   to match the editorial language (Fraunces + JetBrains Mono,
   paper + ink + vermillion palette, grain overlay).
   ═══════════════════════════════════════════════════════════════ */

:root{
  --ed-paper:#f5efe2;
  --ed-paper-2:#ebe4d3;
  --ed-ink:#1a1814;
  --ed-ink-2:#3a3530;
  --ed-vermillion:#ff3b1f;
  --ed-vermillion-soft:#ff7a5c;
  --ed-rule:rgba(26,24,20,.16);
  --ed-muted:#6b6359;
  --ed-display:'Fraunces',Georgia,serif;
  --ed-mono:'JetBrains Mono',ui-monospace,monospace;
}

/* ─── helpers : .ed-mono, .ed-vermillion etc ─── */
.ed-mono{font-family:var(--ed-mono);letter-spacing:.16em;text-transform:uppercase;font-size:11px;font-weight:600}
.ed-display{font-family:var(--ed-display)}
.ed-vermillion{color:var(--ed-vermillion)}
.ed-italic{font-style:italic;color:var(--ed-vermillion);font-weight:400}
em.ed{font-style:italic;color:var(--ed-vermillion);font-weight:400}

/* ═══════════════════════════════════════════════
   NAVBAR — editorial top bar
   ═══════════════════════════════════════════════ */
.navbar.navbar-dark{
  background:var(--ed-paper)!important;
  border-bottom:1px solid var(--ed-rule);
  padding:14px 0;
  box-shadow:none;
}
.navbar.navbar-dark .navbar-brand{padding:0;display:flex;align-items:center}
.navbar.navbar-dark .main-logo-premium{
  height:130px!important;width:auto;margin:-25px 0;display:block;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));
}
@media(max-width:991.98px){
  .navbar.navbar-dark .main-logo-premium{height:90px!important;margin:-15px 0}
}
.navbar.navbar-dark .navbar-nav .nav-link{
  font-family:var(--ed-mono);
  font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;
  color:var(--ed-ink)!important;opacity:.85;
  padding:9px 14px;border-radius:0;
  transition:opacity .2s ease, color .2s ease;
}
.navbar.navbar-dark .navbar-nav .nav-link:hover,
.navbar.navbar-dark .navbar-nav .nav-link.active{
  color:var(--ed-vermillion)!important;opacity:1;
  text-decoration:underline;text-underline-offset:6px;text-decoration-thickness:1.5px;
}
/* Bootstrap toggler removed — replaced by .ed-burger */
.navbar.navbar-dark .navbar-toggler{display:none!important}

/* ───────── Editorial burger button (3 lines → X morph) ───────── */
.ed-burger{
  display:none;width:48px;height:48px;border-radius:50%;
  border:1.5px solid var(--ed-ink);background:var(--ed-ink);
  cursor:pointer;padding:0;align-items:center;justify-content:center;
  flex-direction:column;gap:5px;position:relative;z-index:1102;
  margin-left:auto;transition:background .2s ease, border-color .2s ease;
}
.ed-burger:hover{background:var(--ed-vermillion);border-color:var(--ed-vermillion)}
.ed-burger-line{
  display:block;width:20px;height:2px;background:var(--ed-paper);
  transition:transform .25s ease, opacity .25s ease;
}
.ed-burger.open{background:var(--ed-paper);border-color:var(--ed-ink)}
.ed-burger.open .ed-burger-line{background:var(--ed-ink)}
.ed-burger.open .ed-burger-line:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ed-burger.open .ed-burger-line:nth-child(2){opacity:0}
.ed-burger.open .ed-burger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:991.98px){.ed-burger{display:inline-flex}}

/* ───────── Mobile fullscreen menu overlay (editorial) ─────────
   All children absolutely positioned so FR/EN length differences
   can never reshuffle the layout vertically. */
.ed-mobile-menu{
  position:fixed;inset:0;z-index:1101;background:var(--ed-paper);
  padding:96px 32px 32px;opacity:0;pointer-events:none;
  transition:opacity .4s cubic-bezier(.4,0,.2,1);
}
.ed-mobile-menu.open{opacity:1;pointer-events:auto}
.ed-mobile-menu::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  opacity:.32;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.07  0 0 0 0 0.06  0 0 0 0 0.04  0 0 0 0.45 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* Eyebrow */
.ed-mm-eyebrow{
  position:absolute;top:96px;left:32px;right:32px;z-index:1;
  font-family:var(--ed-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ed-vermillion);font-weight:700;
  display:flex;align-items:center;gap:10px;
  opacity:0;transform:translateY(12px);
  transition:opacity .45s ease .1s, transform .45s ease .1s;
}
.ed-mm-eyebrow::before{
  content:"";width:6px;height:6px;background:var(--ed-vermillion);border-radius:50%;
  box-shadow:0 0 0 4px rgba(255,59,31,.18);flex:none;
}
.ed-mobile-menu.open .ed-mm-eyebrow{opacity:1;transform:translateY(0)}

/* Nav block (absolutely centered) */
.ed-mobile-menu nav{
  position:absolute;top:50%;left:32px;right:32px;transform:translateY(-50%);
  display:flex;flex-direction:column;gap:2px;z-index:1;
}
.ed-mobile-menu nav a{
  font-family:var(--ed-display);font-weight:400;
  font-size:clamp(28px,8vw,46px);line-height:1.05;letter-spacing:-.025em;
  color:var(--ed-ink);text-decoration:none;
  display:flex;align-items:baseline;gap:16px;
  padding:14px 0;border-bottom:1px solid var(--ed-rule);
  box-sizing:border-box;height:clamp(60px,12vw,82px);overflow:hidden;
  opacity:0;transform:translateY(20px);
  transition:opacity .5s cubic-bezier(.2,.7,.2,1), transform .5s cubic-bezier(.2,.7,.2,1), color .2s ease;
}
.ed-mobile-menu nav a:last-of-type{border-bottom:1px solid var(--ed-rule)}
.ed-mobile-menu nav a .num{
  font-family:var(--ed-mono);font-size:11px;letter-spacing:.18em;
  color:var(--ed-vermillion);font-weight:700;min-width:34px;flex:none;
}
.ed-mobile-menu nav a em{font-style:italic;color:var(--ed-vermillion);font-weight:400}
.ed-mobile-menu nav a:hover,.ed-mobile-menu nav a:active,.ed-mobile-menu nav a.active{color:var(--ed-vermillion)}
.ed-mobile-menu.open nav a{opacity:1;transform:translateY(0)}
.ed-mobile-menu.open nav a:nth-child(1){transition-delay:.18s}
.ed-mobile-menu.open nav a:nth-child(2){transition-delay:.24s}
.ed-mobile-menu.open nav a:nth-child(3){transition-delay:.30s}
.ed-mobile-menu.open nav a:nth-child(4){transition-delay:.36s}
.ed-mobile-menu.open nav a:nth-child(5){transition-delay:.42s}

/* Footer of mobile menu (CTA + legal links) */
.ed-mm-foot{
  position:absolute;left:32px;right:32px;bottom:32px;z-index:1;
  display:flex;flex-direction:column;gap:16px;
  opacity:0;transform:translateY(12px);
  transition:opacity .5s ease .55s, transform .5s ease .55s;
}
.ed-mobile-menu.open .ed-mm-foot{opacity:1;transform:translateY(0)}
.ed-mm-cta{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 22px;background:var(--ed-ink);color:var(--ed-paper);
  border:1.5px solid var(--ed-ink);border-radius:999px;
  font-family:var(--ed-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  text-decoration:none;transition:all .2s ease;
}
.ed-mm-cta:hover{background:var(--ed-vermillion);border-color:var(--ed-vermillion);color:#fff}
.ed-mm-arr{transition:transform .2s}
.ed-mm-cta:hover .ed-mm-arr{transform:translateX(3px)}
.ed-mm-legal{
  display:flex;justify-content:center;gap:14px;align-items:center;flex-wrap:wrap;
  font-family:var(--ed-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ed-muted);
}
.ed-mm-legal a{color:var(--ed-ink-2);text-decoration:none;transition:color .15s}
.ed-mm-legal a:hover{color:var(--ed-vermillion)}
.ed-mm-legal span{color:var(--ed-rule)}

/* Hide overlay on desktop */
@media(min-width:992px){.ed-mobile-menu{display:none!important}}

/* Hide Bootstrap navbar-collapse on mobile (we use our custom overlay) */
@media(max-width:991.98px){
  .navbar.navbar-dark .navbar-collapse{display:none!important}
}

/* ═══════════════════════════════════════════════
   BACK TO TOP — floating editorial button
   ═══════════════════════════════════════════════ */
.ed-to-top{
  position:fixed;right:28px;bottom:28px;z-index:90;
  width:54px;height:54px;border-radius:50%;
  background:var(--ed-ink);color:var(--ed-paper);
  border:1.5px solid var(--ed-ink);
  box-shadow:4px 4px 0 var(--ed-vermillion);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ed-mono);font-size:22px;font-weight:700;line-height:1;
  cursor:pointer;opacity:0;pointer-events:none;transform:translateY(12px);
  transition:opacity .25s ease, transform .25s ease, background .15s, box-shadow .15s;
  text-decoration:none!important;
}
.ed-to-top:hover{
  background:var(--ed-vermillion);border-color:var(--ed-vermillion);
  box-shadow:4px 4px 0 var(--ed-ink);color:#fff;
}
.ed-to-top.visible{opacity:1;pointer-events:auto;transform:translateY(0)}
@media(max-width:540px){
  .ed-to-top{right:18px;bottom:18px;width:46px;height:46px;font-size:18px}
}

/* When the collapse is open on mobile, ensure menu is on paper background */
@media(max-width:991.98px){
  .navbar.navbar-dark .navbar-collapse{
    background:var(--ed-paper);border-top:1px solid var(--ed-rule);
    margin-top:14px;padding:14px 0;
  }
  .navbar.navbar-dark .navbar-nav .nav-link{padding:14px 0;text-align:center}
}

/* ═══════════════════════════════════════════════
   FOOTER — editorial
   ═══════════════════════════════════════════════ */
footer.footer{
  background:var(--ed-ink)!important;
  color:var(--ed-paper);
  padding:80px 0 32px;
  position:relative;
  border:0;
  font-family:var(--ed-display);
}
footer.footer::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 18% 28%,rgba(255,59,31,.12) 0%,transparent 55%),
             radial-gradient(circle at 80% 78%,rgba(255,59,31,.10) 0%,transparent 55%);
}
footer.footer > .container{position:relative;z-index:1}

footer.footer h2{
  font-family:var(--ed-mono)!important;
  font-size:11px!important;letter-spacing:.18em!important;text-transform:uppercase!important;
  color:var(--ed-vermillion-soft)!important;
  font-weight:700!important;
  margin-bottom:24px!important;
}
footer.footer p,
footer.footer li,
footer.footer a{font-family:var(--ed-display)}
footer.footer p{color:#d5cebf!important;font-size:15px;line-height:1.6}

footer.footer ul.list-unstyled li{margin-bottom:10px!important}
footer.footer ul.list-unstyled a{
  color:var(--ed-paper)!important;font-size:15px;
  display:inline-flex;align-items:center;gap:8px;
  transition:color .15s ease, transform .15s ease;
}
footer.footer ul.list-unstyled a:hover{
  color:var(--ed-vermillion-soft)!important;transform:translateX(3px);
}
footer.footer ul.list-unstyled a i{
  color:var(--ed-vermillion-soft)!important;font-size:13px!important;width:auto!important;
  margin-right:0!important;
}

/* hide caret icon styling on links — we just keep the arrow on hover */
footer.footer ul.list-unstyled .ph-caret-right,
footer.footer ul.list-unstyled .fa-caret-right{display:none}

/* Contact rows — icon + text aligned to same vertical center */
footer.footer .d-flex.align-items-center{
  align-items:center!important;
  gap:12px!important;
  margin-bottom:14px!important;
}
footer.footer .d-flex.align-items-center > i{
  color:var(--ed-vermillion-soft)!important;
  font-size:16px!important;
  width:20px!important;
  height:20px!important;
  margin:0!important;margin-right:0!important;
  display:inline-flex!important;align-items:center;justify-content:center;
  flex:none;line-height:1;
}
footer.footer .d-flex.align-items-center a,
footer.footer .d-flex.align-items-center span{
  color:var(--ed-paper)!important;font-family:var(--ed-display);
  font-size:15px;font-weight:500;line-height:1.4;
}

/* Social icons container */
footer.footer .social-container-uiverse{margin-top:22px;display:flex;gap:14px}
footer.footer .social-container-uiverse .icon{
  width:42px;height:42px;border-radius:50%;
  background:transparent;border:1.5px solid rgba(245,239,226,.4);
  display:flex;align-items:center;justify-content:center;
  color:var(--ed-paper);transition:all .2s ease;
}
footer.footer .social-container-uiverse .icon svg{width:18px;height:18px}
footer.footer .social-container-uiverse .icon:hover{
  background:var(--ed-vermillion);border-color:var(--ed-vermillion);color:#fff;
  transform:translateY(-2px);
}

/* Bottom bar */
footer.footer > .container > .row.mt-5{
  border-top:1px solid rgba(245,239,226,.15)!important;
  margin-top:60px!important;padding-top:28px!important;
}
footer.footer > .container > .row.mt-5 p,
footer.footer > .container > .row.mt-5 a,
footer.footer > .container > .row.mt-5 small{
  font-family:var(--ed-mono)!important;
  font-size:10.5px!important;letter-spacing:.14em!important;text-transform:uppercase!important;
  color:rgba(245,239,226,.7)!important;font-weight:500;
}
footer.footer > .container > .row.mt-5 strong{
  color:var(--ed-paper)!important;font-weight:700;
}
footer.footer > .container > .row.mt-5 a{
  transition:color .15s ease;text-decoration:none!important;
}
footer.footer > .container > .row.mt-5 a:hover{color:var(--ed-vermillion-soft)!important}
footer.footer > .container > .row.mt-5 span{color:rgba(245,239,226,.25)!important}

/* ───────── Footer responsive — center everything on mobile ───────── */
@media(max-width:780px){
  footer.footer{padding:56px 0 24px;text-align:center}
  footer.footer .row.g-5 > [class*="col-"]{text-align:center}
  footer.footer h2{text-align:center}
  footer.footer p{text-align:center}
  /* Contact rows : stack vertically and center */
  footer.footer .d-flex.align-items-center{
    flex-direction:column!important;
    align-items:center!important;
    gap:6px!important;
    margin-bottom:18px!important;
  }
  footer.footer .d-flex.align-items-center > i{
    margin-top:0!important;font-size:16px!important;
  }
  footer.footer .d-flex.align-items-center a,
  footer.footer .d-flex.align-items-center span{
    text-align:center;font-size:14px;
  }
  /* Navigation links : center the list */
  footer.footer ul.list-unstyled{padding:0;margin:0}
  footer.footer ul.list-unstyled li{text-align:center}
  footer.footer ul.list-unstyled a{justify-content:center}
  /* Social icons : center the row */
  footer.footer .social-container-uiverse{justify-content:center}
  /* Bottom bar : center everything */
  footer.footer > .container > .row.mt-5 .text-md-start,
  footer.footer > .container > .row.mt-5 .text-md-end{text-align:center!important}
  footer.footer > .container > .row.mt-5 > div{margin-bottom:14px}
}

/* ═══════════════════════════════════════════════
   GLOBAL OVERRIDES — body bg, scrollbar, native components
   that main.css set to a dark/blue scheme.
   ═══════════════════════════════════════════════ */
body{
  font-family:var(--ed-display);
  background:var(--ed-paper)!important;
  color:var(--ed-ink)!important;
}
html{background:var(--ed-paper)}

/* Page loader override (dark intro screen) */
.page-loader{background:var(--ed-paper)!important}
.page-loader .loader-text{color:var(--ed-ink)!important;font-family:var(--ed-display)!important}
.page-loader .loader{border-color:var(--ed-rule)!important;border-top-color:var(--ed-vermillion)!important}

/* Animated bg + particles (legacy decoration) — neutralised */
.animated-bg{display:none!important}
.particles{display:none!important}

/* Editorial scrollbar (paper rail, ink thumb, vermillion hover) */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--ed-paper-2)!important;border:0}
::-webkit-scrollbar-thumb{
  background:var(--ed-ink)!important;
  border:2px solid var(--ed-paper-2)!important;
  border-radius:6px;
}
::-webkit-scrollbar-thumb:hover{background:var(--ed-vermillion)!important}
html{scrollbar-color:var(--ed-ink) var(--ed-paper-2);scrollbar-width:thin}

/* Legacy violet buttons (.btn-shiny-*, Bootstrap btn-primary inside modals)
   forced to editorial palette so any old-HTML page renders consistently. */
.btn-shiny-primary,
.btn-shiny-dark,
.modal .btn-primary,
.modal .btn-outline-primary,
.modal .btn-light,
.modal-content .btn-primary{
  background:var(--ed-ink)!important;
  background-image:none!important;
  border:1.5px solid var(--ed-ink)!important;
  color:var(--ed-paper)!important;
  text-shadow:none!important;
  border-radius:999px!important;
  font-family:var(--ed-mono)!important;
  font-size:12px!important;
  letter-spacing:.14em!important;
  text-transform:uppercase!important;
  font-weight:700!important;
  padding:14px 26px!important;
  transition:all .2s ease!important;
  box-shadow:none!important;
}
.btn-shiny-primary:hover,
.btn-shiny-dark:hover,
.modal .btn-primary:hover,
.modal .btn-outline-primary:hover,
.modal .btn-light:hover{
  background:var(--ed-vermillion)!important;
  border-color:var(--ed-vermillion)!important;
  color:#fff!important;
  transform:translateY(-1px)!important;
  filter:none!important;
}
.btn-shiny-silver{
  background:var(--ed-paper-2)!important;
  background-image:none!important;
  border:1.5px solid var(--ed-ink)!important;
  color:var(--ed-ink)!important;
  text-shadow:none!important;
  border-radius:999px!important;
  font-family:var(--ed-mono)!important;
  font-size:12px!important;
  letter-spacing:.14em!important;
  text-transform:uppercase!important;
  font-weight:700!important;
}
.btn-shiny-silver:hover{
  background:var(--ed-ink)!important;
  color:var(--ed-paper)!important;
}

/* Bootstrap modal-content : kill the dark/glassy legacy look on any
   modal that doesn't have our .f-modal-content override applied. */
.modal-content:not(.f-modal-content){
  background:var(--ed-paper)!important;
  border:1.5px solid var(--ed-ink)!important;
  color:var(--ed-ink)!important;
  border-radius:0!important;
  box-shadow:10px 10px 0 var(--ed-ink)!important;
}
.modal-content:not(.f-modal-content) .modal-title,
.modal-content:not(.f-modal-content) h1,
.modal-content:not(.f-modal-content) h2,
.modal-content:not(.f-modal-content) h3,
.modal-content:not(.f-modal-content) p,
.modal-content:not(.f-modal-content) strong{color:var(--ed-ink)!important}
.modal-content:not(.f-modal-content) .text-muted{color:var(--ed-ink-2)!important}
.modal-content:not(.f-modal-content) .btn-close{filter:none!important;opacity:1!important;color:var(--ed-ink)!important}
.modal-content:not(.f-modal-content) .glass-card{
  background:var(--ed-paper-2)!important;
  border:1.5px solid var(--ed-ink)!important;
  backdrop-filter:none!important;
  border-radius:0!important;
}
.modal-content:not(.f-modal-content) .badge.bg-primary{
  background:var(--ed-ink)!important;
  color:var(--ed-paper)!important;
  font-family:var(--ed-mono)!important;
  letter-spacing:.14em!important;
  text-transform:uppercase!important;
  font-weight:600!important;
  border-radius:999px!important;
  padding:5px 11px!important;
}

/* Stack technique pills in the portfolio modal — Bootstrap .bg-primary
   has !important on background, so we must use !important too. The JS
   in portfolio-filter.js injects <span class="badge bg-primary">. */
.f-modal-tech .badge,
.f-modal-tech .badge.bg-primary,
#projectModalTechnologies .badge,
#projectModalTechnologies .badge.bg-primary{
  background:var(--ed-paper-2)!important;
  background-image:none!important;
  color:var(--ed-ink)!important;
  border:1.5px solid var(--ed-ink)!important;
  font-family:var(--ed-mono)!important;
  font-size:10.5px!important;
  letter-spacing:.14em!important;
  text-transform:uppercase!important;
  font-weight:600!important;
  border-radius:999px!important;
  padding:6px 12px!important;
  margin:0 4px 4px 0!important;
}

/* Modal category badge (e.g. "ECOMMERCE") */
#projectModalCategory,
.f-modal-eyebrow{
  color:var(--ed-vermillion)!important;
  font-family:var(--ed-mono)!important;
  font-size:11px!important;
  letter-spacing:.18em!important;
  text-transform:uppercase!important;
  font-weight:700!important;
  background:transparent!important;
}

/* Contact form success popup — match editorial language */
.premium-alert{
  background:var(--ed-paper)!important;
  backdrop-filter:none!important;
  border:1.5px solid var(--ed-ink)!important;
  border-left:5px solid var(--ed-vermillion)!important;
  color:var(--ed-ink)!important;
  padding:18px 22px!important;
  border-radius:0!important;
  box-shadow:6px 6px 0 var(--ed-ink)!important;
  display:flex!important;align-items:center!important;justify-content:flex-start!important;
  gap:14px!important;
  font-family:var(--ed-display)!important;
  font-weight:500!important;font-size:15.5px!important;line-height:1.45!important;
  margin-top:24px!important;
}
.premium-alert i{
  color:var(--ed-vermillion)!important;
  -webkit-text-fill-color:var(--ed-vermillion)!important;
  font-size:18px!important;text-shadow:none!important;flex:none;
}

/* Don't break the existing portfolio scope which has its own f-* tokens */
.f-portfolio h1, .f-portfolio h2, .f-portfolio h3, .f-portfolio h4, .f-portfolio h5{
  font-family:var(--ed-display);
}

/* ═══════════════════════════════════════════════
   PRIMITIVES — reusable editorial blocks
   Use these on any page: .ed-section, .ed-kicker, .ed-h1, .ed-card, .ed-btn
   ═══════════════════════════════════════════════ */
.ed-section{padding:80px 0;position:relative;background:var(--ed-paper);color:var(--ed-ink)}
.ed-section.alt{background:var(--ed-paper-2)}
.ed-section.dark{background:var(--ed-ink);color:var(--ed-paper)}
.ed-section.dark .ed-lede{color:#d5cebf}

.ed-shell{max-width:1240px;margin:0 auto;padding:0 32px}

.ed-kicker{
  display:flex;align-items:center;gap:14px;margin-bottom:34px;
  font-family:var(--ed-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ed-muted);
}
.ed-kicker .dot{width:9px;height:9px;border-radius:50%;background:var(--ed-vermillion);flex:none}
.ed-kicker .line{flex:1;height:1px;background:var(--ed-rule)}

.ed-h1{
  font-family:var(--ed-display);font-weight:300;
  font-size:clamp(48px,8vw,108px);line-height:.95;letter-spacing:-.025em;
  color:var(--ed-ink);margin:0 0 24px;
}
.ed-h1 em{font-style:italic;color:var(--ed-vermillion);font-weight:400}
.ed-h1 strong{font-weight:700}

.ed-h2{
  font-family:var(--ed-display);font-weight:300;
  font-size:clamp(34px,5vw,64px);line-height:1.02;letter-spacing:-.02em;
  color:var(--ed-ink);margin:0 0 18px;
}
.ed-h2 em{font-style:italic;color:var(--ed-vermillion);font-weight:400}

.ed-lede{
  font-family:var(--ed-display);font-size:clamp(17px,1.4vw,21px);line-height:1.55;
  color:var(--ed-ink-2);max-width:680px;margin:0;
}

.ed-card{
  background:var(--ed-paper);border:1.5px solid var(--ed-ink);
  box-shadow:8px 8px 0 var(--ed-ink);padding:30px;
  transition:transform .25s ease, box-shadow .25s ease;
}
.ed-card:hover{transform:translate(-3px,-3px);box-shadow:11px 11px 0 var(--ed-vermillion)}

.ed-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:999px;border:1.5px solid var(--ed-ink);
  font-family:var(--ed-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  text-decoration:none!important;cursor:pointer;
  transition:all .2s ease;
}
.ed-btn.primary{background:var(--ed-ink);color:var(--ed-paper)}
.ed-btn.primary:hover{background:var(--ed-vermillion);border-color:var(--ed-vermillion);color:#fff;transform:translateY(-1px)}
.ed-btn.ghost{background:transparent;color:var(--ed-ink)}
.ed-btn.ghost:hover{background:var(--ed-ink);color:var(--ed-paper)}
.ed-btn.on-dark{border-color:var(--ed-paper);background:var(--ed-paper);color:var(--ed-ink)}
.ed-btn.on-dark:hover{background:var(--ed-vermillion);border-color:var(--ed-vermillion);color:#fff}
.ed-btn .arr{transition:transform .2s}
.ed-btn:hover .arr{transform:translateX(3px)}

.ed-tag{
  display:inline-flex;align-items:center;padding:5px 12px;border-radius:999px;
  background:var(--ed-paper-2);color:var(--ed-ink-2);border:1.5px solid var(--ed-ink);
  font-family:var(--ed-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
}

/* Mobile fixes for editorial primitives */
@media(max-width:780px){
  .ed-section{padding:60px 0}
  .ed-shell{padding:0 20px}
  .ed-card{padding:22px;box-shadow:5px 5px 0 var(--ed-ink)}
  .ed-card:hover{transform:none;box-shadow:5px 5px 0 var(--ed-vermillion)}
}

/* ═══════════════════════════════════════════════
   SERVICE PAGES — vitrine, ecommerce, app-web,
   maintenance, seo, prestations (shared markup)
   ═══════════════════════════════════════════════ */
.s-shell{max-width:1240px;margin:0 auto;padding:0 32px;position:relative;z-index:1}
.s-mono{font-family:var(--ed-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--ed-muted)}
body:has(.s-hero){background:var(--ed-paper)}

/* HERO */
.s-hero{padding:64px 0 80px;background:var(--ed-paper);border-bottom:1px solid var(--ed-rule);position:relative;overflow:hidden}
.s-hero::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.28;mix-blend-mode:multiply;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.07  0 0 0 0 0.06  0 0 0 0 0.04  0 0 0 0.45 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}
.s-kicker{display:flex;align-items:center;gap:16px;margin-bottom:40px;font-family:var(--ed-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ed-muted)}
.s-dot{width:10px;height:10px;border-radius:50%;background:var(--ed-vermillion);flex:none}
.s-line{flex:1;height:1px;background:var(--ed-rule)}
.s-h1{font-family:var(--ed-display);font-weight:300;font-size:clamp(46px,7vw,100px);line-height:.96;letter-spacing:-.025em;color:var(--ed-ink);margin:0 0 22px}
.s-h1 em{font-style:italic;color:var(--ed-vermillion);font-weight:400}
.s-h1 strong{font-weight:700}
.s-lede{font-family:var(--ed-display);font-size:clamp(17px,1.4vw,21px);line-height:1.55;color:var(--ed-ink-2);max-width:680px;margin:0}

/* Section */
.s-section{padding:88px 0;background:var(--ed-paper)}
.s-section.alt{background:var(--ed-paper-2)}
.s-section + .s-section{border-top:1px solid var(--ed-rule)}
.s-section-head{display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:start;margin-bottom:48px}
.s-num{font-family:var(--ed-display);font-style:italic;font-weight:300;color:var(--ed-vermillion);font-size:84px;line-height:.85}
.s-eyebrow{display:block;margin-bottom:12px;color:var(--ed-muted)}
.s-h2{font-family:var(--ed-display);font-weight:300;font-size:clamp(32px,4.5vw,56px);line-height:1.02;letter-spacing:-.02em;color:var(--ed-ink);margin:0}
.s-h2 em{font-style:italic;color:var(--ed-vermillion);font-weight:400}

/* Why us : preview + 3 steps */
.s-why{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:980px){.s-why{grid-template-columns:1fr;gap:32px}}
.s-preview{background:var(--ed-ink);border:1.5px solid var(--ed-ink);box-shadow:14px 14px 0 var(--ed-vermillion);overflow:hidden;transform:rotate(-.4deg)}
.s-preview-head{display:flex;gap:6px;padding:10px 14px;background:#0f0e0c}
.s-preview-head span{width:10px;height:10px;border-radius:50%;background:#5a5550}
.s-preview-head span:nth-child(1){background:#ff5f56}
.s-preview-head span:nth-child(2){background:#ffbd2e}
.s-preview-head span:nth-child(3){background:#27c93f}
.s-preview img{width:100%;height:auto;display:block;background:var(--ed-paper)}
.s-steps{display:flex;flex-direction:column;gap:28px}
.s-step{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start}
.s-step-num{font-family:var(--ed-display);font-style:italic;font-weight:300;color:var(--ed-vermillion);font-size:48px;line-height:.85}
.s-step h3{font-family:var(--ed-display);font-size:22px;font-weight:600;letter-spacing:-.01em;color:var(--ed-ink);margin:0 0 8px}
.s-step p{font-family:var(--ed-display);font-size:15.5px;line-height:1.55;color:var(--ed-ink-2);margin:0}

/* Feature grid */
.s-features{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:880px){.s-features{grid-template-columns:1fr}}
.s-feat-card{background:var(--ed-paper);border:1.5px solid var(--ed-ink);box-shadow:8px 8px 0 var(--ed-ink);padding:30px 26px;transition:transform .25s ease, box-shadow .25s ease;display:flex;flex-direction:column}
.s-feat-card:hover{transform:translate(-3px,-3px);box-shadow:11px 11px 0 var(--ed-vermillion)}
.s-feat-num{font-family:var(--ed-mono);font-size:11px;letter-spacing:.18em;color:var(--ed-vermillion);font-weight:700;margin-bottom:14px}
.s-feat-card h3{font-family:var(--ed-display);font-size:22px;font-weight:600;letter-spacing:-.015em;color:var(--ed-ink);margin:0 0 10px;line-height:1.2}
.s-feat-card h3 em{font-style:italic;color:var(--ed-vermillion);font-weight:400}
.s-feat-card p{font-family:var(--ed-display);font-size:15px;line-height:1.55;color:var(--ed-ink-2);margin:0}

/* Price card (prestations) */
.s-pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:880px){.s-pricing{grid-template-columns:1fr}}
.s-price-card{background:var(--ed-paper);border:1.5px solid var(--ed-ink);box-shadow:8px 8px 0 var(--ed-ink);padding:36px 30px;display:flex;flex-direction:column;position:relative;transition:transform .25s ease, box-shadow .25s ease}
.s-price-card:hover{transform:translate(-3px,-3px);box-shadow:11px 11px 0 var(--ed-vermillion)}
.s-price-card.featured{background:var(--ed-ink);color:var(--ed-paper)}
.s-price-card.featured h3,.s-price-card.featured h3 em{color:var(--ed-paper)}
.s-price-card.featured h3 em{color:var(--ed-vermillion-soft)}
.s-price-card.featured .s-price{color:var(--ed-paper)}
.s-price-card.featured .s-price-mono{color:var(--ed-vermillion-soft)}
.s-price-card.featured li{color:var(--ed-paper);border-color:rgba(245,239,226,.15)}
.s-price-tape{position:absolute;top:-12px;right:18px;background:var(--ed-vermillion);color:#fff;padding:6px 14px;font-family:var(--ed-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;transform:rotate(3deg);box-shadow:0 4px 14px rgba(255,59,31,.35)}
.s-price-name{font-family:var(--ed-mono);font-size:11px;letter-spacing:.18em;color:var(--ed-vermillion);font-weight:700;margin-bottom:14px}
.s-price-card h3{font-family:var(--ed-display);font-size:30px;font-weight:600;letter-spacing:-.015em;color:var(--ed-ink);margin:0 0 14px;line-height:1.1}
.s-price-card h3 em{font-style:italic;color:var(--ed-vermillion);font-weight:400}
.s-price-card .s-price{font-family:var(--ed-display);font-weight:300;font-size:54px;line-height:1;letter-spacing:-.02em;color:var(--ed-ink);margin:0 0 6px}
.s-price-card .s-price-mono{font-family:var(--ed-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ed-muted);font-weight:600;margin-bottom:24px;display:block}
.s-price-card ul{list-style:none;padding:0;margin:0 0 24px;flex:1}
.s-price-card li{font-family:var(--ed-display);font-size:15.5px;color:var(--ed-ink-2);padding:10px 0;border-bottom:1px dashed var(--ed-rule);position:relative;padding-left:22px}
.s-price-card li::before{content:"+";position:absolute;left:0;color:var(--ed-vermillion);font-weight:700;font-family:var(--ed-mono)}
.s-price-card li:last-child{border-bottom:0}

/* Buttons (reuse ed) */
.s-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 26px;border-radius:999px;border:1.5px solid var(--ed-ink);font-family:var(--ed-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;text-decoration:none!important;cursor:pointer;transition:all .2s ease}
.s-btn-primary{background:var(--ed-ink);color:var(--ed-paper)}
.s-btn-primary:hover{background:var(--ed-vermillion);border-color:var(--ed-vermillion);color:#fff;transform:translateY(-1px)}
.s-btn-ghost{background:transparent;color:var(--ed-ink)}
.s-btn-ghost:hover{background:var(--ed-ink);color:var(--ed-paper)}
.s-btn-on-dark{background:var(--ed-paper);border-color:var(--ed-paper);color:var(--ed-ink)}
.s-btn-on-dark:hover{background:var(--ed-vermillion);border-color:var(--ed-vermillion);color:#fff}
.s-btn-on-dark-ghost{background:transparent;border-color:var(--ed-paper);color:var(--ed-paper)}
.s-btn-on-dark-ghost:hover{background:var(--ed-paper);color:var(--ed-ink)}
.s-arr{transition:transform .2s}
.s-btn:hover .s-arr{transform:translateX(3px)}

/* CTA card */
.s-cta{padding:96px 0;background:var(--ed-paper-2)}
.s-cta-card{background:var(--ed-ink);color:var(--ed-paper);padding:72px 60px;text-align:center;position:relative;border:1.5px solid var(--ed-ink);overflow:hidden}
.s-cta-card::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 20% 30%,var(--ed-vermillion) 0%,transparent 50%),radial-gradient(circle at 80% 70%,var(--ed-vermillion) 0%,transparent 50%);opacity:.18}
.s-cta-tape{display:inline-block;background:var(--ed-vermillion);color:#fff;padding:8px 18px;font-family:var(--ed-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;transform:rotate(-2deg);box-shadow:0 6px 18px rgba(255,59,31,.35);margin-bottom:28px;position:relative}
.s-cta h2{font-family:var(--ed-display);font-weight:300;font-size:clamp(36px,5vw,64px);line-height:.98;letter-spacing:-.02em;color:var(--ed-paper);margin:0 0 14px;position:relative}
.s-cta h2 em{font-style:italic;color:var(--ed-vermillion-soft);font-weight:400}
.s-cta p{font-family:var(--ed-display);font-size:18px;line-height:1.55;color:#d5cebf;max-width:560px;margin:0 auto 32px;position:relative}
.s-cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative}

@media(max-width:780px){
  .s-hero{padding:48px 0 60px}
  .s-section{padding:60px 0}
  .s-section-head{grid-template-columns:1fr;gap:10px;margin-bottom:32px}
  .s-num{font-size:48px}
  .s-cta{padding:60px 0}
  .s-cta-card{padding:48px 24px}
  .s-feat-card,.s-price-card{padding:24px;box-shadow:5px 5px 0 var(--ed-ink)}
  .s-feat-card:hover,.s-price-card:hover{transform:none;box-shadow:5px 5px 0 var(--ed-vermillion)}
  .s-preview{box-shadow:8px 8px 0 var(--ed-vermillion)}
  .s-step{grid-template-columns:1fr;gap:8px}
  .s-step-num{font-size:36px}
}

/* ═══════════════════════════════════════════════
   LEGAL PAGES — Mentions, CGU/CGV, Confidentialité
   ═══════════════════════════════════════════════ */
.l-shell{max-width:880px;margin:0 auto;padding:0 32px;position:relative;z-index:1}
body:has(.l-page){background:var(--ed-paper)}
.l-page{padding:64px 0 96px;background:var(--ed-paper);position:relative;overflow:hidden;min-height:60vh}
.l-page::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.28;mix-blend-mode:multiply;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.07  0 0 0 0 0.06  0 0 0 0 0.04  0 0 0 0.45 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}
.l-kicker{display:flex;align-items:center;gap:16px;margin-bottom:36px;font-family:var(--ed-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ed-muted)}
.l-kicker .l-dot{width:10px;height:10px;border-radius:50%;background:var(--ed-vermillion);flex:none}
.l-kicker .l-line{flex:1;height:1px;background:var(--ed-rule)}
.l-h1{font-family:var(--ed-display);font-weight:300;font-size:clamp(40px,5.5vw,80px);line-height:.96;letter-spacing:-.025em;color:var(--ed-ink);margin:0 0 22px}
.l-h1 em{font-style:italic;color:var(--ed-vermillion);font-weight:400}
.l-intro{font-family:var(--ed-display);font-size:17px;line-height:1.6;color:var(--ed-ink-2);margin:0 0 48px;max-width:680px;padding-bottom:32px;border-bottom:1px solid var(--ed-rule)}
.l-section{margin-bottom:36px}
.l-section h2{
  font-family:var(--ed-display);font-weight:600;font-size:24px;letter-spacing:-.015em;color:var(--ed-ink);
  margin:0 0 14px;display:flex;align-items:baseline;gap:14px;
}
.l-section h2::before{
  content:attr(data-num);
  font-family:var(--ed-mono);font-size:11px;letter-spacing:.18em;font-weight:700;color:var(--ed-vermillion);
  border:1.5px solid var(--ed-vermillion);padding:4px 9px;border-radius:999px;
  flex:none;
}
.l-section p{font-family:var(--ed-display);font-size:16px;line-height:1.7;color:var(--ed-ink-2);margin:0 0 12px}
.l-section p:last-child{margin-bottom:0}
.l-section strong{color:var(--ed-ink);font-weight:600}
.l-section a{color:var(--ed-vermillion);text-decoration:none;border-bottom:1px solid var(--ed-vermillion)}
.l-section a:hover{color:var(--ed-ink);border-color:var(--ed-ink)}
.l-section ul{list-style:none;padding:0;margin:0}
.l-section ul li{font-family:var(--ed-display);font-size:16px;line-height:1.6;color:var(--ed-ink-2);padding:9px 0 9px 22px;border-bottom:1px dashed var(--ed-rule);position:relative}
.l-section ul li::before{content:"+";position:absolute;left:0;color:var(--ed-vermillion);font-weight:700;font-family:var(--ed-mono)}
.l-section ul li:last-child{border-bottom:0}
.l-section ul li strong{display:inline-block;min-width:170px;color:var(--ed-ink)}
.l-foot{margin-top:64px;padding-top:24px;border-top:1px solid var(--ed-rule);font-family:var(--ed-mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ed-muted);text-align:center}
@media(max-width:780px){
  .l-page{padding:48px 0 64px}
  .l-shell{padding:0 20px}
  .l-section ul li strong{display:block;min-width:0}
}
