/*
Theme Name: Majal Studio
Theme URI: https://majalstudio.ma
Author: Majal Studio
Description: Thème premium Majal Studio — Agence web marocaine spécialisée Shopify & WordPress
Version: 1.1
License: GNU General Public License v2 or later
Text Domain: majal-studio
*/

/* ── TOKENS ── */
:root[data-theme="dark"]{
  --bg:#08080a;--surface:#0e0e12;
  --fg:#f5ebd2;--muted:#8a8a90;
  --border:rgba(245,235,210,.08);--border-h:rgba(245,235,210,.18);
  --accent:#C8974A;--accent-fg:#08080a;
  --accent-rgb:200,151,74;
  --terracotta:#8B3A1E;--green:#25D366;
  --warm-r:200;--warm-g:151;--warm-b:74;
}
:root[data-theme="light"]{
  --bg:#fafafa;--surface:#fff;
  --fg:#0a0a0a;--muted:#6b6b70;
  --border:rgba(10,10,10,.10);--border-h:rgba(10,10,10,.22);
  --accent:#8B6432;--accent-fg:#fafafa;
  --accent-rgb:139,100,50;
  --terracotta:#8B3A1E;--green:#25D366;
  --warm-r:139;--warm-g:100;--warm-b:50;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--fg);font-family:"Geist",system-ui,sans-serif;-webkit-font-smoothing:antialiased}
body{overflow-x:hidden;cursor:none}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
canvas{user-select:none;-webkit-user-select:none}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--accent);border-radius:2px}

/* SCROLL PROGRESS */
.scroll-progress{position:fixed;top:0;left:0;height:2px;z-index:300;pointer-events:none;transform-origin:left;will-change:transform;background:linear-gradient(90deg,var(--accent),var(--terracotta))}

/* CURSOR */
.cursor-dot{position:fixed;top:0;left:0;z-index:9999999;width:8px;height:8px;border-radius:50%;background:var(--accent);pointer-events:none;transform:translate(-50%,-50%);will-change:transform}
.cursor-ring{position:fixed;top:0;left:0;z-index:9999998;width:38px;height:38px;border-radius:50%;border:1.5px solid var(--accent);opacity:.5;pointer-events:none;transform:translate(-50%,-50%);will-change:transform;transition:width .3s,height .3s,opacity .3s}
.cursor-ring.hovering{width:60px;height:60px;opacity:.8}
@media(pointer:coarse),(max-width:1024px){.cursor-dot,.cursor-ring{display:none!important}body{cursor:auto!important}}

/* HEADER */
.lf-header{position:fixed;inset:0 0 auto 0;height:56px;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(1.25rem,3vw,2.5rem);background:color-mix(in srgb,var(--bg) 75%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
.lf-mark{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:500;letter-spacing:.18em;text-transform:uppercase}
.lf-mark .glyph{width:28px;height:28px;background:var(--accent);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--accent-fg)}
.lf-nav{display:none;gap:32px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.lf-nav a{position:relative;padding:4px 0;transition:color .25s}
.lf-nav a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--accent);transition:width .5s ease}
.lf-nav a:hover{color:var(--fg)}
.lf-nav a:hover::after{width:100%}
@media(min-width:900px){.lf-nav{display:flex}}
.lf-actions{display:flex;align-items:center;gap:12px}
.lf-theme-btn{width:32px;height:32px;border-radius:999px;background:transparent;border:1px solid var(--border);color:var(--muted);cursor:none;display:flex;align-items:center;justify-content:center;font-size:13px;transition:color .25s,border-color .25s}
.lf-theme-btn:hover{color:var(--fg);border-color:var(--border-h)}
.lf-cta{display:none;padding:7px 18px;border-radius:999px;background:var(--accent);color:var(--accent-fg);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;transition:opacity .25s}
.lf-cta:hover{opacity:.85}
@media(min-width:600px){.lf-cta{display:inline-block}}
.nav-mobile-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:none;padding:8px}
.nav-mobile-btn span{display:block;width:22px;height:1.5px;background:var(--muted);transition:all .3s}
@media(max-width:899px){.nav-mobile-btn{display:flex}}

/* SECTION DIVIDER */
.section-divider{height:1px;width:100%;background:var(--border)}

