/* ============================================================
   SZUMSKI ART — TRADITION PAGE STYLES  v2.2 · 2026-06-17
   Shared across all eight sacred geometry tradition pages.
   ============================================================ */

@import '/css/main.css';
@import '/css/nav.css';

:root{
  --gap: clamp(4rem,7vw,6rem);
}

html{scroll-behavior:smooth}
body{background:var(--deep);color:var(--text);font-family:'Cormorant Garamond',Georgia,serif;font-size:19px;line-height:1.82}

/* ── NAV — base styles in /css/nav.css — scroll behaviour here ── */
#sz-nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:1rem 2.5rem;background:rgba(16,12,8,0);backdrop-filter:blur(0);border-bottom:1px solid rgba(74,56,40,0);transition:all 0.4s;gap:1.5rem;overflow:visible}
#sz-nav.scrolled{background:rgba(16,12,8,0.92);backdrop-filter:blur(12px);border-bottom-color:rgba(74,56,40,0.35)}

/* ── HERO ── */
.tradition-hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:8rem 2rem 5rem;position:relative;overflow:hidden}
#hero-canvas-bg{position:absolute;inset:0;width:100%;height:100%;opacity:0.14}
.hero-inner{position:relative;z-index:2;max-width:760px}
.hero-eyebrow{font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.28em;color:var(--rust);text-transform:uppercase;margin-bottom:1.5rem;opacity:0;animation:fadeUp 0.9s 0.2s forwards}
.hero-title{font-size:clamp(3.2rem,8vw,7rem);font-weight:300;color:var(--bone);line-height:0.97;letter-spacing:-0.02em;margin-bottom:1rem;opacity:0;animation:fadeUp 0.9s 0.5s forwards}
.hero-title em{font-style:italic;color:var(--gold);display:block}
.hero-sub{font-size:1.1rem;font-weight:300;color:var(--muted);max-width:500px;margin:0 auto 0;line-height:1.65;opacity:0;animation:fadeUp 0.9s 0.8s forwards}
.hero-scroll{position:absolute;bottom:2.5rem;font-family:'DM Mono',monospace;font-size:0.58rem;letter-spacing:0.22em;color:var(--border);animation:pulse 2.5s ease-in-out infinite}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes pulse{0%,100%{opacity:0.3}50%{opacity:0.8}}

/* ── SECTIONS ── */
.section{max-width:780px;margin:0 auto;padding:var(--gap) 2rem}
.section-wide{max-width:1080px;margin:0 auto;padding:var(--gap) 2rem}
.section-divider{height:1px;background:var(--border);margin:0 2rem;opacity:0.4}

.section-label{font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.25em;color:var(--rust);text-transform:uppercase;margin-bottom:1.75rem;display:flex;align-items:center;gap:1rem}
.section-label::after{content:'';flex:1;height:1px;background:var(--border)}
h2{font-size:clamp(1.9rem,4vw,2.8rem);font-weight:300;color:var(--bone);line-height:1.12;letter-spacing:-0.01em;margin-bottom:1.25rem}
h2 em{font-style:italic;color:var(--gold)}
h3{font-size:1.1rem;font-weight:400;color:var(--bone);margin:2rem 0 0.5rem}
p{color:var(--muted);font-weight:300;line-height:1.78;margin-bottom:1.1rem}
p strong{color:var(--text);font-weight:400}

.pullquote{border-left:2px solid var(--crimson);padding:1rem 0 1rem 1.75rem;margin:2.5rem 0;font-size:1.1rem;font-style:italic;color:var(--text);font-weight:300;line-height:1.6}
.pullquote cite{display:block;margin-top:0.5rem;font-style:normal;font-family:'DM Mono',monospace;font-size:0.62rem;color:var(--dim);letter-spacing:0.08em}

.formula-box{background:rgba(8,6,4,0.8);border:1px solid var(--border);padding:1.25rem 1.75rem;margin:1.75rem 0;font-family:'DM Mono',monospace;font-size:0.82rem;color:var(--gold);letter-spacing:0.03em;line-height:2}
.formula-box .cmt{color:var(--border)}

