/* ============================================================
   TEU LIVING — shared stylesheet for all language pages
   "From the sea, a home." · motion 100% CSS · no framework JS
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;0,6..72,600;1,6..72,400;1,6..72,500;1,6..72,600&family=Figtree:wght@300;400;500;600;700&display=swap');

/* ---- TOKENS ---- */
:root{
  --paper:#ffffff; --paper-2:#f7f3ec; --paper-3:#ece4d6;
  --ink:#2b2620; --ink-2:#6f6354; --ink-3:#988a78;
  --teal:#2f4a45; --teal-deep:#1d302c; --sea:#3c5e57;
  --clay:#bd5f3a; --clay-deep:#9d4a2a; --clay-soft:#dd9b78;
  --ochre:#cd9a52; --ochre-soft:#e3c180;
  --sage:#8d9d86; --sage-soft:#c3cdb8;
  --line:rgba(43,38,32,.14); --line-2:rgba(43,38,32,.08);
  --serif:"Newsreader",Georgia,"Times New Roman",serif; /* @kind font */
  --sans:"Figtree",system-ui,-apple-system,"Segoe UI",sans-serif; /* @kind font */
  --maxw:1280px; --gutter:clamp(22px,5vw,80px); /* @kind spacing */
  --r:10px; --r-lg:20px; --r-xl:30px;
  --shadow:0 24px 60px -28px rgba(29,40,36,.5);
  --shadow-sm:0 12px 32px -18px rgba(29,40,36,.45);
  --ease:cubic-bezier(.22,1,.36,1); /* @kind other */
}

/* ---- RESET ---- */
*{box-sizing:border-box;margin:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);font-weight:400;line-height:1.68;font-size:17px;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.05;letter-spacing:-.012em}
:focus-visible{outline:2px solid var(--clay);outline-offset:3px;border-radius:4px}

/* ---- UTIL ---- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.kicker{font-family:var(--sans);font-weight:600;font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--clay);display:inline-flex;align-items:center;gap:.7em}
.kicker::before{content:"";width:30px;height:1px;background:currentColor;opacity:.55}
.kicker.solo::before{display:none}
section{padding-block:clamp(70px,9vw,136px);position:relative}
.lead{font-size:clamp(1.06rem,1.5vw,1.24rem);color:var(--ink-2);max-width:62ch}
.it{font-style:italic;font-weight:400}

/* ---- BUTTONS ---- */
.btn{position:relative;display:inline-flex;align-items:center;gap:.6em;font-family:var(--sans);font-weight:600;font-size:.92rem;letter-spacing:.01em;padding:1em 1.8em;border-radius:999px;background:var(--teal);color:var(--paper);border:1px solid transparent;cursor:pointer;overflow:hidden;transition:transform .45s var(--ease),box-shadow .45s var(--ease),color .35s;will-change:transform}
.btn::after{content:"";position:absolute;inset:0;background:var(--teal-deep);transform:translateY(101%);transition:transform .45s var(--ease);z-index:0;border-radius:inherit}
.btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.btn:hover::after{transform:translateY(0)}
.btn:active{transform:translateY(-1px) scale(.99)}
.btn>*{position:relative;z-index:1}
.btn--clay{background:var(--clay)}.btn--clay::after{background:var(--clay-deep)}
.btn--ghost{background:transparent;color:var(--teal);border-color:var(--line)}
.btn--ghost::after{background:var(--teal)}.btn--ghost:hover{color:var(--paper)}
.btn .ico{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.7}

