/* =========================================================
   ROTA — Stay In Motion
   Shared stylesheet for the production site
   Palette + type from the ROTA Branding Guide (Spring 2026)
   ========================================================= */

:root{
  --charcoal:#181a1c;
  --charcoal-2:#101113;
  --charcoal-3:#1d2023;
  --quill:#d8d3cf;
  --quill-dim:#b3aea9;
  --cloudy:#6a6a6a;
  --almond:#8e7a6e;
  --almond-soft:#a7958a;
  --line:#2a2d30;
  --line-soft:#23262a;
  --bone:#e7e3df;
  --font:"Montserrat","Gotham",system-ui,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
  --maxw:1320px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font);
  background:var(--charcoal);
  color:var(--quill);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  line-height:1.5;
}
body.no-scroll{overflow:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit}
.photo{filter:grayscale(1) contrast(1.05) brightness(.98)}

/* ---------- layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 3rem}
@media(max-width:760px){.wrap{padding:0 1.3rem}}
.section{padding:7rem 0}
.center{text-align:center}
.muted{color:var(--cloudy)}

.eyebrow{font-weight:700;letter-spacing:.34em;text-transform:uppercase;font-size:.66rem;color:var(--cloudy);display:inline-flex;align-items:center}
.eyebrow .dot{display:inline-block;width:5px;height:5px;background:var(--almond);border-radius:50%;margin-right:.6em;flex:none}
.eyebrow.center{justify-content:center}

h1,h2,h3,h4{font-weight:900;letter-spacing:.01em;line-height:1.04}
h2.disp{font-weight:900;line-height:1.04;font-size:clamp(2rem,4.6vw,3.6rem)}
.lead{font-weight:500}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.6em;border:1px solid var(--quill);color:var(--quill);padding:.95rem 2.4rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;font-size:.7rem;transition:.25s var(--ease);cursor:pointer;background:transparent;line-height:1}
.btn:hover{background:var(--quill);color:var(--charcoal)}
.btn.solid{background:var(--quill);color:var(--charcoal)}
.btn.solid:hover{background:transparent;color:var(--quill)}
.btn.dark{border-color:var(--charcoal);color:var(--charcoal)}
.btn.dark:hover{background:var(--charcoal);color:var(--quill)}
.btn.solid.dark{background:var(--charcoal);color:var(--quill)}
.btn.solid.dark:hover{background:transparent;color:var(--charcoal)}
.btn.full{width:100%}
.btn[disabled]{opacity:.4;cursor:not-allowed}
.tlink{display:inline-block;font-weight:700;letter-spacing:.2em;text-transform:uppercase;font-size:.7rem;border-bottom:1px solid var(--almond);padding-bottom:3px;transition:.2s}
.tlink:hover{color:#fff;border-color:var(--quill)}

/* =========================================================
   NAV
   ========================================================= */
nav.site{position:fixed;top:0;left:0;right:0;z-index:60;transition:.3s var(--ease);border-bottom:1px solid transparent}
nav.site .row{display:flex;align-items:center;justify-content:space-between;padding:.15rem 3rem;gap:1.5rem}
nav.site.scrolled{background:rgba(16,17,19,.92);backdrop-filter:blur(10px);border-bottom-color:var(--line)}
nav.site .brand{display:flex;align-items:center;gap:0.7rem}
nav.site .brand-mark{height:44px;width:auto;transition:height .3s var(--ease);filter:brightness(0) invert(1) opacity(.88)}
nav.site.scrolled .brand-mark{height:36px}
nav.site .brand-word{height:58px;width:auto;filter:brightness(0) invert(1) opacity(.88);transition:height .3s var(--ease)}
nav.site.scrolled .brand-word{height:50px}
nav.site .links{display:flex;gap:2.2rem;font-weight:600;letter-spacing:.15em;font-size:.72rem;text-transform:uppercase}
nav.site .links a{opacity:.85;transition:.2s;position:relative;padding:.2rem 0}
nav.site .links a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1px;background:var(--almond);transition:right .25s var(--ease)}
nav.site .links a:hover{opacity:1}
nav.site .links a:hover::after,nav.site .links a.active::after{right:0}
nav.site .util{display:flex;gap:1.3rem;align-items:center;font-size:.72rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase}
nav.site .util a,nav.site .util button{opacity:.85;transition:.2s;background:none;border:0;color:inherit;cursor:pointer;letter-spacing:inherit;font-weight:inherit;text-transform:inherit;font-size:inherit}
nav.site .util a:hover,nav.site .util button:hover{opacity:1}
.cart-count{color:var(--almond)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:.4rem}
.burger span{display:block;width:24px;height:2px;background:var(--quill);transition:.3s var(--ease)}
@media(max-width:980px){
  nav.site .links{display:none}
  nav.site .row{padding:.3rem 1.3rem}
  nav.site .brand-mark{height:36px}
  nav.site.scrolled .brand-mark{height:32px}
  nav.site .brand-word{height:16px}
  nav.site.scrolled .brand-word{height:14px}
  .burger{display:flex}
  .util .search-link{display:none}
}

