:root{
  --bg:#071410;
  --bg2:#0B1916;
  --paper:#F6F3EE;
  --paper2:#FBFAF8;
  --ink:#151A18;
  --muted:#6B736F;
  --muted2:#8A928D;
  --gold:#C6A86B;
  --gold2:#B69350;
  --line:rgba(198,168,107,0.22);
  --glass: rgba(255,255,255,0.06);
  --glass2: rgba(255,255,255,0.10);
  --shadow: 0 28px 80px rgba(0,0,0,0.28);
  --shadow2: 0 14px 38px rgba(0,0,0,0.14);
  --radius: 18px;
  --radius2: 28px;
  --max: 1180px;
  --ease: cubic-bezier(.2,.8,.2,1);
  --serif: "Playfair Display", ui-serif, Georgia, "Times New Roman", serif;
  --sans: Inter, system-ui, -apple-system, Segoe UI, Arial, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: var(--sans);
  color: var(--ink);
  background: radial-gradient(1200px 900px at 80% -10%, rgba(198,168,107,0.10), transparent 55%),
              radial-gradient(900px 700px at 10% 10%, rgba(15,30,26,0.08), transparent 60%),
              var(--paper);
  line-height:1.7;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a{color:inherit}
img{max-width:100%; display:block}
.container{max-width:var(--max); margin:0 auto; padding:0 26px}
.skip{position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden}
.skip:focus{left:16px; top:16px; width:auto; height:auto; background:var(--paper2); padding:10px 12px; border-radius:12px; box-shadow:var(--shadow2); z-index:9999}

/* NAV */
.nav{
  position:fixed; inset:0 0 auto 0;
  z-index:1000;
  background: rgba(7,20,16,0.28);
  border-bottom: 1px solid rgba(255,255,255,0.10);
  backdrop-filter: blur(14px) saturate(1.15);
  transition: background 280ms var(--ease), border-color 280ms var(--ease);
}
.nav.is-solid{background: rgba(7,20,16,0.92); border-bottom-color: rgba(198,168,107,0.18)}
.nav-inner{display:flex; align-items:center; justify-content:space-between; height:82px; gap: 14px}
.brand{display:flex; align-items:center; gap:12px; text-decoration:none}
.mark{
  width:36px; height:36px; border-radius:14px;
  background: linear-gradient(135deg, rgba(198,168,107,0.95), rgba(198,168,107,0.18));
  border:1px solid rgba(255,255,255,0.14);
  box-shadow: 0 18px 40px rgba(198,168,107,0.14);
}
.brand strong{
  color: var(--paper2);
  letter-spacing: 0.2px;
  font-family: var(--serif);
  font-weight: 700;
  font-size: 18px;
  line-height:1.1;
}
.brand span{
  display:block; color: rgba(246,243,238,0.72);
  font-size: 12px; letter-spacing: 1.2px; text-transform: uppercase;
}
.menu{display:flex; align-items:center; gap: 10px}
.menu a{
  color: rgba(246,243,238,0.86);
  text-decoration:none;
  font-size: 12px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  padding: 10px 12px;
  border-radius: 999px;
  transition: background 200ms var(--ease), color 200ms var(--ease), transform 200ms var(--ease);
}
.menu a:hover{background: rgba(255,255,255,0.08); color: var(--paper2); transform: translateY(-1px)}
.cta{display:flex; align-items:center; gap:10px}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding: 12px 16px;
  border-radius: 999px;
  border:1px solid rgba(198,168,107,0.32);
  background: rgba(198,168,107,0.08);
  color: var(--paper2);
  text-decoration:none;
  font-size: 12px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  transition: transform 200ms var(--ease), background 200ms var(--ease), border-color 200ms var(--ease), box-shadow 200ms var(--ease);
}
.btn:hover{transform: translateY(-1px); background: rgba(198,168,107,0.16); border-color: rgba(198,168,107,0.55); box-shadow: 0 10px 28px rgba(0,0,0,0.20)}
.btn.primary{
  background: linear-gradient(135deg, rgba(198,168,107,0.98), rgba(182,147,80,0.92));
  color: #111513;
  border-color: rgba(255,255,255,0.18);
}
.btn.primary:hover{background: linear-gradient(135deg, rgba(198,168,107,1), rgba(182,147,80,0.98))}
.iconbtn{
  width:44px; height:44px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.06);
  color: var(--paper2);
  display:inline-flex; align-items:center; justify-content:center;
  cursor:pointer;
  transition: transform 180ms var(--ease), background 180ms var(--ease);
}
.iconbtn:hover{transform: translateY(-1px); background: rgba(255,255,255,0.10)}
.lang{position:relative}
.langmenu{
  position:absolute; right:0; top: 54px; min-width: 170px;
  background: rgba(7,20,16,0.98);
  border: 1px solid rgba(198,168,107,0.20);
  border-radius: 16px;
  box-shadow: var(--shadow);
  overflow:hidden;
  display:none;
}
.langmenu a{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding: 12px 14px;
  text-decoration:none;
  color: rgba(246,243,238,0.90);
  font-size: 13px;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.langmenu a:first-child{border-top:none}
.langmenu a:hover{background: rgba(255,255,255,0.06)}
.langmenu.is-open{display:block}
.burger{display:none}
.mobilepanel{
  display:none;
  position:fixed; inset:82px 0 auto 0;
  background: rgba(7,20,16,0.98);
  border-bottom:1px solid rgba(198,168,107,0.18);
}
.mobilepanel a{
  display:block;
  padding:16px 26px;
  color: rgba(246,243,238,0.92);
  text-decoration:none;
  letter-spacing:1px;
  text-transform:uppercase;
  font-size:12px;
  border-top:1px solid rgba(255,255,255,0.06);
}
.mobilepanel a:hover{background: rgba(255,255,255,0.06)}
.mobilepanel.is-open{display:block}

/* HERO */
.hero{
  min-height: 100vh;
  color: var(--paper2);
  position:relative;
  overflow:hidden;
  background: radial-gradient(1200px 800px at 70% 12%, rgba(198,168,107,0.22), transparent 62%),
              linear-gradient(180deg, rgba(7,20,16,0.18), rgba(7,20,16,0.86)),
              url("../img/photos/exterior.webp");
  background-size: cover;
  background-position:center;
  display:flex;
  align-items:flex-end;
}
.hero::after{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(600px 380px at 18% 30%, rgba(255,255,255,0.08), transparent 55%);
  pointer-events:none;
}
.hero-inner{padding: 166px 0 78px; position:relative}
.kicker{display:inline-flex; gap:10px; align-items:center; font-size: 12px; letter-spacing: 1.8px; text-transform: uppercase; color: rgba(246,243,238,0.80)}
.kicker .dot{width:8px; height:8px; border-radius:99px; background: var(--gold); box-shadow: 0 0 0 7px rgba(198,168,107,0.18)}
.hero h1{
  font-family: var(--serif);
  margin: 18px 0 10px;
  font-size: clamp(44px, 5.2vw, 78px);
  line-height: 1.02;
  letter-spacing: -0.6px;
}
.hero p{max-width: 58ch; margin: 0 0 28px; font-size: clamp(16px, 1.6vw, 18px); color: rgba(246,243,238,0.86)}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap}
.hero-meta{margin-top: 34px; display:flex; gap:12px; flex-wrap:wrap}
.pill{
  display:inline-flex; align-items:center;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  color: rgba(246,243,238,0.86);
  font-size: 13px;
}
.pill b{color: var(--paper2); font-weight:600}

