/* ================================================
   ARCANE STUDIOS - style.css
   Fonts: Syne (display) · DM Sans (body) · JetBrains Mono (tags)
   ================================================ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600&family=JetBrains+Mono:wght@400;500&display=swap');

/* ---------- Variables ---------- */
:root {
  --ink:          #07060b;
  --ink-soft:     #0c0a12;
  --panel:        #110e18;
  --panel-raised: #181321;
  --violet-deep:  #382650;
  --violet-line:  rgba(167,122,255,0.22);
  --violet:       #7a4fd9;
  --violet-bright:#a87bff;
  --violet-glow:  rgba(168,123,255,0.35);
  --cream:        #ece2cd;
  --cream-dim:    #cabfa6;
  --bone:         #c6c0d2;
  --bone-dim:     #8d869c;
  --radius:       3px;
  --max:          1180px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
@media(prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  *{ animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.001ms!important; }
}
body{
  background:var(--ink);
  color:var(--bone);
  font-family:"DM Sans",sans-serif;
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{ color:inherit; }
img{ max-width:100%; display:block; }
h1,h2,h3,h4{ margin:0; color:var(--cream); }
p{ margin:0; }

/* ---------- Atmosphere ---------- */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(ellipse 900px 600px at 85% -10%, rgba(122,79,217,.18), transparent 60%),
    radial-gradient(ellipse 700px 500px at -10% 40%, rgba(122,79,217,.10), transparent 60%),
    radial-gradient(ellipse 800px 600px at 50% 110%, rgba(122,79,217,.12), transparent 65%);
  animation: ambientBreathe 14s ease-in-out infinite;
}
@keyframes ambientBreathe{ 0%,100%{opacity:1} 50%{opacity:.7} }
body::after{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  opacity:.3;
  background-image:
    linear-gradient(var(--violet-line) 1px,transparent 1px),
    linear-gradient(90deg,var(--violet-line) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 70% 50% at 50% 0%,black,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 70% 50% at 50% 0%,black,transparent 70%);
}
#emberCanvas{ position:fixed; inset:0; z-index:0; pointer-events:none; width:100%; height:100%; }
.grain-overlay{ position:fixed; inset:0; z-index:70; pointer-events:none; filter:url(#grainFilter); opacity:.45; mix-blend-mode:overlay; }
.vignette{ position:fixed; inset:0; z-index:69; pointer-events:none; background:radial-gradient(ellipse 80% 70% at 50% 40%,transparent 55%,rgba(2,1,5,.55) 100%); }

/* ---------- Typography ---------- */
.display{
  font-family:"Syne",sans-serif;
  font-weight:800;
  letter-spacing:0.02em;
  text-transform:uppercase;
  color:var(--cream);
}
.eyebrow{
  font-family:"JetBrains Mono",monospace;
  font-size:11.5px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--violet-bright);
  display:flex; align-items:center; gap:10px;
}
.eyebrow::before{ content:""; width:18px; height:1px; background:var(--violet-bright); flex:none; }
.mono{ font-family:"JetBrains Mono",monospace; }

/* ---------- Layout ---------- */
.wrap{ max-width:var(--max); margin:0 auto; padding:0 28px; position:relative; z-index:1; }
section{ padding:92px 0; position:relative; }
.section-head{ max-width:640px; margin-bottom:56px; }
.section-head h2{ font-size:clamp(28px,3.4vw,40px); margin-top:14px; }
.section-head p{ margin-top:16px; color:var(--bone-dim); font-size:15.5px; }
.glow-corner-r::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(ellipse 600px 420px at 100% 0%,rgba(122,79,217,.10),transparent 60%);
}
.glow-corner-l::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(ellipse 600px 420px at 0% 100%,rgba(122,79,217,.09),transparent 60%);
}
.glow-corner-r > .wrap, .glow-corner-l > .wrap{ position:relative; z-index:1; }

/* ---------- Sigil / Brand mark ---------- */
.sigil{ display:block; }
.ring{ animation:spin 70s linear infinite; transform-origin:50% 50%; }
@keyframes spin{ to{ transform:rotate(360deg); } }
.flame-flicker{ transform-box:fill-box; transform-origin:50% 85%; animation:flicker 3.6s ease-in-out infinite; }
@keyframes flicker{
  0%,100%{ transform:scaleY(1) scaleX(1); opacity:1; }
  25%{ transform:scaleY(1.045) scaleX(.98); opacity:.92; }
  50%{ transform:scaleY(.97) scaleX(1.02); opacity:1; }
  75%{ transform:scaleY(1.05) scaleX(.985); opacity:.94; }
}
@media(prefers-reduced-motion:reduce){ .ring,.flame-flicker{ animation:none; } }

/* ---------- Nav ---------- */
header{
  position:sticky; top:0; z-index:50;
  background:rgba(7,6,11,.84);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--violet-line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; padding:16px 0; }
.brand{ display:flex; align-items:center; gap:11px; text-decoration:none; }
.brand-word{ font-family:"Syne",sans-serif; font-weight:700; font-size:17px; letter-spacing:.08em; color:var(--cream); }

.nav-links{ display:flex; align-items:center; gap:28px; list-style:none; }
.nav-links a,.nav-links button{
  background:none; border:none; cursor:pointer; padding:0;
  text-decoration:none; font-size:12px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--bone-dim); font-family:"JetBrains Mono",monospace;
  transition:color .2s ease; position:relative; display:flex; align-items:center; gap:5px;
}
.nav-links a:hover,.nav-links button:hover{ color:var(--cream); }
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-5px;
  width:0; height:1px; background:var(--violet-bright); transition:width .25s ease;
}
.nav-links a:hover::after{ width:100%; }