/* mobile drawer menu */
.mobile-menu{position:fixed;inset:0;z-index:70;background:var(--charcoal-2);transform:translateX(100%);transition:transform .4s var(--ease);display:flex;flex-direction:column;padding:1.3rem}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu .mhead{display:flex;justify-content:space-between;align-items:center;margin-bottom:2.5rem}
.mobile-menu .mhead .brand-logo{display:flex;align-items:center;gap:.62rem}
.mobile-menu .mhead .brand-mark{height:36px}
.mobile-menu .mhead .brand-word{height:18px}
.mobile-menu .close{background:none;border:0;color:var(--quill);font-size:1.8rem;cursor:pointer;line-height:1}
.mobile-menu a{font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:1.6rem;padding:.7rem 0;border-bottom:1px solid var(--line);transition:.2s}
.mobile-menu a:hover{color:var(--almond);padding-left:.4rem}
.mobile-menu .mfoot{margin-top:auto;display:flex;gap:1.4rem;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cloudy);padding-top:1.5rem}

/* =========================================================
   CART DRAWER
   ========================================================= */
.overlay{position:fixed;inset:0;background:rgba(8,9,10,.6);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:.3s;z-index:80}
.overlay.show{opacity:1;visibility:visible}
.cart{position:fixed;top:0;right:0;bottom:0;width:min(420px,100%);background:var(--charcoal-2);z-index:90;transform:translateX(100%);transition:transform .4s var(--ease);display:flex;flex-direction:column;border-left:1px solid var(--line)}
.cart.open{transform:translateX(0)}
.cart .chead{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--line)}
.cart .chead h3{font-size:.8rem;letter-spacing:.24em;text-transform:uppercase;font-weight:700}
.cart .chead .close{background:none;border:0;color:var(--quill);font-size:1.5rem;cursor:pointer;line-height:1}
.cart .items{flex:1;overflow-y:auto;padding:1rem 1.5rem}
.cart .empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;gap:1.3rem;color:var(--cloudy)}
.cart .empty .mk{width:64px;opacity:.5}
.citem{display:grid;grid-template-columns:64px 1fr auto;gap:1rem;padding:1.2rem 0;border-bottom:1px solid var(--line-soft)}
.citem img{width:64px;height:80px;object-fit:cover;background:var(--charcoal)}
.citem .ci-name{font-weight:700;font-size:.84rem}
.citem .ci-meta{color:var(--cloudy);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;margin-top:.35rem}
.citem .qty{display:inline-flex;align-items:center;gap:.7rem;margin-top:.7rem;border:1px solid var(--line);padding:.25rem .6rem}
.citem .qty button{background:none;border:0;color:var(--quill);cursor:pointer;font-size:.95rem;line-height:1}
.citem .qty span{font-size:.78rem;min-width:1ch;text-align:center}
.citem .ci-right{display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between}
.citem .ci-price{font-weight:700;font-size:.84rem}
.citem .remove{background:none;border:0;color:var(--cloudy);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:.2s}
.citem .remove:hover{color:var(--almond)}
.cart .cfoot{padding:1.5rem;border-top:1px solid var(--line)}
.cart .crow{display:flex;justify-content:space-between;font-size:.78rem;letter-spacing:.06em;margin-bottom:.6rem;color:var(--cloudy)}
.cart .crow.total{color:var(--quill);font-weight:700;font-size:.95rem;letter-spacing:.02em;margin:1rem 0 1.3rem;padding-top:1rem;border-top:1px solid var(--line)}
.cart .note{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cloudy);text-align:center;margin-top:1rem}

