:root{
    --paper:#ffffff;--paper-2:#f2f1ee;--ink:#0a0a0a;--ink-2:#171717;
    --grey:#6f6f6c;--grey-soft:#a4a3a0;
    --line:rgba(10,10,10,0.13);--line-soft:rgba(10,10,10,0.07);
    --line-w:rgba(255,255,255,0.16);
    --display:"Playfair Display",Georgia,serif;--sans:"Jost","Helvetica Neue",Arial,sans-serif;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{background:var(--paper);color:var(--ink);font-family:var(--sans);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:1240px;margin:0 auto;padding:0 clamp(20px,5vw,64px)}
  body::after{content:"";position:fixed;inset:0;z-index:400;pointer-events:none;opacity:0.035;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

  .eyebrow{font-family:var(--sans);font-size:0.68rem;font-weight:600;letter-spacing:0.3em;text-transform:uppercase;color:var(--ink)}
  .progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--ink);z-index:120;transition:width .1s linear}

  /* buttons */
  .btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:0.7em;overflow:hidden;font-family:var(--sans);font-size:0.72rem;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;padding:1.15em 2.3em;border:1px solid var(--ink);cursor:pointer;will-change:transform}
  .btn s{position:relative;z-index:2;text-decoration:none;transition:color .45s cubic-bezier(.4,0,.1,1)}
  .btn .ar{position:relative;z-index:2;transition:transform .45s cubic-bezier(.4,0,.1,1)}
  .btn::before{content:"";position:absolute;inset:0;z-index:1;transform:translateY(101%);transition:transform .55s cubic-bezier(.4,0,.1,1)}
  .btn:hover::before{transform:translateY(0)}
  .btn:hover .ar{transform:translateX(5px)}
  .btn--solid{background:var(--ink);color:var(--paper)}
  .btn--solid::before{background:var(--paper)}
  .btn--solid:hover s,.btn--solid:hover .ar{color:var(--ink)}
  .btn--ghost{background:transparent;color:var(--ink)}
  .btn--ghost::before{background:var(--ink)}
  .btn--ghost:hover s,.btn--ghost:hover .ar{color:var(--paper)}
  a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--ink);outline-offset:4px}

  html.js .reveal{opacity:0;transform:translateY(34px);transition:opacity 1s ease,transform 1s cubic-bezier(.2,.7,.3,1)}
  html.js .reveal.in{opacity:1;transform:none}

  /* HEADER */
  .header{position:fixed;top:0;left:0;right:0;z-index:90;transform:translateY(-100%);animation:dropIn .9s cubic-bezier(.2,.8,.2,1) .2s forwards}
  @keyframes dropIn{to{transform:translateY(0)}}
  .ticker{background:var(--ink);color:var(--paper);overflow:hidden;transition:height .45s ease,opacity .35s ease;height:38px}
  .ticker .wrap{height:100%;display:flex;align-items:center;justify-content:center;gap:16px}
  .ticker p{font-size:0.65rem;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,.8)}
  .ticker a{font-size:0.65rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--paper);border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:2px}
  .header.scrolled .ticker{height:0;opacity:0}
  .topbar{transition:background .4s,box-shadow .4s,border-color .4s;border-bottom:1px solid transparent}
  .header.scrolled .topbar{background:var(--paper);border-bottom-color:var(--line);box-shadow:0 8px 30px rgba(10,10,10,.05)}
  .nav{display:flex;align-items:center;height:84px;gap:20px}
  .brand{display:inline-flex;align-items:center;gap:13px;flex-shrink:0}
  .brand .logo{width:50px;height:50px;border-radius:50%;background:var(--paper);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}
  .brand .logo img{width:100%;height:100%;object-fit:contain;padding:5px;filter:grayscale(1)}
  .brand .wm{display:flex;flex-direction:column;line-height:1.05}
  .brand .wm b{font-family:var(--display);font-weight:600;font-size:1.06rem;letter-spacing:0.01em}
  .brand .wm small{font-size:0.53rem;font-weight:600;letter-spacing:0.26em;text-transform:uppercase;color:var(--grey);margin-top:4px}
  .menu{display:flex;align-items:center;gap:30px;list-style:none;margin-left:auto}
  .menu>li{position:relative}
  .menu>li>a{font-size:0.78rem;font-weight:500;letter-spacing:0.04em;cursor:pointer;display:inline-flex;align-items:center;gap:6px;padding:12px 0;position:relative}
  .menu>li>a::after{content:"";position:absolute;left:0;bottom:5px;width:0;height:1.5px;background:var(--ink);transition:width .35s cubic-bezier(.4,0,.1,1)}
  .menu>li:hover>a::after{width:100%}
  .actions{display:flex;align-items:center;gap:22px;margin-left:34px;padding-left:34px;border-left:1px solid var(--line)}
  .login{font-size:0.78rem;font-weight:500}
  .actions .btn{padding:0.8em 1.7em;font-size:0.66rem}
  .burger{display:none;background:none;border:none;cursor:pointer;width:28px;height:18px;position:relative;color:var(--ink);margin-left:auto}
  .burger span{position:absolute;left:0;right:0;height:1.8px;background:currentColor;transition:.3s}
  .burger span:nth-child(1){top:0}.burger span:nth-child(2){top:8px}.burger span:nth-child(3){top:16px}
  .mobile{display:none;background:var(--paper);border-top:1px solid var(--line);max-height:78vh;overflow:auto}
  .mobile.open{display:block}
  .mobile a{display:block;padding:14px 0;border-bottom:1px solid var(--line-soft);font-size:0.88rem;font-weight:500}

  /* HERO + interactive leaf */
  .hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;padding:160px 0 90px}
  .leafstage{position:absolute;right:-22px;top:50%;width:min(710px,58vw);z-index:0;perspective:1200px;pointer-events:auto}
  .leaf{position:relative;transform:translateY(-50%);transform-style:preserve-3d;will-change:transform;--mx:55%;--my:42%;filter:drop-shadow(0 18px 22px rgba(10,10,10,.08));cursor:crosshair}
  .leaf::before{content:"";position:absolute;inset:-8%;z-index:-1;border-radius:50%;opacity:0;transition:opacity .35s ease;background:radial-gradient(circle 150px at var(--mx) var(--my),rgba(10,10,10,.13),rgba(10,10,10,.04) 42%,transparent 72%);transform:translateZ(-90px)}
  .leaf::after{content:"";position:absolute;left:var(--mx);top:var(--my);width:116px;height:116px;border:1px solid rgba(10,10,10,.36);border-radius:50%;opacity:0;transform:translate(-50%,-50%) scale(.58);transition:opacity .25s ease,transform .25s ease;mix-blend-mode:multiply;pointer-events:none}
  .leaf.lit::before{opacity:1}
  .leaf.lit::after{opacity:1;transform:translate(-50%,-50%) scale(1)}
  .leaf svg{width:100%;height:auto;display:block}
  .leaf .bold{position:absolute;inset:0}
  .leaf path{fill:none;vector-effect:non-scaling-stroke;stroke-linecap:round;stroke-linejoin:round}
  .leaf .base .outline{stroke:#b8b8b5;stroke-width:1.25}
  .leaf .base .midrib{stroke:#9c9c99;stroke-width:1.15}
  .leaf .base .primary{stroke:#b4b4b1;stroke-width:.95}
  .leaf .base .secondary{stroke:#c3c3c0;stroke-width:.7}
  .leaf .base .tertiary,.leaf .base .grain,.leaf .base .edgefold{stroke:#d0d0cd;stroke-width:.52}
  .leaf .bold .outline{stroke:var(--ink);stroke-width:1.9}
  .leaf .bold .midrib{stroke:var(--ink);stroke-width:1.7}
  .leaf .bold .primary{stroke:var(--ink);stroke-width:1.25}
  .leaf .bold .secondary{stroke:var(--ink);stroke-width:.95}
  .leaf .bold .tertiary,.leaf .bold .grain,.leaf .bold .edgefold{stroke:var(--ink);stroke-width:.62}
  .leaf .bold{opacity:0;transition:opacity .35s ease;-webkit-mask:radial-gradient(circle 185px at var(--mx,55%) var(--my,42%),#000 0%,#000 42%,transparent 73%);mask:radial-gradient(circle 185px at var(--mx,55%) var(--my,42%),#000 0%,#000 42%,transparent 73%)}
  .leaf.lit .bold{opacity:1}
  .leaf.static{cursor:auto}
  .leaf.static::before,.leaf.static::after{display:none}
  .leaf.static .bold{opacity:.48;-webkit-mask:none;mask:none}
  html.js .leaf path{stroke-dasharray:1;stroke-dashoffset:1;animation:draw 1.9s cubic-bezier(.4,0,.2,1) forwards}
  @keyframes draw{to{stroke-dashoffset:0}}
  .hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(90deg,var(--paper) 28%,rgba(255,255,255,.45) 58%,transparent 100%)}
  .hero .wrap{position:relative;z-index:2;width:100%}
  .hero-eyebrow{display:inline-block;opacity:0;animation:fadeUp 1s ease .4s forwards}
  .hero h1{font-family:var(--display);font-weight:500;font-size:clamp(3rem,8.4vw,7rem);line-height:0.98;letter-spacing:-0.012em;margin:22px 0 0;max-width:14ch}
  .hero h1 .ln{display:block;overflow:hidden}
  .hero h1 .ln span{display:block;transform:translateY(110%)}
  .hero h1 .l1 span{animation:up 1.1s cubic-bezier(.16,.84,.3,1) .6s forwards}
  .hero h1 .l2 span{animation:up 1.1s cubic-bezier(.16,.84,.3,1) .75s forwards;font-style:italic}
  .hero-sub{font-size:clamp(1.05rem,1.5vw,1.24rem);color:var(--grey);max-width:34em;margin:30px 0 0;opacity:0;animation:fadeUp 1s ease 1s forwards}
  .hero-cta{display:flex;gap:18px;flex-wrap:wrap;margin-top:40px;opacity:0;animation:fadeUp 1s ease 1.15s forwards}
  .scroll-cue{position:absolute;left:clamp(20px,5vw,64px);bottom:30px;z-index:2;font-size:0.6rem;font-weight:600;letter-spacing:0.3em;text-transform:uppercase;color:var(--grey-soft);display:flex;align-items:center;gap:12px;opacity:0;animation:fadeUp 1s ease 1.5s forwards}
  .scroll-cue::after{content:"";width:46px;height:1px;background:var(--grey-soft)}
  @media (prefers-reduced-motion:no-preference){.scroll-cue::after{animation:cueX 2s ease-in-out infinite}@keyframes cueX{0%,100%{transform:scaleX(.4);transform-origin:left}50%{transform:scaleX(1);transform-origin:left}}}
  @keyframes up{to{transform:translateY(0)}}
  @keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

  /* MARQUEE */
  .marquee{background:var(--ink);color:var(--paper);padding:20px 0;overflow:hidden;white-space:nowrap}
  .mq-track{display:inline-flex;will-change:transform}
  @media (prefers-reduced-motion:no-preference){.mq-track{animation:scroll 44s linear infinite}@keyframes scroll{to{transform:translateX(-50%)}}}
  .mq-track span{font-family:var(--display);font-style:italic;font-weight:400;font-size:clamp(1.2rem,2.2vw,1.85rem);padding:0 32px;color:rgba(255,255,255,.86)}
  .mq-track i{color:rgba(255,255,255,.4);font-style:normal;align-self:center;font-size:0.7em}

  /* STATEMENT */
  .statement{padding:clamp(70px,9vw,130px) 0;text-align:center}
  .statement .big{font-family:var(--display);font-weight:400;font-size:clamp(1.7rem,3.6vw,3rem);line-height:1.34;max-width:18em;margin:18px auto 0;letter-spacing:-0.005em}
  .statement .big em{font-style:italic}

  /* DIRECTORY */
  .directory{padding:0 0 clamp(64px,8vw,120px)}
  .sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:40px}
  .sec-head h2{font-family:var(--display);font-weight:500;font-size:clamp(2rem,4.2vw,3.2rem);line-height:1.04;margin-top:12px}
  .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
  .card{position:relative;background:var(--paper);padding:40px 32px 30px;min-height:268px;display:flex;flex-direction:column;overflow:hidden;isolation:isolate;will-change:transform}
  .card::before{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .55s cubic-bezier(.4,0,.1,1);z-index:-1}
  .card:hover::before{transform:translateY(0)}
  .card .num{font-family:var(--display);font-style:italic;font-size:1.05rem;color:var(--grey);transition:color .5s}
  .card h3{font-family:var(--display);font-weight:600;font-size:1.5rem;margin:16px 0 10px;transition:color .5s}
  .card p{color:var(--grey);font-size:0.97rem;flex:1;transition:color .5s}
  .card .go{margin-top:20px;font-size:0.68rem;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;display:inline-flex;align-items:center;gap:10px;transition:color .5s}
  .card .go::after{content:"";width:22px;height:1px;background:currentColor;transition:width .4s}
  .card:hover .go::after{width:42px}
  .card:hover .num,.card:hover h3,.card:hover .go{color:var(--paper)}
  .card:hover p{color:rgba(255,255,255,.82)}

  /* NUMBERS */
  .proof{background:var(--ink);color:var(--paper);padding:clamp(66px,8vw,116px) 0}
  .proof .eyebrow{color:rgba(255,255,255,.6);display:block;margin-bottom:44px}
  .stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line-w)}
  .stat{padding:36px 0 0;border-right:1px solid var(--line-w)}
  .stat:last-child{border-right:none}
  .stat .n{font-family:var(--display);font-weight:500;font-size:clamp(2.6rem,6vw,4.4rem);line-height:1}
  .stat .l{font-size:0.7rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,.62);margin-top:16px;max-width:12em}
  .proof-note{margin-top:40px;color:rgba(255,255,255,.82);font-weight:300;font-size:clamp(1.05rem,1.6vw,1.28rem);max-width:38em}

  /* EVENTS */
  .events{padding:clamp(64px,8vw,116px) 0}
  .members-note{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:16px}
  .pill{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--ink);padding:8px 15px;font-size:0.6rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase}
  .pill::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--ink)}
  .members-note .txt{font-size:0.92rem;color:var(--grey)}
  .members-note .txt a{color:var(--ink);font-weight:600;border-bottom:1px solid var(--ink);padding-bottom:1px}
  .sched{border-top:1px solid var(--line);margin-top:34px}
  .srow{display:grid;grid-template-columns:130px 1fr auto auto;gap:24px;align-items:center;padding:22px 0;border-bottom:1px solid var(--line);transition:padding-left .35s}
  .srow:hover{padding-left:14px}
  .srow .d{font-family:var(--display);font-style:italic;font-size:1.12rem}
  .srow .t{font-weight:500}
  .srow .c{font-size:0.7rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--grey)}
  .srow a{font-size:0.66rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;border-bottom:1px solid var(--ink);padding-bottom:3px}
  @media(max-width:680px){.srow{grid-template-columns:1fr;gap:5px}.srow a{justify-self:start;margin-top:8px}}

  /* MEMBERSHIP */
  .cta{background:var(--paper-2);text-align:center;padding:clamp(72px,10vw,140px) 0}
  .cta .eyebrow{display:block;margin-bottom:24px}
  .cta h2{font-family:var(--display);font-weight:500;font-size:clamp(2.5rem,7vw,5.2rem);line-height:1.0;letter-spacing:-0.01em}
  .cta h2 em{font-style:italic}
  .cta p{color:var(--grey);font-size:clamp(1.05rem,1.6vw,1.26rem);max-width:36em;margin:28px auto 0}
  .cta .btn{margin-top:40px}
  .subscribe{margin:60px auto 0;padding-top:40px;border-top:1px solid var(--line);max-width:480px}
  .subscribe .eyebrow{color:var(--grey);display:block;margin-bottom:16px;font-weight:500}
  .sub-row{display:flex;border:1px solid var(--ink);background:var(--paper)}
  .sub-row input{flex:1;background:transparent;border:none;color:var(--ink);font-family:var(--sans);font-size:1rem;padding:1em 1.2em}
  .sub-row input::placeholder{color:var(--grey-soft)}
  .sub-row button{background:var(--ink);border:none;color:var(--paper);font-family:var(--sans);font-size:0.7rem;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;padding:0 1.6em;cursor:pointer;transition:.3s}
  .sub-row button:hover{letter-spacing:0.22em}
  .sub-msg{font-size:0.85rem;margin-top:14px;min-height:1.1em;font-weight:600}

  /* FOOTER */
  footer{background:var(--ink);color:var(--paper);padding:64px 0 54px}
  .foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:34px}
  .foot-brand .fb{display:flex;align-items:center;gap:12px}
  .foot-brand .fb .logo{width:44px;height:44px;border-radius:50%;background:var(--paper);display:flex;align-items:center;justify-content:center;overflow:hidden}
  .foot-brand .fb .logo img{width:100%;height:100%;object-fit:contain;padding:5px;filter:grayscale(1)}
  .foot-brand .fb b{font-family:var(--display);font-weight:600;font-size:1.12rem}
  .foot-brand p{color:rgba(255,255,255,.66);font-weight:300;font-size:0.94rem;margin-top:16px;max-width:25em}
  .foot-col h4{font-size:0.64rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:16px}
  .foot-col a{display:block;color:rgba(255,255,255,.8);font-weight:400;font-size:0.92rem;padding:6px 0;transition:.2s}
  .foot-col a:hover{color:var(--paper);padding-left:6px}
  .foot-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px;margin-top:50px;padding-top:26px;border-top:1px solid var(--line-w)}
  .foot-bottom span{font-size:0.66rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,.5)}
  .socials{display:flex;gap:22px}
  .socials a{font-size:0.68rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,.8)}
  .socials a:hover{color:var(--paper)}

  @media (max-width:1100px){.menu,.actions .login{display:none}.actions{margin-left:auto;border:none;padding:0}.burger{display:block;margin-left:18px}.grid{grid-template-columns:1fr 1fr}.foot-top{grid-template-columns:1fr 1fr}.leafstage{opacity:.2;right:-120px}.hero::after{background:linear-gradient(180deg,rgba(255,255,255,.25),var(--paper) 70%)}}
  @media (max-width:760px){.actions .btn{display:none}.stats{grid-template-columns:1fr 1fr}.stat{border-right:none;border-bottom:1px solid var(--line-w);padding-bottom:28px}.stat:nth-child(odd){border-right:1px solid var(--line-w)}.foot-top{grid-template-columns:1fr}.brand .wm small{display:none}}
  @media (max-width:480px){.grid{grid-template-columns:1fr}.stats{grid-template-columns:1fr}.stat:nth-child(odd){border-right:none}}
  @media (prefers-reduced-motion:reduce){.header,.hero-eyebrow,.hero h1 .ln span,.hero-sub,.hero-cta,.scroll-cue{animation:none!important;opacity:1!important;transform:none!important}.hero h1 .ln span{transform:none!important}html.js .leaf path{animation:none!important;stroke-dashoffset:0!important}}