/* Dropdown */
.nav-item-drop{ position:relative; }
.nav-dropdown{
  position:absolute; top:calc(100% + 14px); left:-16px;
  background:rgba(12,10,18,.96); backdrop-filter:blur(16px);
  border:1px solid var(--violet-line); border-radius:var(--radius);
  list-style:none; min-width:210px; padding:8px 0;
  opacity:0; visibility:hidden; transform:translateY(-6px);
  transition:opacity .2s ease,transform .2s ease,visibility .2s;
  z-index:100;
}
.nav-item-drop:hover .nav-dropdown,
.nav-item-drop:focus-within .nav-dropdown{
  opacity:1; visibility:visible; transform:translateY(0);
}
.nav-dropdown li a{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 18px; font-size:12px; letter-spacing:.06em; color:var(--bone-dim);
  transition:background .15s ease,color .15s ease;
}
.nav-dropdown li a::after{ display:none; }
.nav-dropdown li a:hover{ background:rgba(168,123,255,.07); color:var(--cream); }
.nav-badge-sm{
  font-size:9.5px; letter-spacing:.1em; padding:3px 7px;
  border:1px solid var(--violet-deep); border-radius:2px; color:var(--violet-bright);
}

.nav-actions{ display:flex; align-items:center; gap:12px; }
.menu-toggle{
  display:none; background:none; border:1px solid var(--violet-line);
  border-radius:var(--radius); width:40px; height:40px; color:var(--cream); cursor:pointer;
}
#mobileMenu{ display:none; border-top:1px solid var(--violet-line); }
#mobileMenu ul{ list-style:none; padding:16px 28px 20px; display:flex; flex-direction:column; gap:14px; }
#mobileMenu a{
  text-decoration:none; color:var(--bone); font-family:"JetBrains Mono",monospace;
  font-size:12px; letter-spacing:.06em; text-transform:uppercase;
}

/* ---------- Buttons ---------- */
.btn{
  font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:.08em;
  text-transform:uppercase; text-decoration:none; padding:11px 20px;
  border-radius:var(--radius); border:1px solid var(--violet-bright);
  color:var(--cream); display:inline-flex; align-items:center; gap:8px;
  transition:all .2s ease; white-space:nowrap; cursor:pointer; background:transparent;
}
.btn-solid{ background:var(--violet); border-color:var(--violet); color:#100a1c; font-weight:600; }
.btn-solid:hover{ background:var(--violet-bright); border-color:var(--violet-bright); box-shadow:0 0 24px var(--violet-glow); transform:translateY(-1px); }
.btn-ghost:hover{ background:rgba(167,122,255,.08); box-shadow:0 0 20px var(--violet-glow); transform:translateY(-1px); }
.btn:focus-visible{ outline:2px solid var(--violet-bright); outline-offset:3px; }

/* ---------- Pills / tags ---------- */
.tba-pill,.quote-pill,.custom-pill,.sub-pill,.exc-pill{
  flex:none; font-family:"JetBrains Mono",monospace; font-size:10.5px;
  letter-spacing:.1em; text-transform:uppercase;
  border-radius:var(--radius); padding:5px 11px;
}
.tba-pill{ color:var(--violet-bright); border:1px solid var(--violet-deep); }
.quote-pill{ color:var(--cream-dim); border:1px solid var(--violet-line); }
.custom-pill{ color:var(--violet-bright); border:1px solid var(--violet-deep); background:rgba(122,79,217,.08); }
.sub-pill{ color:#2a1d40; border:1px solid var(--violet); background:var(--violet-bright); font-weight:600; }
.exc-pill{ color:var(--cream); border:1px solid var(--cream-dim); background:rgba(236,226,205,.07); }

/* ---------- Index Hero ---------- */
.hero{
  position:relative; padding:96px 0 88px; overflow:hidden;
  border-bottom:1px solid var(--violet-line);
}
.hero::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(circle 380px at var(--mx,80%) var(--my,40%),rgba(168,123,255,.14),transparent 70%);
  transition:background .3s ease;
}
.hero > .wrap{ position:relative; z-index:1; }
.hero-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:center; }
.hero h1{ font-size:clamp(42px,6vw,76px); line-height:1.02; margin-top:18px; }
.hero h1 span{ color:var(--violet-bright); }
.hero-sub{ margin-top:22px; max-width:480px; color:var(--bone); font-size:17px; }
.hero-actions{ margin-top:36px; display:flex; gap:16px; flex-wrap:wrap; }
.hero-meta{
  margin-top:48px; display:flex; gap:28px; flex-wrap:wrap;
  font-family:"JetBrains Mono",monospace; font-size:12px; color:var(--bone-dim); letter-spacing:.04em;
}
.hero-meta span{ color:var(--violet-bright); }
.hero-art{
  position:relative; display:flex; align-items:center;
  justify-content:center; min-height:360px;
}
.hero-art .glow{
  position:absolute; width:440px; height:440px;
  background:radial-gradient(circle,var(--violet-glow),transparent 70%);
  filter:blur(14px); opacity:.7;
}
.embers{ position:absolute; inset:0; pointer-events:none; }
.ember{
  position:absolute; top:56%; left:50%; width:3px; height:3px;
  border-radius:50%; background:var(--violet-bright);
  box-shadow:0 0 7px 1.5px var(--violet-glow); opacity:0;
  transform:translate(var(--x,0),0);
  animation-name:emberDrift; animation-timing-function:ease-out; animation-iteration-count:infinite;
}
@keyframes emberDrift{
  0%{ opacity:0; transform:translate(var(--x,0),10px) scale(.6); }
  14%{ opacity:.9; }
  78%{ opacity:.45; }
  100%{ opacity:0; transform:translate(calc(var(--x,0) + var(--dx,12px)),-190px) scale(.25); }
}