.math-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0.75rem;margin:1.5rem 0}
.math-card{border:1px solid var(--border);padding:1rem 1.25rem}
.math-card .label{font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.14em;color:var(--rust);text-transform:uppercase;margin-bottom:0.3rem}
.math-card .value{font-size:1.5rem;font-weight:300;color:var(--bone)}
.math-card .desc{font-size:0.75rem;color:var(--muted);margin-top:0.2rem;font-family:'DM Mono',monospace}

/* ── SANDBOX ── */
.sandbox-section{max-width:1100px;margin:0 auto;padding:var(--gap) 2rem;border-top:1px solid var(--border)}
.sandbox-layout{display:grid;grid-template-columns:1fr 320px;gap:2rem;align-items:start}
@media(max-width:820px){.sandbox-layout{grid-template-columns:1fr}}

#main-canvas{width:100%;aspect-ratio:1/1;display:block;background:var(--surface);border:1px solid var(--border)}

/* Zoom controls */
.zoom-bar{margin-top:1rem;background:rgba(8,6,4,0.6);border:1px solid var(--border);padding:1rem 1.25rem}
.zoom-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:0.6rem}
.zoom-label-wrap{}
.zoom-label{font-family:'DM Mono',monospace;font-size:0.6rem;color:var(--rust);letter-spacing:0.1em;text-transform:uppercase}
.zoom-desc{font-size:0.82rem;color:var(--muted);margin-top:0.2rem;font-style:italic;line-height:1.4}
.zoom-btns{display:flex;gap:0.5rem;flex-shrink:0}
.zoom-btn{background:none;border:1px solid var(--border);color:var(--muted);font-family:'DM Mono',monospace;font-size:0.65rem;padding:0.35rem 0.85rem;cursor:pointer;transition:all 0.2s;white-space:nowrap}
.zoom-btn:hover:not(:disabled){border-color:var(--gold);color:var(--gold)}
.zoom-btn:disabled{opacity:0.3;cursor:default}
.zoom-dots{display:flex;gap:6px;margin-top:0.75rem}
.zoom-dot{width:8px;height:8px;border-radius:50%;background:var(--border);cursor:pointer;transition:all 0.2s;flex-shrink:0}
.zoom-dot.active{background:var(--gold);transform:scale(1.3)}

