/* Sora Well Bar — Website UI Kit styles
   Ported from the live sorawellbar.com build, wired to the design-system
   tokens in /colors_and_type.css. Local brand vars below alias the tokens
   so the ported rules read cleanly. */
@import url('colors_and_type.css');

:root{
  --ivory: var(--bg);
  --sand: var(--bg-sand);
  --sand-2: var(--bg-recessed);
  --champagne: var(--sora-champagne);
  --bronze: var(--accent);
  --espresso: var(--sora-espresso);
  --taupe: var(--sora-taupe);
  --sage: var(--sora-sage);
  --sage-deep: var(--sora-sage-deep);
  --clay: var(--sora-clay);
  --gold: var(--sora-gold);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg-limewash);
  background-attachment:fixed;
  color:var(--espresso);
  font-family:'Montserrat',sans-serif;font-weight:300;line-height:1.8;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.06;background-image:var(--grain)}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
.page{display:none}.page.active{display:block;animation:pagein .7s ease}
@keyframes pagein{from{opacity:0}to{opacity:1}}

h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:300;letter-spacing:.005em}
em{font-style:italic;color:var(--gold)}
.eyebrow{font-family:'Montserrat';font-weight:400;font-size:11px;letter-spacing:.36em;text-transform:uppercase;color:var(--clay)}

.btn{display:inline-block;font-family:'Montserrat';font-weight:400;font-size:11px;letter-spacing:.26em;text-transform:uppercase;padding:15px 32px;border:1px solid var(--bronze);color:var(--bronze);background:transparent;cursor:pointer;transition:.45s var(--ease);border-radius:1px}
.btn:hover{background:var(--bronze);color:var(--ivory)}
.btn.solid{background:var(--bronze);color:var(--ivory)}.btn.solid:hover{background:var(--espresso);border-color:var(--espresso)}

/* arch frames */
.archframe{position:relative;overflow:hidden;border-top-left-radius:50% 30%;border-top-right-radius:50% 30%;box-shadow:0 40px 90px -45px rgba(58,48,43,.5)}
.archframe img{width:100%;height:100%;object-fit:cover;transition:transform 6s ease;filter:var(--photo-grade)}
.archframe:hover img{transform:scale(1.05)}
.archframe::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(165deg,rgba(247,243,238,.18),rgba(232,221,208,.09) 55%,rgba(156,123,84,.07))}
.imgph{background:#ece1d3;overflow:hidden}
.imgph img{width:100%;height:100%;object-fit:cover;transition:transform 6s ease;filter:var(--photo-grade)}
.imgph:hover img{transform:scale(1.05)}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:20px 40px;transition:.5s;background:transparent}
nav.scrolled{background:rgba(247,243,238,.92);backdrop-filter:blur(10px);box-shadow:0 1px 0 rgba(156,123,84,.14);padding:13px 40px}
.nav-links{display:flex;gap:32px}
.nav-links a{font-family:'Montserrat';font-weight:400;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--espresso);opacity:.76;transition:.3s;position:relative;cursor:pointer}
.nav-links a:after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--champagne);transition:.4s}
.nav-links a:hover{opacity:1}.nav-links a:hover:after,.nav-links a.cur:after{width:100%}.nav-links a.cur{opacity:1}

/* crest logo */
.crest{display:inline-flex;flex-direction:column;align-items:center;gap:7px;border:1px solid rgba(156,123,84,.5);padding:11px 22px 10px;border-radius:42px 42px 6px 6px;cursor:pointer}
.crest .camk{width:23px;color:var(--gold)}
.crest .cs{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:15px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);line-height:1;padding-left:.3em}
.crest .cw{font-family:'Marcellus',serif;font-size:8px;letter-spacing:.34em;text-transform:uppercase;color:var(--taupe);padding-left:.34em}

/* hamburger toggle + mobile menu */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:11px;background:transparent;border:none;cursor:pointer;z-index:101}
.nav-toggle span{display:block;width:100%;height:1.5px;background:var(--espresso);border-radius:2px;transition:transform .45s var(--ease),opacity .3s var(--ease);transform-origin:center}
.nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