/* BTN */
.btn{display:inline-flex;align-items:center;gap:10px;padding:12px 28px;border-radius:999px;font-size:13px;font-weight:500;cursor:none;transition:all .3s;border:1px solid transparent}
.btn-primary{background:var(--accent);color:var(--accent-fg)}
.btn-primary:hover{opacity:.85;transform:scale(1.02)}
.btn-secondary{background:var(--surface);border-color:var(--border);color:var(--muted)}
.btn-secondary:hover{border-color:var(--border-h);color:var(--fg)}
.eyebrow{font-size:10px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--muted)}

/* MEMBRANE */
.membrane{position:relative;height:100vh;width:100%;overflow:hidden;background:var(--bg)}
.membrane-canvas{position:absolute;inset:0;z-index:0}
.membrane-content{position:relative;z-index:10;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 24px;pointer-events:none}
.membrane-content>*{pointer-events:auto}
.membrane-badge{display:inline-flex;align-items:center;gap:14px;margin-bottom:28px;opacity:0;font-size:10px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:color-mix(in srgb,var(--fg) 85%,transparent)}
.membrane-badge svg{opacity:.85}
.membrane-eyebrow{margin-bottom:20px;opacity:0}
.membrane-arabic{font-family:'Noto Naskh Arabic',serif;font-size:clamp(1.8rem,5vw,3.4rem);color:var(--accent);opacity:0;margin-bottom:16px;direction:rtl;unicode-bidi:isolate;word-break:keep-all}
.membrane-title{font-family:"Playfair Display",serif;font-size:clamp(3rem,8vw,7.5rem);line-height:1.05;font-weight:600;letter-spacing:-.02em;opacity:0;color:var(--fg)}
.membrane-title em{font-style:italic;color:var(--accent)}
.membrane-subtitle{margin-top:24px;max-width:36rem;font-size:13px;line-height:1.75;color:var(--muted);opacity:0}
.membrane-buttons{margin-top:36px;display:flex;gap:12px;opacity:0;flex-wrap:wrap;justify-content:center}
/* Zellige */
.zel{position:absolute;pointer-events:none;will-change:transform;z-index:1}
.scroll-hint{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;opacity:.4;z-index:5}
.scroll-hint span{font-size:9px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted)}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--muted),transparent);animation:spulse 2s ease-in-out infinite}
@keyframes spulse{0%,100%{opacity:.3}50%{opacity:1}}

/* MARQUEE */
.marquee-wrap{overflow:hidden;padding:20px 0;border-top:1px solid rgba(var(--accent-rgb),.15);border-bottom:1px solid rgba(var(--accent-rgb),.15);background:rgba(var(--accent-rgb),.03)}
.marquee-track{display:flex;width:max-content;will-change:transform}
.marquee-item{display:flex;align-items:center;gap:32px;padding:0 32px;font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);white-space:nowrap}
.marquee-sep{color:var(--terracotta)}

