/* ============================================================
   ДМИТРИЙ — тёмная премиум-галерея
   Design tokens + base + components
   ============================================================ */
:root{
  --bg:#0a0a0c;
  --bg-2:#0e0d11;
  --panel:#141318;
  --panel-2:#1a191f;
  --panel-3:#211f27;
  --line:rgba(255,255,255,.09);
  --line-2:rgba(255,255,255,.055);
  --ink:#ece8e1;
  --ink-2:#b3aea4;
  --ink-3:#7d776d;
  --ink-4:#544f48;
  --gold:#c4a878;
  --gold-2:#dcc99c;
  --gold-deep:#9a8052;
  --gold-glow:rgba(196,168,120,.22);
  --sold:#cf8a63;
  --ok:#7faa7d;
  --serif:"Playfair Display",Georgia,"Times New Roman",serif;
  --sans:"Manrope",system-ui,-apple-system,sans-serif;
  --maxw:1320px;
  --radius:3px;
  --shadow-art:0 30px 70px -28px rgba(0,0,0,.9),0 8px 22px -12px rgba(0,0,0,.7);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
  overflow-x:hidden;
}
::selection{background:var(--gold);color:#15130e}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font-family:inherit;font-size:15px;color:inherit}
img{display:block;max-width:100%}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.04;letter-spacing:-.01em}
.serif{font-family:var(--serif)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
.eyebrow{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);font-weight:600}
.muted{color:var(--ink-2)}
.dim{color:var(--ink-3)}

/* scrollbar */
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:#2a2830;border-radius:20px;border:3px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:#3a3741}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;justify-content:center;
  font-size:13px;font-weight:600;letter-spacing:.04em;
  padding:14px 26px;border-radius:var(--radius);
  transition:.25s cubic-bezier(.2,.7,.3,1);white-space:nowrap;
}
.btn svg{width:16px;height:16px}
.btn-gold{background:var(--gold);color:#16120a}
.btn-gold:hover{background:var(--gold-2);transform:translateY(-1px)}
.btn-ghost{border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-dark{background:var(--panel-2);color:var(--ink);border:1px solid var(--line)}
.btn-dark:hover{background:var(--panel-3);border-color:var(--line)}
.btn-sm{padding:9px 16px;font-size:12px}
.btn-block{width:100%}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.linklike{color:var(--gold);font-weight:600;font-size:13px;letter-spacing:.03em;display:inline-flex;align-items:center;gap:6px;border-bottom:1px solid transparent;transition:.2s}
.linklike:hover{border-color:var(--gold)}

/* ---------- header ---------- */
.hdr{position:fixed;top:0;left:0;right:0;z-index:60;transition:.35s}
.hdr-in{display:flex;align-items:center;justify-content:space-between;height:78px;
  max-width:var(--maxw);margin:0 auto;padding:0 40px}
.hdr.scrolled{background:rgba(10,10,12,.82);backdrop-filter:blur(18px);border-bottom:1px solid var(--line-2)}
.brand{display:flex;flex-direction:column;line-height:1}
.brand .nm{font-family:var(--serif);font-size:24px;letter-spacing:.14em;font-weight:500}
.brand .sub{font-size:9.5px;letter-spacing:.42em;text-transform:uppercase;color:var(--ink-3);margin-top:5px;padding-left:2px}
.nav{display:flex;gap:34px;align-items:center}
.nav a{font-size:13px;letter-spacing:.05em;color:var(--ink-2);font-weight:500;position:relative;padding:4px 0;transition:.2s}
.nav a:hover,.nav a.active{color:var(--ink)}
.nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--gold)}
.hdr-actions{display:flex;align-items:center;gap:10px}
.iconbtn{width:42px;height:42px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);color:var(--ink-2);transition:.2s;position:relative}
.iconbtn:hover{border-color:var(--gold);color:var(--gold)}
.iconbtn svg{width:18px;height:18px}
.badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;border-radius:10px;
  background:var(--gold);color:#16120a;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}
.menu-toggle{display:none}