/* ---------- Pillars strip ---------- */
.pillars{ padding:0; border-bottom:1px solid var(--violet-line); }
.pillars-row{ display:flex; flex-wrap:wrap; }
.pillar{
  flex:1 1 240px; display:flex; align-items:center; gap:16px;
  padding:28px 28px; border-right:1px solid var(--violet-line);
}
.pillar:last-child{ border-right:none; }
.pillar svg{ flex:none; }
.pillar-title{ font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--cream); }
.pillar-sub{ margin-top:4px; font-size:13.5px; color:var(--bone-dim); }

/* ---------- Statement band ---------- */
.statement{
  border-top:1px solid var(--violet-line); border-bottom:1px solid var(--violet-line);
  background:linear-gradient(180deg,rgba(122,79,217,.05),transparent);
}
.statement .wrap{ padding-top:60px; padding-bottom:60px; }
.statement p{
  font-family:"Syne",sans-serif; font-weight:600;
  font-size:clamp(20px,2.6vw,30px); line-height:1.5; color:var(--cream); max-width:880px;
}
.statement p em{ font-style:normal; color:var(--violet-bright); }

/* ---------- Service list ---------- */
.service-list{ border-bottom:1px solid var(--violet-line); }
.service-row{ border-top:1px solid var(--violet-line); }
.service-row summary{
  list-style:none; cursor:pointer; display:flex; align-items:center;
  gap:22px; padding:26px 4px; transition:background .2s ease; position:relative;
}
.service-row summary::-webkit-details-marker{ display:none; }
.service-row summary::before{
  content:""; position:absolute; left:-4px; top:50%;
  width:64px; height:64px; border-radius:50%;
  background:radial-gradient(circle,rgba(168,123,255,.22),transparent 70%);
  transform:translateY(-50%) scale(.6); opacity:0;
  transition:opacity .35s ease,transform .35s ease; pointer-events:none;
}
.service-row summary:hover::before{ opacity:1; transform:translateY(-50%) scale(1); }
.service-row summary:hover{ background:rgba(167,122,255,.05); }
.service-row summary:focus-visible{ outline:2px solid var(--violet-bright); outline-offset:-2px; }
.icon-badge{
  flex:none; width:48px; height:48px; border:1px solid var(--violet-line);
  border-radius:var(--radius); display:flex; align-items:center; justify-content:center;
  color:var(--violet-bright); background:var(--panel); position:relative; z-index:1;
  transition:border-color .25s ease,box-shadow .25s ease,transform .25s ease;
}
.service-row[open] .icon-badge, .service-row summary:hover .icon-badge{
  border-color:var(--violet-bright); box-shadow:0 0 22px var(--violet-glow); transform:scale(1.06);
}
.row-divider{ width:1px; height:34px; background:var(--violet-line); flex:none; }
.row-text{ flex:1; min-width:0; }
.row-title{ font-family:"Syne",sans-serif; font-weight:700; font-size:clamp(17px,2vw,22px); color:var(--cream); }
.row-tag{ font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--bone-dim); margin-top:4px; }
.row-caret{ flex:none; color:var(--violet-bright); transition:transform .25s ease; }
.service-row[open] .row-caret{ transform:rotate(45deg); }
.row-detail{ padding:0 4px 30px 94px; max-width:640px; }
.row-detail ul{ list-style:none; display:flex; flex-direction:column; gap:10px; }
.row-detail li{ position:relative; padding-left:18px; color:var(--bone); font-size:15px; }
.row-detail li::before{
  content:""; position:absolute; left:0; top:11px;
  width:6px; height:1px; background:var(--violet-bright);
}
.row-page-link{
  display:inline-flex; align-items:center; gap:7px; margin-top:18px;
  font-family:"JetBrains Mono",monospace; font-size:11.5px; letter-spacing:.06em;
  text-transform:uppercase; color:var(--violet-bright); text-decoration:none;
  transition:gap .2s ease;
}
.row-page-link:hover{ gap:11px; }

/* Coming soon row */
.service-row--soon .row-inner{
  display:flex; align-items:center; gap:22px; padding:26px 4px;
}
.service-row--soon .icon-badge{
  color:var(--bone-dim); border-style:dashed; border-color:var(--violet-deep); background:transparent;
}
.service-row--soon .row-title{ color:var(--bone-dim); }
.service-row--soon .row-tag{ color:var(--bone-dim); opacity:.7; }