/* shared subpage system aligned to the new homepage */
.menu>li.active>a::after{width:100%}
.menu>li.active>a{font-weight:600}
.btn--dark{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn--dark::before{background:var(--paper)}
.btn--dark:hover s,.btn--dark:hover .ar{color:var(--ink)}
.btn--line{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--line::before{background:var(--ink)}
.btn--line:hover{border-color:var(--ink)}
.btn--line:hover s,.btn--line:hover .ar{color:var(--paper)}
.dark .btn--ghost{color:var(--paper);border-color:var(--line-w)}
.dark .btn--ghost::before{background:var(--paper)}
.dark .btn--ghost:hover s,.dark .btn--ghost:hover .ar{color:var(--ink)}

.pagehero{position:relative;min-height:70vh;display:flex;align-items:center;overflow:hidden;background:var(--paper);padding:168px 0 88px;text-align:left}
.pagehero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,var(--paper) 18%,rgba(255,255,255,.78) 52%,rgba(255,255,255,.18) 100%)}
.pagehero .wrap{position:relative;z-index:3;width:100%}
.crumb{font-size:0.62rem;font-weight:700;letter-spacing:0.24em;text-transform:uppercase;color:var(--grey);opacity:0;animation:fadeUp 1s ease .35s forwards}
.crumb a{border-bottom:1px solid var(--line);padding-bottom:2px}
.pagehero h1{font-family:var(--display);font-weight:500;font-size:clamp(3.2rem,9vw,7.4rem);line-height:.98;letter-spacing:-.014em;margin:22px 0 0;max-width:11ch;opacity:0;animation:fadeUp 1s ease .5s forwards}
.pagehero h1 em{font-style:italic}
.pagehero p{font-size:clamp(1.05rem,1.5vw,1.25rem);color:var(--grey);max-width:36em;margin:28px 0 0;opacity:0;animation:fadeUp 1s ease .68s forwards}
.rule{width:72px;height:1px;background:var(--ink);margin-top:34px;transform-origin:left;transform:scaleX(0);animation:ruleIn .9s cubic-bezier(.2,.8,.2,1) .85s forwards}
@keyframes ruleIn{to{transform:scaleX(1)}}
.leafmark{position:absolute;right:-90px;top:50%;width:min(620px,55vw);z-index:0;transform:translateY(-50%) rotate(-4deg);opacity:.32;pointer-events:none}
.leafmark svg{width:100%;height:auto;display:block}
.leafmark path{fill:none;stroke:var(--ink);stroke-linecap:round;stroke-width:1;vector-effect:non-scaling-stroke}
.leafmark path.outline,.leafmark path.midrib{stroke-width:1.35}
.leafmark path.grain,.leafmark path.tertiary{opacity:.55;stroke-width:.65}