/* ---------- hero ---------- */
.hero{position:relative;padding:170px 0 90px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.hero-copy .eyebrow{margin-bottom:26px}
.hero-title{font-size:clamp(54px,7vw,104px);line-height:.95;letter-spacing:-.02em}
.hero-title em{font-style:italic;color:var(--gold-2)}
.hero-lead{font-size:18px;color:var(--ink-2);max-width:30em;margin-top:30px;line-height:1.65}
.hero-cta{display:flex;gap:14px;margin-top:38px;flex-wrap:wrap}
.hero-meta{display:flex;gap:40px;margin-top:54px;padding-top:30px;border-top:1px solid var(--line-2)}
.hero-meta .n{font-family:var(--serif);font-size:34px;color:var(--ink)}
.hero-meta .l{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);margin-top:4px}
.hero-art{position:relative;aspect-ratio:1/1}
.hero-art .glow{position:absolute;inset:-12%;background:radial-gradient(circle at 50% 45%,var(--gold-glow),transparent 62%);filter:blur(8px)}
.hero-art img{position:relative;width:100%;height:100%;object-fit:cover;border-radius:50%;box-shadow:var(--shadow-art)}
.hero-art .ring{position:absolute;inset:-4%;border:1px solid var(--line);border-radius:50%}
.hero-cap{position:absolute;bottom:6%;left:-30px;background:rgba(14,13,17,.9);backdrop-filter:blur(8px);
  border:1px solid var(--line);padding:14px 20px;border-radius:var(--radius)}
.hero-cap .t{font-family:var(--serif);font-size:18px;font-style:italic}
.hero-cap .s{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-top:3px}

/* ---------- section ---------- */
.section{padding:88px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:46px}
.sec-head .ttl{font-size:clamp(32px,4vw,52px)}
.sec-head .num{font-family:var(--serif);font-size:15px;color:var(--ink-3);font-style:italic}
.sec-sub{font-size:15px;color:var(--ink-2);max-width:34em;margin-top:12px}

/* ---------- filter bar ---------- */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:34px;align-items:center}
.chip{font-size:12.5px;font-weight:600;letter-spacing:.03em;padding:9px 17px;border-radius:40px;
  border:1px solid var(--line);color:var(--ink-2);transition:.2s;background:transparent}
.chip:hover{border-color:var(--ink-3);color:var(--ink)}
.chip.on{background:var(--gold);border-color:var(--gold);color:#16120a}
.filters .spacer{flex:1}
.sortsel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:9px 14px;font-size:12.5px;color:var(--ink-2)}

/* ---------- gallery (masonry) ---------- */
.masonry{column-count:3;column-gap:30px}
@media(max-width:1000px){.masonry{column-count:2}}
@media(max-width:600px){.masonry{column-count:1}}
.card{break-inside:avoid;margin-bottom:30px;cursor:pointer;display:block}
.card-art{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--panel)}
.card-art::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px var(--line-2);border-radius:var(--radius);pointer-events:none}
.card-art img{width:100%;transition:transform .9s cubic-bezier(.2,.7,.3,1),filter .5s;filter:brightness(.92)}
.card:hover .card-art img{transform:scale(1.05);filter:brightness(1.05)}
.card-glow{position:absolute;inset:0;opacity:0;transition:.5s;background:radial-gradient(circle at 50% 50%,var(--gold-glow),transparent 70%);mix-blend-mode:screen}
.card:hover .card-glow{opacity:1}
.card-tag{position:absolute;top:13px;left:13px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;
  padding:6px 11px;border-radius:2px;background:rgba(10,10,12,.78);backdrop-filter:blur(6px);color:var(--ink-2)}
.card-tag.sold{color:var(--sold)}
.card-fav{position:absolute;top:11px;right:11px;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(10,10,12,.6);backdrop-filter:blur(6px);color:var(--ink-2);opacity:0;transform:translateY(-4px);transition:.3s}
.card:hover .card-fav{opacity:1;transform:none}
.card-fav:hover{color:var(--gold)}
.card-fav svg{width:16px;height:16px}
.card-fav.liked{color:var(--gold)}
.card-info{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:16px 4px 0}
.card-info .ttl{font-family:var(--serif);font-size:21px;font-style:italic}
.card-info .meta{font-size:12px;color:var(--ink-3);margin-top:3px;letter-spacing:.04em}
.card-info .price{font-size:14px;font-weight:600;color:var(--gold);white-space:nowrap}
.card-info .price.sold{color:var(--ink-3);text-decoration:line-through;text-decoration-thickness:1px}