/* Controls panel */
.controls{background:rgba(8,6,4,0.55);border:1px solid var(--border);padding:1.5rem;position:sticky;top:80px;max-height:calc(100vh - 100px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.controls::-webkit-scrollbar{width:3px}
.controls::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
.ctrl-group{margin-bottom:1.4rem}
.ctrl-group:last-child{margin-bottom:0}
.ctrl-label{font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.1em;color:var(--muted);text-transform:uppercase;margin-bottom:0.5rem;display:flex;justify-content:space-between}
.ctrl-label span{color:var(--gold)}
input[type=range]{width:100%;appearance:none;background:var(--border);height:1px;outline:none;cursor:pointer;margin:0.4rem 0}
input[type=range]::-webkit-slider-thumb{appearance:none;width:13px;height:13px;background:var(--bone);border-radius:50%;cursor:pointer}
input[type=range]::-moz-range-thumb{width:13px;height:13px;background:var(--bone);border-radius:50%;border:none;cursor:pointer}
#palette-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:0.35rem;margin-top:0.5rem}
.pal-swatch{aspect-ratio:1;cursor:pointer;border:2px solid transparent;transition:border-color 0.15s}
.pal-swatch.active{border-color:var(--bone)}

.btn-row{display:grid;grid-template-columns:1fr 1fr;gap:0.65rem;margin-top:1rem}
.sz-btn{background:none;border:1px solid var(--border);color:var(--text);font-family:'Cormorant Garamond',serif;font-size:0.9rem;padding:0.6rem;cursor:pointer;letter-spacing:0.05em;transition:all 0.2s}
.sz-btn:hover{border-color:var(--gold);color:var(--gold)}
.sz-btn-primary{grid-column:1/-1;border-color:var(--crimson);color:var(--bone);background:rgba(140,31,23,0.15);font-size:0.95rem;padding:0.75rem}
.sz-btn-primary:hover{background:rgba(140,31,23,0.4);border-color:var(--bone)}
.seed-display-row{font-family:'DM Mono',monospace;font-size:0.58rem;color:var(--border);text-align:center;margin-top:0.7rem;letter-spacing:0.1em}
.seed-display{color:var(--dim)}

/* ── CTA ── */
.cta-section{border-top:1px solid var(--border);padding:var(--gap) 2rem;text-align:center;max-width:640px;margin:0 auto}
.cta-seed-row{font-family:'DM Mono',monospace;font-size:0.68rem;color:var(--border);margin-bottom:1.25rem;letter-spacing:0.1em}
.cta-seed-row .seed-display{color:var(--rust)}
.cta-title{font-size:2rem;font-weight:300;color:var(--bone);margin-bottom:0.75rem}
.cta-body{font-size:0.95rem;color:var(--muted);font-weight:300;margin-bottom:2rem;line-height:1.7}
.cta-btn{display:inline-block;border:1px solid var(--crimson);color:var(--bone);background:rgba(140,31,23,0.18);font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:300;letter-spacing:0.1em;padding:0.9rem 2.8rem;cursor:pointer;text-decoration:none;transition:all 0.25s}
.cta-btn:hover{background:rgba(140,31,23,0.45);border-color:var(--bone)}

/* ── CLAIM MODAL ── */
#claim-modal{display:none;position:fixed;inset:0;z-index:500;background:rgba(6,4,3,0.92);backdrop-filter:blur(8px);align-items:center;justify-content:center}
.modal-box{background:var(--surface);border:1px solid var(--border);padding:2.25rem;max-width:460px;width:90%;position:relative}
.modal-corner{position:absolute;width:16px;height:16px;border-color:var(--gold);border-style:solid}
.modal-corner-tl{top:-1px;left:-1px;border-width:2px 0 0 2px}
.modal-corner-br{bottom:-1px;right:-1px;border-width:0 2px 2px 0}
.modal-kicker{font-family:'DM Mono',monospace;font-size:0.58rem;letter-spacing:0.2em;color:var(--rust);text-transform:uppercase;margin-bottom:1rem}
.modal-title{font-size:1.3rem;font-weight:300;color:var(--bone);margin-bottom:0.25rem}
.modal-seed{font-family:'DM Mono',monospace;font-size:0.62rem;color:var(--dim);margin-bottom:1.5rem}
.modal-seed .seed-display{color:var(--gold)}
.modal-field{display:flex;flex-direction:column;gap:0.65rem;margin-bottom:1.1rem}
.modal-input{background:var(--ink);border:1px solid var(--border);color:var(--text);font-family:'Cormorant Garamond',serif;font-size:1rem;padding:0.6rem 0.85rem;width:100%;outline:none;transition:border-color 0.2s}
.modal-input:focus{border-color:var(--gold)}
.modal-gdpr{display:flex;align-items:flex-start;gap:0.6rem;margin-bottom:1.4rem;cursor:pointer}
.modal-gdpr input{margin-top:0.2rem;accent-color:var(--gold);width:13px;height:13px;flex-shrink:0}
.modal-gdpr span{font-family:'DM Mono',monospace;font-size:0.58rem;color:var(--dim);line-height:1.5}
.modal-actions{display:grid;grid-template-columns:1fr 1fr;gap:0.65rem}
.modal-cancel{background:none;border:1px solid var(--border);color:var(--muted);font-family:'Cormorant Garamond',serif;font-size:0.9rem;padding:0.6rem;cursor:pointer}
.modal-download{background:rgba(140,31,23,0.22);border:1px solid var(--crimson);color:var(--bone);font-family:'Cormorant Garamond',serif;font-size:0.9rem;padding:0.6rem;cursor:pointer;transition:background 0.2s}
.modal-download:hover{background:rgba(140,31,23,0.45)}
.modal-status{font-family:'DM Mono',monospace;font-size:0.6rem;color:var(--dim);text-align:center;margin-top:0.8rem;min-height:1em}

/* ── TRADITION NAVIGATOR — full 8, scrollable ── */
.trad-nav{
  border-top:1px solid var(--border);
  padding:2.5rem 0 0;
  margin:0;
  background:var(--surface);
}
.trad-nav-label{
  font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.22em;
  color:var(--border);text-transform:uppercase;
  padding:0 2rem;margin-bottom:1.25rem;
}
.trad-nav-track-wrap{
  position:relative;
  overflow:hidden;
}
.trad-nav-track{
  display:flex;gap:1px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding:0 2rem 2rem;
  justify-content:safe center;
}
.trad-nav-track::-webkit-scrollbar{display:none}
.trad-card{
  flex:0 0 200px;
  scroll-snap-align:start;
  border:1px solid var(--border);
  padding:1.25rem 1.25rem 1rem;
  text-decoration:none;
  transition:border-color 0.2s,background 0.2s;
  position:relative;
  background:var(--ink);
}
.trad-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--gold);transform:scaleX(0);transform-origin:left;
  transition:transform 0.35s ease;
}
.trad-card:hover{border-color:var(--rust);background:var(--surface)}
.trad-card:hover::before{transform:scaleX(1)}
.trad-card.current{
  border-color:var(--gold);
  background:rgba(200,146,42,0.06);
  cursor:default;
  pointer-events:none;
}
.trad-card.current::before{transform:scaleX(1)}
.trad-card-canvas{
  width:100%;aspect-ratio:1/1;display:block;
  margin-bottom:0.9rem;
  background:var(--deep);
}
.trad-card-origin{
  font-family:'DM Mono',monospace;font-size:0.55rem;letter-spacing:0.1em;
  color:var(--rust);text-transform:uppercase;margin-bottom:0.3rem;
}
.trad-card-name{
  font-size:0.95rem;font-weight:300;color:var(--bone);margin-bottom:0.25rem;line-height:1.2;
}
.trad-card-desc{
  font-family:'DM Mono',monospace;font-size:0.55rem;color:var(--muted);
  line-height:1.45;letter-spacing:0.02em;
}
.trad-card-current-badge{
  display:none;font-family:'DM Mono',monospace;font-size:0.55rem;
  letter-spacing:0.1em;color:var(--gold);text-transform:uppercase;
  margin-top:0.5rem;
}
.trad-card.current .trad-card-current-badge{display:block}