/* ---------- Premade band ---------- */
.premade{
  background:var(--cream); color:#1c1624;
  border-top:1px solid var(--violet-deep); border-bottom:1px solid var(--violet-deep);
}
.premade .eyebrow{ color:var(--violet); }
.premade .eyebrow::before{ background:var(--violet); }
.premade-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:center; }
.premade h2{ color:#1c1624; font-size:clamp(28px,3.4vw,40px); margin-top:14px; }
.premade p{ color:#4a4154; margin-top:16px; font-size:15.5px; max-width:480px; }
.premade-points{ list-style:none; margin:28px 0 0; display:flex; flex-direction:column; gap:14px; }
.premade-points li{ display:flex; align-items:baseline; gap:12px; font-family:"JetBrains Mono",monospace; font-size:13px; letter-spacing:.04em; color:#3a3242; }
.premade-points li span{ color:var(--violet); }
.premade .btn-solid{ margin-top:30px; background:#1c1624; border-color:#1c1624; color:var(--cream); }
.premade .btn-solid:hover{ background:var(--violet); border-color:var(--violet); }
.premade-footnote{ margin-top:16px; font-family:"JetBrains Mono",monospace; font-size:11.5px; letter-spacing:.02em; color:#6b6275; max-width:440px; line-height:1.6; }
.premade-card{ border:1px solid var(--violet-deep); background:#f6f0e2; border-radius:var(--radius); padding:34px; }
.premade-card .row{ display:flex; justify-content:space-between; align-items:center; padding:14px 0; border-bottom:1px dashed #cdbfa0; font-family:"JetBrains Mono",monospace; font-size:13px; }
.premade-card .row:last-child{ border-bottom:none; }
.premade-card .row b{ color:#1c1624; font-weight:600; }

/* ---------- Conversions ---------- */
.convert-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:56px; align-items:start; }
.format-tags{ display:flex; gap:10px; flex-wrap:wrap; margin-top:24px; }
.format-tag{ font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:.06em; border:1px solid var(--violet-line); padding:7px 14px; border-radius:var(--radius); color:var(--violet-bright); }
.convert-list{ list-style:none; margin:26px 0 0; display:flex; flex-direction:column; gap:16px; }
.convert-list li{ display:flex; gap:14px; align-items:flex-start; color:var(--bone); font-size:15px; }
.convert-list li .num{ font-family:"JetBrains Mono",monospace; color:var(--violet-bright); font-size:13px; padding-top:2px; }
.notice{
  margin-top:32px; border:1px solid var(--violet-deep); background:var(--panel);
  border-left:2px solid var(--violet-bright); padding:20px 24px; border-radius:var(--radius);
}
.notice p{ font-size:14px; color:var(--cream-dim); line-height:1.7; }
.notice strong{ color:var(--cream); }

/* ---------- Info grid ---------- */
.info-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--violet-line); border:1px solid var(--violet-line); }
.info-cell{ background:var(--ink-soft); padding:30px 32px; }
.info-cell .index{ font-family:"JetBrains Mono",monospace; font-size:12px; color:var(--violet-bright); letter-spacing:.1em; }
.info-cell p{ margin-top:12px; color:var(--bone); font-size:15px; }

/* ---------- Seal ---------- */
.seal-section{
  display:grid; grid-template-columns:220px 1fr; gap:56px; align-items:center;
  border-top:1px solid var(--violet-line); border-bottom:1px solid var(--violet-line);
  background:radial-gradient(ellipse 600px 400px at 0% 50%,rgba(122,79,217,.10),transparent 70%);
}
.seal{ width:180px; height:180px; margin:0 auto; }
.seal-text h3{ font-family:"Syne",sans-serif; font-weight:800; font-size:clamp(22px,2.8vw,30px); text-transform:uppercase; }
.seal-text p{ margin-top:16px; color:var(--bone); font-size:16px; max-width:560px; line-height:1.7; }

/* ---------- CTA Band ---------- */
.cta-band{ text-align:center; padding:100px 0; }
.cta-band h2{ font-size:clamp(30px,4vw,46px); text-transform:uppercase; }
.cta-band p{ margin-top:18px; color:var(--bone-dim); max-width:480px; margin-left:auto; margin-right:auto; }
.cta-band .hero-actions{ justify-content:center; margin-top:34px; }

/* ---------- Footer ---------- */
footer{ border-top:1px solid var(--violet-line); padding:48px 0; }
.footer-grid{ display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap:24px; }
.footer-links{ display:flex; gap:18px 26px; flex-wrap:wrap; list-style:none; }
.footer-links a{ text-decoration:none; color:var(--bone-dim); font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:.06em; text-transform:uppercase; transition:color .2s ease; }
.footer-links a:hover{ color:var(--violet-bright); }
.footer-credit{ margin-top:10px; font-family:"JetBrains Mono",monospace; font-size:11.5px; letter-spacing:.04em; color:var(--bone-dim); }
.footer-fine{ font-family:"JetBrains Mono",monospace; font-size:11.5px; color:var(--bone-dim); letter-spacing:.04em; max-width:380px; line-height:1.7; }

/* ================================================
   CATEGORY PAGES
   ================================================ */

/* Category hero */
.cat-hero{
  padding:0;
  border-bottom:1px solid var(--violet-line);
  position:relative; overflow:hidden;
  min-height:480px; display:flex; align-items:center;
}
.cat-hero::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(ellipse 700px 500px at 50% 0%,rgba(122,79,217,.20),transparent 65%);
}
.cat-hero .wrap{ position:relative; z-index:1; padding-top:88px; padding-bottom:88px; }
.cat-hero-icon{
  width:88px; height:88px; border:1px solid var(--violet-line); border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center;
  color:var(--violet-bright); background:var(--panel); box-shadow:0 0 36px var(--violet-glow);
  margin-bottom:28px;
}
.cat-hero h1{
  font-family:"Syne",sans-serif; font-weight:800; font-size:clamp(48px,7vw,88px);
  line-height:1; text-transform:uppercase; color:var(--cream); margin-top:12px;
}
.cat-hero-sub{ margin-top:20px; font-size:18px; color:var(--bone); max-width:560px; line-height:1.6; }
.cat-badges{ display:flex; gap:10px; flex-wrap:wrap; margin-top:26px; }

/* Category sections */
.cat-section{ padding:80px 0; }
.cat-section + .cat-section{ border-top:1px solid var(--violet-line); }
.cat-title{
  font-family:"Syne",sans-serif; font-weight:700;
  font-size:clamp(22px,2.4vw,28px); text-transform:uppercase; color:var(--cream);
  margin-bottom:32px;
}

/* Item types grid */
.item-grid{
  display:flex; flex-wrap:wrap; gap:16px;
  justify-content:center; align-items:stretch;
}
.item-card{
  flex:0 1 260px; min-width:180px;
  border:1px solid var(--violet-line); background:var(--panel); border-radius:var(--radius);
  padding:22px 20px; transition:border-color .2s ease,box-shadow .2s ease;
  display:flex; flex-direction:column;
}
.item-card:hover{ border-color:var(--violet-bright); box-shadow:0 0 18px var(--violet-glow); }
.item-card-name{
  font-family:"Syne",sans-serif; font-weight:700; font-size:14px;
  text-transform:uppercase; color:var(--cream); letter-spacing:.04em;
}
.item-card-desc{ margin-top:7px; font-size:14px; color:var(--bone-dim); line-height:1.5; }

/* Pricing cards */
.pricing-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:20px; margin-top:40px; }
.pricing-card{
  border:1px solid var(--violet-line); background:var(--panel);
  border-radius:var(--radius); padding:32px 28px; position:relative;
  transition:border-color .2s ease,box-shadow .2s ease;
}
.pricing-card:hover{ border-color:rgba(168,123,255,.45); box-shadow:0 0 28px rgba(168,123,255,.12); }
.pricing-card--featured{ border-color:var(--violet-bright); box-shadow:0 0 28px rgba(168,123,255,.15); }
.pricing-card-type{
  font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--violet-bright); margin-bottom:14px;
}
.pricing-card h3{ font-family:"Syne",sans-serif; font-weight:700; font-size:20px; color:var(--cream); }
.pricing-card p{ margin-top:12px; color:var(--bone); font-size:14.5px; line-height:1.65; }
.pricing-card .btn{ margin-top:24px; }

/* Exclusive upgrade callout */
.exclusive-callout{
  border:1px solid var(--cream-dim); background:rgba(236,226,205,.04);
  border-radius:var(--radius); padding:32px 36px; margin-top:48px;
  display:grid; grid-template-columns:1fr auto; gap:24px 40px; align-items:center;
}
.exclusive-callout h4{
  font-family:"Syne",sans-serif; font-weight:700; font-size:18px;
  color:var(--cream); text-transform:uppercase;
}
.exclusive-callout p{ margin-top:10px; color:var(--bone); font-size:15px; line-height:1.65; }
.exclusive-callout .btn{ white-space:nowrap; }

/* Custom only note */
.custom-only-banner{
  background:rgba(168,123,255,.08); border:1px solid var(--violet-bright);
  border-radius:var(--radius); padding:20px 28px; display:flex; align-items:center; gap:20px;
  margin-bottom:40px;
}
.custom-only-banner p{ font-size:15px; color:var(--cream); line-height:1.6; }
.custom-only-banner p strong{ color:var(--violet-bright); }

/* Gallery placeholder grid */
.gallery-grid{
  display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:16px; margin-top:36px;
}
.gallery-placeholder{
  aspect-ratio:4/3; border:1px dashed var(--violet-line); border-radius:var(--radius);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:10px; background:var(--panel); color:var(--bone-dim);
  font-family:"JetBrains Mono",monospace; font-size:11.5px; letter-spacing:.08em;
  text-transform:uppercase; transition:border-color .2s ease;
}
.gallery-placeholder:hover{ border-color:rgba(168,123,255,.4); }
.gallery-placeholder svg{ opacity:.4; }

/* TBA page */
.tba-hero{ text-align:center; padding:140px 0; }
.tba-hero h1{ font-size:clamp(40px,6vw,72px); margin-top:16px; }
.tba-hero p{ margin-top:20px; font-size:18px; color:var(--bone-dim); max-width:480px; margin-left:auto; margin-right:auto; }
.tba-hero .hero-actions{ justify-content:center; margin-top:36px; }

/* Reveal */
.reveal{ opacity:1; }
@media(prefers-reduced-motion:no-preference){
  .reveal{ animation:rise .8s ease both; }
}
@keyframes rise{ from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:translateY(0)} }

/* ================================================
   RESPONSIVE
   ================================================ */
@media(max-width:1000px){
  .premade-grid, .convert-grid, .seal-section{ grid-template-columns:1fr; }
  .hero-grid{ grid-template-columns:1fr; }
  .hero-art{ display:none; }
  .seal{ width:140px; height:140px; }
  .exclusive-callout{ grid-template-columns:1fr; }
}
@media(max-width:880px){
  .nav-links{ display:none; }
  .menu-toggle{ display:flex; align-items:center; justify-content:center; }
  .pillar{ flex:1 1 100%; border-right:none; border-bottom:1px solid var(--violet-line); }
  .pillar:last-child{ border-bottom:none; }
  .info-grid{ grid-template-columns:1fr; }
  .row-detail{ padding-left:70px; }
}
@media(max-width:620px){
  section{ padding:64px 0; }
  .cat-hero{ min-height:auto; }
  .cat-hero .wrap{ padding-top:64px; padding-bottom:64px; }
  .cat-hero h1{ font-size:clamp(40px,10vw,60px); }
  .quote-pill,.custom-pill,.exc-pill{ display:none; }
  .hero-actions .btn{ flex:1; justify-content:center; }
  .nav-actions > a.btn-solid{ display:none; }
  .row-divider{ display:none; }
  .row-detail{ padding-left:4px; }
}

/* ================================================
   PRICING & POLICY COMPONENTS
   ================================================ */

/* Price list */
.price-list{ border:1px solid var(--violet-line); border-radius:var(--radius); overflow:hidden; margin-top:32px; }
.price-row{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 24px; border-bottom:1px solid var(--violet-line);
  gap:20px; transition:background .15s ease;
}
.price-row:last-child{ border-bottom:none; }
.price-row:hover{ background:rgba(168,123,255,.04); }
.price-row-info{ flex:1; min-width:0; }
.price-row-name{ font-family:"Syne",sans-serif; font-weight:700; font-size:15px; color:var(--cream); }
.price-row-sub{ display:block; font-size:12.5px; color:var(--bone-dim); margin-top:4px; line-height:1.5; }
.price-row-note{ display:block; font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--violet-bright); letter-spacing:.04em; margin-top:5px; }
.price-row-amount{
  font-family:"Syne",sans-serif; font-weight:800; font-size:22px;
  color:var(--cream); white-space:nowrap; flex:none;
}
.price-row-amount.addon{ color:var(--violet-bright); font-size:16px; }
.price-row-amount.range{ font-size:17px; }