/* ---------- work detail ---------- */
.detail{padding-top:120px}
.detail-back{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-2);margin-bottom:30px;transition:.2s}
.detail-back:hover{color:var(--gold)}
.detail-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:64px;align-items:start}
.detail-art{position:sticky;top:108px}
.detail-art .frame{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--panel);box-shadow:var(--shadow-art)}
.detail-art .frame::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px var(--line);border-radius:var(--radius)}
.detail-art img{width:100%}
.detail-glow{position:absolute;inset:-8%;background:radial-gradient(circle at 50% 40%,var(--gold-glow),transparent 60%);filter:blur(20px);z-index:-1}
.detail-thumbs{display:flex;gap:12px;margin-top:16px}
.detail-info .series{margin-bottom:14px}
.detail-info h1{font-size:clamp(40px,5vw,62px);font-style:italic;margin-bottom:8px}
.detail-info .sub{font-size:14px;color:var(--ink-3);letter-spacing:.05em}
.spec{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-2);border:1px solid var(--line-2);border-radius:var(--radius);margin:34px 0;overflow:hidden}
.spec div{background:var(--bg);padding:16px 18px}
.spec .k{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}
.spec .v{font-size:16px;margin-top:5px;font-family:var(--serif)}
.detail-desc{font-size:16px;line-height:1.8;color:var(--ink-2);margin:26px 0}
.price-row{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:24px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:30px 0}
.price-row .p{font-family:var(--serif);font-size:38px;color:var(--ink)}
.price-row .status{font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;padding:7px 14px;border-radius:3px;border:1px solid var(--line)}
.price-row .status.av{color:var(--ok);border-color:rgba(127,170,125,.4)}
.price-row .status.sold{color:var(--sold);border-color:rgba(207,138,99,.4)}
.detail-actions{display:flex;gap:12px;flex-wrap:wrap}
.detail-actions .btn{flex:1;min-width:170px}

