/* ==========================================================
   TENSHI — Make Your Day Brighter · 天使
   Editorial / Atelier · Bone · Ink · Tenshi Gold
   Vietnam Premium Dental Edition · MMXXVI
   ========================================================== */

:root{
  --bone:#F5F0E3;
  --bone-2:#FAF5E7;
  --cream:#ECE3CB;
  --ink:#1A1815;
  --ink-2:#26231E;
  --ink-soft:#504A3F;
  --muted:#8F887B;
  --gold:#D4A128;
  --gold-dark:#A87D16;
  --gold-soft:#EDD486;
  --line:rgba(26,24,21,.14);
  --line-soft:rgba(26,24,21,.07);
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-2:cubic-bezier(.7,0,.3,1);
  --shadow-1:0 4px 24px rgba(26,24,21,.06);
  --shadow-2:0 18px 60px rgba(26,24,21,.12);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--bone)}
body{
  font-family:'Inter',system-ui,sans-serif;
  font-size:16px;line-height:1.65;
  color:var(--ink);background:var(--bone);
  overflow-x:hidden;
  cursor:none;
  -webkit-font-smoothing:antialiased;
}
@media (hover:none){body{cursor:auto}}

a{color:inherit;text-decoration:none;transition:all .4s var(--ease)}
ul,ol{list-style:none}
img{max-width:100%;display:block}
button{font-family:inherit}

::selection{background:var(--ink);color:var(--bone)}

/* -------- TYPOGRAPHY -------- */
.serif,h1,h2,h3,h4{
  font-family:'Fraunces',serif;
  font-weight:300;
  letter-spacing:-.02em;
  line-height:1;
  color:var(--ink);
}
h1{font-size:clamp(3.2rem, 9vw, 9.5rem);letter-spacing:-.035em;line-height:.95}
h2{font-size:clamp(2.4rem, 5.4vw, 5.4rem);letter-spacing:-.028em;line-height:1}
h3{font-size:clamp(1.8rem, 2.4vw, 2.4rem);font-weight:400}
h4{font-size:1.35rem;font-weight:400;line-height:1.15}
em{font-style:italic;font-weight:300;color:var(--gold)}
.italic{font-style:italic}
.underline{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:8px;text-decoration-color:var(--gold)}

.mono{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.15em;text-transform:uppercase}
.jp,[lang="ja"]{font-family:'Shippori Mincho',serif;font-weight:400}

small,.small{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:400}
p{color:var(--ink-soft);line-height:1.7}
.muted{color:var(--muted)}
.ta-r{text-align:right}

