/*
Theme Name: Alliance Pub
Theme URI: http://www.alliancepub46.fr
Author: Hugo Gourdy
Author URI: http://www.alliancepub46.fr
Description: Thème personnalisé pour Alliance Pub – Atelier de marquage publicitaire à Pradines (Lot, 46)
Version: 1.0
License: Propriétaire
Text Domain: alliance-pub
*/

/* ══════════════════════════════════════════
   VARIABLES & RESET
   ══════════════════════════════════════════ */
:root {
  --dark:    #0d1a38;
  --dark2:   #111f42;
  --dark3:   #16254d;
  --panel:   #1c2e5e;
  --blue:    #23468C;
  --blue-l:  #2d5ab0;
  --blue-p:  rgba(35,70,140,0.12);
  --white:   #f0f4ff;
  --muted:   rgba(240,244,255,0.5);
  --border:  rgba(255,255,255,0.07);
  --gold:    #f0a500;
  --gold-d:  #d4920a;
  --green:   #22c55e;
  --cream:   #fdf8f2;
  --cream2:  #f5efe6;
  --ink:     #111827;
  --ink-m:   #4b5563;
  --ink-l:   #9ca3af;
}

/* Dropdown nav */
.nav-dropdown{position:relative}
.dropdown{display:none;position:absolute;top:100%;left:0;background:rgba(10,15,30,.97);border:1px solid rgba(255,255,255,.08);border-radius:4px;min-width:200px;list-style:none;padding:.5rem 0;z-index:400}
.nav-dropdown:hover .dropdown{display:block}
.dropdown li a{display:block;padding:.75rem 1.4rem;font-size:.76rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(240,244,255,.6);transition:color .2s, background .2s}
.dropdown li a:hover{color:var(--white);background:rgba(255,255,255,.05)}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Nunito Sans',sans-serif;font-weight:400;background:var(--cream);color:var(--ink);overflow-x:hidden;line-height:1.6}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}