/* ---------- messenger buttons ---------- */
.buy-block{margin-top:22px;padding-top:22px;border-top:1px solid var(--line-2)}
.buy-label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);font-weight:600;margin-bottom:12px}
.msg-block{display:flex;flex-direction:column;gap:12px}
.msg-grid{display:flex;flex-wrap:wrap;gap:10px}
.msg-btn{flex:1;min-width:150px;font-weight:600;color:#16120a;border:1px solid transparent}
.msg-btn:hover{transform:translateY(-1px);filter:brightness(1.06)}
.msg-wa{background:#25D366;color:#0a2e16}
.msg-tg{background:#2AABEE;color:#04263b}
.msg-max{background:var(--panel-2);color:var(--ink);border:1px solid var(--gold);}
.msg-max:hover{background:var(--panel-3)}
.msg-phone{background:var(--panel-2);color:var(--ink);border:1px solid var(--line)}
.msg-phone:hover{border-color:var(--gold);color:var(--gold)}
.msg-mail{background:var(--panel-2);color:var(--ink);border:1px solid var(--line)}
.msg-mail:hover{border-color:var(--gold);color:var(--gold)}
.msg-copy{align-self:flex-start}
.contact-row{cursor:pointer}
a.contact-row:hover .ci{border-color:var(--gold);color:var(--gold)}

/* ---------- forms ---------- */
.field{margin-bottom:20px}
.field label{display:block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin-bottom:9px;font-weight:600}
.input,.textarea,.selectf{width:100%;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:13px 15px;font-size:15px;transition:.2s;color:var(--ink)}
.input:focus,.textarea:focus,.selectf:focus{outline:none;border-color:var(--gold);background:var(--panel-2)}
.textarea{resize:vertical;min-height:110px;line-height:1.6}
.selectf{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237d776d' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.hint{font-size:12px;color:var(--ink-3);margin-top:7px}
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg button{flex:1;min-width:90px;padding:12px;border:1px solid var(--line);border-radius:var(--radius);font-size:13px;font-weight:600;color:var(--ink-2);transition:.2s;background:var(--panel)}
.seg button.on{border-color:var(--gold);color:var(--gold);background:rgba(196,168,120,.08)}
.seg button:hover{border-color:var(--ink-3)}

/* ---------- cart / inquiry ---------- */
.two-col{display:grid;grid-template-columns:1.4fr 1fr;gap:56px;align-items:start}
.cart-item{display:flex;gap:18px;padding:18px 0;border-bottom:1px solid var(--line-2)}
.cart-item img{width:96px;height:120px;object-fit:cover;border-radius:var(--radius);flex-shrink:0}
.cart-item .ci-body{flex:1}
.cart-item .ci-title{font-family:var(--serif);font-size:22px;font-style:italic}
.cart-item .ci-meta{font-size:12.5px;color:var(--ink-3);margin-top:4px}
.cart-item .ci-price{font-size:15px;color:var(--gold);font-weight:600;margin-top:10px}
.cart-item .ci-remove{align-self:flex-start;color:var(--ink-3);font-size:12px;transition:.2s;display:flex;align-items:center;gap:5px}
.cart-item .ci-remove:hover{color:var(--sold)}
.panel-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:30px}
.summary-row{display:flex;justify-content:space-between;font-size:14px;padding:9px 0;color:var(--ink-2)}
.summary-row.total{border-top:1px solid var(--line);margin-top:10px;padding-top:18px;font-size:16px;color:var(--ink)}
.summary-row.total .v{font-family:var(--serif);font-size:26px;color:var(--gold)}
.empty{text-align:center;padding:90px 20px;color:var(--ink-3)}
.empty .e-ico{width:60px;height:60px;margin:0 auto 22px;color:var(--ink-4)}
.empty h3{font-size:28px;color:var(--ink-2);margin-bottom:10px}

/* ---------- contacts ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-list{display:flex;flex-direction:column;gap:2px;margin:30px 0}
.contact-row{display:flex;gap:16px;align-items:center;padding:18px 0;border-bottom:1px solid var(--line-2)}
.contact-row .ci{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0}
.contact-row .ci svg{width:18px;height:18px}
.contact-row .k{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3)}
.contact-row .v{font-size:16px;margin-top:2px}
.msgr-row{display:flex;gap:12px;margin-top:24px}
.portrait{border-radius:var(--radius);overflow:hidden;position:relative}
.portrait img{width:100%;filter:grayscale(.3) contrast(1.05)}
.portrait .pcap{position:absolute;bottom:0;left:0;right:0;padding:26px;background:linear-gradient(transparent,rgba(8,8,10,.92))}
.portrait .pcap .nm{font-family:var(--serif);font-size:26px;font-style:italic}
.portrait .pcap .r{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-top:5px}

/* ---------- success ---------- */
.success{text-align:center;padding:60px 30px;max-width:520px;margin:0 auto}
.success .s-ico{width:74px;height:74px;border-radius:50%;border:1px solid var(--gold);color:var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto 26px}
.success .s-ico svg{width:32px;height:32px}
.success h2{font-size:38px;font-style:italic;margin-bottom:14px}
.success p{color:var(--ink-2);font-size:16px;line-height:1.7}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--line-2);padding:70px 0 40px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:54px}
.footer h4{font-family:var(--serif);font-size:30px;letter-spacing:.06em;margin-bottom:14px}
.footer p{color:var(--ink-3);font-size:14px;max-width:26em}
.footer .fcol h5{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);margin-bottom:18px}
.footer .fcol a{display:block;color:var(--ink-2);font-size:14px;padding:6px 0;transition:.2s}
.footer .fcol a:hover{color:var(--gold)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:30px;border-top:1px solid var(--line-2);font-size:12.5px;color:var(--ink-4)}
.footer-bottom a{color:var(--ink-3)}
.footer-bottom a:hover{color:var(--gold)}

/* ============================================================
   СТУДИЯ / личный кабинет
   ============================================================ */
.lock{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:30px;background:
  radial-gradient(circle at 30% 20%,rgba(196,168,120,.08),transparent 50%),var(--bg)}