/* FOLIO */
.folio{position:relative;height:100vh;width:100%;overflow:hidden;background:var(--bg)}
.folio-chrome-tl,.folio-chrome-tr,.folio-chrome-bottom{position:absolute;z-index:20;opacity:0}
.folio-chrome-tl{left:32px;top:32px;display:flex;align-items:center;gap:16px;font-size:10px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--muted)}
.folio-chrome-tl .al{display:inline-block;width:32px;height:1px;background:var(--border-h)}
.folio-chrome-tr{right:32px;top:32px;font-family:"Playfair Display",serif;font-style:italic;font-size:14px;font-variant-numeric:tabular-nums;color:var(--muted)}
.folio-chrome-tr .cur{color:var(--fg)}
.folio-chrome-tr .sep{margin:0 8px;opacity:.6}
.folio-chrome-bottom{left:50%;bottom:32px;transform:translateX(-50%);font-size:10px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--muted)}
.folio-grid{display:grid;height:100%;grid-template-columns:1fr}
@media(min-width:760px){.folio-grid{grid-template-columns:1fr 1fr}}
.folio-titles-col{position:relative;overflow:hidden;padding-left:clamp(2rem,5vw,5rem)}
.folio-titles-strip{will-change:transform}
.folio-title-row{display:flex;flex-direction:column;justify-content:center;height:7.143vh}
.folio-title-text{font-family:"Geist",sans-serif;font-size:clamp(1.8rem,4vw,4rem);line-height:1;letter-spacing:-.02em;font-variation-settings:"wght" 420;color:var(--muted);white-space:nowrap}
.folio-title-sub{margin-top:6px;opacity:0;font-size:10px;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
.folio-images-col{position:relative;overflow:hidden;padding-right:clamp(2rem,5vw,5rem)}
.folio-images-strip{position:absolute;inset:0;will-change:transform}
.folio-image-slot{position:absolute;left:0;right:0;display:flex;align-items:center;justify-content:center;height:65vh;transform-origin:center center}
.folio-image-inner{position:relative;overflow:hidden;width:100%;aspect-ratio:16/9;will-change:transform;background:var(--surface);box-shadow:0 30px 60px -30px rgba(0,0,0,.5)}
.folio-image-inner img{width:100%;height:100%;object-fit:cover;display:block}
.mobile-folio-img-wrap{display:none}
.mobile-folio-list{display:none}

@media(max-width:759px){
  /* Desktop GSAP folio : tout caché */
  .folio{height:auto!important;overflow:visible!important}
  .folio-grid{display:none!important}
  .folio-chrome-tl,.folio-chrome-tr,.folio-chrome-bottom{display:none!important}
  /* Liste mobile : visible */
  .mobile-folio-list{display:block;padding:72px 20px 56px}
  .mobile-folio-card{margin-bottom:52px}
  .mobile-folio-card:last-child{margin-bottom:0}
  .mobile-folio-card-title{font-family:"Geist",sans-serif;font-size:clamp(1.9rem,8vw,3rem);font-weight:700;letter-spacing:-.03em;color:var(--fg);margin-bottom:14px;line-height:1.05}
  .mobile-folio-card-img{width:100%;aspect-ratio:16/9;border-radius:12px;overflow:hidden;box-shadow:0 16px 48px rgba(0,0,0,.45)}
  .mobile-folio-card-img img{width:100%;height:100%;object-fit:cover;display:block}
  .mobile-folio-card-meta{margin-top:10px;font-size:10px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
}

/* SERVICES */
.services-section{padding:120px clamp(1.5rem,4vw,4rem);position:relative}
.sec-label{font-size:10px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:18px}
.sec-label.ac{color:var(--accent)}
.sec-title{font-family:"Playfair Display",serif;font-size:clamp(2.2rem,5vw,4.2rem);font-weight:600;line-height:1.05;letter-spacing:-.02em;margin-bottom:60px}
.sec-title em{font-style:italic;color:var(--accent)}
.sec-header{text-align:center;margin-bottom:72px}
.sec-header .sec-label{margin-bottom:20px}
.sec-header .sec-title{max-width:600px;margin:0 auto 0;display:block}
.services-grid{max-width:1200px;margin:0 auto}

/* PARALLAX */
.parallax-section{position:relative;height:100vh;min-height:500px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.para-bg{position:absolute;inset:-10%;will-change:transform;background:url('https://images.unsplash.com/photo-1441984904996-e0b6ba687e04?w=1920&h=1280&q=80&auto=format&fit=crop') center/cover;filter:blur(6px) brightness(.3)}
.para-mid{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;will-change:transform}
.para-mid img{width:50%;max-width:600px;border-radius:16px;box-shadow:0 50px 100px rgba(0,0,0,.6);will-change:transform}
.para-fg{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:flex-end;padding:48px;pointer-events:none;will-change:transform}
.para-badge{background:var(--accent);color:var(--accent-fg);padding:14px 28px;border-radius:999px;font-weight:700;font-size:.95rem;box-shadow:0 20px 50px rgba(0,0,0,.4)}
.para-text{position:relative;z-index:10;text-align:center;max-width:700px;padding:0 32px}
.para-text h2{font-family:"Playfair Display",serif;font-size:clamp(2rem,4.5vw,3.8rem);font-weight:600;line-height:1.2;text-shadow:0 4px 30px rgba(0,0,0,.6)}

/* WORD REVEAL */
.word-reveal-section{padding:160px clamp(1.5rem,4vw,4rem);background:var(--fg);color:var(--bg);text-align:center}
.word-reveal-text{font-family:'Noto Naskh Arabic','Playfair Display',serif;font-size:clamp(1.4rem,2.8vw,2.4rem);font-weight:500;line-height:1.9;max-width:900px;margin:0 auto;direction:rtl;text-align:center}
.word-reveal-text span{display:inline-block;opacity:.12;transition:opacity .35s ease;margin:.1em .2em}
.word-reveal-text span.revealed{opacity:1}
@media(max-width:759px){.word-reveal-text{font-size:clamp(1.2rem,5vw,1.8rem);line-height:2}}

/* PRICING */
.pricing-section{padding:120px clamp(1.5rem,4vw,4rem)}
/* PRICING COMPARE TABLE */
.pricing-compare{max-width:940px;margin:0 auto;border:1px solid var(--border);border-radius:20px;overflow:hidden}
.pc-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;border-bottom:1px solid var(--border)}
.pc-row:last-child{border-bottom:none}
.pc-cell{padding:18px 22px;display:flex;align-items:center;font-size:.88rem}
.pc-cell.lbl{color:var(--muted);font-size:.84rem;border-right:1px solid var(--border)}
.pc-cell.pkg{flex-direction:column;align-items:flex-start;gap:3px;background:rgba(var(--accent-rgb),.02)}
.pc-cell.pkg.hi{background:rgba(var(--accent-rgb),.07)}
.pc-head .pc-cell{padding:28px 22px;background:var(--surface);border-bottom:2px solid var(--border)}
.pc-head .pc-cell.hi{border-top:3px solid var(--accent)}
.pc-badge{font-size:.64rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.pc-badge.hi{color:var(--accent)}
.pc-pname{font-family:"Playfair Display",serif;font-size:1.35rem;font-weight:600;color:var(--fg);margin:2px 0}
.pc-price-wrap{display:flex;align-items:baseline;gap:5px;margin-top:4px}
.pc-price{font-size:1.7rem;font-weight:700;color:var(--accent);font-family:"Playfair Display",serif;line-height:1}
.pc-cur{font-size:.82rem;font-weight:400;color:var(--muted)}
.pc-desc{font-size:.73rem;color:var(--muted);line-height:1.45;margin-top:8px}
.pc-check{color:var(--accent);font-size:1rem;font-weight:900}
.pc-dim{color:var(--muted);font-size:1rem;opacity:.25}
.pc-val{color:var(--fg);font-size:.88rem;font-weight:500}
.pc-row.pc-footer .pc-cell{padding:22px 22px;background:var(--surface)}
.pc-row.pc-footer .pc-cell.pkg,.pc-row.pc-footer .pc-cell.pkg.hi{align-items:stretch}
.pc-cta{display:block;width:100%;padding:11px 0;border-radius:999px;border:1.5px solid var(--accent);color:var(--accent);font-size:.8rem;font-weight:600;text-align:center;transition:all .3s;background:transparent}
.pc-cta:hover,.pc-cell.hi .pc-cta{background:var(--accent);color:var(--accent-fg)}
.pc-row.pc-total .pc-cell{font-size:.82rem;color:var(--muted);border-top:none}
.pc-row.pc-total .pc-cell.pkg{color:var(--accent);font-size:.95rem;font-weight:600;align-items:center;flex-direction:row}
@media(max-width:700px){
  .pc-row{grid-template-columns:1.3fr 1fr 1fr 1fr}
  .pc-cell{padding:12px 10px;font-size:.78rem}
  .pc-pname{font-size:1rem}
  .pc-price{font-size:1.3rem}
  .pc-desc{display:none}
}

/* DRAG */
.drag-section{position:relative;min-height:80vh;width:100%;overflow:hidden;background:var(--bg);padding:100px 0;display:flex;flex-direction:column;justify-content:center}
.drag-header{text-align:center;max-width:840px;margin:0 auto 60px;padding:0 24px}
.drag-header .eyebrow{display:inline-flex;align-items:center;gap:12px;margin-bottom:18px}
.drag-header .eyebrow::before,.drag-header .eyebrow::after{content:'';display:inline-block;width:18px;height:1px;background:var(--border-h)}
.drag-title{font-family:"Playfair Display",serif;font-weight:500;font-size:clamp(2.2rem,5vw,4rem);line-height:1.05;letter-spacing:-.02em}
.drag-track-wrap{position:relative;width:100%;overflow:hidden;-webkit-mask-image:linear-gradient(to right,transparent 0%,#000 8%,#000 92%,transparent 100%);mask-image:linear-gradient(to right,transparent 0%,#000 8%,#000 92%,transparent 100%);cursor:grab}
.drag-track-wrap:active{cursor:grabbing}
.drag-track{display:flex;gap:20px;padding:24px 60px;will-change:transform;user-select:none}
.drag-card{flex:0 0 auto;width:clamp(280px,34vw,400px);background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:36px 32px;position:relative;overflow:hidden;transition:border-color .35s,transform .35s}
.drag-card:hover{border-color:var(--border-h);transform:translateY(-2px)}
.drag-card::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(var(--accent-rgb),.05) 0%,transparent 70%);opacity:0;transition:opacity .35s}
.drag-card:hover::before{opacity:1}
.tcard-stars{color:var(--accent);font-size:.95rem;margin-bottom:20px;letter-spacing:3px}
.tcard-quote{font-family:"Playfair Display",serif;font-size:1rem;font-style:italic;line-height:1.65;color:var(--fg);margin-bottom:24px}
.tcard-divider{width:40px;height:1px;background:var(--accent);margin-bottom:20px}
.tcard-name{font-weight:600;font-size:.9rem;color:var(--fg)}
.tcard-role{font-size:.78rem;color:var(--muted);margin-top:4px}

/* ZOOM CTA */
.zoom-section{position:relative;height:250vh}
.zoom-sticky{position:sticky;top:0;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.zoom-bg{position:absolute;inset:-20%;background:url('https://images.unsplash.com/photo-1556742049-0cfed4f6a45d?w=1920&h=1280&q=80&auto=format&fit=crop') center/cover;will-change:transform}
.zoom-overlay{position:absolute;inset:0;background:rgba(8,8,10,.78)}
.zoom-content{position:relative;z-index:2;text-align:center;max-width:700px;padding:0 32px}
.zoom-content h2{font-family:"Playfair Display",serif;font-size:clamp(2.2rem,5vw,4rem);font-weight:600;margin-bottom:20px;line-height:1.15}
.zoom-content p{font-size:1rem;color:var(--muted);margin-bottom:48px;max-width:500px;margin-left:auto;margin-right:auto;line-height:1.7}
.zoom-buttons{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}
.zoom-btn{display:inline-flex;align-items:center;gap:12px;padding:16px 36px;border-radius:999px;font-weight:600;font-size:.95rem;transition:all .4s;cursor:none}
.zoom-btn-wa{background:var(--green);color:#fff}
.zoom-btn-wa:hover{transform:scale(1.05) translateY(-2px);box-shadow:0 20px 50px rgba(37,211,102,.35)}
.zoom-btn-email{background:transparent;border:2px solid rgba(245,235,210,.3);color:var(--fg)}
.zoom-btn-email:hover{background:var(--fg);color:var(--bg);transform:scale(1.05) translateY(-2px)}

/* LIQUID */
.liquid{position:relative;height:100vh;width:100%;overflow:hidden;background:var(--bg);cursor:default}
.liquid-canvas{position:absolute;inset:0;z-index:0}
.liquid-content{position:relative;z-index:10;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:56px 24px 64px;pointer-events:none}
.liquid-content>*{pointer-events:auto}
.liquid-eyebrow{margin-bottom:32px;opacity:0}
.liquid-title{font-family:"Geist",sans-serif;font-size:clamp(3rem,10vw,8.5rem);line-height:1.05;letter-spacing:-.03em;color:var(--fg);user-select:none;display:flex;flex-wrap:wrap;gap:.18em;justify-content:center;max-width:14ch;pointer-events:auto}
.liquid-title .word{display:inline-flex}
.liquid-char{display:inline-block;will-change:transform}
.liquid-char .ci{display:inline-block;font-variation-settings:"wght" 300;will-change:transform,font-variation-settings}
.liquid-subtitle{margin-top:24px;max-width:36rem;font-size:13px;line-height:1.7;color:var(--muted);opacity:0}
.liquid-buttons{margin-top:32px;display:flex;gap:12px;opacity:0;flex-wrap:wrap;justify-content:center}

/* CONTACT */
.contact-section{padding:120px clamp(1.5rem,4vw,4rem);background:color-mix(in srgb,var(--surface) 60%,var(--bg))}
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(48px,6vw,100px);max-width:1100px;margin:0 auto;align-items:start}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr}}
.contact-info--centered{max-width:560px;margin:0 auto;text-align:center}
.contact-info--centered .ci-item{justify-content:center}
.contact-info--centered>p{margin-bottom:36px}
.contact-info h3{font-family:"Playfair Display",serif;font-size:1.8rem;font-weight:600;margin-bottom:16px}
.contact-info>p{color:var(--muted);line-height:1.7;margin-bottom:40px;font-size:.9rem}
.ci-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:28px}
.ci-icon{width:44px;height:44px;background:rgba(var(--accent-rgb),.1);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent)}
.ci-icon svg{width:20px;height:20px}
.ci-content h4{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:6px}
.ci-content a,.ci-content p{color:var(--fg);font-size:.9rem;line-height:1.5;transition:color .3s}
.ci-content a:hover{color:var(--accent)}
.contact-form-box{background:rgba(var(--accent-rgb),.03);border:1px solid var(--border);border-radius:20px;padding:48px}
.contact-form-box h3{font-family:"Playfair Display",serif;font-size:1.4rem;font-weight:600;margin-bottom:8px}
.contact-form-box>p{color:var(--muted);font-size:.84rem;margin-bottom:28px}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:.72rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:8px}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:14px 18px;background:rgba(var(--accent-rgb),.04);border:1px solid var(--border);border-radius:10px;color:var(--fg);font-family:"Geist",sans-serif;font-size:.88rem;transition:border-color .3s,box-shadow .3s;outline:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.15)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted);opacity:.6}
.form-group textarea{min-height:120px;resize:vertical}
.form-group select option{background:var(--surface);color:var(--fg)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:480px){.form-row{grid-template-columns:1fr}}
.form-submit{width:100%;padding:16px;background:var(--accent);color:var(--accent-fg);border:none;border-radius:999px;font-family:"Geist",sans-serif;font-size:.95rem;font-weight:600;cursor:none;transition:all .4s;margin-top:8px}
.form-submit:hover{opacity:.85;transform:translateY(-2px)}

