:root{
  --paper:#e8e4e0;--paper-deep:#ddd7cf;--paper-warm:#efeae3;
  --ink:#0c1115;--ink-soft:#2a2f36;--muted:#6b6860;
  --line:rgba(12,17,21,0.14);--accent:#b8935a;--accent-deep:#8e6e3e;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--paper);color:var(--ink);font-family:'Outfit',sans-serif;font-weight:300;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a,a:link,a:visited,a:hover,a:active,a:focus{color:inherit;text-decoration:none;border:none;outline:none}
.display,h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:300;letter-spacing:-0.01em;line-height:1.15;text-wrap:balance}
p{text-wrap:pretty}
.eyebrow{font-family:'Outfit',sans-serif;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--accent-deep);font-weight:500}
.italic{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300}

/* NAV — brand on left, menu on right, language flags on sub-bar below */
.nav{position:fixed;inset:0 0 auto 0;z-index:50;padding:.9rem 2rem .55rem;display:flex;flex-direction:column;gap:.35rem;background:transparent;transition:background .3s,color .3s,border-color .3s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(232,228,224,.94);backdrop-filter:blur(10px);border-bottom-color:var(--line)}
.nav-main{display:flex;align-items:center;justify-content:space-between;gap:2rem;width:100%}
.nav-sub{display:flex;justify-content:flex-end;width:100%;max-height:60px;opacity:1;overflow:hidden;padding:3px 0;transition:max-height .4s ease,opacity .3s ease,margin .4s ease,padding .4s ease}
.nav.scrolled .nav-sub{max-height:0;opacity:0;margin-top:-.35rem;padding-top:0;padding-bottom:0;pointer-events:none}
.nav .menu{display:flex;gap:1.8rem;font-family:'Cormorant Garamond',serif;font-size:.92rem;letter-spacing:.18em;text-transform:uppercase;color:#fff}
.nav.scrolled .menu{color:var(--ink)}
.nav .menu.right{justify-content:flex-end;align-items:center;flex-wrap:wrap}
.nav .menu a{padding:.2rem 0;transition:opacity .2s}
.nav .menu a:hover{opacity:.6}
/* Submenu: hover-activated dropdown anchored to its trigger. */
.nav .menu .menu-item{position:relative;display:inline-flex;align-items:center}
.nav .menu .menu-trigger{padding:.2rem 0;display:inline-flex;align-items:center;gap:.35rem;cursor:pointer;color:inherit;font:inherit;letter-spacing:inherit;text-transform:inherit;transition:opacity .2s}
.nav .menu .menu-trigger:hover{opacity:.6}
.nav .menu .menu-trigger::after{content:"";display:inline-block;width:.42rem;height:.42rem;border-right:1px solid currentColor;border-bottom:1px solid currentColor;transform:rotate(45deg) translate(-2px,-2px);transition:transform .25s ease;opacity:.75}
.nav .menu .menu-item:hover .menu-trigger::after,
.nav .menu .menu-item:focus-within .menu-trigger::after{transform:rotate(-135deg) translate(-2px,-2px)}
.nav .menu .submenu{position:absolute;top:calc(100% + .6rem);right:0;min-width:230px;background:rgba(12,17,21,.55);backdrop-filter:blur(14px) saturate(1.1);-webkit-backdrop-filter:blur(14px) saturate(1.1);border:1px solid rgba(255,255,255,.14);box-shadow:0 16px 40px -14px rgba(0,0,0,.5);padding:.5rem 0;display:flex;flex-direction:column;gap:0;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .22s ease,transform .22s ease,visibility .22s;z-index:60;color:#fff;letter-spacing:.14em}
.nav .menu .menu-item:hover .submenu,
.nav .menu .menu-item:focus-within .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.nav .menu .submenu a{display:block;padding:.6rem 1.2rem;font-size:.82rem;white-space:nowrap;color:#fff;opacity:.88;border-left:2px solid transparent;transition:background .2s,border-color .2s,color .2s,opacity .2s}
.nav .menu .submenu a:hover{background:rgba(255,255,255,.08);border-left-color:var(--accent);color:#fff;opacity:1}
.nav .brand{display:flex;align-items:center;gap:.75rem;text-align:left;color:#fff;transition:color .3s;flex-shrink:0}
.nav.scrolled .brand{color:var(--ink)}
.nav-langs{display:flex;gap:.55rem;align-items:center;padding:2px 3px}
.nav-langs .lang-flag{width:28px;height:28px;margin:2px}
.nav .brand-logo{width:46px;height:46px;object-fit:contain;border-radius:50%;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.nav .brand-text{display:flex;flex-direction:column;line-height:1.1}
.nav .brand-title{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:1.05rem;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap}
.nav .brand-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.68rem;letter-spacing:.12em;opacity:.85;margin-top:.15rem;white-space:nowrap}
.mobile-logo{width:70px;height:70px;object-fit:contain;margin-bottom:.5rem}
.mobile-title{font-family:'Cormorant Garamond',serif;font-size:1.15rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);margin-bottom:1rem;text-align:center}
.nav-spacer-left{display:none}
.hamburger{display:none;background:transparent;border:none;cursor:pointer;width:44px;height:44px;padding:0;position:relative;color:#fff;transition:color .3s}
.nav.scrolled .hamburger{color:var(--ink)}
.hamburger span{position:absolute;left:10px;right:10px;height:1.5px;background:currentColor;transition:transform .3s,opacity .2s,top .3s}
.hamburger span:nth-child(1){top:15px}.hamburger span:nth-child(2){top:22px}.hamburger span:nth-child(3){top:29px}
.hamburger.open span:nth-child(1){top:22px;transform:rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){top:22px;transform:rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;z-index:45;background:var(--paper);transform:translateX(100%);transition:transform .4s cubic-bezier(.2,.9,.2,1);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2rem;gap:1.1rem;overflow-y:auto}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu a{font-family:'Cormorant Garamond',serif;font-size:1.4rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);padding:.45rem 0}
.mobile-menu a:hover{color:var(--accent-deep)}
.mobile-menu .divider{width:40px;height:1px;background:var(--line);margin:.2rem 0}

/* HERO */
.hero{position:relative;width:100vw;height:100vh;min-height:640px;overflow:hidden}
.hero-inner{height:62vh;min-height:420px}
.hero-bg{position:absolute;inset:0;background-position:center;background-size:cover;background-repeat:no-repeat;filter:saturate(.95);z-index:0}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:1;pointer-events:none;filter:saturate(.95)}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.10) 0%,rgba(0,0,0,.25) 50%,rgba(0,0,0,.70) 100%);z-index:2;pointer-events:none}
@media (prefers-reduced-motion:reduce){.hero-video{display:none}}
.hero-content{position:relative;z-index:3;height:100%;width:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:7rem 3rem 3.5rem;color:#fff;max-width:1400px;margin:0 auto;text-align:right;align-items:flex-end;gap:1rem}
.hero-inner .hero-content{justify-content:flex-end;align-items:flex-end;text-align:right;padding:6rem 3rem 3rem}
.hero .eyebrow{color:#e8c98a}
.hero h1{font-size:clamp(1.7rem,3.2vw,2.9rem);font-weight:300;letter-spacing:-.01em;line-height:1.15;color:#fff;max-width:22ch;text-transform:none;text-wrap:balance}
.hero-inner h1{font-size:clamp(1.8rem,3.6vw,3rem);max-width:22ch}
.hero h1{text-transform:initial}
.hero-italic{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.05rem;max-width:34ch;opacity:.92;text-wrap:balance}
.hero .cta{display:inline-flex;align-items:center;padding:.95rem 2.2rem;background:transparent;border:1px solid rgba(255,255,255,.7);color:#fff;font-family:'Outfit',sans-serif;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;transition:all .25s;margin-top:.4rem}
.hero .cta:hover{background:#fff;color:var(--ink)}
.scroll-hint{position:absolute;left:50%;bottom:1.8rem;transform:translateX(-50%);z-index:3;color:#fff;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.9rem;letter-spacing:.08em;opacity:.75}
.scroll-hint::after{content:"";display:block;width:1px;height:28px;background:#fff;margin:.6rem auto 0;opacity:.5}

/* ARTICLE — 25% / 50% / 25% layout (content = middle 50%) */
.article{width:50%;max-width:50%;margin:0 auto;padding:5.5rem 0}
@media (max-width:1400px){.article{width:62%;max-width:62%}}
@media (max-width:1100px){.article{width:75%;max-width:75%}}
@media (max-width:900px){.article{width:auto;max-width:100%;padding:3.5rem 1.2rem}}
.article p{font-size:1.06rem;margin-bottom:1.3rem;color:var(--ink-soft)}
.split:first-of-type .split-text p:first-of-type{font-size:1.2rem;font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;color:var(--ink);margin-bottom:1.5rem;line-height:1.5}

/* SPLIT blocks — side-by-side: square thumbnail on one side, text on the other.
   Thumbnails open the full-size image via lightbox (auto-wired in lightbox.js). */
/* .split now uses CSS float so the text flows UNDER the thumbnail
   once the paragraphs exceed the image's height — instead of leaving
   a tall empty column beside it. Alternating left/right is kept. */
.split{margin:4.5rem 0;overflow:hidden}
.split::after{content:"";display:block;clear:both}
.split-full{max-width:100%}
.text-only{margin:4.5rem auto;max-width:640px;display:block}
.text-only .split-text{text-align:left}
.split-img{position:relative;margin:.35rem 0 1rem;overflow:hidden;border:1px solid var(--line);background:var(--paper-deep);aspect-ratio:1/1;width:220px;max-width:40%;box-shadow:0 10px 28px -16px rgba(12,17,21,.35);transition:box-shadow .35s,transform .35s;cursor:zoom-in;shape-outside:margin-box}
.split-img-right .split-img{float:right;margin-left:2.4rem;margin-right:0}
.split-img-left .split-img{float:left;margin-right:2.4rem;margin-left:0}
.split-img::after{content:"";position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
.split-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease;display:block}
.split:hover .split-img{box-shadow:0 18px 40px -18px rgba(12,17,21,.5);transform:translateY(-2px)}
.split:hover .split-img img{transform:scale(1.05)}
.split-text{text-align:left;min-width:0}
.split-text>*:first-child{margin-top:0 !important}
.split-text p{text-align:justify;hyphens:auto}
.split-text h2.sec-h2,.split-text h3.sec-h3{text-align:left}
.split-text h2.sec-h2{margin-top:0;line-height:1.15}
.split-text h2.sec-h2::after{content:"";display:block;width:42px;height:1px;background:var(--accent);margin:1.1rem 0 1.6rem}
@media (max-width:700px){
  .split-img-right .split-img,.split-img-left .split-img{float:none;width:220px;max-width:100%;margin:0 auto 1.4rem}
  .split-text h2.sec-h2::after{margin:1.1rem auto 1.6rem}
  .split-text h2.sec-h2,.split-text h3.sec-h3{text-align:center}
}
.article h2.sec-h2{font-size:clamp(1.7rem,2.8vw,2.3rem);margin:2.8rem 0 1rem;color:var(--ink)}
.article h3.sec-h3{font-size:1.3rem;margin:2rem 0 .8rem;color:var(--ink);letter-spacing:.02em}
.article h4.sec-h4{font-size:1.05rem;margin:1.5rem 0 .6rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent-deep);font-family:'Outfit',sans-serif;font-weight:500}
.article ul.bullets{margin:1rem 0 2rem;padding-left:1.4rem}
.article ul.bullets li{margin-bottom:.6rem;font-size:1.04rem;color:var(--ink-soft);list-style:square}
.article blockquote{border-left:2px solid var(--accent);padding:.4rem 0 .4rem 1.4rem;margin:2rem 0;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.2rem;color:var(--ink)}

/* VIDEO — all tiles normalized to the same height so horizontal & vertical share visual footprint */
.video-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:1.5rem;margin:3rem auto;max-width:1100px}
.yt-wrap{position:relative;height:460px;background:var(--paper-deep);overflow:hidden;border:1px solid var(--line);flex:0 0 auto}
.yt-wrap.horizontal{aspect-ratio:16/9;width:auto;max-width:100%}
.yt-wrap.vertical{aspect-ratio:9/16;width:auto}
.yt-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* GALLERY */
.gallery{max-width:1100px;margin:3rem auto 1rem;padding:0 1.5rem}
.gallery .g-inner{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,220px));gap:1rem;justify-content:center}
.gallery-lg .g-inner{grid-template-columns:repeat(auto-fit,minmax(160px,200px));gap:.8rem;justify-content:center}
/* 3-up grid — 3 columnas fijas de cuadrados 1:1 para agrupar miniaturas relacionadas */
.gallery-3up{max-width:560px}
.gallery-3up .g-inner{grid-template-columns:repeat(3,1fr);gap:.7rem;justify-content:center}
.gallery-caption{text-align:center;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.95rem;color:var(--muted);margin:1rem auto 0;max-width:520px;letter-spacing:.02em;line-height:1.5}
@media (max-width:700px){.gallery-3up{max-width:360px}.gallery-3up .g-inner{gap:.5rem}}
.g-tile{position:relative;overflow:hidden;aspect-ratio:1/1;background:var(--paper-deep);border:1px solid var(--line);box-shadow:0 10px 28px -16px rgba(12,17,21,.3);transition:box-shadow .35s,transform .35s;cursor:zoom-in}
.g-tile img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.g-tile:hover{box-shadow:0 18px 40px -18px rgba(12,17,21,.5);transform:translateY(-2px)}
.g-tile:hover img{transform:scale(1.06)}

/* FAQ accordion — semantic <details>/<summary>. No JS required. Answers stay
   in the DOM (SEO/AEO-friendly — LLMs read the full text). Gold chevron rotates
   180° on open. Editorial serif summaries match the sober Portuguese aesthetic.
   This block is AEO-ready: in Phase 2 we'll wrap it with FAQPage JSON-LD. */
.faq{max-width:820px;margin:5rem auto 4rem;padding:0 1.2rem}
.faq-head{text-align:center;margin-bottom:2.5rem}
.faq-eyebrow{display:inline-block;font-family:'Outfit',sans-serif;font-size:.68rem;letter-spacing:.32em;text-transform:uppercase;color:var(--accent-deep);font-weight:500;padding-bottom:.9rem;position:relative}
.faq-eyebrow::after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:36px;height:1px;background:var(--accent)}
.faq-title{font-family:'Cormorant Garamond',serif;font-size:clamp(1.7rem,3vw,2.2rem);font-weight:400;color:var(--ink);margin:1.2rem 0 0;text-wrap:balance;line-height:1.2}
.faq-list{border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{list-style:none;cursor:pointer;padding:1.45rem 2.6rem 1.45rem 0;font-family:'Cormorant Garamond',serif;font-size:1.22rem;font-weight:500;color:var(--ink);position:relative;outline:none;transition:color .25s;text-wrap:pretty;line-height:1.35}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"";position:absolute;right:.5rem;top:50%;width:.55rem;height:.55rem;border-right:1.5px solid var(--accent-deep);border-bottom:1.5px solid var(--accent-deep);transform:translateY(-75%) rotate(45deg);transition:transform .3s ease}
.faq-item[open] summary::after{transform:translateY(-25%) rotate(-135deg)}
.faq-item summary:hover{color:var(--accent-deep)}
.faq-item[open] summary{color:var(--accent-deep)}
.faq-answer{padding:.2rem 1.8rem 1.7rem 0;font-family:'Cormorant Garamond',serif;font-size:1.05rem;line-height:1.65;color:var(--muted);text-wrap:pretty}
.faq-answer p{margin:0 0 .9rem}
.faq-answer p:last-child{margin-bottom:0}
@media (max-width:700px){
  .faq{margin:3.5rem auto 3rem}
  .faq-item summary{font-size:1.08rem;padding:1.15rem 2rem 1.15rem 0}
  .faq-answer{font-size:1rem;padding-right:1rem}
}

/* Related pages — "Ver também" block. Editorial card grid that closes a page
   before the final CTA. 1:1 thumbnail, serif title, italic lead, subtle arrow.
   Semantic <aside role="complementary"> so LLM crawlers read it as "related
   content", not as primary nav. Anchors use descriptive page titles (keyword-
   aligned) rather than "ver mais" — internal-link equity for SEO. */
.related{max-width:1080px;margin:5rem auto 3.5rem;padding:0 1rem}
.related-head{text-align:center;margin-bottom:2.2rem}
.related-eyebrow{display:inline-block;font-family:'Outfit',sans-serif;font-size:.68rem;letter-spacing:.32em;text-transform:uppercase;color:var(--accent-deep);font-weight:500;padding-bottom:.9rem;position:relative}
.related-eyebrow::after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:36px;height:1px;background:var(--accent)}
.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.6rem}
.rel-card{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);overflow:hidden;position:relative;transition:box-shadow .4s ease,transform .4s ease,border-color .4s ease;color:inherit;text-decoration:none}
.rel-card:hover{box-shadow:0 22px 50px -22px rgba(12,17,21,.35);transform:translateY(-3px);border-color:var(--accent)}
.rel-img{aspect-ratio:1/1;overflow:hidden;background:var(--paper-deep);position:relative}
.rel-img img{width:100%;height:100%;object-fit:cover;transition:transform .9s ease;display:block}
.rel-card:hover .rel-img img{transform:scale(1.06)}
.rel-body{padding:1.3rem 1.35rem 1.5rem;display:flex;flex-direction:column;gap:.55rem;position:relative}
.rel-kicker{font-family:'Outfit',sans-serif;font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:var(--accent-deep);font-weight:500}
.rel-title{font-family:'Cormorant Garamond',serif;font-size:1.35rem;font-weight:500;line-height:1.25;color:var(--ink);margin:0;text-wrap:balance}
.rel-lede{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1rem;line-height:1.5;color:var(--muted);margin:0;text-wrap:pretty}
.rel-arrow{margin-top:.4rem;font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--accent-deep);transition:transform .35s ease,color .3s;align-self:flex-start;display:inline-flex;align-items:center;gap:.4rem}
.rel-arrow::before{content:"";display:inline-block;width:22px;height:1px;background:currentColor;transition:width .35s ease}
.rel-card:hover .rel-arrow{color:var(--ink)}
.rel-card:hover .rel-arrow::before{width:38px}
@media (max-width:720px){
  .related{margin:3.5rem auto 2.5rem}
  .related-grid{grid-template-columns:1fr;gap:1.2rem}
  .rel-title{font-size:1.2rem}
}

