/* =================================================================
   PAPELITO STUDIO — styles.css
   Système : papier chaud, riso, fait main. Corail primaire,
   bleu secondaire (rare), lime en surligneur uniquement.
   ================================================================= */

:root{
  /* — encre & papier — */
  --ink:#171717;
  --paper:#FFF4E6;
  --paper-card:#FFFAF1;
  --paper-deep:#FBEEDD;
  --paper-grey:#E8E2D8;

  /* — accents (hiérarchie) — */
  --coral:#FF4F3E;        /* primaire */
  --coral-deep:#E23A29;   /* hover / ombre dessinée */
  --blue:#255CFF;         /* secondaire, parcimonie */
  --lime:#DFFF3F;         /* surligneur uniquement */

  /* — encre dérivée — */
  --ink-soft:rgba(23,23,23,.66);
  --ink-faint:rgba(23,23,23,.40);
  --line:rgba(23,23,23,.12);
  --line-strong:rgba(23,23,23,.20);

  /* — typo — */
  --display:"Space Grotesk",system-ui,sans-serif;
  --body:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  --accent:"Fraunces",Georgia,serif;

  /* — ombres papier — */
  --shadow-soft:0 16px 40px rgba(23,23,23,.10);
  --shadow-card:0 28px 70px rgba(23,23,23,.14);
  --shadow-hard:4px 4px 0 var(--ink);

  /* — rythme — */
  --radius:26px;
  --radius-sm:14px;
  --max:1140px;
  --pad-section:clamp(78px,11vh,128px);
}

/* ============ RESET ============ */
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--body);
  font-size:1.0625rem;
  line-height:1.6;
  color:var(--ink);
  background:
    radial-gradient(110% 80% at 78% -8%, rgba(37,92,255,.05), transparent 42%),
    radial-gradient(120% 90% at 8% 4%, rgba(255,79,62,.06), transparent 40%),
    linear-gradient(178deg,var(--paper-card),var(--paper) 38%,#FFEFDC);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea{font:inherit}
ul,ol{margin:0;padding:0;list-style:none}
h1,h2,h3,p{margin:0}

/* ============ GRAIN ============ */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:900;
  opacity:.14;mix-blend-mode:multiply;
  background-image:
    radial-gradient(circle, rgba(23,23,23,.5) .5px, transparent .6px);
  background-size:6px 6px;
}