.mobile-menu{position:fixed;inset:0;z-index:90;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:84px 24px 48px;background:rgba(247,243,238,.97);backdrop-filter:blur(14px);opacity:0;pointer-events:none;transition:opacity .5s var(--ease)}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-menu .mm-eyebrow{font-family:'Montserrat';font-weight:400;font-size:10px;letter-spacing:.34em;text-transform:uppercase;color:var(--clay);margin-bottom:26px}
.mobile-menu a{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:29px;letter-spacing:.01em;color:var(--espresso);padding:9px 0;cursor:pointer;transition:.3s;opacity:.9}
.mobile-menu a.cur{color:var(--gold);font-style:italic;opacity:1}

/* HERO */
.hero{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:40px;padding:120px 64px 60px;position:relative}
.hero-copy{max-width:520px;justify-self:end}
.hero-copy .eyebrow{display:block;margin-bottom:20px}
.hero-sig{width:clamp(280px,38vw,460px);margin:2px 0 6px -6px}
.hero-word{font-family:'Marcellus',serif;font-size:clamp(15px,1.6vw,19px);letter-spacing:.52em;text-transform:uppercase;color:var(--espresso);margin:6px 0 0 6px}
.hero-line{font-family:'Cormorant Garamond';font-size:clamp(20px,2.2vw,26px);font-style:italic;color:var(--taupe);margin:30px 0 36px;line-height:1.5;max-width:430px}
.hero-art{justify-self:start;position:relative}
.hero-art .archframe{width:min(440px,42vw);aspect-ratio:.8}
.hero-art:before{content:"";position:absolute;inset:-22px -22px 18px -22px;z-index:-1;border:1px solid rgba(156,123,84,.4);border-top-left-radius:50% 30%;border-top-right-radius:50% 30%}
.scrollcue{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);font-family:'Montserrat';font-size:10px;letter-spacing:.34em;text-transform:uppercase;color:var(--taupe);opacity:.7}

/* page hero */
.phero{padding:200px 0 96px;text-align:center}
.phero .eyebrow{display:block;margin-bottom:18px}
.phero h1{font-size:clamp(42px,7vw,86px)}
.phero h1 em{color:var(--gold)}
.phero p{max-width:560px;margin:20px auto 0;color:var(--taupe);font-size:15.5px}

/* ticker */
.ticker{overflow:hidden;background:var(--espresso);padding:15px 0;white-space:nowrap;border-top:1px solid #4a3f37;border-bottom:1px solid #4a3f37}
.ticker-track{display:inline-flex;animation:tick 36s linear infinite;will-change:transform}
.ticker .item{display:inline-flex;align-items:center;font-family:'Montserrat',sans-serif;font-weight:400;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:#e9dfd2;padding:0 6px}
.ticker .sep{color:var(--gold);margin:0 22px;font-size:11px}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker:hover .ticker-track{animation-play-state:paused}

/* story / editorial split */
.story{padding:120px 0}
.story .grid{display:grid;grid-template-columns:1fr 1fr;gap:90px;align-items:center}
.story .archframe,.story .imgph{aspect-ratio:1.05/1;border-radius:8px}
.story .archframe{border-top-left-radius:50% 30%;border-top-right-radius:50% 30%}
.story-txt h2{font-size:clamp(38px,4.6vw,60px);line-height:1.04;margin:6px 0 0}
.story-txt p{color:var(--taupe);margin-top:22px;font-size:15px}
.story-txt .sig{font-family:'Great Vibes',cursive;font-size:34px;color:var(--sage-deep);margin-top:24px}

/* community band */
.community{padding:0 0 118px}
.community .head{text-align:center;margin:0 auto 46px}.community .head .eyebrow{display:block;margin-bottom:8px}
.community .head h2{font-size:clamp(32px,4vw,52px)}
.commframe{position:relative;overflow:hidden;max-width:1180px;margin:0 auto;aspect-ratio:2.05/1;border-top-left-radius:46% 64%;border-top-right-radius:46% 64%;box-shadow:0 50px 100px -50px rgba(58,48,43,.5)}
.commframe img{width:100%;height:100%;object-fit:cover;object-position:50% 32%;transition:transform 7s ease;filter:var(--photo-grade)}
.commframe:hover img{transform:scale(1.04)}

/* pillars */
.pillars{background:var(--sand-2);padding:116px 0}
.pillars .head{text-align:center;margin-bottom:64px}.pillars .head .eyebrow{display:block;margin-bottom:8px}
.pillars .head h2{font-size:clamp(34px,4vw,52px)}
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:44px}
.pill{text-align:center}.pill .imgph{aspect-ratio:.82;border-top-left-radius:50% 28%;border-top-right-radius:50% 28%}
.pill h3{font-size:30px;margin:24px 0 6px}
.pill .sub{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--sage-deep)}
.pill p{color:var(--taupe);font-family:'Cormorant Garamond';font-style:italic;font-size:18px;margin-top:8px}