/* ---- HEADER ---- */
.site-head{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--paper) 80%,transparent);backdrop-filter:blur(16px) saturate(1.1);border-bottom:1px solid transparent}
.head-row{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-block:15px}
.brand{display:flex;align-items:center;gap:.5ch;font-family:var(--serif);font-weight:600;font-size:1.5rem;letter-spacing:-.02em;color:var(--teal)}
.brand .mark{width:30px;height:30px;flex:none}
.brand b{font-weight:600}.brand em{font-style:normal;color:var(--clay)}
.nav{display:flex;align-items:center;gap:30px}
.nav a.lnk{font-family:var(--sans);font-weight:500;font-size:.88rem;letter-spacing:.02em;color:var(--ink);position:relative;padding-block:5px}
.nav a.lnk::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1.5px;background:var(--clay);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.nav a.lnk:hover::after{transform:scaleX(1)}
.head-tools{display:flex;align-items:center;gap:14px}
.lang-switch{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;font-family:var(--sans);font-weight:600;font-size:.72rem;letter-spacing:.08em}
.lang-switch a{padding:.55em .78em;color:var(--ink-2);transition:background-color .3s,color .3s}
.lang-switch a+a{border-left:1px solid var(--line)}
.lang-switch a:hover{color:var(--teal);background:rgba(141,157,134,.12)}
.lang-switch a[aria-current="true"]{background:var(--teal);color:var(--paper)}
@media(max-width:980px){.nav .lnk{display:none}}
@supports (animation-timeline: scroll()){@media (prefers-reduced-motion: no-preference){
  .site-head{animation:head-solid linear both;animation-timeline:scroll(root);animation-range:30px 170px}
  @keyframes head-solid{to{background:color-mix(in srgb,var(--paper) 96%,transparent);border-bottom-color:var(--line);box-shadow:0 12px 34px -24px rgba(29,40,36,.5)}}
}}

/* ---- HERO ---- */
.hero{position:relative;min-height:clamp(600px,94vh,960px);display:flex;align-items:flex-end;color:var(--paper);overflow:hidden;isolation:isolate}
.hero-bg{position:absolute;inset:0;z-index:-2;background:#1d302c}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(20,28,24,.5) 0%,rgba(20,28,24,.12) 36%,rgba(20,28,24,.34) 64%,rgba(20,28,24,.82) 100%)}
.hero-inner{padding-bottom:clamp(54px,8vw,104px);padding-top:130px;width:100%}
.hero .kicker{color:var(--ochre-soft)}
.hero h1{font-size:clamp(2.9rem,8.2vw,7rem);font-weight:400;letter-spacing:-.025em;line-height:.98;text-wrap:balance;max-width:17ch}
.hero h1 .it{color:var(--sage-soft)}
.hero p.sub{margin-top:1.5rem;font-size:clamp(1.06rem,1.6vw,1.32rem);max-width:50ch;color:rgba(255,255,255,.9)}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:2.3rem}
.hero .btn--ghost{color:var(--paper);border-color:rgba(255,255,255,.5)}
.hero .btn--ghost::after{background:var(--paper)}.hero .btn--ghost:hover{color:var(--teal)}
.hero-coord{position:absolute;top:128px;right:var(--gutter);writing-mode:vertical-rl;font-family:var(--sans);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:14px}
.hero-coord::after{content:"";width:1px;height:60px;background:rgba(255,255,255,.4)}
@media (prefers-reduced-motion: no-preference){.hero-bg img{animation:kenburns 28s var(--ease) infinite alternate}@keyframes kenburns{from{transform:scale(1.05)}to{transform:scale(1.16) translateY(-2%)}}}
@media(max-width:980px){.hero-coord{display:none}}

/* ---- VOYAGE TICKER ---- */
.voyage{background:var(--teal-deep);color:var(--sage-soft);overflow:hidden;white-space:nowrap;padding-block:15px;border-block:1px solid rgba(255,255,255,.07)}
.voyage-track{display:inline-flex;animation:voyage 38s linear infinite}
.voyage span{font-family:var(--serif);font-style:italic;font-size:1.2rem;padding-inline:30px;display:inline-flex;align-items:center;gap:30px}
.voyage span::after{content:"⚓";color:var(--clay-soft);font-style:normal;font-size:.7em}
@keyframes voyage{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.voyage-track{animation:none}}