/* Contact block */
.contact-block{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin:3rem 0}
.contact-card{padding:1.8rem;background:var(--paper-warm);border:1px solid var(--line)}
.contact-card h3{font-size:.76rem;letter-spacing:.24em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:.8rem;font-family:'Outfit',sans-serif;font-weight:500}
.contact-card p{font-family:'Cormorant Garamond',serif;font-size:1.15rem;color:var(--ink);margin:0}
.contact-card a{border-bottom:1px solid var(--line);padding-bottom:2px}

/* CLIENTS — confiaram nos meus serviços. Exact replica of siluetista.com structure,
   adapted to the cream light theme. Each span mimics its brand's typography. */
.clients-section{background:var(--paper-warm);padding:3.5rem 3rem;text-align:center;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.clients-section .clients-label{font-family:'Outfit',sans-serif;font-size:.6rem;letter-spacing:.4em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:2rem;font-weight:500}
.clients-grid{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:0;max-width:1100px;margin:0 auto}
.cl{padding:1rem 2rem;font-family:'Outfit',sans-serif;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(12,17,21,0.42);font-weight:400;transition:color .4s;white-space:nowrap}
.cl:hover{color:rgba(12,17,21,0.82)}
.cl-serif{font-family:'Cormorant Garamond',serif;font-size:1.15rem;letter-spacing:.08em;text-transform:none;font-weight:500}
.cl-bold{font-weight:600;font-size:.9rem;letter-spacing:.12em}
.cl-light{font-weight:300;font-size:.8rem;letter-spacing:.22em}
.cl-wide{letter-spacing:.3em;font-size:.74rem}
.cl-more{color:var(--accent);font-style:italic;font-family:'Cormorant Garamond',serif;font-size:.95rem;letter-spacing:.05em;text-transform:none}
@media (max-width:900px){
  .clients-section{padding:2.5rem 1.2rem}
  .cl{padding:.55rem 1rem;font-size:.7rem}
  .cl-serif{font-size:.95rem}
}

/* FAQ — Card Soft accordion. Rounded cream cards, soft shadow on open,
   chevron that rotates 180°. Cream-warm fill matches the clients strip. */
.faq-section{background:var(--paper);padding:5rem 2rem;border-top:1px solid var(--line)}
.faq-wrap{max-width:820px;margin:0 auto}
.faq-kicker{display:block;text-align:center;margin-bottom:.7rem}
.faq-h2{text-align:center;font-family:'Cormorant Garamond',serif;font-size:clamp(1.9rem,3vw,2.6rem);font-weight:300;margin-bottom:2.8rem;color:var(--ink);letter-spacing:.01em}
.acc-soft details{background:var(--paper-warm);border:1px solid var(--line);border-radius:14px;margin-bottom:.8rem;overflow:hidden;transition:box-shadow .4s,border-color .4s}
.acc-soft details[open]{box-shadow:0 10px 32px -14px rgba(12,17,21,.18);border-color:rgba(12,17,21,.24)}
.acc-soft summary{list-style:none;cursor:pointer;padding:1.35rem 1.6rem;display:flex;align-items:center;gap:1.2rem}
.acc-soft summary::-webkit-details-marker{display:none}
.acc-soft summary:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:14px}
.acc-soft .fq{font-family:'Outfit',sans-serif;font-weight:400;font-size:1rem;letter-spacing:.01em;color:var(--ink);flex:1;line-height:1.45}
.acc-soft .fic{width:22px;height:22px;flex-shrink:0;transition:transform .4s ease;display:flex;align-items:center;justify-content:center}
.acc-soft .fic svg{width:100%;height:100%;stroke:var(--accent-deep);fill:none;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
.acc-soft details[open] .fic{transform:rotate(180deg)}
.acc-soft .fpanel{padding:0 1.6rem 1.4rem;border-top:1px solid var(--line);padding-top:1.1rem;margin-top:-.1rem}
.acc-soft .fpanel p{font-size:.98rem;color:var(--ink-soft);margin:0;line-height:1.65}
@media (max-width:900px){
  .faq-section{padding:3rem 1rem}
  .acc-soft summary{padding:1.1rem 1.2rem;gap:.9rem}
  .acc-soft .fq{font-size:.95rem}
  .acc-soft .fpanel{padding:0 1.2rem 1.1rem;padding-top:.9rem}
}

/* BLOG INDEX — card grid + pagination */
.blog-index{padding:4rem 2rem 3rem;background:var(--paper)}
.blog-wrap{max-width:1280px;margin:0 auto}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2.2rem;justify-content:center}
.post-card{background:var(--paper-warm);border:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .35s,transform .35s}
.post-card:hover{box-shadow:0 18px 40px -18px rgba(12,17,21,.22);transform:translateY(-2px)}
.post-card-img{display:block;overflow:hidden;aspect-ratio:4/3;background:var(--paper-deep)}
.post-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease;display:block}
.post-card:hover .post-card-img img{transform:scale(1.05)}
.post-card-body{padding:1.5rem 1.5rem 1.8rem;flex:1;display:flex;flex-direction:column}
.post-card-date{font-family:'Outfit',sans-serif;font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:.6rem;font-weight:500}
.post-card-title{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:clamp(1.25rem,1.8vw,1.55rem);line-height:1.22;color:var(--ink);margin-bottom:.75rem;letter-spacing:.005em}
.post-card-title a{color:inherit;transition:color .25s}
.post-card-title a:hover{color:var(--accent-deep)}
.post-card-excerpt{font-size:.97rem;color:var(--ink-soft);margin-bottom:1.2rem;flex:1;line-height:1.55}
.post-card-more{margin-top:auto;font-family:'Outfit',sans-serif;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-deep);font-weight:500;display:inline-flex;gap:.5rem;align-items:center}
.post-card-more span{transition:transform .3s}
.post-card-more:hover span{transform:translateX(4px)}

