/* =================================================================
   Andaman Stillness — Sunny Moon Phuket
   Mood: still, refined, geometric, intentional. Daytime-bright minimalism.
   Display: Unbounded (geometric display, Cyrillic ✓ — Russian-designed)
   Body:    Onest (neutral grotesque, Cyrillic ✓)
   Architectural-photo aesthetic. Numbered sections. Tabular data.
   No italic anywhere. Generous whitespace.
   ================================================================= */

:root{
  --bg:           #FAFAF8;        /* near-white, warm-tinted */
  --bg-alt:       #F0EDE7;        /* limestone-tan softer band */
  --line:        #1A1A18;
  --line-soft:   rgba(17,17,16,0.12);
  --line-mid:    rgba(17,17,16,0.24);
  --text:        #111110;
  --text-soft:   #4A4A47;
  --text-muted:  #8A8682;
  --accent:      #B8A082;         /* limestone-tan — single accent */
  --maxw:        1380px;
  --pad:         clamp(20px, 4vw, 72px);
  --rhythm:      clamp(96px, 14vw, 200px);
  --display:     "Unbounded", "Inter Tight", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --body:        "Onest", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --ease:        cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--body);
  font-size:16px;
  line-height:1.55;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:0}

.skip-nav{position:absolute;left:-999px;top:0;background:var(--text);color:#fff;padding:12px 16px;font-weight:600;z-index:99}
.skip-nav:focus{left:16px;top:16px}

/* Typography utilities */
.display{
  font-family:var(--display);
  font-weight:500;
  letter-spacing:-0.04em;
  line-height:1.02;
  font-size:clamp(36px, 5.6vw, 84px);
  margin:0 0 0.4em;
  color:var(--text);
}
.lede{
  font-family:var(--body);
  font-size:clamp(17px, 1.3vw, 19px);
  line-height:1.5;
  color:var(--text-soft);
  max-width:60ch;
  margin:0 0 1.2em;
  font-weight:400;
}
.section-num{
  font-family:var(--body);
  font-size:12px;font-weight:500;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--text-muted);
  margin:0 0 28px;
  font-variant-numeric:tabular-nums;
}
.section-num span{color:var(--text)}

/* Header — flat, monoline, hamburger-left */
.site-header{
  position:sticky;top:0;z-index:40;
  background:var(--bg);
  border-bottom:1px solid var(--line-soft);
}
.site-header__inner{
  max-width:var(--maxw);margin-inline:auto;
  display:grid;grid-template-columns:auto 1fr auto;
  align-items:center;gap:24px;
  padding:18px var(--pad);
}
.brand{
  display:flex;align-items:baseline;gap:12px;justify-content:center;
}
.brand__word{
  font-family:var(--display);
  font-size:18px;font-weight:500;letter-spacing:-0.02em;color:var(--text);
}
.brand__location{
  font-family:var(--body);
  font-size:12px;font-weight:500;letter-spacing:0.04em;
  color:var(--text-muted);
}

.nav{
  display:flex;justify-content:center;gap:48px;
  padding:14px var(--pad);
  border-bottom:1px solid var(--line-soft);
  font-size:13px;font-weight:500;letter-spacing:0.04em;
}
.nav a{color:var(--text-soft);transition:color .25s var(--ease)}
.nav a:hover{color:var(--text)}

.header-utils{display:flex;align-items:center;gap:14px}
.lang-switch{
  display:flex;gap:6px;align-items:center;
  font-family:var(--body);
  font-size:12px;font-weight:500;letter-spacing:0.1em;color:var(--text-soft);
  padding:8px 4px;
}
.lang-switch__active{color:var(--text)}
.lang-switch__divider{opacity:.4}