/* toast */
.toast{position:fixed;bottom:1.6rem;left:50%;transform:translate(-50%,140%);background:var(--quill);color:var(--charcoal);padding:.9rem 1.6rem;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;z-index:100;transition:transform .4s var(--ease);white-space:nowrap}
.toast.show{transform:translate(-50%,0)}

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;background:var(--charcoal-2);padding:1rem 0}
.marquee .track{display:flex;gap:3rem;white-space:nowrap;animation:scroll 28s linear infinite;font-weight:800;letter-spacing:.28em;text-transform:uppercase;font-size:.8rem;color:var(--cloudy);width:max-content}
.marquee .track span b{color:var(--quill);font-weight:800}
.marquee .track span i{color:var(--almond);font-style:normal;margin:0 1.4rem}
@keyframes scroll{to{transform:translateX(-50%)}}

/* =========================================================
   FOOTER
   ========================================================= */
footer.site{border-top:1px solid var(--line);padding:5rem 0 2.5rem;background:var(--charcoal-2)}
footer.site .top{display:flex;justify-content:space-between;gap:3rem;flex-wrap:wrap;margin-bottom:4rem}
footer.site .brand{max-width:22rem}
footer.site .brand .brand-logo{display:flex;align-items:center;gap:.7rem;margin-bottom:1.1rem}
footer.site .brand .brand-mark{height:40px}
footer.site .brand .brand-word{height:54px}
footer.site .brand .eyebrow{color:var(--almond);margin-bottom:1rem}
footer.site .brand p{color:var(--cloudy);font-size:.82rem;max-width:32ch}
footer.site .cols{display:flex;gap:4rem;flex-wrap:wrap}
footer.site .cols .col{display:flex;flex-direction:column;gap:.8rem;font-size:.8rem;color:var(--cloudy)}
footer.site .cols .col a{transition:.2s}
footer.site .cols .col h4{color:var(--quill);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:.4rem;font-weight:700}
footer.site .cols .col a:hover{color:var(--quill)}
footer.site .legal{display:flex;justify-content:spaitce-between;border-top:1px solid var(--line);padding-top:1.8rem;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cloudy);flex-wrap:wrap;gap:1rem}
@media(max-width:640px){footer.site .top{flex-direction:column;gap:2.5rem}footer.site .cols{gap:2.5rem}}

/* =========================================================
   COLLECTION / PRODUCT GRID  (shared by home + shop)
   ========================================================= */
.collection .head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;flex-wrap:wrap;gap:1rem}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.grid.cols4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--charcoal);position:relative;transition:.3s;display:block;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.card:hover{background:var(--charcoal-2)}
.card .pic{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.card .pic img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.card .pic img.padded{object-fit:contain}
.card:hover .pic img{transform:scale(1.05)}
.card .tag{position:absolute;top:.9rem;left:.9rem;background:var(--almond);color:var(--charcoal);font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;font-weight:800;padding:.3rem .55rem;z-index:2}
.card .pic .mark-ph{width:46%;opacity:.16}
.card .quick{position:absolute;left:0;right:0;bottom:0;background:var(--quill);color:var(--charcoal);text-align:center;padding:.85rem;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;font-weight:800;transform:translateY(100%);transition:.3s var(--ease)}
.card:hover .quick{transform:translateY(0)}
.card-prev,.card-next{position:absolute;top:50%;transform:translateY(-50%);z-index:3;background:rgba(16,17,19,.65);border:0;color:var(--quill);width:32px;height:40px;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}
.card-prev{left:0}
.card-next{right:0}
.card:hover .card-prev,.card:hover .card-next{opacity:1}
.card-prev:hover,.card-next:hover{background:rgba(16,17,19,.9)}
.card .meta{display:flex;justify-content:space-between;align-items:baseline;padding:1.2rem 1.4rem 1.6rem;border-top:1px solid var(--line)}
.card .meta .n{font-weight:700;font-size:.92rem;letter-spacing:.02em}
.card .meta .n small{display:block;color:var(--cloudy);font-weight:500;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;margin-top:.3rem}
.card .meta .pr{font-weight:700;font-size:.92rem;white-space:nowrap}
.card .meta .pr::before{content:"";display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--almond);margin:0 .5em .14em 0}
@media(max-width:980px){.grid.cols4{grid-template-columns:repeat(3,1fr)}}
@media(max-width:860px){.grid,.grid.cols4{grid-template-columns:repeat(2,1fr)}.card .quick{transform:translateY(0)}}
@media(max-width:520px){.grid,.grid.cols4{grid-template-columns:1fr}}