.section{padding:clamp(68px,8vw,118px) 0}
.light{background:var(--paper);color:var(--ink)}
.dark{background:var(--ink);color:var(--paper)}
.dark .eyebrow{color:rgba(255,255,255,.62)}
.dark .sec-head .eyebrow{color:rgba(255,255,255,.62)}
.dark .sec-head h2{color:var(--paper)}
.two{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(32px,6vw,88px);align-items:start}
.lead{font-family:var(--display);font-weight:400;font-size:clamp(1.55rem,3vw,2.45rem);line-height:1.35;max-width:24em;margin-top:16px}
.prose{max-width:44em}
.prose p{color:var(--grey);font-size:clamp(1rem,1.35vw,1.13rem);font-weight:300;margin-top:1.25em}
.dark .prose p{color:rgba(255,255,255,.72)}

.flist{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
.dark .flist{background:var(--line-w);border-color:var(--line-w)}
.fitem{background:var(--paper);padding:38px 32px;min-height:208px}
.dark .fitem{background:var(--ink)}
.fitem .k{font-family:var(--display);font-style:italic;font-size:1.02rem;color:var(--grey)}
.dark .fitem .k{color:rgba(255,255,255,.55)}
.fitem h4{font-family:var(--display);font-weight:500;font-size:1.45rem;margin:14px 0 10px}
.fitem p{color:var(--grey);font-size:.98rem;font-weight:300}
.dark .fitem p{color:rgba(255,255,255,.72)}
.pill{display:inline-flex;align-items:center;gap:9px;border:1px solid var(--ink);padding:8px 15px;font-size:.62rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;white-space:nowrap}
.pill::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--ink)}

