/* =========================================================
   FRYE — main.css  (build concaténé : fonts, base, layout,
   widgets, components, effects). Thème poulet frit / burgers.
   Palette corail · mode clair/sombre · Space Grotesk.
   ========================================================= */

/* ---------- Polices auto-hébergées ---------- */
@font-face{font-family:'Space Grotesk';src:url('../fonts/space-grotesk-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Space Grotesk';src:url('../fonts/space-grotesk-500.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Space Grotesk';src:url('../fonts/space-grotesk-600.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Space Grotesk';src:url('../fonts/space-grotesk-700.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../fonts/hanken-grotesk-300.woff2') format('woff2');font-weight:300;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../fonts/hanken-grotesk-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../fonts/hanken-grotesk-500.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../fonts/hanken-grotesk-600.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../fonts/hanken-grotesk-700.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Space Mono';src:url('../fonts/space-mono-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Space Mono';src:url('../fonts/space-mono-700.woff2') format('woff2');font-weight:700;font-display:swap}

/* ---------- Tokens ---------- */
:root{
  --bg:#F5F0E6; --surface:#FFFFFF; --surface-2:#ECE5D7;
  --ink:#16120E; --ink-soft:#3A352D; --muted:#857C6C;
  --line:rgba(22,18,14,.13); --line-soft:rgba(22,18,14,.07);
  --accent:#FF4536; --accent-2:#FFC22E; --on-accent:#FFF6E9;

  --font-display:'Space Grotesk','Helvetica Neue',Arial,sans-serif;
  --font-body:'Hanken Grotesk','Helvetica Neue',Arial,sans-serif;
  --font-mono:'Space Mono',ui-monospace,monospace;

  --maxw:1560px; --gut:clamp(20px,5vw,80px); --radius:6px;
  --ease:cubic-bezier(.22,1,.36,1); --ease-out:cubic-bezier(.16,1,.3,1);
  --nav-h:84px;
}
body.dark-mode{
  --bg:#100C09; --surface:#191410; --surface-2:#231B14;
  --ink:#F5F0E6; --ink-soft:#DBD4C6; --muted:#948A79;
  --line:rgba(245,240,230,.15); --line-soft:rgba(245,240,230,.08);
  --accent:#FF5A4A; --accent-2:#FFCB4E; --on-accent:#160F0B;
}

/* ---------- Pont vers le plugin Click & Collect (tokens --sr-*) ----------
   Les widgets du plugin (SMASH RIOT / Click & Collect) lisent des variables
   --sr-* ; on les mappe sur la charte FRYE pour qu'ils héritent du style
   (couleurs, surfaces, arrondi) — mode clair ET sombre via la cascade. */
:root,
.srcc-elwrap,
.cc{
  --sr-accent: var(--accent);
  --sr-accent2: var(--ink);
  --sr-on-accent: var(--on-accent);
  --sr-bg: var(--bg);
  --sr-surface: var(--surface);
  --sr-surface-2: var(--surface-2);
  --sr-ink: var(--ink);
  --sr-muted: var(--muted);
  --sr-line: var(--line);
  --sr-radius: var(--radius);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);line-height:1.5;font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .5s var(--ease),color .5s var(--ease)}
img,picture,svg,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
ul,ol{list-style:none}
input,textarea,select{font:inherit;color:inherit}
::selection{background:var(--accent);color:var(--on-accent)}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:16px;top:16px;z-index:9999;background:var(--ink);color:var(--bg);padding:12px 18px;border-radius:6px}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* ---------- Typographie ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:.98;letter-spacing:-.02em}
.lead{font-size:clamp(1.05rem,1.6vw,1.4rem);line-height:1.45;color:var(--ink-soft);font-weight:400}
p{color:var(--ink-soft)}
.mono{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.mono-sm{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:26px}
.eyebrow::before{content:"";width:28px;height:1px;background:currentColor;opacity:.6}
em{font-style:italic}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
.section{padding-block:clamp(70px,12vh,150px)}
.site-content{display:block}
.flex{display:flex}.grid{display:grid}
.between{justify-content:space-between}.items-end{align-items:flex-end}.items-center{align-items:center}
.gap-s{gap:16px}.gap-m{gap:32px}.gap-l{gap:64px}
.muted{color:var(--muted)}.mt-s{margin-top:18px}.mt-m{margin-top:36px}
.divider{height:1px;background:var(--line);width:100%}
.tag{display:inline-flex;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;padding:7px 13px;border:1px solid var(--line);border-radius:100px;color:var(--muted)}
.tag--solid{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}

/* ---------- Boutons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;padding:18px 30px;border-radius:100px;border:1px solid var(--accent);background:var(--accent);color:var(--on-accent);transition:background .4s var(--ease),color .4s var(--ease),transform .5s var(--ease);will-change:transform}
.btn:hover{background:transparent;color:var(--accent)}
.btn--ink{background:var(--ink);border-color:var(--ink);color:var(--bg)}
.btn--ink:hover{background:transparent;color:var(--ink)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--bg)}
.btn--lg{padding:22px 38px;font-size:.8rem}
.btn .arrow{transition:transform .4s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
.link-u{position:relative;display:inline-block}
.link-u::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .45s var(--ease)}
.link-u:hover::after{transform:scaleX(1);transform-origin:left}

/* ---------- Media / placeholder ---------- */
.media{position:relative;overflow:hidden;background:var(--surface-2);border-radius:var(--radius)}
.media img{width:100%;height:100%;object-fit:cover}
.media--parallax img{width:100%;height:122%;object-fit:cover;will-change:transform}
.media .ph-label{position:absolute;left:14px;bottom:12px;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.78)}
.img-zoom img{transition:transform 1.1s var(--ease)}
.img-zoom:hover img{transform:scale(1.05)}
.ph{position:relative;background:repeating-linear-gradient(45deg,var(--surface-2),var(--surface-2) 11px,transparent 11px,transparent 22px),var(--surface);display:grid;place-items:center;color:var(--muted);min-height:200px}
.ph::after{content:attr(data-label);font-family:var(--font-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;padding:6px 12px;background:var(--bg);border:1px solid var(--line);border-radius:100px}
.skedenn-img,.frye-img{width:100%;height:100%;object-fit:cover}

/* ---------- Reveal (gaté sous .fx) ---------- */
.fx [data-reveal]{opacity:0;transform:translateY(var(--reveal-dist,34px));transition:opacity var(--reveal-dur,.9s) var(--ease-out),transform var(--reveal-dur,.9s) var(--ease-out)}
.fx [data-reveal].is-in{opacity:1;transform:none}
.fx [data-reveal-delay="1"]{transition-delay:.08s}
.fx [data-reveal-delay="2"]{transition-delay:.16s}
.fx [data-reveal-delay="3"]{transition-delay:.24s}
.fx [data-reveal-delay="4"]{transition-delay:.32s}
.reveal-mask{display:inline-block;overflow:hidden;vertical-align:top}
.reveal-mask>span{display:inline-block}
.fx .reveal-mask>span{transform:translateY(110%);transition:transform 1s var(--ease-out)}
.fx .reveal-mask.is-in>span{transform:translateY(0)}
@media (prefers-reduced-motion:reduce){.fx [data-reveal],.fx .reveal-mask>span{opacity:1!important;transform:none!important}html{scroll-behavior:auto}}
body.elementor-editor-active [data-reveal],body.elementor-editor-active .reveal-mask>span{opacity:1!important;transform:none!important}

/* ---------- Tilt 3D ---------- */
.skd-tilt-yes .media,.skd-tilt-yes .frye-dish,.skd-tilt-yes .frye-spot{transition:transform .5s var(--ease);will-change:transform}
.skd-tilt-yes .is-tilting{transition:transform .06s linear}

/* ---------- Curseur personnalisé ---------- */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:10050;border-radius:50%;mix-blend-mode:difference;opacity:0;transition:opacity .25s}
body.using-cursor .cursor-dot,body.using-cursor .cursor-ring{opacity:1}
.cursor-dot{width:7px;height:7px;background:#fff;transform:translate(-50%,-50%)}
.cursor-ring{width:42px;height:42px;border:1px solid #fff;transform:translate(-50%,-50%);transition:width .35s var(--ease),height .35s var(--ease),background .35s var(--ease),opacity .3s;display:flex;align-items:center;justify-content:center}
.cursor-ring .c-label{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;opacity:0;transition:opacity .3s;white-space:nowrap}
.cursor-ring.is-view{width:96px;height:96px;background:#fff;mix-blend-mode:normal;border-color:transparent}
.cursor-ring.is-view .c-label{opacity:1;color:#101010}
body.using-cursor,body.using-cursor a,body.using-cursor button{cursor:none}
@media (hover:none),(pointer:coarse){.cursor-dot,.cursor-ring{display:none!important}body.using-cursor{cursor:auto}}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:300;background:color-mix(in srgb,var(--bg) 80%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut);height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:600;font-size:1.45rem;letter-spacing:-.03em}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--accent)}
.nav-links{display:flex;gap:4px}
.nav-links li a{display:inline-flex;align-items:center;padding:8px 16px;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);transition:color .3s}
.nav-links li a:hover,.nav-links li.current-menu-item a{color:var(--ink)}
.nav-right{display:flex;align-items:center;gap:12px}
.theme-toggle{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--ink);transition:background .35s,color .35s,border-color .35s}
.theme-toggle:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.theme-toggle svg{width:17px;height:17px}
.theme-toggle .moon-icon{display:none}
body.dark-mode .theme-toggle .sun-icon{display:none}
body.dark-mode .theme-toggle .moon-icon{display:block}
.mobile-menu-btn{display:none;flex-direction:column;gap:5px;width:42px;height:42px;border:1px solid var(--line);border-radius:50%;align-items:center;justify-content:center}
.mobile-menu-btn span{display:block;width:18px;height:1.6px;background:var(--ink);transition:transform .3s var(--ease),opacity .3s}
.mobile-menu-btn.is-open span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
.mobile-menu-btn.is-open span:nth-child(2){opacity:0}
.mobile-menu-btn.is-open span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}
#mobile-menu{position:fixed;inset:0;z-index:290;background:var(--bg);display:flex;flex-direction:column;justify-content:center;padding:var(--gut);transform:translateY(-100%);transition:transform .55s var(--ease);visibility:hidden}
#mobile-menu.is-open{transform:translateY(0);visibility:visible}
.mobile-menu-links{display:flex;flex-direction:column;gap:6px}
.mobile-menu-links li a{font-family:var(--font-display);font-weight:500;font-size:clamp(2rem,8vw,4rem);letter-spacing:-.03em;color:var(--ink);display:inline-block;padding:6px 0}
.mobile-menu-links li a:hover{color:var(--accent)}
.mobile-menu-foot{display:flex;justify-content:space-between;margin-top:48px}

