/* RYNARAYA — shared stylesheet. Brand: Vol.01 (2026). Self-hosted Sarabun (latin). */

/* ---------- Fonts (self-hosted = GDPR-safe + fast) ---------- */
@font-face{font-family:Sarabun;font-style:normal;font-weight:200;font-display:swap;src:url(/assets/fonts/sarabun-200.woff2) format("woff2")}
@font-face{font-family:Sarabun;font-style:normal;font-weight:300;font-display:swap;src:url(/assets/fonts/sarabun-300.woff2) format("woff2")}
@font-face{font-family:Sarabun;font-style:normal;font-weight:400;font-display:swap;src:url(/assets/fonts/sarabun-400.woff2) format("woff2")}
@font-face{font-family:Sarabun;font-style:normal;font-weight:500;font-display:swap;src:url(/assets/fonts/sarabun-500.woff2) format("woff2")}
@font-face{font-family:Sarabun;font-style:normal;font-weight:600;font-display:swap;src:url(/assets/fonts/sarabun-600.woff2) format("woff2")}

/* ---------- Tokens ---------- */
:root{
  --green:#1B443D; --gold:#C8AD82; --cream:#F1E9D8; --ink:#2B342E; --bronze:#827155;
  --green-90:rgba(27,68,61,.92); --gold-30:rgba(200,173,130,.35); --cream-70:rgba(241,233,216,.72);
  --maxw:1160px; --pad:clamp(1.25rem,5vw,3rem);
  --fs-eyebrow:.78rem; --ls-eyebrow:.28em; --ls-display:.04em;
  --t:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--cream);color:var(--ink);
  font:400 clamp(1rem,.95rem + .3vw,1.0625rem)/1.7 Sarabun,system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,svg{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,p{margin:0}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:2px}

.skip{position:absolute;left:-999px;top:0;background:var(--green);color:var(--cream);padding:.7em 1.1em;z-index:200}
.skip:focus{left:.5rem;top:.5rem}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}

/* ---------- Header / nav ---------- */
.site-header{position:fixed;inset:0 0 auto;z-index:100;
  background:transparent;transition:background .2s ease-out,box-shadow .2s ease-out,backdrop-filter .2s ease-out}
.site-header.scrolled{background:var(--green-90);backdrop-filter:saturate(140%) blur(10px);box-shadow:0 1px 0 var(--gold-30)}
.nav{display:flex;align-items:center;gap:1.25rem;
  max-width:var(--maxw);margin-inline:auto;padding:.7rem var(--pad);min-height:62px}
.brand{display:inline-flex;align-items:center;gap:.62rem;flex:0 0 auto}
.brand-mark{height:44px;width:auto}
.brand-type{height:17px;width:auto}
.nav-links{display:flex;align-items:center;gap:clamp(1rem,2.4vw,2rem);margin-left:auto;list-style:none;padding:0;margin-block:0}
.nav-links a{color:var(--cream);font-size:.92rem;letter-spacing:.04em;position:relative;padding:.35em 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:.05em;width:0;height:1px;background:var(--gold);transition:width .3s var(--t)}
.nav-links a:hover::after,.nav-links a:focus-visible::after{width:100%}
.lang{display:inline-flex;gap:.5rem;align-items:center;color:var(--cream-70);font-size:.86rem;letter-spacing:.05em}
.lang [aria-current="true"]{color:var(--gold)}
.lang span{opacity:.5}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:.55rem;color:var(--cream)}
.nav-cta{flex:0 0 auto;display:inline-flex;align-items:center;background:var(--gold);color:var(--green);
  font-weight:600;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;padding:.5rem .95rem;border-radius:2px;
  white-space:nowrap;transition:background .25s var(--t)}
.nav-cta:hover,.nav-cta:focus-visible{background:var(--cream);color:var(--green)}
.nav-links a,.lang{text-shadow:none}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font:600 .9rem/1 Sarabun,sans-serif;letter-spacing:.12em;text-transform:uppercase;
  padding:.95em 1.9em;border-radius:2px;border:1px solid transparent;cursor:pointer;
  transition:transform .2s var(--t),background .25s var(--t),color .25s var(--t),border-color .25s var(--t)}
