/* ============================================================
   Vista Hotel Casino Resort — informational site stylesheet
   Theme: warm editorial · oat, espresso, clay/terracotta
   Fonts: DM Serif Display (display) + DM Sans (body)
   Layout: ONE container width everywhere · no decorative rules ·
           tight vertical rhythm · full-width note blocks
   ============================================================ */

:root{
  --oat:#efe9dd;
  --paper:#f7f2e8;
  --espresso:#2c2620;
  --espresso-deep:#211c17;
  --ink:#322b24;
  --muted:#6c6356;
  --clay:#b5572f;
  --clay-deep:#8e4222;
  --line:rgba(50,43,36,.14);
  --line-soft:rgba(50,43,36,.08);
  --shadow:0 24px 60px -32px rgba(33,28,23,.5);
  --maxw:1100px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"DM Sans",-apple-system,sans-serif;font-weight:400;
  color:var(--ink);background:var(--oat);line-height:1.7;font-size:17px;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}

h1,h2,h3{font-family:"DM Serif Display",Georgia,serif;font-weight:400;line-height:1.1;color:var(--espresso)}
a{color:var(--clay-deep)}
a:hover{color:var(--espresso)}

/* ---- ONE container width used by every block, hero + inner alike ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 30px}
.narrow{max-width:var(--maxw)}

/* subtle atmosphere on body so the h1 stays the first element */
body.home::before{
  content:"";position:absolute;top:0;right:0;width:46vw;height:560px;z-index:0;pointer-events:none;
  background:radial-gradient(circle at 85% 0%, rgba(181,87,47,.12), transparent 55%);
}