/* ---- STORY ---- */
.story{position:relative;background:var(--paper);overflow:hidden}
.story::before{content:"";position:absolute;inset:0;background:url(img/gallery-7.jpg) center/cover no-repeat;opacity:.16;z-index:0}
.story::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#ffffff 0%,rgba(255,255,255,.9) 44%,rgba(255,255,255,.55) 100%);z-index:0}
.story>.wrap{position:relative;z-index:1}
.story-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(40px,6vw,96px);align-items:center}
.story h2{font-size:clamp(2.2rem,4.6vw,3.9rem);font-weight:400;margin-top:1.1rem;max-width:15ch}
.story h2 em{color:var(--clay)}
.story .body{margin-top:1.6rem;color:var(--ink-2);font-size:1.08rem}
.story .body p+p{margin-top:1.1rem}
.story-note{margin-top:1.7rem;padding:18px 22px;background:var(--paper-2);border-left:3px solid var(--clay);border-radius:0 12px 12px 0}
.story-note p{margin:0;color:var(--ink-2);font-size:1.04rem;line-height:1.6}
.story-note strong{color:var(--teal);font-weight:600}
.story-note .tog{font-family:var(--serif);font-style:italic;font-size:1.12rem;color:var(--clay);font-weight:500}
.story-media{position:relative}
.story-media .frame{border-radius:var(--r-xl);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow)}
.story-media .frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.story-media:hover .frame img{transform:scale(1.05)}
.story-stamp{position:absolute;top:-26px;right:-14px;width:128px;height:128px;border-radius:50%;background:var(--clay);color:var(--paper);display:grid;place-content:center;text-align:center;box-shadow:var(--shadow-sm);transform:rotate(-8deg);padding:14px}
.story-stamp .yr{font-family:var(--serif);font-size:2rem;font-weight:600;line-height:1}
.story-stamp .tx{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;margin-top:4px;opacity:.92}
@media (prefers-reduced-motion: no-preference){.story-stamp{animation:bobseal 6s var(--ease) infinite alternate}@keyframes bobseal{to{transform:rotate(-3deg) translateY(-6px)}}}
@media(max-width:880px){.story-grid{grid-template-columns:1fr}.story-media{order:-1;max-width:420px}}

/* timeline */
.legs{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:clamp(48px,6vw,80px);border-top:1px solid var(--line)}
.leg{padding:30px 26px 30px 0;border-right:1px solid var(--line);position:relative}
.leg:last-child{border-right:0;padding-right:0}
.leg .n{font-family:var(--serif);font-style:italic;font-size:1rem;color:var(--clay)}
.leg h3{font-size:1.4rem;font-weight:500;margin-top:10px;color:var(--teal)}
.leg p{margin-top:8px;color:var(--ink-2);font-size:.96rem}
.leg::before{content:"";position:absolute;top:-1px;left:0;width:46px;height:2px;background:var(--clay)}
@media(max-width:760px){.legs{grid-template-columns:1fr}.leg{border-right:0;border-bottom:1px solid var(--line);padding:26px 0}.leg:last-child{border-bottom:0}}

/* ---- VOYAGE ILLUSTRATION (history-book band) ---- */
.voyage-illo{margin:clamp(44px,6vw,76px) auto 0;max-width:780px;text-align:center}
.voyage-illo img{width:100%;height:auto;display:block}
.voyage-illo figcaption{margin-top:12px;font-family:var(--serif);font-style:italic;color:var(--ink-2);font-size:1.08rem;letter-spacing:.01em}

/* ---- PHILOSOPHY ---- */
.philo{background:var(--teal);color:var(--paper);text-align:center}
.philo .wrap{max-width:980px}
.philo .kicker{color:var(--ochre-soft);justify-content:center}
.philo blockquote{font-family:var(--serif);font-weight:400;font-size:clamp(1.9rem,4.2vw,3.3rem);line-height:1.22;letter-spacing:-.01em;margin-top:1.4rem;text-wrap:balance}
.philo blockquote em{color:var(--sage-soft)}
.philo .by{margin-top:1.8rem;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sage-soft)}

/* ---- STAYS ---- */
.stays{background:var(--paper-2)}
.sec-head{max-width:60ch}
.sec-head h2{font-size:clamp(2.1rem,4.4vw,3.5rem);font-weight:400;margin-top:.9rem}
.sec-head h2 em{color:var(--clay)}
.stay-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin-top:50px}
.stay{background:var(--paper);border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--line-2);transition:transform .5s var(--ease),box-shadow .5s var(--ease);display:flex;flex-direction:column}
.stay:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.stay-img{aspect-ratio:16/11;overflow:hidden;position:relative}
.stay-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.stay:hover .stay-img img{transform:scale(1.06)}
.stay-tag{position:absolute;top:16px;left:16px;background:color-mix(in srgb,var(--paper) 92%,transparent);backdrop-filter:blur(6px);color:var(--teal);font-weight:600;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;padding:.5em .9em;border-radius:999px}
.stay-body{padding:28px;display:flex;flex-direction:column;flex:1}
.stay-body h3{font-size:1.6rem;font-weight:500}
.stay-body p{color:var(--ink-2);font-size:.98rem;margin-top:.5rem;flex:1}
.stay-meta{display:flex;gap:18px;margin:18px 0 22px;flex-wrap:wrap}
.stay-meta span{font-size:.82rem;color:var(--teal);font-weight:600;display:inline-flex;align-items:center;gap:.45em}
.stay-meta .ico{width:16px;height:16px;stroke:var(--sage);fill:none;stroke-width:1.7}
.stay-foot{display:flex;gap:10px;align-items:center}
@media(max-width:760px){.stay-grid{grid-template-columns:1fr}}