/* ── UTILS ── */
.display{font-family:'Barlow Condensed',sans-serif;font-size:clamp(2.8rem,4.5vw,5rem);font-weight:900;line-height:.92;letter-spacing:.02em;text-transform:uppercase}
.display em{font-style:normal;color:var(--blue)}
.display .bl{color:var(--blue-l)}
.label{font-size:.68rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);display:inline-flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.label::after{content:'';display:block;width:32px;height:2px;background:var(--blue)}
.label-gold{color:var(--gold)}
.label-gold::after{background:var(--gold)}
.sub{font-size:1rem;line-height:1.8;color:var(--ink-m);max-width:520px}
.btn{display:inline-block;font-family:'Nunito Sans',sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.95rem 2.2rem;border-radius:3px;cursor:pointer;border:none;transition:all .2s}
.btn-gold{background:var(--gold);color:#0a0f1e}
.btn-gold:hover{background:var(--gold-d);transform:translateY(-2px);box-shadow:0 8px 24px rgba(240,165,0,.3)}
.btn-ghost{background:transparent;color:var(--ink);border:2px solid rgba(0,0,0,.15)}
.btn-ghost:hover{border-color:var(--ink);background:rgba(0,0,0,.05);transform:translateY(-2px)}
.btn-blue{background:var(--blue);color:var(--white)}
.btn-blue:hover{background:var(--blue-l);transform:translateY(-2px)}
.sec{padding:7rem 7rem}
.sec-alt{background:var(--cream2)}
.sec-panel{background:var(--cream)}
.sec-cream{background:var(--cream)}
.sec-dark{background:var(--dark3);color:var(--white)}
.sec-dark .label{color:var(--blue-l)}
.sec-dark .label::after{background:var(--blue-l)}
.sec-dark h2.display{color:var(--white)}
.sec-dark h2.display em{color:rgba(255,255,255,.45)}
.sec-dark .sub{color:rgba(240,244,255,.5)}
.sec-dark .tmcard{background:rgba(255,255,255,.03)}
.sec-dark .tmcard:hover{background:rgba(45,125,210,.15)}
.sec-dark .tmcard h4{color:var(--white)}
.sec-dark .team-col{background:rgba(255,255,255,.05)}
.sec-dark .equipe-photo{border-color:rgba(255,255,255,.08)}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:300;display:flex;align-items:center;justify-content:space-between;padding:0 4rem;height:70px;background:rgba(10,15,30,.97);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);transition:box-shadow .3s}
nav.scrolled{box-shadow:0 4px 30px rgba(0,0,0,.5)}
.logo{display:flex;align-items:center;gap:.7rem}
.logo img{height:40px}
.logo-txt{font-family:'Barlow Condensed',sans-serif;font-size:1.6rem;font-weight:900;letter-spacing:.08em;color:var(--white);display:none}
.logo-txt span{color:var(--gold)}
.nav-links{display:flex;gap:2rem;list-style:none;align-items:center}
.nav-links a{font-size:.76rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(240,244,255,.6);transition:color .2s}
.nav-links a:hover{color:var(--white)}
.nav-cta{background:var(--gold)!important;color:#0a0f1e!important;padding:.5rem 1.4rem;border-radius:3px;font-weight:700!important}
.nav-cta:hover{background:var(--gold-d)!important}

/* ── HERO ── */
#hero{min-height:100vh;position:relative;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-image:url('http://www.alliancepub46.fr/wp-content/uploads/2017/07/cropped-IMG_4938-2L.jpg');background-size:cover;background-position:center;filter:brightness(.7) saturate(.85);transform:scale(1.06);animation:heroZ 20s ease-in-out infinite alternate}
@keyframes heroZ{from{transform:scale(1.06)}to{transform:scale(1.13)}}
.hero-ov{position:absolute;inset:0;background:linear-gradient(115deg,rgba(10,15,30,.96) 0%,rgba(26,63,111,.65) 55%,rgba(45,125,210,.18) 100%)}
.hero-grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:72px 72px}
.hero-content{position:relative;z-index:2;padding:9rem 7rem 6rem;max-width:820px}
.hero-eyebrow{display:flex;align-items:center;gap:.8rem;margin-bottom:2rem;opacity:0;animation:fadeUp .8s .2s forwards}
.hero-dot{width:8px;height:8px;border-radius:50%;background:var(--gold)}
.hero-eyebrow span{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
h1.hero-title{font-family:'Barlow Condensed',sans-serif;font-size:clamp(3.8rem,7vw,7.5rem);font-weight:900;line-height:.9;letter-spacing:.01em;text-transform:uppercase;color:var(--white);margin-bottom:1.8rem;opacity:0;animation:fadeUp .8s .4s forwards}
h1.hero-title .gold{color:var(--gold)}
.hero-desc{font-size:1.1rem;line-height:1.8;font-weight:300;color:var(--muted);max-width:500px;margin-bottom:3rem;opacity:0;animation:fadeUp .8s .6s forwards}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:fadeUp .8s .8s forwards}
.hero-stats{display:flex;gap:4rem;margin-top:4.5rem;padding-top:2.5rem;border-top:1px solid var(--border);opacity:0;animation:fadeUp .8s 1s forwards}
.snum{font-family:'Barlow Condensed',sans-serif;font-size:3rem;font-weight:900;color:var(--gold);line-height:1}
.slbl{font-size:.65rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:.2rem}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:0;animation:fadeIn 1s 1.4s forwards}
.hero-scroll span{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3)}
.scroll-line{width:1px;height:36px;background:linear-gradient(to bottom,rgba(255,255,255,.3),transparent);animation:sp 2s ease-in-out infinite}
@keyframes sp{0%,100%{opacity:.3;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.3)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ── MARQUEE ── */
.mqwrap{background:var(--blue);padding:.9rem 0;overflow:hidden}
.mqtrack{display:flex;gap:2.5rem;animation:mq 24s linear infinite;white-space:nowrap}
.mqtrack span{font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.85)}
.mqtrack .dot{color:var(--gold);font-size:.55rem;vertical-align:middle}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── NOUVEAU LOCAL ── */
.nouveau-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.new-badge{display:inline-block;background:var(--gold);color:#0a0f1e;font-size:.65rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;padding:.35rem 1rem;border-radius:2px;margin-bottom:1.5rem}
.nouveau-desc{font-size:1rem;line-height:1.8;color:var(--muted);margin-bottom:2rem}
.nouveau-photos{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.nouveau-photos img{width:100%;height:210px;object-fit:cover;border-radius:4px;border:2px solid var(--border);transition:transform .3s,border-color .3s}
.nouveau-photos img:hover{transform:scale(1.03);border-color:var(--blue-l)}
.feat-list{display:flex;flex-direction:column;gap:1.2rem;margin-top:-2.5rem}
.feat{display:flex;gap:1rem;align-items:flex-start;padding:1.2rem 1.4rem;background:#fff;border-left:3px solid var(--blue-l);border-radius:0 6px 6px 0;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.feat-icon{font-size:1.3rem;flex-shrink:0}
.feat h4{font-size:.88rem;font-weight:700;margin-bottom:.2rem;color:var(--ink)}
.feat p{font-size:.8rem;color:var(--ink-m);line-height:1.55}

/* ── PRESTATIONS ── */
.pgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;background:transparent}
.pcard{background:#fff;overflow:hidden;transition:background .25s,box-shadow .25s;border:1px solid rgba(0,0,0,.07);box-shadow:0 2px 8px rgba(0,0,0,.05)}
.pcard:hover{background:#fff;box-shadow:0 12px 36px rgba(0,0,0,.1)}
.pcard-imgwrap{overflow:hidden}
.pcard-img{width:100%;height:190px;object-fit:cover;display:block;transition:transform .4s}
.pcard:hover .pcard-img{transform:scale(1.06)}
.pcard-body{padding:2rem 2rem 2.5rem}
.pcard-n{font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);margin-bottom:.6rem}
.pcard h3{font-family:'Barlow Condensed',sans-serif;font-size:1.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.6rem;color:var(--ink)}
.pcard p{font-size:.84rem;color:var(--ink-m);line-height:1.65}
.ptags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.3rem}
.ptag{font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.25rem .7rem;background:rgba(45,125,210,.1);color:var(--blue);border-radius:2px}
.pcard-full{grid-column:span 2;background:var(--dark);display:flex;align-items:center;justify-content:space-between;padding:2.5rem 3rem;gap:2rem}
.pcard-full h3{font-family:'Barlow Condensed',sans-serif;font-size:2rem;font-weight:900;text-transform:uppercase;margin:0}
.pcard-full p{font-size:.88rem;color:var(--muted);margin-top:.3rem}

/* ── TEXTILE ── */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;background:transparent;margin-top:3.5rem}
.tcard{background:#fff;overflow:hidden;transition:box-shadow .25s,transform .25s;border-radius:8px;border:1px solid rgba(0,0,0,.07);box-shadow:0 2px 8px rgba(0,0,0,.05)}
.tcard:hover{box-shadow:0 12px 32px rgba(0,0,0,.1);transform:translateY(-4px)}
.tcard img{width:100%;height:220px;object-fit:cover;display:block;transition:transform .4s}
.tcard:hover img{transform:scale(1.05)}
.tcard-body{padding:1.8rem}
.tcard h4{font-family:'Barlow Condensed',sans-serif;font-size:1.4rem;font-weight:800;text-transform:uppercase;margin-bottom:.5rem;color:var(--ink)}
.tcard p{font-size:.82rem;color:var(--ink-m);line-height:1.65}
.tchip{display:inline-block;margin-top:.9rem;font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.25rem .75rem;background:rgba(45,125,210,.1);color:var(--blue);border-radius:2px}

/* ── EPI ── */
.egrid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;background:transparent;margin-top:3.5rem}
.ecard{background:#fff;display:flex;gap:1.4rem;align-items:flex-start;padding:2rem;transition:box-shadow .25s;border-radius:8px;border:1px solid rgba(0,0,0,.07);box-shadow:0 2px 8px rgba(0,0,0,.04)}
.ecard:hover{box-shadow:0 10px 28px rgba(0,0,0,.1)}
.ecard img{width:100px;height:100px;object-fit:cover;border-radius:3px;flex-shrink:0;border:2px solid var(--border)}
.ecard h4{font-family:'Barlow Condensed',sans-serif;font-size:1.2rem;font-weight:800;text-transform:uppercase;margin-bottom:.5rem;color:var(--ink)}
.ecard ul{padding-left:1rem}
.ecard li{font-size:.8rem;color:var(--ink-m);line-height:1.7}

/* ── LOGOS CAROUSEL ── */
.logos-carousel{overflow:hidden;margin-top:3rem;position:relative}
.logos-track{display:flex;gap:2rem;width:max-content;align-items:center;margin-bottom:1.5rem}
.logos-track:hover{animation-play-state:paused}
.track-left{animation:slidelogos 30s linear infinite}
.track-right{animation:slidelogos2 25s linear infinite}
@keyframes slidelogos{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes slidelogos2{from{transform:translateX(-50%)}to{transform:translateX(0)}}
.logo-card{background:#fff;border:1px solid rgba(0,0,0,.07);border-radius:8px;padding:1.5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:.8rem;min-width:160px;box-shadow:0 2px 8px rgba(0,0,0,.04);transition:box-shadow .2s,transform .2s;flex-shrink:0}
.logo-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.1);transform:translateY(-3px)}
.logo-name{display:none}

/* ── TÉMOIGNAGES ── */
.temo-carousel{overflow:hidden;margin-top:3.5rem;position:relative}
.temo-track{display:flex;gap:1.5rem;animation:slide 40s linear infinite;width:max-content}
.temo-track:hover{animation-play-state:paused}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.temo{background:#fff;padding:2rem;position:relative;border:1px solid rgba(0,0,0,.07);box-shadow:0 2px 8px rgba(0,0,0,.04);border-radius:8px;width:360px;flex-shrink:0}
.temo-name{font-size:.88rem;font-weight:700;color:var(--ink)}
.temo-role{font-size:.72rem;color:var(--ink-l)}
.temo-txt{font-size:.9rem;line-height:1.8;color:var(--ink-m);font-style:italic;margin-bottom:2rem}
.qmark{font-family:'Barlow Condensed',sans-serif;font-size:4rem;line-height:.8;color:rgba(0,0,0,.06);margin-bottom:.5rem;font-weight:900}
.stars{display:flex;gap:.2rem;margin-bottom:1.2rem}
.stars span{font-size:.95rem;color:var(--gold)}
.temo-foot{display:flex;align-items:center;gap:.9rem}
.temo-av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:.95rem;color:white;flex-shrink:0}

/* ── ÉVÉNEMENTS ── */
.events-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;background:transparent;margin-top:3.5rem}
.ev-card{background:#fff;padding:2.5rem 2rem;transition:box-shadow .25s,transform .25s;position:relative;overflow:hidden;border-radius:8px;border:1px solid rgba(0,0,0,.07);border-top:3px solid var(--gold);box-shadow:0 2px 8px rgba(0,0,0,.04)}
.ev-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.ev-card:hover{box-shadow:0 12px 32px rgba(0,0,0,.1);transform:translateY(-4px)}
.ev-card:hover::before{transform:scaleX(1)}
.events-cta-band{background:var(--blue);margin-top:1.5rem;padding:2.5rem 3rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;border-radius:8px}

/* ── ÉQUIPE ── */
.equipe-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.equipe-photo{border-radius:8px;overflow:hidden;border:2px solid rgba(0,0,0,.08);margin-top:2.5rem;box-shadow:0 8px 32px rgba(0,0,0,.1)}
.equipe-photo img{width:100%;display:block}
.team-col{display:flex;flex-direction:column;gap:.6rem;background:transparent;margin-top:2rem}
.tmcard{background:var(--dark);display:flex;align-items:center;gap:1.4rem;padding:1.6rem 1.8rem;transition:background .25s;position:relative;overflow:hidden}
.tmcard:hover{background:var(--panel)}
.tmav{width:48px;height:48px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;border:2px solid rgba(45,125,210,.25)}
.tmcard h4{font-size:.92rem;font-weight:700;margin-bottom:.2rem;color:var(--ink)}
.tmcard p{font-size:.72rem;color:var(--blue);letter-spacing:.08em;text-transform:uppercase}
.tmcard-hover{position:absolute;inset:0;background:rgba(35,70,140,.92);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .25s;pointer-events:none}
.tmcard:hover .tmcard-hover{opacity:1}
.tmcard-hover span{color:#fff;font-size:.85rem;font-weight:600;letter-spacing:.04em}

/* ── DEVIS ── */
.devis-inner{display:grid;grid-template-columns:1fr 1.35fr;gap:6rem;align-items:start}
.devis-info{display:flex;flex-direction:column;gap:1.5rem;margin-top:2.5rem}
.drow{display:flex;gap:1rem;align-items:flex-start}
.dicon{width:44px;height:44px;border-radius:4px;background:rgba(45,125,210,.1);border:1px solid rgba(45,125,210,.2);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.drow h5{font-size:.82rem;font-weight:700;margin-bottom:.15rem;color:var(--ink)}
.drow p{font-size:.8rem;color:var(--ink-m)}
.fcard{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:10px;padding:3rem;box-shadow:0 8px 40px rgba(0,0,0,.07)}
.fsteps{display:flex;gap:.5rem;margin-bottom:2.5rem}
.fdot{flex:1;height:3px;border-radius:99px;background:rgba(0,0,0,.1);transition:background .3s}
.fdot.active{background:var(--blue-l)}
.fdot.done{background:var(--green)}
.fstep{display:none}
.fstep.active{display:block}
.fstep-lbl{font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);margin-bottom:.5rem}
.fstep h3{font-family:'Barlow Condensed',sans-serif;font-size:2rem;font-weight:900;text-transform:uppercase;letter-spacing:.02em;margin-bottom:2rem;color:var(--ink)}
.fstep h3 em{font-style:normal;color:var(--gold)}
.cgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}
.citem{position:relative}
.citem input{position:absolute;opacity:0;pointer-events:none}
.clabel{display:flex;align-items:center;gap:.8rem;padding:1rem 1.2rem;border:2px solid rgba(0,0,0,.1);border-radius:4px;cursor:pointer;font-size:.86rem;font-weight:500;transition:all .2s;user-select:none;color:var(--ink)}
.clabel:hover{border-color:var(--blue-l);background:rgba(45,125,210,.07)}
.citem input:checked+.clabel{border-color:var(--blue);background:rgba(45,125,210,.1);color:var(--blue);font-weight:700}
.cico{font-size:1.2rem}
.fgroup{display:flex;flex-direction:column;gap:1.2rem}
.field{display:flex;flex-direction:column;gap:.5rem}
.field label{font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#374151}
.field input,.field textarea,.field select{padding:.85rem 1.1rem;border:1px solid rgba(0,0,0,.12);border-radius:4px;font-family:'Nunito Sans',sans-serif;font-size:.9rem;color:var(--ink);background:#f9fafb;transition:border-color .2s;outline:none}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--blue-l);background:#fff}
.field textarea{resize:vertical;min-height:90px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fnav{display:flex;justify-content:space-between;align-items:center;margin-top:2rem}
.fbk{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--ink-m);cursor:pointer;background:none;border:none;font-family:inherit;transition:color .2s}
.fbk:hover{color:var(--ink)}
.fsuccess{display:none;text-align:center;padding:2.5rem 0}
.fsuccess .sico{font-size:3.5rem;margin-bottom:1rem}
.fsuccess h3{font-family:'Barlow Condensed',sans-serif;font-size:2.2rem;font-weight:900;text-transform:uppercase;margin-bottom:.8rem;color:var(--ink)}
.fsuccess p{color:var(--ink-m);font-size:.95rem;line-height:1.7}

/* ── CONTACT ── */
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.iblock{margin-bottom:2.3rem}
.iblock h4{font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);margin-bottom:.5rem}
.iblock p{font-size:.95rem;line-height:1.7;color:var(--ink)}
.mapbox{border-radius:8px;overflow:hidden;border:2px solid rgba(0,0,0,.08);height:340px;box-shadow:0 8px 32px rgba(0,0,0,.08)}
.mapbox iframe{width:100%;height:100%;border:none;display:block}

/* ── SOCIALS ── */
.socband{background:var(--blue);padding:3.5rem 7rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.socband h3{font-family:'Barlow Condensed',sans-serif;font-size:2.2rem;font-weight:900;text-transform:uppercase;margin-bottom:.3rem}
.socband p{font-size:.88rem;color:rgba(255,255,255,.65)}
.socbtns{display:flex;gap:1rem}
.socbtn{display:flex;align-items:center;gap:.7rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);padding:.85rem 1.6rem;border-radius:3px;color:white;font-size:.78rem;font-weight:600;letter-spacing:.06em;transition:background .2s}
.socbtn:hover{background:rgba(255,255,255,.22)}
.socbtn svg{width:18px;height:18px;fill:currentColor}

/* ── FOOTER ── */
footer{background:#05080f;padding:5rem 7rem 2.5rem;border-top:1px solid var(--border)}
.ftop{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:2rem;margin-bottom:4rem}
.fbrand img{height:38px;margin-bottom:1rem}
.fbrand-txt{font-family:'Barlow Condensed',sans-serif;font-size:1.5rem;font-weight:900;color:var(--white);margin-bottom:1rem;display:none}
.fbrand-txt span{color:var(--gold)}
.fbrand p{font-size:.83rem;color:rgba(255,255,255,.35);line-height:1.7}
.fcol h5{font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:1.2rem}
.fcol ul{list-style:none}
.fcol li{margin-bottom:.6rem}
.fcol a{color:rgba(255,255,255,.45);font-size:.84rem;transition:color .2s}
.fcol a:hover{color:var(--gold)}
.fbot{border-top:1px solid rgba(255,255,255,.06);padding-top:2rem;margin-top:2rem;display:flex;align-items:center;justify-content:space-between;width:100%}
.fbot p{font-size:.73rem;color:rgba(255,255,255,.18)}
.fbot a{color:rgba(255,255,255,.25)}
.fbot a:hover{color:var(--gold)}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .75s ease,transform .75s ease}
.reveal.visible{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.22s}.d3{transition-delay:.33s}.d4{transition-delay:.44s}

/* ── BURGER MOBILE ── */
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;z-index:350;background:none;border:none}
.burger span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:transform .3s,opacity .3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .burger{display:flex}
  .nav-links{position:fixed;top:0;right:-100%;width:280px;height:100vh;flex-direction:column;background:rgba(10,15,30,.98);padding:5rem 2rem 2rem;gap:1.5rem;transition:right .35s ease;z-index:340;box-shadow:-4px 0 30px rgba(0,0,0,.5)}
  .nav-links.open{right:0}
  .nav-links li{display:block!important}
  .nav-links a{font-size:.85rem;padding:.6rem 0;display:block}
  .nav-cta{text-align:center;margin-top:1rem}
  nav{padding:0 2rem}
  .sec{padding:5rem 2.5rem}
  #hero .hero-content{padding:9rem 2.5rem 5rem}
  .nouveau-inner,.equipe-inner,.devis-inner,.contact-inner{grid-template-columns:1fr;gap:3rem}
  .pgrid{grid-template-columns:1fr 1fr}
  .pcard-full{grid-column:span 2;flex-direction:column;align-items:flex-start}
  .tgrid,.temo-grid{grid-template-columns:1fr}
  .egrid,.events-grid{grid-template-columns:1fr}
  .logos-grid{grid-template-columns:repeat(3,1fr)}
  .logos-row2{grid-template-columns:repeat(2,1fr)}
  .team-col{margin-top:0}
  .ftop{grid-template-columns:1fr 1fr 1fr;gap:2rem}
  .socband{padding:3rem 2.5rem;flex-direction:column;align-items:flex-start}
  footer{padding:3rem 2.5rem 2rem}
  .cgrid{grid-template-columns:1fr}
  .events-cta-band{flex-direction:column;align-items:flex-start}
/* ═══════════════════════════════════════════════════════════════
   ALLIANCE PUB – RESPONSIVE MOBILE
   Remplace TOUT ce qui est après la fermeture } du @media(max-width:1100px)
   dans style.css
   ═══════════════════════════════════════════════════════════════ */

/* ── TABLETTE ── */
@media(max-width:900px){
  .hero-stats{gap:2.5rem}
  .pgrid{grid-template-columns:1fr}
  .events-grid{grid-template-columns:1fr 1fr}
  .ftop{grid-template-columns:1fr 1fr;gap:2rem}
  .fbrand{grid-column:span 2;margin-bottom:1rem}
}

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

  /* ── RESET PADDINGS ── */
  .sec{padding:3rem 1.2rem}
  footer{padding:2.5rem 1.2rem 1.5rem}

  /* ── TYPO ── */
  .display{font-size:clamp(1.6rem,7vw,2.4rem);line-height:1}
  .sub{font-size:.88rem;line-height:1.7}
  .label{font-size:.6rem;letter-spacing:.18em;margin-bottom:.6rem}
  .label::after{width:20px}
  .btn{font-size:.72rem;padding:.85rem 1.6rem;width:100%;text-align:center;display:block}

  /* ── NAV ── */
  nav{padding:0 1rem;height:58px}
  .logo img{height:30px}
  .burger span{width:22px}
  .nav-links{width:100%;right:-100%;padding:4.5rem 1.5rem 2rem}
  .nav-links.open{right:0}
  .nav-links a{font-size:.9rem;padding:.8rem 0;border-bottom:1px solid rgba(255,255,255,.06)}
  .nav-cta{margin-top:1.5rem;display:block;text-align:center;padding:.9rem 1.4rem;border-radius:6px}
  .dropdown{position:static;display:none;background:transparent;border:none;padding:0 0 0 1rem;min-width:auto}
  .nav-dropdown:hover .dropdown{display:block}
  .dropdown li a{padding:.6rem 0;font-size:.78rem;color:rgba(240,244,255,.4)}

  /* ── HERO ── */
  #hero{min-height:100vh;min-height:100svh}
  #hero .hero-content{padding:6.5rem 1.2rem 3rem;max-width:100%}
  h1.hero-title{font-size:clamp(2.2rem,11vw,3.5rem);margin-bottom:1.2rem;line-height:.88}
  .hero-desc{font-size:.92rem;line-height:1.7;margin-bottom:2rem;max-width:100%}
  .hero-desc br{display:none}
  .hero-btns{flex-direction:column;gap:.7rem}
  .hero-btns .btn{display:block;width:100%;text-align:center;padding:1rem}
  .hero-btns .btn-ghost{border-width:1.5px}
  .hero-stats{flex-wrap:wrap;gap:0;margin-top:2.5rem;padding-top:1.5rem;justify-content:space-between}
  .hero-stats > div{flex:1;min-width:45%;margin-bottom:1rem}
  .snum{font-size:2rem}
  .slbl{font-size:.58rem;letter-spacing:.1em}
  .hero-eyebrow span{font-size:.58rem;letter-spacing:.15em}
  .hero-dot{width:6px;height:6px}
  .hero-scroll{display:none}

  /* ── MARQUEE ── */
  .mqwrap{padding:.6rem 0}
  .mqtrack span{font-size:.75rem;letter-spacing:.1em}

  /* ── NOUVEAU LOCAL ── */
  .nouveau-inner{gap:2rem}
  .new-badge{font-size:.58rem;padding:.3rem .8rem;margin-bottom:1rem}
  .nouveau-photos{grid-template-columns:1fr 1fr;gap:.5rem}
  .nouveau-photos img{height:130px;border-radius:6px}
  .feat-list{margin-top:1.5rem;gap:.8rem}
  .feat{padding:.9rem 1rem;border-radius:0 8px 8px 0}
  .feat-icon{font-size:1.1rem}
  .feat h4{font-size:.8rem}
  .feat p{font-size:.72rem}

  /* ── TEXTILE ── */
  .tgrid{grid-template-columns:1fr;gap:.8rem;margin-top:2rem}
  .tcard{border-radius:10px;overflow:hidden}
  .tcard img{height:200px}
  .tcard-body{padding:1.3rem}
  .tcard h4{font-size:1.15rem;margin-bottom:.3rem}
  .tcard p{font-size:.78rem}
  .tchip{font-size:.58rem;padding:.2rem .6rem;margin-top:.6rem;margin-right:.3rem}

  /* ── CATALOGUE BANDEAU ── */
  .pcard-full{padding:1.5rem 1.2rem!important;flex-direction:column;align-items:stretch!important;gap:1rem;border-radius:10px!important;text-align:center}
  .pcard-full h3{font-size:1.2rem;text-align:center;width:100%}
  .pcard-full p{font-size:.78rem;text-align:center}
  .pcard-full .btn{margin:0 auto}

  /* ── PRESTATIONS ── */
  .pgrid{grid-template-columns:1fr;gap:.8rem}
  .pcard{border-radius:10px;overflow:hidden}
  .pcard-img{height:180px}
  .pcard-body{padding:1.3rem}
  .pcard h3{font-size:1.2rem}
  .pcard p{font-size:.78rem}
  .ptags{gap:.3rem;margin-top:.8rem}
  .ptag{font-size:.55rem;padding:.2rem .5rem}

  /* ── EPI ── */
  .egrid{grid-template-columns:1fr;gap:.8rem;margin-top:2rem}
  .ecard{flex-direction:column;gap:1rem;padding:1.2rem;border-radius:10px}
  .ecard img{width:100%;height:180px;border-radius:8px}
  .ecard h4{font-size:1.05rem}
  .ecard li{font-size:.76rem}

  /* ── LOGOS CAROUSEL ── */
  .logos-carousel{margin-top:2rem}
  .logos-track{gap:1rem;margin-bottom:1rem}
  .logo-card{min-width:110px;padding:.8rem 1rem;border-radius:6px}
  .logo-card img{height:36px!important}

  /* ── CONFIANCE HEADER ── */
  .conf-header{margin-bottom:2rem}
  .conf-header .display{font-size:clamp(1.5rem,6vw,2.2rem)}
  .conf-header .sub{font-size:.82rem}
  .conf-header br{display:none}

  /* ── TÉMOIGNAGES ── */
  .temo-carousel{margin-top:2rem}
  .temo{width:260px;padding:1.3rem;border-radius:10px}
  .temo-txt{font-size:.8rem;line-height:1.7;margin-bottom:1.2rem}
  .qmark{font-size:2.8rem;margin-bottom:.3rem}
  .stars span{font-size:.8rem}
  .temo-av{width:36px;height:36px;font-size:.8rem}
  .temo-name{font-size:.8rem}
  .temo-role{font-size:.65rem}

  /* ── ÉVÉNEMENTS ── */
  .events-grid{grid-template-columns:1fr;gap:.8rem;margin-top:2rem}
  .ev-card{padding:1.5rem 1.2rem;border-radius:10px}
  .ev-icon{font-size:2rem;margin-bottom:.8rem}
  .ev-card h4{font-size:1.1rem}
  .ev-card p{font-size:.76rem}
  .ev-tag{font-size:.55rem}
  .events-cta-band{padding:1.5rem 1.2rem;border-radius:8px;flex-direction:column;gap:1rem;text-align:center}
  .events-cta-band p{font-size:.85rem}

  /* ── ÉQUIPE ── */
  .equipe-inner{gap:2rem}
  .equipe-photo{margin-top:1rem;border-radius:10px}
  .team-col{gap:.4rem}
  .tmcard{padding:1rem 1.2rem;gap:1rem;border-radius:6px}
  .tmav{width:38px;height:38px;font-size:.95rem}
  .tmcard h4{font-size:.82rem}
  .tmcard p{font-size:.65rem}
  .tmcard-hover span{font-size:.72rem;text-align:center;padding:0 .8rem;line-height:1.5}

  /* ── DEVIS ── */
  .devis-inner{gap:2rem}
  .devis-info{margin-top:1.5rem;gap:1rem}
  .dicon{width:38px;height:38px;font-size:1rem}
  .drow h5{font-size:.78rem}
  .drow p{font-size:.75rem}
  .fcard{padding:1.5rem 1.2rem;border-radius:12px}
  .fsteps{margin-bottom:1.5rem}
  .fstep h3{font-size:1.4rem;margin-bottom:1.2rem}
  .fstep h3 em{display:inline}
  .fstep-lbl{font-size:.58rem}
  .cgrid{grid-template-columns:1fr;gap:.5rem}
  .clabel{padding:.75rem .9rem;font-size:.8rem;border-radius:6px;gap:.6rem}
  .cico{font-size:1rem}
  .fgroup{gap:.8rem}
  .field label{font-size:.7rem}
  .field input,.field textarea,.field select{padding:.7rem .9rem;font-size:.84rem;border-radius:6px}
  .frow{grid-template-columns:1fr;gap:.8rem}
  .fnav{margin-top:1.5rem}
  .fbk{font-size:.75rem}
  .fsuccess h3{font-size:1.6rem}
  .fsuccess .sico{font-size:2.8rem}
  .fsuccess p{font-size:.85rem}

  /* ── CONTACT ── */
  .contact-inner{gap:2rem}
  .iblock{margin-bottom:1.2rem}
  .iblock h4{font-size:.6rem;margin-bottom:.3rem}
  .iblock p{font-size:.85rem}
  .mapbox{height:220px;border-radius:10px}

  /* ── SOCIALS ── */
  .socband{padding:2.5rem 1.2rem;flex-direction:column;gap:1.2rem;text-align:center;align-items:center}
  .socband h3{font-size:1.4rem}
  .socband p{font-size:.78rem}
  .socbtns{flex-direction:column;gap:.5rem;width:100%}
  .socbtn{justify-content:center;padding:.75rem 1rem;border-radius:6px;font-size:.72rem}
  .socbtn svg{width:16px;height:16px}

  /* ── FOOTER ── */
  footer > div:first-child{grid-template-columns:1fr!important;gap:.6rem;margin-bottom:1.5rem;padding-bottom:1.5rem}
  footer > div:first-child > div{flex-direction:row!important;padding:1rem!important;border-radius:8px!important;gap:.8rem!important}
  footer > div:first-child > div > div:first-child{font-size:1.1rem!important}
  footer > div:first-child p{margin:0}
  .ftop{grid-template-columns:1fr 1fr;gap:1.5rem 1rem}
  .fbrand{grid-column:span 2;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:.5rem}
  .fbrand img{height:30px}
  .fbrand p{font-size:.75rem;line-height:1.6}
  .fcol h5{font-size:.58rem;margin-bottom:.8rem}
  .fcol a{font-size:.78rem}
  .fcol li{margin-bottom:.4rem}
  .fbot{flex-direction:column;gap:.6rem;text-align:center;padding-top:1.5rem}
  .fbot p{font-size:.65rem}
  .fbot a{font-size:.65rem}
  .fbot div{display:flex;gap:1.5rem;justify-content:center}

  /* ── WIDGET AIDE ── */
  #aide-btn{width:52px!important;height:52px!important;bottom:1rem!important;right:1rem!important;box-shadow:0 4px 14px rgba(35,70,140,.4)!important}
  #aide-btn span:first-child{font-size:1rem!important}
  #aide-btn span:last-child{font-size:.55rem!important}
  #aide-popup{width:calc(100vw - 1.5rem)!important;right:.75rem!important;bottom:4.5rem!important;max-height:75vh!important;border-radius:14px!important}
}

/* ── PETIT MOBILE (iPhone SE, etc.) ── */
@media(max-width:390px){
  .sec{padding:2.5rem 1rem}
  #hero .hero-content{padding:5.5rem 1rem 2.5rem}
  h1.hero-title{font-size:2rem;line-height:.85}
  .hero-desc{font-size:.85rem}
  .hero-stats{flex-direction:column;gap:.6rem;align-items:flex-start}
  .hero-stats > div{min-width:100%}
  .display{font-size:clamp(1.4rem,6vw,2rem)}
  .ftop{grid-template-columns:1fr}
  .fbrand{grid-column:span 1}
  .fcard{padding:1.2rem .9rem}
  .fstep h3{font-size:1.2rem}
  .clabel{padding:.65rem .8rem;font-size:.76rem}
  .socband h3{font-size:1.2rem}
  .nouveau-photos{grid-template-columns:1fr}
  .nouveau-photos img{height:180px}
  .temo{width:240px;padding:1.1rem}
  .pcard-full h3{font-size:1.1rem}
  .tmcard{flex-direction:column;text-align:center;padding:1rem}
  .tmav{margin:0 auto}
  .equipe-photo{border-radius:8px}
  .events-cta-band .btn{width:100%;display:block}
  footer{padding:2rem 1rem 1rem}
}
}