/* ---------------- HERO (h1 = first element in body, no divider) ---------------- */
.hero-title{
  position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;
  padding:6.4rem 30px 0;font-size:clamp(2.7rem,6.2vw,5rem);font-weight:400;letter-spacing:-.005em;
}
.hero-stage{position:relative;z-index:1;padding:1.4rem 0 3rem}
.hero-stage .lead{font-size:clamp(1.1rem,2vw,1.32rem);color:#3d352c}
.badge-wrap{margin-top:1.6rem}
.badge18{
  display:inline-flex;align-items:center;gap:.6rem;
  border:1px solid var(--line);border-radius:999px;padding:.5rem 1.1rem;
  font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:var(--paper);
}
.badge18 b{color:var(--clay-deep);font-family:"DM Serif Display",serif;font-size:1rem;letter-spacing:.02em}
.badge-note{margin-top:.85rem;font-size:.95rem;color:var(--muted);line-height:1.6}
.badge-note strong{color:var(--espresso);font-weight:700}

/* ---------------- SECTIONS — tight rhythm ---------------- */
section{padding:2.8rem 0;position:relative;z-index:1}
.section-alt{background:var(--paper);border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.section-dark{background:var(--espresso);color:#e9e2d6}
.section-dark h2,.section-dark h3{color:#fff}
.section-dark a{color:#e0a37f}

h2{font-size:clamp(1.9rem,3.8vw,2.7rem);margin-bottom:.7rem}
h3{font-size:1.32rem;margin-bottom:.35rem}
section p{margin-bottom:1rem;color:#3d352c}
section p:last-child{margin-bottom:0}
.section-dark p{color:#cabfb0}
.lede{font-size:1.18rem;color:#39312a}
.section-dark .lede{color:#ded3c4}

/* numbered rows */
.rows{margin-top:1.6rem;border-top:1px solid var(--line)}
.row{display:grid;grid-template-columns:auto 1fr;gap:1.5rem;padding:1.4rem 0;border-bottom:1px solid var(--line);align-items:baseline}
.row .rnum{font-family:"DM Serif Display",serif;font-size:2rem;color:var(--clay);line-height:1;min-width:2.2ch}
.row p{margin:0;color:#4a4137}

/* trio cards */
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:1.6rem}
.tcard{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.16);border-radius:13px;padding:1.7rem 1.5rem}
.tcard p{color:#cabfb0;margin:0;font-size:.97rem}

/* comparison */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem;margin-top:1.6rem}
.panel{background:var(--paper);border:1px solid var(--line);border-radius:15px;padding:1.9rem 1.7rem}
.panel.feature{background:var(--espresso);color:#e9e2d6;border-color:var(--espresso)}
.panel.feature h3{color:#fff}
.panel h3{margin-bottom:.8rem}
.panel ul{list-style:none}
.panel li{padding:.4rem 0 .4rem 1.4rem;position:relative;font-size:.97rem;color:#4a4137}
.panel.feature li{color:#d2c7b8}
.panel li::before{content:"";position:absolute;left:0;top:.78em;width:7px;height:7px;border:1.5px solid var(--clay);border-radius:50%}

/* inner prose pages — same container width */
.page-title{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:5.6rem 30px 0;font-size:clamp(2.2rem,4.6vw,3.4rem);font-weight:400}
.page-intro{position:relative;z-index:1;padding:.9rem 0 1.8rem;border-bottom:1px solid var(--line-soft)}
.page-intro p{color:var(--muted);font-size:1.08rem;margin-bottom:.4rem}
.page-intro .meta{font-size:.85rem;font-style:italic;color:var(--muted)}
.prose{padding:2.4rem 0 3.4rem}
.prose h2{font-size:1.6rem;margin:1.8rem 0 .6rem}
.prose h2:first-child{margin-top:0}
.prose h3{margin:1.3rem 0 .35rem;font-size:1.18rem}
.prose p,.prose li{color:#3d352c}
.prose ul,.prose ol{margin:0 0 1rem 1.3rem}
.prose li{margin-bottom:.45rem}

.notice{border-left:3px solid var(--clay);background:rgba(181,87,47,.08);padding:1.2rem 1.4rem;border-radius:0 10px 10px 0;margin:1.6rem 0;font-size:.97rem;color:#3d352c}
.notice strong{color:var(--espresso)}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem;margin-top:1.4rem}
.contact-card{border:1px solid var(--line);border-radius:13px;padding:1.6rem;background:var(--paper)}
.contact-card .lbl{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--clay-deep);font-weight:700;margin-bottom:.4rem}
.contact-card .val{font-family:"DM Serif Display",serif;font-size:1.22rem;color:var(--espresso);word-break:break-word}

/* ---------------- FOOTER ---------------- */
.site-footer{background:var(--espresso-deep);color:#b9af9f;padding:3.4rem 0 1.8rem}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2.4rem;padding-bottom:2.2rem;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand .mark{font-family:"DM Serif Display",serif;font-size:1.6rem;color:#fff}
.footer-brand p{margin-top:.8rem;font-size:.92rem;color:#9a8f7e}
.footer-col h4{font-family:"DM Serif Display",serif;font-weight:400;color:#e0a37f;font-size:1.1rem;margin-bottom:.8rem}
.footer-col a{display:block;color:#b9af9f;font-size:.92rem;padding:.26rem 0}
.footer-col a:hover{color:#fff}
.footer-rg{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;padding:1.6rem 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:.88rem;color:#9a8f7e}
.footer-rg .pill{border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:.35rem .85rem;color:#e9e2d6;font-size:.76rem;letter-spacing:.1em}
.footer-note{padding:1.4rem 0 0;font-size:.9rem;color:#a89d8c}
.footer-bottom{padding-top:1.3rem;font-size:.83rem;color:#857a69;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem}
.footer-bottom a{color:#9a8f7e}

@keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.rise{animation:rise .8s cubic-bezier(.2,.7,.2,1) both}
.d1{animation-delay:.08s}.d2{animation-delay:.18s}
@media (prefers-reduced-motion:reduce){.rise{animation:none}}

@media(max-width:880px){
  .trio,.duo,.contact-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:1.8rem}
  .footer-brand{grid-column:1/-1}
  .hero-title{padding-top:5rem}
}
@media(max-width:520px){
  .footer-top{grid-template-columns:1fr}
  body{font-size:16px}
  .row{grid-template-columns:1fr;gap:.3rem}
}
