/* ============================================================
   Rent & Travel — modern travel-journal design system
   Palette: warm cream + slate-ink + coral + sun-gold
   Type: Sora (display) / Figtree (text)
   ============================================================ */

:root{
  --ink:#1f2630;            /* slate near-black (matches logo badge) */
  --ink-2:#2b3742;
  --ink-soft:#4a5662;
  --bg:#fbf6ee;             /* warm cream page */
  --bg-2:#f4ebdc;           /* deeper sand */
  --bg-3:#efe4d2;
  --paper:#fffdf9;          /* card surface */
  --coral:#ec6736;          /* primary accent */
  --coral-2:#f2855c;
  --coral-deep:#cf5021;
  --sun:#f4a623;            /* secondary accent (logo sun) */
  --sun-deep:#d98a0c;
  --sea:#1f6f6a;            /* tertiary, used sparingly */
  --muted:#7b8590;
  --muted-2:#9aa3ad;
  --line:#e9dec9;           /* hairline on cream */
  --line-2:#ddd0b7;
  --white:#ffffff;
  --shadow:0 22px 60px -28px rgba(31,38,48,.34);
  --shadow-sm:0 10px 30px -18px rgba(31,38,48,.30);
  --shadow-card:0 14px 40px -26px rgba(31,38,48,.40);
  --radius:20px;
  --radius-sm:13px;
  --radius-lg:30px;
  --maxw:1220px;
  --display:"Sora",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --text:"Figtree",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--text);
  font-size:18px;
  line-height:1.72;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--coral-deep);text-decoration:none;transition:color .15s ease}
a:hover{color:var(--coral)}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.1;color:var(--ink);margin:0 0 .5em;letter-spacing:-.01em}
h1{font-size:clamp(2.3rem,5.4vw,4rem);font-weight:800;letter-spacing:-.025em}
h2{font-size:clamp(1.7rem,3.4vw,2.5rem)}
h3{font-size:1.32rem}
p{margin:0 0 1.15em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.container-narrow{max-width:760px;margin:0 auto;padding:0 24px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--display);font-weight:600;font-size:.97rem;
  padding:.82em 1.5em;border-radius:999px;cursor:pointer;border:1.6px solid transparent;
  transition:transform .14s ease,box-shadow .2s ease,background .2s ease,color .2s ease;
  white-space:nowrap;letter-spacing:.005em;
}
.btn-primary{background:var(--coral);color:#fff;box-shadow:0 12px 26px -12px rgba(207,80,33,.7)}
.btn-primary:hover{background:var(--coral-deep);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--ink);color:var(--ink);transform:translateY(-2px)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000;color:#fff;transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{background:#fff;transform:translateY(-2px)}

/* ---------- topbar ---------- */
.topbar{background:var(--ink);color:#d9dde2;font-size:.8rem;letter-spacing:.04em}
.topbar .container{display:flex;justify-content:space-between;align-items:center;min-height:38px;gap:16px}
.topbar a{color:#d9dde2}
.topbar a:hover{color:var(--sun)}
.topbar .tb-tag{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:500;text-transform:uppercase;font-size:.7rem;letter-spacing:.16em}
.topbar .tb-tag::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--coral)}
.topbar .tb-links{display:flex;gap:20px}
.topbar .tb-links span{color:#7f8893}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(251,246,238,.86);backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:28px;min-height:76px}
.brand{display:flex;align-items:center;gap:13px;flex-shrink:0}
.brand img{width:46px;height:46px;border-radius:13px;box-shadow:0 8px 18px -10px rgba(31,38,48,.55)}
.brand .bt{display:flex;flex-direction:column;line-height:1}
.brand .bt b{font-family:var(--display);font-weight:800;font-size:1.28rem;color:var(--ink);letter-spacing:-.02em}
.brand .bt b span{color:var(--coral)}
.brand .bt small{font-family:var(--display);font-weight:500;font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);margin-top:3px}
.nav{display:flex;align-items:center;gap:6px;margin-left:auto}
.nav a{font-family:var(--display);font-weight:500;font-size:.96rem;color:var(--ink-2);padding:.5em .85em;border-radius:9px}
.nav a:hover{color:var(--coral-deep);background:var(--bg-2)}
.nav a.active{color:var(--coral-deep)}
.header-cta{margin-left:8px}
.menu-toggle{display:none;margin-left:auto;background:none;border:1.6px solid var(--line-2);border-radius:11px;width:46px;height:46px;cursor:pointer;color:var(--ink)}
.menu-toggle svg{width:22px;height:22px;display:block;margin:auto}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;background:var(--ink)}
.hero-media{position:absolute;inset:0}
.hero-media img{width:100%;height:100%;object-fit:cover;opacity:.62}
.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,25,32,.55) 0%,rgba(20,25,32,.32) 38%,rgba(20,25,32,.78) 100%)}
.hero-inner{position:relative;z-index:2;padding:108px 0 96px;color:#fff}
.hero-eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.2em;font-size:.74rem;color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.26);padding:.55em 1.05em;border-radius:999px;margin-bottom:24px}
.hero-eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--coral)}
.hero h1{color:#fff;max-width:16ch;margin-bottom:.4em;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero h1 em{font-style:normal;color:var(--sun)}
.hero-lead{font-size:1.22rem;line-height:1.6;max-width:48ch;color:#f1ece4;margin-bottom:30px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:40px}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:500;font-size:.88rem;color:#fff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.24);padding:.5em 1em;border-radius:999px;transition:background .18s ease,transform .14s ease}
.chip:hover{background:rgba(255,255,255,.2);color:#fff;transform:translateY(-2px)}
.chip svg{width:15px;height:15px}

/* ---------- section scaffolding ---------- */
.section{padding:84px 0}
.section.tight{padding:60px 0}
.section.alt{background:var(--bg-2)}
.section.ink{background:var(--ink)}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.18em;font-size:.76rem;color:var(--coral-deep);margin-bottom:14px}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--coral);border-radius:2px}
.section-head{margin-bottom:42px;max-width:680px}
.section-head.row{display:flex;justify-content:space-between;align-items:flex-end;max-width:none;gap:24px}
.section-head p{color:var(--ink-soft);font-size:1.08rem;margin:0}
.section-head .link-more{font-family:var(--display);font-weight:600;font-size:.95rem;flex-shrink:0;display:inline-flex;align-items:center;gap:6px}
.section-head .link-more svg{width:17px;height:17px}