/* SECTIONS */
.section{padding: 98px 0}
.section.alt{background: linear-gradient(180deg, rgba(255,255,255,0.45), rgba(255,255,255,0.0))}
.section.dark{
  background: radial-gradient(1200px 900px at 20% -10%, rgba(198,168,107,0.12), transparent 60%),
              linear-gradient(180deg, var(--bg2), var(--bg));
  color: var(--paper2);
}
.head{display:flex; align-items:flex-end; justify-content:space-between; gap:18px; flex-wrap:wrap; margin-bottom: 28px}
.head h2{font-family: var(--serif); margin:0; font-size: 40px; letter-spacing: -0.4px}
.head p{margin:0; max-width: 60ch; color: var(--muted)}
.section.dark .head p{color: rgba(246,243,238,0.78)}
.grid{display:grid; grid-template-columns: repeat(12, 1fr); gap: 18px}
.card{
  grid-column: span 4;
  background: rgba(255,255,255,0.88);
  border-radius: var(--radius2);
  border: 1px solid rgba(10,14,12,0.08);
  box-shadow: var(--shadow2);
  overflow:hidden;
  transition: transform 260ms var(--ease), box-shadow 260ms var(--ease), background 260ms var(--ease);
}
.card:hover{transform: translateY(-4px); box-shadow: var(--shadow)}
.section.dark .card{background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.10); box-shadow: none}
.card .media{aspect-ratio: 16/10; background: linear-gradient(135deg, rgba(198,168,107,0.18), rgba(7,20,16,0.85)); border-bottom: 1px solid rgba(10,14,12,0.06)}
.section.dark .card .media{border-bottom-color: rgba(255,255,255,0.06)}
.card .body{padding: 22px 22px 20px}
.card h3{margin: 0 0 8px; font-size: 18px; letter-spacing: -0.2px; font-weight: 650}
.card p{margin: 0 0 16px; color: var(--muted)}
.section.dark .card p{color: rgba(246,243,238,0.74)}
.meta{display:flex; gap:10px; flex-wrap:wrap; font-size: 13px; color: rgba(107,115,111,0.92)}
.section.dark .meta{color: rgba(246,243,238,0.74)}
.chip{display:inline-flex; align-items:center; gap:8px; padding: 8px 10px; border-radius: 999px; border: 1px solid rgba(198,168,107,0.24); background: rgba(198,168,107,0.07); color: inherit}
.chip i{width:6px; height:6px; border-radius:99px; background: var(--gold); display:inline-block}
.split{display:grid; grid-template-columns: 1.18fr 1fr; gap: 26px; align-items:stretch}
.panel{border-radius: var(--radius2); overflow:hidden; border: 1px solid rgba(255,255,255,0.10); background: rgba(255,255,255,0.06)}
.panel .pad{padding: 26px}
.panel h3{font-family: var(--serif); margin: 0 0 10px; font-size: 28px}
.panel p{margin:0}
.section.dark .panel p{color: rgba(246,243,238,0.80)}
.panel .img{min-height: 390px; background: url("../img/photos/onsen-1.webp") center/cover no-repeat; filter: saturate(1.05)}
.panel .img.alt{background-image:url("../img/photos/room-street-twin-1.webp")}