/* ---------- Marquee ---------- */
.frye-marquee{border-block:1px solid var(--line);overflow:hidden;padding:18px 0}
.frye-marquee__row{display:flex;white-space:nowrap;width:max-content;animation:frye-ticker var(--mq-dur,30s) linear infinite}
.frye-marquee__row span{font-family:var(--font-display);font-weight:500;font-size:clamp(1.6rem,3vw,2.6rem);letter-spacing:-.02em;color:var(--ink);padding-right:.6em}
.frye-marquee--accent{background:var(--accent)}
.frye-marquee--accent span{color:var(--on-accent)}
@keyframes frye-ticker{to{transform:translateX(-50%)}}

/* ---------- Hero ---------- */
.frye-hero{padding-top:clamp(40px,8vh,90px);padding-bottom:clamp(40px,7vh,80px)}
.frye-hero__head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap}
.frye-hero__title{font-family:var(--font-display);font-weight:500;font-size:clamp(3rem,11.5vw,11rem);line-height:.84;letter-spacing:-.045em;max-width:15ch}
.frye-hero__title em{color:var(--accent);font-weight:400}
.frye-hero__meta{max-width:40ch}
.frye-hero__actions{display:flex;gap:13px;flex-wrap:wrap;margin-top:30px}
.frye-hero__chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:28px}
.frye-hero__visual{margin-top:clamp(32px,5vh,60px);position:relative}
.frye-hero__visual .media{aspect-ratio:16/8}
.frye-hero__badge{position:absolute;right:clamp(16px,3vw,44px);bottom:clamp(16px,3vw,44px);background:var(--bg);color:var(--ink);border-radius:100px;padding:16px 26px;display:flex;flex-direction:column;box-shadow:0 18px 50px rgba(0,0,0,.18)}
.frye-hero__badge .n{font-family:var(--font-display);font-size:2rem;font-weight:600;line-height:1}
.frye-hero__badge .l{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:4px}