/* Pricing page grid */
.pricing-page-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(320px,1fr)); gap:28px; margin-top:40px; }
.pricing-block{
  border:1px solid var(--violet-line); background:var(--panel);
  border-radius:var(--radius); overflow:hidden;
}
.pricing-block-head{
  padding:20px 24px 18px; border-bottom:1px solid var(--violet-line);
  background:rgba(168,123,255,.05);
}
.pricing-block-head h3{ font-family:"Syne",sans-serif; font-weight:700; font-size:16px; color:var(--cream); text-transform:uppercase; letter-spacing:.04em; }
.pricing-block .price-row{ padding:14px 24px; }
.pricing-block .price-row-amount{ font-size:17px; }

/* Policy blocks */
.policy-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:16px; margin-top:36px; }
.policy-block{
  border:1px solid var(--violet-line); background:var(--panel);
  border-radius:var(--radius); padding:28px 24px;
}
.policy-block-label{
  font-family:"JetBrains Mono",monospace; font-size:11px;
  letter-spacing:.14em; text-transform:uppercase; color:var(--violet-bright); margin-bottom:12px;
}
.policy-block h4{ font-family:"Syne",sans-serif; font-weight:700; font-size:16px; color:var(--cream); margin-bottom:10px; }
.policy-block p, .policy-block li{ font-size:14.5px; color:var(--bone); line-height:1.7; }
.policy-block ul{ list-style:none; display:flex; flex-direction:column; gap:8px; }
.policy-block ul li{ padding-left:14px; position:relative; }
.policy-block ul li::before{ content:""; position:absolute; left:0; top:10px; width:5px; height:1px; background:var(--violet-bright); }
.policy-block.policy-warning{ border-color:rgba(236,226,205,.3); }
.policy-block.policy-warning h4{ color:var(--cream); }

