/* Dark western elegance — Snake River Hat Company */
:root{
  --bg:#0b0f14;
  --panel:#0f1621;
  --text:#e9edf3;
  --muted:#b9c2cf;
  --faint:#8b95a5;
  --gold:#caa45a;
  --gold2:#f2d08a;
  --shadow: 0 18px 60px rgba(0,0,0,.45);
  --radius:18px;
  --radius2:28px;
  --max:1140px;
  --sans:system-ui,-apple-system,Segoe UI,Roboto,Arial;
  --serif:Georgia,"Times New Roman",Times,serif;
  --mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--text);
  line-height:1.55;
  background:
    radial-gradient(1200px 600px at 15% -10%, rgba(202,164,90,.22), transparent 60%),
    radial-gradient(900px 500px at 90% 5%, rgba(242,208,138,.14), transparent 55%),
    linear-gradient(180deg, var(--bg), #070a0f 75%);
}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
.container{width:min(var(--max), calc(100% - 40px));margin:0 auto}
.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:12px;top:12px;width:auto;height:auto;padding:10px 12px;background:rgba(15,22,33,.95);border:1px solid rgba(242,208,138,.2);border-radius:12px;z-index:9999}
.site-header{
  position:sticky;top:0;z-index:1000;
  background:rgba(11,15,20,.72);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:18px}