/* ---------- Section header ---------- */
.frye-shead{display:flex;justify-content:space-between;align-items:flex-end;gap:36px;flex-wrap:wrap;margin-bottom:clamp(36px,6vh,68px)}
.frye-shead h2{font-size:clamp(2rem,5vw,4.4rem);line-height:.96;letter-spacing:-.03em;max-width:16ch}
.frye-shead h2 em{color:var(--accent)}
.frye-shead p{max-width:42ch}

/* ---------- Menu / dishes ---------- */
.frye-menu{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,36px)}
.frye-dish__media{position:relative;aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;background:var(--surface-2)}
.frye-dish__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.frye-dish:hover .frye-dish__media img{transform:scale(1.05)}
.frye-dish__index{position:absolute;top:14px;left:14px;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.14em;color:#fff;mix-blend-mode:difference}
.frye-dish__tag{position:absolute;top:12px;right:12px;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;padding:7px 13px;border-radius:100px;background:var(--accent);color:var(--on-accent)}
.frye-dish__foot{display:flex;justify-content:space-between;align-items:baseline;gap:16px;margin-top:18px}
.frye-dish__name{font-family:var(--font-display);font-weight:500;font-size:clamp(1.3rem,2.4vw,2rem);letter-spacing:-.02em}
.frye-dish__price{font-family:var(--font-display);font-weight:600;font-size:1.4rem;letter-spacing:-.02em;white-space:nowrap}
.frye-dish__desc{color:var(--ink-soft);font-size:.98rem;line-height:1.5;margin-top:8px;max-width:42ch}
.frye-dish__add{margin-top:16px;display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;padding:12px 20px;border-radius:100px;border:1px solid var(--line);transition:transform .5s var(--ease),background .35s,color .35s,border-color .35s}
.frye-dish__add:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}