/* shop filter bar */
.shop-bar{display:flex;justify-content:space-between;align-items:center;gap:1.2rem;flex-wrap:wrap;margin-bottom:2.6rem;border-bottom:1px solid var(--line);padding-bottom:1.4rem}
.filters{display:flex;gap:.5rem;flex-wrap:wrap}
.filters button{background:transparent;border:1px solid var(--line);color:var(--cloudy);padding:.6rem 1.2rem;font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;cursor:pointer;transition:.2s}
.filters button:hover{color:var(--quill);border-color:var(--cloudy)}
.filters button.active{background:var(--quill);color:var(--charcoal);border-color:var(--quill)}
.sortwrap{display:flex;align-items:center;gap:.7rem;font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cloudy)}
.sortwrap select{background:var(--charcoal-2);color:var(--quill);border:1px solid var(--line);padding:.55rem .8rem;font-family:inherit;font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer}

/* =========================================================
   PAGE HEADER (shop / about / journal)
   ========================================================= */
.page-head{padding:9rem 0 3.5rem;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.page-head .mark-bg{position:absolute;top:50%;right:-4%;transform:translateY(-50%);width:min(380px,42%);opacity:.045;pointer-events:none}
.page-head h1{font-size:clamp(2.4rem,6vw,5rem);font-weight:900;line-height:.95;margin-top:1rem}
.page-head p{color:var(--cloudy);max-width:46ch;margin-top:1.4rem;font-size:.95rem}
.breadcrumb{font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cloudy);margin-bottom:.4rem}
.breadcrumb a:hover{color:var(--quill)}
.breadcrumb span{color:var(--almond)}

/* =========================================================
   PRODUCT DETAIL (PDP)
   ========================================================= */
.pdp{display:grid;grid-template-columns:1.05fr .95fr;gap:0;padding-top:6.5rem}
.pdp .gallery{background:var(--bone);position:sticky;top:0;align-self:start;height:100vh;display:flex;flex-direction:column}
.pdp .gallery .main{flex:1;overflow:hidden}
.pdp .gallery .main img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.pdp .gallery .thumbs{display:flex;gap:.6rem;padding:0 2rem 2rem;justify-content:center}
.pdp .gallery .thumbs button{width:64px;height:64px;border:1px solid rgba(24,26,28,.2);background:#dcd7d2;cursor:pointer;padding:0;overflow:hidden;transition:.2s}
.pdp .gallery .thumbs button.active{border-color:var(--charcoal)}
.pdp .gallery .thumbs img{width:100%;height:100%;object-fit:cover;object-position:center top}
.pdp .info{padding:4rem 5rem;display:flex;flex-direction:column}
.pdp .info .crumb{font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cloudy);margin-bottom:1.6rem}
.pdp .info .crumb a:hover{color:var(--quill)}
.pdp .info h1{font-size:clamp(1.8rem,3.4vw,2.6rem);font-weight:900;line-height:1.02}
.pdp .info .price{font-size:1.35rem;font-weight:700;margin:1rem 0 .4rem}
.pdp .info .price::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--almond);margin:0 .55em .2em 0}
.pdp .info .rating{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cloudy);margin-bottom:2rem}
.pdp .info .rating b{color:var(--almond)}
.opt-label{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cloudy);margin-bottom:.8rem;display:block}
.opt-label b{color:var(--quill);margin-left:.4em}
.swatches{display:flex;gap:.6rem;margin-bottom:2rem}
.swatches button{width:34px;height:34px;border:1px solid var(--line);cursor:pointer;position:relative;transition:.2s}
.swatches button.active{outline:1px solid var(--quill);outline-offset:2px;border-color:transparent}
.sizes{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2.2rem}
.sizes button{min-width:50px;padding:.7rem .9rem;background:transparent;border:1px solid var(--line);color:var(--quill);font-size:.72rem;font-weight:700;letter-spacing:.08em;cursor:pointer;transition:.2s}
.sizes button:hover{border-color:var(--cloudy)}
.sizes button.active{background:var(--quill);color:var(--charcoal);border-color:var(--quill)}
.pdp .accordion{border-top:1px solid var(--line);margin-top:2.4rem}
.acc-item{border-bottom:1px solid var(--line)}
.acc-item button{width:100%;display:flex;justify-content:space-between;align-items:center;background:none;border:0;color:var(--quill);padding:1.2rem 0;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;cursor:pointer}
.acc-item .acc-body{max-height:0;overflow:hidden;transition:max-height .35s var(--ease);color:var(--cloudy);font-size:.86rem;line-height:1.7}
.acc-item .acc-body p{padding-bottom:1.3rem}
.acc-item.open .acc-body{max-height:280px}
.acc-item button .ic{transition:.3s var(--ease)}
.acc-item.open button .ic{transform:rotate(45deg)}
@media(max-width:900px){
  .pdp{grid-template-columns:1fr;padding-top:5.5rem}
  .pdp .gallery{position:static;height:auto;min-height:60vh}
  .pdp .info{padding:3rem 1.3rem}
}