.lock-card{width:100%;max-width:400px;text-align:center}
.lock-card .lk-ico{width:58px;height:58px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin:0 auto 26px;color:var(--gold)}
.lock-card h1{font-size:34px;font-style:italic;margin-bottom:6px}
.lock-card .lk-sub{color:var(--ink-3);font-size:13px;margin-bottom:34px;letter-spacing:.04em}
.pin{display:flex;gap:12px;justify-content:center;margin-bottom:8px}
.pin input{width:56px;height:64px;text-align:center;font-size:26px;font-family:var(--serif);background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);color:var(--ink)}
.pin input:focus{outline:none;border-color:var(--gold)}
.lk-err{color:var(--sold);font-size:13px;height:18px;margin:10px 0}
.lk-hint{font-size:12px;color:var(--ink-4);margin-top:18px}

.studio{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{background:var(--bg-2);border-right:1px solid var(--line-2);padding:30px 18px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.side-brand{padding:8px 14px 26px}
.side-brand .nm{font-family:var(--serif);font-size:22px;letter-spacing:.12em}
.side-brand .sub{font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:var(--ink-3);margin-top:5px}
.side-nav{display:flex;flex-direction:column;gap:3px;flex:1}
.side-nav button{display:flex;align-items:center;gap:13px;padding:12px 14px;border-radius:var(--radius);font-size:14px;font-weight:500;color:var(--ink-2);transition:.18s;text-align:left;width:100%}
.side-nav button svg{width:18px;height:18px;opacity:.8}
.side-nav button:hover{background:var(--panel);color:var(--ink)}
.side-nav button.on{background:var(--panel-2);color:var(--ink)}
.side-nav button.on svg{color:var(--gold);opacity:1}
.side-nav .count{margin-left:auto;font-size:11px;background:var(--gold);color:#16120a;font-weight:700;min-width:19px;height:19px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 5px}
.side-foot{border-top:1px solid var(--line-2);padding-top:14px;display:flex;flex-direction:column;gap:3px}
.side-foot button{display:flex;align-items:center;gap:13px;padding:11px 14px;border-radius:var(--radius);font-size:13px;color:var(--ink-3);transition:.18s;width:100%;text-align:left}
.side-foot button:hover{background:var(--panel);color:var(--ink)}
.side-foot button svg{width:16px;height:16px}

.main{padding:38px 46px 80px;max-width:1180px}
.main-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:34px}
.main-head h1{font-size:40px;font-style:italic}
.main-head .mh-sub{color:var(--ink-3);font-size:14px;margin-top:6px}

.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:34px}
.stat{background:var(--panel);border:1px solid var(--line-2);border-radius:var(--radius);padding:22px 22px 20px;position:relative;overflow:hidden}
.stat .si{width:34px;height:34px;border-radius:8px;background:var(--panel-3);display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:16px}
.stat .si svg{width:17px;height:17px}
.stat .sv{font-family:var(--serif);font-size:38px;line-height:1}
.stat .sl{font-size:12px;color:var(--ink-3);margin-top:7px;letter-spacing:.03em}
.stat .sd{font-size:11px;color:var(--ok);margin-top:8px}

.panel-block{background:var(--panel);border:1px solid var(--line-2);border-radius:var(--radius);padding:26px}
.panel-block .pb-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.panel-block .pb-head h3{font-size:22px;font-style:italic}
.two-up{display:grid;grid-template-columns:1.3fr 1fr;gap:18px;margin-bottom:18px}

/* bar chart */
.bars{display:flex;flex-direction:column;gap:14px}
.bar-row{display:grid;grid-template-columns:130px 1fr 46px;align-items:center;gap:14px;font-size:13px}
.bar-row .bl{color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--serif);font-style:italic;font-size:15px}
.bar-track{height:8px;background:var(--panel-3);border-radius:6px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--gold-deep),var(--gold));border-radius:6px;transition:width .8s cubic-bezier(.2,.7,.3,1)}
.bar-row .bv{text-align:right;color:var(--ink-3);font-variant-numeric:tabular-nums}

/* studio toolbar */
.toolbar{display:flex;gap:12px;align-items:center;margin-bottom:24px;flex-wrap:wrap}
.search{position:relative;flex:1;min-width:200px;max-width:340px}
.search svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--ink-3)}
.search input{width:100%;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:11px 14px 11px 38px;font-size:14px}
.search input:focus{outline:none;border-color:var(--gold)}