/* GALLERY */
.gallery{display:grid; grid-template-columns: repeat(12, 1fr); gap: 14px}
.gallery a{position:relative; display:block; border-radius: 22px; overflow:hidden; border: 1px solid rgba(10,14,12,0.08); box-shadow: var(--shadow2); transform: translateZ(0)}
.gallery a:hover{box-shadow: var(--shadow)}
.gallery img{width:100%; height:100%; object-fit:cover; transition: transform 700ms var(--ease)}
.gallery a:hover img{transform: scale(1.03)}
.gallery .g1{grid-column: span 7; aspect-ratio: 16/9}
.gallery .g2{grid-column: span 5; aspect-ratio: 16/9}
.gallery .g3{grid-column: span 4; aspect-ratio: 1/1}
.gallery .g4{grid-column: span 4; aspect-ratio: 1/1}
.gallery .g5{grid-column: span 4; aspect-ratio: 1/1}
.badge{position:absolute; left:14px; top:14px; padding: 8px 10px; border-radius: 999px; background: rgba(7,20,16,0.78); border: 1px solid rgba(198,168,107,0.26); color: rgba(246,243,238,0.92); font-size: 11px; letter-spacing: 1.1px; text-transform: uppercase}

/* BOOKING */
.formwrap{display:grid; grid-template-columns: 1fr 1fr; gap: 18px; background: rgba(255,255,255,0.92); border: 1px solid rgba(10,14,12,0.08); border-radius: var(--radius2); box-shadow: var(--shadow2); overflow:hidden}
.formwrap .aside{
  background: radial-gradient(900px 520px at 70% 18%, rgba(198,168,107,0.20), transparent 62%),
              linear-gradient(180deg, rgba(7,20,16,0.72), rgba(7,20,16,0.95)),
              url("../img/photos/exterior.webp");
  background-size: cover; background-position:center;
  color: var(--paper2);
  padding: 28px;
}
.formwrap .aside h3{font-family:var(--serif); margin:0 0 8px; font-size: 28px}
.formwrap .aside p{margin:0; color: rgba(246,243,238,0.84)}
.formwrap form{padding: 28px}
.field{display:flex; flex-direction:column; gap:8px; margin-bottom: 14px}
label{font-size: 11px; letter-spacing: 1.4px; text-transform: uppercase; color: rgba(21,26,24,0.72)}
input, select, textarea{font: inherit; padding: 12px 12px; border-radius: 14px; border: 1px solid rgba(10,14,12,0.14); outline:none; background: var(--paper2)}
input:focus, select:focus, textarea:focus{border-color: rgba(198,168,107,0.70); box-shadow: 0 0 0 5px rgba(198,168,107,0.16)}
.row2{display:grid; grid-template-columns: 1fr 1fr; gap: 12px}
.notice{font-size: 13px; color: rgba(21,26,24,0.68); margin: 10px 0 0}
.result{margin-top: 14px; padding: 14px 14px; border-radius: 16px; border: 1px solid rgba(198,168,107,0.30); background: rgba(198,168,107,0.10); display:none}
.result.show{display:block}

