/* ---- fonts ---- */
@font-face{font-family:'Cinzel';src:url(fonts/Cinzel.ttf) format('truetype');font-weight:400 900;font-display:swap}
@font-face{font-family:'Inter';src:url(fonts/Inter.ttf) format('truetype');font-weight:100 900;font-display:swap}
@font-face{font-family:'Cormorant';src:url(fonts/Cormorant.ttf) format('truetype');font-weight:300 700;font-display:swap}
@font-face{font-family:'Zodiac';src:url(fonts/Zodiac.ttf) format('truetype');font-display:swap}

:root{
  --bg0:#08070c; --bg1:#14111d; --bg2:#0c0a12;
  --ink:#ece9f3; --val:#c7c4d4; --mut:#8c8a9c; --lbl:#74718a;
  --gold:#d9c08a; --gold2:#b29259; --line:rgba(216,200,150,.16);
  --panel:#15121d; --panel2:#1b1726;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--bg0);
  min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased}
.bg{position:fixed;inset:0;z-index:-1;background:
  radial-gradient(120% 60% at 50% 0%, #1b1530 0%, rgba(27,21,48,0) 55%),
  radial-gradient(90% 55% at 50% 100%, #1a1222 0%, rgba(26,18,34,0) 60%),
  linear-gradient(180deg, var(--bg0), var(--bg1) 45%, var(--bg2))}
a{color:inherit}
.hidden{display:none !important}

/* ---- hero ---- */
.hero{text-align:center;padding:3.2rem 1.2rem 1.4rem;max-width:1100px;margin:0 auto}
.kick{font-weight:600;letter-spacing:.5em;font-size:.62rem;color:var(--gold2);text-transform:uppercase;padding-left:.5em}
h1{font-family:'Cinzel',serif;font-weight:800;font-size:clamp(2.3rem,6vw,4.2rem);letter-spacing:.05em;
  color:var(--gold);text-shadow:0 0 36px rgba(217,192,138,.28);line-height:1;margin:.7rem 0 .5rem}
.sub{font-family:'Cormorant',serif;font-style:italic;font-size:clamp(1.05rem,2.6vw,1.5rem);color:var(--val)}
.rule{height:1px;width:min(58%,420px);margin:1.3rem auto;background:linear-gradient(90deg,transparent,var(--gold2),transparent)}

/* ---- controls ---- */
.controls{max-width:820px;margin:0 auto}
.search{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:.7rem;
  color:var(--ink);font-size:1rem;padding:.85rem 1.1rem;outline:none;transition:border-color .2s,background .2s;font-family:inherit}
.search::placeholder{color:var(--mut)}
.search:focus{border-color:var(--gold2);background:rgba(255,255,255,.06)}
.chips{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin:1rem 0 .4rem}
.chip{display:inline-flex;align-items:center;gap:.45rem;background:rgba(255,255,255,.03);
  border:1px solid var(--line);border-radius:2rem;color:var(--val);font-size:.78rem;font-weight:500;
  letter-spacing:.04em;padding:.4rem .85rem;cursor:pointer;transition:all .18s;white-space:nowrap}
.chip:hover{background:rgba(255,255,255,.07);color:var(--ink)}
.chip .dot{width:.6rem;height:.6rem;border-radius:50%;background:var(--c,var(--gold))}
.chip.active{border-color:var(--c,var(--gold));background:color-mix(in srgb,var(--c,var(--gold)) 16%,transparent);color:#fff}
.count{color:var(--mut);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;margin-top:.5rem}

/* ---- grid + cards ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.1rem;
  max-width:1280px;margin:1.6rem auto 3rem;padding:0 1.2rem}
.card{position:relative;background:linear-gradient(180deg,var(--panel),var(--panel2));
  border:1px solid var(--line);border-radius:1rem;padding:1rem .9rem 1.05rem;cursor:pointer;overflow:hidden;
  transition:transform .25s,border-color .25s,box-shadow .25s}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--glow),transparent);opacity:.85}
.card:hover,.card.spin{transform:translateY(-4px);border-color:color-mix(in srgb,var(--glow) 45%,var(--line));
  box-shadow:0 14px 34px rgba(0,0,0,.45)}
.thumb{position:relative;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;margin-bottom:.7rem;perspective:700px}
.thumb::before{content:"";position:absolute;width:84%;height:84%;border-radius:50%;
  background:radial-gradient(circle,var(--glow) 0%,transparent 66%);opacity:.5;transition:opacity .3s,transform .4s}
.card:hover .thumb::before,.card.spin .thumb::before{opacity:.92;transform:scale(1.12)}
.stone-img{max-width:92%;max-height:92%;object-fit:contain;position:relative;
  filter:drop-shadow(0 5px 12px rgba(0,0,0,.6));transition:transform .5s cubic-bezier(.2,.7,.2,1),filter .3s}
/* hover (desktop) OR press-near (touch): a REAL 360° turntable GIF/video swaps in via JS the
   moment a stone has a `spin` asset. Until those exist, just a tasteful pop — no flat-image flip. */
.card:hover .stone-img,.card.spin .stone-img{transform:scale(1.1);filter:drop-shadow(0 8px 20px rgba(0,0,0,.8)) brightness(1.05)}
.card.has-spin:hover .stone-img,.card.has-spin.spin .stone-img{transform:none}
.stone-spin{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:98%;height:98%;object-fit:contain;opacity:0;transition:opacity .25s;pointer-events:none;border-radius:10px}
.card:hover .stone-spin,.card.spin .stone-spin{opacity:1}
.cname{font-family:'Cinzel',serif;font-weight:600;font-size:1.02rem;color:var(--ink);line-height:1.1}
.ctag{display:inline-flex;align-items:center;gap:.35rem;font-size:.66rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--mut);margin:.32rem 0}
.ctag .dot{width:.5rem;height:.5rem;border-radius:50%;background:var(--glow)}
.cgood{font-size:.82rem;color:var(--val);line-height:1.32;margin-top:.15rem}
.empty{text-align:center;color:var(--mut);font-family:'Cormorant',serif;font-style:italic;font-size:1.3rem;padding:3rem 1rem}

/* ---- modal ---- */
.modal{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:1.2rem}
.modal-back{position:absolute;inset:0;background:rgba(4,3,8,.78);backdrop-filter:blur(6px)}
.modal-card{position:relative;background:linear-gradient(180deg,#161320,#100e18);border:1px solid var(--line);
  border-radius:1.2rem;max-width:880px;width:100%;max-height:90vh;overflow-y:auto;padding:0;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.m-banner{padding:1.5rem 1.8rem 1.2rem;border-bottom:1px solid var(--line);position:relative;
  background:linear-gradient(180deg,color-mix(in srgb,var(--glow) 16%,transparent),transparent)}
.m-head{display:flex;gap:1.4rem;align-items:center}
.m-thumb{flex:none;width:128px;height:128px;display:flex;align-items:center;justify-content:center;position:relative}
.m-thumb::before{content:"";position:absolute;width:90%;height:90%;border-radius:50%;
  background:radial-gradient(circle,var(--glow) 0%,transparent 65%);opacity:.6}
.m-thumb img{max-width:100%;max-height:100%;object-fit:contain;position:relative;filter:drop-shadow(0 6px 16px rgba(0,0,0,.7))}
.m-title h2{font-family:'Cinzel',serif;font-weight:700;font-size:1.9rem;color:var(--gold);letter-spacing:.02em}
.m-chakra{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);margin:.4rem 0}
.m-chakra .dot{display:inline-block;width:.55rem;height:.55rem;border-radius:50%;background:var(--glow);margin-right:.4rem;vertical-align:middle}
.m-energy{font-family:'Cormorant',serif;font-style:italic;font-size:1.2rem;color:var(--val)}
.m-close{position:absolute;top:.9rem;right:1.1rem;width:2rem;height:2rem;border-radius:50%;border:1px solid var(--line);
  background:rgba(0,0,0,.3);color:var(--val);font-size:1.1rem;cursor:pointer;line-height:1;display:flex;align-items:center;justify-content:center}
.m-close:hover{color:#fff;border-color:var(--gold2)}
.m-body{padding:1.4rem 1.8rem 1.9rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.1rem 1.6rem}
.m-sec h3{font-family:'Inter';font-weight:700;letter-spacing:.14em;font-size:.66rem;text-transform:uppercase;
  color:var(--gold2);margin-bottom:.55rem;border-bottom:1px solid var(--line);padding-bottom:.35rem}
.m-row{display:flex;justify-content:space-between;gap:1rem;font-size:.86rem;padding:.18rem 0;border-bottom:1px solid rgba(255,255,255,.04)}
.m-row .k{color:var(--mut)}
.m-row .v{color:var(--ink);text-align:right}
.m-row .v.zod{font-family:'Inter','Zodiac','Apple Symbols',sans-serif}
.m-row .v.vibe{color:var(--gold);font-weight:600}
.m-note{grid-column:1/-1;font-family:'Cormorant',serif;font-style:italic;color:var(--mut);font-size:.92rem;border-top:1px solid var(--line);padding-top:.9rem}
.m-note .star{color:var(--gold)}

/* ---- footer ---- */
.foot{max-width:980px;margin:0 auto;padding:2rem 1.4rem 3rem;text-align:center;border-top:1px solid var(--line)}
.disc{font-family:'Cormorant',serif;font-style:italic;color:var(--val);font-size:1rem;line-height:1.4}
.legend{color:var(--mut);font-size:.72rem;margin-top:.7rem;line-height:1.4}
.cred{color:var(--lbl);font-size:.66rem;margin-top:.5rem}
.mark{font-family:'Cinzel',serif;letter-spacing:.32em;color:var(--gold2);font-size:.74rem;margin-top:.9rem;text-transform:uppercase}

@media (max-width:560px){
  .m-head{flex-direction:column;text-align:center}
  .m-body{padding:1.2rem 1.2rem 1.6rem}
  .grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.8rem}
}

/* ---- iPhone / touch ---- */
html{-webkit-text-size-adjust:100%}
body{overscroll-behavior-y:none}
.card{-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.search{font-size:16px} /* keep iOS from zooming the page on focus */
@supports(padding:max(0px)){
  .hero{padding-left:max(1.2rem,env(safe-area-inset-left));padding-right:max(1.2rem,env(safe-area-inset-right))}
  .grid{padding-left:max(1.2rem,env(safe-area-inset-left));padding-right:max(1.2rem,env(safe-area-inset-right))}
  .foot{padding-bottom:max(3rem,env(safe-area-inset-bottom))}
  .modal{padding-bottom:max(1.2rem,env(safe-area-inset-bottom))}
}
@media (max-width:560px){ .hero{padding-top:2.1rem} h1{font-size:clamp(2.1rem,9vw,3rem)} }