/* works table */
.wtable{display:flex;flex-direction:column;gap:10px}
.wrow{display:grid;grid-template-columns:64px 1.6fr 1fr .8fr 130px 100px;align-items:center;gap:18px;
  background:var(--panel);border:1px solid var(--line-2);border-radius:var(--radius);padding:12px 18px 12px 12px;transition:.2s}
.wrow:hover{border-color:var(--line)}
.wrow .wthumb{width:64px;height:64px;border-radius:4px;object-fit:cover;background:var(--panel-2)}
.wrow .wt-title{font-family:var(--serif);font-size:19px;font-style:italic}
.wrow .wt-meta{font-size:12px;color:var(--ink-3);margin-top:2px}
.wrow .wt-series{font-size:12px;color:var(--ink-2);background:var(--panel-3);padding:5px 11px;border-radius:30px;display:inline-block}
.wrow .wt-price{font-size:15px;color:var(--gold);font-weight:600}
.statpill{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:7px 12px;border-radius:30px;border:1px solid;transition:.2s;display:inline-flex;align-items:center;gap:7px}
.statpill.av{color:var(--ok);border-color:rgba(127,170,125,.35);background:rgba(127,170,125,.07)}
.statpill.sold{color:var(--sold);border-color:rgba(207,138,99,.35);background:rgba(207,138,99,.07)}
.statpill .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.wrow-actions{display:flex;gap:6px;justify-content:flex-end}
.wrow-actions button{width:34px;height:34px;border-radius:6px;border:1px solid var(--line-2);color:var(--ink-3);display:flex;align-items:center;justify-content:center;transition:.18s}
.wrow-actions button:hover{border-color:var(--gold);color:var(--gold)}
.wrow-actions button.del:hover{border-color:var(--sold);color:var(--sold)}
.wrow-actions svg{width:15px;height:15px}
.wt-stats{display:flex;gap:14px;font-size:12px;color:var(--ink-3)}
.wt-stats span{display:flex;align-items:center;gap:5px}
.wt-stats svg{width:13px;height:13px}

/* series cards */
.series-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.series-card{background:var(--panel);border:1px solid var(--line-2);border-radius:var(--radius);overflow:hidden;transition:.2s}
.series-card:hover{border-color:var(--line)}
.series-card .sc-cover{aspect-ratio:16/10;overflow:hidden;background:var(--panel-2);position:relative}
.series-card .sc-cover img{width:100%;height:100%;object-fit:cover}
.series-card .sc-body{padding:18px}
.series-card .sc-title{font-family:var(--serif);font-size:23px;font-style:italic}
.series-card .sc-count{font-size:12px;color:var(--ink-3);margin-top:4px}
.series-card .sc-actions{display:flex;gap:8px;margin-top:14px}

/* inquiries */
.inq-tabs{display:flex;gap:8px;margin-bottom:22px}
.inq-list{display:flex;flex-direction:column;gap:12px}
.inq-card{background:var(--panel);border:1px solid var(--line-2);border-radius:var(--radius);padding:20px 22px;display:grid;grid-template-columns:1fr auto;gap:16px}
.inq-card.new-inq{border-left:2px solid var(--gold)}
.inq-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.inq-type{font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;padding:4px 10px;border-radius:3px}
.inq-type.buy{background:rgba(196,168,120,.12);color:var(--gold)}
.inq-type.commission{background:rgba(127,170,125,.12);color:var(--ok)}
.inq-card .iname{font-family:var(--serif);font-size:21px;font-style:italic}
.inq-card .imsg{font-size:14px;color:var(--ink-2);line-height:1.6;margin-top:8px;max-width:60ch}
.inq-card .imeta{font-size:12.5px;color:var(--ink-3);margin-top:10px;display:flex;gap:18px;flex-wrap:wrap}
.inq-card .imeta b{color:var(--ink-2);font-weight:600}
.inq-works{display:flex;gap:8px;margin-top:12px}
.inq-works img{width:46px;height:56px;object-fit:cover;border-radius:3px}
.inq-side{display:flex;flex-direction:column;align-items:flex-end;gap:10px;text-align:right}
.inq-time{font-size:11.5px;color:var(--ink-4)}