/* Addon pills */
.addon-list{ display:flex; flex-direction:column; gap:0; border:1px solid var(--violet-line); border-radius:var(--radius); overflow:hidden; margin-top:32px; }
.addon-row{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 22px; border-bottom:1px solid var(--violet-line);
  gap:16px;
}
.addon-row:last-child{ border-bottom:none; }
.addon-row-name{ font-size:14.5px; color:var(--bone); }
.addon-row-name span{ display:block; font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--bone-dim); margin-top:3px; letter-spacing:.04em; }
.addon-price{ font-family:"Syne",sans-serif; font-weight:700; font-size:16px; color:var(--violet-bright); white-space:nowrap; }

/* Texture policy banner */
.texture-banner{
  background:rgba(168,123,255,.07); border:1px solid var(--violet-line);
  border-left:2px solid var(--violet-bright); border-radius:var(--radius);
  padding:16px 22px; margin-top:24px;
  font-family:"JetBrains Mono",monospace; font-size:12.5px; color:var(--cream-dim);
  line-height:1.7;
}
.texture-banner strong{ color:var(--cream); }

@media(max-width:620px){
  .pricing-page-grid{ grid-template-columns:1fr; }
  .price-row-amount{ font-size:18px; }
}

/* ---------- Color picker tip ---------- */
.color-tip{
  display:flex; align-items:center; gap:18px;
  border:1px solid var(--violet-line); border-radius:var(--radius);
  background:var(--panel); padding:18px 22px; margin-top:24px;
}
.color-tip-swatch{
  flex:none; width:44px; height:44px; border-radius:var(--radius);
  background: conic-gradient(red, yellow, lime, cyan, blue, magenta, red);
  border:1px solid var(--violet-line);
}
.color-tip p{ font-size:14px; color:var(--bone); line-height:1.6; margin:0; }
.color-tip p strong{ color:var(--cream); }
.color-tip a{ color:var(--violet-bright); text-decoration:none; }
.color-tip a:hover{ text-decoration:underline; }
.color-tip p code{
  font-family:"JetBrains Mono",monospace; font-size:12px;
  background:rgba(168,123,255,.12); padding:2px 7px; border-radius:2px;
  color:var(--violet-bright);
}

/* ---------- Gallery real images ---------- */
.gallery-item{
  position:relative; border-radius:var(--radius); overflow:hidden;
  border:1px solid var(--violet-line); aspect-ratio:4/3;
  background:var(--panel); transition:border-color .25s ease, box-shadow .25s ease;
}
.gallery-item:hover{ border-color:var(--violet-bright); box-shadow:0 0 28px var(--violet-glow); }
.gallery-item img{
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .4s ease;
}
.gallery-item:hover img{ transform:scale(1.04); }
.gallery-item-label{
  position:absolute; bottom:0; left:0; right:0;
  padding:12px 16px;
  background:linear-gradient(transparent, rgba(7,6,11,.88));
  font-family:"JetBrains Mono",monospace; font-size:11.5px;
  letter-spacing:.06em; text-transform:uppercase; color:var(--cream);
}

/* ---------- Lightbox ---------- */
.lightbox{
  position:fixed; inset:0; z-index:200;
  background:rgba(7,6,11,.92);
  backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden;
  transition:opacity .25s ease, visibility .25s ease;
  padding:24px;
}
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox-inner{
  position:relative;
  max-width:min(90vw, 1100px);
  max-height:90vh;
  display:flex; align-items:center; justify-content:center;
}
.lightbox-img{
  max-width:100%; max-height:90vh;
  border-radius:var(--radius);
  border:1px solid var(--violet-line);
  box-shadow:0 0 80px rgba(168,123,255,.25);
  transform:scale(.94);
  transition:transform .3s cubic-bezier(.2,.8,.3,1);
  display:block;
}
.lightbox.open .lightbox-img{ transform:scale(1); }
.lightbox-label{
  position:absolute; bottom:-36px; left:0; right:0; text-align:center;
  font-family:"JetBrains Mono",monospace; font-size:12px;
  letter-spacing:.08em; text-transform:uppercase; color:var(--bone-dim);
}
.lightbox-close{
  position:absolute; top:-16px; right:-16px;
  width:36px; height:36px; border-radius:50%;
  background:var(--panel); border:1px solid var(--violet-line);
  color:var(--cream); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:border-color .2s ease, box-shadow .2s ease;
  z-index:1;
}
.lightbox-close:hover{ border-color:var(--violet-bright); box-shadow:0 0 16px var(--violet-glow); }
.gallery-item{ cursor:zoom-in; }

