/* ============================================================
   Samui Prime — Property Management · Landing page
   Locked system: navy / white / sand · Fraunces + Manrope
   Mobile-first · Full RTL support (logical properties)
   ============================================================ */

:root{
  --navy:        #14294A;
  --navy-700:    #0E1F38;
  --navy-900:    #0A1729;
  --bg:          #FFFFFF;
  --bg-warm:     #FCFAF6;
  --sand:        #F4EEE4;
  --sand-deep:   #EBE2D2;
  --line:        #E3DACB;
  --line-soft:   #EFE8DC;
  --ink:         #16202B;
  --ink-soft:    #5B6672;
  --ink-faint:   #8A93A0;
  --accent:      #1F9FB5;   /* sea teal — hairlines & tiny details only */
  --on-navy:     #F7F2E9;   /* warm white text on navy */
  --on-navy-soft:#B9C2D2;

  --font-display: "Fraunces", Georgia, serif;
  --font-body:    "Manrope", system-ui, sans-serif;

  --wrap: 1200px;
  --gutter: clamp(20px, 5vw, 56px);
  --radius: 4px;

  --shadow-card: 0 1px 2px rgba(20,41,74,.04), 0 12px 32px -18px rgba(20,41,74,.18);
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* Hebrew / RTL type swap */
[dir="rtl"]{
  --font-display: "Frank Ruhl Libre", "Fraunces", Georgia, serif;
  --font-body:    "Heebo", "Manrope", system-ui, sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg-warm);
  font-size:17px;
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

/* ---------- Type ---------- */
h1,h2,h3{
  font-family:var(--font-display);
  font-weight:400;
  line-height:1.08;
  letter-spacing:-.01em;
  margin:0;
  text-wrap:balance;
}
[dir="rtl"] h1,[dir="rtl"] h2,[dir="rtl"] h3{ letter-spacing:0; line-height:1.2; }

.eyebrow{
  font-family:var(--font-body);
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-soft);
  display:inline-flex;
  align-items:center;
  gap:.6em;
  margin:0;
}
[dir="rtl"] .eyebrow{ letter-spacing:.08em; }
.eyebrow::before{
  content:""; width:26px; height:1px; background:var(--navy); opacity:.5;
}

.lead{ font-size:clamp(1.12rem,2.4vw,1.4rem); color:var(--ink-soft); line-height:1.65; }

/* ---------- Layout ---------- */
.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(64px,11vw,128px); }
.section--tight{ padding-block:clamp(48px,8vw,88px); }
.sand{ background:var(--sand); }
.warm{ background:var(--bg-warm); }
.divider{ height:1px; background:var(--line); border:0; margin:0; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.62em;
  padding:1.02em 1.7em;
  font-size:.96rem; font-weight:600; letter-spacing:.01em;
  border-radius:999px; border:1px solid transparent;
  transition:transform .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease), color .25s var(--ease);
  white-space:nowrap; line-height:1;
}
.btn svg{ width:1.18em; height:1.18em; flex:none; }
.btn--primary{ background:var(--navy); color:var(--on-navy); box-shadow:0 14px 30px -16px rgba(20,41,74,.7); }
.btn--primary:hover{ background:var(--navy-700); transform:translateY(-2px); }
.btn--light{ background:var(--on-navy); color:var(--navy); }
.btn--light:hover{ background:#fff; transform:translateY(-2px); }
.btn--ghost{ background:transparent; color:var(--navy); border-color:var(--line); }
.btn--ghost:hover{ border-color:var(--navy); background:var(--sand); }
.btn--block{ width:100%; }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:color-mix(in srgb, var(--bg-warm) 88%, transparent);
  backdrop-filter:saturate(1.4) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease), background .3s var(--ease);
}
.site-header.is-stuck{ border-bottom-color:var(--line); }
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:16px; height:68px; }
.brand{ display:flex; align-items:center; gap:10px; }
.brand img{ height:38px; width:auto; }
.header-actions{ display:flex; align-items:center; gap:8px; }

.lang-toggle{
  display:inline-flex; align-items:center; gap:.35em;
  background:transparent; border:1px solid var(--line);
  border-radius:999px; padding:.5em .85em;
  font-size:.78rem; font-weight:600; letter-spacing:.04em; color:var(--ink-soft);
  transition:border-color .2s var(--ease), color .2s var(--ease);
}
.lang-toggle:hover{ border-color:var(--navy); color:var(--navy); }
.lang-toggle .glyph{ width:14px; height:14px; opacity:.7; }
.header-nav{ display:none; }
.header-cta-text{ display:none; }