/* =========================================================
   CREED / EDITORIAL / PHASES / APP / JOIN
   (used across home + about)
   ========================================================= */
.creed{position:relative;text-align:center;padding:9rem 0;overflow:hidden}
.creed .mark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(560px,80%);opacity:.05;z-index:0}
.creed .inner{position:relative;z-index:2;max-width:60rem;margin:0 auto}
.creed h2{font-weight:800;font-size:clamp(1.7rem,3.6vw,2.9rem);line-height:1.22;margin-top:1.6rem;letter-spacing:.005em}
.creed h2 em{font-style:normal;color:var(--quill);border-bottom:2px solid var(--almond);padding-bottom:2px}
.creed h3{line-height:1.6}

.edit{display:grid;grid-template-columns:1fr 1fr;background:var(--bone);color:var(--charcoal)}
.edit.flip .img{order:2}
.edit .img{position:relative;min-height:88vh;background:var(--bone)}
.edit .img img{width:100%;height:100%;object-fit:contain;object-position:center;padding:2rem}
.edit .img.cover img{object-fit:cover;padding:0}
.edit .copy{display:flex;flex-direction:column;justify-content:center;padding:5rem}
.edit .copy .eyebrow{color:#7a716a}
.edit .copy h2{margin:1.2rem 0 1.4rem}
.edit .copy p{max-width:42ch;color:#3c3a38;margin-bottom:1.4rem;font-size:1rem}
.edit .copy .cta{margin-top:1rem}
@media(max-width:860px){.edit{grid-template-columns:1fr}.edit.flip .img{order:0}.edit .img{min-height:62vh}.edit .copy{padding:3rem 1.3rem}}

.phases{padding:7rem 0;border-top:1px solid var(--line);text-align:center}
.phases .markrow{display:flex;justify-content:center;margin-bottom:1.4rem}
.phases .markrow img{width:140px;opacity:.9}

/* Wheel mark turns when you engage it (ROTA = the wheel, always in motion).
   Animation is always live but paused, so on hover it resumes from its last
   angle and coasts to a stop in place instead of snapping back to 0. */
/* Spin is driven by JS (initWheels in rota.js): turns forward while hovered, then
   keeps going forward at the same speed to the next upright — it never reverses. */
.wheel-spin{will-change:transform}
.phases .four{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:3.5rem;border-top:1px solid var(--line);text-align:left}
.phases .four .ph{padding:2.6rem 1.6rem;border-right:1px solid var(--line);transition:.3s}
.phases .four .ph:hover{background:var(--charcoal-2)}
.phases .four .ph:last-child{border-right:0}
.phases .four .ph .no{color:var(--almond);font-weight:800;font-size:.7rem;margin-bottom:.9rem;letter-spacing:.2em}
.phases .four .ph .lat{font-weight:800;font-size:1.15rem;letter-spacing:.02em}
.phases .four .ph .tr{color:var(--quill-dim);font-size:.78rem;font-style:italic;margin-top:.3rem}
.phases .four .ph .en{color:var(--cloudy);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;margin-top:.7rem}
.phases .four .ph .desc{color:var(--cloudy);font-size:.82rem;line-height:1.6;margin-top:1rem}
.phases .four .ph .pos{color:var(--cloudy);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;margin-top:.9rem;border-top:1px solid var(--line-soft);padding-top:.7rem}
@media(max-width:760px){.phases .four{grid-template-columns:repeat(2,1fr)}.phases .four .ph:nth-child(2){border-right:0}.phases .four .ph:nth-child(1),.phases .four .ph:nth-child(2){border-bottom:1px solid var(--line)}}
@media(max-width:460px){.phases .four{grid-template-columns:1fr}.phases .four .ph{border-right:0;border-bottom:1px solid var(--line)}}

.app{display:grid;grid-template-columns:1.1fr 1fr;align-items:center;gap:3rem;padding:6rem 0;border-top:1px solid var(--line)}
.app .copy h2{margin:1.2rem 0 1.4rem}
.app .copy p{max-width:38ch;color:var(--cloudy);margin-bottom:2.2rem}
.app .shots{display:flex;gap:1rem;justify-content:center}
.app .shots img{width:48%;border-radius:14px;border:1px solid var(--line)}
@media(max-width:860px){.app{grid-template-columns:1fr;gap:2.4rem}}

.join{position:relative;min-height:80vh;display:flex;align-items:center;overflow:hidden;border-top:1px solid var(--line)}
.join .shot{position:absolute;inset:0;z-index:0}
.join .shot img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.join .shot::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(16,17,19,.95) 30%,rgba(16,17,19,.45))}
.join .inner{position:relative;z-index:2;max-width:34rem}
.join h2{margin:1.2rem 0 1rem}
.join p{color:var(--quill);margin-bottom:2rem;max-width:34ch}
.signup{display:flex;gap:.6rem;flex-wrap:wrap}
.signup input{flex:1;min-width:220px;background:transparent;border:1px solid var(--cloudy);color:var(--quill);padding:.95rem 1.2rem;font-family:var(--font);font-size:.85rem;letter-spacing:.05em}
.signup input::placeholder{color:var(--cloudy)}
.signup input:focus{outline:none;border-color:var(--quill)}
.signup .msg{flex-basis:100%;color:var(--almond);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;margin-top:.4rem}

