/* Casa De Natalia — Your Latin home in London (Latin-luxe theme) */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}

/* ---------- AGE VERIFICATION GATE (18+) ---------- */
.age-gate{
  position:fixed;inset:0;z-index:99999;
  background:
    linear-gradient(180deg, rgba(7,10,7,.74) 0%, rgba(7,10,7,.86) 100%),
    url('/images/london-bg.jpg') center/cover no-repeat,
    #070a07;
  display:flex;align-items:center;justify-content:center;
  padding:24px;overflow-y:auto;
  animation:age-fade 220ms ease;
}
@keyframes age-fade{from{opacity:0}to{opacity:1}}
html.age-ok .age-gate{display:none!important}
html:not(.age-ok) body{overflow:hidden}
.age-gate-card{
  max-width:480px;width:100%;
  background:linear-gradient(180deg,#16211a,#0f160f);
  border:1px solid #d6b257;
  padding:40px 32px;text-align:center;
  box-shadow:0 30px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(0,0,0,.4) inset;
}
.age-gate-card .crown-m{width:62px;margin:0 auto 6px}
.age-gate-brand{
  font-family:'Great Vibes',cursive;font-size:42px;line-height:1;
  background:linear-gradient(180deg,#f6e7b3 0%,#e6c869 45%,#c79a32 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.age-gate-warn{
  font-family:'Cinzel',sans-serif;font-size:12px;letter-spacing:.32em;
  text-transform:uppercase;color:#eccd76;margin:14px 0 18px;
}
.age-gate-card h2{
  font-family:'Cormorant Garamond',serif;font-weight:600;
  font-size:28px;color:#f6edda;margin-bottom:14px;
}
.age-gate-card p{
  color:#e7dcc2;font-size:15px;font-style:italic;line-height:1.55;
  margin-bottom:26px;
}
.age-gate-card p a{color:#eccd76;text-decoration:underline}
.age-gate-actions{
  display:flex;gap:12px;justify-content:center;flex-wrap:wrap;
}
.age-gate-actions .btn{flex:1 1 180px;padding:14px 20px}
@media (max-width:480px){
  .age-gate{padding:14px}
  .age-gate-card{padding:30px 22px}
  .age-gate-brand{font-size:34px}
  .age-gate-card h2{font-size:23px}
  .age-gate-card p{font-size:14px;margin-bottom:22px}
}
:root{
  --bg:#0a0f0b;
  --bg-2:#0d150f;
  --surface:#121b14;
  --surface-2:#16211a;
  --ink:#f4ecd8;          /* primary text (cream) */
  --ink-soft:#e7dcc2;
  --muted:#a99f86;
  --line:#2c3a2d;
  --line-gold:rgba(214,178,87,.32);
  --gold:#d6b257;
  --gold-2:#eccd76;
  --gold-soft:#f3e2ad;
  --green:#1f7a44;
  --red:#c8341f;
  --paper:#0a0f0b;
  --paper-2:#0d150f;
}
body{
  font-family:'Cormorant Garamond', Georgia, serif;
  color:var(--ink);
  background:
    radial-gradient(1200px 700px at 50% -10%, rgba(214,178,87,.10), transparent 60%),
    linear-gradient(180deg, #0b120d 0%, #0a0f0b 100%);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
  font-size:17px;
  line-height:1.65;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
em{font-style:italic}

/* ---------- HERO + HEADER (overlay) ---------- */
.hero{
  position:relative;
  min-height:100vh;
  background:#070a07;
  display:flex;
  flex-direction:column;
  color:var(--ink);
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  width:100%;height:100%;object-fit:cover;object-position:center center;
  transform:scale(0.92);transform-origin:center center;
  opacity:.80;
}
.hero-tint{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(900px 520px at 50% 24%, rgba(214,178,87,.12), transparent 62%),
    linear-gradient(180deg, rgba(7,10,7,.20) 0%, rgba(7,10,7,.55) 100%);
  pointer-events:none;
}
.hero > .utility,
.hero > .brand-block,
.hero > .navwrap,
.hero > .welcome-wrap,
.hero > .hero-foot{position:relative;z-index:2}

/* Top utility row */
.utility{
  position:relative;z-index:3;
  display:flex;justify-content:flex-end;align-items:center;gap:10px;
  padding:24px 40px 0;
}
.search{
  display:flex;align-items:center;gap:8px;
  background:rgba(0,0,0,.4);
  border:1px solid var(--line-gold);
  padding:7px 14px;border-radius:2px;
  font-family:'Inter',sans-serif;font-size:12px;
  color:#e8dfd0;
  min-width:240px;
}
.search input{
  flex:1;background:transparent;border:0;outline:none;color:#fff;
  font-family:'Inter',sans-serif;font-size:12px;
}
.search input::placeholder{color:#bcae8e;font-style:italic}
.signin{
  background:linear-gradient(180deg,var(--gold-2),var(--gold));
  color:#241a06;
  font-family:'Cinzel','Inter',sans-serif;font-size:11px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  padding:9px 20px;border-radius:2px;
  border:1px solid var(--gold);
}
.signin:hover{filter:brightness(1.08)}

/* Centered brand block */
.brand-block{
  position:relative;z-index:2;
  text-align:center;
  padding:30px 20px 0;
}
.crown-m{
  width:70px;height:auto;margin:0 auto 4px;
  display:block;
}
.brand-name{
  font-family:'Cinzel', serif;
  font-weight:600;
  font-size:25px;
  letter-spacing:.34em;
  text-indent:.34em;
  color:var(--gold-soft);
  line-height:1;
  text-transform:uppercase;
}
.brand-name .script{
  display:block;
  font-family:'Great Vibes', cursive;
  font-weight:400;
  font-size:74px;
  letter-spacing:.01em;text-indent:0;
  text-transform:none;
  margin-top:2px;
  line-height:1.02;
  background:linear-gradient(180deg,#f6e7b3 0%,#e6c869 45%,#c79a32 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  filter:drop-shadow(0 2px 10px rgba(214,178,87,.25));
}
.brand-tag{
  font-family:'Cinzel',sans-serif;
  font-size:12px;
  letter-spacing:.30em;
  text-transform:uppercase;
  color:var(--gold-2);
  margin-top:10px;
}

/* Latin flags band */
.flags{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;
  gap:9px;margin:16px auto 0;max-width:560px;
}
.flags .flag{
  height:18px;width:auto;border-radius:2px;
  border:1px solid rgba(0,0,0,.35);
  box-shadow:0 1px 3px rgba(0,0,0,.5);
}
.flags-rule{
  display:flex;align-items:center;justify-content:center;gap:12px;
  color:var(--gold);margin-top:14px;
  font-family:'Cinzel',sans-serif;font-size:11px;letter-spacing:.34em;text-transform:uppercase;
}
.flags-rule::before,.flags-rule::after{content:"";width:54px;height:1px;background:var(--line-gold)}

/* Nav bar */
.navwrap{
  position:relative;z-index:2;
  margin-top:26px;
  border-top:1px solid var(--line-gold);
  border-bottom:1px solid var(--line-gold);
  background:rgba(0,0,0,.28);
}
.nav{
  display:flex;justify-content:center;align-items:center;
  gap:46px;
  padding:18px 20px;
  font-family:'Cinzel','Inter',sans-serif;
  font-size:13px;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.nav a{color:#ece1cb;font-weight:500;transition:color .2s}
.nav a:hover,.nav a.active{color:var(--gold-2)}

/* Welcome panel */
.welcome-wrap{
  position:relative;z-index:2;
  flex:1;
  display:flex;align-items:center;justify-content:center;
  padding:70px 24px;
}
.welcome{
  max-width:900px;width:100%;
  background:rgba(10,15,11,.5);
  border:1px solid var(--line-gold);
  box-shadow:0 0 0 1px rgba(0,0,0,.3) inset, 0 30px 80px rgba(0,0,0,.45);
  padding:58px 40px;
  text-align:center;
  backdrop-filter:blur(5px);
  -webkit-backdrop-filter:blur(5px);
}
.ornament{
  display:flex;align-items:center;justify-content:center;gap:14px;
  color:var(--gold);
  margin-bottom:30px;
}
.ornament .l,.ornament .r{
  flex:0 0 80px;height:1px;background:var(--gold);opacity:.6;
}
.ornament .d{
  width:14px;height:14px;border:1px solid var(--gold);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.ornament .d::before{content:"";width:5px;height:5px;background:var(--gold);border-radius:50%}
.welcome h1{
  font-family:'Cormorant Garamond',serif;
  font-weight:600;
  font-size:50px;
  line-height:1.18;
  color:#f8efde;
  letter-spacing:.005em;
}
.welcome h1 .row2{
  display:block;margin-top:10px;
  font-family:'Great Vibes',cursive;font-weight:400;
  font-size:46px;color:var(--gold-2);letter-spacing:.01em;
}
.welcome .lead{
  margin-top:24px;
  font-size:18px;
  font-style:italic;
  color:var(--ink-soft);
  max-width:640px;margin-left:auto;margin-right:auto;
}
.welcome .actions{
  margin-top:36px;
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap;
}

/* Buttons */
.btn{
  display:inline-block;
  font-family:'Cinzel','Inter',sans-serif;
  font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;
  padding:14px 28px;border-radius:2px;
  border:1px solid transparent;cursor:pointer;
  transition:all .2s;
}
.btn-gold{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#241a06;border-color:var(--gold);font-weight:600}
.btn-gold:hover{filter:brightness(1.08);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--gold-soft);border-color:var(--line-gold)}
.btn-ghost:hover{border-color:var(--gold);background:rgba(214,178,87,.08)}
.btn-dark{background:#000;color:var(--gold-soft);border-color:#000}
.btn-dark:hover{background:#111}
.btn-outline{background:transparent;color:var(--gold-soft);border-color:var(--line-gold)}
.btn-outline:hover{background:rgba(214,178,87,.1);border-color:var(--gold)}

/* Hero footer */
.hero-foot{
  position:relative;z-index:2;
  background:rgba(0,0,0,.5);
  border-top:1px solid var(--line-gold);
  padding:18px 20px;
  text-align:center;
  font-family:'Cormorant Garamond',serif;
  font-size:14px;
  font-style:italic;
  color:var(--ink-soft);
  letter-spacing:.03em;
}
.hero-foot a{margin:0 18px;color:var(--ink-soft)}
.hero-foot a:hover{color:var(--gold-2)}

/* ---------- INNER PAGE HEADER ---------- */
body.inner{background:var(--bg)}
.site-header{
  background:linear-gradient(180deg,#0c130d,#0a0f0b);
  color:var(--ink);
  border-bottom:1px solid var(--line-gold);
}
.site-header .utility{padding:18px 40px 0}
.site-header .brand-block{padding:16px 20px 6px}
.site-header .brand-name{font-size:18px}
.site-header .brand-name .script{font-size:46px}
.site-header .brand-tag{font-size:11px}
.site-header .crown-m{width:48px}
.site-header .flags{margin-top:10px}
.site-header .navwrap{margin-top:14px;background:rgba(0,0,0,.3)}

/* ---------- SECTIONS ---------- */
.section-sep{
  display:flex;align-items:center;justify-content:center;gap:18px;
  padding:28px 28px;
  background:linear-gradient(180deg, #070a07 0%, #0c130d 50%, #070a07 100%);
  border-top:1px solid rgba(214,178,87,.55);
  border-bottom:1px solid rgba(214,178,87,.55);
}
.section-sep .sep-line{
  flex:1 1 0;max-width:280px;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold-2) 35%, var(--gold) 65%, transparent);
  opacity:.85;
}
.section-sep .sep-gem{
  flex:0 0 auto;
  width:11px;height:11px;
  border:1px solid var(--gold-2);
  transform:rotate(45deg);
  background:rgba(214,178,87,.14);
  box-shadow:0 0 16px rgba(236,205,118,.35), inset 0 0 6px rgba(214,178,87,.2);
}

.section{
  max-width:1180px;margin:0 auto;padding:96px 28px;
}
.companions-band{
  max-width:none;
  background:linear-gradient(180deg, #0e1611 0%, #0a0f0b 55%, #0d150f 100%);
  border-top:1px solid rgba(214,178,87,.22);
  border-bottom:1px solid rgba(214,178,87,.22);
  box-shadow:inset 0 1px 0 rgba(236,205,118,.06), inset 0 -1px 0 rgba(0,0,0,.35);
}
.companions-band > .section-head,
.companions-band > .companions,
.companions-band > div[style]{
  max-width:1180px;margin-left:auto;margin-right:auto;
}
.section-head{text-align:center;margin-bottom:52px}
.section-head .pre{
  font-family:'Cinzel','Inter',sans-serif;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;
}
.section-head h2{
  font-family:'Cormorant Garamond',serif;
  font-weight:600;
  font-size:44px;line-height:1.2;color:#f6edda;
}
.section-head h2 em{font-style:italic;color:var(--gold-2)}
.section-head .div{
  width:60px;height:1px;background:var(--gold);
  margin:22px auto 18px;
}
.section-head .intro{
  max-width:680px;margin:0 auto;
  color:var(--muted);font-size:17px;font-style:italic;
}

.about{background:var(--bg-2)}
.about .grid{
  max-width:1100px;margin:0 auto;padding:96px 28px;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.about .pre{
  font-family:'Cinzel','Inter',sans-serif;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;
}
.about h2{
  font-family:'Cormorant Garamond',serif;
  font-weight:600;font-size:38px;line-height:1.25;color:#f6edda;
}
.about h2 em{font-style:italic;color:var(--gold-2)}
.about .div{width:60px;height:1px;background:var(--gold);margin:20px 0}
.about p{color:var(--ink-soft);margin-bottom:14px}
.about .photo{
  background:url('https://images.unsplash.com/photo-1564501049412-61c2a3083791?auto=format&fit=crop&w=1200&q=80') center/cover no-repeat;
  min-height:480px;
  border:1px solid var(--line-gold);
}

/* ---------- COMPANIONS ---------- */
.companions{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:28px;
}
.companions-featured{
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  max-width:1180px;margin:0 auto;
}
.companion{
  background:var(--surface);
  border:1px solid var(--line);
  transition:all .25s;
  display:flex;flex-direction:column;
  color:var(--ink);
}
.companion:hover{transform:translateY(-3px);box-shadow:0 18px 38px rgba(0,0,0,.5);border-color:var(--gold)}
.ph{
  position:relative;aspect-ratio:3/4;overflow:hidden;background:#0f160f;
}
.ph img{width:100%;height:100%;object-fit:contain;background:#0a0f0b;transition:transform .5s ease}
.companion:hover .ph img{transform:scale(1.04)}
.ph .vmark{
  position:absolute;top:12px;left:12px;
  background:rgba(10,15,11,.85);color:var(--gold-soft);
  font-family:'Inter',sans-serif;font-size:10.5px;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;
  padding:6px 11px;display:flex;align-items:center;gap:6px;
  border:1px solid var(--line-gold);
}
.ph .vmark::before{
  content:"";width:7px;height:7px;border-radius:50%;
  background:var(--gold);box-shadow:0 0 0 2px rgba(214,178,87,.22);
}

/* ---------- INCALL BADGE & BANNER ---------- */
.incall-badge{
  position:absolute;bottom:12px;right:12px;z-index:2;
  background:linear-gradient(180deg,#34d27a,#1ea35a);
  color:#fff;
  font-family:'Cinzel','Inter',sans-serif;
  font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  padding:6px 10px;border:1px solid rgba(255,255,255,.22);
  box-shadow:0 4px 14px rgba(30,163,90,.45);
  display:inline-flex;align-items:center;gap:5px;
  white-space:nowrap;
}
.incall-badge::before{
  content:"\2713";font-size:11px;font-weight:700;
}
.incall-badge-lg{
  bottom:14px;right:14px;top:auto;font-size:11px;padding:7px 13px;letter-spacing:.18em;
}
.card-incall{
  display:flex;align-items:center;gap:6px;
  margin:6px 0 2px;
  font-family:'Inter',sans-serif;font-size:12px;font-weight:600;
  color:#34d27a;letter-spacing:.02em;
}
.incall-banner{
  display:flex;align-items:center;gap:14px;
  margin-top:22px;padding:14px 18px;
  background:linear-gradient(180deg, rgba(52,210,122,.10), rgba(30,163,90,.06));
  border:1px solid rgba(52,210,122,.35);
}
.incall-banner .ib-icon{
  flex:0 0 36px;width:36px;height:36px;border-radius:50%;
  background:linear-gradient(180deg,#34d27a,#1ea35a);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:700;
  box-shadow:0 4px 14px rgba(30,163,90,.4);
}
.incall-banner .ib-title{
  font-family:'Cinzel',sans-serif;font-size:12px;letter-spacing:.22em;
  text-transform:uppercase;color:#34d27a;margin-bottom:2px;
}
.incall-banner .ib-sub{
  font-family:'Cormorant Garamond',serif;font-size:15px;color:var(--ink-soft);
  font-style:italic;line-height:1.5;
}
.incall-banner .ib-sub b{font-style:normal;color:#52d987;font-weight:600;font-family:'Inter',sans-serif;font-size:13px;letter-spacing:.04em;margin-right:2px}
.tag-incall{
  background:linear-gradient(180deg,#34d27a,#1ea35a)!important;
  color:#fff!important;border-color:#1ea35a!important;
  font-weight:600;letter-spacing:.08em;
}

@media (max-width:760px){
  .incall-badge{bottom:8px;right:8px;top:auto;font-size:9px;padding:4px 8px;letter-spacing:.10em}
  .incall-badge::before{font-size:10px}
  .incall-badge-lg{bottom:10px;right:10px;font-size:10px;padding:6px 11px;letter-spacing:.14em}
  .card-incall{font-size:11px}
  .incall-banner{padding:12px 14px;gap:11px;margin-top:18px}
  .incall-banner .ib-icon{flex-basis:30px;width:30px;height:30px;font-size:15px}
  .incall-banner .ib-title{font-size:11px;letter-spacing:.18em}
  .incall-banner .ib-sub{font-size:13.5px;line-height:1.4}
}
.body{padding:22px 22px 24px}
.row1{display:flex;justify-content:space-between;align-items:center;gap:6px 12px;margin-bottom:6px;flex-wrap:wrap}
.nm{font-family:'Cormorant Garamond',serif;font-size:25px;font-weight:600;color:#f6edda;line-height:1.1}
.rate{font-family:'Inter',sans-serif;font-size:13px;font-weight:500;color:var(--gold);letter-spacing:.04em;white-space:nowrap}
.aa{font-style:italic;color:var(--muted);font-size:15px;margin-bottom:10px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.nat-pill{
  font-style:normal;font-family:'Inter',sans-serif;font-size:10.5px;font-weight:500;
  letter-spacing:.08em;text-transform:uppercase;color:var(--gold-2);
  border:1px solid var(--line-gold);padding:2px 7px;border-radius:2px;
}

/* ---------- GALLERY TOOLBAR (filter + search + sort) ---------- */
.gallery-section{padding-top:72px}
.gal-toolbar{
  display:flex;flex-wrap:wrap;align-items:center;gap:14px 16px;
  margin:0 auto 36px;max-width:1100px;
  background:var(--surface);border:1px solid var(--line-gold);
  padding:18px 22px;border-radius:2px;
  position:sticky;top:0;z-index:20;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.gal-search{
  display:flex;align-items:center;gap:8px;
  background:var(--bg-2);border:1px solid var(--line);
  padding:8px 14px;flex:1 1 220px;min-width:200px;
}
.gal-search-ico{color:var(--gold);font-size:13px}
.gal-search input{
  flex:1;background:transparent;border:0;outline:none;color:var(--ink);
  font-family:'Inter',sans-serif;font-size:14px;
}
.gal-search input::placeholder{color:var(--muted);font-style:italic}
.gal-chips{display:flex;align-items:center;flex-wrap:wrap;gap:6px}
.chip-label{
  font-family:'Cinzel',sans-serif;font-size:10.5px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);margin-right:6px;
}
.chip{
  background:transparent;color:var(--ink-soft);border:1px solid var(--line);
  font-family:'Inter',sans-serif;font-size:12px;letter-spacing:.04em;
  padding:7px 13px;border-radius:2px;cursor:pointer;transition:all .15s;
}
.chip:hover{border-color:var(--gold);color:var(--gold-2)}
.chip.active{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#241a06;border-color:var(--gold);font-weight:600}
.chip-clear{margin-left:auto;color:var(--muted);font-style:italic}
.chip-clear:hover{color:var(--gold-2)}
.gal-sort{display:flex;align-items:center;gap:8px}
.gal-sort label{
  font-family:'Cinzel',sans-serif;font-size:10.5px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);
}
.gal-sort select{
  background:var(--bg-2);color:var(--ink);border:1px solid var(--line);
  font-family:'Inter',sans-serif;font-size:13px;
  padding:7px 12px;cursor:pointer;outline:none;
}
.gal-sort select:focus{border-color:var(--gold)}
.gal-empty{
  text-align:center;color:var(--muted);font-style:italic;
  padding:60px 20px;font-size:17px;
}
.gal-empty button{
  background:transparent;color:var(--gold-2);border:0;
  font-family:'Cinzel',sans-serif;font-size:12px;letter-spacing:.18em;
  text-transform:uppercase;cursor:pointer;margin-left:8px;text-decoration:underline;
}

@media (max-width:760px){
  .gal-toolbar{position:static}
  .gal-chips{width:100%}
  .gal-sort{width:100%;justify-content:space-between}
  .gal-search{flex-basis:100%}
}
.lang{
  font-family:'Inter',sans-serif;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:#8a8169;
  border-top:1px solid var(--line);padding-top:14px;margin-top:6px;
}
.companion-cta{
  margin-top:14px;
  font-family:'Cinzel','Inter',sans-serif;
  font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);display:flex;justify-content:space-between;align-items:center;
}
.companion-cta::after{content:"\2192";color:var(--gold);font-size:14px}

/* ---------- SERVICES ---------- */
.services-band{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.services{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-left:1px solid var(--line);
}
.svc{
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:44px 32px;background:var(--surface);
}
.svc:nth-child(-n+3){border-top:1px solid var(--line)}
.svc .num{
  font-family:'Cinzel',serif;font-size:13px;letter-spacing:.24em;
  color:var(--gold);margin-bottom:18px;
}
.svc h3{
  font-family:'Cormorant Garamond',serif;font-weight:600;
  font-size:24px;color:#f6edda;margin-bottom:10px;
}
.svc p{color:var(--muted);font-size:16px}

/* ---------- TESTIMONIALS ---------- */
.testi-band{
  background:linear-gradient(180deg,#101812 0%,#0c130d 50%,#090d0a 100%);
  color:var(--ink);
  padding:96px 28px;text-align:center;
  border-top:2px solid rgba(214,178,87,.45);
  border-bottom:2px solid rgba(214,178,87,.45);
  box-shadow:inset 0 12px 40px rgba(0,0,0,.25);
}
.testi-band .pre{
  font-family:'Cinzel',sans-serif;font-size:11px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold-2);margin-bottom:14px;
}
.testi-band h2{
  font-family:'Cormorant Garamond',serif;font-weight:600;
  font-size:44px;color:#f6edda;
}
.testi-band h2 em{font-style:italic;color:var(--gold-2)}
.testi-band .div{width:60px;height:1px;background:var(--gold);margin:22px auto 56px}
.testimonials{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:36px;
}
.q{
  background:rgba(214,178,87,.04);
  border:1px solid var(--line-gold);
  padding:34px 28px;text-align:left;
}
.q::before{
  content:"\201C";
  font-family:'Cormorant Garamond',serif;
  color:var(--gold);font-size:54px;line-height:.5;display:block;margin-bottom:14px;
}
.q p{font-style:italic;color:var(--ink-soft);font-size:17px;margin-bottom:18px;line-height:1.6}
.q .by{
  font-family:'Cinzel','Inter',sans-serif;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold-2);
}

/* ---------- CTA BAND ---------- */
.cta-band{
  background:linear-gradient(180deg, #0d150f 0%, #121b14 50%, #0d150f 100%);
  padding:90px 28px;text-align:center;
  border-top:1px solid rgba(214,178,87,.35);
  border-bottom:1px solid rgba(214,178,87,.35);
}
.cta-band .pre{
  font-family:'Cinzel',sans-serif;font-size:11px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold);margin-bottom:14px;
}
.cta-band h3{
  font-family:'Cormorant Garamond',serif;font-weight:600;
  font-size:40px;color:#f6edda;max-width:760px;margin:0 auto;
}
.cta-band h3 em{font-style:italic;color:var(--gold-2)}
.cta-band p{
  color:var(--muted);font-style:italic;font-size:17px;
  max-width:620px;margin:18px auto 32px;
}
.cta-band .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- FOOTER ---------- */
footer.site{
  background:linear-gradient(180deg,#0a0f0b,#070a07);
  color:var(--ink-soft);
  padding:64px 28px 0;
  border-top:1px solid var(--line-gold);
}
footer.site .inner{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:50px;
}
footer.site .brand-foot .crown-m{width:46px;margin:0 0 12px}
footer.site .brand-foot .nm{
  font-family:'Great Vibes',cursive;font-size:34px;letter-spacing:.01em;
  color:var(--gold-2);margin-bottom:6px;line-height:1;
}
footer.site .brand-foot p{font-size:15px;color:#988e76;line-height:1.7}
footer.site h4{
  font-family:'Cinzel',sans-serif;font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--gold-2);margin-bottom:18px;
}
footer.site ul{list-style:none}
footer.site li{margin-bottom:10px;font-size:15px}
footer.site a:hover{color:var(--gold-2)}
footer.site .copy{
  max-width:1180px;margin:54px auto 0;
  border-top:1px solid var(--line);padding:22px 0;
  font-size:12.5px;font-style:italic;color:#7a715c;
  text-align:center;
}

/* ---------- LEGAL/INNER PAGES ---------- */
.legal{
  max-width:820px;margin:0 auto;padding:90px 28px;
}
.legal .pre{
  font-family:'Cinzel',sans-serif;font-size:11px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold);text-align:center;margin-bottom:14px;
}
.legal h1{
  font-family:'Cormorant Garamond',serif;font-weight:600;font-size:48px;
  text-align:center;color:#f6edda;
}
.legal h1 em{font-style:italic;color:var(--gold-2)}
.legal .div{width:60px;height:1px;background:var(--gold);margin:22px auto 40px}
.loc-band{
  max-width:1180px;
  background:linear-gradient(180deg, rgba(214,178,87,.05) 0%, rgba(10,15,11,.4) 100%);
  border-top:1px solid rgba(214,178,87,.3);
  border-bottom:1px solid rgba(214,178,87,.3);
  padding:90px 28px 96px;
  margin:0 auto;
}
.legal h2{
  font-family:'Cormorant Garamond',serif;font-weight:600;font-size:25px;
  color:#f6edda;margin:36px 0 12px;
}
.legal p,.legal li{color:var(--ink-soft);margin-bottom:14px}
.legal ul{padding-left:22px}

.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:40px;
}
.contact-grid a{
  background:var(--surface);border:1px solid var(--line-gold);
  padding:30px;display:block;transition:all .2s;
}
.contact-grid a:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,0,0,.45)}
.contact-grid .l{
  font-family:'Cinzel',sans-serif;font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--gold);margin-bottom:10px;
}
.contact-grid .v{
  font-family:'Cormorant Garamond',serif;font-size:24px;color:#f6edda;margin-bottom:8px;
}
.contact-grid .d{color:var(--muted);font-style:italic;font-size:15px}
.loc-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}

/* ---------- WHATSAPP AREA BUTTONS ---------- */
.wa-areas{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:8px auto 0;max-width:760px}
.btn-wa{
  display:inline-flex;align-items:center;gap:9px;
  background:#25d366;color:#fff;border:1px solid #1da851;
  font-family:'Cinzel',sans-serif;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  padding:13px 20px;transition:all .2s;
}
.btn-wa:hover{background:#1da851;transform:translateY(-2px);box-shadow:0 10px 24px rgba(37,211,102,.28)}
.btn-wa .wa-ico{flex:none}
.wa-ico{vertical-align:middle}

/* ---------- PRICE CTA ---------- */
.price-cta{background:var(--surface);border:1px solid var(--line-gold);padding:30px;text-align:center}
.price-cta .pre{color:var(--gold)}
.price-cta h3{font-family:'Cormorant Garamond',serif;font-size:30px;color:#f6edda;margin:6px 0 10px}
.price-cta p{color:var(--muted);font-size:15px;margin-bottom:20px}
.price-cta .wa-areas{margin-top:4px}

/* price label on companion cards */
.rate-wa{display:inline-flex;align-items:center;gap:6px;color:#52d987;font-size:13px;font-weight:600;white-space:nowrap}
.rate-wa .wa-ico{width:15px;height:15px;flex:none}
.card-wa{display:inline-flex;align-items:center;gap:7px;margin-top:10px;color:#52d987;font-size:13px;font-weight:600}
.card-wa .wa-ico{width:15px;height:15px;flex:none}

/* ---------- WHATSAPP FAB ---------- */
.wa-fab{
  position:fixed;bottom:24px;right:24px;z-index:50;
  width:56px;height:56px;border-radius:50%;
  background:#25d366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:26px;
  box-shadow:0 10px 28px rgba(0,0,0,.4);
  transition:transform .2s;
}
.wa-fab:hover{transform:scale(1.08)}
.wa-fab .wa-ico{width:30px;height:30px}

/* ---------- RESPONSIVE ---------- */
@media (max-width:980px){
  .companions{grid-template-columns:repeat(2,1fr)}
  .services{grid-template-columns:1fr}
  .testimonials{grid-template-columns:1fr}
  .about .grid{grid-template-columns:1fr;gap:36px;padding:64px 24px}
  footer.site .inner{grid-template-columns:1fr 1fr;gap:40px}
  .nav{gap:22px;font-size:12px;letter-spacing:.18em}
  .brand-name{font-size:20px}
  .brand-name .script{font-size:58px}
  .welcome{padding:42px 24px}
  .welcome h1{font-size:34px}
  .welcome h1 .row2{font-size:34px}
  .utility{padding:18px 18px 0}
  .search{min-width:0;flex:1}
}
@media (max-width:560px){
  .companions{grid-template-columns:1fr}
  footer.site .inner{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .nav{flex-wrap:wrap;gap:14px}
  .utility{flex-wrap:wrap}
  .section{padding:72px 22px}
  .brand-name .script{font-size:50px}
}

/* ---------- COMPANION PROFILE PAGE ---------- */
/* Prev / next companion navigator */
.prof-nav{
  max-width:1180px;margin:24px auto 0;padding:0 28px;
  display:grid;grid-template-columns:1fr auto 1fr;gap:16px;align-items:stretch;
}
.pn-card,.pn-center{
  background:var(--surface);border:1px solid var(--line-gold);
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;color:var(--ink-soft);
  transition:all .2s;min-height:74px;
}
.pn-card:hover,.pn-center:hover{
  border-color:var(--gold);transform:translateY(-2px);
  box-shadow:0 10px 24px rgba(0,0,0,.4);color:var(--ink);
}
.pn-prev{justify-content:flex-start}
.pn-next{justify-content:flex-end;text-align:right}
.pn-arrow{
  font-family:'Cinzel',serif;font-size:24px;color:var(--gold);
  flex:0 0 auto;line-height:1;
}
.pn-thumb{
  width:46px;height:46px;flex:0 0 auto;
  background:#0f160f;border:1px solid var(--line);overflow:hidden;
}
.pn-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.pn-meta{flex:1;min-width:0}
.pn-next .pn-meta{order:-1}
.pn-dir{
  font-family:'Cinzel',sans-serif;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);margin-bottom:2px;
}
.pn-name{
  font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;
  color:#f6edda;line-height:1.1;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.pn-center{
  flex-direction:column;justify-content:center;gap:2px;text-align:center;
  padding:14px 26px;
}
.pn-count{
  font-family:'Cinzel',serif;font-size:14px;color:var(--gold-2);letter-spacing:.14em;
}
.pn-back{
  font-family:'Cinzel',sans-serif;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--muted);
}
.pn-center:hover .pn-back{color:var(--gold)}

@media (max-width:760px){
  .prof-nav{margin:14px auto 0;padding:0 12px;grid-template-columns:1fr 1fr;gap:10px}
  .pn-center{display:none}
  .pn-card{padding:10px 12px;gap:10px;min-height:62px}
  .pn-thumb{width:40px;height:40px}
  .pn-name{font-size:16px}
  .pn-dir{font-size:9px;letter-spacing:.18em}
  .pn-arrow{font-size:18px}
}

.profile{
  max-width:1180px;margin:0 auto;padding:64px 28px 40px;
}
.profile-grid{
  display:grid;grid-template-columns:5fr 6fr;gap:60px;align-items:start;
}
.profile-photo{
  position:relative;aspect-ratio:3/4;overflow:hidden;
  background:#0f160f;border:1px solid var(--line-gold);
}
.profile-photo img{width:100%;height:100%;object-fit:contain;background:#0a0f0b;display:block}
.profile-photo .vmark{
  position:absolute;top:14px;left:14px;z-index:2;
  background:rgba(10,15,11,.85);color:var(--gold-soft);
  font-family:'Inter',sans-serif;font-size:10.5px;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;
  padding:7px 12px;display:flex;align-items:center;gap:6px;
  border:1px solid var(--line-gold);
}
.profile-photo .vmark::before{
  content:"";width:7px;height:7px;border-radius:50%;
  background:var(--gold);box-shadow:0 0 0 2px rgba(214,178,87,.22);
}
.profile-meta .back{
  font-family:'Cinzel',sans-serif;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);margin-bottom:24px;display:inline-block;
}
.profile-meta .back:hover{color:var(--gold-2)}
.profile-meta .pre{
  font-family:'Cinzel',sans-serif;font-size:11px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold);margin-bottom:10px;
}
.profile-meta h1{
  font-family:'Cormorant Garamond',serif;font-weight:600;
  font-size:64px;line-height:1;color:#f6edda;margin-bottom:20px;
}
.prof-stats{
  display:flex;flex-wrap:wrap;gap:18px 26px;margin-bottom:14px;
  font-size:15px;color:var(--ink);
}
.prof-stats span b{
  font-family:'Cinzel',sans-serif;font-size:10.5px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--gold);
  display:block;margin-bottom:3px;
}
.profile-meta .div{
  width:60px;height:1px;background:var(--gold);margin:24px 0;
}
.bio-lead{
  font-size:19px;font-style:italic;color:var(--ink);margin-bottom:14px;
}
.profile-meta p{color:var(--ink-soft);margin-bottom:14px}
.prof-actions{
  display:flex;gap:12px;flex-wrap:wrap;margin-top:26px;
}

/* Detail block */
.prof-detail{
  background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.pd-grid{
  max-width:1180px;margin:0 auto;padding:72px 28px;
  display:grid;grid-template-columns:6fr 5fr;gap:60px;align-items:start;
}
.pd-block .pre,.pd-rates .pre{
  font-family:'Cinzel',sans-serif;font-size:11px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold);margin-bottom:8px;
}
.pd-block h3,.pd-rates h3{
  font-family:'Cormorant Garamond',serif;font-weight:600;
  font-size:26px;color:#f6edda;margin-bottom:14px;
}
.pd-block .avail{color:var(--ink-soft);font-size:17px}
.tags{display:flex;flex-wrap:wrap;gap:8px}
.tag{
  background:var(--surface-2);border:1px solid var(--line-gold);
  font-family:'Inter',sans-serif;font-size:12px;letter-spacing:.06em;
  padding:8px 14px;color:var(--ink-soft);
}
.tag-soft{background:transparent;color:var(--gold-2);border-color:var(--gold)}
.interest-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:8px 18px;font-size:16px;color:var(--ink-soft)}
.interest-list li::before{content:"\25C6 ";color:var(--gold);font-size:10px;margin-right:6px;vertical-align:middle}
.pd-rates{
  background:var(--surface);border:1px solid var(--line-gold);padding:32px;
}
table.rates{width:100%;border-collapse:collapse;margin-top:6px}
table.rates td{
  padding:13px 4px;border-bottom:1px solid var(--line);
  font-size:16px;color:var(--ink-soft);
}
table.rates td:last-child{
  text-align:right;font-family:'Cinzel',serif;color:var(--gold);font-weight:500;letter-spacing:.04em;
}
table.rates tr:last-child td{border-bottom:0}
.rates-note{
  margin-top:18px;font-size:13.5px;font-style:italic;color:var(--muted);line-height:1.5;
}

/* Profile gallery */
.prof-gallery{
  max-width:1180px;margin:0 auto;padding:80px 28px;
}
.gal-grid{
  display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:240px;gap:14px;
}
.gal-cell{
  position:relative;overflow:hidden;background:#0f160f;border:1px solid var(--line-gold);
}
.gal-cell.gal-tall{grid-row:span 2;grid-column:span 2}
.gal-cell img{width:100%;height:100%;object-fit:contain;background:#0a0f0b;display:block;transition:transform .5s ease}
.gal-cell:hover img{transform:scale(1.04)}
.gal-cell a{display:block;width:100%;height:100%}
.gal-cell .lock{
  position:absolute;left:14px;bottom:14px;
  background:rgba(10,15,11,.82);color:var(--gold-soft);
  font-family:'Cinzel',sans-serif;font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;padding:6px 10px;
}

/* Other companions */
.prof-other{
  background:var(--bg-2);padding:80px 28px;border-top:1px solid var(--line);
}
.prof-other .section-head{margin-bottom:36px}
.other-grid{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
.other-comp{
  background:var(--surface);border:1px solid var(--line);
  display:flex;flex-direction:column;color:var(--ink);transition:all .2s;
}
.other-comp:hover{transform:translateY(-3px);border-color:var(--gold);box-shadow:0 12px 28px rgba(0,0,0,.45)}
.op{aspect-ratio:3/4;overflow:hidden;background:#0f160f}
.op img{width:100%;height:100%;object-fit:contain;background:#0a0f0b}
.ob{padding:14px 18px}
.on{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:#f6edda}
.oa{font-style:italic;color:var(--muted);font-size:14px}

@media (max-width:980px){
  .profile-grid{grid-template-columns:1fr;gap:36px}
  .pd-grid{grid-template-columns:1fr;gap:40px;padding:54px 22px}
  .gal-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}
  .other-grid{grid-template-columns:repeat(2,1fr)}
  .profile-meta h1{font-size:46px}
}
@media (max-width:560px){
  .gal-grid{grid-template-columns:1fr}
  .other-grid{grid-template-columns:1fr}
  .interest-list{grid-template-columns:1fr}
}

/* ---------- PHONE-FRIENDLY UPGRADES (≤760px and ≤480px) ---------- */
@media (max-width:760px){
  /* Hide decorative search input on phones */
  .hero > .utility .search,
  .site-header .utility .search { display:none }
  .hero > .utility,
  .site-header .utility { justify-content:flex-end; padding:14px 16px 0 }
  .signin{ padding:8px 16px; font-size:11px }

  /* Tighter hero/header brand block */
  .brand-block{ padding:18px 12px 0 }
  .crown-m{ width:54px }
  .brand-name{ font-size:18px; letter-spacing:.28em; text-indent:.28em }
  .brand-name .script{ font-size:52px }
  .brand-tag{ font-size:11px; letter-spacing:.22em; margin-top:8px }
  .flags{ gap:6px; margin-top:12px }
  .flags .flag{ height:14px }
  .flags-rule{ font-size:10px; letter-spacing:.26em; margin-top:10px }
  .flags-rule::before,.flags-rule::after{ width:32px }

  /* Tighter nav as scrollable row */
  .navwrap{ margin-top:18px }
  .nav{
    gap:18px; padding:12px 14px; font-size:11px; letter-spacing:.16em;
    overflow-x:auto; flex-wrap:nowrap; justify-content:flex-start;
    scrollbar-width:none;
  }
  .nav::-webkit-scrollbar{ display:none }
  .nav a{ white-space:nowrap; flex:0 0 auto }

  /* Welcome / hero copy */
  .welcome-wrap{ padding:48px 16px }
  .welcome{ padding:34px 20px }
  .welcome h1{ font-size:30px; line-height:1.2 }
  .welcome h1 .row2{ font-size:24px }
  .welcome .lead{ font-size:16px; margin-top:18px }
  .ornament{ margin-bottom:22px }
  .ornament .l,.ornament .r{ flex:0 0 50px }
  .welcome .actions{ gap:10px; margin-top:26px }
  .welcome .actions .btn{ flex:1 1 auto; padding:14px 18px; font-size:11px; letter-spacing:.18em }

  /* Section headings — easier to read */
  .section{ padding:60px 16px }
  .section-sep{ padding:20px 16px; gap:12px }
  .section-sep .sep-line{ max-width:90px }
  .loc-band{ padding:60px 16px 72px }
  .section-head{ margin-bottom:36px }
  .section-head h2,.testi-band h2,.cta-band h3{ font-size:30px }
  .section-head .intro{ font-size:15px }

  /* Companion cards — keep 2 columns on phones for browsing */
  .companions{ grid-template-columns:repeat(2,1fr); gap:14px }
  .body{ padding:14px 14px 16px }
  .nm{ font-size:19px }
  .aa{ font-size:13px; gap:5px }
  .nat-pill{ font-size:9.5px; padding:1px 5px }
  .lang{ font-size:10px; padding-top:10px }
  .card-wa{ font-size:11.5px; margin-top:8px }
  .card-wa .wa-ico{ width:13px; height:13px }
  .rate-wa{ font-size:11.5px }
  .companion-cta{ font-size:9.5px; margin-top:10px }

  /* "Other companions" on profile pages — 2 columns too */
  .other-grid{ grid-template-columns:repeat(2,1fr); gap:12px }
  .on{ font-size:17px }
  .oa{ font-size:13px }

  /* Gallery toolbar — full-width search, horizontally scrollable chips */
  .gallery-section{ padding-top:48px }
  .gal-toolbar{
    position:static; padding:14px; gap:12px;
    flex-direction:column; align-items:stretch;
  }
  .gal-search{ flex-basis:auto; min-width:0 }
  .gal-chips{
    flex-wrap:nowrap; overflow-x:auto; padding-bottom:4px;
    scrollbar-width:none; -webkit-overflow-scrolling:touch;
  }
  .gal-chips::-webkit-scrollbar{ display:none }
  .chip-label{ flex:0 0 auto; margin-right:4px }
  .chip{ flex:0 0 auto; padding:8px 13px; font-size:12px }
  .gal-sort{ width:100%; justify-content:space-between }
  .gal-sort select{ flex:1; margin-left:10px }
  .chip-clear{ margin-left:0; align-self:flex-end }

  /* WhatsApp area buttons — full-width and thumb-friendly */
  .wa-areas{ flex-direction:column; gap:10px }
  .btn-wa{ width:100%; justify-content:center; padding:14px 18px; font-size:13px }

  /* Contact / location cards — single column with bigger touch area */
  .contact-grid{ grid-template-columns:1fr; gap:14px; margin-top:28px }
  .contact-grid a{ padding:22px }
  .contact-grid .v{ font-size:21px }

  /* Profile page — better mobile layout */
  .profile{ padding:32px 16px 24px }
  .profile-meta h1{ font-size:40px }
  .prof-stats{ gap:12px 18px; font-size:14px }
  .prof-detail{ }
  .pd-grid{ padding:48px 16px; gap:32px }
  .prof-gallery{ padding:48px 16px }
  .gal-grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:160px; gap:10px }
  .gal-cell.gal-tall{ grid-row:span 2; grid-column:span 1 }
  .prof-other{ padding:48px 16px }
  .pd-rates{ padding:24px }
  .price-cta{ padding:24px }
  .price-cta h3{ font-size:24px }
  .interest-list{ grid-template-columns:1fr; gap:6px }
  .pd-block h3,.pd-rates h3{ font-size:22px }

  /* Footer compact on phone */
  footer.site{ padding:48px 16px 0 }
  footer.site .inner{ grid-template-columns:1fr; gap:32px }
  footer.site .brand-foot .nm{ font-size:28px }
  footer.site .copy{ margin-top:36px; padding:18px 0 }

  /* Hero foot links wrap nicely */
  .hero-foot{ font-size:12.5px; padding:14px 12px }
  .hero-foot a{ margin:0 10px }

  /* Legal pages compact */
  .legal{ padding:54px 16px }
  .legal h1{ font-size:34px }
  .legal h2{ font-size:21px }

  /* WhatsApp floating icon — slightly smaller on phones so it doesn't cover content */
  .wa-fab{ width:52px; height:52px; bottom:18px; right:18px }
  .wa-fab .wa-ico{ width:26px; height:26px }
}

@media (max-width:380px){
  .brand-name .script{ font-size:44px }
  .companions{ grid-template-columns:1fr }
  .gal-grid{ grid-template-columns:1fr; grid-auto-rows:240px }
  .gal-cell.gal-tall{ grid-row:span 1; grid-column:span 1 }
  .other-grid{ grid-template-columns:1fr }
}