/* ---------- modal ---------- */
.overlay{position:fixed;inset:0;z-index:200;background:rgba(6,6,8,.72);backdrop-filter:blur(6px);display:flex;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto;animation:fade .2s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{background:var(--bg-2);border:1px solid var(--line);border-radius:6px;width:100%;max-width:760px;margin:auto;animation:rise .35s cubic-bezier(.2,.7,.3,1)}
.modal-sm{max-width:440px}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;border-bottom:1px solid var(--line-2)}
.modal-head h2{font-size:26px;font-style:italic}
.modal-body{padding:28px}
.modal-foot{display:flex;gap:12px;justify-content:flex-end;padding:20px 28px;border-top:1px solid var(--line-2)}
.modal-close{width:38px;height:38px;border-radius:50%;border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;color:var(--ink-3);transition:.2s}
.modal-close:hover{border-color:var(--sold);color:var(--sold)}

/* dropzone */
.dropzone{border:1px dashed var(--line);border-radius:var(--radius);aspect-ratio:4/5;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;cursor:pointer;transition:.2s;color:var(--ink-3);text-align:center;padding:20px;position:relative;overflow:hidden;background:var(--panel)}
.dropzone:hover{border-color:var(--gold);color:var(--gold)}
.dropzone.has{border-style:solid;padding:0}
.dropzone img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.dropzone .dz-ico{width:34px;height:34px}
.dropzone .dz-replace{position:absolute;inset:0;background:rgba(8,8,10,.7);display:flex;align-items:center;justify-content:center;opacity:0;transition:.2s;font-size:13px;font-weight:600;color:var(--ink)}
.dropzone.has:hover .dz-replace{opacity:1}
.modal-2col{display:grid;grid-template-columns:300px 1fr;gap:28px}

/* toast */
.toasts{position:fixed;bottom:28px;left:50%;transform:translateX(-50%);z-index:300;display:flex;flex-direction:column;gap:10px;align-items:center}
.toast{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--radius);padding:14px 22px;font-size:14px;
  display:flex;align-items:center;gap:11px;box-shadow:0 16px 40px -16px rgba(0,0,0,.8);animation:rise .3s}
.toast svg{width:17px;height:17px;color:var(--gold)}

/* preview banner */
.preview-bar{position:fixed;bottom:20px;right:20px;z-index:120;background:var(--panel-2);border:1px solid var(--line);
  border-radius:40px;padding:8px 8px 8px 18px;display:flex;align-items:center;gap:14px;font-size:12.5px;color:var(--ink-2);
  box-shadow:0 16px 40px -16px rgba(0,0,0,.7)}
.preview-bar .pv-dot{width:7px;height:7px;border-radius:50%;background:var(--gold)}

/* responsive */
@media(max-width:980px){
  .hero-grid,.detail-grid,.two-col,.contact-grid,.modal-2col{grid-template-columns:1fr}
  .hero-art{max-width:420px;margin:0 auto}
  .detail-art{position:static}
  .stat-grid{grid-template-columns:1fr 1fr}
  .series-grid{grid-template-columns:1fr 1fr}
  .nav{display:none}
  .menu-toggle{display:flex}
  .studio{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;z-index:90;transform:translateX(-100%);transition:.3s;width:248px}
  .side.open{transform:none}
  .main{padding:24px}
  .two-up{grid-template-columns:1fr}
  .wrow{grid-template-columns:56px 1fr auto;grid-template-areas:"img title actions";row-gap:10px}
}
@media(max-width:560px){
  .wrap{padding:0 22px}
  .hdr-in{padding:0 22px}
  .footer-grid{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:1fr 1fr}
  .field-row,.field-row-3{grid-template-columns:1fr}
  .hero{padding:130px 0 60px}
  .series-grid{grid-template-columns:1fr}
}
.mobile-nav{position:fixed;inset:0;z-index:80;background:var(--bg);padding:100px 30px;display:flex;flex-direction:column;gap:8px;transform:translateY(-100%);transition:.4s;opacity:0;pointer-events:none}
.mobile-nav.open{transform:none;opacity:1;pointer-events:auto}
.mobile-nav a{font-family:var(--serif);font-size:34px;font-style:italic;color:var(--ink-2);padding:12px 0;border-bottom:1px solid var(--line-2)}
.mobile-nav a:hover{color:var(--gold)}
@media(max-width:980px){.hide-narrow{display:none}}