.brand-logo{height:44px;width:auto;display:block}
.nav{display:flex;align-items:center;gap:10px;position:relative}
.nav-links{display:flex;align-items:center;gap:14px}
.nav-links a{padding:10px 10px;border-radius:12px;color:var(--muted)}
.nav-links a:hover{text-decoration:none;color:var(--text);background:rgba(255,255,255,.04)}
.nav-cta{border:1px solid rgba(242,208,138,.18);background:linear-gradient(180deg, rgba(202,164,90,.18), rgba(255,255,255,.00))}
.nav-toggle{display:none;width:44px;height:44px;border-radius:14px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.03);color:var(--text);cursor:pointer}
.nav-toggle-bars{display:block;width:18px;height:2px;background:var(--text);margin:0 auto;position:relative}
.nav-toggle-bars:before,.nav-toggle-bars:after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--text)}
.nav-toggle-bars:before{top:-6px}
.nav-toggle-bars:after{top:6px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
.hero{position:relative;padding:46px 0 26px;overflow:hidden}
.hero-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(11,15,20,.88), rgba(11,15,20,.58) 45%, rgba(11,15,20,.08) 78%, rgba(11,15,20,.0) 100%),
    radial-gradient(900px 500px at 18% 30%, rgba(202,164,90,.22), transparent 62%),
    radial-gradient(860px 460px at 70% 22%, rgba(242,208,138,.14), transparent 62%),
    url('/assets/img/hero.jpg');
  background-size: cover;
  background-position: center 35%;
  filter: grayscale(1) contrast(1.12) brightness(0.92);
  pointer-events:none;
}
.hero-inner{position:relative;display:grid;grid-template-columns:1.2fr .8fr;gap:26px;align-items:start}
.eyebrow{font-family:var(--mono);color:rgba(242,208,138,.88);letter-spacing:.08em;text-transform:uppercase;font-size:12px;margin:0 0 10px}
h1{font-family:var(--serif);font-weight:700;font-size:clamp(34px,4.3vw,56px);line-height:1.08;margin:0 0 14px}
.lead{color:var(--muted);font-size:16.8px;margin:0 0 20px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin:18px 0 12px}
.hero-badges{margin:14px 0 0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:10px}
.hero-badges li{padding:10px 12px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);border-radius:999px;color:var(--faint);font-size:13px}
.section{padding:64px 0}
.section-alt{background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.00));border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06)}
.section-footer{padding-top:64px;background:radial-gradient(900px 400px at 15% 40%, rgba(202,164,90,.18), transparent 65%),linear-gradient(180deg, rgba(15,22,33,.55), rgba(11,15,20,.0) 80%);border-top:1px solid rgba(255,255,255,.08)}
.section-head{max-width:780px;margin-bottom:24px}
.section-head h2{font-family:var(--serif);font-size:34px;margin:0 0 10px}
.section-head p{color:var(--muted);margin:0}
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-tight{gap:12px}
.card{background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.08);border-radius:var(--radius2);box-shadow:var(--shadow);overflow:hidden}
.card-header{padding:18px 18px 0}
.card-title{margin:0;font-family:var(--serif);font-size:22px}
.card-sub{margin:6px 0 0;color:var(--muted);font-size:13.5px}
.card-body{padding:18px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 14px;border-radius:16px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.03);color:var(--text);cursor:pointer;font-weight:650;letter-spacing:.01em}
.btn:hover{text-decoration:none;filter:brightness(1.06)}
.btn-primary{border:1px solid rgba(242,208,138,.26);background:linear-gradient(180deg, rgba(202,164,90,.30), rgba(15,22,33,.12));box-shadow:0 18px 60px rgba(0,0,0,.45),0 0 0 1px rgba(242,208,138,.10) inset}
.btn-ghost{border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.02)}
.btn-small{padding:10px 12px;border-radius:14px;font-size:13px}
.btn-block{width:100%}
.service{padding:18px;border-radius:var(--radius2);border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg, rgba(15,22,33,.65), rgba(15,22,33,.20))}
.service h3{margin:0 0 10px;font-family:var(--serif);font-size:20px}
.service p{margin:0 0 12px;color:var(--muted)}
.service ul{margin:0;padding-left:18px;color:var(--faint)}
.service li{margin:6px 0}
.contact-lines{display:flex;flex-direction:column;gap:10px}
.contact-line{display:flex;justify-content:space-between;gap:16px;padding:12px;border:1px solid rgba(255,255,255,.08);border-radius:16px;background:rgba(255,255,255,.02)}
.contact-line:hover{text-decoration:none;background:rgba(255,255,255,.04)}
.contact-k{color:var(--faint);font-family:var(--mono);font-size:12px}
.contact-v{font-weight:650}
.note{margin-top:14px;padding:12px;border-radius:16px;border:1px solid rgba(242,208,138,.18);background:radial-gradient(600px 240px at 15% 30%, rgba(202,164,90,.18), transparent 65%),rgba(255,255,255,.02)}
.note strong{display:block;font-family:var(--serif)}
.note span{color:var(--muted)}
.fineprint{margin:10px 0 0;color:rgba(185,194,207,.82);font-size:12.5px}
.gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.gallery-item{position:relative;border:1px solid rgba(255,255,255,.10);border-radius:22px;padding:0;background:rgba(255,255,255,.02);overflow:hidden;cursor:pointer}
.gallery-item img{width:100%;height:230px;object-fit:cover;display:block}
.gallery-label{position:absolute;left:12px;bottom:12px;padding:8px 10px;border-radius:999px;border:1px solid rgba(242,208,138,.20);background:rgba(11,15,20,.62);font-size:12.5px;backdrop-filter:blur(10px)}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.72);display:none;align-items:center;justify-content:center;padding:24px}
.lightbox.open{display:flex}
.lightbox-img{width:min(1100px,100%);max-height:76vh;object-fit:contain;border-radius:18px;border:1px solid rgba(255,255,255,.12);box-shadow:0 28px 90px rgba(0,0,0,.65);background:rgba(0,0,0,.20)}
.lightbox-caption{margin:12px 0 0;color:var(--muted);text-align:center}
.lightbox-close{position:absolute;top:16px;right:16px;width:46px;height:46px;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.04);color:var(--text);font-size:26px;cursor:pointer}
.reviews-layout{display:grid;grid-template-columns:1.2fr .8fr;gap:16px;align-items:start}
.reviews-panel{display:flex;flex-direction:column;gap:12px}
.reviews-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px}
.rating-summary{font-family:var(--mono);color:rgba(242,208,138,.90);font-size:12px;letter-spacing:.05em;text-transform:uppercase}
.review-card{border:1px solid rgba(255,255,255,.10);border-radius:var(--radius2);background:linear-gradient(180deg, rgba(15,22,33,.70), rgba(15,22,33,.30));padding:18px;box-shadow:var(--shadow);min-height:160px}
.review-top{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:10px}
.review-name{font-weight:760;font-family:var(--serif);font-size:18px}
.review-stars{color:rgba(242,208,138,.92);letter-spacing:.08em;font-family:var(--mono);font-size:12px}
.review-text{color:var(--muted);margin:0}
.review-meta{margin-top:10px;color:rgba(185,194,207,.70);font-size:12.5px}
.reviews-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.review-mini{border:1px solid rgba(255,255,255,.10);border-radius:18px;background:rgba(255,255,255,.02);padding:12px;cursor:pointer}
.review-mini:hover{background:rgba(255,255,255,.04)}
.review-mini .review-name{font-size:14px}
.review-mini .review-text{font-size:12.5px;margin-top:6px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.form{display:flex;flex-direction:column;gap:12px}
.field label{display:block;color:var(--faint);font-size:13px;margin-bottom:6px}
input,select,textarea{width:100%;padding:12px;border-radius:16px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.20);color:var(--text);outline:none}
textarea{resize:vertical}
input:focus,select:focus,textarea:focus{border-color:rgba(242,208,138,.30);box-shadow:0 0 0 3px rgba(202,164,90,.18)}
.hidden{display:none}
.checkbox{display:flex;align-items:flex-start;gap:10px;color:var(--muted);font-size:13px}
.checkbox input{width:auto;margin-top:4px}
.divider{height:1px;background:rgba(255,255,255,.08);margin:6px 0}
.steps{margin:0;padding-left:18px;color:var(--muted)}
.steps li{margin:10px 0}
.mini-contact{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.faq{border:1px solid rgba(255,255,255,.10);border-radius:18px;padding:12px;background:rgba(255,255,255,.02);margin-bottom:10px}
.faq summary{cursor:pointer;font-weight:680}
.faq p{color:var(--muted);margin:10px 0 0}
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:16px;align-items:start}
.muted{color:rgba(185,194,207,.88)}
.site-footer{margin-top:44px;padding:18px 0 10px;border-top:1px solid rgba(255,255,255,.08)}
.footer-inner{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:rgba(185,194,207,.80);font-size:13px}
.card-sticky{position:sticky;top:92px}
.form-success{border:1px solid rgba(242,208,138,.22);border-radius:var(--radius2);padding:16px;background:radial-gradient(700px 250px at 15% 35%, rgba(202,164,90,.16), transparent 65%),rgba(255,255,255,.02)}
.form-success h4{margin:0 0 8px;font-family:var(--serif)}
.form-success p{margin:0;color:var(--muted)}
@media (max-width:980px){
  .hero-inner,.reviews-layout,.contact-grid{grid-template-columns:1fr}
  .grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}
  .gallery{grid-template-columns:repeat(2,minmax(0,1fr))}
  .reviews-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .card-sticky{position:relative;top:auto}
}
@media (max-width:680px){
  .nav-toggle{display:inline-flex}
  .nav-links{
    position:absolute;right:0;top:56px;
    width:min(320px, calc(100vw - 40px));
    flex-direction:column;align-items:stretch;gap:6px;
    padding:10px;border-radius:18px;
    border:1px solid rgba(255,255,255,.10);
    background:rgba(11,15,20,.92);
    box-shadow:var(--shadow);
    display:none;
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:12px}
  .grid-2,.grid-3,.gallery,.reviews-grid{grid-template-columns:1fr}
}