/* ── TWEMOJI ── */
img.twemoji{height:1.2em;width:1.2em;vertical-align:-.15em;display:inline-block}
.cico img.twemoji{height:1.4em;width:1.4em}
.feat-icon img.twemoji{height:1.5em;width:1.5em}


/* ═══════════════════════════════════════════
   PAGES PRESTATIONS (Broderie, DTF, Patch)
   ═══════════════════════════════════════════ */

/* ── HERO PRESTATION ── */
.brod-hero{background:var(--dark);position:relative;overflow:hidden;padding:9rem 7rem 5rem}
.brod-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(35,70,140,.95),rgba(13,26,56,.85))}
.brod-hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:72px 72px}
.brod-hero-img{position:absolute;right:0;top:0;bottom:0;width:45%;object-fit:cover;opacity:.25;filter:saturate(.6)}
.brod-hero-content{position:relative;z-index:2;max-width:680px}

/* ── AVANTAGES ── */
.avantages-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.av-card{background:#fff;border:1px solid rgba(0,0,0,.07);border-radius:10px;padding:2rem;box-shadow:0 2px 8px rgba(0,0,0,.05);transition:transform .25s,box-shadow .25s;border-top:3px solid var(--blue)}
.av-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.1)}
.av-icon{font-size:2.2rem;margin-bottom:1rem}
.av-card h4{font-family:'Barlow Condensed',sans-serif;font-size:1.2rem;font-weight:800;text-transform:uppercase;color:var(--ink);margin-bottom:.5rem}
.av-card p{font-size:.85rem;color:var(--ink-m);line-height:1.65}