/* ============ HELPERS ============ */
.container{width:min(var(--max),calc(100% - 44px));margin-inline:auto}
.section{padding-block:var(--pad-section)}
.hero[id],.section[id]{scroll-margin-top:92px}
.accent-ital{font-family:var(--accent);font-style:italic;font-weight:500}
.tag-blue{background:var(--blue) !important;color:#fff !important}

.skip-link{
  position:absolute;left:-9999px;top:10px;z-index:1000;
  background:var(--ink);color:var(--paper);padding:10px 16px;border-radius:999px;font-weight:600;
}
.skip-link:focus{left:16px}

:focus-visible{outline:3px solid var(--coral);outline-offset:3px;border-radius:6px}

/* ============ BOUTONS ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 24px;border-radius:999px;font-weight:600;font-size:1rem;
  letter-spacing:-.01em;transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
  border:2px solid var(--ink);
}
.btn-primary{background:var(--coral);color:#fff;box-shadow:var(--shadow-hard)}
.btn-primary:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink);background:var(--coral-deep)}
.btn-primary:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}
.btn-ghost{background:var(--paper-card);color:var(--ink)}
.btn-ghost:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-hard)}
.btn.block{display:flex;width:100%}

/* ============ HEADER ============ */
.site-header{
  position:sticky;top:14px;z-index:80;
  width:min(var(--max),calc(100% - 28px));margin:14px auto 0;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:11px 12px 11px 16px;
  border:1.5px solid var(--ink);border-radius:999px;
  background:rgba(255,250,241,.82);backdrop-filter:blur(14px);
  box-shadow:var(--shadow-soft);
  transition:transform .3s ease,box-shadow .3s ease;
}
.site-header.tucked{transform:translateY(-2px);box-shadow:0 10px 26px rgba(23,23,23,.14)}
.brand{display:flex;align-items:center;gap:9px}
.brand-name{display:flex;align-items:center;gap:7px;line-height:1}
.brand-name strong{font-family:var(--display);font-weight:700;font-size:1.32rem;letter-spacing:-.06em}
.brand-name em{
  font-style:normal;text-transform:uppercase;font-size:.55rem;font-weight:700;letter-spacing:.14em;
  padding:3px 5px 2px;border:1.5px solid currentColor;border-radius:5px;transform:rotate(-3deg);
}
.nav{display:flex;align-items:center;gap:2px}
.nav a{padding:9px 14px;border-radius:999px;font-weight:500;font-size:.95rem;color:var(--ink-soft);transition:background .15s,color .15s}
.nav a:hover{background:rgba(23,23,23,.06);color:var(--ink)}
.nav .nav-cta{background:var(--ink);color:var(--paper);font-weight:600}
.nav .nav-cta:hover{background:var(--coral);color:#fff}
.menu-btn{display:none;width:44px;height:40px;border:1.5px solid var(--ink);border-radius:12px;background:var(--paper-card)}
.menu-btn span{display:block;width:18px;height:2px;background:var(--ink);margin:3px auto;transition:transform .25s,opacity .2s}
.menu-btn[aria-expanded="true"] span:first-child{transform:translateY(5px) rotate(45deg)}
.menu-btn[aria-expanded="true"] span:last-child{transform:translateY(-5px) rotate(-45deg)}

/* ============ HERO ============ */
.hero{padding-block:clamp(48px,7vh,84px) clamp(40px,7vh,90px)}
.hero-grid{display:grid;grid-template-columns:1.06fr .94fr;align-items:center;gap:54px}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;margin-bottom:20px;
  font-family:var(--accent);font-style:italic;font-size:1.02rem;color:var(--coral-deep);
}
.eyebrow-dot{width:9px;height:9px;border-radius:50%;background:var(--coral);box-shadow:0 0 0 4px rgba(255,79,62,.18)}
.hero h1{
  font-family:var(--display);font-weight:700;
  font-size:clamp(2.9rem,7vw,5.6rem);line-height:.96;letter-spacing:-.04em;
}
.hero-line{display:inline-block}
.mark-word{position:relative;display:inline-block;color:var(--coral);white-space:nowrap}
.scribble{
  position:absolute;left:-9%;top:-12%;width:118%;height:128%;
  color:var(--coral);overflow:visible;pointer-events:none;
}
.scribble-path{
  stroke-dasharray:560;stroke-dashoffset:560;
}
.is-drawn .scribble-path{animation:draw 1s ease .25s forwards}
@keyframes draw{to{stroke-dashoffset:0}}

.hero-lead{margin-top:24px;max-width:38ch;font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--ink-soft)}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px}
.hero-proof{display:flex;gap:30px;margin-top:40px;flex-wrap:wrap}
.hero-proof li{display:flex;flex-direction:column}
.hero-proof strong{font-family:var(--display);font-weight:700;font-size:1.5rem;letter-spacing:-.03em}
.hero-proof span{font-size:.86rem;color:var(--ink-faint)}

/* — hero art (pile de papier) — */
.hero-art{position:relative;height:clamp(380px,42vw,500px);perspective:1200px}
.paper-stack{position:absolute;inset:0;transform-style:preserve-3d;transition:transform .3s ease}
.card{
  position:absolute;border-radius:var(--radius-sm);border:1.5px solid var(--ink);
  background:var(--paper-card);box-shadow:var(--shadow-card);padding:20px 22px;
}
.card-tag{
  display:inline-block;margin-bottom:12px;padding:4px 11px;border-radius:999px;
  background:var(--coral);color:#fff;font-size:.74rem;font-weight:700;letter-spacing:.02em;
}
.card strong{display:block;font-family:var(--display);font-weight:600;font-size:1.05rem;letter-spacing:-.02em}
.card small{display:block;margin-top:6px;color:var(--ink-faint);font-size:.84rem}
.card-back{width:60%;top:4%;right:0;transform:rotate(4deg) translateZ(0px)}
.card-mid{width:58%;top:30%;left:0;transform:rotate(-3deg) translateZ(40px)}
.card-front{width:70%;bottom:2%;right:4%;padding:0;overflow:hidden;transform:translateZ(80px)}
.paper-stack[data-tilt]{transform:rotateY(calc(var(--mx,0)*7deg)) rotateX(calc(var(--my,0)*-7deg))}