/* values section header */
.values-head{padding:3.5rem 0 0;text-align:center}
.values-head .eyebrow{justify-content:center}

/* name meaning block */
.name-meaning{border-top:1px solid var(--line);padding:4rem 0;background:var(--charcoal-2)}
.name-meaning .inner{display:grid;grid-template-columns:auto 1fr;gap:5rem;align-items:center;max-width:var(--maxw);margin:0 auto;padding:0 3rem}
.name-meaning .wordmark{font-size:clamp(5rem,13vw,10rem);font-weight:900;letter-spacing:.08em;line-height:1;color:var(--quill);border-right:1px solid var(--line);padding-right:5rem}
.name-meaning .wordmark span{display:block;font-size:.64rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--cloudy);margin-bottom:.9rem}
.name-meaning .def{display:flex;flex-direction:column}
.name-meaning .def .pronunciation{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cloudy);margin-bottom:.8rem}
.name-meaning .def .noun{font-weight:700;color:var(--quill);margin-bottom:1.2rem;font-size:1rem}
.name-meaning .def p{color:var(--quill-dim);font-size:.92rem;line-height:1.75;max-width:54ch;flex:1}
.name-meaning .def p + p{margin-top:1rem}
@media(max-width:760px){.name-meaning .inner{grid-template-columns:1fr;gap:2rem}.name-meaning .wordmark{border-right:0;padding-right:0;border-bottom:1px solid var(--line);padding-bottom:1.5rem}.name-meaning .inner{padding:0 1.3rem}}

/* marquee centered (single-quote variant) */
.marquee.centered .track{animation:none;justify-content:center;white-space:normal;width:100%;padding:0 2rem;text-align:center}

/* =========================================================
   VALUES / FEATURE STRIPS
   ========================================================= */