.cta{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--body);font-size:13px;font-weight:500;
  letter-spacing:0.04em;
  padding:12px 22px;border-radius:0;
  transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
  white-space:nowrap;
  min-height:44px;
}
.cta--primary{background:var(--text);color:var(--bg)}
.cta--primary:hover{background:#000}
.cta--ghost{border:1px solid var(--line);color:var(--text);background:transparent}
.cta--ghost:hover{background:var(--text);color:var(--bg)}

.nav-toggle{
  display:flex;width:44px;height:44px;
  flex-direction:column;justify-content:center;gap:5px;align-items:center;
}
.nav-toggle span{width:22px;height:1px;background:var(--text);display:block}

/* HERO — split screen */
.hero{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  min-height:88vh;min-height:88dvh;
}
.hero__copy{
  padding:clamp(72px, 9vw, 120px) clamp(28px, 5vw, 96px);
  display:flex;flex-direction:column;justify-content:center;
  border-right:1px solid var(--line-soft);
}
.hero__index{
  font-family:var(--body);font-size:11px;font-weight:500;
  letter-spacing:0.2em;text-transform:uppercase;
  color:var(--text-muted);margin:0 0 64px;
  font-variant-numeric:tabular-nums;
}
.hero__title{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(56px, 8vw, 124px);
  line-height:0.94;
  letter-spacing:-0.05em;
  margin:0 0 36px;
  color:var(--text);
}
.hero__title span{display:block}
.hero__title span:nth-child(2){color:var(--accent)}
.hero__sub{
  font-family:var(--body);
  font-size:clamp(18px, 1.4vw, 22px);
  font-weight:400;color:var(--text-soft);line-height:1.45;
  max-width:30ch;margin:0 0 56px;
}

.hero__meta{
  list-style:none;padding:0;margin:0 0 48px;
  display:grid;gap:12px;
  border-top:1px solid var(--line-soft);
  padding-top:28px;
}
.hero__meta li{
  display:flex;justify-content:space-between;
  font-size:14px;font-weight:500;
  border-bottom:1px solid var(--line-soft);padding-bottom:12px;
}
.hero__meta-k{color:var(--text-muted);text-transform:uppercase;letter-spacing:0.1em;font-size:11px;font-weight:600}
.hero__meta-v{color:var(--text);font-variant-numeric:tabular-nums}

.hero__cta{
  font-family:var(--body);
  font-size:14px;font-weight:600;letter-spacing:0.04em;
  color:var(--text);
  border-bottom:1px solid var(--text);
  padding-bottom:6px;align-self:flex-start;
  transition:color .25s var(--ease), border-color .25s var(--ease);
}
.hero__cta:hover{color:var(--accent);border-color:var(--accent)}

.hero__media{margin:0;position:relative;background:#000;overflow:hidden}
.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__media figcaption{
  position:absolute;bottom:24px;left:24px;
  font-family:var(--body);font-size:11px;font-weight:500;
  letter-spacing:0.12em;text-transform:uppercase;
  color:#fff;background:rgba(0,0,0,.35);
  padding:8px 14px;
}

/* Booking */
.booking{
  background:var(--text);color:var(--bg);
  padding:0 var(--pad);
}
.booking__inner{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr) auto;
  align-items:stretch;
}
.booking__field{
  padding:18px 24px;display:flex;flex-direction:column;gap:6px;
  border-right:1px solid rgba(255,255,255,.18);
}
.booking__field:last-of-type{border-right:0}
.booking__field label{
  font-family:var(--body);
  font-size:10px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;
  color:rgba(255,255,255,.55);
}
.booking__field input,.booking__field select{
  background:transparent;border:0;color:var(--bg);
  font-family:var(--body);font-size:15px;font-weight:500;
  outline:0;padding:0;color-scheme:dark;min-width:0;
}
.booking__submit{
  background:var(--accent);color:var(--text);
  padding:0 32px;font-weight:600;
  border-radius:0;
}
.booking__submit:hover{background:#D9C4A8}

/* Story */
.story{padding:var(--rhythm) var(--pad)}
.story__inner{max-width:var(--maxw);margin:0 auto 56px}
.story__columns{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;
  margin-top:48px;max-width:var(--maxw);
}
.story__columns p{
  font-size:18px;line-height:1.55;color:var(--text);margin:0;
}

.facts-table{
  max-width:var(--maxw);margin:0 auto;width:100%;
  border-collapse:collapse;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.facts-table th,.facts-table td{
  padding:18px 0;text-align:left;
  border-bottom:1px solid var(--line-soft);
  font-size:15px;
}
.facts-table tr:last-child th,.facts-table tr:last-child td{border-bottom:0}
.facts-table th{
  font-family:var(--body);font-weight:500;color:var(--text-muted);
  font-size:13px;text-transform:uppercase;letter-spacing:0.06em;width:36%;
}
.facts-table td{
  font-family:var(--display);font-weight:500;color:var(--text);
  letter-spacing:-0.01em;font-variant-numeric:tabular-nums;
}

/* Apartments */
.apartments{padding:0 var(--pad) var(--rhythm)}
.apartments__head{max-width:var(--maxw);margin:0 auto 56px}

.rates{
  max-width:var(--maxw);margin:0 auto;width:100%;
  border-collapse:collapse;
  border-top:1px solid var(--line);
}
.rates th,.rates td{
  padding:24px 18px;text-align:left;
  border-bottom:1px solid var(--line-soft);
  font-size:15px;
}
.rates thead th{
  font-family:var(--body);font-weight:500;color:var(--text-muted);
  font-size:11px;text-transform:uppercase;letter-spacing:0.14em;
  vertical-align:bottom;
  border-bottom:1px solid var(--line);
}
.rates thead th span{display:block;color:var(--text);font-size:13px;letter-spacing:0.08em}
.rates thead th em{font-style:normal;font-size:11px;color:var(--text-muted);font-weight:500;display:block;margin-top:4px}
.rates__name{
  font-family:var(--display);font-weight:500;font-size:18px;
  letter-spacing:-0.01em;color:var(--text);
}
.rates strong{
  font-family:var(--display);font-weight:500;font-size:22px;
  color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-0.01em;
}
.rates td span{color:var(--text-muted);font-size:12px;font-weight:500;letter-spacing:0.04em}
.rates__feature{background:var(--bg-alt)}
.rates__feature .rates__name::after{
  content:"·  one of one";color:var(--accent);font-size:12px;font-weight:500;
  margin-left:10px;letter-spacing:0.04em;
}

.rooms-gallery{
  max-width:var(--maxw);margin:48px auto 0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.rooms-gallery figure{margin:0;display:flex;flex-direction:column;gap:14px}
.rooms-gallery img{aspect-ratio:5/4;object-fit:cover;width:100%}
.rooms-gallery figcaption{
  display:flex;justify-content:space-between;
  font-family:var(--body);font-size:13px;color:var(--text-muted);
  border-top:1px solid var(--line-soft);padding-top:12px;
}
.rooms-gallery figcaption strong{
  font-family:var(--display);font-weight:500;color:var(--text);
  font-size:14px;letter-spacing:-0.01em;
}

/* Architecture */
.architecture{
  background:var(--bg-alt);
  padding:0;
  display:grid;grid-template-columns:1.2fr 1fr;
  align-items:stretch;
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
}
.architecture__media{margin:0;position:relative}
.architecture__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:auto;min-height:480px}
.architecture__copy{
  padding:var(--rhythm) clamp(28px, 5vw, 96px);
  display:flex;flex-direction:column;justify-content:center;
}
.arch__list{
  list-style:none;padding:0;margin:24px 0 0;
  display:grid;gap:0;
  border-top:1px solid var(--line-soft);
}
.arch__list li{
  font-family:var(--body);font-size:15px;color:var(--text);
  padding:18px 0 18px 32px;border-bottom:1px solid var(--line-soft);
  position:relative;line-height:1.5;
}
.arch__list li::before{
  content:"+";position:absolute;left:0;top:18px;
  font-family:var(--display);font-weight:500;color:var(--accent);
}

/* Wellness */
.wellness{padding:var(--rhythm) var(--pad)}
.wellness__head{max-width:var(--maxw);margin:0 auto 64px}
.wellness__list{
  max-width:var(--maxw);margin:0 auto;
  list-style:none;padding:0;
  display:grid;grid-template-columns:repeat(2,1fr);gap:0;
  border-top:1px solid var(--line);
}
.wellness__list li{
  display:grid;grid-template-columns:60px 1fr auto;gap:24px;
  align-items:center;padding:28px 0;
  border-bottom:1px solid var(--line-soft);
}
.wellness__list li:nth-child(odd){
  padding-right:48px;
  border-right:1px solid var(--line-soft);
}
.wellness__list li:nth-child(even){padding-left:48px}
.wellness__num{
  font-family:var(--display);font-weight:500;font-size:24px;
  color:var(--accent);letter-spacing:-0.01em;
  font-variant-numeric:tabular-nums;
}
.wellness__list strong{
  font-family:var(--display);font-weight:500;font-size:22px;
  letter-spacing:-0.02em;color:var(--text);
}
.wellness__where{
  font-family:var(--body);font-size:11px;font-weight:600;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--text-muted);
}

/* Amenities */
.amenities{padding:0 var(--pad) var(--rhythm);background:var(--bg-alt)}
.amenities__head{max-width:var(--maxw);margin:0 auto 56px;padding-top:var(--rhythm)}
.amenities__list{
  max-width:var(--maxw);margin:0 auto;
  list-style:none;padding:0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--line);
  border-left:1px solid var(--line-soft);
}
.amenities__list li{
  font-family:var(--display);font-weight:500;font-size:18px;
  color:var(--text);letter-spacing:-0.01em;
  padding:32px 24px;
  border-right:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
  min-height:120px;display:flex;align-items:flex-end;
}

/* Location */
.location{padding:var(--rhythm) var(--pad)}
.location__head{max-width:var(--maxw);margin:0 auto 56px}
.location-table{
  max-width:var(--maxw);margin:0 auto;width:100%;
  border-collapse:collapse;border-top:1px solid var(--line);
}
.location-table th,.location-table td{
  padding:20px 0;text-align:left;
  border-bottom:1px solid var(--line-soft);
  font-size:15px;
  vertical-align:top;
}
.location-table th{
  font-family:var(--body);font-weight:500;color:var(--text);
  width:40%;line-height:1.4;
}
.location-table td{
  font-family:var(--display);font-weight:500;color:var(--text);
  letter-spacing:-0.005em;font-variant-numeric:tabular-nums;
}

/* Investment */
.invest{padding:var(--rhythm) var(--pad);background:var(--text);color:var(--bg)}
.invest__inner{max-width:760px;margin:0 auto;text-align:left}
.invest .display{color:var(--bg)}
.invest .lede{color:rgba(250,250,248,.7)}
.invest .section-num{color:rgba(250,250,248,.4)}
.invest .section-num span{color:var(--bg)}
.invest .cta--ghost{border-color:var(--bg);color:var(--bg)}
.invest .cta--ghost:hover{background:var(--bg);color:var(--text)}

/* Trust */
.trust{padding:var(--rhythm) var(--pad)}
.trust__head{max-width:var(--maxw);margin:0 auto 56px}
.trust__grid{
  list-style:none;padding:0;margin:0 auto;max-width:var(--maxw);
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.trust__grid li{
  display:flex;flex-direction:column;gap:12px;
  padding:48px 24px;
  border-right:1px solid var(--line-soft);
}
.trust__grid li:last-child{border-right:0}
.trust__grid strong{
  font-family:var(--display);font-weight:500;
  font-size:clamp(40px, 5vw, 64px);
  letter-spacing:-0.04em;color:var(--text);line-height:1;
  font-variant-numeric:tabular-nums;
}
.trust__grid span{font-size:13px;color:var(--text-soft);font-weight:500;line-height:1.4}
.trust__appa{
  max-width:var(--maxw);margin:32px auto 0;
  font-family:var(--body);font-size:13px;font-weight:500;
  letter-spacing:0.04em;color:var(--accent);
}

/* Contact */
.contact{padding:var(--rhythm) var(--pad);background:var(--bg-alt)}
.contact__head{max-width:var(--maxw);margin:0 auto 56px}
.contact__columns{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:start;
}
.contact__form{display:grid;gap:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-row > label,.contact__form > label{display:flex;flex-direction:column;gap:6px}
.form-row > label > span,.contact__form > label > span{
  font-family:var(--body);
  font-size:11px;font-weight:600;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--text-muted);
}
.contact__form input,.contact__form select,.contact__form textarea{
  background:var(--bg);
  border:1px solid var(--line-mid);
  color:var(--text);
  font-family:var(--body);font-size:15px;font-weight:500;
  padding:14px 16px;border-radius:0;outline:0;
  transition:border-color .25s var(--ease);
  min-height:44px;
}
.contact__form input:focus,.contact__form select:focus,.contact__form textarea:focus{border-color:var(--text)}
.contact__form textarea{resize:vertical}
.contact__form button{margin-top:12px;justify-self:start}

.contact__direct dl{margin:0;display:grid;gap:24px}
.contact__direct dt{
  font-family:var(--body);
  font-size:11px;font-weight:600;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--text-muted);margin-bottom:4px;
}
.contact__direct dd{
  margin:0;font-size:15px;color:var(--text);line-height:1.5;
}
.contact__phone{
  font-family:var(--display);font-size:24px;font-weight:500;
  letter-spacing:-0.02em;color:var(--text);
}

/* Footer */
.site-footer{padding:48px var(--pad);border-top:1px solid var(--line)}
.site-footer__inner{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:center;
}
.site-footer__brand{
  font-family:var(--display);font-size:18px;font-weight:500;
  letter-spacing:-0.01em;margin:0;
}
.site-footer__links{
  display:flex;gap:32px;justify-content:flex-end;
  font-size:13px;color:var(--text-soft);
}
.site-footer__links a:hover{color:var(--text)}
.site-footer__legal{
  grid-column:1/-1;border-top:1px solid var(--line-soft);
  padding-top:24px;margin:24px 0 0;
  font-size:12px;color:var(--text-muted);font-weight:500;
}

/* RU adjustments */
[data-lang="ru"] .display,
[data-lang="ru"] .hero__title{
  letter-spacing:-0.04em;
}
[data-lang="ru"] .hero__title{font-size:clamp(48px, 7vw, 108px)}
[data-lang="ru"] .rates__name,
[data-lang="ru"] .amenities__list li,
[data-lang="ru"] .wellness__list strong{
  letter-spacing:-0.02em;
}

/* Responsive */
@media (max-width: 1024px){
  .nav{display:none;flex-direction:column;gap:16px;padding:24px var(--pad);background:var(--bg)}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero__copy{padding-top:48px;padding-bottom:48px;border-right:0;border-bottom:1px solid var(--line-soft)}
  .hero__media{aspect-ratio:4/3}
  .booking__inner{grid-template-columns:repeat(2,1fr)}
  .booking__field{border-right:0;border-bottom:1px solid rgba(255,255,255,.15)}
  .booking__submit{grid-column:1/-1;margin:0}
  .story__columns{grid-template-columns:1fr;gap:24px}
  .rooms-gallery{grid-template-columns:1fr}
  .architecture{grid-template-columns:1fr}
  .architecture__media img{aspect-ratio:4/3;min-height:auto}
  .wellness__list{grid-template-columns:1fr}
  .wellness__list li:nth-child(odd){padding-right:0;border-right:0}
  .wellness__list li:nth-child(even){padding-left:0}
  .amenities__list{grid-template-columns:repeat(2,1fr)}
  .trust__grid{grid-template-columns:repeat(2,1fr)}
  .trust__grid li:nth-child(2){border-right:0}
  .contact__columns{grid-template-columns:1fr;gap:48px}
  .site-footer__inner{grid-template-columns:1fr;gap:24px}
  .site-footer__links{justify-content:flex-start;flex-wrap:wrap}
}

@media (max-width: 640px){
  body{font-size:15px}
  .hero__title{font-size:14vw}
  .form-row{grid-template-columns:1fr}
  .amenities__list{grid-template-columns:1fr}
  .trust__grid{grid-template-columns:1fr 1fr;gap:0}
  .facts-table th,.facts-table td{padding:14px 8px;font-size:14px}
  .facts-table th{width:42%}
  .rates{font-size:13px}
  .rates th,.rates td{padding:14px 8px}
  .rates__name{font-size:15px}
  .rates strong{font-size:18px}
  .location-table th,.location-table td{padding:14px 0;font-size:13px}
}

.reveal{opacity:0;transform:translateY(16px);transition:opacity .8s var(--ease), transform .8s var(--ease)}
.reveal.is-revealed,.reveal.is-failsafe{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none}
  *{animation:none!important;transition:none!important}
}