/* Masonry gallery */
.gallery.masonry{
  column-count: 3;
  column-gap: 14px;
}
.gallery.masonry .gallery-item{
  display: inline-block;
  width: 100%;
  margin: 0 0 14px;
}
.gallery.masonry .gallery-item img{
  height: auto;
  display:block;
}
@media (max-width: 980px){
  .gallery.masonry{ column-count: 2; }
}
@media (max-width: 680px){
  .gallery.masonry{ column-count: 1; }
}

/* Subtle western texture overlay (very light) */
.hero-texture{
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity: .14;
  background-image:
    radial-gradient(circle at 10% 20%, rgba(242,208,138,.12), transparent 40%),
    radial-gradient(circle at 90% 30%, rgba(202,164,90,.10), transparent 45%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.02) 0 2px, rgba(0,0,0,.00) 2px 8px);
  mix-blend-mode: overlay;
}

/* Animated gold accents (subtle, premium) */
.hero-accents{
  position:absolute;
  inset:-120px -120px auto -120px;
  height: 720px;
  pointer-events:none;
  filter: blur(18px);
  opacity: .55;
  background:
    radial-gradient(500px 260px at 22% 40%, rgba(242,208,138,.22), transparent 65%),
    radial-gradient(520px 280px at 70% 30%, rgba(202,164,90,.20), transparent 65%);
  animation: floatGlow 10s ease-in-out infinite;
}
@keyframes floatGlow{
  0%{ transform: translate3d(0,0,0) scale(1); opacity:.50; }
  50%{ transform: translate3d(0,18px,0) scale(1.02); opacity:.62; }
  100%{ transform: translate3d(0,0,0) scale(1); opacity:.50; }
}