/* ---- AMENITIES ---- */
.amen{background:var(--paper)}
.am-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:50px}
.am{border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 16px 26px;text-align:center;background:var(--paper);transition:background-color .4s var(--ease),transform .4s var(--ease),border-color .4s,box-shadow .4s}
.am:hover{background:var(--paper-2);transform:translateY(-4px);border-color:var(--clay-soft);box-shadow:var(--shadow-sm)}
.am .ico{width:60px;height:60px;padding:15px;box-sizing:border-box;border-radius:50%;background:var(--paper-2);stroke:var(--teal);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;margin:0 auto 16px;transition:background-color .4s,stroke .4s}
.am:hover .ico{stroke:var(--clay);background:color-mix(in srgb,var(--clay) 14%,var(--paper))}
.am span{font-size:.94rem;font-weight:600;letter-spacing:.01em;display:block;line-height:1.3;color:var(--ink)}
@media(max-width:900px){.am-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.am-grid{grid-template-columns:repeat(2,1fr)}}

/* ---- COMPARE TABLE ---- */
.compare{background:var(--paper-2)}
.tbl-wrap{margin-top:44px;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--line);background:var(--paper)}
table.compare-tbl{width:100%;border-collapse:collapse;font-size:.96rem}
.compare-tbl th,.compare-tbl td{padding:18px 24px;text-align:left;border-bottom:1px solid var(--line)}
.compare-tbl thead th{background:var(--teal);color:var(--paper);font-family:var(--sans);font-weight:600;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase}
.compare-tbl tbody th{font-weight:600;color:var(--teal);width:40%}
.compare-tbl td{color:var(--ink-2)}
.compare-tbl tbody tr:last-child th,.compare-tbl tbody tr:last-child td{border-bottom:0}
.compare-tbl tbody tr:hover{background:rgba(141,157,134,.08)}
.compare-tbl .yes{color:var(--sea);font-weight:700}

/* ---- DINING ---- */
.dine{position:relative;color:var(--paper);overflow:hidden;isolation:isolate}
.dine-bg{position:absolute;inset:0;z-index:-2}
.dine-bg img{width:100%;height:100%;object-fit:cover}
.dine::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(20,28,24,.9),rgba(20,28,24,.56) 66%,rgba(20,28,24,.34))}
.dine .kicker{color:var(--ochre-soft)}
.dine h2{font-size:clamp(2.2rem,4.8vw,3.9rem);font-weight:400;margin-top:1rem;max-width:14ch}
.dine h2 em{color:var(--sage-soft)}
.dine p{margin-top:1.4rem;max-width:48ch;color:rgba(255,255,255,.9);font-size:1.08rem}
.dine ul{margin-top:1.7rem;display:flex;flex-direction:column;gap:.8rem;max-width:46ch;list-style:none}
.dine li{display:flex;gap:.8em;align-items:flex-start;color:rgba(255,255,255,.92)}
.dine li .ico{width:19px;height:19px;stroke:var(--clay-soft);fill:none;stroke-width:1.6;flex:none;margin-top:4px}

/* ---- GALLERY ---- */
.gallery{background:var(--paper)}
.masonry{margin-top:46px;columns:4;column-gap:16px}
.masonry figure{break-inside:avoid;margin-bottom:16px;border-radius:var(--r-lg);overflow:hidden;position:relative;background:var(--paper-3)}
.masonry img{width:100%;height:auto;transition:transform .9s var(--ease),filter .6s;filter:saturate(.97)}
.masonry figure:hover img{transform:scale(1.07);filter:saturate(1.08)}
.masonry figure::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 60%,rgba(29,40,36,.34));opacity:0;transition:opacity .5s}
.masonry figure:hover::after{opacity:1}
@media(max-width:1000px){.masonry{columns:3}}
@media(max-width:680px){.masonry{columns:2}}