/* PAGE HERO */
.page-hero{
  padding: 148px 0 58px;
  background: radial-gradient(1000px 700px at 70% 0%, rgba(198,168,107,0.22), transparent 60%),
              linear-gradient(180deg, rgba(7,20,16,0.20), rgba(7,20,16,0.92)),
              url("../img/photos/room-lake-2.webp");
  background-size: cover;
  background-position:center;
  color: var(--paper2);
}
.page-hero h1{font-family:var(--serif); margin:0 0 8px; font-size: 56px; letter-spacing:-0.4px}
.breadcrumbs{font-size: 11px; letter-spacing: 1.6px; text-transform: uppercase; color: rgba(246,243,238,0.78)}

/* TABLE */
.table{
  width:100%;
  border-collapse: separate;
  border-spacing: 0;
  overflow:hidden;
  border-radius: 18px;
  border: 1px solid rgba(10,14,12,0.08);
  background: rgba(255,255,255,0.92);
  box-shadow: var(--shadow2);
}
.table th, .table td{padding: 14px 14px; border-bottom: 1px solid rgba(10,14,12,0.08); text-align:left; font-size: 14px}
.table th{background: rgba(198,168,107,0.12); letter-spacing: 1.0px; text-transform: uppercase; font-size: 11px; color: rgba(21,26,24,0.78)}
.table tr:last-child td{border-bottom:none}

.map{border-radius: var(--radius2); overflow:hidden; border: 1px solid rgba(10,14,12,0.08); box-shadow: var(--shadow2); background: rgba(255,255,255,0.92)}
.map iframe{width:100%; height:360px; border:0}

