/* ============================================================
   Visit Maghreb Agency — Unified Tour List + Page CSS
   v2026.05 — Mobile-first, fluid, Core Web Vitals optimised
   Extracted from the canonical DE/EN/FR/ES/IT tour template.
   Keep ABOVE-THE-FOLD critical CSS inlined in each HTML file.
   This file contains all non-critical rules (lazy stylesheet).
============================================================ */

:root{
 --o:#F07820;--od:#C85E10;--ol:#FEF0E4;--om:#FDCF9C;
 --g:#B07A00;--gl:#FFF6E0;
 --navy:#0F1923;--page:#F8F3EE;--card:#fff;--muted:#F3EDE6;
 --t1:#1A1008;--t2:#4A3218;--t3:#6B4F33;
 --ton:#EDD8C0;--tonm:#C4A07A;
 --bs:#E8DAC8;--bm:#D4C0A4;
 --ok:#1E6B3A;--no:#B02A1A;
 --r4:4px;--r8:8px;--r12:12px;--r50:50px;
 --s1:0 2px 10px rgba(26,16,8,.09);--s2:0 4px 22px rgba(26,16,8,.14);
 --fh:'Playfair Display',Georgia,serif;--fb:'Inter',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--fb);color:var(--t1);background:var(--page);line-height:1.75;-webkit-font-smoothing:antialiased;-webkit-user-select:none;-moz-user-select:none;user-select:none}
