/* ---------- Tokens ---------- */
:root{
  --bg:#0f0d0a;
  --bg-2:#14110e;
  --text:#f4efe9;
  --muted:#bcb5ab;
  --line:#25221e;
  --card:#141313;
  --accent:#d2a574;
  --accent-2:#b07b3e;
  --radius:20px;
  --shadow:0 20px 60px rgba(0,0,0,.35);
}

/* ---------- Base ---------- */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.7;
}
.container{width:min(1100px,92%);margin-inline:auto}
.skip{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip:focus{left:12px;top:12px;width:auto;height:auto;background:#000;color:#fff;padding:8px 10px;border-radius:10px}

/* ---------- Header ---------- */
.header{position:sticky;top:0;background:rgba(15,13,10,.55);
  backdrop-filter:saturate(160%) blur(8px);border-bottom:1px solid var(--line);z-index:10}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px}
.mark{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
      background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#140e08;
      font-weight:700;letter-spacing:1px;box-shadow:var(--shadow)}
.brand-name{font-family:'Playfair Display',serif;font-weight:700;font-size:1.2rem}
.brand-tag{color:var(--muted);font-size:.95rem}
.nav a{color:var(--text);text-decoration:none;margin-left:18px;opacity:.9}
.nav a:hover{opacity:1}

/* ---------- Backdrop Decorations ---------- */
.backdrop{position:fixed;inset:0;z-index:-1;overflow:hidden}
.blob{position:absolute;filter:blur(40px);opacity:.35;transform:translate(-50%,-50%);pointer-events:none}
.b1{left:12%;top:10%;width:520px;height:520px;background:radial-gradient(50% 50% at 50% 50%, #5a3a22, transparent 60%)}
.b2{right:-8%;top:0;width:680px;height:680px;background:radial-gradient(50% 50% at 50% 50%, #2b1b0f, transparent 60%)}
.grain{position:absolute;inset:-50%;background-image:url('data:image/svg+xml;utf8,<svg xmlns=%22http://www.w3.org/2000/svg%22 width=%22400%22 height=%22400%22><filter id=%22n%22><feTurbulence type=%22fractalNoise%22 baseFrequency=%220.9%22 numOctaves=%222%22 stitchTiles=%22stitch%22/></filter><rect width=%22100%25%22 height=%22100%25%22 filter=%22url(%23n)%22 opacity=%220.03%22/></svg>');mix-blend-mode:overlay}
.sheen{position:absolute;inset:0;background:radial-gradient(1200px 500px at 50% -10%,rgba(255,255,255,.06),transparent 70%)}

/* ---------- Typo ---------- */
.display{font-family:'Playfair Display',serif;font-weight:700;letter-spacing:.3px;
  font-size:clamp(2rem,5vw,3.6rem);margin:0 0 .25em}
.h{font-family:'Playfair Display',serif;font-weight:700;font-size:clamp(1.3rem,3vw,2rem);margin:.2em 0 .4em}
.lead{font-size:1.1rem;color:var(--muted);max-width:780px}
.center{text-align:center}
.muted{color:var(--muted)}
.kicker{color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-size:.85rem;margin:0 0 8px}
.big{font-size:1.2rem}

/* ---------- Sections ---------- */
.section{padding:64px 0}
.hero{padding:80px 0 48px}
.cta{margin:20px 0 6px;display:flex;gap:12px;flex-wrap:wrap}
.highlights{display:flex;gap:18px;list-style:none;padding:0;margin:16px 0 0;color:var(--muted);flex-wrap:wrap}
.highlights li::before{content:'• ';color:var(--accent)}

.two-col{display:grid;grid-template-columns:1.1fr 1fr;gap:26px;align-items:start}
.panel{background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}

.promises{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:10px}
.pill{display:inline-block;padding:8px 12px;border-radius:999px;background:rgba(210,165,116,.12);border:1px solid rgba(210,165,116,.25);color:#f3e8d8;font-weight:600}
.promise p{margin:.5em 0 0}

/* ---------- Tiles ---------- */
.grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-top:16px}
.tile{background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));border:1px solid var(--line);
      border-radius:16px;padding:16px;box-shadow:var(--shadow);transition:transform .08s ease}
.tile:hover{transform:translateY(-2px)}
.icon{font-size:1.6rem}

/* ---------- Cards & Forms ---------- */
.card{border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow)}
.card--glass{background:rgba(255,255,255,.03)}
.card--soft{background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));padding:20px}
.form{display:grid;grid-template-columns:1fr auto;gap:12px;margin-top:12px}
.form input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--line);background:var(--bg-2);color:var(--text);font:inherit}
.form button{white-space:nowrap}

/* ---------- Buttons ---------- */
.btn{display:inline-block;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#1a1207;border:none;
  border-radius:999px;padding:12px 18px;text-decoration:none;font-weight:700;box-shadow:var(--shadow);transition:transform .08s ease}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn.ghost{background:transparent;color:var(--text);border:1px solid var(--line)}
.btn.small{padding:8px 12px;font-weight:600}
.btn.wide{display:block;text-align:center;margin-top:10px}

/* ---------- Visit / Map ---------- */
.visit .map-wrap{margin-top:12px;border-radius:16px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.visit iframe{width:100%;height:340px;border:0}

/* ---------- FAQ ---------- */
.faq details{background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:12px;padding:12px;margin:10px 0}
.faq summary{cursor:pointer;font-weight:600}

/* ---------- Footer ---------- */
.footer{border-top:1px solid var(--line);margin-top:40px}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;padding:18px 0;color:var(--muted)}
.footer a{color:var(--text);opacity:.9;text-decoration:none}
.footer a:hover{opacity:1}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .two-col{grid-template-columns:1fr}
  .promises{grid-template-columns:1fr}
}
