:root{
  --paper:#f5eee4;
  --paper-2:#eadcc9;
  --ink:#241e18;
  --soft:#756858;
  --gold:#a77b45;
  --clay:#6f4d35;
  --line:rgba(36,30,24,.16);
  --white:#fff7ea;
  --topbar-h:72px;
}
/* Touch optimization */
*{-webkit-tap-highlight-color:transparent}
button,a,[role="button"]{touch-action:manipulation}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{
  font-family:Inter,system-ui,sans-serif;
  background:
    radial-gradient(circle at 12% 18%, rgba(167,123,69,.18), transparent 32rem),
    radial-gradient(circle at 88% 42%, rgba(111,77,53,.13), transparent 26rem),
    linear-gradient(180deg,#f8f1e8 0%,#f1e5d6 52%,#f7efe4 100%);
  overflow-x:hidden;
  color:var(--ink);
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.2;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 160 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.38'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
a{color:inherit}
img{display:block;max-width:100%}

.topbar{
  position:fixed;top:0;left:0;right:0;z-index:50;
  height:var(--topbar-h);padding:0 clamp(0.9rem,2.6vw,2rem);
  display:flex;align-items:center;justify-content:space-between;gap:.75rem;
  color:#fff4e6;
  background:linear-gradient(to bottom,rgba(30,23,18,.94),rgba(30,23,18,.62));
  backdrop-filter:blur(12px) saturate(118%);
  -webkit-backdrop-filter:blur(12px) saturate(118%);
  border-bottom:1px solid rgba(255,244,230,.16);
  box-shadow:0 8px 28px rgba(0,0,0,.18);
  transition:background .25s ease,border-color .25s ease,box-shadow .25s ease;
}
.topbar.scrolled{background:rgba(30,23,18,.96);border-bottom-color:rgba(255,244,230,.22);box-shadow:0 10px 30px rgba(12,9,7,.28)}
.topbar .brand{color:#fff7ea;flex-shrink:0}
.brand{font-family:"Cormorant Garamond",serif;font-size:clamp(1.3rem,2vw,1.8rem);text-decoration:none;letter-spacing:.02em}
.topbar-end{display:flex;align-items:center;justify-content:flex-end;gap:.55rem;min-width:0;flex:1}
.menu-btn{display:none;flex-shrink:0;border:1px solid rgba(255,244,230,.38);background:rgba(36,30,24,.55);color:#fff4e6;padding:.45rem .75rem;font-size:.55rem;letter-spacing:.13em;text-transform:uppercase;border-radius:999px}
.topbar .nav{
  display:flex;gap:.15rem;align-items:center;flex-wrap:nowrap;
  max-width:min(100%,74rem);overflow-x:auto;overflow-y:hidden;
  padding:.28rem .35rem;border:1px solid rgba(255,244,230,.28);border-radius:999px;
  background:rgba(22,17,13,.68);box-shadow:0 6px 20px rgba(0,0,0,.22);
  -webkit-overflow-scrolling:touch;scrollbar-width:none;
}
.topbar .nav::-webkit-scrollbar{display:none}
.topbar .nav a{font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;text-decoration:none;color:#fff7ea;opacity:1;padding:.4rem .52rem;border-radius:999px;white-space:nowrap;transition:background .2s ease,color .2s ease}
.topbar .nav a:hover,.topbar .nav a.active{color:#f2cd91;background:rgba(242,205,145,.14)}
.mobile-menu a.active{color:#f2cd91;background:rgba(242,205,145,.1)}

.mobile-menu{display:block;position:fixed;top:var(--topbar-h);left:.7rem;right:.7rem;z-index:49;background:rgba(22,17,13,.98);padding:.6rem .75rem;border:1px solid rgba(255,244,230,.12);border-radius:20px;transform:translateY(-12px);opacity:0;pointer-events:none;max-height:calc(100svh - var(--topbar-h) - 20px);overflow:auto;transition:transform .2s ease,opacity .2s ease}
.mobile-menu a{display:block;padding:.75rem .7rem;font-size:.63rem;letter-spacing:.16em;text-transform:uppercase;color:#fff4e6;text-decoration:none;border-radius:12px}
.mobile-menu a:hover,.mobile-menu a:focus-visible{background:rgba(255,244,230,.08);outline:none}
.mobile-menu.show{transform:translateY(0);opacity:1;pointer-events:auto}
body.menu-open{overflow:hidden}
body.menu-open::before{opacity:.35}

.btn{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border:1px solid rgba(255,244,230,.42);padding:.82rem 1rem;border-radius:999px;text-transform:uppercase;letter-spacing:.16em;font-size:.62rem}
.btn.dark{background:#241e18;border-color:#241e18;color:#fff4e6}

h1{
  font-family:"Cormorant Garamond",serif;
  font-weight:300;
  font-size:clamp(3.4rem,10vw,9.5rem);
  line-height:.85;
  letter-spacing:-.045em;
}
h2.section-title{
  font-family:"Cormorant Garamond",serif;
  font-weight:300;
  font-size:clamp(2.4rem,5.5vw,5.5rem);
  line-height:.88;
  letter-spacing:-.035em;
}
h3{
  font-family:"Cormorant Garamond",serif;
  font-weight:300;
  font-size:clamp(1.8rem,3.5vw,3.6rem);
  line-height:.9;
  letter-spacing:-.025em;
}
p{
  font-family:Inter,system-ui,sans-serif;
  font-size:clamp(1rem,1.35vw,1.15rem);
  font-weight:300;
  line-height:1.9;
  color:var(--soft);
  letter-spacing:.01em;
}
p.lead{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(1.5rem,2.8vw,2.4rem);
  font-weight:300;
  line-height:1.15;
  color:var(--ink);
  letter-spacing:-.015em;
}
.eyebrow,.kicker,.mini{
  font-family:Inter,system-ui,sans-serif;
  font-size:.58rem;
  font-weight:500;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--gold);
}

blockquote,.pullquote{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(1.6rem,3vw,2.8rem);
  font-weight:300;
  font-style:italic;
  line-height:1.2;
  color:var(--ink);
  border-left:2px solid var(--gold);
  padding-left:1.5rem;
  margin:2rem 0;
  letter-spacing:-.01em;
}

.reveal{opacity:0;transform:translateY(30px)}
@keyframes shine{from{background-position:120% 0}to{background-position:0 0}}
.shimmer{
  background:linear-gradient(100deg,rgba(255,247,234,.75) 0%,rgba(255,236,201,.98) 42%,rgba(167,123,69,.92) 50%,rgba(255,236,201,.98) 58%,rgba(255,247,234,.75) 100%);
  background-size:260% 100%;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  animation:shine .95s ease-out;
}

.footer{padding:2rem clamp(1.2rem,4vw,4rem);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;color:var(--soft);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase}
.footer-social{display:flex;gap:1.2rem}
.footer-social a{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;color:var(--soft);transition:color .2s ease}
.footer-social a:hover{color:var(--gold)}
.testimonials{padding:3rem clamp(1.2rem,6vw,7rem)}
.testimonial-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.5rem,4vw,4rem);margin-top:1.5rem}
.pullquote cite{display:block;margin-top:.8rem;font-style:normal;font-family:Inter,sans-serif;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}

@media(max-width:1280px){
  .topbar .nav a{font-size:.52rem;letter-spacing:.13em;padding:.36rem .44rem}
}
@media(max-width:980px){
  .topbar .nav{display:none}
  .menu-btn{display:inline-flex}
}
@media(max-width:620px){
  :root{--topbar-h:64px}
  .topbar{padding:0 .85rem}
  .mobile-menu{left:.45rem;right:.45rem}
  .footer{display:grid}
}
@media(max-width:720px){.testimonial-grid{grid-template-columns:1fr}}
@media(max-width:768px){
  .nav a,.mobile-menu a{min-height:46px;display:flex;align-items:center}
  .btn{min-height:48px;padding:.9rem 1.4rem}
  .menu-btn{min-height:46px;min-width:46px;display:flex;align-items:center;justify-content:center}
  .eyebrow,.kicker,.mini{font-size:.65rem;letter-spacing:.2em}
  .footer{font-size:.65rem;gap:1.2rem;padding:1.5rem 1.2rem}
  .footer-social{gap:1rem;flex-wrap:wrap}
}

@media(max-width:430px){
  :root{--topbar-h:60px}
  .topbar{padding:0 .72rem}
  .brand{font-size:1.26rem}
  .menu-btn{font-size:.5rem;letter-spacing:.12em;padding:.4rem .62rem}
  .mobile-menu{left:.35rem;right:.35rem;padding:.5rem .6rem;border-radius:16px;max-height:calc(100svh - 74px)}
  .mobile-menu a{padding:.68rem .55rem;font-size:.58rem}
}

@media(max-height:740px) and (max-width:640px){
  .mobile-menu{max-height:calc(100svh - 68px)}
}

/* Smooth scrolling on iOS for overlay panels */
.class-panel,
.mobile-menu{
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
}