.btn:active{transform:translateY(1px)}
.btn-gold{background:var(--gold);color:var(--green);border-color:var(--gold)}
.btn-gold:hover{background:#d8bf97;border-color:#d8bf97}
.btn-ghost{background:transparent;color:var(--green);border-color:var(--gold)}
.btn-ghost:hover{background:var(--gold);color:var(--green)}
.section--green .btn-ghost,.consent-banner .btn-ghost{color:var(--cream);border-color:var(--gold-30)}
.section--green .btn-ghost:hover,.consent-banner .btn-ghost:hover{background:var(--gold);color:var(--green);border-color:var(--gold)}

/* ---------- Sections ---------- */
.section{padding:clamp(4rem,9vw,7rem) 0;scroll-margin-top:72px}
.section--green{background:var(--green);color:var(--cream)}
.eyebrow{font-weight:600;font-size:var(--fs-eyebrow);letter-spacing:var(--ls-eyebrow);
  text-transform:uppercase;color:var(--bronze);margin-bottom:.9rem}
.section--green .eyebrow{color:var(--gold)}
.h2{font-weight:200;font-size:clamp(2rem,1.4rem + 2.6vw,3.25rem);line-height:1.05;
  letter-spacing:var(--ls-display);color:var(--green)}
.section--green .h2{color:var(--gold)}
.lead{max-width:46ch;margin-top:1.1rem;color:var(--ink)}
.section--green .lead{color:var(--cream-70)}
.section-head{margin-bottom:clamp(2.25rem,5vw,3.5rem)}

/* divider with mini emblem */
.rule{display:flex;align-items:center;gap:1.1rem;max-width:340px;margin:0 auto clamp(1.25rem,3vw,2rem)}
.rule span{flex:1;height:1px;background:var(--gold-30)}
.rule img{height:26px;width:auto;opacity:.95}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:grid;place-items:center;text-align:center;
  background:var(--green) url(/assets/img/hero-poster.jpg) center/cover no-repeat;color:var(--cream);
  padding:6rem var(--pad) 4rem;overflow:hidden;isolation:isolate}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
/* green vignette: clear-ish centre, green darkening toward the edges (footage stays visible) */
.hero::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(118% 118% at 50% 42%,rgba(27,68,61,.11) 0%,rgba(27,68,61,.28) 46%,rgba(12,32,27,.81) 100%),
    linear-gradient(rgba(13,33,28,.51),rgba(13,33,28,0) 18%,rgba(13,33,28,0) 82%,rgba(11,29,25,.75))}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(120% 80% at 50% 18%,rgba(200,173,130,.10),transparent 60%)}
.hero-inner{position:relative;max-width:680px;text-shadow:0 1px 12px rgba(9,24,20,.45)}
.hero img.lockup{width:clamp(160px,25vw,255px);margin:0 auto 1.5rem;
  filter:drop-shadow(0 3px 14px rgba(9,24,20,.5))}
.hero .tagline{font-weight:500;font-size:.82rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin:0}
.hero-inner .btn{margin-top:2.4rem;text-shadow:none}
.hero .subline{font-weight:200;font-size:1.18rem;line-height:1.4;
  letter-spacing:.02em;margin:2.4rem auto 0;max-width:30ch;color:var(--cream)}
.hero .scroll-hint{position:absolute;left:50%;bottom:1.6rem;translate:-50% 0;color:var(--cream-70);
  font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:.65rem}
.hero .scroll-hint::after{content:"";width:9px;height:9px;border-right:1.5px solid var(--gold);
  border-bottom:1.5px solid var(--gold);transform:rotate(45deg);animation:scrollcue 1.7s ease-in-out infinite}
@keyframes scrollcue{0%,100%{transform:rotate(45deg) translate(-2px,-2px);opacity:.4}
  50%{transform:rotate(45deg) translate(2px,2px);opacity:1}}

/* ---------- Pricing menu ---------- */
.menu{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.75rem,4vw,3.25rem) clamp(2.5rem,6vw,5rem)}
.svc{break-inside:avoid}
.svc h3{font-weight:500;font-size:1.18rem;letter-spacing:.06em;color:var(--green);margin-bottom:.15rem}
.section--green .svc h3{color:var(--cream)}
.svc .note{font-size:.92rem;color:var(--bronze);margin-bottom:.85rem}
.section--green .svc .note{color:var(--cream-70)}
.price-row{display:flex;align-items:baseline;gap:.6em;padding:.32rem 0;font-size:.98rem}
.price-row .dur{color:var(--ink)}
.section--green .price-row .dur{color:var(--cream)}
.price-row .leader{flex:1 1 auto;border-bottom:1px dotted var(--gold-30);transform:translateY(-.28em)}
.price-row .price{font-variant-numeric:tabular-nums;font-weight:600;color:var(--green);letter-spacing:.02em}
.section--green .price-row .price{color:var(--gold)}
.disclaimer{margin-top:clamp(2.25rem,5vw,3.25rem);font-size:.82rem;color:var(--bronze);letter-spacing:.03em}
.section--green .disclaimer{color:var(--cream-70)}

/* ---------- About ---------- */
.about-grid{display:grid;gap:clamp(2rem,5vw,4rem);grid-template-columns:1fr;align-items:center}
.about-grid p+p{margin-top:1.1rem}
.about-photo{justify-self:stretch}
.about-photo img{width:100%;height:auto;border-radius:4px;box-shadow:0 18px 40px rgba(20,48,41,.18)}