/* testimonials */
.testi{background:var(--sand-2);padding:112px 0}
.testi .head{text-align:center;margin-bottom:50px}.testi .head .eyebrow{display:block;margin-bottom:8px}
.testi .head h2{font-size:clamp(32px,4vw,52px)}
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:1060px;margin:0 auto}
.testi blockquote{background:var(--ivory);border:1px solid rgba(156,123,84,.2);border-radius:6px 6px 6px 38px;padding:34px 30px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:20px;line-height:1.5;color:var(--espresso)}
.testi blockquote cite{display:block;font-family:'Montserrat';font-style:normal;font-weight:400;font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--clay);margin-top:18px}

/* quote band */
.quote{background:linear-gradient(160deg,#caa089,var(--clay));color:#fff7f0;text-align:center;padding:116px 24px}
.quote p{font-family:'Cormorant Garamond';font-size:clamp(28px,3.6vw,46px);font-style:italic;line-height:1.32;max-width:760px;margin:0 auto}
.quote .by{font-family:'Montserrat';font-weight:400;font-size:11px;letter-spacing:.3em;text-transform:uppercase;margin-top:32px;opacity:.85}

/* cta */
.cta{text-align:center;padding:124px 24px}.cta .eyebrow{display:block;margin-bottom:16px}
.cta h2{font-size:clamp(36px,5vw,66px);line-height:1.03}
.cta p{color:var(--taupe);max-width:480px;margin:20px auto 36px;font-size:15px}

/* movement */
.movement{padding:110px 32px;display:flex;flex-direction:column;gap:90px}
.mrow{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.mrow.rev .imgph{order:2}
.mrow .imgph{aspect-ratio:1.1/1;border-radius:8px;border-top-left-radius:50% 26%;border-top-right-radius:50% 26%}
.mtxt h2{font-size:clamp(36px,4.4vw,56px)}
.mtxt .sub{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--sage-deep);margin-top:6px}
.mline{font-family:'Cormorant Garamond';font-style:italic;font-size:22px;color:var(--sage-deep);margin:14px 0}
.mtxt p{color:var(--taupe);font-size:15px}
.schedule{text-align:center;margin-top:8px}

/* membership */
.founding{padding:64px 0 8px}
.founding-card{max-width:1050px;margin:0 auto;background:linear-gradient(165deg,#3a302b,#4a3d34);color:#efe4d6;border:1px solid rgba(194,161,114,.35);border-radius:8px;padding:46px 52px;box-shadow:0 34px 80px -46px rgba(58,48,43,.7)}
.founding-tag{font-family:'Montserrat',sans-serif;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.founding-card h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(30px,4.2vw,48px);color:#fff;margin:0 0 10px;line-height:1.02}
.founding-card h2 em{font-style:italic;color:var(--gold)}
.founding-card>p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:19px;color:#d9cab8;max-width:640px;margin:0}
.founding-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:44px;margin-top:30px;align-items:center}
.founding-price{border-right:1px solid rgba(255,255,255,.14);padding-right:40px}
.fp{display:flex;align-items:baseline;gap:8px}
.fp .amt{font-family:'Cormorant Garamond',serif;font-size:66px;color:var(--gold);line-height:1}
.fp .per{font-family:'Montserrat',sans-serif;font-size:13px;letter-spacing:.08em;color:#cdbfae}
.fp-note{font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:#b3a48f;margin:12px 0 22px}
.founding-price .btn.solid{background:var(--gold);color:#3a302b;border-color:var(--gold)}
.fp-left{font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-top:16px}
.founding-perks{list-style:none}
.founding-perks li{font-family:'Cormorant Garamond',serif;font-size:19px;color:#ece0d2;padding:9px 0 9px 28px;border-bottom:1px solid rgba(255,255,255,.08);position:relative;line-height:1.35}
.founding-perks li:last-child{border-bottom:none}
.founding-perks li:before{content:"\2726";position:absolute;left:0;top:11px;color:var(--gold);font-size:13px}

.member{padding:116px 0}
.member .head{text-align:center;margin-bottom:42px}.member .head .eyebrow{display:block;margin-bottom:8px}
.member .head h2{font-size:clamp(30px,3.6vw,46px)}.member .head h2 em{font-style:italic;color:var(--gold)}
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;max-width:1040px;margin:0 auto}
.tier{background:var(--ivory);border:1px solid rgba(156,123,84,.22);padding:42px 30px;text-align:center;position:relative;border-radius:2px;display:flex;flex-direction:column;gap:14px}
.tier.feature{border-color:var(--bronze);box-shadow:0 30px 70px -40px rgba(58,48,43,.45);transform:translateY(-10px)}
.tier .rib{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--bronze);color:#fff;font-family:'Montserrat';font-size:9px;letter-spacing:.24em;text-transform:uppercase;padding:6px 16px;border-radius:20px}
.tier .tname{font-family:'Marcellus';font-size:15px;letter-spacing:.14em;text-transform:uppercase;color:var(--espresso)}
.tier .price{font-family:'Cormorant Garamond';font-size:40px;color:var(--bronze)}.tier .price small{font-size:14px;color:var(--taupe)}
.tier ul{list-style:none;color:var(--taupe);font-size:13.5px;display:flex;flex-direction:column;gap:9px;text-align:left}
.tier ul li{padding-top:9px;border-top:1px solid rgba(156,123,84,.14)}
.tier .btn{margin-top:auto}
.finehint{text-align:center;color:var(--champagne);font-style:italic;font-size:13px;margin-top:30px}

/* experiences */
.exp{padding:110px 32px}
.egrid{display:grid;grid-template-columns:1fr 1fr;gap:56px 64px}
.ecard .imgph{aspect-ratio:1.2/1;border-radius:8px;border-top-left-radius:46% 24%;border-top-right-radius:46% 24%}
.ecard h3{font-size:30px;margin:22px 0 6px}
.ecard p{color:var(--taupe);font-size:14.5px}

/* corporate */
.chero{padding:200px 0 90px;text-align:center}
.chero .eyebrow{display:block;margin-bottom:18px}.chero h1{font-size:clamp(40px,6.4vw,82px);line-height:1.02}
.chero h1 em{color:var(--gold)}
.chero p{max-width:580px;margin:22px auto 34px;color:var(--taupe);font-size:15.5px}
.cband{padding:10px 32px 0}.cband .imgph{aspect-ratio:2.4/1;border-radius:200px 200px 8px 8px}
.services{padding:110px 32px}.services .head{text-align:center;margin-bottom:54px}.services .head .eyebrow{display:block;margin-bottom:8px}.services .head h2{font-size:clamp(32px,4vw,50px)}
.sgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:rgba(156,123,84,.2);border:1px solid rgba(156,123,84,.2)}
.srv{background:var(--ivory);padding:46px 40px}
.srv h4{font-size:26px;color:var(--espresso)}.srv p{color:var(--taupe);font-size:14.5px;margin-top:10px}

/* contact */
.contact{padding:100px 32px 130px}
.cgrid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px}
.cinfo h4{font-family:'Marcellus';font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--bronze);margin:30px 0 8px}
.cinfo h4:first-child{margin-top:0}.cinfo p{color:var(--taupe);font-size:15px;line-height:1.9}
.cform label{display:block;font-family:'Montserrat';font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--taupe);margin:18px 0 7px}
.cform input,.cform textarea,.cform select{width:100%;background:#fff;border:1px solid rgba(156,123,84,.3);padding:13px 14px;font-family:'Montserrat';font-weight:300;font-size:14px;color:var(--espresso);border-radius:1px;transition:border-color .35s var(--ease)}
.cform input:focus,.cform textarea:focus,.cform select:focus{outline:none;border-color:var(--bronze)}
.cform textarea{resize:vertical;min-height:120px}
.cform select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239C7B54' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;cursor:pointer}
.cform .btn{margin-top:24px;border:none}
.cform .btn:disabled{opacity:.55;cursor:default}
.cform .form-result{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:19px;line-height:1.5;color:var(--sage-deep);margin-top:18px;min-height:1px}
.cform .form-result.error{color:var(--clay)}

/* footer */
footer{background:var(--espresso);color:#e9dfd2;padding:78px 0 34px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:46px}
.fbrand .crest{border-color:rgba(181,154,114,.55);margin-bottom:16px}
.fbrand .crest .cs{color:#fff}.fbrand .crest .cw{color:#b6a89a}
.fbrand p{font-size:13px;color:#b6a89a;margin-top:4px;max-width:280px;line-height:1.85}
.fcol h5{font-family:'Marcellus';font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:#fff;margin-bottom:16px}
.fcol a{display:block;color:#b6a89a;font-size:13px;margin-bottom:10px;cursor:pointer;transition:.3s}.fcol a:hover{color:var(--champagne)}
.fnews input{width:100%;background:transparent;border:1px solid #5a4d44;color:#e9dfd2;padding:12px 13px;font-family:'Montserrat';font-size:12px;margin-bottom:11px;border-radius:1px}
.fnews input::placeholder{color:#8a7c6f}
.fbottom{display:flex;justify-content:space-between;border-top:1px solid #4a3f37;margin-top:54px;padding-top:20px;font-size:11px;letter-spacing:.12em;color:#8a7c6f;text-transform:uppercase}

/* reveal */
.reveal{opacity:0;transform:translateY(24px);transition:1s cubic-bezier(.2,.7,.2,1)}.reveal.in{opacity:1;transform:none}
@media print, (prefers-reduced-motion: reduce){.reveal{opacity:1 !important;transform:none !important}}

@media(max-width:980px){
 .nav-links{display:none}
 .nav-toggle{display:flex}
 nav{padding:14px 22px}
 nav.scrolled{padding:11px 22px}
 .crest{padding:9px 18px 8px;gap:6px}
 .wrap{padding:0 22px}

 /* hero — brand copy first, art below; tighter to the header */
 .hero{grid-template-columns:1fr;min-height:auto;padding:104px 24px 60px;text-align:center;gap:34px}
 .hero-copy{justify-self:center;order:1;margin-top:0;max-width:none}
 .hero-copy .eyebrow{margin-left:auto;margin-right:auto}
 .hero-sig{width:min(280px,72vw);margin:6px auto 2px}
 .hero-word{margin:6px auto 0}
 .hero-line{margin:22px auto 28px}
 .hero-art{justify-self:center;order:2}
 .hero-art .archframe{width:min(360px,80vw)}
 .scrollcue{display:none}

 .story{padding:74px 0}
 .story .grid,.mrow,.cgrid,.fgrid,.egrid,.sgrid{grid-template-columns:1fr;gap:44px}
 .community{padding:0 0 74px}
 .commframe{aspect-ratio:1.4/1}
 .pillars{padding:74px 0}.pillars .head{margin-bottom:42px}
 .testi{padding:74px 0}
 .quote{padding:80px 24px}
 .cta{padding:84px 24px}
 .movement{padding:80px 24px;gap:60px}
 .mrow.rev .imgph{order:0}.trio,.tiers,.tgrid{grid-template-columns:1fr;gap:40px}
 .member{padding:74px 0}
 .founding{padding:40px 0 6px}.founding-card{padding:34px 26px}
 .tier.feature{transform:none}.fbottom{flex-direction:column;gap:10px}
 .founding-grid{grid-template-columns:1fr;gap:24px}.founding-price{border-right:none;border-bottom:1px solid rgba(255,255,255,.14);padding-right:0;padding-bottom:24px}
 .exp{padding:74px 24px}
 .phero{padding:128px 0 60px}
 .chero{padding:128px 0 60px}
 .cband{padding:6px 24px 0}
 .services{padding:74px 24px}.services .head{margin-bottom:42px}
 .contact{padding:64px 24px 92px}
 footer{padding:60px 0 30px}
}

@media(max-width:560px){
 .hero{padding:96px 20px 52px}
 .hero-art .archframe{width:min(320px,82vw)}
 .story .story-txt h2{font-size:clamp(34px,9vw,46px)}
 .testi blockquote{padding:28px 24px;font-size:18px}
 .founding-card{padding:28px 22px}
 .fp .amt{font-size:54px}
 .mobile-menu a{font-size:26px}
}