/* FOOTER */
.lf-footer{padding:80px clamp(1.5rem,4vw,4rem) 32px;border-top:1px solid var(--border)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1.4fr;gap:40px;max-width:1300px;margin:0 auto 60px}
@media(max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr 1fr}}
@media(max-width:640px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.footer-brand-icon{width:28px;height:28px;background:var(--accent);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--accent-fg)}
.footer-brand-text{font-family:"Playfair Display",serif;font-size:1.3rem;font-weight:600}
.footer-tagline{font-size:.84rem;color:var(--muted);line-height:1.7;max-width:260px;margin-bottom:24px}
.footer-social{display:flex;gap:12px}
.footer-social a{width:36px;height:36px;border-radius:8px;background:rgba(var(--accent-rgb),.06);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .3s;border:1px solid var(--border)}
.footer-social a:hover{background:var(--accent);color:var(--accent-fg);border-color:var(--accent);transform:translateY(-2px)}
.footer-social a svg{width:15px;height:15px}
.ft{font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:18px}
.footer-links{list-style:none}
.footer-links li{margin-bottom:10px}
.footer-links a{color:var(--muted);font-size:.84rem;transition:color .3s,padding-left .3s;display:inline-block}
.footer-links a:hover{color:var(--fg);padding-left:4px}
.fci{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-size:.84rem;color:var(--muted)}
.fci svg{width:15px;height:15px;color:var(--accent);flex-shrink:0}
.fci a{color:var(--muted);transition:color .3s}
.fci a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;border-top:1px solid var(--border);max-width:1300px;margin:0 auto;font-size:.74rem;color:var(--muted);flex-wrap:wrap;gap:12px}