.mini-browser{background:var(--paper-card)}
.mini-bar{display:flex;align-items:center;gap:6px;padding:10px 14px;background:var(--paper-deep);border-bottom:1.5px solid var(--ink)}
.mini-bar i{width:9px;height:9px;border-radius:50%;background:var(--ink);opacity:.25}
.mini-bar span{margin-left:8px;font-size:.72rem;color:var(--ink-faint);font-weight:500}
.mini-body{padding:18px 20px 22px}
.mini-eyebrow{font-size:.74rem;font-weight:700;color:var(--coral);text-transform:uppercase;letter-spacing:.06em}
.mini-body h3{margin-top:8px;font-family:var(--display);font-weight:700;font-size:1.32rem;line-height:1.05;letter-spacing:-.03em}
.mini-photo{height:74px;margin:16px 0;border-radius:10px;background:
  linear-gradient(135deg,#D9B48A,#C49A6C);position:relative;overflow:hidden}
.mini-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 60%,rgba(255,79,62,.35))}
.mini-btn{display:inline-block;padding:9px 16px;border-radius:999px;background:var(--ink);color:var(--paper);font-size:.82rem;font-weight:600}

.sticky-note{
  position:absolute;font-family:var(--accent);font-style:italic;font-size:.92rem;font-weight:600;
  padding:8px 13px;border-radius:4px 12px 6px 10px;box-shadow:var(--shadow-soft);
  border:1px solid rgba(23,23,23,.1);
}
.note-a{top:-4%;left:6%;background:var(--lime);transform:rotate(-8deg)}
.note-b{bottom:18%;left:-6%;background:var(--paper-grey);transform:rotate(6deg)}
.note-c{top:46%;right:-5%;background:#fff;transform:rotate(-5deg)}

/* ============ TICKER ============ */
.ticker{
  border-block:1.5px solid var(--ink);background:var(--ink);color:var(--paper);
  overflow:hidden;padding:13px 0;
}
.ticker-row{display:inline-flex;align-items:center;gap:26px;white-space:nowrap;
  animation:slide 26s linear infinite;will-change:transform}
.ticker:hover .ticker-row{animation-play-state:paused}
.ticker-row span{font-family:var(--display);font-weight:600;font-size:1.04rem;letter-spacing:.01em}
.ticker-row i{color:var(--coral);font-style:normal;font-size:.8rem}
@keyframes slide{to{transform:translateX(-50%)}}

/* ============ SECTION HEADS ============ */
.section-head{max-width:760px;margin-bottom:54px}
.section-head.centered{margin-inline:auto;text-align:center}
.section-head.split{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:end;max-width:none}
.kicker{
  display:inline-block;margin-bottom:14px;text-transform:uppercase;
  letter-spacing:.16em;font-size:.76rem;font-weight:700;color:var(--coral);
}
.section-head h2{font-family:var(--display);font-weight:700;font-size:clamp(1.9rem,4.2vw,3.1rem);line-height:1.04;letter-spacing:-.035em}
.section-sub{margin-top:18px;color:var(--ink-soft);font-size:1.08rem;max-width:54ch}
.section-head.split .section-sub{margin-top:0}

/* ============ APPROCHE (pillars) ============ */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pillar{
  padding:30px 26px;border:1.5px solid var(--ink);border-radius:var(--radius);
  background:var(--paper-card);box-shadow:var(--shadow-soft);
  transition:transform .2s ease,box-shadow .2s ease;
}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow-card)}
.pillar-mark{
  display:inline-block;margin-bottom:18px;padding:5px 13px;border-radius:999px;
  background:var(--coral);color:#fff;font-size:.78rem;font-weight:700;
}
.pillar h3{font-family:var(--display);font-weight:600;font-size:1.22rem;letter-spacing:-.02em;line-height:1.15}
.pillar p{margin-top:12px;color:var(--ink-soft);font-size:.98rem}