.pg-nav{display:flex;justify-content:center;gap:.5rem;margin:3.5rem 0 .5rem;flex-wrap:wrap}
.pg-link{padding:.65rem 1rem;border:1px solid var(--line);font-family:'Outfit',sans-serif;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);background:var(--paper-warm);transition:all .25s}
.pg-link:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.pg-cur{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* POST META (on individual blog posts) */
.post-meta{display:flex;justify-content:space-between;align-items:center;padding:0 0 2rem;margin-bottom:1rem;border-bottom:1px solid var(--line);flex-wrap:wrap;gap:1rem}
.post-back{font-family:'Outfit',sans-serif;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-deep);transition:color .25s;font-weight:500}
.post-back:hover{color:var(--ink)}
.post-date{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.95rem;color:var(--muted);letter-spacing:.04em}
@media (max-width:900px){
  .blog-grid{grid-template-columns:1fr;gap:1.8rem}
  .blog-index{padding:2.5rem 1rem}
  .post-card-body{padding:1.3rem 1.3rem 1.5rem}
  .pg-nav{margin-top:2.5rem}
}

/* CTA inline — the a.btn-dark selector beats the generic a:link color:inherit reset */
.article-cta{padding-top:3rem;padding-bottom:2rem}
.cta-inline{text-align:center;margin:2rem 0 1rem}
a.btn-dark,a.btn-dark:link,a.btn-dark:visited{display:inline-block;padding:1.1rem 2.8rem;background:#6b5847;color:var(--paper);font-family:'Outfit',sans-serif;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;transition:all .25s;border:1px solid #6b5847}
a.btn-dark:hover,a.btn-dark:focus{background:#5c4a3a;border-color:#5c4a3a;color:var(--paper)}
/* btn-dark with inline WhatsApp icon — icon sits neatly before the label */
a.btn-wa,a.btn-wa:link,a.btn-wa:visited{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;padding:1.1rem 2.4rem;line-height:1}
a.btn-wa .wa-ic{width:18px;height:18px;flex:0 0 18px;fill:#25D366;display:inline-block;vertical-align:middle}
a.btn-wa span{display:inline-block;vertical-align:middle}
/* Contact intro block — replaces heavy WA photo split */
.contact-intro{margin:0 auto 3rem;max-width:640px;text-align:center}
.contact-intro h2{margin-bottom:.8rem}
.contact-intro p{margin:0 auto 1.2rem;max-width:56ch}

/* FOOTER — minimal: brand left, language flags right */
.footer{padding:3rem 2rem 1.8rem;border-top:1px solid var(--line);background:var(--paper);margin-top:5rem}
.footer-inner{max-width:1300px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap;padding-bottom:1.8rem;border-bottom:1px solid var(--line)}
.foot-brand{display:flex;align-items:center;gap:.9rem;color:var(--ink);transition:opacity .25s}
.foot-brand:hover{opacity:.75}
.foot-brand .foot-logo{width:54px;height:54px;object-fit:contain;flex-shrink:0}
.foot-brand .foot-title{font-family:'Cormorant Garamond',serif;font-size:1.1rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);white-space:nowrap}
.foot-langs{display:flex;gap:.55rem;align-items:center;flex-wrap:wrap;padding:4px 2px}
.foot-langs .lang-flag{width:28px;height:28px}
.lang-flag{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;transition:background .22s,transform .25s,box-shadow .25s;margin:2px;overflow:hidden;isolation:isolate;background:rgba(12,17,21,.58);backdrop-filter:blur(14px) saturate(1.1);-webkit-backdrop-filter:blur(14px) saturate(1.1);border:1px solid rgba(255,255,255,.14);box-shadow:0 2px 8px -3px rgba(0,0,0,.4)}
.lang-flag .lang-svg{width:100%;height:100%;display:block;border-radius:50%}
.lang-flag .lang-svg circle{fill:transparent!important;stroke:rgba(255,255,255,.22)!important}
.lang-flag:hover{background:rgba(12,17,21,.7);transform:translateY(-1px) scale(1.06);box-shadow:0 6px 14px -6px rgba(0,0,0,.5)}
.lang-flag-active{background:rgba(0,0,0,.82);border-color:rgba(255,255,255,.26);pointer-events:none;cursor:default;box-shadow:0 2px 10px -3px rgba(0,0,0,.55),inset 0 0 0 1px rgba(255,255,255,.06)}
.lang-flag-active:hover{background:rgba(0,0,0,.82);transform:none}
.lang-flag-active .lang-svg circle{stroke:rgba(255,255,255,.32)!important}

/* Mobile menu — language flags row inside the overlay */
.mobile-divider-wide{width:60%;height:1px;background:var(--line);margin:1.2rem 0 .6rem}
.mobile-langs{display:flex;gap:.9rem;align-items:center;justify-content:center;flex-wrap:wrap;padding:.5rem 4px 1.2rem}
.mobile-langs .lang-flag{width:40px;height:40px;margin:2px}
.foot-bottom{max-width:1300px;margin:1.4rem auto 0;display:flex;flex-direction:column;align-items:center;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);gap:.9rem;text-align:center}

/* Contact — disclosure card */
.disclosure-card{max-width:880px;margin:2.4rem auto;padding:1.8rem 2rem;border:1px solid var(--line);border-radius:10px;background:var(--paper-warm,#efeae3);box-shadow:0 1px 0 rgba(12,17,21,.04) inset}
.disclosure-card h2{margin:0 0 .8rem;font-family:'Cormorant Garamond',serif;font-size:1.45rem;font-weight:500;color:var(--ink);letter-spacing:.01em}
.disclosure-card p{margin:0 0 .75rem;line-height:1.7;color:var(--ink-soft,#2a2f36);font-size:.98rem}
.disclosure-card p:last-child{margin-bottom:0}

/* Contact — form */
.contact-form-wrap{max-width:880px;margin:2.8rem auto 3rem;padding:0 1rem}
.contact-form-wrap h2{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:1.9rem;color:#f5cf7a;margin:0 0 .5rem}
.form-intro{color:var(--muted);font-size:.94rem;margin:0 0 1.6rem;line-height:1.6}
.contact-form{display:block}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem 1.2rem}
.field{display:flex;flex-direction:column;gap:.35rem}
.field-full{grid-column:1 / -1}
.field-label{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:500}
.field input,.field select,.field textarea{background:rgba(255,255,255,.02);border:1px solid rgba(245,207,122,.18);border-radius:6px;padding:.75rem .9rem;color:#eadfc8;font-family:inherit;font-size:.98rem;transition:border-color .2s,background .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:rgba(245,207,122,.55);background:rgba(245,207,122,.04)}
.field textarea{resize:vertical;min-height:120px;line-height:1.55}
.form-submit{margin-top:1.4rem;display:flex;flex-wrap:wrap;gap:1rem 1.4rem;align-items:center}
.form-privacy{font-size:.78rem;color:var(--muted);max-width:480px;line-height:1.55;opacity:.85}
@media (max-width:640px){.form-grid{grid-template-columns:1fr}}
.foot-travel{font-size:.75rem;letter-spacing:.02em;text-transform:none;color:var(--muted);max-width:720px;line-height:1.55;margin:0;opacity:.85}
.foot-bottom a{color:inherit;text-decoration:underline;text-decoration-color:rgba(245,207,122,.35);text-underline-offset:3px}
.foot-bottom a:hover{text-decoration-color:rgba(245,207,122,.85)}

/* RESPONSIVE */
@media (max-width:900px){
  .nav{padding:.7rem 1rem .5rem;gap:0}
  .nav-main{gap:.75rem}
  .nav .menu{display:none}
  .nav-sub{display:none}
  /* Allow brand to shrink so the hamburger never overflows on narrow iOS widths */
  .nav .brand{min-width:0;flex-shrink:1}
  .nav .brand-logo{width:40px;height:40px;flex-shrink:0}
  .nav .brand-text{min-width:0}
  .nav .brand-title{font-size:.92rem;letter-spacing:.08em;overflow:hidden;text-overflow:ellipsis}
  .hamburger{display:block;filter:drop-shadow(0 1px 2px rgba(0,0,0,.55));z-index:55;flex-shrink:0}
  .hamburger span{height:2px;background:#fff;box-shadow:0 1px 0 rgba(0,0,0,.35)}
  .nav.scrolled .hamburger span{background:var(--ink);box-shadow:none}
  .hero,.hero-inner{height:62vh;min-height:420px;max-height:640px}
  .hero-bg{background-position:center 30%}
  .hero-content{padding:5rem 1.3rem 2rem;max-width:100%;gap:.75rem}
  .hero-inner .hero-content{padding:4.5rem 1.3rem 2rem}
  /* Mobile only: eyebrow moves below the CTA, as a subtle footer line inside the hero */
  .hero .hero-content > .eyebrow{order:2;margin-top:.9rem;opacity:.85}
  .hero h1{font-size:clamp(1.45rem,5.4vw,2.2rem);max-width:14ch}
  .hero-inner h1{font-size:clamp(1.4rem,5.2vw,2rem);max-width:14ch;line-height:1.18}
  .hero-italic{font-size:.95rem;max-width:28ch}
  .hero .eyebrow{font-size:.68rem}
  .hero .cta{padding:.8rem 1.6rem;font-size:.7rem}
  .article{padding:3.5rem 1.2rem}
  .article h2.sec-h2{font-size:1.55rem;margin-top:2rem}
  /* Mobile: thumbnail square centered, text below. Same 1:1 format as desktop. */
  .split{margin:2.8rem 0}
  .split-img,.split-img-left .split-img,.split-img-right .split-img{float:none;width:180px;max-width:60%;aspect-ratio:1/1;margin:0 auto 1.4rem}
  .split-text{max-width:100%}
  .split-text p{text-align:left;hyphens:none}
  .shorts-row{grid-template-columns:1fr;max-width:320px}
  .contact-block{grid-template-columns:1fr}
  .footer-inner{flex-direction:column;text-align:center;gap:1.5rem}
  .foot-brand .foot-title{font-size:1rem;letter-spacing:.14em}
  .foot-langs{justify-content:center}
  .foot-bottom{gap:.7rem}
  .foot-travel{font-size:.72rem}
}
@media (max-width:480px){
  .mobile-menu a{font-size:1.2rem}
  .article p:first-of-type{font-size:1.08rem}
  /* Very narrow phones: keep only the logo + hamburger, title/subtitle live in the open mobile menu */
  .nav .brand-text{display:none}
  .nav .brand-logo{width:38px;height:38px}
}

/* ===========================================================================
   BANDS SYSTEM — 13-band editorial body layout.
   Translated from siluetista.com's dark palette to silhueta.vip's light cream+gold.
   Palette mapping: siluetista `--paper`(#0a0a0a) → `--paper`(#e8e4e0),
   `--warm`(#111) → `--paper-warm`(#efeae3), `--cream`(#141414) → `--paper-deep`(#ddd7cf),
   `--ink`(#f0ece4) → `--ink`(#0c1115), `--gold`(#d4a843) → `--accent`(#b8935a).
   The dark bands in siluetista.com (stats, about) keep their high-contrast feel
   here by using `--ink` as the background — ink-on-cream is the visual equivalent.
   =========================================================================== */

/* Local helpers — accent-wash replaces siluetista's --gold-light rgba tint */
.bands{--accent-wash:rgba(184,147,90,.10);--accent-line:rgba(184,147,90,.22)}

/* Generic section-tag (kicker used by every band) */
.band-tag{display:block;font-family:'Outfit',sans-serif;font-size:.6rem;letter-spacing:.4em;text-transform:uppercase;color:var(--accent-deep);font-weight:500;margin-bottom:1rem}
.band h2 em,.band h2 .gold{font-style:italic;color:var(--accent-deep);font-weight:400}

/* ——— TERMINOLOGY (def-grid) ——— */
.terminology{background:var(--paper-warm);padding:6rem 3rem;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.terminology-inner{max-width:1050px;margin:0 auto}
.terminology .band-tag{text-align:center}
.terminology h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.9rem,2.8vw,2.8rem);font-weight:300;text-align:center;margin-bottom:3.5rem;line-height:1.3;color:var(--ink)}
.def-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.def-card{background:var(--paper);padding:2.5rem;border-left:2px solid var(--accent);border-top:1px solid var(--line);border-right:1px solid var(--line);border-bottom:1px solid var(--line);box-shadow:0 8px 24px -16px rgba(12,17,21,.18)}
.def-word{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:400;color:var(--ink);margin-bottom:.35rem}
.def-origin{font-size:.7rem;letter-spacing:.08em;color:var(--accent-deep);margin-bottom:1rem;font-style:italic}
.def-text{font-size:.92rem;line-height:1.78;color:var(--ink-soft);margin-bottom:1rem}
.def-note{font-size:.82rem;line-height:1.68;color:var(--ink);background:var(--accent-wash,rgba(184,147,90,.10));padding:1rem 1.2rem;border:1px solid var(--accent-line,rgba(184,147,90,.22))}

/* ——— INTRO ——— */
.band-intro{max-width:900px;margin:0 auto;padding:7rem 2rem;text-align:center;background:var(--paper)}
.band-intro h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,3vw,2.7rem);font-weight:300;line-height:1.35;margin-bottom:1.8rem;color:var(--ink)}
.band-intro p{font-size:1.02rem;line-height:1.9;color:var(--ink-soft);max-width:620px;margin:0 auto}

/* ——— STATS — dark band of metrics ——— */
.band-stats{display:grid;grid-template-columns:repeat(4,1fr);background:linear-gradient(180deg,#6b5847 0%,#5c4a3a 100%);border-top:1px solid rgba(232,228,224,.18);border-bottom:1px solid rgba(232,228,224,.18)}
.band-stat{padding:3.5rem 2rem;text-align:center;border-right:1px solid rgba(232,228,224,.10)}
.band-stat:last-child{border-right:none}
.band-stat-num{font-family:'Cormorant Garamond',serif;font-size:3.2rem;color:var(--accent);line-height:1;font-weight:300}
.band-stat-label{font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(232,228,224,.62);margin-top:.6rem;font-family:'Outfit',sans-serif;font-weight:400}

/* ——— VIDEO SECTION (2-col) ——— */
.band-video{padding:7rem 3rem;max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;background:var(--paper)}
.band-video .video-text h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,2.5vw,2.6rem);font-weight:300;line-height:1.3;margin-bottom:1.4rem;color:var(--ink)}
.band-video .video-text p{font-size:.95rem;line-height:1.86;color:var(--ink-soft);margin-bottom:1rem}
.band-video .video-wrap iframe{display:block;width:100%;aspect-ratio:1/1;border:1px solid var(--line)}
.band-video .video-caption{margin-top:.75rem;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);text-align:center;font-family:'Outfit',sans-serif}

/* ——— WHY — 2-col with portrait + reasons list ——— */
.why{padding:6rem 3rem 7rem;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;max-width:1300px;margin:0 auto;background:var(--paper)}
.why-img img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:center;border:1px solid var(--line);box-shadow:0 14px 42px -18px rgba(12,17,21,.28)}
.why-img-caption{margin-top:1rem;font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-family:'Outfit',sans-serif}
.why-content{padding-top:1rem}
.why-content h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.9rem,2.6vw,2.6rem);font-weight:300;line-height:1.28;margin-bottom:2.4rem;color:var(--ink)}
.reason-item{padding:1.4rem 0;border-bottom:1px solid var(--line)}
.reason-item:first-of-type{border-top:1px solid var(--line)}
.reason-item h3{font-family:'Cormorant Garamond',serif;font-size:1.18rem;font-weight:500;margin-bottom:.5rem;display:flex;align-items:center;gap:.75rem;color:var(--ink)}
.rnum{font-family:'Outfit',sans-serif;font-size:.66rem;color:var(--accent-deep);letter-spacing:.1em;width:30px;height:30px;border:1px solid var(--accent);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:500}
.reason-item p{font-size:.92rem;line-height:1.8;color:var(--ink-soft);padding-left:calc(30px + .75rem);margin:0}