.buttonstack{margin-top:26px;display:flex;flex-direction:column;align-items:flex-start;gap:14px}
.form{margin-top:24px;display:grid;gap:16px}
.field{display:grid;gap:8px}
.field label{font-size:.62rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--grey)}
.field input,.field textarea{width:100%;border:1px solid var(--line);background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:1rem;padding:1rem 1.05rem;outline:none}
.field textarea{min-height:150px;resize:vertical}
.field input:focus,.field textarea:focus{border-color:var(--ink)}
.formmsg{min-height:1.2em;color:var(--ink);font-size:.92rem;font-weight:600}

.atlas{position:relative;min-height:440px;border:1px solid var(--line);background:var(--paper-2);overflow:hidden;padding:clamp(28px,5vw,56px)}
.atlas .dots{position:absolute;inset:0;opacity:.65;background-image:radial-gradient(rgba(10,10,10,.18) 1px,transparent 1.4px);background-size:26px 26px;-webkit-mask-image:radial-gradient(90% 90% at 50% 46%,#000 40%,transparent 80%);mask-image:radial-gradient(90% 90% at 50% 46%,#000 40%,transparent 80%)}
.pins{position:relative;display:flex;flex-wrap:wrap;gap:12px;max-width:850px}
.pin{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--ink);background:var(--paper);padding:9px 14px;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;transition:transform .35s ease,background .35s ease,color .35s ease}
.pin::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--ink)}
.pin:hover{transform:translateY(-4px);background:var(--ink);color:var(--paper)}
.pin:hover::before{background:var(--paper)}
.pin.dim{opacity:.52}