/* ---------- Gallery item - cart overlay ---------- */
.gallery-item{ position:relative; overflow:hidden; }
.gallery-overlay{
  position:absolute; inset:0; z-index:2;
  background:linear-gradient(transparent 30%, rgba(7,6,11,.92) 70%);
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:16px; gap:10px;
  opacity:0; transition:opacity .25s ease;
  pointer-events:none;
}
.gallery-item:hover .gallery-overlay{ opacity:1; pointer-events:auto; }
.gallery-item img{ position:relative; z-index:1; }
.gallery-overlay-top{
  display:flex; justify-content:space-between; align-items:flex-end;
}
.gallery-overlay-name{
  font-family:"Syne",sans-serif; font-weight:700; font-size:14px;
  text-transform:uppercase; color:var(--cream); letter-spacing:.04em;
}
.gallery-overlay-price{
  font-family:"Syne",sans-serif; font-weight:800; font-size:18px;
  color:var(--violet-bright); white-space:nowrap; flex:none;
}
.btn-cart{
  display:flex; align-items:center; justify-content:center; gap:8px;
  width:100%; padding:10px 16px;
  background:var(--violet); border:1px solid var(--violet-bright);
  border-radius:var(--radius); color:#100a1c;
  font-family:"JetBrains Mono",monospace; font-size:12px;
  font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  text-decoration:none; cursor:pointer;
  transition:background .2s ease, box-shadow .2s ease;
}
.btn-cart:hover{ background:var(--violet-bright); box-shadow:0 0 20px var(--violet-glow); }

/* ---------- Cart request modal ---------- */
.cart-modal{
  position:fixed; inset:0; z-index:300;
  background:rgba(7,6,11,.88); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center; padding:24px;
  opacity:0; visibility:hidden; transition:opacity .25s ease, visibility .25s;
}
.cart-modal.open{ opacity:1; visibility:visible; }
.cart-modal-box{
  background:var(--panel-raised); border:1px solid var(--violet-line);
  border-radius:var(--radius); width:100%; max-width:480px;
  transform:translateY(12px); transition:transform .3s cubic-bezier(.2,.8,.3,1);
  overflow:hidden;
}
.cart-modal.open .cart-modal-box{ transform:translateY(0); }
.cart-modal-head{
  padding:22px 24px 18px;
  border-bottom:1px solid var(--violet-line);
  display:flex; justify-content:space-between; align-items:center;
}
.cart-modal-head h3{
  font-family:"Syne",sans-serif; font-weight:700; font-size:16px;
  color:var(--cream); text-transform:uppercase; letter-spacing:.04em;
}
.cart-modal-close{
  background:none; border:none; color:var(--bone-dim); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  width:32px; height:32px; border-radius:50%;
  transition:color .2s ease;
}
.cart-modal-close:hover{ color:var(--cream); }
.cart-modal-body{ padding:24px; }
.cart-item-summary{
  display:flex; justify-content:space-between; align-items:center;
  background:var(--panel); border:1px solid var(--violet-line);
  border-radius:var(--radius); padding:14px 18px; margin-bottom:22px;
}
.cart-item-name{ font-family:"Syne",sans-serif; font-weight:700; font-size:15px; color:var(--cream); }
.cart-item-sub{ font-size:13px; color:var(--bone-dim); margin-top:3px; }
.cart-item-price{ font-family:"Syne",sans-serif; font-weight:800; font-size:22px; color:var(--violet-bright); }
.cart-field{ margin-bottom:18px; }
.cart-field label{
  display:block; font-family:"JetBrains Mono",monospace; font-size:11.5px;
  letter-spacing:.08em; text-transform:uppercase; color:var(--bone-dim); margin-bottom:8px;
}
.cart-field input, .cart-field textarea{
  width:100%; background:var(--panel); border:1px solid var(--violet-line);
  border-radius:var(--radius); padding:12px 14px;
  color:var(--cream); font-family:"DM Sans",sans-serif; font-size:15px;
  outline:none; transition:border-color .2s ease;
  resize:none;
}
.cart-field input:focus, .cart-field textarea:focus{
  border-color:var(--violet-bright);
}
.cart-field input::placeholder, .cart-field textarea::placeholder{ color:var(--bone-dim); }
.cart-submit{
  width:100%; padding:13px; border:none; border-radius:var(--radius);
  background:var(--violet); color:#100a1c;
  font-family:"JetBrains Mono",monospace; font-size:12.5px; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase; cursor:pointer;
  display:flex; align-items:center; justify-content:center; gap:8px;
  transition:background .2s ease, box-shadow .2s ease;
}
.cart-submit:hover{ background:var(--violet-bright); box-shadow:0 0 24px var(--violet-glow); }
.cart-submit:disabled{ opacity:.5; cursor:not-allowed; }
.cart-success{
  text-align:center; padding:32px 24px;
}
.cart-success-icon{
  width:56px; height:56px; border-radius:50%;
  background:rgba(168,123,255,.12); border:1px solid var(--violet-bright);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 18px; color:var(--violet-bright);
}
.cart-success h4{ font-family:"Syne",sans-serif; font-weight:700; font-size:18px; color:var(--cream); }
.cart-success p{ margin-top:10px; font-size:14.5px; color:var(--bone-dim); line-height:1.65; }
.cart-note{
  margin-top:16px; font-family:"JetBrains Mono",monospace;
  font-size:11px; letter-spacing:.04em; color:var(--bone-dim); text-align:center;
}

