
:root{
  --bg:#100e0b; --bg2:#0b0a08;
  --card:#1a1713; --card2:#211d17;
  --ink:#efe9df; --dim:#9a9286;
  --gold:#d9b566; --goldd:#b8924a;
  --goldsoft:rgba(217,181,102,.13);
  --line:rgba(217,181,102,.16);
  --line2:rgba(255,255,255,.06);
  --shadow:0 16px 38px rgba(0,0,0,.5), 0 3px 8px rgba(0,0,0,.4);
  --serif:"Fraunces", Georgia, serif;
  --sans:"Inter", system-ui, -apple-system, sans-serif;
  --col:460px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;overflow-x:hidden}
body{
  background:radial-gradient(120% 70% at 50% -10%, #1d1813 0%, var(--bg) 55%) fixed, var(--bg);
  color:var(--ink); font-family:var(--sans); -webkit-font-smoothing:antialiased; min-height:100dvh;
}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,select,textarea{font-family:inherit}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:4px}
img{display:block}
.app{max-width:var(--col);margin:0 auto;min-height:100dvh;position:relative;padding-bottom:96px}

/* ---------- top bar ---------- */
.top{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 8px}
.logo{display:flex;align-items:center;gap:12px}
.logo svg{width:34px;height:34px}
.logo h1{font-family:var(--serif);font-weight:600;font-size:27px;margin:0;letter-spacing:.005em}
.pika{display:flex;align-items:center;gap:7px;padding:8px 13px;border:1px solid var(--line);border-radius:999px;color:var(--gold);font-size:12px;font-weight:600;transition:background .2s}
.pika:hover{background:var(--goldsoft)}
.pika svg{width:15px;height:15px}

/* ---------- views ---------- */
.view{display:none}
.view.on{display:block}

/* search */
.searchbar{display:flex;align-items:center;gap:11px;margin:12px 16px 0;padding:13px 16px;background:var(--card);border:1px solid var(--line);border-radius:14px}
.searchbar svg{width:18px;height:18px;color:var(--dim);flex:none}
.searchbar input{flex:1;background:none;border:0;color:var(--ink);font-size:15px;outline:none}
.searchbar input::placeholder{color:var(--dim)}

/* hero */
.hero{position:relative;margin:16px 16px 0;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:linear-gradient(180deg,#241f18,#161310);min-height:188px;display:flex;align-items:center}
.hero .art{position:absolute;right:-22px;top:50%;transform:translateY(-50%);height:172%;aspect-ratio:1;z-index:1;display:flex;align-items:center;justify-content:center;pointer-events:none}
.hero .art img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 12px 20px rgba(0,0,0,.55))}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,#191510 22%, rgba(25,21,16,.55) 52%, rgba(25,21,16,0) 78%)}
.hero .txt{position:relative;z-index:2;padding:24px 22px}
.hero .h1{color:var(--ink);font-size:15px;opacity:.85}
.hero .nm{font-family:var(--serif);font-size:42px;font-weight:600;line-height:1;margin:3px 0 13px}
.hero .h2{color:var(--gold);font-family:var(--serif);font-style:italic;font-size:17px;line-height:1.35;max-width:200px}

/* lisää levy */
.bigadd{display:flex;align-items:center;justify-content:center;gap:12px;margin:16px 16px 0;padding:18px;border-radius:14px;background:linear-gradient(135deg,#e6c47c,#c39a4f);color:#241a09;font-weight:700;letter-spacing:.13em;text-transform:uppercase;font-size:14px;box-shadow:0 10px 26px rgba(176,140,60,.22);transition:transform .15s}
.bigadd:hover{transform:translateY(-2px)}
.bigadd svg{width:23px;height:23px}

/* stats */
.stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:14px 16px 0}
.stat{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:17px 16px;text-align:left}
.stat .ic{width:32px;height:32px;color:var(--gold);opacity:.92;margin-bottom:11px}
.stat .lab{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim)}
.stat .num{font-size:27px;font-weight:600;color:var(--gold);margin:3px 0 3px;font-variant-numeric:tabular-nums;line-height:1}
.stat .sub{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim);display:flex;align-items:center;gap:4px}
.stat .sub.link{color:var(--gold)}
.stat .sub svg{width:13px;height:13px}

