:root {
  --ink: #171514;
  --stone: #5f625b;
  --night: #061b27;
  --blue: #0b5362;
  --paper: #f4ead9;
  --white: #fffaf0;
  --gold: #c9973c;
  --line: rgba(23, 21, 20, .15);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; }
img { display: block; width: 100%; height: 100%; object-fit: cover; }
a { color: inherit; text-decoration: none; }

.topbar {
  position: sticky; top: 0; z-index: 20;
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
  min-height: 64px; padding: 0 34px; color: var(--white);
  background: rgba(23,21,20,.94); backdrop-filter: blur(18px);
}
.brand { color: var(--gold); font-family: Fraunces, Georgia, serif; font-size: 24px; font-weight: 900; }
nav { display: flex; gap: 28px; font-size: 12px; font-weight: 900; }
.lang { justify-self: end; display: inline-flex; gap: 4px; padding: 4px; border: 1px solid rgba(255,255,255,.18); border-radius: 999px; }
.lang button { width: 34px; height: 28px; border: 0; border-radius: 999px; color: var(--white); background: transparent; font: 900 11px Inter, sans-serif; cursor: pointer; }
.lang button.active { color: var(--ink); background: var(--gold); }

.hero {
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(280px, .5fr); gap: 48px; align-items: end;
  min-height: calc(100vh - 64px); padding: 76px 48px 56px; color: var(--white);
  background:
    linear-gradient(90deg, rgba(23,21,20,.96) 0%, rgba(23,21,20,.78) 46%, rgba(23,21,20,.25) 100%),
    url("assets/kosi-hero.jpg") center/cover;
}
.hero-copy { max-width: 840px; }
.kicker { margin: 0 0 18px; color: var(--gold); font-size: 12px; font-weight: 900; letter-spacing: 0; text-transform: uppercase; }
h1, h2, h3 { margin: 0; font-family: Fraunces, Georgia, serif; line-height: .9; letter-spacing: 0; overflow-wrap: anywhere; }
h1 { max-width: 820px; font-size: clamp(74px, 8.5vw, 150px); }
h2 { font-size: clamp(42px, 5.2vw, 86px); }
h3 { font-size: 32px; }
.lead { max-width: 680px; margin: 28px 0 0; color: rgba(255,250,240,.86); font-size: 19px; line-height: 1.65; }
.actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.btn, .pill { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 0 22px; border-radius: 999px; font-size: 13px; font-weight: 900; }
.primary, .pill:first-child { color: var(--ink); background: var(--gold); }
.secondary, .pill { color: var(--white); border: 1px solid rgba(255,255,255,.28); background: rgba(255,255,255,.08); }
.proof { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; max-width: 580px; margin-top: 30px; }
.proof div, .hero-card { border: 1px solid rgba(255,255,255,.16); border-radius: 8px; background: rgba(255,255,255,.09); backdrop-filter: blur(12px); }
.proof div { padding: 18px; }
.proof strong, .proof span, .hero-card span, .hero-card strong { display: block; }
.proof strong { color: var(--gold); font-size: 23px; }
.proof span { margin-top: 4px; color: rgba(255,250,240,.74); font-size: 12px; font-weight: 800; }
.hero-card { align-self: end; padding: 28px; color: var(--white); }
.hero-card span { color: var(--gold); font-size: 12px; font-weight: 900; text-transform: uppercase; }
.hero-card strong { margin-top: 10px; font-family: Fraunces, Georgia, serif; font-size: 36px; line-height: .95; }

.story, .reviews, .contact {
  display: grid; grid-template-columns: .82fr 1.18fr; gap: 48px; padding: 96px 48px;
}
.story p, .day-copy p, .contact-card p, .offer-grid p { color: rgba(23,21,20,.72); font-size: 17px; line-height: 1.7; }
.story > p { max-width: 780px; font-size: 21px; }
.daynight, .lounge { display: grid; grid-template-columns: 1fr 1fr; }
.daynight > *, .lounge > * { min-width: 0; }
.day-photo, .lounge img { min-height: 660px; }
.day-copy, .lounge-copy { align-self: center; padding: 74px 64px; }
.daynight { background: #e7dfd0; }
.lounge { color: var(--white); background: var(--night); }
.lounge .kicker { color: #efd083; }

.offer { color: var(--white); background: var(--stone); }
.section-head { display: grid; grid-template-columns: .35fr .65fr; gap: 40px; align-items: end; padding: 96px 48px 42px; }
.offer-grid { display: grid; grid-template-columns: repeat(3, 1fr); }
.offer-grid article { min-width: 0; min-height: 330px; padding: 34px; border-top: 1px solid rgba(255,255,255,.14); border-right: 1px solid rgba(255,255,255,.14); }
.offer-grid span { color: var(--gold); font-size: 13px; font-weight: 900; }
.offer-grid p { color: rgba(255,250,240,.75); }

.reviews { color: var(--white); background: var(--blue); }
.reviews .kicker { color: #efd083; }
.quotes { display: grid; gap: 14px; }
.quotes blockquote, .hours { border: 1px solid var(--line); border-radius: 8px; background: rgba(255,255,255,.62); }
.quotes blockquote { margin: 0; padding: 24px; color: var(--ink); font-family: Fraunces, Georgia, serif; font-size: 28px; line-height: 1.08; overflow-wrap: anywhere; }
.contact { align-items: start; }
.contact-card { padding: 44px; border-radius: 8px; color: var(--white); background: var(--night); }
.contact-card p { color: rgba(255,250,240,.78); }
.hours { padding: 34px; }
.hours h3 { margin-bottom: 24px; font-size: 28px; }
.hours p { display: flex; justify-content: space-between; gap: 20px; padding: 18px 0; margin: 0; border-top: 1px solid var(--line); font-size: 14px; }
.hours strong { text-align: right; }
footer { display: flex; justify-content: space-between; gap: 18px; padding: 26px 48px; color: rgba(255,250,240,.76); background: #100f0e; font-size: 13px; font-weight: 900; }

@media (max-width: 1000px) {
  .topbar { grid-template-columns: 1fr auto; }
  nav { display: none; }
  .hero, .story, .daynight, .lounge, .section-head, .reviews, .contact { grid-template-columns: 1fr; }
  .hero { min-height: auto; padding: 54px 22px 30px; }
  h1 { font-size: clamp(58px, 16vw, 106px); }
  .story, .section-head, .reviews, .contact { padding: 64px 22px; }
  .day-copy, .lounge-copy { padding: 56px 22px; }
  .day-photo, .lounge img { width: 100%; max-width: 100%; min-height: 420px; }
  .offer-grid { grid-template-columns: 1fr; }
}

@media (max-width: 560px) {
  .topbar { min-height: 58px; padding: 0 14px; }
  .brand { font-size: 20px; }
  .lang button { width: 30px; }
  .lead, .story > p { font-size: 17px; }
  .proof { grid-template-columns: 1fr; }
  .hero-card strong { font-size: 29px; }
  h2 { font-size: clamp(38px, 13vw, 58px); }
  .contact-card, .hours, .quotes blockquote { padding: 24px; }
  .quotes blockquote { font-size: 23px; }
  footer { display: grid; padding: 24px 22px; }
}