.authwrap{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--ink);overflow:hidden;padding:160px 20px 80px}
.authwrap::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 80% at 50% 40%,rgba(255,255,255,.08),transparent 62%);z-index:1}
.authleaf{opacity:.12;right:50%;transform:translate(50%,-50%) rotate(-6deg);width:min(760px,80vw)}
.authcard{position:relative;z-index:2;width:min(460px,100%);background:var(--paper);color:var(--ink);border:1px solid var(--line);padding:42px 34px;text-align:center;box-shadow:0 30px 90px rgba(0,0,0,.28)}
.authcard .logo{width:64px;height:64px;margin:0 auto 20px;border-radius:50%;background:var(--paper);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;overflow:hidden}
.authcard .logo img{width:100%;height:100%;object-fit:contain;padding:6px;filter:grayscale(1)}
.authcard h1{font-family:var(--display);font-size:clamp(2rem,5vw,3rem);font-weight:500;line-height:1}
.authcard .sub{color:var(--grey);margin:12px 0 24px}
.authcard .btn{width:100%;margin-top:8px}
.authrow{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:18px;font-size:.85rem;color:var(--grey);flex-wrap:wrap}
.authrow label{display:flex;align-items:center;gap:8px}
.authrow input{width:auto}
.authrow a,.authfoot a{font-weight:600;border-bottom:1px solid var(--line);padding-bottom:2px;color:var(--ink)}
.authfoot{margin-top:26px;padding-top:22px;border-top:1px solid var(--line);color:var(--grey);font-size:.92rem}