input,textarea,select{-webkit-user-select:text;user-select:text}
img{max-width:100%;height:auto;display:block}
a{color:var(--o);text-decoration:none}
a:hover{color:var(--od)}
strong{font-weight:600}
ul,ol{list-style:none}
.skip{position:absolute;left:-9999px;top:6px;background:var(--o);color:#fff;padding:8px 18px;border-radius:var(--r4);font-weight:600;z-index:9999}
.skip:focus{left:6px}
.sr{position:absolute;width:1px;height:1px;left:-9999px;overflow:hidden}
h1{font-family:var(--fh);font-size:clamp(1.75rem,5vw,2.8rem);font-weight:700;line-height:1.2;color:var(--t1)}
h2{font-family:var(--fh);font-size:clamp(1.3rem,3.5vw,1.8rem);font-weight:700;line-height:1.25;color:var(--t1)}
h3{font-family:var(--fh);font-size:clamp(1rem,2.5vw,1.2rem);font-weight:600;line-height:1.3;color:var(--t1)}
p{font-size:1rem;margin-bottom:.9em;color:var(--t1)}
p:last-child{margin-bottom:0}
hr.div{border:none;border-top:1px solid var(--bs);margin:28px 0}
.sec-ttl{font-size:clamp(1.25rem,3.5vw,1.75rem);padding-bottom:8px;border-bottom:3px solid var(--o);display:inline-block;margin-bottom:18px}
.hdr{position:sticky;top:0;z-index:900;background:var(--navy);border-bottom:2px solid var(--o)}
.hdr-in{display:flex;align-items:center;justify-content:space-between;gap:10px;height:58px;min-height:58px;max-width:1200px;margin:0 auto;padding:0 16px}
.logo{font-family:var(--fh);font-size:1.15rem;font-weight:700;color:#fff;line-height:1.1;white-space:nowrap}
.logo small{display:block;font-size:.55rem;font-style:normal;font-family:var(--fb);font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--o)}
.logo:hover{text-decoration:none;color:#fff}
.dnav{display:flex;align-items:center;gap:2px}
.dnav a{display:block;padding:7px 10px;color:var(--ton);font-size:.8rem;font-weight:500;border-radius:var(--r4);transition:.2s}
.dnav a:hover{background:rgba(240,120,32,.22);color:#fff;text-decoration:none}
.dnav.cta{background:var(--o);color:#fff;padding:8px 16px;border-radius:var(--r50);font-weight:700;margin-left:5px}
.dnav.cta:hover{background:var(--od)}
.lbar{display:flex;gap:4px}
.lbar a{font-size:.66rem;font-weight:600;color:var(--tonm);padding:3px 7px;border:1px solid rgba(255,255,255,.14);border-radius:3px;transition:.2s}
.lbar a:hover,.lbar a[aria-current]{background:var(--o);color:#fff;border-color:var(--o);text-decoration:none}
.ham{display:none;background:none;border:none;cursor:pointer;padding:8px;color:#fff;font-size:1.25rem;line-height:1;min-width:44px;min-height:44px;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;flex-shrink:0}
.mnav{display:none;position:fixed;inset:58px 0 0;background:var(--navy);z-index:800;overflow-y:auto;overflow-x:hidden;padding:12px 12px 80px;flex-direction:column;gap:3px;-webkit-overflow-scrolling:touch}
.mnav.open{display:flex!important;visibility:visible}
.mnav a{display:block;padding:13px 14px;color:var(--ton);font-size:.93rem;font-weight:500;border-radius:var(--r8);border-bottom:1px solid rgba(255,255,255,.07);transition:.2s;min-height:44px}
.mnav a:hover{background:rgba(240,120,32,.2);text-decoration:none}
.mnav.mcta-link,.mnav a.mcta-link{background:var(--o);color:#fff;text-align:center;font-weight:700;margin-top:10px;border-radius:var(--r50)}
.mlang{display:flex;gap:7px;padding:12px 4px 0;flex-wrap:wrap}
.mlang a{font-size:.71rem;font-weight:600;color:var(--tonm);padding:8px 12px;border:1px solid rgba(255,255,255,.17);border-radius:3px;min-height:44px;display:inline-flex;align-items:center}
.mlang a:hover{background:var(--o);color:#fff;border-color:var(--o);text-decoration:none}
@media(max-width:860px){.ham{display:flex!important}.dnav,.lbar{display:none!important}}
.hero{background:var(--o);padding:42px 16px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(140deg,rgba(0,0,0,.26) 0%,rgba(0,0,0,.04) 55%,transparent 100%);pointer-events:none}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:28px;background:linear-gradient(to bottom,transparent,var(--page));pointer-events:none}
.hero-in{max-width:760px;margin:0 auto;text-align:center;position:relative;padding-bottom:14px}
.eyebrow{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.4);color:#fff;font-size:.73rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 14px;border-radius:var(--r50);margin-bottom:15px}
.hero h1{color:#fff;margin-bottom:12px;text-shadow:0 2px 12px rgba(0,0,0,.28)}
.hero-sub{font-size:.98rem;color:rgba(255,255,255,.92);max-width:600px;margin:0 auto 20px}
.pills{display:flex;flex-wrap:wrap;justify-content:center;gap:7px;margin-bottom:22px}
.pill{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.35);color:#fff;font-size:.76rem;font-weight:500;padding:5px 11px;border-radius:var(--r50)}
.pill i{font-size:.69rem;width:12px;display:inline-block;text-align:center}
.hbtns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--fb);font-weight:700;font-size:.9rem;padding:12px 24px;border-radius:var(--r50);text-decoration:none;transition:.2s;border:none;cursor:pointer;line-height:1;min-height:44px;touch-action:manipulation}
.btn-white{background:#fff;color:var(--o)}.btn-white:hover{background:#FEF4EC;color:var(--od);text-decoration:none}
.btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.6)}.btn-outline:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff;text-decoration:none}
.bc-bar{background:var(--card);border-bottom:1px solid var(--bs)}
.bc{display:flex;flex-wrap:wrap;gap:4px;padding:9px 16px;max-width:1200px;margin:0 auto;font-size:.73rem}
.bc li{display:flex;align-items:center;gap:4px;color:var(--t2)}
.bc li+li::before{content:'/';color:var(--bm)}
.bc a{color:var(--t2)}.bc a:hover{color:var(--o)}
.bc [aria-current]{color:var(--o);font-weight:600}
.tbar{background:var(--gl);border-bottom:1px solid #EFD88A;contain:layout paint}
.tbar-in{max-width:1200px;margin:0 auto;padding:10px 16px;display:flex;flex-wrap:wrap;gap:10px 20px;justify-content:center;align-items:center}
.ti{display:flex;align-items:center;gap:6px;font-size:.77rem;font-weight:500;color:var(--t2);white-space:nowrap}
.ti i{color:var(--g);font-size:.82rem;width:14px;display:inline-block;text-align:center}
.stars{color:var(--g);letter-spacing:-1px;font-size:.85rem}
.ti a{color:var(--o);font-weight:700}.ti a:hover{text-decoration:underline}
@media(max-width:600px){.ti-opt{display:none}}
.stats-bar{background:var(--o);padding:16px;contain:layout paint}
.stats-in{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:12px;text-align:center}
@media(max-width:540px){.stats-in{grid-template-columns:repeat(2,1fr)}}
.stat-item{color:#fff}
.stat-val{font-family:var(--fh);font-size:1.5rem;font-weight:700;line-height:1;display:block}
.stat-lbl{font-size:.72rem;opacity:.88;margin-top:2px;display:block}
.pgrid{max-width:1200px;margin:0 auto;padding:32px 16px;display:grid;grid-template-columns:1fr 304px;gap:26px;align-items:start}
@media(max-width:900px){.pgrid{grid-template-columns:1fr}.sidebar{order:2}}
.card{background:var(--card);border:1px solid var(--bs);border-radius:var(--r12);padding:20px;box-shadow:var(--s1);margin-bottom:16px}
.card:last-child{margin-bottom:0}
.gal-hero{position:relative;border-radius:var(--r12);overflow:hidden;margin-bottom:11px;cursor:pointer;aspect-ratio:800/530;background:var(--muted)}
.gal-hero img{width:100%;height:100%;object-fit:cover;transition:transform .4s;display:block}
.gal-hero:hover img{transform:scale(1.03)}
@media(max-width:600px){.gal-hero{aspect-ratio:4/3;max-height:240px}}
.gal-cap{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(15,25,35,.82));padding:20px 16px 12px;color:#fff;font-size:.83rem;font-weight:500;pointer-events:none}
.gal-cap strong{display:block;font-size:.97rem;font-family:var(--fh)}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px}
@media(max-width:640px){.gal-grid{grid-template-columns:repeat(2,1fr)}}
.gal-th{position:relative;border-radius:var(--r8);overflow:hidden;cursor:pointer;aspect-ratio:4/3;background:var(--muted);min-height:44px}
.gal-th img{width:100%;height:100%;object-fit:cover;transition:transform .32s;display:block}
.gal-th:hover img{transform:scale(1.07)}
.gal-th-cap{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(15,25,35,.75));padding:16px 8px 6px;color:#fff;font-size:.68rem;font-weight:500;pointer-events:none;opacity:0;transition:opacity .3s}
.gal-th:hover .gal-th-cap{opacity:1}
.gal-note{font-size:.76rem;color:var(--t3);margin-top:7px;text-align:center}
.lb{display:none;position:fixed;inset:0;background:rgba(5,10,15,.95);z-index:9000;align-items:center;justify-content:center;padding:14px}
.lb.open{display:flex}
.lb-in{position:relative;max-width:880px;width:100%;text-align:center}
.lb-in img{max-width:100%;max-height:82vh;object-fit:contain;border-radius:var(--r8);width:100%;height:auto}
.lb-cap{color:rgba(255,255,255,.8);font-size:.83rem;margin-top:9px}
.lb-x{position:absolute;top:-38px;right:0;background:none;border:none;color:#fff;font-size:1.7rem;cursor:pointer;padding:4px 8px;line-height:1;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
.lb-p,.lb-n{position:absolute;top:50%;transform:translateY(-50%);background:rgba(240,120,32,.88);border:none;color:#fff;font-size:1.1rem;padding:11px 13px;cursor:pointer;border-radius:var(--r4);transition:.2s;z-index:1;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;touch-action:manipulation}
.lb-p{left:-46px}.lb-n{right:-46px}
.lb-p:hover,.lb-n:hover{background:var(--o)}
@media(max-width:680px){.lb-p{left:0}.lb-n{right:0}}
.prose p{font-size:.97rem;line-height:1.78;color:var(--t1);margin-bottom:.9em}
.hl-list{padding:0}
.hl-item{display:flex;gap:12px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--bs)}
.hl-item:last-child{border-bottom:none}
.hldot{width:30px;height:30px;flex-shrink:0;border-radius:50%;background:var(--o);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.72rem;margin-top:4px}
.hl-text strong{display:block;margin-bottom:2px;font-size:.9rem}
.hl-text p{font-size:.82rem;color:var(--t2);margin:0}
.dayd{background:var(--card);border:1px solid var(--bs);border-radius:var(--r8);margin-bottom:10px;overflow:hidden}
.dsum{display:flex;align-items:center;gap:11px;padding:13px 16px;cursor:pointer;background:var(--navy);list-style:none;user-select:none;touch-action:manipulation;min-height:44px}
.dsum::-webkit-details-marker{display:none}
.dnum{width:33px;height:33px;flex-shrink:0;border-radius:50%;background:var(--o);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:.96rem;font-weight:700}
.dinfo{flex:1;min-width:0}
.dtitle{color:#fff;font-family:var(--fh);font-size:.93rem;line-height:1.3}
.dmeta{color:#D4B896;font-size:.67rem;margin-top:2px}
.dtog{color:var(--tonm);font-size:.75rem;flex-shrink:0;transition:transform .28s}
details[open] .dtog{transform:rotate(180deg)}
.dbody{padding:16px;contain:layout style}
.dbody p{font-size:.92rem;margin-bottom:10px;line-height:1.75}
.dbody p:last-child{margin-bottom:0}
.srow{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-top:16px}
@media(max-width:500px){.srow{grid-template-columns:1fr}}
.sbox{border-radius:var(--r8);padding:13px;font-size:.82rem}
.sbox.winter{background:#EBF4FB;border:1px solid #B8D8EE}
.sbox.summer{background:#FFF6E0;border:1px solid #EDD278}
.sbox strong{display:block;font-size:.87rem;margin-bottom:4px;font-family:var(--fb)}
.pcrow{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:11px;margin-bottom:17px}
.pc{background:var(--card);border:1px solid var(--bs);border-radius:var(--r12);padding:18px 14px;position:relative;transition:.2s}
.pc:hover{box-shadow:var(--s2)}
.pc.pop{border:2px solid var(--o);box-shadow:var(--s2)}
.pbadge{position:absolute;top:-9px;left:50%;transform:translateX(-50%);background:var(--o);color:#fff;font-size:.65rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 11px;border-radius:var(--r50);white-space:nowrap}
.pc h3{font-size:.87rem;font-family:var(--fb);margin-bottom:4px}
.pcp{font-family:var(--fh);font-size:1.9rem;font-weight:700;color:var(--o);line-height:1;margin-bottom:2px}
.pcp sub{font-size:.77rem;font-family:var(--fb);color:var(--t2);font-weight:400}
.pcd{font-size:.75rem;color:var(--t2);margin-bottom:11px}
.pc ul{font-size:.78rem;margin-bottom:12px}
.pc ul li{padding:3px 0;display:flex;gap:6px;border-bottom:1px solid var(--muted)}
.pc ul li:last-child{border-bottom:none}
.chk{color:var(--ok);flex-shrink:0;font-size:.75rem;margin-top:2px}
.pcbtn{display:block;text-align:center;padding:10px;border-radius:var(--r50);font-size:.82rem;font-weight:700;background:var(--o);color:#fff;transition:.2s;min-height:44px;touch-action:manipulation}
.pcbtn:hover{background:var(--od);color:#fff;text-decoration:none}
.pcbtn.out{background:transparent;color:var(--o);border:2px solid var(--o)}
.pcbtn.out:hover{background:var(--o);color:#fff}
.ptbl{width:100%;border-collapse:collapse;font-size:.84rem;margin-bottom:18px;border-radius:var(--r8);overflow:hidden;border:1px solid var(--bs)}
.ptbl thead th{background:var(--navy);color:var(--ton);padding:10px 12px;text-align:left;font-size:.76rem;font-weight:600;letter-spacing:.02em}
.ptbl tbody td{padding:10px 12px;border-bottom:1px solid var(--bs);vertical-align:top}
.ptbl tbody tr:last-child td{border-bottom:none}
.ptbl tbody tr:nth-child(even){background:var(--muted)}
.incgrid{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:17px}
@media(max-width:500px){.incgrid{grid-template-columns:1fr}}
.ibox{background:var(--muted);border-radius:var(--r8);padding:14px}
.ibox h4{font-size:.84rem;font-family:var(--fb);margin-bottom:8px}
.ibox ul{font-size:.79rem}
.ibox ul li{padding:4px 0;display:flex;gap:6px;align-items:flex-start;border-bottom:1px solid var(--bs)}
.ibox ul li:last-child{border-bottom:none}
.iy{color:var(--ok);flex-shrink:0;font-size:.75rem;margin-top:2px}
.in_{color:var(--no);flex-shrink:0;font-size:.75rem;margin-top:2px}
.dtbl{width:100%;border-collapse:collapse;font-size:.82rem;background:var(--card);border-radius:var(--r8);overflow:hidden;border:1px solid var(--bs)}
.dtbl thead th{background:var(--navy);color:var(--ton);padding:9px 11px;text-align:left;font-size:.75rem;font-weight:600;letter-spacing:.02em}
.dtbl tbody td{padding:9px 11px;border-bottom:1px solid var(--bs);vertical-align:top}
.dtbl tbody tr:last-child td{border-bottom:none}
.dtbl tbody tr:nth-child(even){background:var(--muted)}
.cmpbox{background:var(--card);border:1px solid var(--bs);border-radius:var(--r12);padding:20px;margin-bottom:17px}
.cmpcols{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-top:11px}
@media(max-width:480px){.cmpcols{grid-template-columns:1fr}}
.cmpc{border-radius:var(--r8);padding:12px}
.cwin{background:#EDFAF3;border:1px solid #9FD4B6}
.clos{background:var(--muted);border:1px solid var(--bs);opacity:.82}
.cmpc h4{font-size:.84rem;font-family:var(--fb);margin-bottom:8px;font-weight:600}
.cmpc ul{font-size:.8rem}
.cmpc ul li{padding:3px 0;display:flex;gap:6px}
.rvgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:11px}
.rvc{background:var(--card);border:1px solid var(--bs);border-radius:var(--r8);padding:16px;transition:box-shadow .2s}
.rvc:hover{box-shadow:var(--s2)}
.rvs{color:var(--g);font-size:.85rem;letter-spacing:1px;margin-bottom:8px}
.rvt{font-size:.82rem;color:var(--t2);font-style:italic;margin-bottom:10px;line-height:1.55}
.rvm{font-size:.73rem;font-weight:600;display:flex;justify-content:space-between;flex-wrap:wrap;gap:3px}
.rvg{color:var(--o)}.rvp{color:var(--t3)}
.rvcta{background:var(--ol);border:1px solid var(--om);border-radius:var(--r8);padding:15px;text-align:center;margin-top:11px}
.rvcta p{font-size:.84rem;margin-bottom:6px}
.adgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:9px}
.adc{background:var(--card);border:1px solid var(--bs);border-radius:var(--r8);padding:13px;text-align:center;transition:border-color .2s}
.adc:hover{border-color:var(--om)}
.adi{font-size:1.3rem;margin-bottom:6px}
.adc strong{display:block;font-size:.79rem;font-family:var(--fb);margin-bottom:2px}
.adc p{font-size:.73rem;color:var(--t2);margin:0}
.relgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:9px}
.relc{display:block;background:var(--card);border:1px solid var(--bs);border-radius:var(--r8);padding:13px;color:var(--t1);transition:.2s}
.relc:hover{box-shadow:var(--s2);transform:translateY(-2px);border-color:var(--o);text-decoration:none;color:var(--t1)}
.reld{font-size:.67rem;color:var(--o);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}
.relc strong{display:block;font-size:.85rem;font-family:var(--fh);margin-bottom:2px}
.relc p{font-size:.75rem;color:var(--t2);margin:0}
.fqi{background:var(--card);border:1px solid var(--bs);border-radius:var(--r8);margin-bottom:7px;overflow:hidden}
.fqi summary{padding:13px 15px;font-weight:600;font-size:.89rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:10px;user-select:none;transition:background .2s;min-height:44px;touch-action:manipulation}
.fqi summary::-webkit-details-marker{display:none}
.fqi summary::after{content:'+';font-size:1.2rem;color:var(--o);flex-shrink:0;line-height:1}
.fqi[open] summary::after{content:'\2212'}
.fqi[open] summary{border-bottom:1px solid var(--bs);background:var(--ol)}
.fqb{padding:12px 15px;font-size:.86rem;line-height:1.72;color:var(--t2)}
.tip-box{background:var(--gl);border:1px solid #EDD278;border-radius:var(--r8);padding:14px 16px;font-size:.87rem;color:var(--t2);margin:14px 0}
.tip-box strong{color:var(--t1)}
.sidebar{position:sticky;top:70px}
.expc{background:var(--navy);border-radius:var(--r12);padding:18px;margin-bottom:12px;text-align:center;border:2px solid var(--o)}
.exav{width:60px;height:60px;border-radius:50%;background:var(--o);margin:0 auto 8px;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:1.65rem;font-weight:700;color:#fff}
.exname{font-family:var(--fh);font-size:1rem;color:#fff;margin-bottom:1px}
.exrole{font-size:.72rem;color:#D4B896;margin-bottom:8px}
.exq{font-size:.77rem;color:rgba(237,216,192,.88);line-height:1.5;font-style:italic;margin-bottom:11px}
.exst{display:flex;justify-content:center;gap:16px;padding-top:9px;border-top:1px solid rgba(255,255,255,.1)}
.exs{text-align:center}
.exs strong{display:block;font-size:1.02rem;color:var(--o);font-family:var(--fh)}
.exs span{font-size:.65rem;color:#D4B896}
.bkcard{background:var(--card);border:1px solid var(--bs);border-radius:var(--r12);padding:18px;box-shadow:var(--s2);margin-bottom:12px}
.bkfrom{font-family:var(--fh);font-size:1.88rem;color:var(--o);font-weight:700;line-height:1}
.bkfrom sub{font-size:.77rem;font-family:var(--fb);color:var(--t2);font-weight:400}
.bknote{font-size:.71rem;color:var(--t2);margin:3px 0 11px}
.bkopts{display:flex;flex-direction:column;gap:7px;margin-bottom:11px}
.bko{display:flex;align-items:center;gap:10px;padding:10px 11px;border:1px solid var(--bs);border-radius:var(--r8);text-decoration:none;color:var(--t1);transition:.2s;background:var(--card);min-height:44px;touch-action:manipulation}
.bko:hover{border-color:var(--o);background:var(--ol);text-decoration:none;color:var(--t1)}
.bkoic{font-size:1.05rem;flex-shrink:0;width:24px;text-align:center}
.bkotxt strong{display:block;font-size:.8rem;font-family:var(--fb);font-weight:600}
.bkotxt span{font-size:.69rem;color:var(--t2)}
.bkop{margin-left:auto;font-weight:700;color:var(--o);font-size:.82rem;white-space:nowrap}
.bknow{display:block;text-align:center;background:var(--o);color:#fff;font-weight:700;font-size:.95rem;padding:13px;border-radius:var(--r50);margin-bottom:8px;transition:.2s;min-height:44px;touch-action:manipulation}
.bknow:hover{background:var(--od);color:#fff;text-decoration:none;transform:translateY(-1px)}
.wabtn{display:flex;align-items:center;justify-content:center;gap:8px;background:#25D366;color:#fff;font-weight:700;font-size:.87rem;padding:11px;border-radius:var(--r50);transition:.2s;min-height:44px;touch-action:manipulation}
.wabtn:hover{background:#1EAF56;color:#fff;text-decoration:none}
.tchips{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}
.chip{font-size:.67rem;background:var(--muted);border:1px solid var(--bs);border-radius:var(--r50);padding:3px 9px;color:var(--t2);font-weight:500}
.qft{width:100%;font-size:.81rem;border-collapse:collapse}
.qft tr{border-bottom:1px solid var(--bs)}
.qft tr:last-child{border-bottom:none}
.qft td{padding:5px 0}
.qft td:first-child{color:var(--t2)}
.qft td:last-child{text-align:right;font-weight:600}
.share-bar{background:var(--card);border:1px solid var(--bs);border-radius:var(--r12);padding:18px 20px;margin-bottom:28px}
.share-bar h3{font-size:.9rem;font-family:var(--fb);font-weight:600;margin-bottom:12px;color:var(--t2)}
.share-btns{display:flex;flex-wrap:wrap;gap:9px}
.sbtn{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;border-radius:var(--r50);font-size:.83rem;font-weight:700;text-decoration:none;transition:.2s;border:none;cursor:pointer;min-height:44px;min-width:44px;touch-action:manipulation;line-height:1;color:#fff}
.sbtn:hover{text-decoration:none;opacity:.88;transform:translateY(-1px)}
.sbtn-fb{background:#1877F2}.sbtn-wa{background:#25D366}.sbtn-tw{background:#000}
.sbtn-em{background:var(--o)}.sbtn-pi{background:#E60023}
.share-note{font-size:.73rem;color:var(--t3);margin-top:8px}
.mb20{margin-bottom:20px}.mb28{margin-bottom:28px}
#reiseprogramm,#preise,#unterkunft,#bewertungen,#faq,
#itinerary,#prices,#accommodation,#reviews,
#programme,#prix,#hebergement,#avis,
#itinerario,#precios,#alojamiento,#opiniones,
#programma,#prezzi,#alloggi,#recensioni,
.share-bar{content-visibility:auto;contain-intrinsic-size:0 500px}
button,.btn,.bknow,.wabtn,.pcbtn,.bko,.fqi summary,.ham,.mnav a,.gal-th,.gal-hero,.lb-p,.lb-n,.lb-x{touch-action:manipulation}
.mcta{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--navy);padding:8px 11px;z-index:800;gap:8px;border-top:2px solid var(--o)}
.mcta a{flex:1;text-align:center;padding:12px;border-radius:var(--r50);font-weight:700;font-size:.86rem;text-decoration:none;min-height:44px;display:flex;align-items:center;justify-content:center;touch-action:manipulation}
.mbk{background:var(--o);color:#fff}.mbk:hover{background:var(--od);color:#fff}
.mwa{background:#25D366;color:#fff}
@media(max-width:900px){.mcta{display:flex}.sidebar{position:static}}
.wafl{position:fixed;right:14px;bottom:17px;width:50px;height:50px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.32rem;z-index:700;box-shadow:0 4px 11px rgba(0,0,0,.21);transition:.2s;text-decoration:none;touch-action:manipulation}
.wafl:hover{background:#1EAF56;transform:scale(1.08);color:#fff}
@media(max-width:900px){.wafl{bottom:69px;right:11px}}
.ftr{background:var(--navy);color:var(--ton);padding:44px 16px 20px;border-top:3px solid var(--o)}
.ftop{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:192px repeat(4,1fr);gap:22px;padding-bottom:26px;border-bottom:1px solid rgba(255,255,255,.09);margin-bottom:18px}
@media(max-width:860px){.ftop{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.ftop{grid-template-columns:1fr}}
.fbrand img{height:33px;display:block;margin-bottom:9px;aspect-ratio:150/33;filter:brightness(0) saturate(100%) invert(85%) sepia(90%) saturate(600%) hue-rotate(5deg) brightness(105%) contrast(100%);max-width:150px}
.fbrand p{font-size:.77rem;color:#D4B896;line-height:1.6}
.fbname{font-family:var(--fb);font-size:1.15rem;font-weight:700;color:#F6C343;margin-bottom:8px;letter-spacing:.3px}
.fcol h4{font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--o);margin-bottom:9px;font-family:var(--fb)}
.fcol ul li{margin-bottom:6px}
.fcol ul a{color:#D4B896;font-size:.78rem;transition:.2s}
.fcol ul a:hover{color:#fff;text-decoration:none}
.fcol.fm,.fcol .fm{color:#D4B896;font-size:.78rem}
.fbot{max-width:1200px;margin:0 auto;display:flex;flex-wrap:wrap;gap:9px 18px;justify-content:space-between;align-items:center;font-size:.72rem;color:rgba(160,128,96,.65)}
.ftrust{display:flex;gap:12px;flex-wrap:wrap}
.ftrust a{color:var(--g);font-weight:700;font-size:.76rem}
.ftrust a:hover{text-decoration:underline}
.fpols{display:flex;gap:10px;flex-wrap:wrap}
.fpols a{color:rgba(160,128,96,.65)}.fpols a:hover{color:#fff}
.fsoc{display:flex;gap:11px}
.fsoc a{color:var(--tonm);font-size:.95rem;transition:.2s;text-decoration:none}
.fsoc a:hover{color:var(--o)}

/* Recap / Quick day summary cards */
.recap{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:14px}
.recapc{background:#fff;border:1px solid var(--bs);border-radius:var(--r8);padding:14px 14px 12px;transition:.2s;position:relative;overflow:hidden}
.recapc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--o),#F6C343)}
.recapc:hover{border-color:var(--om);transform:translateY(-2px);box-shadow:0 6px 20px rgba(240,120,32,.08)}
.recaphd{display:flex;justify-content:space-between;align-items:center;margin-bottom:9px;flex-wrap:wrap;gap:6px}
.recapd{font-family:var(--fb);font-size:.78rem;font-weight:700;color:var(--o);background:var(--ol);padding:3px 10px;border-radius:var(--r50);letter-spacing:.4px;text-transform:uppercase}
.recapkm{font-size:.74rem;color:var(--t2)}
.recapt{font-family:var(--fb);font-size:.93rem;font-weight:600;color:var(--t1);margin-bottom:9px;line-height:1.35}
.recapul{list-style:none;padding:0;margin:0}
.recapul li{font-size:.82rem;color:var(--t2);line-height:1.55;padding-left:16px;position:relative;margin-bottom:5px}
.recapul li::before{content:'▸';position:absolute;left:0;color:var(--o);font-weight:700}
@media (max-width:900px){.recap{grid-template-columns:1fr}}

@media print{.hdr,.mcta,.wafl,.sidebar{display:none!important}.pgrid{display:block}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{transition:none!important;animation:none!important}}

/* ============================================================
   INDEX / CONTACT / GENERAL PAGE COMPONENTS (Task 4)
============================================================ */
.idx-hero{position:relative;min-height:clamp(420px,70vh,640px);background:linear-gradient(135deg,#0F1923 0%,#3a2410 100%);overflow:hidden;display:flex;align-items:center}
.idx-hero-bg{position:absolute;inset:0;background-image:url('/images/3-days-tour-from-marrakech-to-merzouga-desert.webp');background-size:cover;background-position:center;opacity:.35;filter:saturate(1.1)}
.idx-hero-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,25,35,.55) 0%,rgba(15,25,35,.25) 50%,rgba(15,25,35,.85) 100%)}
.idx-hero-in{position:relative;max-width:980px;margin:0 auto;padding:60px 18px;text-align:center;color:#fff;z-index:2}
.idx-hero h1{color:#fff;text-shadow:0 4px 18px rgba(0,0,0,.45);margin-bottom:14px}
.idx-hero-sub{color:rgba(255,255,255,.92);font-size:clamp(1rem,2vw,1.15rem);max-width:680px;margin:0 auto 22px}
.idx-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;max-width:1200px;margin:0 auto;padding:36px 16px}
.idx-card{background:var(--card);border:1px solid var(--bs);border-radius:var(--r12);overflow:hidden;transition:.25s;box-shadow:var(--s1);display:flex;flex-direction:column}
.idx-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(26,16,8,.16);border-color:var(--om);text-decoration:none}
.idx-card-img{aspect-ratio:16/10;width:100%;object-fit:cover;background:var(--muted)}
.idx-card-body{padding:16px 18px 18px;flex:1;display:flex;flex-direction:column}
.idx-card h3{font-size:1rem;margin-bottom:6px;color:var(--t1)}
.idx-card p{font-size:.86rem;color:var(--t2);flex:1;margin-bottom:12px}
.idx-card-meta{display:flex;justify-content:space-between;align-items:center;font-size:.78rem;font-weight:700}
.idx-card-meta .price{color:var(--o);font-family:var(--fh);font-size:1.05rem}
.idx-card-meta .days{color:var(--t3)}

.idx-section{max-width:1200px;margin:0 auto;padding:36px 16px}
.idx-section h2{text-align:center;margin-bottom:8px}
.idx-section-lead{text-align:center;color:var(--t2);font-size:.95rem;max-width:680px;margin:0 auto 26px}

.idx-features{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.idx-feature{text-align:center;padding:18px 14px}
.idx-feature-icon{width:56px;height:56px;border-radius:50%;background:var(--ol);color:var(--o);display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-size:1.4rem}
.idx-feature h4{font-size:.95rem;margin-bottom:6px}
.idx-feature p{font-size:.84rem;color:var(--t2);margin:0}

.contact-grid{max-width:1100px;margin:0 auto;padding:32px 16px;display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr}}
.contact-form{background:var(--card);border:1px solid var(--bs);border-radius:var(--r12);padding:24px;box-shadow:var(--s1)}
.contact-form label{display:block;font-size:.83rem;font-weight:600;color:var(--t2);margin-bottom:5px;margin-top:12px}
.contact-form label:first-child{margin-top:0}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;padding:10px 12px;border:1px solid var(--bs);border-radius:var(--r4);font-family:var(--fb);font-size:.92rem;background:#fff;color:var(--t1);transition:border-color .15s}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:var(--o);box-shadow:0 0 0 3px rgba(240,120,32,.15)}
.contact-form textarea{min-height:120px;resize:vertical}
.contact-form button[type="submit"]{margin-top:18px;width:100%;background:var(--o);color:#fff;border:none;padding:14px;border-radius:var(--r50);font-weight:700;font-size:.95rem;cursor:pointer;transition:background .2s;min-height:48px}
.contact-form button[type="submit"]:hover{background:var(--od)}
.contact-info{padding:8px 0}
.contact-info h3{margin-bottom:14px}
.contact-info-row{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--bs)}
.contact-info-row:last-child{border-bottom:none}
.contact-info-icon{width:42px;height:42px;border-radius:50%;background:var(--ol);color:var(--o);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.contact-info-row strong{display:block;font-size:.9rem;margin-bottom:2px;color:var(--t1)}
.contact-info-row a,.contact-info-row span{font-size:.85rem;color:var(--t2)}

/* ============================================================
   RESPONSIVE OVERHAUL — mobile-first, all breakpoints
   (320 / 375 / 480 / 640 / 768 / 1024)
   Added 2026-06: fixes mobile footer, WhatsApp button, Book Now bar,
   horizontal-scroll bugs, contact-page 2-col grid lock.
   ============================================================ */

/* --- Guardrails: stop ALL horizontal scrolling --- */
html,body{max-width:100%;overflow-x:hidden}
*,*::before,*::after{box-sizing:border-box}
img,video,iframe{max-width:100%;height:auto}
.ftop-pro>*,.ct-grid>*,.idx-cards>*,.hl-list>*,.relgrid>*,.adgrid>*,.incgrid>*{min-width:0}

/* --- Container helper (used by Step 4 pages) --- */
.vm-container{width:100%;max-width:1200px;margin:0 auto;padding-left:16px;padding-right:16px}

/* ============================================================
   PRO FOOTER (was inline-grid 1.6fr 1fr 1fr 1fr 1fr — now responsive)
   ============================================================ */
.ftr-pro{background:var(--navy,#1a2030);color:rgba(255,255,255,.78);border-top:3px solid var(--o,#F07820)}
.ftop-pro{
  width:100%;max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;
  gap:32px;padding:40px 20px 28px
}
.ftop-pro h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:#ffd47a;margin-bottom:12px;font-weight:700}
.ftop-pro ul{list-style:none;padding:0;margin:0;font-size:.84rem;line-height:1.75}
.ftop-pro ul li{margin-bottom:4px;word-break:break-word}
.ftop-pro ul a{color:rgba(255,255,255,.78);text-decoration:none;display:inline-block;min-height:32px;line-height:1.45;padding:3px 0;transition:color .15s}
.ftop-pro ul a:hover,.ftop-pro ul a:focus{color:#fff}
.ftop-pro .fbrand .fbname{font-size:1.15rem;font-weight:700;color:#fff;margin-bottom:8px}
.ftop-pro .fbrand p{font-size:.85rem;line-height:1.55;color:rgba(255,255,255,.78);margin-bottom:14px}
.ftop-pro .fbrand .ftrust{margin-bottom:10px}
.ftop-pro .fbrand .ftrust a{color:#ffd47a;font-size:.86rem;font-weight:600;text-decoration:none}
.ftop-pro .fbrand .fsoc{display:flex;flex-wrap:wrap;gap:14px;font-size:1.15rem}
.ftop-pro .fbrand .fsoc a{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.06);color:rgba(255,255,255,.78);text-decoration:none;transition:background .15s,color .15s}
.ftop-pro .fbrand .fsoc a:hover,.ftop-pro .fbrand .fsoc a:focus{background:rgba(255,255,255,.12);color:#fff}
.ftr-pro .fbot{
  border-top:1px solid rgba(255,255,255,.12);
  padding:18px 20px;
  display:flex;flex-wrap:wrap;gap:14px;
  align-items:center;justify-content:space-between;
  font-size:.78rem;color:rgba(255,255,255,.62);
  max-width:1200px;margin:0 auto;
  text-align:left
}
.ftr-pro .fbot a{color:rgba(255,255,255,.78);text-decoration:none;margin-right:14px;display:inline-block;padding:4px 0;min-height:28px}
.ftr-pro .fbot a:hover{color:#fff}

/* Tablet (1024 -> 768) */
@media (max-width:1024px){
  .ftop-pro{grid-template-columns:repeat(3,1fr);gap:28px;padding:36px 18px 24px}
  .ftop-pro .fbrand{grid-column:1 / -1}
}
/* Small tablet / large mobile (768 -> 480) */
@media (max-width:768px){
  .ftop-pro{grid-template-columns:repeat(2,1fr);gap:24px 22px;padding:32px 16px 22px}
  .ftop-pro .fbrand{grid-column:1 / -1;text-align:left}
  .ftop-pro h4{font-size:.74rem;margin-bottom:10px}
  .ftop-pro ul{font-size:.82rem}
  .ftr-pro .fbot{flex-direction:column;align-items:flex-start;text-align:left;padding:16px}
  .ftr-pro .fbot>div{width:100%;text-align:left}
}
/* Mobile (480 -> 320) */
@media (max-width:480px){
  .ftop-pro{grid-template-columns:1fr;gap:22px;padding:26px 14px 18px}
  .ftop-pro h4{font-size:.72rem;margin-bottom:8px}
  .ftop-pro ul{font-size:.86rem;line-height:1.7}
  .ftop-pro ul a{padding:5px 0;min-height:36px}
  .ftop-pro .fbrand p{font-size:.86rem}
  .ftop-pro .fbrand .fbname{font-size:1.05rem}
  .ftr-pro .fbot{font-size:.74rem;padding:14px}
  .ftr-pro .fbot a{margin-right:10px;padding:6px 0;min-height:32px}
}
/* Extra small (320 / iPhone SE) */
@media (max-width:360px){
  .ftop-pro{padding:22px 12px 16px;gap:18px}
  .ftop-pro h4{font-size:.7rem}
  .ftop-pro ul li{margin-bottom:2px}
}

/* ============================================================
   CONTACT PAGE GRID (was inline 1.4fr 1fr — now responsive)
   ============================================================ */
.ct-grid{
  width:100%;max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr;
  gap:36px;padding:36px 16px
}
.ct-form{background:#fff;border:1px solid #eee;border-radius:14px;padding:24px;min-width:0}
.ct-form .ct-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ct-form label{display:flex;flex-direction:column;font-size:.85rem;font-weight:600;color:#3a2e1f;min-width:0}
.ct-form input,.ct-form select,.ct-form textarea{
  width:100%;margin-top:6px;padding:12px;
  border:1px solid #ddd;border-radius:8px;font-size:1rem;
  background:#fff;color:#2a1b0a;
  -webkit-appearance:none;appearance:none;
  min-height:44px;font-family:inherit
}
.ct-form input:focus,.ct-form select:focus,.ct-form textarea:focus{outline:none;border-color:var(--o,#F07820);box-shadow:0 0 0 3px rgba(240,120,32,.15)}
.ct-form textarea{min-height:120px;resize:vertical;font-family:inherit}
.ct-form .ct-submit{margin-top:18px;width:100%;padding:14px;font-size:1rem;font-weight:600;border:none;border-radius:50px;background:var(--o,#F07820);color:#fff;cursor:pointer;min-height:48px;touch-action:manipulation}
.ct-form .ct-submit:hover{background:var(--od,#d96b1c)}
.ct-form .ct-wa{display:block;text-align:center;margin-top:10px;padding:14px;background:#25D366;color:#fff;border-radius:50px;font-weight:600;text-decoration:none;min-height:48px;touch-action:manipulation}
.ct-aside{display:flex;flex-direction:column;gap:20px;min-width:0}
.ct-aside-card{background:#fff7ee;border-radius:14px;padding:24px}
.ct-aside-card.alt{background:#fff;border:1px solid #eee}
.ct-aside-card h3{margin-top:0;font-size:1.05rem}
.ct-aside-card p{font-size:.94rem;color:#52473a;line-height:1.6}
.ct-aside-card iframe{width:100%;height:200px;border:0;border-radius:10px;margin-top:14px;display:block}

@media (max-width:760px){
  .ct-grid{grid-template-columns:1fr;gap:24px;padding:24px 14px}
  .ct-form{padding:20px}
  .ct-form .ct-row{grid-template-columns:1fr;gap:10px}
}
@media (max-width:480px){
  .ct-grid{padding:18px 12px;gap:18px}
  .ct-form{padding:16px}
  .ct-form input,.ct-form select,.ct-form textarea{font-size:16px}
}

/* ============================================================
   ABOUT US helpers
   ============================================================ */
.ab-hero{background:linear-gradient(135deg,#fff7ee 0%,#fff 100%);padding:60px 20px 36px;text-align:center}
.ab-hero h1{font-family:Georgia,serif;font-size:clamp(1.8rem,5vw,2.6rem);line-height:1.15;margin-bottom:14px;color:#2a1b0a}
.ab-hero p{font-size:clamp(1rem,2.2vw,1.15rem);color:#52473a;max-width:680px;margin:0 auto}
.ab-wrap{max-width:900px;margin:0 auto;padding:40px 16px}
.ab-numbers{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:18px;background:#fff7ee;border-radius:14px;padding:24px}
.ab-team{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.ab-cta{background:linear-gradient(135deg,#fff7ee,#fff);padding:26px;border-radius:14px;border:1px solid #f3e4d0;text-align:center}
.ab-cta .btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;margin:6px 4px;min-height:44px;padding:12px 18px;font-size:.95rem;touch-action:manipulation}
@media (max-width:480px){
  .ab-hero{padding:40px 14px 24px}
  .ab-wrap{padding:28px 14px}
  .ab-numbers{padding:18px}
  .ab-cta{padding:20px 16px}
  .ab-cta .btn{width:100%;margin:6px 0}
}

/* ============================================================
   BLOG hub helpers
   ============================================================ */
.bl-hero{background:linear-gradient(135deg,#fff7ee 0%,#fff 100%);padding:50px 20px 30px;text-align:center}
.bl-hero h1{font-family:Georgia,serif;font-size:clamp(1.7rem,4.8vw,2.4rem);margin-bottom:12px;color:#2a1b0a}
.bl-hero p{font-size:clamp(1rem,2.1vw,1.1rem);color:#52473a}
.bl-wrap{max-width:1100px;margin:0 auto;padding:36px 16px}
.bl-catg{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.bl-postg{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
@media (max-width:480px){
  .bl-hero{padding:32px 14px 22px}
  .bl-wrap{padding:24px 14px}
  .bl-catg{grid-template-columns:repeat(2,1fr);gap:10px}
  .bl-catg .blcat{padding:12px;font-size:.86rem}
}

/* ============================================================
   WHATSAPP FLOATING BUTTON — bigger, safer, never overlaps
   ============================================================ */
.wafl{
  position:fixed;
  right:max(14px,env(safe-area-inset-right));
  bottom:max(17px,env(safe-area-inset-bottom));
  width:56px;height:56px;
  background:#25D366;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:1.5rem;text-decoration:none;
  box-shadow:0 6px 16px rgba(0,0,0,.25);
  z-index:900;
  transition:transform .15s,background .15s;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent
}
.wafl:hover,.wafl:focus{background:#1EAF56;transform:scale(1.06);color:#fff}
.wafl:active{transform:scale(.96)}
/* When mobile Book Now bar is visible, lift WhatsApp above it */
@media (max-width:900px){
  .wafl{bottom:calc(72px + env(safe-area-inset-bottom));right:12px}
}
@media (max-width:480px){
  .wafl{width:52px;height:52px;font-size:1.4rem;right:10px;bottom:calc(68px + env(safe-area-inset-bottom))}
}
@media (max-width:360px){
  .wafl{width:48px;height:48px;font-size:1.3rem;right:8px}
}

/* ============================================================
   BOOK NOW / MOBILE CTA BAR — touch-friendly, no overlap
   ============================================================ */
.mcta{
  display:none;
  position:fixed;left:0;right:0;
  bottom:0;
  background:var(--navy,#1a2030);
  padding:8px 10px calc(8px + env(safe-area-inset-bottom));
  z-index:850;
  gap:8px;
  border-top:2px solid var(--o,#F07820);
  box-shadow:0 -4px 14px rgba(0,0,0,.18)
}
.mcta a{
  flex:1 1 0;
  min-width:0;
  text-align:center;
  padding:13px 8px;
  border-radius:50px;
  font-weight:700;font-size:.88rem;text-decoration:none;
  min-height:48px;
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis
}
.mcta a i{flex:0 0 auto}
.mbk{background:var(--o,#F07820);color:#fff}
.mbk:hover,.mbk:focus{background:var(--od,#d96b1c);color:#fff}
.mwa{background:#25D366;color:#fff}
.mwa:hover,.mwa:focus{background:#1EAF56;color:#fff}
@media (max-width:900px){.mcta{display:flex}}
@media (max-width:480px){
  .mcta{padding:7px 8px calc(7px + env(safe-area-inset-bottom));gap:6px}
  .mcta a{font-size:.82rem;padding:12px 6px;min-height:46px}
  .mcta a i{font-size:.95rem}
}
@media (max-width:360px){
  .mcta a{font-size:.78rem;padding:11px 4px;gap:4px}
}
/* Push body content above the fixed mobile bar */
@media (max-width:900px){
  body{padding-bottom:72px}
}

/* ============================================================
   HEADER Book Now — touch-friendly desktop
   ============================================================ */
.hdr .cta{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:40px;padding:8px 18px;border-radius:50px;
  background:var(--o,#F07820);color:#fff;font-weight:700;
  text-decoration:none;transition:background .15s,transform .15s;
  touch-action:manipulation
}
.hdr .cta:hover,.hdr .cta:focus{background:var(--od,#d96b1c);color:#fff;transform:translateY(-1px)}

/* ============================================================
   FLUID TYPOGRAPHY for hero blocks
   ============================================================ */
@media (max-width:768px){
  .hero h1{font-size:clamp(1.45rem,5vw,2rem);line-height:1.18}
  .hero .hero-sub{font-size:clamp(.95rem,2.6vw,1.1rem)}
  .hero{padding:36px 16px 32px}
  .sec-ttl{font-size:clamp(1.15rem,3.6vw,1.5rem)}
  .pgrid{padding:0 14px;gap:24px}
  .pills{gap:6px}
  .pill{font-size:.74rem;padding:5px 9px}
}
@media (max-width:480px){
  .hero h1{font-size:clamp(1.3rem,5.5vw,1.7rem)}
  .hero{padding:28px 14px 24px}
  .pgrid{padding:0 12px;gap:18px}
}

/* ============================================================
   TABLES — horizontal scroll instead of breaking layout
   ============================================================ */
.dtbl,.ptbl{width:100%;border-collapse:collapse;min-width:520px}
.dtbl th,.dtbl td,.ptbl th,.ptbl td{padding:10px 12px;font-size:.86rem;text-align:left;vertical-align:top}
@media (max-width:600px){
  .dtbl,.ptbl{font-size:.82rem;min-width:480px}
  .dtbl th,.dtbl td,.ptbl th,.ptbl td{padding:8px 10px;font-size:.8rem}
}

/* ============================================================
   PRICE CARDS row — proper wrap on mobile
   ============================================================ */
.pcrow{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.pc{min-width:0;background:#fff;border:1px solid var(--bs,#eee);border-radius:12px;padding:18px}
.pc.pop{border-color:var(--o,#F07820);box-shadow:0 6px 22px rgba(240,120,32,.08)}
@media (max-width:480px){
  .pcrow{grid-template-columns:1fr;gap:12px}
  .pc{padding:16px}
}

/* ============================================================
   CTA FINAL section — full-width buttons on mobile
   ============================================================ */
.cta-final .btn,.cta-final .btn-outline{margin:6px 6px 0 0}
@media (max-width:480px){
  .cta-final{padding:22px 16px}
  .cta-final .btn,.cta-final .btn-outline{display:block;width:100%;margin:8px 0 0 0;min-height:48px}
}

/* ============================================================
   MOBILE NAV — bigger touch targets
   ============================================================ */
.mnav a{min-height:48px;display:flex;align-items:center;padding:10px 18px;font-size:1rem;touch-action:manipulation}

/* ============================================================
   IDX / HOMEPAGE hero — better mobile sizing
   ============================================================ */
.idx-hero-in{padding:48px 18px}
@media (max-width:768px){.idx-hero-in{padding:36px 16px}}
@media (max-width:480px){
  .idx-hero{min-height:clamp(360px,60vh,520px)}
  .idx-hero-in{padding:28px 14px}
  .idx-cards{padding:24px 14px;gap:14px}
}

/* ============================================================
   SAFE-AREA padding for iPhone notch
   ============================================================ */
@supports (padding:max(0px)){
  .hdr-in,.idx-hero-in,.vm-container,.ftop-pro,.ftr-pro .fbot,.ct-grid,.ab-wrap,.bl-wrap{
    padding-left:max(16px,env(safe-area-inset-left));
    padding-right:max(16px,env(safe-area-inset-right))
  }
}
