:root{
  /* Brand tokens (aligned to assets/logo.png) */
  --red:#BF1724;
  --red-dark:#9E121C;
  --charcoal:#2b2b2b;
  --muted:#5b616b;
  /* Warm neutrals (prevents the harsh white/black/red look) */
  --bg:#FBFAF8;
  --card:#ffffff;
  --border:#E6E2DE;
  --shadow: 0 10px 30px rgba(0,0,0,.08);
  --radius:20px;
  --max:1100px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--charcoal);
  background:var(--bg);
  line-height:1.5;
}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}

/* Header */
.header{position:sticky;top:0;background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border);z-index:50}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0}
/* HTML uses .navwrap as the header flex row */
.navwrap{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:42px;height:42px;border-radius:999px}
.brand .name{display:flex;flex-direction:column;line-height:1.1}
.brand .name strong{font-size:14px;letter-spacing:.2px}
.brand .name span{font-size:12px;color:var(--muted)}
/* HTML in this project uses a simple <span> for the brand name */
.brand > span{font-weight:800;letter-spacing:.2px}
.nav{display:flex;align-items:center;gap:18px}
.nav a{font-size:14px;color:var(--charcoal);text-decoration:none;padding:8px 10px;border-radius:10px}
.nav a:hover{background:#f3f4f6;text-decoration:none}
.nav a[aria-current="page"]{background:#f3f4f6}
/* In HTML the header CTA uses class="btn" */
.nav .btn{background:var(--red);border-color:var(--red);color:white;padding:10px 14px}
.nav .btn:hover{background:var(--red-dark);border-color:var(--red-dark)}

/* Mobile menu button (HTML uses .menu-btn) */
.menu-btn,
.burger{display:none;border:1px solid var(--border);background:white;border-radius:12px;padding:10px 12px;cursor:pointer}
.menu-btn span{display:block;width:22px;height:2px;background:var(--charcoal);border-radius:2px}
.menu-btn span+span{margin-top:5px}
.menu-btn:active,
.burger:active{transform:translateY(1px)}

/* Mobile nav (HTML uses .mobile + data-open) */
.mobile{display:none;border-top:1px solid var(--border);padding:10px 0}
.mobile a{display:block;padding:12px 20px;text-decoration:none;border-radius:12px}
.mobile a:hover{background:#f3f4f6}
.mobile .btn{margin:8px 20px 0}
.mobile[data-open="true"]{display:block}

/* Back-compat with earlier class names */
.mobile-nav{display:none;border-top:1px solid var(--border)}
.mobile-nav a{display:block;padding:12px 20px;text-decoration:none}
.mobile-nav a:hover{background:#f3f4f6}
.mobile-nav .cta{background:var(--red);color:#fff}

/* Hero */
.hero{position:relative;padding:52px 0 26px;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg, rgba(251,250,248,.92), rgba(251,250,248,.98)), url('assets/photos/hero-banner.jpg');background-size:cover;background-position:center;filter:saturate(1.05);}
.hero > .container{position:relative}
.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:28px;align-items:center}
/* HTML uses .pill instead of .kicker */
.pill,
.kicker{display:inline-flex;gap:10px;align-items:center;background:#fff;border:1px solid var(--border);padding:8px 12px;border-radius:999px;box-shadow:0 2px 10px rgba(0,0,0,.04);font-size:13px}
.kicker .dot{width:10px;height:10px;background:var(--red);border-radius:999px}
.hero h1{font-size:46px;line-height:1.06;margin:14px 0 12px}
.hero p{font-size:18px;color:var(--muted);margin:0 0 18px}
/* HTML uses .cta-row instead of .hero-actions */
.cta-row,
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-top:8px}

/* Buttons (default = primary to match the site copy/CTAs) */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 16px;border-radius:14px;border:1px solid var(--red);background:var(--red);color:#fff;font-weight:700;text-decoration:none;box-shadow:0 6px 18px rgba(0,0,0,.08);cursor:pointer}
.btn:hover{text-decoration:none;background:var(--red-dark);border-color:var(--red-dark)}
.btn:active{transform:translateY(1px)}
.btn.secondary,
.btn.btn-secondary{
  background: rgba(191, 23, 36, 0.06);
  border-color: rgba(191, 23, 36, 0.22);
  color: var(--charcoal);
  font-weight: 800;
}
.btn.secondary:hover,
.btn.btn-secondary:hover{
  background: rgba(191, 23, 36, 0.10);
  border-color: rgba(191, 23, 36, 0.30);
  text-decoration:none;
}
.btn.primary,
.btn.btn-primary{background:var(--red);border-color:var(--red);color:#fff}
.btn.primary:hover,
.btn.btn-primary:hover{background:var(--red-dark);border-color:var(--red-dark)}
.btn.ghost{background:transparent;border-color:var(--border);color:var(--charcoal)}
.btn.small{padding:10px 12px;border-radius:12px;font-size:14px}

.hero-card{
  background:linear-gradient(180deg, #fff, #fff);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:var(--shadow);
}
.hero-card h3{margin:0 0 8px;font-size:16px}
.hero-card ul{margin:0;padding-left:18px;color:var(--muted)}
.hero-card li{margin:8px 0}

.divider{height:1px;background:var(--border);margin:14px 0}

/* Trust row under hero */
.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}
.trust-item{border:1px solid var(--border);border-radius:16px;padding:12px 14px;background:#fff;box-shadow:0 4px 14px rgba(0,0,0,.04)}
.trust-item strong{display:block;font-size:14px}
.trust-item span{display:block;font-size:13px;color:var(--muted);margin-top:2px}

/* Sections */
.section{padding:34px 0}
.section h2{font-size:28px;margin:0 0 10px}
.section p.lead{color:var(--muted);font-size:16px;margin:0 0 18px}

/* HTML uses .section-title + .section-sub */
.section-title{font-size:28px;margin:0 0 10px}
.section-sub{color:var(--muted);font-size:16px;margin:0 0 18px}
.section.alt{background:#F3F1EE;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

.cards{display:grid;grid-template-columns:repeat(3, 1fr);gap:14px}
.card{border:1px solid var(--border);border-radius:var(--radius);padding:18px;background:var(--card);box-shadow:0 4px 18px rgba(0,0,0,.04)}
.card h3{margin:0 0 8px;font-size:18px}
.card p{margin:0 0 12px;color:var(--muted)}
.card-img{width:100%;height:170px;object-fit:cover;border-radius:16px;border:1px solid var(--border);background:#eee;margin:0 0 12px}
@media (max-width: 600px){.card-img{height:160px}}


.tag{display:inline-flex;align-items:center;font-size:12px;font-weight:700;color:var(--charcoal);background:#f3f4f6;border:1px solid var(--border);padding:4px 10px;border-radius:999px;margin-left:8px;vertical-align:middle}
.meta{color:var(--muted);font-size:14px;margin:6px 0}
.link{font-weight:800;color:var(--red)}
.link:hover{color:var(--red-dark)}

.list{margin:0 0 12px;padding-left:18px;color:var(--muted)}
.list li{margin:8px 0}

.card.callout{border-color:rgba(191,23,36,.35);background:linear-gradient(180deg, rgba(191,23,36,.06), #fff)}
.card.callout p{color:var(--muted)}
.badge{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:#111827;background:#f3f4f6;border:1px solid #e5e7eb;padding:6px 10px;border-radius:999px}
.badge .dot{width:8px;height:8px;background:var(--red);border-radius:999px}

.split{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
.panel{border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:0 4px 18px rgba(0,0,0,.04)}
.panel h3{margin:0 0 10px}

/* Simple 3-column grid blocks used on index + other pages */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.feature{border:1px solid var(--border);border-radius:var(--radius);padding:18px;background:#fff;box-shadow:0 4px 18px rgba(0,0,0,.04)}
.feature h3{margin:0 0 8px}
.feature p{margin:0;color:var(--muted)}

/* Booking */
.booking-frame{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}

/* Banner CTA block (used on index) */
.banner{
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px;
  background: linear-gradient(180deg, rgba(191,23,36,.06), var(--card));
  box-shadow: var(--shadow);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.banner h2{margin:0 0 6px;font-size:24px}
.banner p{margin:0;color:var(--muted)}

/* Footer */
.footer{padding:30px 0;border-top:1px solid var(--border);margin-top:30px}
.footer-grid{display:grid;grid-template-columns: 1.2fr .8fr .8fr;gap:18px;align-items:start}
.footer-brand{display:flex;align-items:center;gap:12px}
.footer-brand img{width:44px;height:44px;border-radius:999px}
.footer-links{display:grid;gap:8px;margin-top:10px}
.footer-links a{color:var(--muted);text-decoration:none}
.footer-links a:hover{color:var(--charcoal);text-decoration:underline}

.small{font-size:12px;color:var(--muted)}
.tiny{margin-top:14px;color:var(--muted);font-size:12px}
.muted{color:var(--muted)}

/* Forms */
form{display:grid;gap:12px}
label{font-size:13px;color:#111827;font-weight:600}
input,select,textarea{width:100%;padding:12px 12px;border-radius:14px;border:1px solid var(--border);font:inherit}
textarea{min-height:120px;resize:vertical}
.help{font-size:12px;color:var(--muted)}

/* Responsive */
@media (max-width: 940px){
  .hero-grid{grid-template-columns:1fr}
  .hero h1{font-size:40px}
  .cards{grid-template-columns:1fr 1fr}
  .trust{grid-template-columns:1fr;}
  .grid-3{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .banner{flex-direction:column;align-items:flex-start}
}
@media (max-width: 720px){
  .nav{display:none}
  .menu-btn,
  .burger{display:inline-flex}
  .cards{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .hero{padding-top:34px}
  .hero h1{font-size:34px}
  .grid-3{grid-template-columns:1fr}
}

/* Social links */
.social{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.social a{font-size:0.95rem;text-decoration:none}
.social a:hover{text-decoration:underline}

/* Honeypot field for spam protection (keep off-screen) */
.hp-field{
  position:absolute !important;
  left:-10000px !important;
  top:auto !important;
  width:1px !important;
  height:1px !important;
  overflow:hidden !important;
  opacity:0 !important;
  pointer-events:none !important;
}

/* Contact form confirmation banner */
.contact-confirm{
  margin:12px 0 16px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  font-weight:700;
}
.contact-confirm.ok{
  border-color: rgba(191,23,36,.25);
  background: rgba(191,23,36,.06);
}
.contact-confirm.err{
  border-color: rgba(185,28,28,.25);
  background: rgba(185,28,28,.06);
}