/* FOOTER */
.footer{
  background: radial-gradient(900px 520px at 20% 0%, rgba(198,168,107,0.10), transparent 60%),
              linear-gradient(180deg, var(--bg2), var(--bg));
  color: rgba(246,243,238,0.86);
  padding: 58px 0;
}
.footgrid{display:grid; grid-template-columns: 2fr 1fr 1fr; gap: 18px}
.footer h4{font-family:var(--serif); margin: 0 0 10px; color: var(--paper2)}
.footer a{color: rgba(246,243,238,0.86); text-decoration:none}
.footer a:hover{color: var(--paper2)}
.small{font-size: 13px; color: rgba(246,243,238,0.72)}
.hr{height:1px; background: rgba(255,255,255,0.10); margin: 18px 0}

/* REVEAL */
.reveal{opacity:0; transform: translateY(16px); transition: opacity 820ms var(--ease), transform 820ms var(--ease)}
.reveal.is-in{opacity:1; transform: translateY(0)}

/* FLOAT */
.floatbook{
  position:fixed; right: 18px; bottom: 18px; z-index: 1200;
  display:flex; gap:10px; align-items:center;
  padding: 10px 10px; border-radius: 999px;
  background: rgba(7,20,16,0.88);
  border: 1px solid rgba(198,168,107,0.22);
  box-shadow: var(--shadow);
  backdrop-filter: blur(12px);
}
.floatbook .label{color: rgba(246,243,238,0.86); font-size: 12px; letter-spacing: 1.1px; text-transform: uppercase; display:none}
.floatbook:hover .label{display:block}

/* REDUCED MOTION */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .reveal{transition:none}
  .gallery img{transition:none}
  .btn, .iconbtn, .menu a{transition:none}
}

/* RESPONSIVE */
@media (max-width: 1040px){
  .split{grid-template-columns: 1fr}
  .panel .img{min-height: 320px}
  .formwrap{grid-template-columns: 1fr}
  .footgrid{grid-template-columns: 1fr}
}
@media (max-width: 880px){
  .menu{display:none}
  .burger{display:inline-flex}
}
@media (max-width: 680px){
  .nav-inner{height:76px}
  .mobilepanel{inset:76px 0 auto 0}
  .row2{grid-template-columns: 1fr}
  .head h2{font-size: 34px}
  .page-hero h1{font-size: 44px}
}


/* FINAL PRO refinements */
.hero{
  background-image:
    radial-gradient(1200px 820px at 70% 10%, rgba(198,168,107,0.22), transparent 62%),
    linear-gradient(180deg, rgba(7,20,16,0.10), rgba(7,20,16,0.90)),
    url("../img/photos/exterior.webp");
}
.hero::before{
  content:"";
  position:absolute; inset:-20%;
  background-image: radial-gradient(circle at 20% 30%, rgba(255,255,255,0.06), transparent 38%),
                    radial-gradient(circle at 80% 10%, rgba(198,168,107,0.10), transparent 40%);
  filter: blur(10px);
  opacity: .85;
  pointer-events:none;
}
.hero::after{opacity: .7;}
/* better image rendering for webp */
img{image-rendering:auto}
/* Rooms page immersive sections */
.room-hero{
  display:grid;
  grid-template-columns: 1.08fr 1fr;
  gap: 22px;
  align-items: stretch;
}
.room-hero .photo{
  border-radius: var(--radius2);
  overflow:hidden;
  border: 1px solid rgba(10,14,12,0.08);
  box-shadow: var(--shadow2);
  min-height: 420px;
  background: center/cover no-repeat;
}
.room-hero .copy{
  border-radius: var(--radius2);
  border: 1px solid rgba(10,14,12,0.08);
  background: rgba(255,255,255,0.92);
  box-shadow: var(--shadow2);
  padding: 26px;
}
.room-hero .copy h2{font-family: var(--serif); margin:0 0 10px; font-size: 40px; letter-spacing:-0.4px}
.room-hero .copy p{margin:0 0 16px; color: rgba(21,26,24,0.72)}
.room-specs{display:flex; gap:10px; flex-wrap:wrap; margin-top: 14px}
.room-specs .chip{background: rgba(198,168,107,0.08)}
@media (max-width: 1040px){
  .room-hero{grid-template-columns: 1fr}
  .room-hero .photo{min-height: 320px}
}