/* -------- GRAIN OVERLAY -------- */
.grain{
  position:fixed;inset:0;z-index:200;pointer-events:none;
  opacity:.14;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .6 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* -------- ANNOUNCEMENT BAR -------- */
.announce-bar{
  position:relative;z-index:51;
  background:var(--ink);color:var(--bone);
  overflow:hidden;
  border-bottom:1px solid rgba(245,240,227,.08);
}
.announce-bar__track{
  display:flex;gap:3rem;width:max-content;
  padding:.7rem 0;
  font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.18em;
  color:rgba(245,240,227,.85);text-transform:uppercase;
  animation:marquee 50s linear infinite;
  white-space:nowrap;
}
.announce-bar__track em{color:var(--gold-soft);font-style:italic;font-weight:400}

/* -------- PRELOADER -------- */
.preloader{
  position:fixed;inset:0;z-index:1000;
  background:var(--bone-2);color:var(--ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  transition:opacity .9s var(--ease), visibility .9s var(--ease);
}
.preloader.done{opacity:0;visibility:hidden}
.preloader__inner{display:flex;flex-direction:column;align-items:center;gap:1.6rem}
.preloader__logo{
  width:clamp(220px, 28vw, 320px);
  aspect-ratio:1/1;
  background:url("LOGO%20TENSHIN%20V3_TENSHI%20LOGO.png") no-repeat center/contain;
  opacity:0;transform:translateY(14px) scale(.94);
  animation:logo-in 1.4s .1s var(--ease) forwards;
}
@keyframes logo-in{to{opacity:1;transform:translateY(0) scale(1)}}
.preloader__tag{
  font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.24em;
  color:var(--gold-dark);text-transform:uppercase;
  opacity:0;animation:fade-in 1s .9s var(--ease) forwards;
}
.preloader__tag::before,.preloader__tag::after{
  content:"";display:inline-block;width:24px;height:1px;
  background:var(--gold);vertical-align:middle;margin:0 .8rem;
}
.preloader__count{
  font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.2em;
  color:var(--muted);
  opacity:0;animation:fade-in 1s 1.2s var(--ease) forwards;
}
@keyframes fade-in{to{opacity:1}}
.preloader__bar{position:absolute;left:0;right:0;bottom:0;height:1px;background:rgba(26,24,21,.08)}
.preloader__bar i{display:block;height:100%;width:0;background:var(--gold);animation:bar 1.8s .1s var(--ease) forwards}
@keyframes bar{to{width:100%}}

/* -------- CUSTOM CURSOR -------- */
.cursor{
  position:fixed;top:0;left:0;z-index:999;pointer-events:none;
  width:44px;height:44px;border:1px solid var(--ink);border-radius:50%;
  transform:translate(-50%,-50%);
  transition:transform .25s var(--ease-2), width .25s var(--ease), height .25s var(--ease), background .25s var(--ease);
  mix-blend-mode:difference;
  border-color:var(--bone);
}
.cursor-dot{
  position:fixed;top:0;left:0;z-index:999;pointer-events:none;
  width:4px;height:4px;background:var(--bone);border-radius:50%;
  transform:translate(-50%,-50%);mix-blend-mode:difference;
}
.cursor.hover{width:72px;height:72px;background:var(--bone);mix-blend-mode:difference}
@media (hover:none){.cursor,.cursor-dot{display:none}}

/* -------- HEADER -------- */
.site-header{
  position:sticky;top:0;left:0;right:0;z-index:50;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:2rem;
  padding:1.2rem 3rem;
  background:rgba(245,240,227,.85);
  backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid var(--line-soft);
  transition:padding .35s var(--ease);
}
.site-header.scrolled{padding:.8rem 3rem}
.brand{display:flex;align-items:center;gap:.85rem}
.brand__mark{
  width:56px;height:44px;
  background:url("LOGO%20TENSHIN%20V3_TENSHI%20LOGO.png") no-repeat center/contain;
  flex-shrink:0;
  transition:transform .5s var(--ease);
}
.brand:hover .brand__mark{transform:translateY(-3px) rotate(-4deg)}
.brand__name em{font-family:'Fraunces',serif;font-style:italic;font-weight:400;font-size:1.6rem;color:var(--ink);display:block;line-height:1;margin-bottom:3px}
.brand__name small{font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.2em;color:var(--muted);text-transform:uppercase}

.site-nav{display:flex;gap:1.7rem;justify-content:center;flex-wrap:wrap}
.site-nav a{
  font-size:.82rem;color:var(--ink);position:relative;padding:.4rem 0;
  font-weight:500;
  transition:color .3s var(--ease);
}
.site-nav a::before{
  content:"";position:absolute;left:0;bottom:-3px;width:0;height:1px;background:var(--gold);
  transition:width .4s var(--ease);
}
.site-nav a:hover{color:var(--gold)}
.site-nav a:hover::before{width:100%}

.site-header__right{display:flex;align-items:center;gap:1.4rem;justify-self:end}

.header-phone{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.5rem .9rem .5rem .5rem;
  border:1px solid var(--line);border-radius:999px;
  transition:all .3s var(--ease);
}
.header-phone:hover{border-color:var(--gold);background:var(--bone-2)}
.header-phone__icon{
  width:32px;height:32px;border-radius:50%;
  background:var(--gold);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  position:relative;
}
.header-phone__icon::before{
  content:"☎";color:var(--bone);font-size:.85rem;line-height:1;
}
.header-phone__icon::after{
  content:"";position:absolute;inset:-3px;border-radius:50%;
  border:1px solid var(--gold);
  animation:dot-pulse 1.8s infinite;opacity:.6;
}
.header-phone__text{display:flex;flex-direction:column;line-height:1.1}
.header-phone__text small{font-size:.55rem;letter-spacing:.18em;color:var(--muted)}
.header-phone__text strong{font-family:'Fraunces',serif;font-style:italic;font-size:1.05rem;font-weight:500;color:var(--ink)}

.link-cta{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.85rem;color:var(--ink);font-weight:500;
  padding:.7rem 0;position:relative;
}
.link-cta__dot{
  width:7px;height:7px;border-radius:50%;background:var(--gold);
  animation:dot-pulse 1.8s infinite;
}
@keyframes dot-pulse{
  0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(212,161,40,.4)}
  50%{transform:scale(1.15);box-shadow:0 0 0 6px rgba(212,161,40,0)}
}

.menu-btn{
  width:44px;height:44px;border:1px solid var(--ink);
  background:transparent;border-radius:50%;cursor:none;
  display:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  transition:all .4s var(--ease);
}
.menu-btn span{width:16px;height:1px;background:var(--ink);transition:all .4s var(--ease)}
.menu-btn:hover{background:var(--ink)}
.menu-btn:hover span{background:var(--bone)}
.menu-btn.active span:nth-child(1){transform:rotate(45deg) translate(3px,3px)}
.menu-btn.active span:nth-child(2){transform:rotate(-45deg) translate(3px,-3px)}

/* -------- MENU OVERLAY -------- */
.menu-overlay{
  position:fixed;inset:0;z-index:49;
  background:var(--ink);color:var(--bone);
  transform:translateY(-100%);
  transition:transform 1s var(--ease-2);
  overflow-y:auto;
}
.menu-overlay.open{transform:translateY(0)}
.menu-overlay__inner{
  min-height:100%;display:grid;grid-template-columns:1fr 2fr;
  padding:8rem 3rem 3rem;gap:3rem;align-items:end;
}
.menu-overlay__side small{color:var(--bone);opacity:.5;display:block;margin-top:2rem}
.menu-overlay__side small:first-child{margin-top:0}
.menu-overlay__side p{color:var(--bone);opacity:.85;margin-top:.6rem;line-height:1.6;font-size:.95rem}
.menu-overlay__side a{opacity:.85}
.menu-overlay__side a:hover{color:var(--gold);opacity:1}

.menu-overlay__nav{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
.menu-overlay__nav a{
  font-family:'Fraunces',serif;font-size:clamp(2.4rem, 6vw, 5rem);
  font-weight:300;letter-spacing:-.03em;line-height:1;color:var(--bone);
  position:relative;overflow:hidden;padding:.4rem 0;
  display:flex;align-items:baseline;gap:1.5rem;
}
.menu-overlay__nav a span{
  font-family:'JetBrains Mono',monospace;font-size:.85rem;letter-spacing:.2em;
  color:var(--gold);font-style:normal;
}
.menu-overlay__nav a:hover{color:var(--gold);font-style:italic}

/* -------- HERO -------- */
.hero{
  min-height:100vh;padding:6rem 3rem 4rem;
  display:grid;grid-template-columns:1fr;gap:3rem;
  position:relative;
}
.hero__eyebrow{
  display:flex;align-items:center;gap:1rem;flex-wrap:wrap;
  font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.2em;
  color:var(--ink-soft);text-transform:uppercase;
}
.hero__eyebrow .dot{
  width:7px;height:7px;border-radius:50%;background:var(--gold);
  animation:dot-pulse 1.8s infinite;
}
.hero__title{
  font-family:'Fraunces',serif;
  font-weight:300;
  font-size:clamp(4rem, 14vw, 14rem);
  line-height:.92;letter-spacing:-.045em;
  margin:-.2em 0;
}
.hero__title .line{display:block;overflow:hidden}
.hero__title .line em{font-style:italic;font-weight:300;color:var(--gold)}
.hero__title .line--italic{font-style:italic;padding-left:8vw}

.hero__meta{
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;
  padding-top:2rem;max-width:1400px;
}
.hero__meta-col small{display:block;margin-bottom:1rem;color:var(--muted)}
.hero__meta-col p{max-width:480px;font-size:1.02rem}
.hero__meta-col--right{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;gap:2rem}
.hero__cta-stack{display:flex;flex-direction:column;gap:.9rem;width:100%;max-width:320px}

.signature{margin-top:1.8rem;padding-top:1rem;border-top:1px solid var(--line)}
.signature span{font-family:'Fraunces',serif;font-style:italic;font-size:1.2rem;display:block}
.signature small{margin-top:.3rem}

.pill-btn{
  display:inline-flex;align-items:center;justify-content:space-between;gap:.8rem;
  padding:1.05rem 1.8rem;border:1px solid var(--ink);border-radius:999px;
  font-size:.9rem;color:var(--ink);position:relative;overflow:hidden;
  font-weight:500;
  transition:color .5s var(--ease);
  cursor:none;
  background:transparent;
}
.pill-btn span{position:relative;z-index:2}
.pill-btn .arrow{
  display:inline-block;width:14px;height:10px;position:relative;z-index:2;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 10' fill='none' stroke='%231A1815' stroke-width='1.2'%3E%3Cpath d='M0 5h13M8 1l5 4-5 4'/%3E%3C/svg%3E") no-repeat center/contain;
  transition:transform .4s var(--ease), filter .4s var(--ease);
}
.pill-btn::before{
  content:"";position:absolute;inset:0;background:var(--ink);
  transform:translateY(101%);transition:transform .55s var(--ease-2);
}
.pill-btn:hover{color:var(--bone)}
.pill-btn:hover::before{transform:translateY(0)}
.pill-btn:hover .arrow{transform:translateX(4px);filter:brightness(0) invert(1)}

.pill-btn--primary{background:var(--ink);color:var(--bone);border-color:var(--ink)}
.pill-btn--primary .arrow{filter:brightness(0) invert(1)}
.pill-btn--primary::before{background:var(--gold);transform:translateY(101%)}
.pill-btn--primary:hover{color:var(--ink)}
.pill-btn--primary:hover::before{transform:translateY(0)}
.pill-btn--primary:hover .arrow{filter:none}

.pill-btn--ghost{border-color:var(--line)}
.pill-btn--gold{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.pill-btn--gold::before{background:var(--ink)}
.pill-btn--gold:hover{color:var(--bone)}
.pill-btn--gold:hover .arrow{filter:brightness(0) invert(1)}

.hero__scroll{display:flex;align-items:center;gap:1rem}
.scroll-line{width:42px;height:1px;background:var(--ink);position:relative;overflow:hidden}
.scroll-line::after{content:"";position:absolute;left:0;top:0;height:100%;width:30%;background:var(--gold);animation:scroll-slide 2.4s infinite var(--ease)}
@keyframes scroll-slide{0%{transform:translateX(-100%)}100%{transform:translateX(340%)}}

.hero__frame{
  margin-top:3rem;
  position:relative;
  width:100%;aspect-ratio:16/7;
  overflow:hidden;
  border-radius:2px;
}
.hero__image{
  width:100%;height:110%;margin-top:-5%;
  background:
    linear-gradient(180deg,rgba(19,22,26,.05),rgba(19,22,26,.45)),
    url("https://images.unsplash.com/photo-1629909613654-28e377c37b09?auto=format&fit=crop&w=2400&q=85") center/cover;
  transform:scale(1.04);transition:transform 1.5s var(--ease);
  filter:saturate(.9) contrast(1.05);
}
.hero__frame:hover .hero__image{transform:scale(1)}
.hero__frame figcaption{
  position:absolute;left:2rem;bottom:2rem;color:var(--bone);
  display:flex;align-items:flex-end;gap:1rem;
}
.hero__frame figcaption small{color:var(--bone);opacity:.7}
.hero__frame figcaption span{font-family:'Fraunces',serif;font-style:italic;font-size:1.05rem;font-weight:300;max-width:300px;line-height:1.3}

.hero__badge-row{
  position:absolute;right:2rem;bottom:2rem;
  display:flex;gap:.7rem;
}
.hero__badge{
  background:rgba(26,24,21,.55);backdrop-filter:blur(12px);
  border:1px solid rgba(245,240,227,.18);
  color:var(--bone);
  padding:.9rem 1.1rem;border-radius:6px;
  display:flex;flex-direction:column;gap:.15rem;min-width:130px;
  transition:transform .4s var(--ease);
}
.hero__badge:hover{transform:translateY(-4px)}
.hero__badge small{color:var(--gold-soft);font-size:.6rem;letter-spacing:.2em}
.hero__badge strong{font-family:'Fraunces',serif;font-style:italic;font-weight:500;font-size:1.15rem;color:var(--bone)}
.hero__badge span{font-size:.7rem;color:rgba(245,240,227,.7);font-family:'Inter',sans-serif;letter-spacing:.02em}

/* -------- TRUST STRIP -------- */
.trust-strip{
  display:flex;align-items:stretch;justify-content:space-between;
  padding:3rem 3rem;
  background:var(--ink);color:var(--bone);
  border-top:1px solid rgba(245,240,227,.06);
  border-bottom:1px solid rgba(245,240,227,.06);
  flex-wrap:wrap;gap:2rem;
}
.trust-strip__item{
  flex:1;min-width:160px;
  display:flex;flex-direction:column;align-items:center;gap:.6rem;text-align:center;
}
.trust-strip__item strong{
  font-family:'Fraunces',serif;font-weight:300;font-style:italic;
  font-size:clamp(2.2rem, 4.4vw, 3.6rem);
  color:var(--bone);line-height:1;letter-spacing:-.02em;
}
.trust-strip__item small{color:rgba(245,240,227,.6);line-height:1.5;font-size:.68rem}
.trust-strip__divider{width:1px;background:rgba(245,240,227,.12)}

/* -------- MARQUEE -------- */
.marquee{
  overflow:hidden;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:1.8rem 0;
  background:var(--bone-2);
}
.marquee__track{
  display:flex;gap:3rem;width:max-content;
  animation:marquee 40s linear infinite;
  font-family:'Fraunces',serif;font-size:2rem;font-weight:300;color:var(--ink);
  font-style:italic;white-space:nowrap;
}
.marquee__track span{display:inline-block}
.marquee__track .star{color:var(--gold);font-style:normal}
@keyframes marquee{to{transform:translateX(-50%)}}

/* -------- SECTION LABELS -------- */
.intro__label{
  display:flex;flex-direction:column;gap:.4rem;
  padding-right:2rem;
}
.intro__label .num{
  font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.2em;
  color:var(--gold);text-transform:uppercase;font-weight:500;
}
.intro__label small{color:var(--muted)}
.intro__label.light .num{color:var(--gold)}
.intro__label.light small{color:rgba(245,240,227,.6)}

/* -------- INTRO -------- */
.intro{
  padding:8rem 3rem;display:grid;grid-template-columns:1fr 3fr;gap:6rem;
  border-top:1px solid var(--line);
}
.intro__headline{
  font-family:'Fraunces',serif;font-size:clamp(1.8rem, 3.6vw, 3.5rem);
  font-weight:300;letter-spacing:-.02em;line-height:1.18;
  margin-bottom:4rem;max-width:1100px;
}
.intro__headline em{color:var(--gold)}
.intro__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:3rem;
  padding-top:3rem;border-top:1px solid var(--line);
}
.intro__grid small{color:var(--gold);display:block;margin-bottom:1rem}
.intro__grid p{max-width:320px}

/* -------- FEATURE IMAGE -------- */
.feature-image{padding:0 3rem 8rem}
.feature-image__frame{
  width:100%;aspect-ratio:16/8;overflow:hidden;border-radius:2px;
  position:relative;
}
.feature-image__bg{
  width:100%;height:120%;margin-top:-10%;
  background:
    linear-gradient(180deg,rgba(19,22,26,0) 55%,rgba(19,22,26,.35)),
    url("https://images.unsplash.com/photo-1606811971618-4486d14f3f99?auto=format&fit=crop&w=2400&q=85") center/cover;
  transform:translateZ(0);
  filter:saturate(.85) contrast(1.06);
  transition:transform 1.2s var(--ease);
}
.feature-image:hover .feature-image__bg{transform:scale(1.04)}
.feature-image__caption{
  display:flex;align-items:flex-start;gap:1.5rem;
  margin-top:1.5rem;
}
.feature-image__caption small{color:var(--gold)}
.feature-image__caption span{font-family:'Fraunces',serif;font-style:italic;font-size:1.1rem;color:var(--ink-soft);font-weight:300;line-height:1.45;max-width:420px}

/* -------- SERVICES -------- */
.services{padding:6rem 3rem 8rem;border-top:1px solid var(--line)}
.services__head{
  display:grid;grid-template-columns:1fr 3fr;gap:6rem;
  margin-bottom:5rem;
}
.services__head h2 em{display:inline}

.services__list{counter-reset:svc}
.svc{
  display:grid;grid-template-columns:90px 1.6fr 220px 200px;
  gap:2.5rem;align-items:center;
  padding:2.6rem 0;border-bottom:1px solid var(--line);
  position:relative;overflow:hidden;
  transition:padding .55s var(--ease);
}
.svc:first-child{border-top:1px solid var(--line)}
.svc::after{
  content:"";position:absolute;left:0;top:0;height:100%;width:0;
  background:var(--ink);z-index:-1;transition:width .6s var(--ease-2);
}
.svc:hover{padding:3.4rem 1.5rem;color:var(--bone)}
.svc:hover::after{width:100%}
.svc:hover h3,
.svc:hover .svc__num span,
.svc:hover p,
.svc:hover .svc__meta small,
.svc:hover .svc__meta strong,
.svc:hover .svc__meta strong small,
.svc:hover .svc__tags li,
.svc:hover .svc__link{color:var(--bone)}
.svc:hover p strong{color:var(--gold-soft)}
.svc:hover .svc__tags li{border-color:rgba(245,240,227,.2)}
.svc:hover .svc__img{opacity:1;transform:translateX(0)}
.svc:hover .svc__link{color:var(--gold-soft)}

.svc__num span{
  font-family:'Fraunces',serif;font-size:2.2rem;font-style:italic;
  font-weight:300;color:var(--ink);transition:color .5s var(--ease);
  display:block;
}
.svc__body h3{font-weight:400;margin-bottom:.7rem;transition:color .5s var(--ease)}
.svc__body p{color:var(--ink-soft);max-width:520px;font-size:.96rem;transition:color .5s var(--ease);margin-bottom:1rem}
.svc__body p strong{color:var(--gold-dark);font-weight:500;transition:color .5s var(--ease)}

.svc__tags{display:flex;flex-wrap:wrap;gap:.4rem}
.svc__tags li{
  font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.15em;
  text-transform:uppercase;color:var(--muted);
  padding:.35rem .7rem;border:1px solid var(--line);border-radius:999px;
  transition:all .5s var(--ease);
}

.svc__img{
  width:220px;height:140px;background-size:cover;background-position:center;
  border-radius:2px;opacity:0;transform:translateX(-30px);
  transition:all .6s var(--ease);
  filter:saturate(.9);
}
.svc__img--1{background-image:url("https://images.unsplash.com/photo-1616391182219-e080b4d1043a?auto=format&fit=crop&w=600&q=80")}
.svc__img--2{background-image:url("https://images.unsplash.com/photo-1609840114035-3c981b782dfe?auto=format&fit=crop&w=600&q=80")}
.svc__img--3{background-image:url("https://images.unsplash.com/photo-1581594693702-fbdc51b2763b?auto=format&fit=crop&w=600&q=80")}
.svc__img--4{background-image:url("https://images.unsplash.com/photo-1598256989800-fe5f95da9787?auto=format&fit=crop&w=600&q=80")}
.svc__img--5{background-image:url("https://images.unsplash.com/photo-1606811971618-4486d14f3f99?auto=format&fit=crop&w=600&q=80")}
.svc__img--6{background-image:url("https://images.unsplash.com/photo-1588776814546-1ffcf47267a5?auto=format&fit=crop&w=600&q=80")}

.svc__meta{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:.4rem}
.svc__meta small{display:block;color:var(--muted);transition:color .5s var(--ease)}
.svc__meta strong{font-family:'Fraunces',serif;font-size:1.55rem;font-weight:400;font-style:italic;transition:color .5s var(--ease);line-height:1}
.svc__meta strong small{font-family:'Inter',sans-serif;font-size:.7rem;letter-spacing:.05em;font-style:normal;color:var(--muted);text-transform:none;display:inline}
.svc__link{
  font-family:'JetBrains Mono',monospace;font-size:.65rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold);
  margin-top:.5rem;padding:.4rem 0;
  border-bottom:1px solid currentColor;
  transition:color .5s var(--ease);
}

/* -------- PROCESS -------- */
.process{
  padding:8rem 3rem;border-top:1px solid var(--line);
  background:var(--bone-2);
}
.process__head{max-width:760px;margin:0 auto 5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}
.process__head .intro__label{align-items:center;padding:0}
.process__head h2{margin-bottom:.6rem}
.process__head p{max-width:560px}

.process__list{
  display:grid;grid-template-columns:repeat(5,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
  border-radius:4px;overflow:hidden;
}
.process__step{
  background:var(--bone-2);padding:2.5rem 1.8rem;
  display:flex;flex-direction:column;gap:1rem;
  position:relative;transition:background .5s var(--ease);
}
.process__step:hover{background:var(--bone)}
.process__num{
  width:48px;height:48px;border-radius:50%;
  border:1px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif;font-style:italic;font-size:1.2rem;
  color:var(--gold);
  transition:all .5s var(--ease);
}
.process__step:hover .process__num{background:var(--gold);color:var(--bone)}
.process__step h4{font-weight:500;line-height:1.25;font-size:1.15rem;font-family:'Fraunces',serif}
.process__step p{font-size:.92rem;color:var(--ink-soft);flex-grow:1}
.process__step small{color:var(--gold-dark);margin-top:auto;padding-top:.8rem;border-top:1px solid var(--line)}

/* -------- TECHNOLOGY -------- */
.tech{padding:8rem 3rem;border-top:1px solid var(--line)}
.tech__head{
  display:grid;grid-template-columns:1fr 3fr;gap:6rem;margin-bottom:5rem;align-items:start;
}

.tech__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;
}
.tech__card{
  padding:2.4rem 2rem;background:var(--bone-2);
  border:1px solid var(--line);border-radius:4px;
  display:flex;flex-direction:column;gap:1rem;
  transition:all .5s var(--ease);position:relative;overflow:hidden;
}
.tech__card::before{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--gold);transition:width .6s var(--ease-2);
}
.tech__card:hover{transform:translateY(-6px);box-shadow:var(--shadow-2);border-color:transparent}
.tech__card:hover::before{width:100%}
.tech__icon{
  width:54px;height:54px;border-radius:8px;
  background:var(--ink);
  position:relative;
  display:flex;align-items:center;justify-content:center;
}
.tech__icon::before{
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;font-size:1.5rem;
  color:var(--gold);
}
.tech__icon[data-icon="scan"]::before{content:"⌒"}
.tech__icon[data-icon="ct"]::before{content:"◎"}
.tech__icon[data-icon="microscope"]::before{content:"◉"}
.tech__icon[data-icon="laser"]::before{content:"✧"}
.tech__icon[data-icon="sterilize"]::before{content:"❋"}
.tech__icon[data-icon="cad"]::before{content:"◈"}
.tech__icon[data-icon="ortho"]::before{content:"≣"}
.tech__icon[data-icon="implant"]::before{content:"◆"}
.tech__icon[data-icon="whitening"]::before{content:"✶"}