/* ============ ATELIER EN DIRECT (builder) ============ */
.studio{position:relative}
.builder{
  display:grid;grid-template-columns:340px 1fr;gap:30px;align-items:start;
  padding:30px;border:1.5px solid var(--ink);border-radius:calc(var(--radius) + 6px);
  background:
    repeating-linear-gradient(0deg,transparent 0 31px,rgba(23,23,23,.05) 31px 32px),
    var(--paper-deep);
  box-shadow:var(--shadow-card);
}
.builder-controls{
  position:sticky;top:96px;display:flex;flex-direction:column;gap:26px;
  padding:24px;border:1.5px solid var(--ink);border-radius:var(--radius);
  background:var(--paper-card);box-shadow:var(--shadow-hard);
}
.control-label{display:block;margin-bottom:12px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint)}
.trade-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.trade-btn{
  display:flex;align-items:center;gap:8px;padding:12px 13px;border-radius:13px;
  border:1.5px solid var(--ink);background:var(--paper);font-weight:600;font-size:.92rem;
  transition:transform .15s,background .15s,color .15s,box-shadow .15s;text-align:left;
}
.trade-emoji{font-size:1.05rem;line-height:1}
.trade-btn:hover{transform:translateY(-2px)}
.trade-btn.is-active{background:var(--ink);color:var(--paper);box-shadow:2px 2px 0 var(--coral)}
.swatch-row{display:flex;gap:10px}
.swatch{
  width:38px;height:38px;border-radius:50%;background:var(--sw);
  border:1.5px solid var(--ink);transition:transform .15s,box-shadow .15s;position:relative;
}
.swatch:hover{transform:scale(1.08)}
.swatch.is-active{box-shadow:0 0 0 3px var(--paper-card),0 0 0 5px var(--ink)}
.builder-hint{font-size:.84rem;color:var(--ink-faint);line-height:1.4;font-family:var(--accent);font-style:italic}

.builder-preview{display:flex;flex-direction:column;gap:12px}
.preview-browser{
  border:1.5px solid var(--ink);border-radius:18px;overflow:hidden;
  background:#fff;box-shadow:var(--shadow-card);
}
.preview-bar{display:flex;align-items:center;gap:7px;padding:12px 16px;background:var(--paper-deep);border-bottom:1.5px solid var(--ink)}
.preview-bar i{width:11px;height:11px;border-radius:50%;background:var(--ink);opacity:.22}
.preview-url{
  margin-left:10px;padding:5px 14px;border-radius:999px;background:var(--paper-card);
  border:1px solid var(--line);font-size:.8rem;color:var(--ink-soft);font-weight:500;
  transition:opacity .2s;flex:1;max-width:280px;
}
.preview-url.loading{opacity:.45}