/* sections */
.sec{margin:28px 0 0}
.sec-h{display:flex;align-items:center;gap:10px;padding:0 16px;margin-bottom:14px}
.sec-h .si{width:18px;height:18px;color:var(--gold);flex:none}
.sec-h h2{font-family:var(--serif);font-size:21px;font-weight:500;margin:0;flex:1}
.sec-h .all{color:var(--gold);font-size:12.5px;display:flex;align-items:center;gap:3px}
.sec-h .all svg{width:14px;height:14px}
.scroll{display:flex;gap:14px;overflow-x:auto;padding:0 16px 6px;scrollbar-width:none}
.scroll::-webkit-scrollbar{display:none}

.acard{flex:none;width:152px;text-align:left;padding:0}
.acard .cov{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;box-shadow:var(--shadow);outline:1px solid rgba(239,233,223,.1);outline-offset:-1px}
.acard .cov img{width:100%;height:100%}
.acard .favb{position:absolute;top:8px;right:8px;width:30px;height:30px;border-radius:50%;background:rgba(16,12,8,.62);display:grid;place-items:center;color:var(--gold);backdrop-filter:blur(3px)}
.acard .favb svg{width:16px;height:16px}
.acard .meta{display:flex;gap:6px;padding:10px 2px 0}
.acard .meta .mtxt{flex:1;min-width:0}
.acard .ti{font-size:13.5px;color:var(--ink);line-height:1.25;font-weight:500;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.acard .mt{font-size:11.5px;color:var(--dim);margin-top:3px}
.acard .dots{flex:none;color:var(--dim);width:22px;height:28px;display:grid;place-items:center}
.acard .dots svg{width:16px;height:16px}

/* genres card */
.genres{margin:28px 16px 0;background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.genres .gh{display:flex;align-items:center;padding:16px 16px 12px}
.genres .gh h2{font-family:var(--serif);font-size:20px;font-weight:500;margin:0;flex:1}
.genres .gh .all{color:var(--gold);font-size:12.5px;display:flex;align-items:center;gap:3px}
.genres .gh .all svg{width:14px;height:14px}
.glist{display:grid;grid-template-columns:1fr 1fr;column-gap:14px;padding:0 16px 10px}
.grow{display:flex;align-items:center;gap:12px;padding:12px 2px;border-top:1px solid var(--line2)}
.grow .gi{width:20px;height:20px;color:var(--gold);opacity:.85;flex:none}
.grow .gn{flex:1;font-size:14.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.grow .gc{font-size:14px;color:var(--dim);font-variant-numeric:tabular-nums}

/* collection controls + grid */
.ctrls{padding:14px 16px 2px}
.vtitle{font-family:var(--serif);font-size:26px;font-weight:500;margin:6px 16px 2px}
.groupby{display:flex;gap:22px;margin:12px 0 12px}
.groupby button{position:relative;padding:0 0 8px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--dim)}
.groupby button.on{color:var(--ink)}
.groupby button.on::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--gold),#efd9a0)}
.tags{display:flex;gap:9px;overflow-x:auto;padding:0 16px 6px;scrollbar-width:none;margin:0 -16px}
.tags::-webkit-scrollbar{display:none}
.chip{flex:none;padding:7px 14px;border-radius:999px;border:1px solid var(--line);font-size:12.5px;color:var(--dim);white-space:nowrap;transition:all .18s}
.chip:hover{color:var(--ink)}
.chip.on{color:var(--ink);border-color:var(--gold);background:var(--goldsoft)}

.shelf{padding:6px 16px 0}
.section{margin-top:24px}
.section-head{display:flex;align-items:baseline;gap:10px;margin-bottom:14px}
.eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);font-weight:600}
.count{font-size:11px;color:var(--dim)}
.section-rule{flex:1;height:1px;background:var(--line2);align-self:center}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 16px}
.tile{position:relative;text-align:left;width:100%;padding:0}
.sleeve{position:relative;aspect-ratio:1}
.sleeve .disc{position:absolute;top:6%;left:6%;width:88%;height:88%;border-radius:50%;transform:translateX(6%);transition:transform .5s cubic-bezier(.2,.7,.2,1),filter .5s;z-index:1;filter:brightness(.85)}
.sleeve .cover{position:relative;z-index:2;width:100%;height:100%;border-radius:4px;box-shadow:var(--shadow);outline:1px solid rgba(239,233,223,.13);outline-offset:-1px}
.tile:hover .disc{transform:translateX(34%) rotate(8deg);filter:brightness(1)}
.tile .favmark{position:absolute;top:8px;right:8px;z-index:3;width:26px;height:26px;border-radius:50%;background:rgba(16,12,8,.6);display:grid;place-items:center;color:var(--gold)}
.tile .favmark svg{width:14px;height:14px}
.cap{margin-top:11px;line-height:1.35}
.cap .ar{font-size:13px;color:var(--ink);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cap .al{font-size:11.5px;color:var(--dim);font-style:italic;font-family:var(--serif);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.empty{padding:64px 16px;text-align:center;color:var(--dim);font-size:14px;line-height:1.6}

/* settings */
.setwrap{padding:6px 16px 0}
.setcard{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;margin-top:14px}
.setcard h3{font-family:var(--serif);font-weight:500;font-size:17px;margin:0 0 6px}
.setcard p{color:var(--dim);font-size:13px;line-height:1.6;margin:0 0 14px}
.setbtn{width:100%;padding:13px;border-radius:11px;border:1px solid var(--line);color:var(--ink);font-size:14px;font-weight:500;margin-top:8px;transition:background .2s}
.setbtn:hover{background:rgba(239,233,223,.05)}
.setbtn.danger{color:#e2806e;border-color:rgba(226,128,110,.3)}

/* ---------- bottom nav ---------- */
.nav{position:fixed;bottom:0;left:0;right:0;max-width:var(--col);margin:0 auto;height:72px;display:flex;justify-content:space-around;align-items:flex-start;background:rgba(11,10,8,.93);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--line);z-index:40;padding-top:11px;padding-bottom:env(safe-area-inset-bottom)}
.nav button{display:flex;flex-direction:column;align-items:center;gap:5px;color:var(--dim);font-size:10.5px;letter-spacing:.02em;flex:1}
.nav button svg{width:22px;height:22px}
.nav button.on{color:var(--gold)}
.nav .add{margin-top:-24px}
.nav .add .ring{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,#e6c47c,#c39a4f);display:grid;place-items:center;color:#241a09;box-shadow:0 8px 22px rgba(0,0,0,.5);margin-bottom:5px}
.nav .add .ring svg{width:26px;height:26px}

/* ---------- detail ---------- */
.detail{position:fixed;inset:0;z-index:60;overflow-y:auto;background:radial-gradient(130% 70% at 50% 0%, #1d1813, var(--bg) 60%),var(--bg);max-width:var(--col);margin:0 auto;opacity:0;transform:translateY(14px);pointer-events:none;transition:opacity .3s,transform .3s}
.detail.open{opacity:1;transform:none;pointer-events:auto}
.detail-top{position:sticky;top:0;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:rgba(16,14,11,.72);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line);z-index:5}
.back{display:flex;align-items:center;gap:7px;color:var(--dim);font-size:14px}
.back svg{width:18px;height:18px}
.dacts{display:flex;align-items:center;gap:6px}
.dacts button{width:38px;height:38px;display:grid;place-items:center;border-radius:50%;color:var(--dim);transition:color .2s,background .2s}
.dacts button:hover{background:var(--goldsoft)}
.dacts button.fav.on{color:var(--gold)}
.dacts button svg{width:19px;height:19px}
.detail-body{padding:26px 24px 60px}
.stage{position:relative;perspective:1400px;margin:6px auto 4px;max-width:300px}
.stage .disc{position:absolute;top:0;left:0;width:100%;aspect-ratio:1;border-radius:50%;transform:translateX(2%) scale(.98);opacity:0;transition:transform .7s cubic-bezier(.2,.7,.2,1),opacity .5s;z-index:1}
.detail.open .stage .disc{transform:translateX(46%) rotate(12deg) scale(.98);opacity:1}
.card{position:relative;z-index:2;aspect-ratio:1;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,.1,.2,1)}
.card.flipped{transform:rotateY(180deg)}
.face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:5px;overflow:hidden;box-shadow:var(--shadow);outline:1px solid rgba(239,233,223,.13);outline-offset:-1px}
.face img{width:100%;height:100%}
.face.back{transform:rotateY(180deg)}
.flipbtn{display:block;margin:22px auto 30px;padding:10px 20px;border-radius:999px;border:1px solid var(--gold);color:var(--gold);font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;transition:background .2s}
.flipbtn:hover{background:var(--goldsoft)}
.flipbtn svg{width:14px;height:14px;vertical-align:-2px;margin-right:7px}
.title{font-family:var(--serif);font-size:27px;line-height:1.12;font-weight:500;margin:0 0 4px}
.subt{font-family:var(--serif);font-style:italic;color:var(--dim);font-size:16px;margin-bottom:18px}
.dtags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px}
.dtag{padding:5px 12px;border-radius:999px;border:1px solid var(--line);font-size:11.5px;color:var(--dim)}
.rows{border-top:1px solid var(--line2)}
.row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:13px 0;border-bottom:1px solid var(--line2)}
.row .k{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);flex:none}
.row .v{font-size:14.5px;color:var(--ink);text-align:right}
.row .v .g{color:var(--dim);font-size:13px}
.price{font-family:var(--serif);font-size:20px;color:var(--gold);font-weight:500}
.price small{display:block;font-family:var(--sans);font-size:10.5px;color:var(--dim);letter-spacing:.04em;font-weight:400;margin-top:2px}
.story{margin-top:26px}
.story .lbl{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);margin-bottom:10px}
.story p{font-family:var(--serif);font-size:16.5px;line-height:1.62;color:#ddd4c4;margin:0;font-style:italic}

/* ---------- scrim / sheets ---------- */
.scrim{position:fixed;inset:0;background:rgba(5,4,3,.62);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:opacity .3s;z-index:70}
.scrim.open{opacity:1;pointer-events:auto}
.sheet{position:fixed;left:0;right:0;bottom:0;z-index:80;max-width:var(--col);margin:0 auto;background:var(--card);border:1px solid var(--line);border-bottom:0;border-radius:22px 22px 0 0;padding:18px 20px 28px;transform:translateY(102%);transition:transform .34s cubic-bezier(.2,.7,.2,1);max-height:92dvh;overflow-y:auto}
.sheet.open{transform:none}
.grab{width:38px;height:4px;border-radius:4px;background:rgba(239,233,223,.18);margin:0 auto 16px}
.sheet h2{font-family:var(--serif);font-size:23px;font-weight:500;margin:0 0 4px}
.sheet .lead{color:var(--dim);font-size:13px;margin:0 0 18px;line-height:1.5}
.sheet .lead b{color:var(--gold);font-weight:600;font-style:normal}

/* quick-scan */
.drop{border:1.5px dashed rgba(217,181,102,.4);border-radius:16px;padding:32px 16px;text-align:center;background:rgba(217,181,102,.04);transition:all .2s}
.drop:hover{background:var(--goldsoft);border-color:var(--gold)}
.drop svg{width:34px;height:34px;color:var(--gold);margin-bottom:12px}
.drop .t{font-size:15px;color:var(--ink);font-weight:500}
.drop .s{font-size:12px;color:var(--dim);margin-top:5px}
.scanview{display:none}
.scanview.show{display:block}
.scanrow{display:flex;gap:16px;margin-bottom:18px}
.scanrow .thumb{width:96px;height:96px;border-radius:10px;flex:none;object-fit:cover;box-shadow:var(--shadow);outline:1px solid var(--line)}
.scanrow .id{flex:1;min-width:0;align-self:center}
.scanrow .id .a{font-size:12px;color:var(--dim);text-transform:uppercase;letter-spacing:.12em}
.scanrow .id .b{font-family:var(--serif);font-size:21px;line-height:1.15;margin-top:3px}
.scanrow .id .c{font-style:italic;color:var(--dim);font-family:var(--serif);font-size:14.5px;margin-top:2px}
.status{display:flex;align-items:center;gap:12px;padding:24px 4px;color:var(--dim);font-size:14px}
.spin{width:20px;height:20px;border-radius:50%;border:2px solid var(--line2);border-top-color:var(--gold);animation:sp .8s linear infinite;flex:none}
@keyframes sp{to{transform:rotate(360deg)}}
.confi{display:inline-block;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;padding:3px 9px;border-radius:999px;border:1px solid var(--line);color:var(--dim);margin-left:8px;vertical-align:2px}
.note{font-size:11.5px;color:var(--dim);line-height:1.55;margin-top:16px;padding-top:14px;border-top:1px solid var(--line2)}
.note b{color:var(--ink);font-weight:600}
.closebtn{width:100%;margin-top:18px;padding:13px;border-radius:12px;border:1px solid var(--line);color:var(--ink);font-size:14px;font-weight:500;transition:background .2s}
.closebtn:hover{background:rgba(239,233,223,.05)}
.retry{color:var(--gold);text-decoration:underline;cursor:pointer}

/* add form */
.photos{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:4px 0 20px}
.pslot{aspect-ratio:1;border:1.5px dashed var(--line);border-radius:13px;display:grid;place-items:center;text-align:center;color:var(--dim);position:relative;overflow:hidden;background:rgba(217,181,102,.03);transition:border-color .2s}
.pslot:hover{border-color:var(--gold)}
.pslot.filled{border-style:solid;border-color:var(--line)}
.pslot>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pslot .ph svg{width:30px;height:30px;color:var(--gold);margin-bottom:8px}
.pslot .ph .pt{font-size:13px;color:var(--ink);font-weight:500}
.pslot .ph .ps{font-size:11px;color:var(--dim);margin-top:3px}
.pslot .edit{position:absolute;right:8px;bottom:8px;background:rgba(16,12,8,.78);border-radius:9px;padding:6px 10px;font-size:11px;color:var(--gold);display:flex;gap:5px;align-items:center}
.pslot .edit svg{width:13px;height:13px}
.req{color:var(--gold)}
.idbtn{width:100%;margin:0 0 20px;padding:13px;border-radius:12px;border:1px solid var(--gold);color:var(--gold);font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:9px;transition:background .2s}
.idbtn:hover{background:var(--goldsoft)}
.idbtn:disabled{opacity:.45;cursor:default}
.idbtn svg{width:17px;height:17px}
.idnote{font-size:11.5px;color:var(--dim);margin:-12px 0 18px;display:flex;align-items:center;gap:8px}
.field{margin-bottom:14px}
.field>label{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;background:#0e0c0a;border:1px solid var(--line);border-radius:11px;color:var(--ink);font-size:15px;padding:12px 13px;outline:none;transition:border-color .2s}
.field textarea{min-height:84px;resize:vertical;line-height:1.5}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold)}
.field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239a9286' stroke-width='2'><path d='m6 9 6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 14px center}
.tworow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.formact{display:flex;gap:12px;margin-top:22px}
.formact button{flex:1;padding:15px;border-radius:12px;font-size:14.5px;font-weight:600}
.formact .save{background:linear-gradient(135deg,#e6c47c,#c39a4f);color:#241a09}
.formact .save:disabled{opacity:.45;cursor:default}
.formact .cancel{border:1px solid var(--line);color:var(--ink)}

/* cropper */
.cropper{position:fixed;inset:0;z-index:120;background:rgba(6,5,4,.95);display:none;flex-direction:column;align-items:center;justify-content:center;padding:24px}
.cropper.open{display:flex}
.cropper h3{font-family:var(--serif);color:var(--ink);font-size:19px;margin:0 0 4px;font-weight:500}
.cropper .hint{color:var(--dim);font-size:12.5px;margin-bottom:18px;text-align:center}
.cview{position:relative;width:86vw;max-width:330px;aspect-ratio:1;border-radius:8px;overflow:hidden;background:#000;touch-action:none;box-shadow:0 0 0 1px var(--line),0 22px 50px rgba(0,0,0,.6);cursor:grab}
.cview:active{cursor:grabbing}
.cview img{position:absolute;top:0;left:0;transform-origin:top left;user-select:none;-webkit-user-drag:none;pointer-events:none;will-change:transform}
.cview .frame{position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 0 1px rgba(255,255,255,.22);border-radius:8px}
.cview .frame::before,.cview .frame::after{content:"";position:absolute;background:rgba(255,255,255,.14)}
.cview .frame::before{left:33.3%;right:33.3%;top:0;bottom:0;border-left:1px solid rgba(255,255,255,.12);border-right:1px solid rgba(255,255,255,.12);background:none}
.cview .frame::after{top:33.3%;bottom:33.3%;left:0;right:0;border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12);background:none}
.zoom{width:86vw;max-width:330px;margin:18px 0;display:flex;align-items:center;gap:13px;color:var(--dim)}
.zoom svg{width:18px;height:18px;flex:none}
.zoom input[type=range]{flex:1;accent-color:var(--gold);height:3px}
.crow{display:flex;gap:12px;width:86vw;max-width:330px}
.crow button{flex:1;padding:14px;border-radius:12px;font-size:14.5px;font-weight:600}
.crow .use{background:linear-gradient(135deg,#e6c47c,#c39a4f);color:#241a09}
.crow .cnc{border:1px solid var(--line);color:var(--ink)}

/* popover */
.pop{position:fixed;z-index:130;background:var(--card2);border:1px solid var(--line);border-radius:13px;box-shadow:var(--shadow);padding:6px;display:none;min-width:170px}
.pop.open{display:block}
.pop button{display:flex;align-items:center;gap:11px;width:100%;padding:11px 12px;border-radius:9px;color:var(--ink);font-size:14px;text-align:left;transition:background .15s}
.pop button:hover{background:rgba(239,233,223,.06)}
.pop button svg{width:17px;height:17px;color:var(--dim)}
.pop button.danger{color:#e2806e}
.pop button.danger svg{color:#e2806e}

/* toast */
.toast{position:fixed;bottom:96px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--card2);border:1px solid var(--gold);color:var(--ink);padding:13px 20px;border-radius:12px;font-size:14px;z-index:140;opacity:0;pointer-events:none;transition:all .3s;box-shadow:var(--shadow);max-width:90vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media (max-width:360px){.hero .nm{font-size:36px}.grid{gap:14px 12px}.pika span{display:none}.pika{padding:9px}}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}.tile:hover .disc,.detail.open .stage .disc{transform:none}}


/* ===== monikuva (1–10) ===== */
.photogrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:4px 0 18px}
.pthumb{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;outline:1px solid var(--line);outline-offset:-1px;background:#0e0c0a}
.pthumb img{width:100%;height:100%;object-fit:cover}
.pthumb .coverbadge{position:absolute;left:6px;bottom:6px;font-size:10px;font-weight:700;letter-spacing:.04em;color:#241a09;background:var(--gold);padding:3px 7px;border-radius:6px}
.pthumb .rm{position:absolute;top:5px;right:5px;width:24px;height:24px;border-radius:50%;background:rgba(10,8,6,.72);color:var(--ink);display:grid;place-items:center;backdrop-filter:blur(3px)}
.pthumb .rm svg{width:13px;height:13px}
.paddtile{aspect-ratio:1;border-radius:12px;border:1.5px dashed var(--line);background:var(--goldsoft);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;color:var(--gold);transition:all .18s}
.paddtile:hover{border-color:var(--gold)}
.paddtile svg{width:26px;height:26px}
.paddtile span{font-size:11px;color:var(--ink)}
.paddtile .cnt{font-size:10px;color:var(--dim)}

/* ===== detaljinäkymän galleria ===== */
.gwrap{position:relative;z-index:2;aspect-ratio:1;border-radius:4px;overflow:hidden;box-shadow:var(--shadow);outline:1px solid rgba(239,233,223,.13);outline-offset:-1px;touch-action:pan-y;user-select:none}
.gwrap .gmain{width:100%;height:100%;object-fit:cover;display:block;-webkit-user-drag:none}
.gnav{position:absolute;top:50%;transform:translateY(-50%);width:38px;height:38px;border-radius:50%;background:rgba(10,8,6,.55);backdrop-filter:blur(4px);color:var(--ink);font-size:24px;line-height:1;display:grid;place-items:center;z-index:3}
.gnav.prev{left:8px}
.gnav.next{right:8px}
.gcount{position:absolute;bottom:8px;right:10px;font-size:11px;color:var(--ink);background:rgba(10,8,6,.6);padding:3px 9px;border-radius:999px;backdrop-filter:blur(3px);z-index:3}
.thumbs{display:flex;gap:8px;overflow-x:auto;margin:14px 0 4px;scrollbar-width:none;padding-bottom:2px}
.thumbs::-webkit-scrollbar{display:none}
.thumbs .thumb{flex:none;width:54px;height:54px;border-radius:8px;overflow:hidden;outline:1px solid var(--line);outline-offset:-1px;opacity:.55;transition:opacity .2s,outline-color .2s;padding:0}
.thumbs .thumb.on{opacity:1;outline:2px solid var(--gold)}
.thumbs .thumb img{width:100%;height:100%;object-fit:cover}

/* ===== myynnissä-merkinnät ===== */
.dacts button.sell.on{color:#83d0a0}
.acard .sellb,.tile .sellmark{position:absolute;top:8px;left:8px;z-index:3;font-size:10px;font-weight:700;letter-spacing:.03em;color:#241a09;background:linear-gradient(135deg,#e6cd8c,#cda75f);padding:3px 8px;border-radius:7px;box-shadow:0 2px 6px rgba(0,0,0,.4)}