/* 5-card layout: 3 on top, 2 centered below */
.tech__grid--5{grid-template-columns:repeat(6,1fr)}
.tech__grid--5 > .tech__card{grid-column:span 2}
.tech__grid--5 > .tech__card:nth-child(4){grid-column:2 / span 2}
.tech__grid--5 > .tech__card:nth-child(5){grid-column:span 2}
@media (max-width:980px){
  .tech__grid--5{grid-template-columns:1fr 1fr}
  .tech__grid--5 > .tech__card,
  .tech__grid--5 > .tech__card:nth-child(4),
  .tech__grid--5 > .tech__card:nth-child(5){grid-column:auto}
}
@media (max-width:640px){
  .tech__grid--5{grid-template-columns:1fr}
}
.tech__card h4{font-family:'Fraunces',serif;font-weight:500;font-size:1.2rem}
.tech__card p{font-size:.92rem;color:var(--ink-soft);flex-grow:1}
.tech__card small{color:var(--gold-dark);margin-top:.4rem}

/* -------- PULL QUOTE -------- */
.pullquote{
  padding:9rem 3rem;text-align:center;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--bone-2);position:relative;overflow:hidden;
}
.pullquote::before{
  content:"";position:absolute;top:50%;left:50%;
  width:380px;height:300px;transform:translate(-50%,-50%);
  background:url("LOGO%20TENSHIN%20V3_TENSHI%20LOGO.png") no-repeat center/contain;
  opacity:.05;pointer-events:none;
  animation:hover-logo 6s ease-in-out infinite;
}
@keyframes hover-logo{
  0%,100%{transform:translate(-50%,-50%) translateY(0)}
  50%{transform:translate(-50%,-50%) translateY(-14px)}
}
.pullquote > *{position:relative;z-index:1}
.pullquote__marks span{
  font-family:'Fraunces',serif;font-size:10rem;font-weight:300;color:var(--gold);
  line-height:.3;display:block;margin-bottom:2rem;
}
.pullquote blockquote{
  font-family:'Fraunces',serif;font-size:clamp(1.8rem, 3.2vw, 3rem);
  font-weight:300;line-height:1.25;letter-spacing:-.015em;
  max-width:1000px;margin:0 auto 3rem;color:var(--ink);
}
.pullquote blockquote .italic{color:var(--gold);font-style:italic;display:block;margin-top:.5rem}
.pullquote footer{display:flex;align-items:center;justify-content:center;gap:1.5rem}
.pq-line{width:48px;height:1px;background:var(--ink)}
.pullquote cite{font-style:normal;text-align:left}
.pullquote cite strong{font-family:'Fraunces',serif;font-style:italic;font-size:1.1rem;font-weight:400;display:block;color:var(--ink)}
.pullquote cite small{color:var(--muted)}