@media (max-width:1100px){
  .pagehero{min-height:62vh}
  .leafmark{right:-150px;opacity:.18;width:min(620px,72vw)}
}
@media (max-width:760px){
  .pagehero{padding:150px 0 70px;text-align:left;min-height:auto}
  .pagehero::after{background:linear-gradient(180deg,rgba(255,255,255,.35),var(--paper) 74%)}
  .pagehero h1{font-size:clamp(3rem,16vw,5.2rem);max-width:9ch}
  .two{grid-template-columns:1fr}
  .flist{grid-template-columns:1fr}
  .sec-head .btn,.sec-head .pill{margin-top:4px}
  .atlas{min-height:360px}
  .pin{font-size:.62rem;padding:8px 11px}
}
@media (max-width:480px){
  .authcard{padding:34px 24px}
  .authrow{justify-content:center}
}

/* login page dark header fix */
.auth-page .header:not(.scrolled){color:var(--paper)}
.auth-page .header:not(.scrolled) .topbar{background:rgba(10,10,10,.82);border-bottom-color:rgba(255,255,255,.14);backdrop-filter:blur(14px)}
.auth-page .header:not(.scrolled) .brand .wm small{color:rgba(255,255,255,.64)}
.auth-page .header:not(.scrolled) .menu>li>a::after{background:var(--paper)}
.auth-page .header:not(.scrolled) .actions{border-left-color:rgba(255,255,255,.16)}
.auth-page .header:not(.scrolled) .login{color:var(--paper)}
.auth-page .header:not(.scrolled) .burger{color:var(--paper)}
.auth-page .header:not(.scrolled) .actions .btn--solid{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.auth-page .header:not(.scrolled) .actions .btn--solid::before{background:transparent}
.auth-page .header:not(.scrolled) .actions .btn--solid:hover s{color:var(--ink)}

/* embedded cigar map */
.map-frame-shell{position:relative;border:1px solid var(--line);background:var(--paper);padding:12px;box-shadow:0 28px 80px rgba(10,10,10,.09);overflow:hidden}
.map-frame-shell::before{content:"";position:absolute;inset:12px;pointer-events:none;z-index:2;border:1px solid rgba(10,10,10,.12)}
.map-frame{position:relative;z-index:1;width:100%;height:min(72vh,720px);min-height:520px;border:0;display:block;filter:grayscale(1) contrast(1.08)}
.map-frame-note{margin-top:18px;color:var(--grey);font-size:.94rem;max-width:58em}
@media(max-width:680px){.map-frame-shell{padding:8px}.map-frame-shell::before{inset:8px}.map-frame{min-height:460px;height:70vh}}