/* ---- REVIEWS ---- */
.reviews{background:var(--paper-2);overflow:hidden}
.rev-top{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.rev-rating{display:flex;align-items:center;gap:16px}
.rev-rating .big{font-family:var(--serif);font-size:3.4rem;font-weight:600;color:var(--teal);line-height:1}
.stars{display:flex;gap:3px}
.stars .ico{width:18px;height:18px;fill:var(--ochre);stroke:none}
.rev-rating .sub{font-size:.84rem;color:var(--ink-2)}
.rev-row{margin-top:46px;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.marquee{display:flex;gap:20px;width:max-content;animation:marq 54s linear infinite}
.marquee:hover{animation-play-state:paused}
.rev-card{flex:0 0 360px;background:var(--paper);border:1px solid var(--line-2);border-radius:var(--r-xl);padding:30px;display:flex;flex-direction:column;gap:14px}
.rev-card .stars .ico{width:15px;height:15px}
.rev-card p{font-size:.98rem;color:var(--ink);line-height:1.6}
.rev-card .who{display:flex;align-items:center;gap:12px;margin-top:auto}
.rev-card .av{width:42px;height:42px;border-radius:50%;background:var(--teal);color:var(--paper);display:grid;place-items:center;font-family:var(--serif);font-size:1.2rem;font-weight:600}
.rev-card .who b{display:block;font-family:var(--sans);font-size:.9rem;color:var(--teal)}
.rev-card .who span{font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2)}
@keyframes marq{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.marquee{animation:none;flex-wrap:wrap;width:auto}.rev-row{mask:none;-webkit-mask:none}}

/* ---- FAQ ---- */
.faq{background:var(--paper)}
.faq-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,6vw,80px);margin-top:20px;align-items:start}
.faq-aside{position:sticky;top:112px}
.faq-aside h2{font-size:clamp(2rem,4vw,3.2rem);font-weight:400;margin-top:.9rem}
.faq-aside p{margin-top:1.1rem;color:var(--ink-2)}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{cursor:pointer;list-style:none;padding:24px 4px;display:flex;justify-content:space-between;gap:20px;align-items:baseline}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary h3{font-size:1.3rem;font-weight:500;color:var(--teal);transition:color .3s}
.faq-item:hover summary h3{color:var(--clay)}
.faq-item .pm{flex:none;width:22px;height:22px;position:relative;margin-top:5px}
.faq-item .pm::before,.faq-item .pm::after{content:"";position:absolute;background:var(--clay);transition:transform .35s var(--ease)}
.faq-item .pm::before{top:50%;left:0;width:100%;height:1.6px;transform:translateY(-50%)}
.faq-item .pm::after{left:50%;top:0;width:1.6px;height:100%;transform:translateX(-50%)}
.faq-item[open] .pm::after{transform:translateX(-50%) scaleY(0)}
.faq-ans{padding:0 4px 28px;max-width:62ch}
.faq-ans .short{font-size:1.05rem;color:var(--ink);font-weight:500}
.faq-ans .deep{margin-top:.7rem;color:var(--ink-2);font-size:.97rem}
@media(max-width:880px){.faq-grid{grid-template-columns:1fr}.faq-aside{position:static}}