/* -------- PHILOSOPHY (card grid) -------- */
.philosophy{padding:8rem 3rem;border-top:1px solid var(--line)}
.philosophy__head{
  max-width:880px;margin:0 auto 4rem;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:1rem;
}
.philosophy__head .intro__label{align-items:center;padding:0}
.philosophy__head h2{margin-bottom:.4rem;max-width:780px}
.philosophy__head p{max-width:620px}

.philosophy__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;
  max-width:1400px;margin:0 auto;
}
.phi-card{
  background:var(--bone-2);
  border:1px solid var(--line);border-radius:6px;
  padding:2.2rem 2rem 2.4rem;
  display:flex;flex-direction:column;gap:1rem;
  position:relative;overflow:hidden;
  transition:all .55s var(--ease);
}
.phi-card--wide{grid-column:span 4;display:grid;grid-template-columns:1fr 2.2fr;gap:2.5rem;align-items:center}
.phi-card--wide .phi-card__top{flex-direction:column;align-items:flex-start;gap:1rem}
.phi-card--wide h4{margin:0}
.phi-card::before{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--gold);transition:width .6s var(--ease-2);
}
.phi-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-2);border-color:transparent;background:var(--bone)}
.phi-card:hover::before{width:100%}
.phi-card:hover .phi-card__kanji{color:var(--gold);transform:translateY(-4px) rotate(-3deg);opacity:.32}

.phi-card__top{
  display:flex;justify-content:space-between;align-items:flex-start;
  border-bottom:1px solid var(--line);padding-bottom:1.2rem;
}
.p-num{
  font-family:'Fraunces',serif;font-size:1.4rem;font-style:italic;
  font-weight:400;color:var(--gold);letter-spacing:.05em;line-height:1;
  display:inline-flex;align-items:center;gap:.5rem;
}
.p-num::before{
  content:"";width:24px;height:1px;background:var(--gold);display:inline-block;
}
.phi-card__kanji{
  font-family:'Shippori Mincho',serif;font-weight:500;
  font-size:3.6rem;line-height:1;color:var(--ink);
  opacity:.12;
  transition:all .6s var(--ease);
}
.phi-card h4{
  font-family:'Fraunces',serif;font-weight:500;
  font-size:1.4rem;line-height:1.25;color:var(--ink);
  letter-spacing:-.01em;
}
.phi-card h4 em{
  font-style:italic;font-weight:300;color:var(--muted);
  font-size:.85em;display:inline;
}
.phi-card p{
  font-size:.95rem;line-height:1.7;color:var(--ink-soft);
  margin:0;
}

/* -------- ATELIER -------- */
.atelier{padding:8rem 3rem;border-top:1px solid var(--line);background:var(--bone-2)}
.atelier__head{display:grid;grid-template-columns:1fr 3fr;gap:6rem;margin-bottom:5rem}

.atelier__stage{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:stretch}
.atelier__image{
  position:relative;aspect-ratio:3/4;overflow:hidden;border-radius:2px;
}
.atelier__photo{
  position:absolute;inset:0;background-size:cover;background-position:center top;
  opacity:0;transform:scale(1.06);
  transition:opacity 1s var(--ease-2), transform 1.8s var(--ease-2);
  filter:saturate(.85) contrast(1.02);
}
.atelier__photo.active{opacity:1;transform:scale(1)}
.atelier__photo--1{background-image:url("images/BSThao.jpg")}
.atelier__photo--2{background-image:url("images/BSThom.jpg")}
.atelier__photo--3{background-image:url("images/BsHoang.jpg")}

.atelier__list{display:flex;flex-direction:column;justify-content:center;gap:1px}
.atelier__list li{
  padding:1.6rem 0;border-top:1px solid var(--line);cursor:none;
  transition:padding .5s var(--ease), color .4s var(--ease);
  position:relative;
}
.atelier__list li:last-child{border-bottom:1px solid var(--line)}
.atelier__list li.active,.atelier__list li:hover{padding-left:1.5rem}
.atelier__list li.active h3,.atelier__list li:hover h3{color:var(--gold);font-style:italic}
.atelier__name{display:flex;align-items:baseline;gap:1.5rem;margin-bottom:.4rem}
.atelier__name span{
  font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.2em;
  color:var(--gold);
}
.atelier__list h3{font-weight:400;transition:all .4s var(--ease);font-size:1.6rem}
.atelier__list small{color:var(--muted);padding-left:3.4rem;display:block}
.atelier__bio{
  padding-left:3.4rem;font-size:.85rem;color:var(--ink-soft);margin-top:.4rem;
  font-style:italic;
}