/* ---------- Cart buttons - price rows & item cards ---------- */
.price-row{ flex-wrap:wrap; }
.btn-cart-sm{
  flex:none; font-family:"JetBrains Mono",monospace; font-size:10px;
  letter-spacing:.1em; text-transform:uppercase;
  padding:7px 14px; background:transparent;
  border:1px solid var(--violet-line); border-radius:var(--radius);
  color:var(--bone-dim); cursor:pointer; white-space:nowrap;
  transition:all .2s ease;
}
.btn-cart-sm:hover{
  border-color:var(--violet-bright); color:var(--violet-bright);
  background:rgba(168,123,255,.08);
}
.item-card{ flex-direction:column; justify-content:space-between; }
.btn-cart-item{
  margin-top:14px; width:100%; padding:9px;
  background:transparent; border:1px solid var(--violet-line);
  border-radius:var(--radius); color:var(--bone-dim);
  font-family:"JetBrains Mono",monospace; font-size:10px;
  letter-spacing:.1em; text-transform:uppercase;
  cursor:pointer; transition:all .2s ease; display:flex;
  align-items:center; justify-content:center; gap:6px;
}
.btn-cart-item:hover{
  border-color:var(--violet-bright); color:var(--violet-bright);
  background:rgba(168,123,255,.08);
}

/* ---------- Multi-item cart drawer ---------- */
.cart-drawer-overlay{
  position:fixed; inset:0; z-index:190;
  background:rgba(7,6,11,.6); backdrop-filter:blur(4px);
  opacity:0; visibility:hidden; transition:opacity .25s ease, visibility .25s;
}
.cart-drawer-overlay.open{ opacity:1; visibility:visible; }
.cart-drawer{
  position:fixed; top:0; right:0; bottom:0; z-index:195;
  width:min(420px, 100vw); background:var(--panel-raised);
  border-left:1px solid var(--violet-line);
  display:flex; flex-direction:column;
  transform:translateX(100%); transition:transform .3s cubic-bezier(.2,.8,.3,1);
}
.cart-drawer.open{ transform:translateX(0); }
.cart-drawer-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:20px 24px; border-bottom:1px solid var(--violet-line); flex:none;
}
.cart-drawer-head h3{
  font-family:"Syne",sans-serif; font-weight:700; font-size:16px;
  color:var(--cream); text-transform:uppercase; letter-spacing:.04em;
  display:flex; align-items:center; gap:10px;
}
.cart-drawer-count{
  font-family:"JetBrains Mono",monospace; font-size:11px;
  background:var(--violet); color:#100a1c; padding:3px 8px;
  border-radius:2px; font-weight:600; letter-spacing:.04em;
}
.cart-drawer-close{
  background:none; border:none; color:var(--bone-dim); cursor:pointer;
  width:32px; height:32px; display:flex; align-items:center; justify-content:center;
  border-radius:50%; transition:color .2s ease;
}
.cart-drawer-close:hover{ color:var(--cream); }
.cart-drawer-items{
  flex:1; overflow-y:auto; padding:16px 24px;
  display:flex; flex-direction:column; gap:10px;
}
.cart-drawer-empty{
  text-align:center; padding:40px 0; color:var(--bone-dim);
  font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:.08em;
  text-transform:uppercase;
}
.cart-line{
  display:flex; align-items:center; gap:14px;
  background:var(--panel); border:1px solid var(--violet-line);
  border-radius:var(--radius); padding:12px 14px;
  transition:border-color .2s ease;
}
.cart-line:hover{ border-color:rgba(168,123,255,.35); }
.cart-line-info{ flex:1; min-width:0; }
.cart-line-name{ font-family:"Syne",sans-serif; font-weight:700; font-size:14px; color:var(--cream); }
.cart-line-type{ font-size:12.5px; color:var(--bone-dim); margin-top:2px; }
.cart-line-price{ font-family:"Syne",sans-serif; font-weight:800; font-size:15px; color:var(--violet-bright); white-space:nowrap; }
.cart-line-remove{
  background:none; border:none; color:var(--bone-dim); cursor:pointer;
  width:26px; height:26px; display:flex; align-items:center; justify-content:center;
  border-radius:50%; transition:color .2s ease, background .2s ease; flex:none;
}
.cart-line-remove:hover{ color:var(--cream); background:rgba(255,255,255,.06); }
.cart-drawer-form{
  padding:16px 24px 24px; border-top:1px solid var(--violet-line); flex:none;
  display:flex; flex-direction:column; gap:14px;
}
.cart-total{
  display:flex; justify-content:space-between; align-items:center;
  font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:.06em;
  text-transform:uppercase; color:var(--bone-dim); margin-bottom:2px;
}
.cart-total span:last-child{ color:var(--cream); font-weight:600; }
.cart-note-sm{
  font-family:"JetBrains Mono",monospace; font-size:10.5px;
  color:var(--bone-dim); letter-spacing:.04em; line-height:1.6; text-align:center;
}

/* Nav cart icon */
.cart-nav-btn{
  position:relative; background:none; border:1px solid var(--violet-line);
  border-radius:var(--radius); width:40px; height:40px;
  color:var(--bone-dim); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:border-color .2s ease, color .2s ease;
}
.cart-nav-btn:hover{ border-color:var(--violet-bright); color:var(--cream); }
.cart-nav-badge{
  position:absolute; top:-6px; right:-6px;
  background:var(--violet); color:#fff;
  font-family:"JetBrains Mono",monospace; font-weight:600;
  font-size:10px; min-width:18px; height:18px;
  border-radius:9px; display:flex; align-items:center; justify-content:center;
  padding:0 4px; pointer-events:none;
}
.btn-cart-sm.added, .btn-cart-item.added, .btn-cart.added{
  border-color:var(--violet-bright); color:var(--violet-bright);
}