/* Booking */
.booking-box{
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius2);
  background: rgba(255,255,255,.02);
  padding: 14px;
}
.booking-placeholder code{
  font-family: var(--mono);
  padding: 2px 6px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  color: rgba(242,208,138,.90);
}
.calendly-inline-widget{
  border-radius: 18px;
  overflow: hidden;
  min-height: 720px;
}
@media (max-width: 680px){
  .calendly-inline-widget{ min-height: 760px; }
}

/* Film grain overlay (subtle) */
.film-grain{
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.08;
  background-image:
    repeating-radial-gradient(circle at 0 0, rgba(255,255,255,.04) 0 1px, rgba(0,0,0,0) 1px 3px);
  mix-blend-mode: overlay;
}
@media (prefers-reduced-motion: reduce){
  .hero-accents{ animation:none; }
}

/* Layout refinements */
.section-head{
  margin-bottom: 18px;
}
.grid{
  gap: 18px;
}
@media (max-width: 680px){
  .section{ padding: 64px 0 48px; }
  .grid{ gap: 14px; }
}
.center{ display:flex; justify-content:center; }

/* Gallery page */
.gallery-page-hero{
  padding-top: 110px;
}
.gallery-full{
  margin-top: 14px;
}

/* Nav dropdown */
.nav-drop{ position:relative; display:inline-flex; }
.nav-drop-menu{
  position:absolute;
  top: calc(100% + 10px);
  left: 0;
  min-width: 180px;
  background: rgba(11,15,20,.92);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px;
  padding: 8px;
  box-shadow: 0 16px 44px rgba(0,0,0,.55);
  backdrop-filter: blur(10px);
  display:none;
  z-index: 50;
}
.nav-drop-menu a{
  display:block;
  padding: 10px 12px;
  border-radius: 12px;
}
.nav-drop-menu a:hover{
  background: rgba(255,255,255,.06);
}
.nav-drop:hover .nav-drop-menu,
.nav-drop:focus-within .nav-drop-menu{
  display:block;
}

/* Rugged pass */
:root{
  --edge: rgba(255,255,255,.14);
  --edge2: rgba(255,255,255,.10);
}
body{
  background:
    radial-gradient(1200px 900px at 20% 0%, rgba(255,255,255,.03), transparent 60%),
    radial-gradient(900px 700px at 80% 10%, rgba(202,164,90,.06), transparent 62%),
    radial-gradient(1200px 900px at 50% 120%, rgba(0,0,0,.55), transparent 60%),
    linear-gradient(180deg, #070a0f 0%, #0b1017 55%, #070a0f 100%);
}
.card{
  border: 1px solid var(--edge2);
  background: rgba(255,255,255,.03);
}
.card::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  pointer-events:none;
  background:
    radial-gradient(800px 420px at 10% 0%, rgba(255,255,255,.05), transparent 55%),
    radial-gradient(700px 360px at 90% 10%, rgba(202,164,90,.05), transparent 55%);
  opacity:.7;
}
.btn{ border-color: rgba(255,255,255,.14); }
.btn-primary{ box-shadow: 0 10px 26px rgba(0,0,0,.55); }
.section{ position: relative; }
.section::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.05;
  mix-blend-mode: overlay;
  background-image:
    repeating-linear-gradient(115deg, rgba(255,255,255,.10) 0 1px, rgba(0,0,0,0) 1px 10px);
}
.hero-bg{
  background:
    radial-gradient(1200px 700px at 50% 20%, rgba(0,0,0,.15), rgba(0,0,0,.72) 70%),
    linear-gradient(180deg, rgba(0,0,0,.75), rgba(11,15,20,.55) 45%, rgba(11,15,20,.08) 78%, rgba(11,15,20,.0) 100%),
    radial-gradient(900px 500px at 18% 30%, rgba(202,164,90,.22), transparent 62%),
    radial-gradient(860px 460px at 70% 22%, rgba(242,208,138,.14), transparent 62%),
    url('/assets/img/hero.jpg');
  background-size: cover;
  background-position: center 35%;
  filter: grayscale(1) contrast(1.16) brightness(0.88);
}
#gallery .card{ max-width: 980px; margin: 0 auto; }