/* -------- ARCHIVE (Gallery) -------- */
.archive{padding:8rem 3rem;border-top:1px solid var(--line)}
.archive__head{max-width:720px;margin:0 auto 5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}
.archive__head .intro__label{align-items:center;padding:0}
.archive__head h2{margin-bottom:.8rem}

.archive__grid{
  display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:220px;gap:1rem;
}
.archive__grid figure{position:relative;overflow:hidden;border-radius:2px}
.archive__grid figure div{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transition:transform 1.2s var(--ease-2);
  filter:saturate(.85) contrast(1.04);
}
.archive__grid figure:hover div{transform:scale(1.06)}
.archive__grid figcaption{
  position:absolute;bottom:1rem;left:1rem;right:1rem;
  font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.18em;
  color:var(--bone);text-transform:uppercase;z-index:2;
  opacity:0;transform:translateY(8px);transition:all .5s var(--ease);
}
.archive__grid figure::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(19,22,26,.75));
  opacity:0;transition:opacity .5s var(--ease);
}
.archive__grid figure:hover::after{opacity:1}
.archive__grid figure:hover figcaption{opacity:1;transform:translateY(0)}

.a1{grid-column:span 3;grid-row:span 2}
.a1 div{background-image:url("https://images.unsplash.com/photo-1606811971618-4486d14f3f99?auto=format&fit=crop&w=1200&q=85")}
.a2{grid-column:span 3;grid-row:span 1}
.a2 div{background-image:url("https://images.unsplash.com/photo-1609840114035-3c981b782dfe?auto=format&fit=crop&w=1200&q=85")}
.a3{grid-column:span 2;grid-row:span 1}
.a3 div{background-image:url("https://images.unsplash.com/photo-1629909615957-be38d48fbbe4?auto=format&fit=crop&w=800&q=85")}
.a4{grid-column:span 1;grid-row:span 1}
.a4 div{background-image:url("https://images.unsplash.com/photo-1588776814546-1ffcf47267a5?auto=format&fit=crop&w=600&q=85")}
.a5{grid-column:span 6;grid-row:span 2}
.a5 div{background-image:url("https://images.unsplash.com/photo-1581594693702-fbdc51b2763b?auto=format&fit=crop&w=2400&q=85")}

/* -------- TESTIMONIALS -------- */
.testimonials{padding:8rem 3rem;border-top:1px solid var(--line);background:var(--bone-2)}
.testimonials__head{
  max-width:760px;margin:0 auto 4rem;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:1rem;
}
.testimonials__head .intro__label{align-items:center;padding:0}
.testimonials__rating{display:flex;flex-direction:column;align-items:center;gap:.4rem;margin-top:.4rem}
.stars{color:var(--gold);letter-spacing:.2em;font-size:1.4rem;line-height:1}
.stars.small{font-size:.95rem}

.testimonials__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;
}
.quote-card{
  background:var(--bone);
  border:1px solid var(--line);border-radius:4px;padding:2rem 1.8rem;
  display:flex;flex-direction:column;gap:1rem;
  transition:all .5s var(--ease);
}
.quote-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2);border-color:transparent}
.quote-card__top{display:flex;align-items:center;gap:1rem}
.quote-card__avatar{
  width:52px;height:52px;border-radius:50%;background-size:cover;background-position:center;
  background-color:var(--cream);flex-shrink:0;
  border:2px solid var(--gold-soft);
}
.quote-card__avatar--1{background-image:url("https://images.unsplash.com/photo-1494790108377-be9c29b29330?auto=format&fit=crop&w=200&q=80")}
.quote-card__avatar--2{background-image:url("https://images.unsplash.com/photo-1507003211169-0a1dd7228f2d?auto=format&fit=crop&w=200&q=80")}
.quote-card__avatar--3{background-image:url("https://images.unsplash.com/photo-1438761681033-6461ffad8d80?auto=format&fit=crop&w=200&q=80")}
.quote-card__top strong{font-family:'Fraunces',serif;font-style:italic;font-weight:500;font-size:1.05rem;display:block}
.quote-card__top small{display:block;color:var(--muted);margin-top:.2rem}
.quote-card p{font-size:.95rem;line-height:1.65;color:var(--ink-soft);font-style:italic}

.press{
  margin-top:5rem;padding:2.5rem 0;border-top:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;gap:1.4rem;
}
.press small{color:var(--muted)}
.press__logos{
  display:flex;flex-wrap:wrap;justify-content:center;gap:2.5rem;
}
.press__logos span{
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:1.4rem;color:var(--ink-soft);opacity:.55;
  transition:opacity .4s var(--ease);
}
.press__logos span:hover{opacity:1;color:var(--gold)}

/* -------- PRICING -------- */
.pricing{padding:8rem 3rem;border-top:1px solid var(--line)}
.pricing__head{
  max-width:760px;margin:0 auto 3.5rem;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:1rem;
}
.pricing__head .intro__label{align-items:center;padding:0}
.pricing__head p{max-width:580px}

.pricing__tabs{
  display:flex;justify-content:center;gap:.4rem;
  flex-wrap:wrap;margin-bottom:2.5rem;
  padding:.4rem;background:var(--bone-2);
  border:1px solid var(--line);border-radius:999px;
  width:fit-content;margin-left:auto;margin-right:auto;
}
.pricing__tab{
  padding:.7rem 1.4rem;border:none;background:transparent;
  font-family:'Inter',sans-serif;font-size:.85rem;font-weight:500;
  color:var(--ink-soft);border-radius:999px;cursor:none;
  transition:all .35s var(--ease);
}
.pricing__tab:hover{color:var(--ink)}
.pricing__tab.active{background:var(--ink);color:var(--bone)}

.pricing__panel{display:none;animation:fade-in-up .5s var(--ease)}
.pricing__panel.active{display:block}
@keyframes fade-in-up{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

.pricing__table{
  width:100%;border-collapse:collapse;
  background:var(--bone-2);border:1px solid var(--line);border-radius:4px;overflow:hidden;
}
.pricing__table th{
  text-align:left;padding:1.2rem 1.4rem;
  font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.18em;
  color:var(--muted);text-transform:uppercase;font-weight:500;
  background:var(--bone);
  border-bottom:1px solid var(--line);
}
.pricing__table td{
  padding:1.3rem 1.4rem;border-bottom:1px solid var(--line);
  font-size:.95rem;color:var(--ink-soft);vertical-align:middle;
}
.pricing__table tr:last-child td{border-bottom:none}
.pricing__table td:first-child{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:500;color:var(--ink)}
.pricing__table td.ta-r strong{font-family:'Fraunces',serif;font-style:italic;font-size:1.15rem;font-weight:500;color:var(--ink)}
.pricing__table td.ta-r small{font-family:'Inter',sans-serif;font-size:.7rem;letter-spacing:.04em;color:var(--muted);text-transform:none;font-weight:400}
.pricing__table td.ta-r em{color:var(--gold-dark);font-size:.85rem;display:block;margin-top:.3rem;font-style:italic}
.pricing__table tr.hl{background:linear-gradient(90deg,rgba(212,161,40,.08),rgba(212,161,40,0))}
.pricing__table tr.hl td:first-child{color:var(--gold-dark)}
.pricing__table tr:hover{background:rgba(26,24,21,.02)}

.pricing__notes{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;
  margin-top:2.5rem;padding:2rem 0 0;border-top:1px solid var(--line);
}
.pricing__notes div small{color:var(--gold);display:block;margin-bottom:.6rem}
.pricing__notes div p{font-size:.92rem;line-height:1.65}

/* -------- PROMO -------- */
.promo{padding:6rem 3rem;border-top:1px solid var(--line);background:var(--ink);color:var(--bone)}
.promo__inner{
  display:grid;grid-template-columns:1.4fr 1fr;gap:4rem;align-items:center;
  max-width:1400px;margin:0 auto;
}
.promo__text small{color:var(--gold);display:block;margin-bottom:1rem}
.promo__text h2{color:var(--bone);margin-bottom:1.5rem}
.promo__text h2 em{color:var(--gold);font-size:1.2em}
.promo__text p{color:rgba(245,240,227,.75);max-width:480px;margin-bottom:2rem}
.promo__text .pill-btn--gold{display:inline-flex}

.promo__count{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(245,240,227,.1)}
.promo__count-item{
  background:var(--ink);padding:2.5rem 1rem;text-align:center;
  display:flex;flex-direction:column;gap:.4rem;
  border:1px solid rgba(245,240,227,.06);
}
.promo__count-item strong{font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:clamp(2rem, 4vw, 3.4rem);color:var(--gold);line-height:1}
.promo__count-item small{color:rgba(245,240,227,.6)}

/* -------- FAQ -------- */
.faq{padding:8rem 3rem;border-top:1px solid var(--line)}
.faq__head{
  max-width:820px;margin:0 auto 3rem;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:1rem;
}
.faq__head .intro__label{align-items:center;padding:0}
.faq__sub{color:var(--ink-soft);font-size:1rem;line-height:1.7;max-width:680px;margin-top:.6rem}
.faq__sub a{color:var(--ink);border-bottom:1px solid var(--gold);padding-bottom:1px}
.faq__sub a:hover{color:var(--gold)}

.faq__filters{
  max-width:920px;margin:0 auto 2.6rem;
  display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;
}
.faq__filter{
  background:transparent;border:1px solid var(--line);
  padding:.55rem 1.15rem;border-radius:99px;cursor:none;
  font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-soft);
  transition:all .35s var(--ease);
}
.faq__filter:hover{border-color:var(--ink);color:var(--ink)}
.faq__filter.active{background:var(--ink);border-color:var(--ink);color:var(--bone)}