.values{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.values .v{padding:3rem 2rem;border-right:1px solid var(--line)}
.values .v:last-child{border-right:0}
.values .v .no{color:var(--almond);font-weight:800;letter-spacing:.2em;font-size:.66rem;margin-bottom:1rem}
.values .v h3{font-size:1.2rem;font-weight:800;margin-bottom:.7rem}
.values .v p{color:var(--cloudy);font-size:.85rem;line-height:1.6}
@media(max-width:860px){.values{grid-template-columns:repeat(2,1fr)}.values .v:nth-child(2){border-right:0}.values .v:nth-child(1),.values .v:nth-child(2){border-bottom:1px solid var(--line)}}
@media(max-width:480px){.values{grid-template-columns:1fr}.values .v{border-right:0;border-bottom:1px solid var(--line)}}

.promos{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.promos .p{background:var(--charcoal);padding:2.4rem 2rem;display:flex;flex-direction:column;gap:.6rem}
.promos .p .ic{width:30px;height:30px;color:var(--almond);margin-bottom:.4rem}
.promos .p h4{font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700}
.promos .p p{color:var(--cloudy);font-size:.8rem;line-height:1.55}
@media(max-width:760px){.promos{grid-template-columns:1fr}}

/* about: personas / community */
.personas{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
.persona{background:var(--charcoal-2);padding:2.6rem}
.persona .no{font-size:3rem;font-weight:900;color:var(--line);line-height:1}
.persona h3{font-size:1.4rem;font-weight:800;margin:.4rem 0 1rem}
.persona .who{color:var(--cloudy);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.2rem}
.persona p{color:var(--quill-dim);font-size:.88rem;line-height:1.65}
@media(max-width:760px){.personas{grid-template-columns:1fr}}

/* generic prose block */
.prose{max-width:60rem}
.prose p{color:var(--quill-dim);font-size:1rem;line-height:1.8;margin-bottom:1.4rem}
.prose p strong{color:var(--quill)}

/* journal */
.journal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.jcard{display:block;transition:.3s}
.jcard .jpic{aspect-ratio:4/5;overflow:hidden;background:var(--charcoal-2);margin-bottom:1.2rem}
.jcard .jpic img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.jcard:hover .jpic img{transform:scale(1.05)}
.jcard .jcat{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--almond);font-weight:700}
.jcard h3{font-size:1.15rem;font-weight:800;margin:.7rem 0 .5rem;line-height:1.25}
.jcard p{color:var(--cloudy);font-size:.85rem;line-height:1.6}
.jcard .jdate{color:var(--cloudy);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;margin-top:.9rem}
@media(max-width:860px){.journal-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.journal-grid{grid-template-columns:1fr}}

/* =========================================================
   CHECKOUT
   ========================================================= */
.checkout{display:grid;grid-template-columns:1.15fr .85fr;align-items:start;padding-top:6.5rem;min-height:100vh}
.checkout .form-col{padding:4rem 4.5rem 6rem}
.checkout .sum-col{background:var(--charcoal-2);border-left:1px solid var(--line);padding:4rem 3.5rem 6rem;position:sticky;top:0;min-height:100vh}
.checkout .crumb{font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cloudy);margin-bottom:1.4rem}
.checkout .crumb a:hover{color:var(--quill)}
.checkout h1{font-size:clamp(1.8rem,3.2vw,2.4rem);font-weight:900;margin-bottom:2.6rem}
.co-block{margin-bottom:2.6rem}
.co-block .lbl{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;font-weight:700;color:var(--quill);margin-bottom:1.1rem;display:flex;justify-content:space-between;align-items:baseline}
.co-block .lbl .step{color:var(--almond);font-size:.62rem}
.field{position:relative;margin-bottom:.8rem}
.field input,.field select{width:100%;background:transparent;border:1px solid var(--line);color:var(--quill);padding:1rem 1.1rem;font-family:var(--font);font-size:.86rem;letter-spacing:.02em;transition:.2s}
.field select{appearance:none;cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,var(--cloudy) 50%),linear-gradient(135deg,var(--cloudy) 50%,transparent 50%);background-position:calc(100% - 20px) 50%,calc(100% - 14px) 50%;background-size:6px 6px;background-repeat:no-repeat}
.field input::placeholder{color:var(--cloudy)}
.field input:focus,.field select:focus{outline:none;border-color:var(--quill)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.field-row.three{grid-template-columns:1.4fr 1fr 1fr}
.check{display:flex;align-items:center;gap:.7rem;font-size:.78rem;color:var(--cloudy);margin-top:.6rem;cursor:pointer}
.check input{width:16px;height:16px;accent-color:var(--almond)}
.ship-opt{display:flex;align-items:center;gap:1rem;border:1px solid var(--line);padding:1rem 1.1rem;margin-bottom:.7rem;cursor:pointer;transition:.2s}
.ship-opt:hover{border-color:var(--cloudy)}
.ship-opt.active{border-color:var(--quill);background:rgba(216,211,207,.04)}
.ship-opt input{accent-color:var(--almond)}
.ship-opt .so-main{flex:1}
.ship-opt .so-name{font-size:.82rem;font-weight:600;color:var(--quill)}
.ship-opt .so-sub{font-size:.7rem;color:var(--cloudy);margin-top:.2rem;letter-spacing:.04em}
.ship-opt .so-price{font-weight:700;font-size:.84rem}
.pay-note{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cloudy);margin-top:.9rem;display:flex;align-items:center;gap:.5rem}
.pay-note .lock{width:11px;height:11px;flex:none}