/* ---- TEAM (natural photos) ---- */
.team{background:var(--paper-2)}
/* founders feature */
.founders{display:grid;grid-template-columns:.66fr 1.34fr;gap:clamp(28px,5vw,56px);align-items:center;margin-top:52px;background:var(--paper);border:1px solid var(--line-2);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-sm)}
.founders-ph{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--paper-2);display:flex;align-items:center;justify-content:center;padding:clamp(16px,2.2vw,26px)}
.founders-ph img{width:100%;height:100%;object-fit:contain;object-position:center;border-radius:6px;box-shadow:var(--shadow-sm)}
.founders-ph .seal{position:absolute;left:18px;bottom:18px;z-index:2;background:var(--clay);color:var(--paper);font-family:var(--sans);font-weight:600;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;padding:.5em .9em;border-radius:999px}
.founders-tx{padding:clamp(24px,4vw,44px) clamp(24px,4vw,52px) clamp(24px,4vw,44px) 0}
.founders-tx .kicker{margin-bottom:14px}
.founders-tx h3{font-size:clamp(1.7rem,3vw,2.4rem);font-weight:400;color:var(--teal)}
.founders-tx h3 em{color:var(--clay)}
.founders-tx p{margin-top:1rem;color:var(--ink-2);font-size:1.04rem}
.founders-tx .paw{margin-top:1.2rem;display:inline-flex;align-items:center;gap:.5em;font-family:var(--serif);font-style:italic;font-size:1.15rem;color:var(--teal)}
.founders-tx .paw svg{width:20px;height:20px;fill:var(--clay)}
@media(max-width:760px){.founders{grid-template-columns:1fr}.founders-ph{aspect-ratio:3/2}.founders-tx{padding:clamp(22px,5vw,32px)}}
/* team grid */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:24px;max-width:640px}
.member{text-align:center}
.member .ph{position:relative;aspect-ratio:3/4;border-radius:var(--r-lg);overflow:hidden;background:var(--paper-3);box-shadow:var(--shadow-sm)}
.member .ph img{width:100%;height:100%;object-fit:cover;object-position:center top}
.member .role{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:10px;background:linear-gradient(transparent,rgba(29,40,36,.66));color:var(--paper);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600}
.member b{display:block;margin-top:14px;font-family:var(--serif);font-size:1.3rem;font-weight:500;color:var(--teal);text-transform:capitalize}
.member span{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay);font-weight:600}
@media(max-width:900px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.team-grid{grid-template-columns:repeat(2,1fr)}}

/* ---- MAKING OF (build story) ---- */
.makingof{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:16px;margin-top:30px}
.makingof figure{margin:0;position:relative;aspect-ratio:3/4;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);background:#1b231f}
.makingof img,.makingof video{width:100%;height:100%;display:block}
.makingof img{object-fit:cover}
.makingof video{object-fit:contain}
.makingof figcaption{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:10px 12px;font-size:.74rem;line-height:1.32;font-weight:500;color:var(--paper);background:linear-gradient(transparent,rgba(20,28,24,.86))}
.makingof .mk-video figcaption{top:0;bottom:auto;background:linear-gradient(rgba(20,28,24,.86),transparent)}
@media(max-width:760px){.makingof{grid-template-columns:1fr 1fr}.makingof .mk-video{grid-column:1/-1;aspect-ratio:16/10}}