/* ---------- Filtres ---------- */
.frye-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:clamp(30px,5vh,50px)}
.filter-btn{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;padding:11px 20px;border-radius:100px;border:1px solid var(--line);color:var(--muted);transition:background .35s,color .35s,border-color .35s}
.filter-btn:hover{border-color:var(--ink);color:var(--ink)}
.filter-btn.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.fx .frye-dish-item{transition:opacity .3s var(--ease),transform .3s var(--ease)}

/* ---------- Steps (services numérotés) ---------- */
.frye-steps{border-top:1px solid var(--line)}
.frye-step{display:grid;grid-template-columns:.5fr 2fr 2.5fr auto;gap:24px;align-items:start;padding:clamp(26px,4vh,46px) 0;border-bottom:1px solid var(--line);transition:padding-left .4s var(--ease)}
.frye-step:hover{padding-left:18px}
.frye-step__num{font-family:var(--font-mono);font-size:.78rem;color:var(--muted);padding-top:8px}
.frye-step__name{font-family:var(--font-display);font-weight:500;font-size:clamp(1.6rem,3.4vw,2.8rem);letter-spacing:-.025em}
.frye-step__desc{color:var(--ink-soft);max-width:46ch;line-height:1.55}
.frye-step__arrow{width:52px;height:52px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;transition:background .4s var(--ease),color .4s,transform .4s;flex-shrink:0}
.frye-step:hover .frye-step__arrow{background:var(--accent);color:var(--on-accent);border-color:var(--accent);transform:rotate(-45deg)}