/* ---------- cards ---------- */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .25s ease}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-card)}
.card-media{position:relative;aspect-ratio:16/10;overflow:hidden}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.card:hover .card-media img{transform:scale(1.05)}
.tag{position:absolute;top:14px;left:14px;font-family:var(--display);font-weight:600;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);background:rgba(255,255,255,.92);padding:.42em .8em;border-radius:999px;backdrop-filter:blur(4px)}
.tag.coral{background:var(--coral);color:#fff}
.tag.sun{background:var(--sun);color:var(--ink)}
.tag.sea{background:var(--sea);color:#fff}
.card-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.card-body h3{margin-bottom:.4em;letter-spacing:-.01em}
.card-body h3 a{color:var(--ink)}
.card-body h3 a:hover{color:var(--coral-deep)}
.card .excerpt{color:var(--ink-soft);font-size:1rem;margin-bottom:18px;flex:1}
.meta{display:flex;align-items:center;gap:10px;font-size:.82rem;color:var(--muted);font-family:var(--display);font-weight:500;margin-top:auto}
.meta .dot{width:3px;height:3px;border-radius:50%;background:var(--muted-2)}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}

/* ---------- asymmetric featured grid ---------- */
.feature-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:30px}
.feature-grid .lead .card-media{aspect-ratio:16/11}
.feature-grid .lead h3{font-size:1.9rem}
.feature-grid .stack{display:flex;flex-direction:column;gap:30px}
.feature-grid .stack .card{flex-direction:row}
.feature-grid .stack .card-media{aspect-ratio:1/1;width:44%;flex-shrink:0}
.feature-grid .stack .card-body{padding:20px 22px}
.feature-grid .stack .card-body h3{font-size:1.18rem}
.feature-grid .stack .excerpt{display:none}