/* ——— EVENTS SECTION — 3-up cards ——— */
.events-section{padding:5rem 3rem 7rem;max-width:1300px;margin:0 auto;background:var(--paper)}
.events-header{text-align:center;margin-bottom:3rem}
.events-header h2{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,3vw,2.8rem);font-weight:300;color:var(--ink)}
.events-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line)}
.event-card{background:var(--paper-warm);padding:2.6rem 2rem;transition:background .4s,transform .4s;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.6rem}
.event-card:hover{background:var(--accent-wash,rgba(184,147,90,.10));transform:translateY(-2px)}
.event-card .eicon{font-size:1.6rem;margin-bottom:.6rem;opacity:.75;color:var(--accent-deep)}
.event-card h3{font-family:'Cormorant Garamond',serif;font-size:1.32rem;font-weight:500;color:var(--ink);margin:0}
.event-card p{font-size:.9rem;line-height:1.78;color:var(--ink-soft);margin:0}
.event-card .etag{display:inline-block;margin-top:.8rem;font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--accent-deep);border:1px solid var(--accent);padding:.4rem .9rem;font-family:'Outfit',sans-serif;font-weight:500}

/* ——— CITIES — tags strip ——— */
.cities{background:var(--paper-warm);padding:5rem 3rem;text-align:center;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cities h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.6rem,2.4vw,2.1rem);font-weight:300;margin-bottom:.8rem;color:var(--ink)}
.cities p{color:var(--ink-soft);font-size:.95rem;margin:0 auto 2.2rem;max-width:520px;line-height:1.78}
.city-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:.55rem;max-width:820px;margin:0 auto}
.city-tag{padding:.45rem 1.1rem;border:1px solid var(--line);font-size:.78rem;color:var(--ink-soft);background:var(--paper);letter-spacing:.06em;transition:all .3s;font-family:'Outfit',sans-serif;font-weight:400}
.city-tag:hover{border-color:var(--accent);color:var(--accent-deep)}
.city-tag-base{background:var(--accent);color:#fff;border-color:var(--accent-deep);font-weight:500;letter-spacing:.08em}
.city-tag-base:hover{background:var(--accent-deep);color:#fff}

/* ——— ACTION — 2-col image + text with cred box ——— */
.action{display:grid;grid-template-columns:1fr 1fr;align-items:center;max-width:1300px;margin:6rem auto;padding:0 3rem;gap:5rem}
.action-img img{width:100%;aspect-ratio:4/3;object-fit:cover;border:1px solid var(--line);box-shadow:0 18px 48px -22px rgba(12,17,21,.25)}
.action-text h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,2.5vw,2.5rem);font-weight:300;line-height:1.32;margin-bottom:1.4rem;color:var(--ink)}
.action-text p{font-size:.96rem;line-height:1.86;color:var(--ink-soft);margin-bottom:1rem}
.action-cred{margin-top:1.6rem;padding:1.2rem 1.5rem;background:var(--accent-wash,rgba(184,147,90,.10));border-left:2px solid var(--accent)}
.action-cred p{font-size:.86rem;line-height:1.7;color:var(--ink);margin:0}
.action-cred strong{color:var(--accent-deep);font-weight:500}