/* ---------- Stats ---------- */
.frye-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,48px)}
.frye-stat{border-top:1px solid var(--ink);padding-top:22px}
.frye-stat__n{font-family:var(--font-display);font-weight:500;font-size:clamp(2.6rem,6vw,5rem);line-height:.95;letter-spacing:-.03em;color:var(--accent)}
.frye-stat__l{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:12px}

/* ---------- Spots ---------- */
.frye-spots{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,28px)}
.frye-spot{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(26px,3vw,38px);transition:transform .5s var(--ease),border-color .4s}
.frye-spot:hover{border-color:var(--ink)}
.frye-spot h3{font-family:var(--font-display);font-weight:500;font-size:clamp(1.3rem,2vw,1.8rem);letter-spacing:-.02em}
.frye-spot__open{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-top:12px}
.frye-spot__open .d{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:frye-pulse 1.8s ease-in-out infinite}
.frye-spot p{color:var(--ink-soft);font-size:.95rem;line-height:1.65;margin-top:16px}
@keyframes frye-pulse{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.25);opacity:1}}

/* ---------- FAQ ---------- */
.frye-faq{max-width:920px}
.frye-faq__item{border-bottom:1px solid var(--line)}
.frye-faq__q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:20px;text-align:left;padding:clamp(22px,3vh,32px) 0;font-family:var(--font-display);font-size:clamp(1.15rem,2vw,1.6rem);font-weight:500;letter-spacing:-.015em}
.frye-faq__icon{width:34px;height:34px;flex-shrink:0;position:relative}
.frye-faq__icon::before,.frye-faq__icon::after{content:"";position:absolute;background:var(--ink);transition:transform .4s var(--ease)}
.frye-faq__icon::before{top:50%;left:7px;right:7px;height:1.6px;transform:translateY(-50%)}
.frye-faq__icon::after{left:50%;top:7px;bottom:7px;width:1.6px;transform:translateX(-50%)}
.frye-faq__item.is-open .frye-faq__icon::after{transform:translateX(-50%) scaleY(0)}
.frye-faq__a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.frye-faq__a p{padding-bottom:clamp(22px,3vh,30px);max-width:60ch;color:var(--ink-soft);line-height:1.6}

/* ---------- CTA ---------- */
.frye-cta{text-align:center}
.frye-cta h2{font-size:clamp(2.6rem,9vw,9rem);letter-spacing:-.045em;line-height:.9}
.frye-cta h2 em{color:var(--accent)}
.frye-cta p{margin:26px auto 36px;max-width:46ch}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:var(--bg)}
.site-footer .wrap{padding-block:clamp(60px,9vh,110px) 40px}
.footer-cta{margin-bottom:clamp(48px,8vh,90px)}
.footer-cta a{display:inline-flex;align-items:center;gap:clamp(16px,3vw,40px);font-family:var(--font-display);font-weight:500;font-size:clamp(2.4rem,8vw,7rem);letter-spacing:-.04em;line-height:.9;color:var(--bg)}
.footer-cta svg{width:clamp(40px,6vw,90px);height:auto;flex-shrink:0;transition:transform .5s var(--ease)}
.footer-cta a:hover svg{transform:translate(8px,-8px)}
.footer-main{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:40px}
.footer-column h5{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:color-mix(in srgb,var(--bg) 55%,transparent);margin-bottom:18px}
.footer-column ul{display:grid;gap:11px}
.footer-column li a,.footer-column li{font-family:var(--font-body);font-size:1rem;color:color-mix(in srgb,var(--bg) 78%,transparent)}
.footer-column li a:hover{color:var(--bg)}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-top:46px;padding-top:22px;border-top:1px solid color-mix(in srgb,var(--bg) 16%,transparent)}
.footer-bottom .mono{color:color-mix(in srgb,var(--bg) 55%,transparent)}