/* order summary */
.sum-col h3{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;font-weight:700;margin-bottom:1.6rem;color:var(--quill)}
.sum-items{border-bottom:1px solid var(--line);padding-bottom:.5rem;margin-bottom:1.4rem}
.sum-item{display:grid;grid-template-columns:56px 1fr auto;gap:1rem;align-items:center;padding:.9rem 0}
.sum-item .si-thumb{position:relative;width:56px;height:70px}
.sum-item img{width:56px;height:70px;object-fit:cover;background:var(--charcoal)}
.sum-item .si-qty{position:absolute;top:-8px;right:-8px;background:var(--cloudy);color:var(--charcoal);font-size:.62rem;font-weight:800;min-width:19px;height:19px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.sum-item .si-name{font-size:.8rem;font-weight:600}
.sum-item .si-meta{font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cloudy);margin-top:.25rem}
.sum-item .si-price{font-size:.82rem;font-weight:700;white-space:nowrap}
.promo{display:flex;gap:.5rem;margin-bottom:1.6rem}
.promo input{flex:1;background:transparent;border:1px solid var(--line);color:var(--quill);padding:.8rem 1rem;font-family:var(--font);font-size:.78rem;letter-spacing:.06em}
.promo input::placeholder{color:var(--cloudy)}
.promo input:focus{outline:none;border-color:var(--quill)}
.promo button{border:1px solid var(--line);background:transparent;color:var(--quill);padding:0 1.2rem;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;cursor:pointer;transition:.2s}
.promo button:hover{background:var(--quill);color:var(--charcoal)}
.sum-row{display:flex;justify-content:space-between;font-size:.82rem;color:var(--cloudy);margin-bottom:.7rem}
.sum-row.grand{color:var(--quill);font-weight:800;font-size:1.15rem;border-top:1px solid var(--line);padding-top:1.2rem;margin:1.2rem 0 1.6rem}
.sum-row.grand .cur{font-size:.66rem;color:var(--cloudy);font-weight:600;margin-right:.5em;letter-spacing:.1em}

/* confirmation */
.co-confirm{max-width:560px;margin:0 auto;text-align:center;padding:7rem 1.3rem 9rem}
.co-confirm .tick{width:64px;height:64px;border:2px solid var(--almond);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.8rem;color:var(--almond)}
.co-confirm .eyebrow{justify-content:center;margin-bottom:1rem}
.co-confirm h1{font-size:clamp(2rem,5vw,3.4rem);font-weight:900;margin-bottom:1.2rem}
.co-confirm p.sub{color:var(--cloudy);margin-bottom:2.6rem}
.co-receipt{border:1px solid var(--line);background:var(--charcoal-2);text-align:left;padding:2rem;margin-bottom:2.4rem}
.co-receipt .rrow{display:flex;justify-content:space-between;padding:.7rem 0;border-bottom:1px solid var(--line-soft);font-size:.82rem}
.co-receipt .rrow:last-child{border-bottom:0}
.co-receipt .rrow .k{color:var(--cloudy);letter-spacing:.08em;text-transform:uppercase;font-size:.66rem}
.co-receipt .rrow .v{color:var(--quill);font-weight:700}
@media(max-width:900px){
  .checkout{grid-template-columns:1fr;padding-top:5.5rem}
  .checkout .form-col{padding:2.5rem 1.3rem;order:2}
  .checkout .sum-col{position:static;min-height:0;order:1;padding:2.5rem 1.3rem;border-left:0;border-bottom:1px solid var(--line)}
}

/* utilities */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.marquee .track{animation:none}}