/* scroll arrows */
.trad-nav-arrow{
  position:absolute;top:0;bottom:2rem;width:3rem;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(to right,var(--surface) 60%,transparent);
  border:none;cursor:pointer;color:var(--muted);font-size:1.2rem;
  transition:color 0.2s;z-index:2;
}
.trad-nav-arrow:hover{color:var(--gold)}
.trad-nav-arrow.right{
  right:0;
  background:linear-gradient(to left,var(--surface) 60%,transparent);
}
.trad-nav-arrow.left{left:0}

/* ── TAGS ── */
.tags{display:flex;flex-wrap:wrap;gap:0.45rem;margin:1.5rem 0}
.tag{font-family:'DM Mono',monospace;font-size:0.58rem;letter-spacing:0.08em;border:1px solid var(--border);color:var(--muted);padding:0.2rem 0.65rem}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(18px);transition:opacity 0.75s ease,transform 0.75s ease}
.reveal.visible{opacity:1;transform:none}

/* ── FOOTER ── */
.tradition-footer{text-align:center;padding:2rem;font-family:'DM Mono',monospace;font-size:0.58rem;color:var(--border);border-top:1px solid rgba(74,56,40,0.25);letter-spacing:0.1em}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  #sz-nav{padding:1rem 1.25rem}
  .section,.section-wide,.sandbox-section{padding-left:1.25rem;padding-right:1.25rem}
  .trad-nav-label{padding:0 1.25rem}
  .trad-nav-track{padding:0 1.25rem 2rem}
  .trad-card{flex:0 0 160px}
  .math-grid{grid-template-columns:1fr}
}

/* ── FORMULA OVERLAY ── */
.canvas-wrap{position:relative;display:block}
#formula-display{
  position:absolute;bottom:6px;right:8px;
  font-family:'DM Mono',monospace;font-size:0.58rem;
  letter-spacing:0.05em;color:rgba(240,232,222,0.2);
  max-width:320px;text-align:right;
  pointer-events:none;line-height:1.55;
  z-index:5;
}

/* ── COLOUR PICKERS ── */
.colour-pickers-section{margin-bottom:1.4rem}
.colour-pickers-label{font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.1em;color:var(--muted);text-transform:uppercase;margin-bottom:0.6rem}
/* ── MOBILE NAV — see /css/nav.css ── */