/* ── PROCESSUS ── */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:3rem;counter-reset:step}
.process-card{background:#fff;border:1px solid rgba(0,0,0,.07);border-radius:10px;padding:2rem;text-align:center;position:relative;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.process-num{width:40px;height:40px;background:var(--blue);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:1.2rem;margin:0 auto 1rem}
.process-card h4{font-family:'Barlow Condensed',sans-serif;font-size:1.1rem;font-weight:800;text-transform:uppercase;color:var(--ink);margin-bottom:.5rem}
.process-card p{font-size:.82rem;color:var(--ink-m);line-height:1.6}

/* ── APPLICATIONS ── */
.appli-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:3rem}
.appli-card{background:var(--cream);border:1px solid rgba(0,0,0,.07);border-radius:8px;padding:1.5rem;text-align:center;transition:background .2s}
.appli-card:hover{background:#fff}
.appli-card .ico{font-size:2rem;margin-bottom:.8rem}
.appli-card p{font-size:.82rem;font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.04em}

/* ── ENTRETIEN ── */
.entretien-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:2rem}
.entretien-card{padding:1.5rem 2rem;border-radius:8px;display:flex;align-items:center;gap:1rem}
.entretien-ok{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.2)}
.entretien-nok{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.15)}
.entretien-card .ico{font-size:1.8rem;flex-shrink:0}
.entretien-card p{font-size:.85rem;font-weight:600;color:var(--ink);line-height:1.5}
.entretien-card span{font-size:.75rem;color:var(--ink-m)}