.faq__list{
  max-width:920px;margin:0 auto;
  display:flex;flex-direction:column;
  border-top:1px solid var(--line);
}
.faq__item{border-bottom:1px solid var(--line);transition:opacity .4s var(--ease)}
.faq__item.hidden{display:none}
.faq__q{
  width:100%;background:transparent;border:none;
  padding:1.8rem 0;
  display:flex;justify-content:space-between;align-items:center;gap:2rem;
  text-align:left;cursor:none;
  font-family:'Fraunces',serif;font-weight:400;
  font-size:clamp(1.05rem, 1.4vw, 1.3rem);color:var(--ink);
  transition:color .35s var(--ease);
}
.faq__q > span{display:inline-flex;flex-wrap:wrap;align-items:baseline;gap:.6rem}
.faq__q:hover{color:var(--gold)}
.faq__cat{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.18em;
  text-transform:uppercase;font-style:normal;
  padding:.32rem .65rem;border:1px solid var(--gold);color:var(--gold-dark);
  border-radius:99px;line-height:1;background:rgba(212,161,40,.06);
}
.faq__icon{
  width:32px;height:32px;border:1px solid var(--ink);border-radius:50%;
  position:relative;flex-shrink:0;
  transition:all .4s var(--ease);
}
.faq__icon::before,.faq__icon::after{
  content:"";position:absolute;top:50%;left:50%;
  background:var(--ink);transition:all .4s var(--ease);
}
.faq__icon::before{width:12px;height:1px;transform:translate(-50%,-50%)}
.faq__icon::after{width:1px;height:12px;transform:translate(-50%,-50%)}
.faq__item.open .faq__icon{background:var(--gold);border-color:var(--gold)}
.faq__item.open .faq__icon::before,.faq__item.open .faq__icon::after{background:var(--bone)}
.faq__item.open .faq__icon::after{transform:translate(-50%,-50%) scaleY(0)}

.faq__a{
  max-height:0;overflow:hidden;
  transition:max-height .55s var(--ease-2);
}
.faq__a p{
  padding:0 0 2rem;font-size:.98rem;color:var(--ink-soft);
  max-width:780px;
}
.faq__a p strong{color:var(--ink);font-weight:500}
.faq__item.open .faq__a{max-height:900px}

.faq__cta{
  max-width:920px;margin:3rem auto 0;text-align:center;
  font-size:.92rem;color:var(--muted);
}
.faq__cta a{color:var(--ink);border-bottom:1px solid var(--gold);padding-bottom:1px}
.faq__cta a:hover{color:var(--gold)}

/* -------- JOURNAL · SEO INSIGHTS -------- */
.journal{padding:8rem 3rem;border-top:1px solid var(--line);background:var(--bone-2)}
.journal__head{display:grid;grid-template-columns:1fr 3fr;gap:6rem;margin-bottom:3rem;align-items:end}
.journal__head-text p{max-width:620px;margin-top:1.4rem}

.journal__filters{
  max-width:1400px;margin:0 auto 3.5rem;
  display:flex;flex-wrap:wrap;gap:.6rem;justify-content:flex-start;
  padding-bottom:1.6rem;border-bottom:1px solid var(--line);
}
.journal__filter{
  background:transparent;border:1px solid var(--line);
  padding:.55rem 1.15rem;border-radius:99px;cursor:none;
  font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-soft);
  transition:all .35s var(--ease);
}
.journal__filter:hover{border-color:var(--ink);color:var(--ink)}
.journal__filter.active{background:var(--ink);border-color:var(--ink);color:var(--bone)}

.journal__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3rem 2.4rem;max-width:1400px;margin:0 auto}
.note{cursor:none;transition:transform .5s var(--ease),opacity .4s var(--ease)}
.note.hidden{display:none}
.note:hover{transform:translateY(-6px)}
.note__link{display:block;color:inherit}
.note__img{
  width:100%;aspect-ratio:4/5;background-size:cover;background-position:center;
  border-radius:2px;margin-bottom:1.5rem;
  filter:saturate(.88) contrast(1.02);
  transition:filter .5s var(--ease);
}
.note:hover .note__img{filter:saturate(1) contrast(1.05)}
.note__img--1{background-image:url("https://images.unsplash.com/photo-1606811971618-4486d14f3f99?auto=format&fit=crop&w=1000&q=85")}
.note__img--2{background-image:url("https://images.unsplash.com/photo-1609840114035-3c981b782dfe?auto=format&fit=crop&w=1000&q=85")}
.note__img--3{background-image:url("https://images.unsplash.com/photo-1616391182219-e080b4d1043a?auto=format&fit=crop&w=1000&q=85")}
.note__img--4{background-image:url("https://images.unsplash.com/photo-1588776814546-1ffcf47267a5?auto=format&fit=crop&w=1000&q=85")}
.note__img--5{background-image:url("https://images.unsplash.com/photo-1581585504171-ee99b6f3d8a4?auto=format&fit=crop&w=1000&q=85")}
.note__img--6{background-image:url("https://images.unsplash.com/photo-1542736667-069246bdbc6d?auto=format&fit=crop&w=1000&q=85")}
.note__body{display:flex;flex-direction:column;gap:.8rem}
.note__meta{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.4rem;flex-wrap:wrap}
.note__cat{
  font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold-dark);
  padding:.32rem .65rem;border:1px solid var(--gold);border-radius:99px;
  background:rgba(212,161,40,.06);line-height:1;
}
.note__meta time{font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.18em;color:var(--muted);text-transform:uppercase}
.note h4{font-weight:400;line-height:1.35;transition:color .3s var(--ease);margin-bottom:.2rem}
.note:hover h4{color:var(--gold)}
.note__excerpt{
  font-size:.92rem;line-height:1.65;color:var(--ink-soft);
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.note__more{
  display:inline-flex;align-items:center;gap:.55rem;margin-top:.7rem;
  font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink);
  border-bottom:1px solid var(--gold);padding-bottom:4px;align-self:flex-start;
  transition:gap .3s var(--ease),color .3s var(--ease);
}
.note__more .arrow{width:14px;height:1px;background:var(--ink);position:relative;transition:all .3s var(--ease)}
.note__more .arrow::after{content:"";position:absolute;right:0;top:50%;width:6px;height:6px;border-top:1px solid var(--ink);border-right:1px solid var(--ink);transform:translateY(-50%) rotate(45deg)}
.note:hover .note__more{color:var(--gold-dark);gap:.9rem}
.note:hover .note__more .arrow,.note:hover .note__more .arrow::after{background:var(--gold-dark);border-color:var(--gold-dark)}

.journal__footer{
  max-width:920px;margin:5rem auto 0;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:1.4rem;
  padding-top:4rem;border-top:1px solid var(--line);
}
.journal__newsletter{
  display:flex;gap:.6rem;width:100%;max-width:460px;
  border-bottom:1px solid var(--ink);padding-bottom:.7rem;
}
.journal__newsletter input{
  flex:1;border:none;background:transparent;padding:.5rem 0;
  font-family:'Inter',sans-serif;font-size:.95rem;color:var(--ink);outline:none;
}
.journal__newsletter button{
  background:transparent;border:none;cursor:none;
  font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink);
  transition:color .3s var(--ease);
}
.journal__newsletter button:hover{color:var(--gold)}
.journal__all{align-self:center}

