/* Afalia demos — shared structural styles. Each demo sets the theme vars below. */
:root{
  --accent:#2563eb; --accent-d:#1d4ed8; --accent-soft:#eef3ff; --accent-contrast:#fff;
  --ink:#0f172a; --ink-2:#334155; --bg:#f8fafc; --surface:#fff; --line:#e2e8f0; --muted:#64748b;
  --radius:12px; --font-head:'Manrope',sans-serif; --font-body:'Inter',sans-serif;
}
*{box-sizing:border-box;margin:0} html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--font-head);line-height:1.13;letter-spacing:-.02em}
a{color:inherit;text-decoration:none} img{display:block;max-width:100%} ul{list-style:none;padding:0}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}
section{padding:84px 0}
.eyebrow{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-d);font-weight:700}
.lead{color:var(--muted);font-size:1.08rem}
.center{text-align:center}
h2.title{font-size:clamp(1.9rem,3.5vw,2.5rem);margin-top:10px}

.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);font-weight:600;font-size:.95rem;padding:13px 22px;border-radius:9px;cursor:pointer;border:1.5px solid transparent;transition:background .15s,color .15s,border-color .15s}
.btn-primary{background:var(--accent);color:var(--accent-contrast)} .btn-primary:hover{background:var(--accent-d)}
.btn-out{border-color:var(--line);color:var(--ink);background:var(--surface)} .btn-out:hover{border-color:var(--accent);color:var(--accent)}
.btn-ghost{color:var(--accent)}

/* header */
header{position:sticky;top:0;z-index:40;background:color-mix(in srgb,var(--surface) 90%,transparent);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;height:72px;gap:26px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-head);font-weight:800;font-size:1.25rem}
.brand .logo-ic{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:var(--accent);color:var(--accent-contrast)}
.nav-links{display:flex;gap:24px;margin-left:auto}
.nav-links a{font-family:var(--font-head);font-size:.93rem;font-weight:600;color:var(--ink-2)} .nav-links a:hover{color:var(--accent)}

/* hero */
.hero{background:linear-gradient(180deg,var(--surface),var(--bg));border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:center}
.hero h1{font-size:clamp(2.3rem,4.6vw,3.5rem);margin:16px 0 18px}
.hero .lead{max-width:46ch}
.hero-cta{display:flex;gap:13px;margin-top:28px;flex-wrap:wrap}
.hero-meta{display:flex;gap:24px;margin-top:28px;flex-wrap:wrap;font-size:.9rem;color:var(--ink-2)}
.hero-art{aspect-ratio:5/4;border-radius:16px;display:grid;place-items:center;position:relative;overflow:hidden;box-shadow:0 24px 60px rgba(15,23,42,.18);background:linear-gradient(135deg,var(--accent),var(--accent-d))}
.hero-art .big-ic{color:rgba(255,255,255,.92)}
.hero-art .chip{position:absolute;background:var(--surface);padding:9px 15px;border-radius:999px;font-size:.82rem;font-weight:700;display:flex;gap:8px;align-items:center;box-shadow:0 8px 22px rgba(15,23,42,.12)}
.urgent{background:var(--ink);color:#fff;text-align:center;font-weight:600;font-size:.9rem;padding:10px}
.urgent a{color:#fff;text-decoration:underline}

/* generic card grids */
.cards{display:grid;gap:18px;margin-top:44px}
.cards-3{grid-template-columns:repeat(3,1fr)}
.cards-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:26px}
.svc-ic{width:50px;height:50px;border-radius:12px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent-d);margin-bottom:16px}
.card h3{font-size:1.15rem;margin-bottom:6px}
.card p{color:var(--muted);font-size:.93rem}
.card .price{font-family:var(--font-head);font-weight:700;font-size:1.15rem;margin-top:14px}
.card .price small{font-weight:500;font-size:.8rem;color:var(--muted)}

/* feature list */
.checks li{display:flex;gap:10px;align-items:flex-start;margin:11px 0;color:var(--ink-2)}
.checks svg{color:var(--accent);flex:none;margin-top:3px}

/* zones / pills */
.pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px;justify-content:center}
.pill{background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:9px 18px;font-weight:600;font-size:.9rem}

/* booking */
.book-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:46px;align-items:center;margin-top:16px}
#booking{--bk-accent:var(--accent);--bk-accent-contrast:var(--accent-contrast);--bk-surface:var(--surface);--bk-bg:var(--bg);--bk-border:var(--line);--bk-ink:var(--ink);--bk-muted:var(--muted);--bk-radius:14px;box-shadow:0 18px 50px rgba(15,23,42,.10)}

/* reviews */
.dark{background:var(--ink);color:#e6eaf2}
.dark .eyebrow{color:color-mix(in srgb,var(--accent) 60%,#fff)} .dark h2{color:#fff}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:42px}
.rev-card{background:color-mix(in srgb,var(--ink) 86%,#fff);border:1px solid color-mix(in srgb,var(--ink) 70%,#fff);border-radius:12px;padding:24px}
.stars{color:#f6c344;letter-spacing:2px;margin-bottom:10px}
.rev-card p{color:#d2d8e6;font-size:.94rem} .rev-card .who{margin-top:14px;font-weight:700;color:#fff;font-size:.9rem}

/* stats band */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
.stat .n{font-family:var(--font-head);font-weight:800;font-size:2rem;color:var(--accent)}
.stat .l{color:var(--muted);font-size:.88rem}

/* footer */
footer.ft{background:#0b1120;color:#aeb6c7;padding:60px 0 26px}
footer.ft h4{font-family:var(--font-head);color:#fff;margin-bottom:14px;font-size:1.02rem}
footer.ft a{color:#aeb6c7} footer.ft a:hover{color:#fff}
footer.ft li{margin:7px 0;font-size:.92rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px}
.foot-bottom{margin-top:38px;padding-top:20px;border-top:1px solid #1e293b;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.85rem;color:#7c879c}
.vitrino-credit{color:#fff!important;font-weight:700}

@media(max-width:860px){
  .nav-links{display:none}
  .hero-grid{grid-template-columns:1fr;gap:30px} .hero-art{order:-1;aspect-ratio:16/10}
  .cards-3,.cards-4,.rev-grid{grid-template-columns:1fr} .stats{grid-template-columns:1fr 1fr}
  .book-grid{grid-template-columns:1fr} .foot-grid{grid-template-columns:1fr 1fr}
  section{padding:58px 0}
}