/* ——— VS — comparison table ——— */
.vs{padding:0 3rem 7rem;max-width:1050px;margin:0 auto;background:var(--paper)}
.vs-header{text-align:center;margin-bottom:2.5rem}
.vs-header h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,2.5vw,2.5rem);font-weight:300;color:var(--ink)}
.vs-table{width:100%;border-collapse:collapse;background:var(--paper);border:1px solid var(--line)}
.vs-table th{padding:1rem 1.2rem;font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--paper);text-align:left;background:var(--ink);font-family:'Outfit',sans-serif;font-weight:500}
.vs-table th:not(:first-child){text-align:center}
.vs-table td{padding:.95rem 1.2rem;font-size:.86rem;color:var(--ink-soft);border-bottom:1px solid var(--line)}
.vs-table tr:last-child td{border-bottom:none}
.vs-table td:first-child{color:var(--ink);font-weight:400}
.vs-table td:not(:first-child){text-align:center}
.vs-table tr:hover td{background:var(--accent-wash,rgba(184,147,90,.08))}
.chk{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;font-size:.9rem;font-weight:400}
.chk.yes{color:var(--accent-deep)}
.chk.no{color:rgba(12,17,21,.18)}
.chk.mid{color:rgba(12,17,21,.32)}

/* ——— TESTIMONIALS — 3 starred cards ——— */
.testimonials{padding:6rem 3rem;max-width:1150px;margin:0 auto;background:var(--paper)}
.testimonials .band-tag{text-align:center}
.testimonials h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.9rem,2.6vw,2.6rem);font-weight:300;text-align:center;margin-bottom:3rem;color:var(--ink)}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line)}
.test-card{padding:2.4rem 2rem;background:var(--paper-warm);border-top:2px solid var(--accent)}
.test-stars{color:var(--accent);font-size:.85rem;margin-bottom:1.1rem;letter-spacing:.18em}
.test-text{font-family:'Cormorant Garamond',serif;font-size:1.08rem;font-style:italic;line-height:1.68;color:var(--ink);margin-bottom:1.3rem;font-weight:300}
.test-author{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-family:'Outfit',sans-serif;font-weight:500}