/* ---------- regions ---------- */
.regions{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.region{position:relative;border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:3/4;display:block;box-shadow:var(--shadow-sm)}
.region img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.region:hover img{transform:scale(1.07)}
.region::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,25,32,0) 35%,rgba(20,25,32,.78) 100%)}
.region span{position:absolute;left:0;right:0;bottom:14px;z-index:2;text-align:center;color:#fff;font-family:var(--display);font-weight:600;font-size:.95rem;letter-spacing:.01em}
.region small{display:block;font-size:.68rem;font-weight:400;color:#d7dbe0;letter-spacing:.06em}

/* ---------- voice / about strip ---------- */
.voice{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.voice .v-media{position:relative}
.voice .v-media img{border-radius:var(--radius);box-shadow:var(--shadow)}
.voice .v-badge{position:absolute;right:-18px;bottom:-18px;background:var(--coral);color:#fff;border-radius:18px;padding:18px 22px;box-shadow:var(--shadow);max-width:200px}
.voice .v-badge b{font-family:var(--display);font-weight:800;font-size:1.9rem;display:block;line-height:1}
.voice .v-badge span{font-size:.86rem;color:#ffe9df}
.voice h2{margin-bottom:.5em}
.voice p{color:var(--ink-soft)}
.signoff{display:flex;align-items:center;gap:14px;margin-top:26px}
.signoff .sig{font-family:var(--display);font-weight:700;color:var(--ink)}
.signoff small{color:var(--muted);font-size:.85rem}

/* ---------- popular numbered list ---------- */
.poplist{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 56px}
.popitem{display:flex;gap:20px;padding:22px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.popitem .num{font-family:var(--display);font-weight:800;font-size:1.6rem;color:var(--coral);line-height:1;min-width:42px}
.popitem h4{font-family:var(--display);font-weight:600;font-size:1.1rem;margin:0 0 4px}
.popitem h4 a{color:var(--ink)}
.popitem h4 a:hover{color:var(--coral-deep)}
.popitem p{margin:0;font-size:.9rem;color:var(--muted)}

/* ---------- newsletter ---------- */
.news{background:var(--ink);border-radius:var(--radius-lg);padding:62px 64px;color:#fff;position:relative;overflow:hidden}
.news::before{content:"";position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(236,103,54,.5),transparent 68%);top:-160px;right:-120px}
.news::after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(244,166,35,.32),transparent 68%);bottom:-150px;left:-90px}
.news-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
.news h2{color:#fff;margin-bottom:.4em}
.news p{color:#c8cdd4;margin:0}
.news-form{display:flex;flex-direction:column;gap:12px}
.news-form .row{display:flex;gap:12px}
.field{flex:1;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.18);border-radius:13px;padding:.95em 1.1em;color:#fff;font-family:var(--text);font-size:1rem;transition:border .18s ease,background .18s ease}
.field::placeholder{color:#9aa3ad}
.field:focus{outline:none;border-color:var(--coral);background:rgba(255,255,255,.12)}
.news-form small{color:#9aa3ad;font-size:.8rem}
.form-note{font-size:.92rem;margin-top:6px;min-height:1.2em}
.form-note.ok{color:#7fd6a3}
.form-note.err{color:#ff9b86}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#c4cad1;padding:74px 0 32px;font-size:.95rem}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand .brand b{color:#fff}
.footer-brand .brand small{color:var(--muted)}
.footer-brand p{margin:18px 0 0;color:#9aa3ad;max-width:34ch;font-size:.92rem}
.footer-col h5{font-family:var(--display);font-weight:600;color:#fff;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin:0 0 16px}
.footer-col a{display:block;color:#aeb5bd;padding:5px 0;font-size:.93rem}
.footer-col a:hover{color:var(--sun)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:18px;padding-top:26px;color:#8b939c;font-size:.84rem;flex-wrap:wrap}
.footer-bottom .fb-links{display:flex;gap:18px;flex-wrap:wrap}
.footer-bottom a{color:#8b939c}
.footer-bottom a:hover{color:var(--sun)}

/* ---------- page hero (interior) ---------- */
.page-hero{background:var(--bg-2);border-bottom:1px solid var(--line);padding:64px 0 56px}
.page-hero .eyebrow{margin-bottom:16px}
.page-hero h1{max-width:18ch;margin-bottom:.3em}
.page-hero p{font-size:1.16rem;color:var(--ink-soft);max-width:62ch;margin:0}
.crumbs{font-family:var(--display);font-size:.82rem;color:var(--muted);margin-bottom:18px;font-weight:500}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--coral-deep)}

/* ---------- article ---------- */
.article-hero{position:relative;height:clamp(360px,52vh,560px);overflow:hidden;background:var(--ink)}
.article-hero img{width:100%;height:100%;object-fit:cover;opacity:.72}
.article-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,25,32,.25),rgba(20,25,32,.82))}
.article-hero-inner{position:absolute;left:0;right:0;bottom:0;z-index:2;padding-bottom:46px}
.article-hero .tag{position:static;display:inline-block;margin-bottom:18px}
.article-hero h1{color:#fff;max-width:20ch;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.article-hero .a-meta{display:flex;gap:12px;align-items:center;color:#e3e6ea;font-family:var(--display);font-weight:500;font-size:.9rem;margin-top:14px}
.article-hero .a-meta .dot{width:3px;height:3px;border-radius:50%;background:#cfd4da}

.article-wrap{padding:64px 0 40px}
.prose{font-size:1.14rem;line-height:1.82;color:#303a44}
.prose>p:first-of-type{font-size:1.24rem;color:var(--ink-2)}
.prose .dropcap::first-letter{float:left;font-family:var(--display);font-weight:800;font-size:3.6rem;line-height:.82;padding:6px 12px 0 0;color:var(--coral)}
.prose h2{margin:1.7em 0 .55em;font-size:1.72rem}
.prose h2::before{content:"";display:block;width:42px;height:3px;background:var(--coral);border-radius:3px;margin-bottom:.6em}
.prose h3{margin:1.5em 0 .4em;font-size:1.28rem}
.prose p{margin:0 0 1.25em}
.prose ul,.prose ol{margin:0 0 1.4em;padding-left:1.3em}
.prose li{margin-bottom:.6em}
.prose ul li::marker{color:var(--coral)}
.prose a{text-decoration:underline;text-decoration-color:var(--coral-2);text-underline-offset:3px}
.prose figure{margin:2.2em 0}
.prose figure img{border-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}
.prose figcaption{font-size:.86rem;color:var(--muted);margin-top:10px;text-align:center;font-family:var(--display);font-weight:500}
.pullquote{margin:2em 0;padding:6px 0 6px 28px;border-left:4px solid var(--coral);font-family:var(--display);font-weight:600;font-size:1.5rem;line-height:1.35;color:var(--ink);letter-spacing:-.01em}
.factbox{background:var(--bg-2);border:1px solid var(--line);border-left:4px solid var(--sun);border-radius:var(--radius-sm);padding:26px 30px;margin:2em 0}
.factbox h4{font-family:var(--display);font-weight:700;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sun-deep);margin:0 0 14px}
.factbox ul{margin:0;padding-left:1.1em}
.factbox li{margin-bottom:.5em;font-size:1rem;color:var(--ink-2)}
.factbox.sea{border-left-color:var(--sea)}
.factbox.sea h4{color:var(--sea)}
.factbox.coral{border-left-color:var(--coral)}
.factbox.coral h4{color:var(--coral-deep)}
.keytakes{background:var(--ink);color:#fff;border-radius:var(--radius);padding:34px 36px;margin:2.4em 0}
.keytakes h4{color:#fff;font-family:var(--display);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;margin:0 0 16px;color:var(--sun)}
.keytakes ul{margin:0;padding-left:1.1em}
.keytakes li{margin-bottom:.6em;color:#dfe3e8}
.keytakes li::marker{color:var(--coral-2)}

.author-box{display:flex;gap:18px;align-items:center;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:24px 26px;margin:46px 0 0}
.author-box .av{width:60px;height:60px;border-radius:50%;background:var(--coral);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:800;font-size:1.3rem;flex-shrink:0}
.author-box b{font-family:var(--display);font-size:1.02rem}
.author-box p{margin:.25em 0 0;font-size:.92rem;color:var(--muted)}

.share{display:flex;align-items:center;gap:12px;margin:34px 0 0;font-family:var(--display);font-weight:500;font-size:.9rem;color:var(--muted)}
.share a{width:38px;height:38px;border-radius:50%;border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;color:var(--ink)}
.share a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.share a svg{width:17px;height:17px}

.related{border-top:1px solid var(--line);margin-top:60px;padding-top:50px}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px}
.info-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:30px 32px;margin-bottom:22px;box-shadow:var(--shadow-sm)}
.info-card h3{font-size:1.12rem;margin-bottom:14px}
.info-row{display:flex;gap:14px;align-items:flex-start;padding:11px 0;border-bottom:1px dashed var(--line)}
.info-row:last-child{border-bottom:0}
.info-row .ic{width:40px;height:40px;border-radius:11px;background:var(--bg-2);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--coral-deep)}
.info-row .ic svg{width:19px;height:19px}
.info-row b{font-family:var(--display);font-size:.96rem;display:block;margin-bottom:1px}
.info-row span,.info-row a{color:var(--ink-soft);font-size:.96rem}
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow-sm)}
.form-card label{display:block;font-family:var(--display);font-weight:500;font-size:.86rem;margin:0 0 7px;color:var(--ink-2)}
.form-field{width:100%;background:var(--bg);border:1.5px solid var(--line-2);border-radius:12px;padding:.85em 1em;font-family:var(--text);font-size:1rem;color:var(--ink);margin-bottom:18px;transition:border .16s ease,background .16s ease}
.form-field:focus{outline:none;border-color:var(--coral);background:#fff}
textarea.form-field{min-height:140px;resize:vertical}
.map-embed{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);margin-top:8px}
.map-embed iframe{display:block;width:100%;height:300px;border:0;filter:saturate(.92)}

/* ---------- legal ---------- */
.legal{padding:56px 0 80px}
.legal .prose h2{font-size:1.4rem}
.legal .prose h2::before{display:none}
.legal-toc{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:22px 26px;margin-bottom:38px}
.legal-toc h4{font-family:var(--display);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:0 0 12px}
.legal-toc ol{margin:0;padding-left:1.3em;columns:2;column-gap:34px}
.legal-toc li{margin-bottom:7px;font-size:.94rem}
.updated{font-family:var(--display);font-size:.85rem;color:var(--muted);margin-bottom:8px}

/* ---------- misc ---------- */
.pill-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.pill{font-family:var(--display);font-weight:500;font-size:.85rem;color:var(--ink-2);background:var(--paper);border:1px solid var(--line-2);padding:.5em 1.05em;border-radius:999px}
.pill.active,.pill:hover{background:var(--coral);color:#fff;border-color:var(--coral)}
.lead-note{font-size:1.16rem;color:var(--ink-soft)}
.divider{height:1px;background:var(--line);margin:0}
.center{text-align:center}
.mt-0{margin-top:0}

/* ---------- cookie banner ---------- */
.cookie{position:fixed;left:20px;right:20px;bottom:20px;z-index:90;max-width:560px;margin:0 auto;background:var(--ink);color:#e7e9ec;border-radius:18px;padding:22px 24px;box-shadow:0 24px 60px -20px rgba(0,0,0,.5);display:none;gap:18px;align-items:center}
.cookie.show{display:flex}
.cookie p{margin:0;font-size:.9rem;color:#c4cad1}
.cookie a{color:var(--sun)}
.cookie .cookie-actions{display:flex;gap:10px;flex-shrink:0}
.cookie .btn{padding:.6em 1.1em;font-size:.86rem}

/* ---------- toast ---------- */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(120%);background:var(--ink);color:#fff;padding:14px 22px;border-radius:12px;box-shadow:var(--shadow);z-index:120;font-family:var(--display);font-weight:500;font-size:.92rem;transition:transform .35s cubic-bezier(.2,.8,.2,1);max-width:90vw}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.ok{background:#1f6f4a}
.toast.err{background:#a23a28}

/* ---------- responsive ---------- */
@media(max-width:1000px){
  .feature-grid{grid-template-columns:1fr}
  .regions{grid-template-columns:repeat(3,1fr)}
  .voice{grid-template-columns:1fr;gap:40px}
  .voice .v-media{order:-1}
  .news-inner{grid-template-columns:1fr;gap:30px}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .contact-grid{grid-template-columns:1fr;gap:34px}
  .poplist{grid-template-columns:1fr;gap:0}
}
@media(max-width:780px){
  body{font-size:17px}
  .nav{display:none}
  .nav.open{display:flex;position:absolute;top:76px;left:0;right:0;flex-direction:column;align-items:stretch;background:var(--bg);border-bottom:1px solid var(--line);padding:14px 24px 22px;gap:2px;box-shadow:var(--shadow)}
  .nav.open a{padding:.8em .6em;border-radius:10px}
  .nav.open .btn-primary{margin-top:10px;justify-content:center}
  .menu-toggle{display:flex}
  .grid-3,.grid-2{grid-template-columns:1fr}
  .feature-grid .stack .card{flex-direction:column}
  .feature-grid .stack .card-media{width:100%;aspect-ratio:16/10}
  .feature-grid .stack .excerpt{display:block}
  .regions{grid-template-columns:repeat(2,1fr)}
  .section{padding:60px 0}
  .news{padding:42px 28px}
  .news-form .row{flex-direction:column}
  .footer-top{grid-template-columns:1fr;gap:26px}
  .legal-toc ol{columns:1}
  .voice .v-badge{right:12px;bottom:-14px;padding:14px 18px}
  .topbar .tb-links{display:none}
  .article-hero-inner{padding-bottom:30px}
  .cookie{flex-direction:column;align-items:flex-start}
}