/* — canvas du mini-site (thémé par --pv) — */
.preview-canvas{--pv:var(--coral);padding:26px 28px 30px;background:#fffdf9;min-height:430px}
.pv-nav{display:flex;align-items:center;justify-content:space-between;padding-bottom:18px;border-bottom:1px solid var(--line)}
.pv-logo{font-family:var(--display);font-weight:700;font-size:1.12rem;letter-spacing:-.02em}
.pv-link{font-size:.82rem;font-weight:600;padding:6px 13px;border-radius:999px;background:var(--pv);color:#fff}
.pv-hero{padding:26px 0 22px}
.pv-eyebrow{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--pv)}
.pv-title{margin-top:9px;font-family:var(--display);font-weight:700;font-size:clamp(1.4rem,2.4vw,1.9rem);line-height:1.04;letter-spacing:-.03em}
.pv-text{margin-top:12px;color:var(--ink-soft);font-size:.95rem;max-width:42ch}
.pv-cta{display:inline-block;margin-top:18px;padding:11px 20px;border-radius:999px;background:var(--pv);color:#fff;font-weight:600;font-size:.9rem}
.pv-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:8px 0 22px}
.pv-tile{aspect-ratio:1;border-radius:11px;border:1px solid var(--line)}
.pv-tile:nth-child(1){background:color-mix(in srgb,var(--pv) 88%,#000 4%)}
.pv-tile:nth-child(2){background:color-mix(in srgb,var(--pv) 30%,var(--paper-grey))}
.pv-tile:nth-child(3){background:var(--paper-deep)}
.pv-tile:nth-child(4){background:color-mix(in srgb,var(--pv) 60%,#fff 8%)}
.pv-services{display:flex;flex-wrap:wrap;gap:8px}
.pv-services span{padding:7px 14px;border-radius:999px;background:var(--paper-card);border:1px solid var(--line);font-size:.82rem;font-weight:500}
.preview-caption{font-size:.82rem;color:var(--ink-faint);text-align:center;font-family:var(--accent);font-style:italic}

/* transitions de reconstruction */
.pv-swap{animation:pvIn .5s cubic-bezier(.2,.7,.2,1) both}
.pv-swap-1{animation-delay:.02s}.pv-swap-2{animation-delay:.08s}
.pv-swap-3{animation-delay:.14s}.pv-swap-4{animation-delay:.2s}
@keyframes pvIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ============ OFFRES ============ */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.price-card{
  display:flex;flex-direction:column;padding:30px 26px;
  border:1.5px solid var(--ink);border-radius:var(--radius);
  background:var(--paper-card);box-shadow:var(--shadow-soft);position:relative;
}
.price-card.featured{background:var(--ink);color:var(--paper);box-shadow:var(--shadow-card);transform:translateY(-6px)}
.price-card.subtle{background:var(--paper-deep)}
.badge{
  align-self:flex-start;margin-bottom:18px;padding:5px 13px;border-radius:999px;
  font-size:.74rem;font-weight:700;background:var(--coral);color:#fff;
}
.badge.alt{background:var(--blue)}
.badge.plain{background:var(--paper);color:var(--ink);border:1.5px solid var(--ink)}
.price-card h3{font-family:var(--display);font-weight:600;font-size:1.3rem;letter-spacing:-.02em}
.price{margin-top:10px;font-size:1.05rem;color:inherit;opacity:.9}
.price strong{font-family:var(--display);font-weight:700;font-size:2.6rem;letter-spacing:-.04em;opacity:1}
.featured .price{color:var(--lime);opacity:1}
.price-desc{margin-top:12px;font-size:.96rem;color:var(--ink-soft)}
.featured .price-desc{color:rgba(255,244,230,.78)}
.price-list{margin:20px 0 26px;display:flex;flex-direction:column;gap:11px}
.price-list li{position:relative;padding-left:26px;font-size:.94rem}
.price-list li::before{
  content:"";position:absolute;left:0;top:7px;width:14px;height:9px;
  border-left:2.5px solid var(--coral);border-bottom:2.5px solid var(--coral);
  transform:rotate(-45deg);
}
.featured .price-list li::before{border-color:var(--lime)}
.price-card .btn{margin-top:auto}

/* ============ PROCESS ============ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:step}
.step{padding:30px 26px;border:1.5px solid var(--ink);border-radius:var(--radius);background:var(--paper-card);box-shadow:var(--shadow-soft)}
.step-num{font-family:var(--display);font-weight:700;font-size:2.4rem;letter-spacing:-.04em;color:var(--coral)}
.step h3{margin-top:8px;font-family:var(--display);font-weight:600;font-size:1.24rem;letter-spacing:-.02em}
.step p{margin-top:10px;color:var(--ink-soft);font-size:.96rem}

/* ============ SOUS LE CAPOT ============ */
.under-hood{
  background:var(--ink);color:var(--paper);border-block:1.5px solid var(--ink);
  border-radius:0;
}
.under-hood .kicker{color:var(--lime)}
.under-hood .section-sub{color:rgba(255,244,230,.74)}
.hood-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.hood-card{
  padding:26px 22px;border:1.5px solid rgba(255,244,230,.22);border-radius:var(--radius);
  background:rgba(255,244,230,.04);
}
.hood-icon{font-size:1.7rem;line-height:1}
.hood-card h3{margin-top:14px;font-family:var(--display);font-weight:600;font-size:1.16rem;letter-spacing:-.02em}
.hood-card p{margin-top:9px;color:rgba(255,244,230,.7);font-size:.92rem}

/* ============ FAQ ============ */
.faq-list{max-width:780px;margin-inline:auto;display:flex;flex-direction:column;gap:12px}
.faq-list details{
  border:1.5px solid var(--ink);border-radius:var(--radius-sm);
  background:var(--paper-card);overflow:hidden;transition:box-shadow .2s;
}
.faq-list details[open]{box-shadow:var(--shadow-soft)}
.faq-list summary{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:19px 22px;font-family:var(--display);font-weight:600;font-size:1.06rem;
  letter-spacing:-.02em;list-style:none;
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-plus{position:relative;width:18px;height:18px;flex-shrink:0}
.faq-plus::before,.faq-plus::after{content:"";position:absolute;background:var(--coral);border-radius:2px}
.faq-plus::before{top:8px;left:0;width:18px;height:2.5px}
.faq-plus::after{top:0;left:8px;width:2.5px;height:18px;transition:transform .25s}
.faq-list details[open] .faq-plus::after{transform:rotate(90deg);opacity:0}
.faq-list p{padding:0 22px 22px;color:var(--ink-soft);font-size:.98rem}

/* ============ CONTACT ============ */
.contact-card{
  display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;
  padding:clamp(32px,5vw,56px);border:1.5px solid var(--ink);border-radius:calc(var(--radius) + 8px);
  background:
    radial-gradient(120% 130% at 100% 0%,rgba(255,79,62,.12),transparent 50%),
    var(--paper-card);
  box-shadow:var(--shadow-card);
}
.contact-intro h2{margin-top:6px}
.contact-mail{display:inline-block;margin-top:22px;font-family:var(--display);font-weight:600;font-size:1.1rem;color:var(--coral);border-bottom:2px solid var(--lime);padding-bottom:2px}
.contact-form{display:flex;flex-direction:column;gap:14px}
.hidden-field{display:none}
.field{display:flex;flex-direction:column;gap:7px;font-size:.86rem;font-weight:600;color:var(--ink-soft)}
.field input,.field textarea{
  padding:13px 15px;border:1.5px solid var(--line-strong);border-radius:13px;
  background:var(--paper);color:var(--ink);font-weight:400;transition:border-color .15s,box-shadow .15s;
}
.field textarea{resize:vertical;min-height:96px}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3px rgba(255,79,62,.16)}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-faint);font-weight:400}
.form-note{font-size:.82rem;color:var(--ink-faint);text-align:center}

/* ============ FOOTER ============ */
.site-footer{border-top:1.5px solid var(--ink);padding:46px 0 30px;background:var(--paper-deep)}
.footer-grid{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer-line{color:var(--ink-soft);font-size:.96rem;flex:1;min-width:220px}
.footer-mail{font-weight:600;color:var(--coral)}
.footer-credits{margin-top:26px;padding-top:20px;border-top:1px solid var(--line);text-align:center;color:var(--ink-faint);font-size:.84rem}

/* ============ REVEAL ============ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:44px}
  .hero-art{height:420px;max-width:480px}
  .section-head.split{grid-template-columns:1fr;gap:18px;align-items:start}
  .pillars,.pricing,.steps,.hood-grid{grid-template-columns:1fr 1fr}
  .builder{grid-template-columns:1fr}
  .builder-controls{position:static}
  .trade-grid{grid-template-columns:repeat(4,1fr)}
  .contact-card{grid-template-columns:1fr;gap:30px}
  .price-card.featured{transform:none}
}
@media (max-width:680px){
  .nav{
    position:absolute;top:calc(100% + 10px);right:0;left:0;
    flex-direction:column;align-items:stretch;gap:6px;padding:14px;
    border:1.5px solid var(--ink);border-radius:22px;background:var(--paper-card);
    box-shadow:var(--shadow-card);
    opacity:0;transform:translateY(-10px) scale(.98);pointer-events:none;transition:opacity .2s,transform .2s;
  }
  .nav.open{opacity:1;transform:none;pointer-events:auto}
  .nav a{padding:12px 16px}
  .menu-btn{display:block}
  .pillars,.pricing,.steps,.hood-grid{grid-template-columns:1fr}
  .trade-grid{grid-template-columns:1fr 1fr}
  .hero-proof{gap:22px}
  .preview-canvas{padding:20px 18px 24px}
  .pv-gallery{grid-template-columns:repeat(4,1fr);gap:7px}
  .builder{padding:18px}
  .footer-grid{flex-direction:column;text-align:center}
}

/* =================================================================
   MOUVEMENT RÉDUIT — on coupe tout ce qui n'est pas essentiel
   ================================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
  .scribble-path{stroke-dashoffset:0}
  .ticker-row{animation:none;transform:none}
  .paper-stack[data-tilt]{transform:none}
  .pv-swap{animation:none}
}

/* =================================================================
   v16 — LE PAPIER PREND VIE
   ================================================================= */

/* ---- avion en papier (compagnon de scroll) ---- */
.flight{position:fixed;inset:0;z-index:60;pointer-events:none}
#flightSvg{position:absolute;top:0;right:0;height:100%;width:104px;overflow:visible}
.flight-route{stroke:var(--ink);stroke-width:2;stroke-linecap:round;stroke-dasharray:2 10;opacity:.16}
.flight-trail{stroke:var(--coral);stroke-width:2.5;stroke-linecap:round}
.plane{position:fixed;top:0;left:0;width:30px;height:30px;will-change:transform;
  filter:drop-shadow(0 6px 7px rgba(23,23,23,.22));transition:opacity .5s ease}
.plane svg{width:100%;height:100%;display:block}
@media (max-width:1180px){.flight{display:none}}

/* ---- confettis ---- */
.confetti{position:fixed;inset:0;z-index:950;pointer-events:none}

/* ---- annotations dessinées ---- */
.draw-underline{position:relative;display:inline-block}
.annot-line{position:absolute;left:-2%;bottom:-.18em;width:104%;height:.42em;overflow:visible;color:var(--coral)}
.annot-path{stroke-dasharray:240;stroke-dashoffset:240}
.draw-underline.is-drawn .annot-path{animation:draw 1s ease .15s forwards}

/* ---- réglage mise en page (atelier) ---- */
.layout-row{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.layout-btn{padding:11px 13px;border-radius:13px;border:1.5px solid var(--ink);background:var(--paper);
  font-weight:600;font-size:.92rem;transition:transform .15s,background .15s,color .15s,box-shadow .15s}
.layout-btn:hover{transform:translateY(-2px)}
.layout-btn.is-active{background:var(--ink);color:var(--paper);box-shadow:2px 2px 0 var(--blue)}

/* ---- bouton publier + confettis ---- */
.publish-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.publish-btn{
  padding:13px 22px;border-radius:999px;border:2px solid var(--ink);
  background:var(--lime);color:var(--ink);font-weight:700;font-size:.96rem;
  box-shadow:var(--shadow-hard);transition:transform .16s,box-shadow .16s,background .16s;
}
.publish-btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.publish-btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}
.publish-btn.is-busy{background:var(--paper-grey);pointer-events:none}
.publish-btn.is-done{background:var(--coral);color:#fff}
.publish-status{font-family:var(--accent);font-style:italic;font-size:.92rem;color:var(--coral-deep);opacity:0;transition:opacity .3s}
.publish-status.show{opacity:1}

/* ---- post-it attrapables ---- */
.sticky-note[data-draggable]{cursor:grab;touch-action:none;user-select:none;will-change:transform;z-index:5}
.sticky-note[data-draggable]:active{cursor:grabbing}
.sticky-note.is-grabbing{transition:none;z-index:20;box-shadow:0 18px 30px rgba(23,23,23,.26)}

/* ---- aperçu : variante AUDACIEUX ---- */
.preview-canvas.is-audacieux{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  grid-template-areas:"nav nav" "hero gallery" "services services";
  gap:14px 22px;align-content:start;
}
.preview-canvas.is-audacieux .pv-nav{grid-area:nav}
.preview-canvas.is-audacieux .pv-hero{grid-area:hero;padding:6px 0 0}
.preview-canvas.is-audacieux .pv-gallery{grid-area:gallery;grid-template-columns:1fr 1fr;align-self:center;margin:0}
.preview-canvas.is-audacieux .pv-services{grid-area:services;margin-top:6px}
.preview-canvas.is-audacieux .pv-title{font-size:clamp(1.7rem,3.2vw,2.5rem);letter-spacing:-.04em}
.preview-canvas.is-audacieux .pv-eyebrow{font-size:.82rem}
.preview-canvas.is-audacieux .pv-tile{aspect-ratio:4/5}
.preview-canvas.is-audacieux .pv-services span{font-size:.86rem;padding:8px 16px}
@media (max-width:680px){
  .preview-canvas.is-audacieux{grid-template-columns:1fr;grid-template-areas:"nav" "hero" "gallery" "services"}
  .preview-canvas.is-audacieux .pv-gallery{grid-template-columns:repeat(4,1fr)}
}

/* ---- tilt 3D des cartes (piloté JS) ---- */
.pillar,.price-card,.hood-card{transform-style:preserve-3d;will-change:transform}

/* ---- réglages mouvement réduit (v16) ---- */
@media (prefers-reduced-motion:reduce){
  .flight,.plane{display:none !important}
  .annot-path{stroke-dashoffset:0}
  .sticky-note.is-grabbing{transition:none}
}