/* ——— ABOUT — dark band with portrait ——— */
.about{display:grid;grid-template-columns:1fr 1fr;background:var(--ink);color:#f0ece4}
.about-img{overflow:hidden;min-height:520px;background:var(--ink);display:flex;align-items:center;justify-content:center}
.about-img img{width:100%;height:100%;object-fit:cover;object-position:center 22%;display:block}
.about-content{padding:5rem 4.5rem;display:flex;flex-direction:column;justify-content:center}
.about-content .band-tag{color:var(--accent)}
.about-content h2{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,2.5vw,2.6rem);font-weight:300;line-height:1.3;margin-bottom:1.8rem;color:#f0ece4}
.about-content h2 em{font-style:italic;color:var(--accent)}
.about-content p{font-size:.96rem;line-height:1.86;color:rgba(240,236,228,.78);margin-bottom:1.1rem}

/* ——— CONTACT — 2-col info + form ——— */
.band-contact{padding:7rem 3rem;background:var(--paper-warm);border-top:1px solid var(--line)}
.contact-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.contact-info h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.9rem,2.8vw,2.6rem);font-weight:300;line-height:1.28;margin-bottom:1.4rem;color:var(--ink)}
.contact-info h2 em{font-style:italic;color:var(--accent-deep)}
.contact-info p{font-size:.96rem;line-height:1.86;color:var(--ink-soft);margin-bottom:1rem}
.contact-urgency{font-size:.85rem;color:var(--ink);letter-spacing:.02em;margin-top:1.4rem!important;background:var(--accent-wash,rgba(184,147,90,.10));padding:.9rem 1.1rem;border-left:2px solid var(--accent)}
.wa-btn{display:inline-block;margin-top:1.6rem;transition:opacity .3s}
.wa-btn:hover{opacity:.85}
.contact-form{background:var(--paper);padding:2.4rem;border:1px solid var(--line);box-shadow:0 14px 42px -20px rgba(12,17,21,.22)}
.form-title{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:500;margin-bottom:1.6rem;color:var(--ink)}
.form-row{margin-bottom:1.1rem}
.form-row label{display:block;font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:.4rem;font-family:'Outfit',sans-serif;font-weight:500}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:.8rem 1rem;border:1px solid var(--line);background:var(--paper-warm);font-family:'Outfit',sans-serif;font-size:.9rem;color:var(--ink);outline:none;transition:border-color .3s;appearance:none;border-radius:0;font-weight:300}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--accent)}
.form-row textarea{resize:vertical;min-height:100px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-submit{display:flex;align-items:center;gap:1rem;margin-top:.4rem;flex-wrap:wrap}
.btn-form{padding:.95rem 2.2rem;background:#6b5847;color:var(--paper);border:none;font-family:'Outfit',sans-serif;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:all .3s;font-weight:500}
.btn-form:hover{background:#5c4a3a}
.form-note{font-size:.72rem;color:var(--muted);font-family:'Outfit',sans-serif}
.form-success{display:none;margin-top:1rem;padding:1.2rem 1.4rem;background:#eef6ee;border:1px solid #bcd9bc;color:#2c5a2c;font-family:'Outfit',sans-serif;font-size:.9rem;line-height:1.5;border-radius:2px}

/* ——— BANDS RESPONSIVE ——— */
@media (max-width:900px){
  .terminology{padding:3.5rem 1.3rem}
  .terminology h2{margin-bottom:2.2rem}
  .def-grid{grid-template-columns:1fr;gap:1.2rem}
  .def-card{padding:1.8rem}
  .band-intro{padding:4rem 1.3rem}
  .band-stats{grid-template-columns:repeat(2,1fr)}
  .band-stat{padding:2.4rem 1rem;border-right:none;border-bottom:1px solid rgba(232,228,224,.10)}
  .band-stat:nth-child(2n){border-right:none}
  .band-stat:nth-last-child(-n+2){border-bottom:none}
  .band-stat-num{font-size:2.6rem}
  .band-video{grid-template-columns:1fr;gap:2.4rem;padding:4rem 1.3rem}
  .why{grid-template-columns:1fr;padding:4rem 1.3rem;gap:2.6rem}
  .why-content{padding-top:0}
  .events-section{padding:3rem 1.3rem 4.5rem}
  .events-grid{grid-template-columns:1fr}
  .cities{padding:3.5rem 1.3rem}
  .action{grid-template-columns:1fr;gap:2rem;margin:4rem auto;padding:0 1.3rem}
  .vs{padding:0 1rem 4.5rem}
  .vs-table th,.vs-table td{padding:.7rem .6rem;font-size:.78rem}
  .vs-table th{font-size:.58rem}
  .testimonials{padding:4rem 1.3rem}
  .test-grid{grid-template-columns:1fr}
  .about{grid-template-columns:1fr}
  .about-img{min-height:68vw}
  .about-content{padding:3rem 1.4rem}
  .band-contact{padding:4rem 1.3rem}
  .contact-inner{grid-template-columns:1fr;gap:2.4rem}
  .form-grid{grid-template-columns:1fr}
}

/* LIGHTBOX — overlay a juego con la paleta (tinta profunda + crema).
   Botones redondos, flechas finas, contador y pie discretos. */
.split-img img,.g-tile img{cursor:zoom-in}
.lbx-ov{position:fixed;inset:0;z-index:120;background:rgba(12,17,21,.92);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .28s ease;padding:3rem 4rem}
.lbx-ov.lbx-open{opacity:1;pointer-events:auto}
.lbx-stage{display:flex;flex-direction:column;align-items:center;justify-content:center;max-width:100%;max-height:100%;gap:.9rem;margin:0}
.lbx-img{max-width:min(1200px,90vw);max-height:85vh;width:auto;height:auto;object-fit:contain;box-shadow:0 30px 80px -30px rgba(0,0,0,.7);background:var(--paper-deep);display:block}
.lbx-caption{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.95rem;color:rgba(255,255,255,.78);text-align:center;max-width:60ch;letter-spacing:.02em;line-height:1.5}
.lbx-counter{position:absolute;top:1.3rem;left:50%;transform:translateX(-50%);font-family:'Outfit',sans-serif;font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(245,207,122,.85);font-weight:500}
.lbx-close,.lbx-prev,.lbx-next{position:absolute;background:rgba(232,228,224,.08);border:1px solid rgba(232,228,224,.25);color:#f3ede4;cursor:pointer;transition:background .25s,border-color .25s,transform .25s;-webkit-tap-highlight-color:transparent}
.lbx-close:hover,.lbx-prev:hover,.lbx-next:hover{background:rgba(232,228,224,.18);border-color:rgba(232,228,224,.55)}
.lbx-close{top:1.1rem;right:1.1rem;width:44px;height:44px;border-radius:50%;font-size:1.1rem;line-height:1;display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif}
.lbx-prev,.lbx-next{top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;font-size:1.8rem;line-height:1;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif}
.lbx-prev{left:1.2rem}
.lbx-next{right:1.2rem}
.lbx-prev:hover{transform:translateY(-50%) translateX(-2px)}
.lbx-next:hover{transform:translateY(-50%) translateX(2px)}
@media (max-width:700px){
  .lbx-ov{padding:2rem .6rem}
  .lbx-img{max-width:92vw;max-height:72vh}
  .lbx-prev,.lbx-next{width:42px;height:42px;font-size:1.5rem}
  .lbx-prev{left:.4rem}.lbx-next{right:.4rem}
  .lbx-close{top:.6rem;right:.6rem;width:40px;height:40px}
  .lbx-counter{top:.85rem;font-size:.65rem}
  .lbx-caption{font-size:.88rem;padding:0 .8rem}
}

/* Explore band — internal linking hub */
.explore.band{background:#faf6ef;border-top:1px solid rgba(184,154,110,.22);border-bottom:1px solid rgba(184,154,110,.22);padding:4.5rem 1.5rem}
.explore .band-inner{max-width:1200px;margin:0 auto}
.explore .band-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(1.8rem,3.5vw,2.6rem);color:#1a1815;margin:.2rem 0 .6rem;letter-spacing:-.01em}
.explore .band-lede{font-size:1.02rem;color:#5c5a54;max-width:640px;line-height:1.55;margin:0 0 2.4rem}
.explore-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.explore-col{background:#fff;border:1px solid rgba(184,154,110,.18);border-radius:6px;padding:1.6rem 1.4rem}
.explore-h3{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:1.2rem;color:#2a2824;margin:0 0 1rem;padding-bottom:.6rem;border-bottom:1px solid rgba(184,154,110,.2)}
.explore-list{list-style:none;padding:0;margin:0}
.explore-list li{font-size:.92rem;line-height:1.45;color:#4a4842;margin-bottom:.85rem;padding-left:1em;position:relative}
.explore-list li::before{content:"›";position:absolute;left:0;color:var(--accent-deep);font-weight:600}
.explore-list a{color:#1a1815;text-decoration:none;border-bottom:1px solid rgba(184,154,110,.35);transition:border-color .2s}
.explore-list a:hover{border-color:var(--accent-deep)}
@media(max-width:960px){
  .explore-grid{grid-template-columns:1fr;gap:1.2rem}
  .explore.band{padding:3rem 1rem}
}

/* Portfolio gallery band on /imagenes/ */
.gallery.band{background:#faf6ef;border-top:1px solid rgba(184,154,110,.22);border-bottom:1px solid rgba(184,154,110,.22);padding:5rem 1.5rem}
.gallery .band-inner{max-width:1200px;margin:0 auto}
.gallery h2{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(1.9rem,3.5vw,2.6rem);color:#1a1815;margin:.2rem 0 .6rem;letter-spacing:-.01em;line-height:1.25}
.gal-lead{font-size:1.02rem;color:#5c5a54;max-width:720px;line-height:1.65;margin:0 0 2.4rem}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.gal-item{margin:0;background:#fff;border:1px solid rgba(184,154,110,.18);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s}
.gal-item:hover{transform:translateY(-2px);box-shadow:0 12px 28px -16px rgba(42,40,36,.28)}
.gal-item picture,.gal-item img{display:block;width:100%;height:auto}
.gal-item img{aspect-ratio:4/3;object-fit:cover;background:#eee}
.gal-item figcaption{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.92rem;color:#4a4842;padding:.9rem 1rem 1.1rem;line-height:1.35;border-top:1px solid rgba(184,154,110,.15)}
.gal-note{font-size:.92rem;color:#5c5a54;margin:2rem 0 0;text-align:center}
.gal-note a{color:#1a1815;border-bottom:1px solid rgba(184,154,110,.4)}
@media(max-width:900px){.gal-grid{grid-template-columns:repeat(2,1fr);gap:1rem}}
@media(max-width:560px){.gal-grid{grid-template-columns:1fr}.gallery.band{padding:3rem 1rem}}

/* Legal pages (Privacidade / Termos) */
.article-legal{max-width:780px;margin:0 auto;padding:4rem 1.6rem 6rem;font-family:'Outfit',sans-serif;color:#2a2824;line-height:1.75;font-size:1rem}
.article-legal h2{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:1.5rem;color:#1a1815;margin:3rem 0 1rem;line-height:1.3;padding-bottom:.5rem;border-bottom:1px solid rgba(184,154,110,.22)}
.article-legal p{margin:0 0 1.1rem;color:#3a3832}
.article-legal ul{margin:.2rem 0 1.2rem;padding-left:1.4rem}
.article-legal li{margin-bottom:.55rem;color:#3a3832}
.article-legal a{color:#7a5a2e;border-bottom:1px solid rgba(184,154,110,.4);text-decoration:none;transition:border-color .2s}
.article-legal a:hover{border-color:#7a5a2e}
.article-legal .legal-meta{font-family:'Outfit',sans-serif;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:#8a8680;margin:0 0 2.5rem;padding:.5rem 0;border-bottom:1px solid rgba(184,154,110,.18)}
.article-legal strong{color:#1a1815;font-weight:500}
@media (max-width:700px){.article-legal{padding:2.5rem 1.2rem 4rem}.article-legal h2{font-size:1.3rem;margin-top:2.2rem}}

/* 404 page — centered tiles grid + CTA */
.not-found-hero{height:48vh;min-height:380px}
.not-found{padding:4rem 1.5rem 6rem;max-width:980px;margin:0 auto}
.not-found .container{max-width:880px;margin:0 auto;text-align:center}
.not-found .lead{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:1.35rem;line-height:1.55;color:#2a2824;margin:0 auto 2.5rem;max-width:58ch;text-wrap:balance}
.nf-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:2rem 0 3rem}
.nf-tile{display:flex;flex-direction:column;padding:1.5rem 1.2rem;border:1px solid rgba(184,154,110,.25);background:rgba(255,252,246,.5);text-align:left;transition:background .25s,border-color .25s,transform .25s}
.nf-tile:hover{background:#fff;border-color:rgba(184,154,110,.55);transform:translateY(-2px)}
.nf-tile-title{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:400;color:#1a1815;letter-spacing:.04em;margin-bottom:.3rem}
.nf-tile-sub{font-family:'Outfit',sans-serif;font-size:.84rem;color:#5c5a54;line-height:1.45}
.nf-cta{font-family:'Outfit',sans-serif;font-size:.95rem;color:#4a4842;margin-top:2.5rem;line-height:1.6}
.nf-cta a{color:#7a5a2e;border-bottom:1px solid rgba(184,154,110,.4)}
@media(max-width:760px){.nf-tiles{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.nf-tiles{grid-template-columns:1fr}.not-found-hero{height:38vh;min-height:300px}}

/* Case study pages — expanded editorial layout */
.case-study .lead{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:1.28rem;line-height:1.55;color:#2a2824;margin:0 0 1rem;text-wrap:balance}
.band-case{background:rgba(245,238,226,.6);padding:2.5rem 0;margin:2.5rem 0}
.case-meta{max-width:1000px;margin:0 auto;padding:0 1.5rem}
.case-facts{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem 2rem}
.case-facts li{display:flex;flex-direction:column;gap:.35rem}
.cf-label{font-family:'Outfit',sans-serif;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:#7a5a2e;font-weight:500}
.cf-value{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:#1a1815;line-height:1.35}
.band-quote{padding:3rem 1.5rem;background:#1a1815;color:#f5eee2;margin:3rem 0}
.band-quote .container{max-width:780px;margin:0 auto}
.quote-large{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.55rem;line-height:1.45;text-wrap:balance;margin:0}
.quote-large p{margin:0 0 1.2rem}
.quote-large footer{font-family:'Outfit',sans-serif;font-style:normal;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(245,238,226,.6);font-weight:400}
.band-cta{background:rgba(255,252,246,.4);padding:3rem 1.5rem;margin-top:3rem;text-align:center}
.band-cta .container{max-width:780px;margin:0 auto}
.band-cta h2{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:1.6rem;margin:0 0 1rem}
.band-cta p{font-family:'Outfit',sans-serif;color:#3a3832;line-height:1.7;margin:0}
.band-cta a{color:#7a5a2e;border-bottom:1px solid rgba(184,154,110,.4);transition:border-color .2s}
.band-cta a:hover{border-color:#7a5a2e}
@media(max-width:760px){.case-facts{grid-template-columns:repeat(2,1fr);gap:1.2rem 1.5rem}.quote-large{font-size:1.25rem}}
@media(max-width:460px){.case-facts{grid-template-columns:1fr}}