/* ---- BOOK / CONTACT ---- */
.book{background:var(--teal);color:var(--paper)}
.book-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,72px);align-items:start}
.book .kicker{color:var(--ochre-soft)}
.book h2{font-size:clamp(2.1rem,4.4vw,3.6rem);font-weight:400;margin-top:1rem}
.book h2 em{color:var(--sage-soft)}
.book .lead{color:rgba(255,255,255,.85);margin-top:1.2rem}
.contact-list{margin-top:2rem;display:flex;flex-direction:column}
.contact-list a{display:flex;gap:14px;align-items:center;padding:15px 0;border-bottom:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.92);font-size:1rem;transition:color .3s}
.contact-list a:hover{color:var(--clay-soft)}
.contact-list .ico{width:20px;height:20px;stroke:var(--clay-soft);fill:none;stroke-width:1.6;flex:none}
.airbnb-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.airbnb-row a{font-size:.82rem;font-weight:500;color:var(--sage-soft);border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:.6em 1.1em;transition:background-color .3s,color .3s}
.airbnb-row a:hover{background:var(--paper);color:var(--teal);border-color:var(--paper)}
.book-card{background:var(--paper);border-radius:var(--r-xl);padding:clamp(28px,4vw,42px);color:var(--ink);box-shadow:var(--shadow)}
.book-card h3{font-size:1.55rem;font-weight:500;color:var(--teal)}
.book-card p.note{font-size:.9rem;color:var(--ink-2);margin-top:.4rem}
.field{margin-top:18px}
.field label{display:block;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--ink-2);margin-bottom:7px}
.field input,.field select{width:100%;font-family:var(--sans);font-size:.98rem;color:var(--ink);background:var(--paper-2);border:1px solid var(--line);border-radius:10px;padding:.85em 1em;transition:border-color .3s,box-shadow .3s}
.field input:focus,.field select:focus{outline:none;border-color:var(--sage);box-shadow:0 0 0 3px rgba(141,157,134,.2)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.book-card .btn{width:100%;justify-content:center;margin-top:24px}
.book-card .alt{margin-top:13px;text-align:center;font-size:.86rem;color:var(--ink-2)}
.book-card .alt a{color:var(--clay-deep);font-weight:600;border-bottom:1px solid currentColor}
@media(max-width:880px){.book-grid{grid-template-columns:1fr}}

/* map */
.map{padding:0}
.map iframe{width:100%;height:clamp(320px,42vw,480px);border:0;display:block;filter:grayscale(.2) sepia(.08)}

/* ---- FOOTER ---- */
.site-foot{background:var(--teal-deep);color:rgba(255,255,255,.72);padding-block:66px 32px;font-size:.92rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.foot-brand .brand{color:var(--paper)}
.foot-brand p{margin-top:16px;max-width:40ch;color:rgba(255,255,255,.6)}
.foot-col h4{font-family:var(--sans);font-weight:600;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sage-soft);margin-bottom:16px}
.foot-col a,.foot-col p{display:block;color:rgba(255,255,255,.7);padding-block:5px;transition:color .3s}
.foot-col a:hover{color:var(--clay-soft)}
.foot-social{display:flex;gap:12px;margin-top:20px}
.foot-social a{width:40px;height:40px;border:1px solid rgba(255,255,255,.2);border-radius:50%;display:grid;place-items:center;transition:background-color .3s,border-color .3s}
.foot-social a:hover{background:var(--clay);border-color:var(--clay)}
.foot-social .ico{width:18px;height:18px;stroke:var(--paper);fill:none;stroke-width:1.7}
.foot-legal{margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:.8rem;color:rgba(255,255,255,.5)}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr}.foot-brand{grid-column:1/-1}}

/* ---- BUILD / CONSTRUCTION PAGE ---- */
.bhead{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--paper) 92%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.bhead .wrap{display:flex;align-items:center;justify-content:space-between;height:72px}
.bhead .back{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:.92rem;color:var(--teal);text-decoration:none}
.bhead .back svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.build-intro{max-width:760px;margin:0 auto;padding:clamp(48px,8vh,90px) var(--gutter) 10px;text-align:center}
.build-intro .kicker{justify-content:center}
.build-intro h1{font-family:var(--serif);font-weight:400;font-size:clamp(2.2rem,5vw,3.6rem);color:var(--teal);line-height:1.05;margin-top:14px}
.build-intro h1 em{color:var(--clay);font-style:italic}
.build-intro p{margin-top:16px;color:var(--ink-2);font-size:1.08rem;line-height:1.6}
.build-line{position:relative;max-width:680px;margin:0 auto;padding:34px var(--gutter) 40px}
.build-step{position:relative;padding:0 0 52px 38px}
.build-step::before{content:"";position:absolute;left:7px;top:6px;bottom:-6px;width:2px;background:var(--line-2)}
.build-step:last-child::before{display:none}
.build-step .dot{position:absolute;left:0;top:5px;width:16px;height:16px;border-radius:50%;background:var(--clay);border:3px solid var(--paper);box-shadow:0 0 0 1px var(--line-2)}
.build-date{font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--clay)}
.build-step figure{margin:12px 0 0;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);background:var(--paper-3)}
.build-step img,.build-step video{width:100%;display:block;max-height:560px;object-fit:cover}
.build-cap{margin-top:11px;font-size:1.05rem;color:var(--teal);font-family:var(--serif);line-height:1.4}
.build-cap .pt{display:block;color:var(--ink-3);font-size:.92rem;font-family:var(--sans);margin-top:3px}
.build-foot{text-align:center;padding:10px var(--gutter) 96px}

/* ---- SCROLL REVEAL ---- */
@supports (animation-timeline: view()){@media (prefers-reduced-motion: no-preference){
  .reveal{opacity:0;transform:translateY(36px);animation:reveal-in linear both;animation-timeline:view();animation-range:entry 5% entry 50%}
  .reveal.d1{animation-range:entry 14% entry 60%}
  .reveal.d2{animation-range:entry 22% entry 70%}
  @keyframes reveal-in{to{opacity:1;transform:none}}
}}