/* ---------- Consent cards / embeds ---------- */
.consent-card{border:1px solid var(--gold-30);border-radius:4px;padding:clamp(1.5rem,4vw,2.4rem);
  max-width:560px;background:rgba(241,233,216,.5)}
.section--green .consent-card{background:rgba(0,0,0,.12)}
.consent-card>p{margin-bottom:1.1rem}
.consent-fine{font-size:.82rem;color:var(--bronze);margin-top:1rem!important}
.section--green .consent-fine{color:var(--cream-70)}
.consent-actions{display:flex;flex-wrap:wrap;gap:.85rem}
.embed-mount iframe{width:100%;border:0;display:block;border-radius:4px}
.embed-mount[hidden]{display:none}

/* booking layout */
.booking-wrap{display:grid;gap:1.5rem;justify-items:start}
.contact-grid{display:grid;gap:clamp(2rem,5vw,3.5rem);grid-template-columns:1fr}
.contact-info dt{font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:.74rem;color:var(--green);margin-top:1.4rem}
.section--green .contact-info dt{color:var(--gold)}
.contact-info dt:first-child{margin-top:0}
.contact-info dd{margin:.3rem 0 0;font-size:1.05rem}
.contact-info a{border-bottom:1px solid var(--gold-30)}
.contact-info a:hover{border-color:var(--gold)}

/* ---------- Footer ---------- */
.site-footer{background:#143029;color:var(--cream-70);padding:clamp(3rem,7vw,4.5rem) 0 2.5rem;text-align:center}
.site-footer img{height:54px;width:auto;margin:0 auto 1.5rem;opacity:.9}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 1.75rem;list-style:none;padding:0;margin:0 0 1.75rem;
  font-size:.86rem;letter-spacing:.04em}
.footer-nav a:hover{color:var(--gold)}
.footer-meta{font-size:.82rem;line-height:1.8}
.footer-meta a:hover{color:var(--gold)}
.footer-legal{margin-top:1.1rem;font-size:.78rem;color:rgba(241,233,216,.5)}
.footer-legal a{border-bottom:1px solid var(--gold-30)}

/* ---------- Consent banner ---------- */
.consent-banner{position:fixed;inset:auto 0 0;z-index:120;
  background:var(--green-90);backdrop-filter:blur(8px);border-top:1px solid var(--gold-30);
  color:var(--cream);padding:1.1rem var(--pad);
  display:flex;flex-wrap:wrap;align-items:center;gap:1rem 1.5rem;justify-content:center}
.consent-banner p{font-size:.92rem;max-width:60ch}
.consent-banner a{color:var(--gold);border-bottom:1px solid var(--gold-30)}
.consent-banner[hidden]{display:none}

/* ---------- Reveal (JS-gated; no-JS keeps content visible) ---------- */
.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .8s var(--t),transform .8s var(--t)}
.js .reveal.is-in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(min-width:760px){
  .about-grid{grid-template-columns:1fr 1.2fr}
  .contact-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:719px){
  .menu{grid-template-columns:1fr}
  .brand-type{display:none}
  .nav{gap:.7rem}
  .nav-cta{order:1;margin-left:auto;padding:.44rem .8rem;font-size:.76rem}
  .lang{order:2}
  .nav-toggle{display:inline-flex;align-items:center;order:3}
  .burger{position:relative;display:block;width:20px;height:2px;background:currentColor;border-radius:2px;transition:background 0s .2s}
  .burger::before,.burger::after{content:"";position:absolute;left:0;width:20px;height:2px;background:currentColor;border-radius:2px;transition:transform .2s var(--t),top .2s var(--t)}
  .burger::before{top:-6px}
  .burger::after{top:6px}
  .nav.open .burger{background:transparent}
  .nav.open .burger::before{top:0;transform:rotate(45deg)}
  .nav.open .burger::after{top:0;transform:rotate(-45deg)}
  .nav .nav-links{position:fixed;inset:62px 0 auto;flex-direction:column;align-items:stretch;
    gap:0;margin:0;padding:.25rem var(--pad) 1.25rem;background:var(--green);
    border-top:1px solid var(--gold-30);box-shadow:0 16px 30px rgba(0,0,0,.25);display:none}
  .nav.open .nav-links{display:flex}
  .nav-links a{width:100%;padding:.9rem 0;border-bottom:1px solid rgba(200,173,130,.14);font-size:1rem;text-shadow:none}
  .nav-links a::after{display:none}
}

/* ---------- Motion / print safety ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .site-header{transition-duration:.2s!important}
  .js .reveal{opacity:1;transform:none}
}