/* ---------- Loader ---------- */
.page-load{position:fixed;inset:0;z-index:9999;background:var(--ink);color:var(--bg);display:grid;place-items:center;transition:opacity .6s var(--ease),visibility .6s}
.page-load.is-done{opacity:0;visibility:hidden}
.pl-count{font-family:var(--font-display);font-weight:500;font-size:clamp(3rem,12vw,9rem);letter-spacing:-.04em}

/* ---------- Commander : étapes ---------- */
.frye-order__steps{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:clamp(28px,5vh,52px)}
.frye-order__step{display:inline-flex;align-items:center;gap:11px;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:11px 18px;border:1px solid var(--line);border-radius:100px}
.frye-order__step .n{width:22px;height:22px;border-radius:50%;border:1px solid currentColor;display:grid;place-items:center;font-size:.64rem}
.frye-order__step.is-active{color:var(--ink);border-color:var(--ink)}
.frye-order__step.is-active .n{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}
.frye-order__step.is-done{color:var(--ink)}
.frye-order__step.is-done .n{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.frye-order__panel[hidden]{display:none}

/* ---------- Locator (carte + liste) ---------- */
.frye-locator__grid{display:grid;grid-template-columns:1.35fr .9fr;gap:clamp(18px,2.4vw,32px);align-items:stretch}
.frye-locator__map{position:relative;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface);min-height:440px}
.frye-map{position:absolute;inset:0;width:100%;height:100%}
.frye-map .block{fill:var(--surface-2);opacity:.55}
.frye-map .street{stroke:var(--line);stroke-width:2;fill:none}
.frye-map .river{fill:none;stroke:var(--accent-2);stroke-width:16;opacity:.26;stroke-linecap:round}
.frye-map__tag{position:absolute;left:16px;bottom:14px;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);background:var(--bg);border:1px solid var(--line);border-radius:100px;padding:6px 12px}
.frye-pin{position:absolute;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;gap:7px;z-index:2}
.frye-pin__dot{position:relative;width:22px;height:22px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);background:var(--ink);border:2px solid var(--bg);box-shadow:0 6px 14px rgba(0,0,0,.28);transition:transform .35s var(--ease),background .35s}
.frye-pin__dot::before{content:"";position:absolute;inset:5px;border-radius:50%;background:var(--bg)}
.frye-pin__dot::after{content:"";position:absolute;inset:-9px;border-radius:50%;border:1px solid var(--accent);opacity:0;transition:opacity .4s}
.frye-pin__label{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;background:var(--bg);border:1px solid var(--line);border-radius:100px;padding:4px 10px;white-space:nowrap;opacity:0;transform:translateY(4px);transition:opacity .3s,transform .3s;pointer-events:none}
.frye-pin:hover{z-index:3}
.frye-pin:hover .frye-pin__label,.frye-pin.is-selected .frye-pin__label{opacity:1;transform:translateY(0)}
.frye-pin:hover .frye-pin__dot{transform:rotate(-45deg) scale(1.14)}
.frye-pin.is-selected .frye-pin__dot{background:var(--accent);transform:rotate(-45deg) scale(1.28)}
.frye-pin.is-selected .frye-pin__dot::before{background:var(--on-accent)}
.frye-pin.is-selected .frye-pin__dot::after{opacity:1;animation:frye-ping 1.8s ease-out infinite}
@keyframes frye-ping{0%{opacity:.7;transform:scale(.7)}100%{opacity:0;transform:scale(1.6)}}
.frye-locator__list{display:flex;flex-direction:column;gap:10px}
.frye-resto{position:relative;text-align:left;border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;background:var(--surface);transition:border-color .35s,box-shadow .35s,transform .35s}
.frye-resto:hover{border-color:var(--ink)}
.frye-resto.is-selected{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}
.frye-resto__name{font-family:var(--font-display);font-weight:500;font-size:1.25rem;letter-spacing:-.02em;display:flex;justify-content:space-between;align-items:center;gap:10px}
.frye-resto__check{width:24px;height:24px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;flex-shrink:0;color:var(--on-accent);font-size:13px;line-height:1;transition:background .3s,border-color .3s}
.frye-resto__check svg{width:12px;height:12px;opacity:0;transition:opacity .3s}
.frye-resto.is-selected .frye-resto__check{background:var(--accent);border-color:var(--accent)}
.frye-resto.is-selected .frye-resto__check svg{opacity:1}
.frye-resto__meta{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);margin-top:9px;display:inline-flex;gap:8px;align-items:center}
.frye-resto__meta .d{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:frye-pulse 1.8s ease-in-out infinite}
.frye-resto__addr{color:var(--ink-soft);font-size:.92rem;line-height:1.55;margin-top:10px}
.frye-locator__foot{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-top:clamp(22px,3.5vh,36px)}
.frye-locator__hint{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.frye-locator__continue[disabled]{opacity:.38;pointer-events:none}

/* ---------- Étape 2 : bandeau + zone plugin ---------- */
.frye-order__selected{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;border:1px solid var(--line);border-radius:var(--radius);padding:16px 22px;margin-bottom:26px;background:var(--surface)}
.frye-order__selected .lbl{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.frye-order__selected .nm{font-family:var(--font-display);font-weight:600;font-size:1.25rem;letter-spacing:-.02em;margin-top:3px}
.frye-order__change{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);border-bottom:1px solid var(--accent);padding-bottom:2px}
.frye-plugin-slot{border:1px dashed var(--line);border-radius:var(--radius);padding:clamp(34px,6vw,64px);text-align:center}
.frye-plugin-slot .mono{display:block;margin-bottom:10px}
.frye-plugin-slot p{max-width:48ch;margin:0 auto;color:var(--ink-soft)}

/* ---------- Aperçu plugin de commande (démo) ---------- */
.frye-shop{display:grid;grid-template-columns:1.4fr .85fr;gap:clamp(20px,3vw,40px);align-items:start}
.frye-shop__cat{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:6px 0 4px;padding-top:18px;border-top:1px solid var(--line)}
.frye-shop__cat:first-child{border-top:none;padding-top:0}
.frye-shop__row{display:grid;grid-template-columns:1fr auto auto;gap:18px;align-items:center;padding:15px 0;border-bottom:1px solid var(--line)}
.frye-shop__row h4{font-family:var(--font-display);font-weight:500;font-size:1.15rem;letter-spacing:-.01em}
.frye-shop__row p{font-size:.88rem;color:var(--muted);margin-top:2px}
.frye-shop__price{font-family:var(--font-display);font-weight:600;font-size:1.1rem;white-space:nowrap}
.frye-shop__add{width:44px;height:44px;border-radius:50%;border:1px solid var(--line);font-size:19px;line-height:1;transition:transform .5s var(--ease),background .3s,color .3s,border-color .3s}
.frye-shop__add:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.frye-cart{position:sticky;top:104px;background:var(--ink);color:var(--bg);border-radius:8px;overflow:hidden}
.frye-cart__head{display:flex;align-items:baseline;justify-content:space-between;padding:22px 24px 6px}
.frye-cart__head .t{font-family:var(--font-display);font-weight:600;font-size:1.35rem;letter-spacing:-.02em}
.frye-cart__head .c{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.frye-cart__lines{padding:6px 24px}
.frye-cart__empty{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:color-mix(in srgb,var(--bg) 55%,transparent);padding:22px 0;text-align:center}
.frye-cart__line{display:flex;align-items:center;gap:13px;padding:15px 0;border-bottom:1px solid color-mix(in srgb,var(--bg) 16%,transparent)}
.frye-cart__line .nm{font-family:var(--font-display);font-weight:500;font-size:1.02rem;letter-spacing:-.01em}
.frye-cart__line .pe{font-family:var(--font-mono);font-size:.64rem;color:color-mix(in srgb,var(--bg) 58%,transparent);margin-top:2px}
.frye-cart__line .qty{display:flex;align-items:center;border:1px solid color-mix(in srgb,var(--bg) 28%,transparent);border-radius:100px;overflow:hidden;margin-left:auto}
.frye-cart__line .qty button{width:30px;height:30px;font-family:var(--font-mono);color:var(--bg);transition:background .25s}
.frye-cart__line .qty button:hover{background:var(--accent);color:var(--on-accent)}
.frye-cart__line .qty span{width:26px;text-align:center;font-family:var(--font-mono);font-size:.8rem}
.frye-cart__line .lt{font-family:var(--font-display);font-weight:600;font-size:1rem;width:64px;text-align:right}
.frye-cart__slots{padding:10px 24px 0}
.frye-cart__slots .h{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin:16px 0 10px}
.frye-cart__chips{display:flex;flex-wrap:wrap;gap:7px}
.frye-slot{border:1px solid color-mix(in srgb,var(--bg) 26%,transparent);border-radius:100px;padding:9px 14px;font-family:var(--font-mono);font-size:.7rem;color:var(--bg);transition:background .25s,color .25s,border-color .25s}
.frye-slot:hover{border-color:var(--bg)}
.frye-slot.is-active{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}
.frye-cart__foot{padding:18px 24px 24px;margin-top:16px;border-top:1px solid color-mix(in srgb,var(--bg) 18%,transparent)}
.frye-cart__row{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:color-mix(in srgb,var(--bg) 62%,transparent);margin-bottom:8px}
.frye-cart__total{display:flex;justify-content:space-between;align-items:baseline;margin:6px 0 16px}
.frye-cart__total .l{font-family:var(--font-display);font-weight:600;font-size:1.2rem}
.frye-cart__total .v{font-family:var(--font-display);font-weight:600;font-size:2rem;letter-spacing:-.02em}
.frye-cart .btn{width:100%}
.frye-cart__note{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.06em;text-transform:uppercase;text-align:center;margin-top:12px;color:color-mix(in srgb,var(--bg) 55%,transparent)}
.frye-powered{text-align:center;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:clamp(30px,5vh,52px)}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .frye-locator__grid{grid-template-columns:1fr}
  .frye-locator__map{min-height:320px}
  .frye-shop{grid-template-columns:1fr}
  .frye-cart{position:relative;top:0}
  .frye-menu{grid-template-columns:1fr 1fr}
  .frye-stats{grid-template-columns:1fr 1fr;gap:32px 24px}
  .frye-spots{grid-template-columns:1fr}
  .frye-step{grid-template-columns:.4fr 1.6fr auto}
  .frye-step__desc{grid-column:2/-1}
  .footer-main{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:680px){
  .nav-links{display:none}
  .mobile-menu-btn{display:flex}
  .frye-menu{grid-template-columns:1fr}
  .frye-stats{grid-template-columns:1fr 1fr}
  .frye-step{grid-template-columns:.4fr 1fr}
  .frye-step__arrow{display:none}
  .footer-main{grid-template-columns:1fr}
  .frye-shop__row{grid-template-columns:1fr auto}
  .frye-order__steps{gap:7px}
  .frye-order__step{padding:9px 13px;font-size:.62rem}
}