/* -------- RESERVE -------- */
.reserve{
  padding:8rem 3rem;
  background:var(--ink);color:var(--bone);
  border-top:1px solid var(--line);
}
.reserve__inner{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start;max-width:1400px;margin:0 auto}
.reserve__text h2{color:var(--bone);margin:1.5rem 0 2rem}
.reserve__text h2 em{color:var(--gold)}
.reserve__text p{color:rgba(245,240,227,.75);max-width:430px}

.reserve__contact{display:flex;gap:2rem;margin-top:3rem}
.reserve__contact a{color:var(--bone);display:flex;flex-direction:column;gap:.5rem;padding:1.2rem 0;border-top:1px solid rgba(245,240,227,.15);flex:1}
.reserve__contact a small{color:var(--gold)}
.reserve__contact a strong{font-family:'Fraunces',serif;font-weight:400;font-style:italic;font-size:1.3rem}
.reserve__contact a:hover{color:var(--gold)}

.reserve__channels{display:flex;gap:.7rem;margin-top:1.5rem;flex-wrap:wrap}
.channel{
  flex:1;min-width:180px;display:flex;align-items:center;gap:.8rem;
  padding:.9rem 1rem;border:1px solid rgba(245,240,227,.18);border-radius:8px;
  transition:all .4s var(--ease);
}
.channel:hover{background:rgba(245,240,227,.04);border-color:var(--gold);transform:translateY(-2px)}
.channel__icon{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif;font-style:italic;font-weight:500;font-size:1.1rem;
  color:var(--bone);flex-shrink:0;
}
.channel--zalo .channel__icon{background:#0068FF}
.channel--fb .channel__icon{background:#0084FF}
.channel__text{display:flex;flex-direction:column;line-height:1.2}
.channel__text small{font-size:.6rem;letter-spacing:.18em;color:rgba(245,240,227,.6)}
.channel__text strong{font-family:'Fraunces',serif;font-style:italic;font-weight:400;font-size:.95rem;color:var(--bone)}

.reserve__form{display:flex;flex-direction:column;gap:1.6rem}
.field{display:flex;flex-direction:column;gap:.6rem}
.field label{font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.18em;color:rgba(245,240,227,.5);text-transform:uppercase}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.reserve__form input,
.reserve__form select,
.reserve__form textarea{
  background:transparent;border:none;
  border-bottom:1px solid rgba(245,240,227,.18);
  padding:.8rem 0;color:var(--bone);
  font-family:'Fraunces',serif;font-size:1.05rem;font-weight:300;
  outline:none;transition:border-color .3s var(--ease);resize:none;
}
.reserve__form input::placeholder,.reserve__form textarea::placeholder{color:rgba(245,240,227,.3);font-style:italic}
.reserve__form input:focus,.reserve__form select:focus,.reserve__form textarea:focus{border-color:var(--gold)}
.reserve__form select{cursor:none;color:var(--bone)}
.reserve__form select option{background:var(--ink);color:var(--bone)}
.reserve__form input[type="date"]{color-scheme:dark}

.field-check{
  display:flex;align-items:flex-start;gap:.8rem;cursor:none;
  font-size:.85rem;color:rgba(245,240,227,.7);line-height:1.5;
}
.field-check input{
  width:18px;height:18px;flex-shrink:0;margin-top:3px;
  accent-color:var(--gold);
}
.field-check a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}

.submit-btn{
  margin-top:.5rem;padding:1.2rem 2rem;
  background:var(--gold);color:var(--ink);border:none;border-radius:999px;
  font-family:'Inter',sans-serif;font-size:.92rem;letter-spacing:.02em;font-weight:600;
  display:inline-flex;align-items:center;justify-content:center;gap:.7rem;
  cursor:none;transition:all .4s var(--ease);align-self:flex-start;
}
.submit-btn:hover{background:var(--bone);color:var(--ink);transform:translateY(-2px)}
.submit-btn:disabled{opacity:.6;pointer-events:none}
.submit-btn .arrow{
  display:inline-block;width:14px;height:10px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 10' fill='none' stroke='%231A1815' stroke-width='1.4'%3E%3Cpath d='M0 5h13M8 1l5 4-5 4'/%3E%3C/svg%3E") no-repeat center/contain;
  transition:transform .4s var(--ease);
}
.submit-btn:hover .arrow{transform:translateX(4px)}
.reserve__form-note{color:var(--gold-soft);text-align:center;margin-top:.4rem;font-size:.62rem}

/* -------- BRANCHES -------- */
.branches{padding:8rem 3rem;border-top:1px solid var(--line)}
.branches__head{
  max-width:760px;margin:0 auto 4rem;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:1rem;
}
.branches__head .intro__label{align-items:center;padding:0}

.branches__grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.branch{
  background:var(--bone-2);border:1px solid var(--line);border-radius:4px;
  overflow:hidden;display:flex;flex-direction:column;
  transition:all .5s var(--ease);
}
.branch:hover{transform:translateY(-4px);box-shadow:var(--shadow-2);border-color:transparent}
.branch__map{aspect-ratio:16/9;background:var(--cream);position:relative;overflow:hidden}
.branch__map iframe{width:100%;height:100%;border:0;filter:grayscale(.4) contrast(1.05)}
.branch__info{padding:2rem 2rem 2.4rem}
.branch__info small{color:var(--gold);display:block;margin-bottom:.6rem}
.branch__info h3{font-weight:500;margin-bottom:.8rem}
.branch__info > p{margin-bottom:1.4rem;color:var(--ink-soft);font-size:.95rem}
.branch__meta{display:flex;flex-direction:column;gap:.7rem;border-top:1px solid var(--line);padding-top:1.2rem}
.branch__meta li{display:flex;justify-content:space-between;align-items:center;gap:1rem;font-size:.9rem}
.branch__meta li small{color:var(--muted);margin:0}
.branch__meta li a,.branch__meta li span{color:var(--ink);font-family:'Fraunces',serif;font-style:italic}
.branch__meta li a:hover{color:var(--gold)}

/* Single branch — flagship layout */
.branches--single .branches__head{margin-bottom:3rem}
.branches--single .branches__head .muted{color:var(--ink-soft);font-size:.95rem;line-height:1.7;max-width:560px}
.branches--single .branches__grid{grid-template-columns:1fr;max-width:1100px;margin:0 auto}
.branch--solo{display:grid;grid-template-columns:1.3fr 1fr;align-items:stretch}
.branch--solo .branch__map{aspect-ratio:auto;min-height:460px}
.branch--solo .branch__info{padding:3rem 3rem 3rem;display:flex;flex-direction:column;justify-content:center}
.branch--solo .branch__info h3{font-family:'Fraunces',serif;font-weight:400;font-size:2rem;letter-spacing:-.01em}
.branch__cta{
  margin-top:1.6rem;align-self:flex-start;
  font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold);
  padding:.9rem 1.4rem;border:1px solid var(--gold);border-radius:999px;
  transition:all .35s var(--ease);
}
.branch__cta:hover{background:var(--gold);color:var(--bone)}
@media (max-width:900px){
  .branch--solo{grid-template-columns:1fr}
  .branch--solo .branch__map{min-height:280px;aspect-ratio:16/10}
  .branch--solo .branch__info{padding:2rem}
}

/* -------- FOOTER -------- */
.footer{
  background:var(--ink);color:var(--bone);padding:6rem 3rem 0;
  border-top:1px solid rgba(245,240,227,.1);
}
.footer__top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1.3fr;gap:3rem;
  padding-bottom:5rem;
}
.footer__col{display:flex;flex-direction:column;gap:.8rem}
.footer__col small{color:var(--gold);margin-bottom:.5rem}
.footer__col a,.footer__col p{color:rgba(245,240,227,.75);font-size:.92rem;line-height:1.6}
.footer__col a:hover{color:var(--gold)}

.footer__brand{display:flex;flex-direction:column;gap:.2rem;margin-bottom:1rem}
.footer__brand em{font-family:'Fraunces',serif;font-style:italic;font-weight:400;font-size:1.8rem;color:var(--bone)}
.footer__brand small{color:var(--gold);font-size:.62rem}
.footer__col--brand p{max-width:380px;margin-bottom:.5rem}
.footer__social{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1rem}
.footer__social a{font-size:.85rem}

.newsletter{
  display:flex;gap:.5rem;margin-top:.6rem;
  border-bottom:1px solid rgba(245,240,227,.18);padding-bottom:.5rem;
}
.newsletter input{
  flex:1;background:transparent;border:none;outline:none;
  color:var(--bone);font-family:'Fraunces',serif;font-style:italic;font-size:1rem;
}
.newsletter input::placeholder{color:rgba(245,240,227,.35)}
.newsletter button{
  width:38px;height:38px;border-radius:50%;background:var(--gold);color:var(--ink);
  border:none;cursor:none;font-size:1.1rem;
  transition:all .35s var(--ease);
}
.newsletter button:hover{background:var(--bone)}