[data-reveal]{opacity:0;transform:translateY(40px);will-change:transform,opacity}

/* ── MOBILE DRAWER ── */
.mobile-drawer{position:fixed;inset:56px 0 0 0;background:color-mix(in srgb,var(--bg) 97%,transparent);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);z-index:98;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;transform:translateY(-100%);opacity:0;transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .4s;pointer-events:none;border-bottom:1px solid var(--border)}
.mobile-drawer.open{transform:translateY(0);opacity:1;pointer-events:auto}
.mobile-drawer-nav{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;padding:0 32px}
.mobile-drawer-link{font-size:1.6rem;font-family:"Playfair Display",serif;font-weight:600;color:var(--fg);padding:16px 0;text-align:center;width:100%;border-bottom:1px solid var(--border);transition:color .3s}
.mobile-drawer-link:last-child{border-bottom:none}
.mobile-drawer-link:hover{color:var(--accent)}
.mobile-drawer-wa{margin-top:32px;display:inline-flex;align-items:center;gap:10px;background:var(--green);color:#fff;padding:14px 36px;border-radius:999px;font-weight:600;font-size:.95rem}
.nav-mobile-btn.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-mobile-btn.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-mobile-btn.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ── MOBILE GLOBAL ── */
@media(max-width:767px){

  /* Tables comparison : scroll horizontal */
  .services-section,.pricing-section{padding-left:0;padding-right:0;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .services-section .sec-header,.pricing-section .sec-header{padding:0 20px}
  .pricing-compare,.services-grid .pricing-compare{min-width:560px;border-radius:12px;margin:0 20px}
  .services-grid{min-width:560px;margin:0 20px}

  /* Sections : padding réduit */
  .services-section{padding:60px 20px}
  .pricing-section{padding:60px 20px}
  .contact-section{padding:60px 20px}
  .word-reveal-section{padding:80px 20px}
  .drag-section{padding:60px 0}
  .drag-header{padding:0 20px;margin-bottom:32px}

  /* Contact form */
  .contact-form-box{padding:28px 20px}
  .form-row{grid-template-columns:1fr}

  /* Folio */
  .folio-chrome-tl,.folio-chrome-tr{display:none}
  .folio-chrome-bottom{font-size:9px;letter-spacing:.2em}
  .folio-titles-strip{width:100%}

  /* Zoom/CTA section */
  .zoom-section{height:160vh}
  .zoom-content{padding:0 20px}
  .zoom-buttons{flex-direction:column;align-items:center}
  .zoom-btn{width:100%;justify-content:center;padding:14px 24px}

  /* Parallax */
  .para-mid img{width:75%;max-width:300px}
  .para-fg{padding:24px}
  .para-badge{font-size:.8rem;padding:10px 20px}

  /* Footer */
  .footer-bottom{flex-direction:column;text-align:center;gap:8px}

  /* Liquid */
  .liquid-title{font-size:clamp(2.4rem,10vw,5rem)}

  /* Sec header */
  .sec-header{margin-bottom:40px}
  .sec-title{margin-bottom:32px;font-size:clamp(1.8rem,6vw,3rem)}
  .contact-info h3{font-size:1.4rem}
  .contact-info>p{margin-bottom:24px}
}

/* ── MOBILE SMALL (< 480px) ── */
@media(max-width:479px){
  .membrane-title{font-size:clamp(2.4rem,10vw,4rem)}
  .membrane-subtitle{font-size:.82rem}
  .membrane-buttons{gap:8px}
  .btn{padding:10px 20px;font-size:.82rem}
  .para-text h2{font-size:clamp(1.6rem,7vw,2.4rem)}
  .zoom-content h2{font-size:clamp(1.8rem,7vw,2.6rem)}
  .contact-form-box{padding:20px 16px}
  .lf-footer{padding:48px 20px 24px}
  .footer-bottom{font-size:.68rem}
  .drag-card{width:clamp(240px,80vw,320px);padding:24px 20px}
}

/* ══════════════════════════════════════════
   AMÉLIORATIONS PREMIUM — MOBILE FIRST
   ══════════════════════════════════════════ */

/* ── Arabic text — RTL correct ── */
.membrane-arabic {
  font-family: 'Noto Naskh Arabic', serif !important;
  font-size: clamp(1.8rem, 5vw, 3.4rem);
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.55;
  color: var(--accent);
  direction: rtl;
  unicode-bidi: isolate;
  text-align: center;
  display: block;
  word-break: keep-all;
  overflow-wrap: normal;
}
.membrane-subtitle {
  direction: ltr;
  text-align: center;
}
.word-reveal-text {
  direction: ltr;
  text-align: center;
  font-family: 'Playfair Display', serif;
}
@media(max-width:759px) {
  .membrane-arabic { font-size: clamp(1.6rem, 7.5vw, 2.6rem); padding: 0 16px; }
}

/* ── Floating WhatsApp Button ── */
.wa-float {
  position: fixed;
  bottom: 24px;
  right: 20px;
  z-index: 9998;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #25D366;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 24px rgba(37,211,102,.4);
  animation: wa-pulse 2.8s ease-in-out infinite;
  transition: transform .25s ease, box-shadow .25s ease;
  cursor: pointer;
}
.wa-float:hover {
  transform: scale(1.1) translateY(-2px);
  box-shadow: 0 16px 40px rgba(37,211,102,.55);
}
.wa-float svg { width: 28px; height: 28px; fill: #fff; }
@keyframes wa-pulse {
  0%,100% { box-shadow: 0 8px 24px rgba(37,211,102,.4); }
  50%      { box-shadow: 0 8px 40px rgba(37,211,102,.7), 0 0 0 8px rgba(37,211,102,.08); }
}

/* ── Hero mobile amélioré ── */
@media(max-width:759px) {
  .membrane-content  { padding-top: 72px; padding-bottom: 32px; }
  .membrane-badge    { font-size: 9px; letter-spacing: .15em; gap: 10px; margin-bottom: 20px; }
  .membrane-title    { font-size: clamp(2rem, 8.5vw, 3.2rem); line-height: 1.1; padding: 0 8px; }
  .membrane-subtitle { font-size: .875rem; line-height: 1.72; margin-top: 18px; padding: 0 12px; max-width: 100%; }
  .membrane-buttons  { margin-top: 28px; flex-direction: column; align-items: center; gap: 10px; padding: 0 20px; width: 100%; }
  .membrane-buttons .btn { width: 100%; max-width: 340px; justify-content: center; padding: 15px 20px; font-size: .92rem; border-radius: 8px; }
  .scroll-hint { bottom: 88px; }
  /* iOS — évite le zoom auto sur les inputs */
  input, textarea, select { font-size: 16px !important; }
}

/* ── Portfolio cards mobile premium ── */
@media(max-width:759px) {
  .mobile-folio-list { padding: 56px 20px 72px; }
  .mobile-folio-card { margin-bottom: 48px; }
  .mobile-folio-card-img {
    aspect-ratio: 4/3;
    border-radius: 16px;
    box-shadow: 0 20px 56px rgba(0,0,0,.5);
    overflow: hidden;
    transition: transform .4s ease;
  }
  .mobile-folio-card-img img {
    width: 100%; height: 100%;
    object-fit: cover; display: block;
    transition: transform .6s cubic-bezier(.16,1,.3,1);
  }
  .mobile-folio-card-img:active img { transform: scale(1.03); }
  .mobile-folio-card-title {
    font-size: clamp(1.7rem, 7.5vw, 2.8rem);
    letter-spacing: -.03em;
    margin-bottom: 12px;
    line-height: 1.05;
  }
  .mobile-folio-card-meta {
    margin-top: 12px;
    font-size: 10px;
    letter-spacing: .2em;
    color: var(--accent);
    display: flex;
    align-items: center;
    gap: 8px;
  }
  .mobile-folio-card-meta::before {
    content: '';
    display: inline-block;
    width: 20px; height: 1px;
    background: var(--accent);
  }
}

/* ── Témoignages — amélioration ── */
.tcard-stars { letter-spacing: 4px; font-size: 1rem; }
.tcard-name  { font-size: .95rem; }
.tcard-role  { font-size: .8rem; color: var(--accent); margin-top: 3px; }
.drag-card   { transition: border-color .35s, transform .35s, box-shadow .35s; }
.drag-card:hover { box-shadow: 0 24px 60px rgba(0,0,0,.3); }

/* ── Footer links — tap targets ── */
.footer-links a { display: block; padding: 7px 0; min-height: 40px; line-height: 1.5; }

/* ── CTA boutons — hover premium ── */
.btn-primary {
  box-shadow: 0 4px 20px rgba(var(--accent-rgb),.2);
  transition: all .3s cubic-bezier(.16,1,.3,1);
}
.btn-primary:hover {
  opacity: 1;
  transform: translateY(-2px);
  box-shadow: 0 12px 36px rgba(var(--accent-rgb),.35);
}

/* ── Nav mobile — tap zone ── */
.nav-mobile-btn { width: 44px; height: 44px; padding: 10px; }

/* ── Scroll reveal amélioré ── */
[data-reveal] {
  transition: opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1);
}