/* ---------- Hero ---------- */
.hero{ position:relative; isolation:isolate; min-height:92svh; display:flex; align-items:flex-end; overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:-2; }
.hero__media img{ width:100%; height:100%; object-fit:cover; filter:saturate(.82) contrast(1.02); }
.hero__media::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(10,23,41,.30) 0%, rgba(10,23,41,.05) 30%, rgba(10,23,41,.55) 78%, rgba(10,23,41,.86) 100%),
    linear-gradient(to right, rgba(10,23,41,.62), rgba(10,23,41,.12));
  mix-blend-mode:normal;
}
[dir="rtl"] .hero__media::after{ background:
    linear-gradient(180deg, rgba(10,23,41,.30) 0%, rgba(10,23,41,.05) 30%, rgba(10,23,41,.55) 78%, rgba(10,23,41,.86) 100%),
    linear-gradient(to left, rgba(10,23,41,.62), rgba(10,23,41,.12)); }
.hero__inner{ padding-block:clamp(40px,9vw,96px); }
.hero__content{ max-width:680px; color:var(--on-navy); }
.hero h1{ color:var(--on-navy); font-size:clamp(2.6rem,9.5vw,5.2rem); line-height:1.02; font-optical-sizing:auto; }
.hero h1 .soft{ color:var(--on-navy-soft); }
.hero__sub{ margin-block:1.1em 1.9em; font-size:clamp(1.1rem,2.7vw,1.42rem); line-height:1.55; color:#E8E2D6; max-width:34ch; font-weight:400; }
.hero__cta-row{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.hero__micro{ margin-top:1.4em; display:flex; align-items:center; gap:.6em; font-size:.86rem; color:var(--on-navy-soft); letter-spacing:.02em; }
.dot-pulse{ width:7px; height:7px; border-radius:50%; background:#5fd07e; box-shadow:0 0 0 0 rgba(95,208,126,.6); animation:pulse 2.6s infinite; flex:none; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(95,208,126,.55);} 70%{box-shadow:0 0 0 7px rgba(95,208,126,0);} 100%{box-shadow:0 0 0 0 rgba(95,208,126,0);} }

/* hero entrance */
.reveal{ opacity:0; transform:translateY(18px); }
.is-ready .reveal{ animation:rise .9s var(--ease) forwards; }
.is-ready .reveal.d1{ animation-delay:.08s; }
.is-ready .reveal.d2{ animation-delay:.18s; }
.is-ready .reveal.d3{ animation-delay:.28s; }
.is-ready .reveal.d4{ animation-delay:.38s; }
@keyframes rise{ to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1!important; transform:none!important; animation:none!important; } }

/* scroll reveal */
[data-animate]{ opacity:0; transform:translateY(22px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
[data-animate].in{ opacity:1; transform:none; }
[data-animate].s1{ transition-delay:.08s; } [data-animate].s2{ transition-delay:.16s; } [data-animate].s3{ transition-delay:.24s; }
@media (prefers-reduced-motion:reduce){ [data-animate]{ opacity:1!important; transform:none!important; } }

/* ---------- Trust strip ---------- */
.trust{ background:var(--navy); color:var(--on-navy); }
.trust__grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:rgba(247,242,233,.14); }
.trust__item{ background:var(--navy); padding:24px clamp(16px,4vw,30px); display:flex; gap:13px; align-items:flex-start; }
.trust__item .pin{ width:20px; height:20px; flex:none; margin-top:3px; color:var(--accent); }
.trust__item h3{ font-family:var(--font-body); font-size:.98rem; font-weight:600; line-height:1.35; color:var(--on-navy); letter-spacing:0; }
.trust__item p{ margin:.25em 0 0; font-size:.84rem; color:var(--on-navy-soft); line-height:1.5; }

/* ---------- Section heading ---------- */
.sec-head{ max-width:760px; }
.sec-head h2{ font-size:clamp(2rem,5.4vw,3.4rem); margin-top:.5em; }
.sec-head .lead{ margin-top:1em; }

/* ---------- Problem ---------- */
.problem__body{ display:grid; gap:clamp(28px,5vw,64px); align-items:center; }
.problem__text p{ font-size:clamp(1.18rem,2.7vw,1.62rem); line-height:1.6; color:var(--ink); font-weight:400; letter-spacing:-.01em; }
.problem__text p + p{ margin-top:1.1em; }
.problem__desire{ font-family:var(--font-display); color:var(--navy); font-size:clamp(1.4rem,3.4vw,2rem)!important; line-height:1.3!important; padding-top:.7em; }
.problem__media{ position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:4/5; }
.problem__media img{ width:100%; height:100%; object-fit:cover; filter:saturate(.8) contrast(1.02); }

/* ---------- Services ---------- */
.services__featured{
  display:grid; gap:0; border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; background:var(--bg); box-shadow:var(--shadow-card); margin-bottom:clamp(20px,3vw,28px);
}
.services__featured-media{ position:relative; aspect-ratio:16/10; }
.services__featured-media img{ width:100%; height:100%; object-fit:cover; filter:saturate(.82) contrast(1.02); }
.services__featured-tag{
  position:absolute; inset-block-start:16px; inset-inline-start:16px;
  background:var(--navy); color:var(--on-navy); font-size:.68rem; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase; padding:.55em 1em; border-radius:999px;
}
.services__featured-body{ padding:clamp(26px,5vw,44px); display:flex; flex-direction:column; gap:14px; }
.services__featured-body h3{ font-size:clamp(1.6rem,3.6vw,2.3rem); }
.services__featured-body p{ color:var(--ink-soft); margin:0; max-width:52ch; }

.services__grid{ display:grid; grid-template-columns:1fr; gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.svc{ background:var(--bg); padding:clamp(24px,4vw,34px); display:flex; flex-direction:column; gap:11px; transition:background .25s var(--ease); }
.svc:hover{ background:var(--sand); }
.svc__num{ font-family:var(--font-display); font-size:1.05rem; color:var(--accent); letter-spacing:.04em; }
.svc h3{ font-family:var(--font-body); font-size:1.12rem; font-weight:600; letter-spacing:0; line-height:1.3; }
.svc p{ margin:0; font-size:.95rem; color:var(--ink-soft); line-height:1.6; }

/* ---------- Why ---------- */
.why__grid{ display:grid; grid-template-columns:1fr; gap:clamp(28px,4vw,40px); }
.why-card{ display:flex; flex-direction:column; }
.why-card__media{ position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:3/2; margin-bottom:22px; }
.why-card__media img{ width:100%; height:100%; object-fit:cover; filter:saturate(.8) contrast(1.02); transition:transform .9s var(--ease); }
.why-card:hover .why-card__media img{ transform:scale(1.04); }
.why-card__n{ font-size:.78rem; font-weight:600; letter-spacing:.18em; color:var(--ink-faint); text-transform:uppercase; }
.why-card h3{ font-size:clamp(1.4rem,3vw,1.8rem); margin:.5em 0 .45em; }
.why-card p{ margin:0; color:var(--ink-soft); }

/* ---------- Process ---------- */
.process{ background:var(--navy); color:var(--on-navy); }
.process .eyebrow{ color:var(--on-navy-soft); }
.process .eyebrow::before{ background:var(--on-navy-soft); opacity:.6; }
.process .sec-head h2{ color:var(--on-navy); }
.process__steps{ display:grid; grid-template-columns:1fr; gap:0; margin-top:clamp(36px,6vw,56px); }
.pstep{ display:grid; grid-template-columns:auto 1fr; gap:clamp(18px,4vw,34px); padding-block:clamp(24px,4vw,34px); border-top:1px solid rgba(247,242,233,.16); }
.pstep:last-child{ border-bottom:1px solid rgba(247,242,233,.16); }
.pstep__n{ font-family:var(--font-display); font-size:clamp(2.2rem,6vw,3.4rem); line-height:1; color:var(--accent); }
.pstep__c h3{ font-family:var(--font-body); font-weight:600; font-size:1.18rem; letter-spacing:0; color:var(--on-navy); }
.pstep__c p{ margin:.4em 0 0; color:var(--on-navy-soft); max-width:48ch; }

/* ---------- FAQ ---------- */
.faq{ max-width:860px; margin-inline:auto; }
.faq__item{ border-top:1px solid var(--line); }
.faq__item:last-child{ border-bottom:1px solid var(--line); }
.faq__q{
  width:100%; background:none; border:0; text-align:start;
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  padding:clamp(22px,3.5vw,30px) 0; color:var(--navy);
  font-family:var(--font-display); font-size:clamp(1.12rem,2.6vw,1.42rem); line-height:1.3;
}
.faq__icon{ position:relative; width:18px; height:18px; flex:none; }
.faq__icon::before,.faq__icon::after{ content:""; position:absolute; inset-inline:0; inset-block-start:50%; height:1.6px; background:var(--navy); transition:transform .35s var(--ease); }
.faq__icon::after{ transform:rotate(90deg); }
.faq__item.open .faq__icon::after{ transform:rotate(0); }
.faq__a{ overflow:hidden; max-height:0; transition:max-height .4s var(--ease); }
.faq__a-inner{ padding-block:0 clamp(22px,3.5vw,30px); color:var(--ink-soft); max-width:64ch; }
.faq__item.open .faq__a{ max-height:340px; }

/* ---------- Final CTA ---------- */
.final{ position:relative; background:var(--navy-700); color:var(--on-navy); overflow:hidden; isolation:isolate; }
.final__mark{ position:absolute; inset-block-start:50%; inset-inline-end:-4%; transform:translateY(-50%); width:min(46vw,440px); opacity:.06; z-index:-1; }
[dir="rtl"] .final__mark{ inset-inline-end:auto; inset-inline-start:-4%; }
.final__inner{ max-width:660px; }
.final h2{ color:var(--on-navy); font-size:clamp(2.2rem,6vw,3.7rem); }
.final p{ color:var(--on-navy-soft); font-size:clamp(1.08rem,2.4vw,1.3rem); margin:1em 0 2em; }
.final__micro{ margin-top:1.6em; font-size:.86rem; color:var(--on-navy-soft); display:flex; align-items:center; gap:.6em; flex-wrap:wrap; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--navy-900); color:var(--on-navy-soft); padding-block:clamp(48px,7vw,72px); }
.footer-top{ display:grid; grid-template-columns:1fr; gap:36px; }
.footer-brand img{ height:54px; width:auto; margin-bottom:18px; }
.footer-brand p{ margin:0; max-width:38ch; font-size:.92rem; line-height:1.6; }
.footer-col h4{ font-family:var(--font-body); font-size:.72rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--on-navy-soft); margin:0 0 14px; }
.footer-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:9px; }
.footer-col a,.footer-col li{ color:var(--on-navy); font-size:.95rem; }
.footer-col a:hover{ color:var(--accent); }
.footer-bottom{ margin-top:clamp(40px,6vw,60px); padding-top:24px; border-top:1px solid rgba(247,242,233,.12); display:flex; flex-wrap:wrap; gap:10px 24px; justify-content:space-between; font-size:.8rem; color:var(--on-navy-soft); }
.footer-bottom .tag{ font-family:var(--font-display); color:var(--on-navy); letter-spacing:.01em; }

/* sticky mobile CTA */
.mobile-cta{ position:fixed; inset-inline:14px; inset-block-end:14px; z-index:40; display:flex; transition:transform .35s var(--ease), opacity .35s var(--ease); }
.mobile-cta.hide{ transform:translateY(140%); opacity:0; pointer-events:none; }

/* ---------- Responsive ---------- */
@media (min-width:560px){
  .trust__grid{ grid-template-columns:repeat(4,1fr); }
  .services__grid{ grid-template-columns:repeat(2,1fr); }
}
@media (min-width:768px){
  body{ font-size:18px; }
  .header-nav{ display:flex; align-items:center; gap:30px; }
  .header-nav a{ font-size:.92rem; color:var(--ink-soft); font-weight:500; transition:color .2s; }
  .header-nav a:hover{ color:var(--navy); }
  .header-cta-text{ display:inline; }
  .problem__body{ grid-template-columns:1.15fr .85fr; }
  .services__featured{ grid-template-columns:1.1fr 1fr; }
  .services__featured-media{ aspect-ratio:auto; }
  .why__grid{ grid-template-columns:repeat(3,1fr); }
  .process__steps{ column-gap:60px; }
  .footer-top{ grid-template-columns:1.6fr 1fr 1fr; gap:48px; }
  .mobile-cta{ display:none; }
}
@media (min-width:980px){
  .services__grid{ grid-template-columns:repeat(3,1fr); }
}