.footer__wordmark{
  overflow:hidden;padding:2rem 0;border-top:1px solid rgba(245,240,227,.1);
}
.footer__wordmark span{
  display:block;font-family:'Fraunces',serif;
  font-size:clamp(6rem, 22vw, 22rem);
  font-weight:300;font-style:italic;letter-spacing:-.045em;
  line-height:.82;color:var(--bone);
  text-align:center;
}

.footer__bottom{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  padding:2rem 0;border-top:1px solid rgba(245,240,227,.1);
}
.footer__bottom small{color:rgba(245,240,227,.5)}
.footer__bottom small a{color:rgba(245,240,227,.6)}
.footer__bottom small a:hover{color:var(--gold)}

/* -------- FLOATING CTA -------- */
.floating-cta{
  position:fixed;right:1.5rem;bottom:1.5rem;z-index:90;
  display:flex;flex-direction:column;gap:.7rem;align-items:flex-end;
}
.fab{
  width:54px;height:54px;border-radius:50%;
  background:var(--ink);color:var(--bone);
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-2);
  transition:all .35s var(--ease);
  position:relative;
}
.fab:hover{transform:scale(1.08) translateY(-2px)}
.fab__icon{font-family:'Fraunces',serif;font-style:italic;font-weight:500;font-size:1.2rem;line-height:1}
.fab--call{background:var(--gold);color:var(--ink)}
.fab--call .fab__pulse{
  position:absolute;inset:-4px;border-radius:50%;
  border:1px solid var(--gold);
  animation:dot-pulse 1.8s infinite;
}
.fab--zalo{background:#0068FF;color:var(--bone)}
.fab--fb{background:#0084FF;color:var(--bone)}
.fab--book{
  width:auto;padding:0 1.4rem;border-radius:999px;background:var(--ink);
  display:inline-flex;gap:.5rem;height:54px;
}
.fab--book .fab__label{
  font-family:'Inter',sans-serif;font-size:.85rem;letter-spacing:.04em;font-weight:500;
}
.fab--book:hover{background:var(--gold);color:var(--ink)}

/* -------- TOAST -------- */
.toast{
  position:fixed;left:50%;bottom:2rem;transform:translateX(-50%) translateY(140%);
  z-index:100;background:var(--ink);color:var(--bone);
  border:1px solid rgba(245,240,227,.18);
  padding:.9rem 1.4rem;border-radius:999px;
  display:flex;align-items:center;gap:.7rem;
  font-family:'Inter',sans-serif;font-size:.9rem;
  box-shadow:var(--shadow-2);
  transition:transform .55s var(--ease-2);
}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast__icon{
  width:22px;height:22px;border-radius:50%;background:var(--gold);color:var(--ink);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;
}

/* -------- REVEAL ANIMATION -------- */
.reveal{opacity:0;transform:translateY(36px);transition:all 1s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-line{display:block;overflow:hidden}
.reveal-line > *{display:inline-block;transform:translateY(110%);transition:transform 1s var(--ease-2)}
.reveal-line.in > *{transform:translateY(0)}

/* -------- RESPONSIVE -------- */
@media (max-width:1280px){
  .site-nav{gap:1.2rem}
  .site-nav a{font-size:.78rem}
  .header-phone{display:none}
}

@media (max-width:1100px){
  .site-header{padding:1.2rem 1.5rem;gap:1rem}
  .site-nav{display:none}
  .menu-btn{display:flex}
  .hero,.intro,.feature-image,.services,.process,.tech,.philosophy,.atelier,.archive,.testimonials,.pricing,.promo,.faq,.journal,.reserve,.branches,.footer{padding-left:1.5rem;padding-right:1.5rem}
  .hero{padding-top:3rem}
  .hero__meta{grid-template-columns:1fr;gap:2rem}
  .hero__meta-col--right{align-items:stretch}
  .hero__cta-stack{max-width:100%}
  .hero__badge-row{position:static;margin-top:1rem;justify-content:center;flex-wrap:wrap}
  .intro{grid-template-columns:1fr;gap:3rem}
  .intro__grid{grid-template-columns:1fr 1fr;gap:2rem}
  .services__head,.tech__head,.atelier__head,.journal__head{grid-template-columns:1fr;gap:2rem;margin-bottom:3rem}
  .svc{grid-template-columns:50px 1fr;gap:1.2rem;padding:2rem 0}
  .svc__img,.svc__meta{grid-column:1 / -1}
  .svc__img{display:none}
  .svc__meta{text-align:left;align-items:flex-start;flex-direction:row;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.6rem;border-top:1px dashed var(--line);padding-top:1rem}
  .process__list{grid-template-columns:1fr 1fr}
  .tech__grid{grid-template-columns:1fr 1fr}
  .philosophy__grid{grid-template-columns:repeat(2,1fr)}
  .phi-card--wide{grid-column:span 2;grid-template-columns:1fr;gap:1.2rem}
  .atelier__stage{grid-template-columns:1fr;gap:3rem}
  .archive__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}
  .a1,.a2,.a3,.a4,.a5{grid-column:span 2;grid-row:span 1}
  .a1{grid-row:span 2}
  .testimonials__grid{grid-template-columns:1fr}
  .pricing__notes{grid-template-columns:1fr}
  .promo__inner{grid-template-columns:1fr;gap:2.5rem}
  .branches__grid{grid-template-columns:1fr}
  .journal__grid{grid-template-columns:1fr;gap:2rem}
  .reserve__inner{grid-template-columns:1fr;gap:3rem}
  .footer__top{grid-template-columns:1fr 1fr;gap:2rem}
  .footer__col--brand{grid-column:1 / -1}
  .menu-overlay__inner{grid-template-columns:1fr;padding:7rem 1.5rem 2rem;align-items:start}
  .cursor,.cursor-dot{display:none}
  body{cursor:auto}
  .pill-btn,.menu-btn,.fab,.submit-btn,.faq__q,.faq__filter,.journal__filter,.pricing__tab,.atelier__list li,.note,.field-check,.newsletter button,.journal__newsletter button{cursor:pointer}
  .reserve__form select{cursor:pointer}
  .journal__head{grid-template-columns:1fr;gap:2rem;align-items:start}
  .journal__filters{justify-content:center;gap:.5rem}
  .faq__filters{gap:.4rem}
  .faq__filter,.journal__filter{padding:.5rem .9rem;font-size:.65rem}
}

@media (max-width:760px){
  .journal__grid{grid-template-columns:1fr;gap:2.4rem}
  .journal__newsletter{flex-direction:column;align-items:stretch;border-bottom:none}
  .journal__newsletter input{border-bottom:1px solid var(--ink);padding:.7rem 0}
  .journal__newsletter button{padding:.7rem 0;text-align:left;border-bottom:1px solid var(--gold)}
  .faq__filters{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:.6rem;-webkit-overflow-scrolling:touch}
  .faq__filters::-webkit-scrollbar{display:none}
  .faq__filter{flex-shrink:0}
  .journal__filters{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}
  .journal__filters::-webkit-scrollbar{display:none}
  .journal__filter{flex-shrink:0}
  .hero{padding-top:2rem}
  .hero__title{font-size:clamp(2.6rem, 13vw, 5rem)}
  .hero__title .line--italic{padding-left:4vw}
  .intro__grid{grid-template-columns:1fr}
  .field-grid{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .footer__col--brand{grid-column:auto}
  .archive__grid{grid-template-columns:1fr}
  .a1,.a2,.a3,.a4,.a5{grid-column:span 1;grid-row:span 1}
  .pricing__table{font-size:.85rem}
  .pricing__table th,.pricing__table td{padding:.8rem .7rem}
  .pricing__table thead{display:none}
  .pricing__table,.pricing__table tbody,.pricing__table tr,.pricing__table td{display:block;width:100%}
  .pricing__table tr{padding:1rem;border-bottom:1px solid var(--line)}
  .pricing__table td{border:none;padding:.3rem 0}
  .pricing__table td.ta-r{text-align:left;padding-top:.6rem;border-top:1px dashed var(--line);margin-top:.4rem}
  .process__list{grid-template-columns:1fr}
  .tech__grid{grid-template-columns:1fr}
  .philosophy__grid{grid-template-columns:1fr}
  .phi-card--wide{grid-column:span 1}
  .reserve__contact{flex-direction:column;gap:0}
  .trust-strip{padding:2.5rem 1.5rem;gap:1.5rem}
  .trust-strip__divider{display:none}
  .trust-strip__item{flex-basis:45%}
  .floating-cta{right:1rem;bottom:1rem}
  .fab{width:48px;height:48px}
  .fab--book .fab__label{display:none}
  .fab--book{width:48px;padding:0;border-radius:50%}
  .header-phone{display:none}
}