/* ── CTA BAND ── */
.cta-band{background:var(--blue);padding:5rem 7rem;display:flex;align-items:center;justify-content:space-between;gap:3rem}
.cta-band h2{font-family:'Barlow Condensed',sans-serif;font-size:clamp(2rem,3vw,3rem);font-weight:900;text-transform:uppercase;color:#fff;margin-bottom:.5rem}
.cta-band p{color:rgba(255,255,255,.65);font-size:.95rem}

/* ── TABLEAU COMPARATIF ── */
.compare-table{width:100%;border-collapse:collapse;margin-top:2rem}
.compare-table th{background:var(--blue);color:#fff;padding:1rem 1.5rem;font-family:'Barlow Condensed',sans-serif;font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;text-align:left}
.compare-table td{padding:1rem 1.5rem;border-bottom:1px solid rgba(0,0,0,.06);font-size:.88rem;color:var(--ink-m)}
.compare-table tr:nth-child(even) td{background:var(--cream)}
.compare-table tr:hover td{background:rgba(35,70,140,.05)}
.compare-table td:first-child{font-weight:700;color:var(--ink)}
.check{color:#22c55e;font-size:1.1rem}
.cross{color:#ef4444;font-size:1.1rem}

/* ── RESPONSIVE PRESTATIONS ── */
@media(max-width:1100px){
  .brod-hero{padding:8rem 2.5rem 4rem}
  .brod-hero-img{display:none}
  .avantages-grid,.process-grid{grid-template-columns:1fr 1fr}
  .appli-grid{grid-template-columns:repeat(2,1fr)}
  .entretien-grid{grid-template-columns:1fr}
  .cta-band{padding:4rem 2.5rem;flex-direction:column;align-items:flex-start}
}
@media(max-width:768px){
  .brod-hero{padding:6.5rem 1.2rem 3rem}
  .avantages-grid,.process-grid,.appli-grid{grid-template-columns:1fr}
  .cta-band{padding:3rem 1.2rem}
  .cta-band h2{font-size:1.6rem}
  .compare-table th,.compare-table td{padding:.7rem .8rem;font-size:.78rem}
}

/* ── HERO DTF ── */
.dtf-hero{background:var(--dark);position:relative;overflow:hidden;padding:9rem 7rem 5rem}
.dtf-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(35,70,140,.95),rgba(13,26,56,.85))}
.dtf-hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:72px 72px}
.dtf-hero-img{position:absolute;right:0;top:0;bottom:0;width:45%;object-fit:cover;opacity:.25;filter:saturate(.6)}
.dtf-hero-content{position:relative;z-index:2;max-width:680px}

/* ── HERO PATCH SILICONE ── */
.patch-hero{background:var(--dark);position:relative;overflow:hidden;padding:9rem 7rem 5rem}
.patch-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(35,70,140,.95),rgba(13,26,56,.85))}
.patch-hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:72px 72px}
.patch-hero-img{position:absolute;right:0;top:0;bottom:0;width:45%;object-fit:cover;opacity:.25;filter:saturate(.6)}
.patch-hero-content{position:relative;z-index:2;max-width:680px}

/* ── RESPONSIVE DTF & PATCH ── */
@media(max-width:1100px){
  .dtf-hero,.patch-hero{padding:8rem 2.5rem 4rem}
  .dtf-hero-img,.patch-hero-img{display:none}
}
@media(max-width:768px){
  .dtf-hero,.patch-hero{padding:6.5rem 1.2rem 3rem}
}