/* GoodGreet — public site styles.
   Ported from the original single-file design and extended for the
   multi-page Flask app (blog, coming-soon, flash messages). */

:root{
  --blue:#172a8e; --blue-bright:#2540c6; --blue-deep:#0e1c5e;
  --board:#0b0d16; --flap:#eceadd;
  --white:#fff; --paper:#eef1f9; --ink:#111422; --muted:#5c627a;
  --status:#2cd17e; --line:rgba(255,255,255,.28);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}
body{margin:0;background:var(--blue);color:var(--white);
  font-family:'Hanken Grotesk',system-ui,sans-serif;font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{margin:0;line-height:1.05;letter-spacing:-.015em;font-weight:800;color:inherit}
a{color:inherit}
img{max-width:100%}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.mono{font-family:'DM Mono',monospace}
.skip{position:absolute;left:-999px;top:0;background:#fff;color:var(--blue);padding:10px 16px;border-radius:8px;z-index:100}
.skip:focus{left:16px;top:12px}

/* ---- Language switch ---- */
.nav-right{display:flex;align-items:center;gap:14px;margin-left:auto}
.lang{display:flex;align-items:center;gap:7px;position:relative;border:1.5px solid var(--line);border-radius:8px;padding:0 9px 0 11px;background:rgba(255,255,255,.06)}
.lang .globe{width:16px;height:16px;color:#cfd3ee;flex:0 0 auto}
.lang select{appearance:none;-webkit-appearance:none;flex:1;width:100%;background:transparent;border:none;color:#fff;
  font-family:'Hanken Grotesk';font-weight:600;font-size:14px;padding:0 16px 0 0;cursor:pointer;outline:none}
.lang select option{color:#111422}
.lang .caret{position:absolute;right:9px;color:#cfd3ee;font-size:11px;pointer-events:none}
.lang:focus-within{outline:2px solid var(--status);outline-offset:2px}
.nav-right .lang,.nav-right .book-btn{height:46px;width:150px;box-sizing:border-box}
.nav-right .book-btn{justify-content:center;padding:0}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:15px;text-decoration:none;
  border:2px solid #fff;border-radius:9px;padding:13px 22px;cursor:pointer;background:#fff;color:var(--blue);
  transition:background .15s,color .15s,transform .12s}
.btn:hover{transform:translateY(-2px)}
.btn:focus-visible{outline:3px solid var(--status);outline-offset:3px}
.btn--ghost{background:transparent;color:#fff}
.btn--ghost:hover{background:#fff;color:var(--blue)}
.btn .ar{font-family:'DM Mono',monospace;transition:transform .12s}
.btn:hover .ar{transform:translateX(4px)}
.btn[disabled]{opacity:.6;cursor:not-allowed;transform:none}

/* ---- Header ---- */
header.nav{position:sticky;top:0;z-index:50;background:var(--blue);border-bottom:1.5px solid rgba(255,255,255,.16)}
.nav .row{display:flex;align-items:center;height:74px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand .mark{width:42px;height:42px;flex:0 0 auto}
.brand .name{font-weight:800;font-size:24px;letter-spacing:-.02em}
nav.links{display:flex;align-items:center;gap:28px;margin-left:38px}
nav.links a{font-weight:600;font-size:15px;text-decoration:none;opacity:.92}
nav.links a:hover{opacity:1;text-decoration:underline;text-underline-offset:5px;text-decoration-thickness:2px}
.nav-cities{position:relative}
.nav-cities-btn{font:inherit;font-weight:600;font-size:15px;color:inherit;background:none;border:none;cursor:pointer;opacity:.92;display:inline-flex;align-items:center;gap:5px;padding:0}
.nav-cities-btn:hover{opacity:1}
.nav-cities-btn .caret{font-size:10px;transition:transform .15s}
.nav-cities.open .nav-cities-btn .caret{transform:rotate(180deg)}
.nav-cities-menu{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(6px);
  background:#fff;border-radius:12px;box-shadow:0 18px 44px rgba(10,16,50,.24);padding:8px;min-width:180px;
  display:flex;flex-direction:column;opacity:0;visibility:hidden;transition:opacity .15s,transform .15s,visibility .15s;z-index:60}
.nav-cities.open .nav-cities-menu,.nav-cities:hover .nav-cities-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-cities-menu a{color:#1a1d29;padding:10px 14px;border-radius:8px;font-size:15px;font-weight:600;opacity:1;text-decoration:none}
.nav-cities-menu a:hover{background:#f1f3fb;text-decoration:none}
.menu-btn{display:none;background:#fff;color:var(--blue);border:none;border-radius:7px;padding:9px 12px;font-size:18px;cursor:pointer;margin-left:14px}

/* ---- Hero ---- */
.hero{padding:58px 0 30px}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(40px,5.6vw,64px);font-weight:800}
.hero p.lead{font-size:19px;max-width:40ch;margin:22px 0 28px;color:#dfe3f4}
.hero p.lead b{color:#fff}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap}

/* ---- Split-flap arrivals board ---- */
.board{background:var(--board);border-radius:14px;padding:20px 18px;box-shadow:0 24px 60px rgba(0,0,0,.4);border:1px solid #1c2030}
.board .bhead{display:flex;align-items:center;justify-content:space-between;padding:0 6px 14px;border-bottom:1px dashed #2a2f44;margin-bottom:8px}
.board .bhead .t{display:flex;align-items:center;gap:9px;font-weight:800;letter-spacing:.04em;color:var(--flap);font-size:18px}
.board .bhead .t svg{width:20px;height:20px}
.board .bhead .lbl{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.16em;color:#8b90ab;display:flex;align-items:center;gap:7px}
.board .bhead .live{width:8px;height:8px;border-radius:50%;background:var(--status);animation:blink 1.8s infinite}
@keyframes blink{0%,60%{opacity:1}80%{opacity:.25}100%{opacity:1}}
.brow{display:grid;grid-template-columns:1.5fr .75fr .7fr 1fr;align-items:center;gap:10px;padding:9px 6px;transform-origin:top center}
.brow + .brow{border-top:1px solid #161a28}
.cell{font-family:'DM Mono',monospace;font-weight:500;color:var(--flap);letter-spacing:.05em;
  background:linear-gradient(#20243a 0 49%,#171a2b 51% 100%);padding:7px 9px;border-radius:4px;font-size:13.5px;box-shadow:inset 0 -1px 0 #0a0c14}
.cell.code,.cell.time{text-align:center;color:#fff}
.cell.stat{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--status);background:none;box-shadow:none;justify-content:flex-end;padding-right:2px}
.cell.stat .dot{width:7px;height:7px;border-radius:50%;background:var(--status)}
.cell.stat[data-status="delayed"]{color:#f0b429}
.cell.stat[data-status="delayed"] .dot{background:#f0b429}
.cell.stat[data-status="cancelled"]{color:#ff6b6b}
.cell.stat[data-status="cancelled"] .dot{background:#ff6b6b}
.board.loading{opacity:.85}
.anim .brow{animation:flapin .5s cubic-bezier(.2,.8,.3,1) backwards}
.anim .brow:nth-child(2){animation-delay:.12s}.anim .brow:nth-child(3){animation-delay:.24s}
.anim .brow:nth-child(4){animation-delay:.36s}.anim .brow:nth-child(5){animation-delay:.48s}.anim .brow:nth-child(6){animation-delay:.6s}
@keyframes flapin{from{transform:rotateX(-92deg);opacity:0}to{transform:rotateX(0);opacity:1}}
@media (prefers-reduced-motion: reduce){.anim .brow{animation:none}.board .bhead .live{animation:none}}

/* ---- Booking panel ---- */
.book-panel{background:#fff;color:var(--ink);border-radius:14px;padding:24px;box-shadow:0 18px 50px rgba(0,0,0,.28);margin-top:40px}
.book-panel .ph{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;margin-bottom:16px;color:var(--blue)}
.book-panel .ph svg{width:22px;height:22px}
.tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:18px}
.tab{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--paper);border:1.5px solid #d4d9ea;border-radius:9px;
  padding:12px 8px;font-weight:600;font-size:14px;cursor:pointer;color:var(--ink)}
.tab svg{width:17px;height:17px}
.tab[aria-selected="true"]{background:var(--blue);border-color:var(--blue);color:#fff}
.grid4{display:grid;grid-template-columns:1fr 1fr;gap:14px}
label.fld{display:block;font-weight:700;font-size:13px;color:var(--ink);margin:13px 0 6px}
.input,select.input{width:100%;border:1.5px solid #cfd5e8;border-radius:8px;background:#f7f9fe;padding:12px 13px;font-size:15px;color:var(--ink);font-family:'Hanken Grotesk'}
.input:focus,select.input:focus{outline:none;border-color:var(--blue);background:#fff}
.flightrow{background:var(--paper);border:1.5px solid #d4d9ea;border-radius:10px;padding:12px 13px;margin-top:14px}
.flightrow label{display:flex;align-items:center;gap:8px;font-weight:700;font-size:13px;color:var(--blue);margin-bottom:7px}
.flightrow label svg{width:16px;height:16px}
.flightrow input{width:100%;border:1.5px solid #cfd5e8;border-radius:8px;background:#fff;padding:11px 12px;font-family:'DM Mono',monospace;font-size:15px;text-transform:uppercase}
.flightrow .note{font-size:12.5px;color:var(--muted);margin-top:7px}
.book-panel .btn{width:100%;justify-content:center;margin-top:18px;background:var(--blue);color:#fff;border-color:var(--blue);text-decoration:none}
.book-panel .btn:hover{background:var(--blue-bright);border-color:var(--blue-bright);transform:none}

.trust{display:flex;flex-wrap:wrap;gap:11px;justify-content:center;margin:30px 0 0}
.chip{background:rgba(255,255,255,.1);border:1.5px solid var(--line);border-radius:7px;padding:8px 14px;font-weight:600;font-size:13px;display:flex;gap:8px;align-items:center}
.chip svg{width:15px;height:15px}

/* ---- Sections ---- */
section{padding:78px 0}
.light{background:var(--paper);color:var(--ink)}
.light h2,.light h3{color:var(--ink)}
.sec-head{text-align:center;margin-bottom:46px}
.sec-head h2{font-size:clamp(32px,5vw,50px)}
.sec-head p{max-width:54ch;margin:14px auto 0;color:var(--muted)}
.blue-sec .sec-head p{color:#dfe3f4}

/* ---- Wayfinding sign panels ---- */
.signs{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.sign{background:var(--blue);border-radius:12px;padding:26px 24px;color:#fff;position:relative;display:flex;flex-direction:column;min-height:200px}
.light .sign{box-shadow:0 10px 30px rgba(23,42,142,.16)}
.sign .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:auto}
.sign .pic{width:54px;height:54px;background:rgba(255,255,255,.14);border-radius:10px;display:flex;align-items:center;justify-content:center}
.sign .pic svg{width:30px;height:30px}
.sign .ar{font-family:'DM Mono',monospace;font-size:30px;opacity:.85;line-height:1}
.sign h3{font-size:21px;color:#fff;margin:18px 0 8px}
.sign p{font-size:14.5px;color:#cdd3f0;margin:0}
.sign .gate{position:absolute;top:18px;right:20px;font-family:'DM Mono',monospace;font-size:12px;letter-spacing:.18em;color:#aeb6e0}
.sign-img{width:100%;height:150px;object-fit:cover;border-radius:10px;margin-bottom:16px;background:rgba(255,255,255,.1)}
.hero-art{width:100%;max-width:520px;margin-left:auto}
.hero-art svg{width:100%;height:auto;display:block;filter:drop-shadow(0 24px 50px rgba(0,0,0,.34))}
.hero-art img{width:100%;height:auto;display:block;border-radius:20px;box-shadow:0 24px 50px rgba(0,0,0,.34)}
/* City picker */
.city-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:8px}
.city-card{display:flex;flex-direction:column;background:#fff;border-radius:16px;overflow:hidden;
  text-decoration:none;color:inherit;box-shadow:0 10px 30px rgba(14,28,94,.08);transition:transform .16s,box-shadow .16s;border:1px solid #eaedf7}
.city-card:hover{transform:translateY(-4px);box-shadow:0 20px 44px rgba(14,28,94,.16)}
.city-card-img{position:relative;height:150px;background:linear-gradient(135deg,#2540c6,#172a8e);background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center}
.city-card-code{font-family:'DM Mono',monospace;font-size:34px;font-weight:500;color:rgba(255,255,255,.9);letter-spacing:3px}
.city-card-glyph{width:58px;height:58px;opacity:.92}
/* Compact hero booking widget (city pages) */
.hero-book{display:flex;flex-direction:column;gap:12px;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:16px 16px 18px;max-width:400px;margin-top:8px}
.hero-book-lbl{font-weight:700;font-size:13px;opacity:.85;letter-spacing:.02em}
.hero-book .tabs{margin-bottom:0}
.hero-book .tab{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.22);color:#fff;padding:11px 10px;font-size:14px}
.hero-book .tab[aria-selected="true"]{background:#fff;border-color:#fff;color:var(--blue)}
.hero-book .btn{width:100%;justify-content:center;background:var(--green,#2cd17e);color:#06351f;border-color:var(--green,#2cd17e);text-decoration:none}
.hero-book .btn:hover{filter:brightness(1.06);transform:none}
.hero .trust{justify-content:flex-start;margin-top:18px}
.city-card-badge{position:absolute;top:12px;right:12px;background:#ffd23f;color:#3a2c00;font-size:11px;font-weight:800;
  text-transform:uppercase;letter-spacing:.04em;padding:5px 10px;border-radius:20px}
.city-card.is-soon .city-card-img{filter:grayscale(.3) brightness(.92)}
.city-card-body{padding:18px 20px 20px}
.city-card-body h3{margin:0;font-size:20px;font-weight:800}
.city-card-meta{display:block;color:#6a7290;font-size:14px;margin-top:2px}
.city-card-go{display:inline-flex;align-items:center;gap:6px;margin-top:14px;color:var(--blue,#172a8e);font-weight:700;font-size:14px}
.city-card-go .ar{transition:transform .16s}
.city-card:hover .city-card-go .ar{transform:translateX(4px)}
@media (max-width:900px){.city-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.city-grid{grid-template-columns:1fr}}
.qs-simple{grid-template-columns:1fr 1fr;gap:16px}
#arrivals{padding-bottom:26px}
.cta{padding-top:40px}

/* ---- Pricing ---- */
.prices{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start}
.price{background:#fff;border:1.5px solid #d4d9ea;border-radius:14px;padding:26px 24px;position:relative;color:var(--ink)}
.price.feat{background:var(--blue);border-color:var(--blue);color:#fff}
.price.feat h3{color:#fff}
.price .pop{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--status);color:#06351f;
  font-family:'DM Mono',monospace;font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;border-radius:6px;white-space:nowrap}
.price h3{font-size:21px}
.price .cap{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);margin:4px 0 16px;letter-spacing:.04em}
.price.feat .cap{color:#c2c9f0}
.price .amt{font-size:40px;font-weight:800;line-height:1}
.price .amt small{display:block;font-size:13px;font-weight:500;color:var(--muted);margin-top:4px}
.price.feat .amt small{color:#c2c9f0}
.price ul{list-style:none;margin:18px 0;padding:0}
.price li{display:flex;gap:10px;font-size:14px;margin:11px 0;line-height:1.4}
.price li svg{width:17px;height:17px;flex:0 0 auto;margin-top:2px}
.price .btn{width:100%;justify-content:center;background:var(--blue);color:#fff;border-color:var(--blue)}
.price.feat .btn{background:#fff;color:var(--blue);border-color:#fff}
.addons{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:34px}
.addon{background:#fff;border:1.5px solid #d4d9ea;border-radius:10px;padding:14px 20px;font-size:14px;max-width:340px;color:var(--muted)}
.addon b{display:block;font-weight:800;font-size:16px;color:var(--ink);margin-bottom:2px}
.pricing-note{text-align:center;margin-top:24px;font-size:14px;color:var(--muted)}

/* ---- Coverage ---- */
.cov-point{display:flex;align-items:center;gap:12px;justify-content:center;background:var(--blue-bright);border-radius:10px;padding:14px 18px;max-width:560px;margin:0 auto 26px;font-size:15px}
.cov-point svg{width:22px;height:22px;flex:0 0 auto}
.chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:760px;margin:0 auto}
.nb{background:rgba(255,255,255,.1);border:1.5px solid var(--line);border-radius:8px;padding:8px 14px;font-weight:600;font-size:14px}

/* ---- Reviews ---- */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review{background:#fff;border:1.5px solid #d4d9ea;border-radius:14px;padding:26px 24px;margin:0;display:flex;flex-direction:column;gap:14px}
.review .stars{color:var(--blue);font-size:15px;letter-spacing:3px}
.review blockquote{margin:0;font-size:15.5px;line-height:1.62;color:#23242c}
.review figcaption{font-family:'DM Mono',monospace;font-size:13px;color:var(--muted);letter-spacing:.03em;margin-top:auto;padding-top:4px}
.rating-line{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:28px;font-weight:600;color:var(--ink)}
.rating-line .stars{color:var(--blue);letter-spacing:3px}

/* ---- Closing CTA ---- */
.cta{text-align:center}
.cta h2{font-size:clamp(31px,4.4vw,46px)}
.cta p{max-width:46ch;margin:14px auto 26px;color:#dfe3f4}

/* ---- FAQ ---- */
.faq-list{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.acc{border:1.5px solid #d4d9ea;border-radius:11px;background:#fff;overflow:hidden}
.acc summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 22px;font-weight:700;font-size:16.5px;color:var(--ink)}
.acc summary::-webkit-details-marker{display:none}
.acc summary .pm{flex:0 0 auto;width:24px;height:24px;border-radius:6px;background:var(--paper);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--blue);transition:transform .2s}
.acc[open] summary .pm{transform:rotate(45deg);background:var(--blue);color:#fff}
.acc .body{padding:0 22px 20px;font-size:15.5px;color:#3a3f55;line-height:1.65}
.acc summary:focus-visible{outline:3px solid var(--blue);outline-offset:-3px}

/* ---- SEO Q&A ---- */
.seo{max-width:840px;margin:0 auto}
.seo h2{font-size:clamp(28px,4vw,40px);text-align:center;margin-bottom:14px;color:#fff}
.seo .qa{border-top:1.5px solid rgba(255,255,255,.18);padding:24px 0}
.seo .qa:last-child{border-bottom:1.5px solid rgba(255,255,255,.18)}
.seo h3{font-size:20px;margin-bottom:8px;color:#fff}
.seo p{margin:0;color:#dfe3f4}

/* ---- Footer ---- */
footer{background:var(--blue-deep);padding:60px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.5fr repeat(4,1fr);gap:32px}
.foot-brand .name{font-weight:800;font-size:22px}
.foot-brand p{font-size:14px;color:#aab1d8;margin:14px 0 16px;max-width:32ch;font-family:'DM Mono',monospace}
.foot-brand .ct{font-size:14px;color:#cdd3f0;margin:6px 0}
.foot-col h5{font-family:'DM Mono',monospace;font-weight:500;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#8e96c6;margin:0 0 15px}
.foot-col a{display:block;font-size:14px;color:#c7cbe4;text-decoration:none;margin:10px 0}
.foot-col a:hover{color:#fff;text-decoration:underline;text-underline-offset:3px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:42px;padding-top:22px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:13px;color:#8e96c6}
.foot-bottom .langs{display:flex;gap:14px;flex-wrap:wrap}
.foot-bottom .langs a{color:#8e96c6;text-decoration:none}
.foot-bottom .langs a[aria-current="true"]{color:#fff;font-weight:600}

/* ---- Reveal-on-scroll ---- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s,transform .6s}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---- Flash messages ---- */
.flash{max-width:1180px;margin:14px auto 0;padding:0 28px}
.flash .msg{border-radius:9px;padding:12px 16px;font-weight:600;font-size:14px}
.flash .ok{background:rgba(44,209,126,.16);border:1.5px solid var(--status);color:#0a6b3d}
.flash .err{background:rgba(214,58,58,.14);border:1.5px solid #d63a3a;color:#9a1d1d}

/* ---- Blog ---- */
.page-head{padding:64px 0 12px;text-align:center}
.page-head h1{font-size:clamp(34px,5vw,52px)}
.page-head p{max-width:56ch;margin:14px auto 0;color:#dfe3f4}
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px;padding:30px 0 90px}
.post-card{background:#fff;color:var(--ink);border-radius:14px;overflow:hidden;border:1.5px solid #d4d9ea;display:flex;flex-direction:column;text-decoration:none;transition:transform .12s,box-shadow .12s}
.post-card:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(0,0,0,.2)}
.post-card .cover{height:160px;background:var(--blue) center/cover no-repeat}
.post-card .pc-body{padding:20px 22px;display:flex;flex-direction:column;gap:8px;flex:1}
.post-card h3{font-size:19px;color:var(--ink)}
.post-card p{font-size:14px;color:var(--muted);margin:0}
.post-card .more{margin-top:auto;font-family:'DM Mono',monospace;font-size:13px;color:var(--blue);font-weight:600}
.article{background:var(--paper);color:var(--ink)}
.article .wrap{max-width:760px}
.article .crumbs{font-family:'DM Mono',monospace;font-size:13px;color:var(--muted);padding:34px 0 0}
.article .crumbs a{color:var(--blue);text-decoration:none}
.article h1{font-size:clamp(30px,4.4vw,46px);color:var(--ink);margin:18px 0 10px}
.article .meta{font-family:'DM Mono',monospace;font-size:13px;color:var(--muted);margin-bottom:26px}
.article .content{font-size:17px;line-height:1.75;color:#2a2e3e;padding-bottom:70px}
.article .content h2{font-size:26px;margin:34px 0 12px;color:var(--ink)}
.article .content h3{font-size:20px;margin:26px 0 10px;color:var(--ink)}
.article .content p{margin:0 0 18px}
.article .content ul{margin:0 0 18px;padding-left:22px}

/* ---- Coming soon ---- */
.soon{text-align:center;padding:90px 0}
.soon .badge{display:inline-flex;align-items:center;gap:8px;font-family:'DM Mono',monospace;font-size:12px;letter-spacing:.16em;text-transform:uppercase;background:rgba(255,255,255,.1);border:1.5px solid var(--line);border-radius:30px;padding:8px 16px;margin-bottom:22px}
.soon .badge .live{width:8px;height:8px;border-radius:50%;background:var(--status);animation:blink 1.8s infinite}
.soon h1{font-size:clamp(36px,6vw,62px);margin-bottom:16px}
.soon p{max-width:50ch;margin:0 auto 30px;color:#dfe3f4;font-size:18px}
.notify-form{display:flex;gap:10px;max-width:440px;margin:0 auto;flex-wrap:wrap}
.notify-form input{flex:1;min-width:200px;border:1.5px solid var(--line);border-radius:9px;background:rgba(255,255,255,.08);padding:13px 15px;font-size:15px;color:#fff;font-family:'Hanken Grotesk'}
.notify-form input::placeholder{color:#aeb6e0}
.notify-form input:focus{outline:2px solid var(--status);outline-offset:2px;background:rgba(255,255,255,.12)}
.soon .other-cities{margin-top:46px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.soon .other-cities a{font-size:14px;font-weight:600;background:rgba(255,255,255,.1);border:1.5px solid var(--line);border-radius:8px;padding:8px 14px;text-decoration:none}
.soon .thanks{background:rgba(44,209,126,.16);border:1.5px solid var(--status);border-radius:10px;padding:14px 18px;max-width:440px;margin:0 auto;font-weight:600}

/* ---- Responsive ---- */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:34px}
  .hero p.lead{max-width:none}
  .signs,.prices{grid-template-columns:1fr}
  .reviews{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1 / -1}
  nav.links{display:none}.menu-btn{display:block}
  nav.links.open .nav-cities{width:100%}
  nav.links.open .nav-cities-btn{padding:12px 28px;width:100%;justify-content:space-between;color:#fff}
  nav.links.open .nav-cities-menu{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;background:rgba(255,255,255,.06);border-radius:0;padding:0;min-width:0}
  nav.links.open .nav-cities-menu a{color:#fff;padding:11px 40px}
  nav.links.open .nav-cities-menu a:hover{background:rgba(255,255,255,.08)}
  nav.links.open{display:flex;position:absolute;top:74px;left:0;right:0;background:var(--blue);flex-direction:column;gap:0;margin:0;padding:8px 0;border-bottom:1.5px solid rgba(255,255,255,.16)}
  nav.links.open a{padding:12px 28px}
}
@media (max-width:560px){
  .wrap{padding:0 18px}
  .grid4{grid-template-columns:1fr}.foot-grid{grid-template-columns:1fr}
  .nav-right{gap:8px}
  .nav-right .lang,.nav-right .book-btn{width:auto;height:42px}
  .nav-right .book-btn{padding:0 14px;font-size:14px}
  .lang select{font-size:13px;padding-right:14px}
  .brow{grid-template-columns:1.4fr .7fr 1fr;gap:7px}.brow .time{display:none}
  .hero-art{max-width:none;margin:0 auto}
  .sign{min-height:0;padding:22px 20px}
  .sign-img{height:130px}
  .price{padding:24px 20px}
  h1,.hero h1{font-size:40px;line-height:1.05}
  .nav .row{height:64px}.menu-btn{margin-left:10px}
  nav.links.open{top:64px}
}
@media (max-width:380px){
  .brand span{font-size:17px}
  .nav-right .book-btn span:last-child{display:none}
  .nav-right .lang{max-width:96px}
}
