/* Storefront-specific styles */

/* Ticker */
.ticker{display:flex;align-items:center;gap:16px;background:var(--ink-200);border-bottom:1px solid var(--ink-500);padding:0 0 0 24px;height:36px;overflow:hidden;position:relative}
.ticker.hidden{display:none}
.ticker-label{font:600 10px/1 var(--font-body);text-transform:uppercase;letter-spacing:.28em;color:var(--gold-500);padding-right:16px;border-right:1px solid var(--ink-500);height:100%;display:flex;align-items:center;flex-shrink:0;background:var(--ink-200);position:relative;z-index:2}
.ticker-track{flex:1;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.ticker-row{display:flex;gap:36px;animation:ticker 60s linear infinite;width:max-content;padding-left:36px}
.ticker-item{display:inline-flex;align-items:center;gap:10px;font:500 11px/1 var(--font-mono);letter-spacing:.06em;color:var(--ink-800);white-space:nowrap;text-transform:uppercase}
.ticker-item .dot{width:5px;height:5px;border-radius:999px;background:var(--gold-500);box-shadow:0 0 8px var(--gold-500)}

.storefront-page{padding:48px 32px 96px;max-width:1400px;margin:0 auto;position:relative;z-index:2;width:100%}

/* Hero */
.hero{display:grid;grid-template-columns:1.15fr 1fr;gap:64px;align-items:center;padding:32px 0 96px;position:relative;min-height:560px}
.hero-orb{position:absolute;width:340px;height:340px;border-radius:999px;background:radial-gradient(circle,rgba(212,175,55,.18),transparent 60%);top:-60px;left:30%;filter:blur(20px);pointer-events:none;animation:drift 8s ease-in-out infinite}
.hero-orb.two{top:300px;left:55%;width:280px;height:280px;background:radial-gradient(circle,rgba(122,31,31,.25),transparent 60%);animation-delay:-4s}
.hero-grid-bg{position:absolute;inset:-32px;background:
  linear-gradient(rgba(212,175,55,.05) 1px,transparent 1px),
  linear-gradient(90deg,rgba(212,175,55,.05) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 70% 60% at 30% 50%,#000,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 30% 50%,#000,transparent 80%);
  pointer-events:none;z-index:0}
.hero-content{position:relative;z-index:2}
.hero-eyebrow{display:inline-flex;align-items:center;gap:14px;font:600 11px/1 var(--font-body);letter-spacing:.22em;text-transform:uppercase;color:var(--gold-500);margin-bottom:32px}
.hero-eyebrow .dash{width:36px;height:1px;background:var(--gold-500);box-shadow:0 0 8px var(--gold-500)}
.hero-title{font-family:var(--font-display);font-weight:500;font-size:clamp(48px,6vw,84px);line-height:1.02;letter-spacing:-.025em;margin:0 0 24px;color:var(--ink-900)}
.hero-title .line{display:block}
.hero-title .line.two{display:flex;gap:18px;align-items:baseline;font-style:italic;color:var(--gold-500)}
.hero-title .word-foil{position:relative;display:inline-block;background:linear-gradient(115deg,var(--gold-700) 0%,var(--gold-300) 30%,#fff5d9 45%,var(--gold-300) 60%,var(--gold-700) 100%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:foil 4.5s linear infinite}
.hero-lede{font:400 18px/1.55 var(--font-body);color:var(--ink-700);max-width:480px;margin:0 0 36px}
.hero-actions{display:flex;gap:14px;align-items:center;margin-bottom:48px}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;border-top:1px solid var(--ink-500);padding-top:32px;max-width:520px}
.stat{position:relative}
.stat-num{font:500 32px/1 var(--font-display);color:var(--ink-900);letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.stat-lbl{font:600 10px/1 var(--font-body);text-transform:uppercase;letter-spacing:.16em;color:var(--ink-700);margin-top:8px}
.stat-pulse{display:inline-block;width:6px;height:6px;border-radius:999px;background:var(--verdigris-500);box-shadow:0 0 0 0 rgba(63,143,126,.6);animation:pulse 1.6s infinite;margin-left:8px;vertical-align:middle}

/* Binder hologram */
.binder-stage{position:relative;perspective:1400px;perspective-origin:50% 30%;height:520px;display:flex;align-items:center;justify-content:center}
.binder-eyebrow{position:absolute;top:0;left:50%;transform:translateX(-50%);font:600 10px/1 var(--font-body);letter-spacing:.32em;color:var(--ink-700);text-transform:uppercase}
.binder-3d{position:relative;width:280px;height:380px;transform-style:preserve-3d;transition:transform .25s var(--ease-out)}
.binder-face{position:absolute;background:linear-gradient(140deg,#16161B 0%,#0E0E12 50%,#1A1A21 100%);border:1px solid var(--ink-500);box-shadow:inset 0 0 60px rgba(0,0,0,.5)}
.binder-face.front,.binder-face.back{width:280px;height:380px;border-radius:6px}
.binder-face.front{transform:translateZ(28px)}
.binder-face.back{transform:translateZ(-28px) rotateY(180deg)}
.binder-face.left,.binder-face.right{width:56px;height:380px;top:0}
.binder-face.left{left:0;transform:rotateY(-90deg) translateZ(28px);background:linear-gradient(90deg,#0A0A0E,#1F1F26,#0A0A0E)}
.binder-face.right{right:0;transform:rotateY(90deg) translateZ(28px);background:linear-gradient(90deg,#1F1F26,#0A0A0E,#1F1F26)}
.binder-face.top,.binder-face.bottom{width:280px;height:56px;left:0}
.binder-face.top{top:0;transform:rotateX(90deg) translateZ(28px)}
.binder-face.bottom{bottom:0;transform:rotateX(-90deg) translateZ(28px)}
.binder-emblem{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px}
.binder-monogram{font:500 140px/1 var(--font-display);color:transparent;background:linear-gradient(135deg,var(--gold-700),var(--gold-300) 40%,#fff5d9 50%,var(--gold-300) 60%,var(--gold-700));-webkit-background-clip:text;background-clip:text;background-size:200% 100%;animation:foil 4s linear infinite;letter-spacing:-.02em;filter:drop-shadow(0 0 20px rgba(212,175,55,.25))}
.binder-foil-ring{position:absolute;width:200px;height:200px;border-radius:999px;border:1px solid var(--gold-700);top:50%;left:50%;transform:translate(-50%,-50%);opacity:.6}
.binder-foil-ring::after{content:"";position:absolute;inset:-1px;border-radius:999px;border:1px solid var(--gold-500);clip-path:polygon(50% 0,100% 0,100% 30%,50% 30%);animation:spin-slow 6s linear infinite;transform-origin:center}
.binder-stamp{font:600 9px/1 var(--font-body);text-transform:uppercase;letter-spacing:.4em;color:var(--gold-500);position:absolute;bottom:32px;opacity:.7}
.binder-pages{position:absolute;width:268px;height:368px;left:6px;top:6px;background:repeating-linear-gradient(180deg,#1A1A21 0,#1A1A21 4px,#23232C 4px,#23232C 5px);transform:translateZ(0);border-radius:4px;opacity:.92;box-shadow:inset 0 0 30px rgba(0,0,0,.3)}
.binder-shadow{position:absolute;bottom:30px;left:50%;width:300px;height:30px;background:radial-gradient(ellipse,rgba(0,0,0,.7),transparent 70%);transform:translateX(-50%);filter:blur(8px)}
.binder-readout{position:absolute;bottom:0;left:50%;transform:translateX(-50%);display:flex;gap:24px;font:500 11px/1 var(--font-mono);color:var(--ink-700);text-transform:uppercase;letter-spacing:.12em}
.binder-readout .live{display:inline-flex;align-items:center;gap:8px;color:var(--verdigris-500)}
.binder-readout .d{width:6px;height:6px;border-radius:999px;background:var(--verdigris-500);box-shadow:0 0 0 0 rgba(63,143,126,.6);animation:pulse 1.6s infinite}

/* Holo product card */
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:8px}
.product-carousel{position:relative;overflow:hidden;margin-top:8px}
.carousel-track{display:flex;gap:28px;transition:transform .4s cubic-bezier(.4,0,.2,1);will-change:transform}
.carousel-track .holo-card{min-width:calc(33.333% - 19px);flex-shrink:0}
.carousel-nav{display:flex;gap:12px}
.carousel-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--ink-500);background:rgba(15,15,20,.8);color:var(--ink-900);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.carousel-btn:hover{border-color:var(--gold-700);color:var(--gold-500);box-shadow:0 0 12px rgba(212,175,55,.2)}
.section-head{display:flex;justify-content:space-between;align-items:flex-end}
.holo-card{position:relative;perspective:1200px;transform-style:preserve-3d;will-change:transform;transition:filter .3s,transform .3s}
.holo-frame{background:linear-gradient(160deg,#15151B,#0F0F14);border:1px solid var(--ink-500);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;height:100%;transition:border-color .3s,box-shadow .3s}
.holo-card:hover .holo-frame{border-color:var(--gold-700);box-shadow:0 12px 40px rgba(0,0,0,.5),0 0 0 1px rgba(212,175,55,.2)}
.holo-card:hover{transform:translateY(-4px)}
.holo-art{position:relative;aspect-ratio:3/4;overflow:hidden;background:linear-gradient(135deg,#0E0E12,#1A1A21 40%,#0E0E12)}
.holo-foil{position:absolute;inset:0;background:radial-gradient(circle 200px at 50% 50%,rgba(212,175,55,.4),rgba(212,175,55,0) 60%);mix-blend-mode:screen;pointer-events:none}
.holo-grid{position:absolute;inset:0;background-image:
  linear-gradient(rgba(212,175,55,.06) 1px,transparent 1px),
  linear-gradient(90deg,rgba(212,175,55,.06) 1px,transparent 1px);
  background-size:24px 24px;pointer-events:none}
.holo-tag{position:absolute;top:14px;left:14px;font:600 10px/1 var(--font-body);letter-spacing:.18em;text-transform:uppercase;color:var(--gold-500);background:rgba(11,11,13,.7);backdrop-filter:blur(8px);padding:6px 10px;border:1px solid rgba(212,175,55,.4);border-radius:3px;z-index:3}
.holo-glyph{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--gold-500);filter:drop-shadow(0 0 16px rgba(212,175,55,.4));animation:drift 4s ease-in-out infinite;z-index:2;font-size:56px}
.holo-scan{position:absolute;left:0;right:0;height:60px;background:linear-gradient(180deg,transparent,rgba(212,175,55,.18) 50%,transparent);animation:scan 3.6s linear infinite;pointer-events:none}
.holo-meta-mono{position:absolute;bottom:12px;right:14px;font:500 10px/1 var(--font-mono);color:var(--ink-700);letter-spacing:.18em;z-index:3}
.holo-info{padding:18px 20px 20px;display:flex;flex-direction:column;gap:14px}
.holo-title{font:500 19px/1.25 var(--font-display);margin:0;color:var(--ink-900)}
.holo-sub{font:400 12px/1.4 var(--font-body);color:var(--ink-700)}
.holo-row{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
.holo-price{font:500 22px/1 var(--font-display);color:var(--gold-500)}
.holo-cta{display:inline-flex;align-items:center;gap:8px;height:34px;padding:0 14px;background:transparent;border:1px solid var(--ink-500);color:var(--ink-900);font:600 11px/1 var(--font-body);text-transform:uppercase;letter-spacing:.12em;border-radius:4px;transition:all var(--motion-fast);text-decoration:none}
.holo-cta:hover{background:var(--gold-500);color:var(--ink-100);border-color:var(--gold-500);box-shadow:0 0 20px rgba(212,175,55,.3)}

/* Commission */
.commission{padding:64px 0 0}
.commission-inner{position:relative;background:linear-gradient(140deg,#0E0E12,#1A1A21);border:1px solid var(--ink-500);border-radius:16px;padding:64px 56px;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center;overflow:hidden}
.comm-bg-grid{position:absolute;inset:0;background-image:
  linear-gradient(rgba(212,175,55,.06) 1px,transparent 1px),
  linear-gradient(90deg,rgba(212,175,55,.06) 1px,transparent 1px);
  background-size:32px 32px;mask-image:linear-gradient(135deg,transparent,#000);
  -webkit-mask-image:linear-gradient(135deg,transparent,#000);opacity:.4;pointer-events:none}
.comm-orb{position:absolute;width:380px;height:380px;border-radius:999px;background:radial-gradient(circle,rgba(212,175,55,.15),transparent 60%);right:-80px;top:-80px;filter:blur(30px);pointer-events:none}
.commission-content{position:relative;z-index:2}
.comm-h{font:500 44px/1.05 var(--font-display);margin:14px 0 14px;letter-spacing:-.015em}
.commission-cta{position:relative;z-index:2;display:flex;flex-direction:column;align-items:flex-end;gap:12px}

/* Products page */
.products-page{padding:48px 32px 96px;max-width:1400px;margin:0 auto;position:relative;z-index:2}
.cat-filter{display:flex;gap:8px;margin-bottom:32px;flex-wrap:wrap}
.cat-filter a{display:inline-flex;align-items:center;height:36px;padding:0 18px;border:1px solid var(--ink-500);border-radius:999px;font:500 12px/1 var(--font-body);text-transform:uppercase;letter-spacing:.12em;color:var(--ink-800);transition:all .15s;text-decoration:none}
.cat-filter a:hover{border-color:var(--gold-700);color:var(--ink-900)}
.cat-filter a.active{background:var(--gold-500);color:var(--ink-100);border-color:var(--gold-500);box-shadow:0 0 16px rgba(212,175,55,.3)}

/* Product detail */
.product-detail{padding:48px 32px 96px;max-width:900px;margin:0 auto;position:relative;z-index:2}
.pd-card{background:linear-gradient(160deg,#15151B,#0F0F14);border:1px solid var(--ink-500);border-radius:14px;overflow:hidden;display:grid;grid-template-columns:1fr 1fr;gap:0}
.pd-art{position:relative;aspect-ratio:1;background:linear-gradient(135deg,#0E0E12,#1A1A21 40%,#0E0E12);display:flex;align-items:center;justify-content:center}
.pd-art .holo-glyph{position:static;transform:none;font-size:80px}
.pd-info{padding:48px 40px;display:flex;flex-direction:column;gap:18px}
.pd-sku{font:500 11px/1 var(--font-mono);color:var(--gold-500);letter-spacing:.14em}
.pd-name{font:500 36px/1.1 var(--font-display);margin:0;color:var(--ink-900)}
.pd-sub{font:400 14px/1.5 var(--font-body);color:var(--ink-700)}
.pd-price{font:500 32px/1 var(--font-display);color:var(--gold-500);margin-top:auto}

@media (max-width: 1024px){
  .hero{grid-template-columns:1fr;gap:48px}
  .hero-card{display:flex;justify-content:center}
  .binder-stage{height:420px}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .carousel-track .holo-card{min-width:calc(50% - 14px)}
  .commission-inner{grid-template-columns:1fr;text-align:left}
  .pd-card{grid-template-columns:1fr}
}
@media (max-width: 768px){
  .storefront-page{padding:32px 16px 64px}
  .products-page{padding:32px 16px 64px}
  .product-detail{padding:32px 16px 64px}
  .hero{padding:24px 0 48px;gap:32px}
  .hero-title{font-size:clamp(36px,8vw,64px)}
  .hero-lede{font-size:16px}
  .hero-actions{flex-wrap:wrap}
  .section-head{flex-direction:column;align-items:flex-start;gap:12px}
  .section-head h2{font-size:32px}
  .comm-h{font-size:32px}
  .commission-inner{padding:40px 24px}
  .ticker{padding-left:12px}
  .ticker-label{font-size:9px;letter-spacing:.2em;padding-right:10px}
}
@media (max-width: 640px){
  .product-grid{grid-template-columns:1fr}
  .carousel-track .holo-card{min-width:100%}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .hero-card{display:none}
  .cat-filter{gap:6px}
  .cat-filter a{height:32px;padding:0 14px;font-size:10px}
}

/* Order Confirmation */
.confirmation-page{padding:80px 24px;display:flex;justify-content:center;align-items:center;min-height:70vh}
.confirm-box{max-width:540px;width:100%;background:linear-gradient(160deg,#15151B,#0F0F14);border:1px solid var(--ink-500);border-radius:16px;padding:48px 40px;text-align:center}
.confirm-check{width:64px;height:64px;border-radius:50%;background:var(--gold-500);color:var(--ink-100);font-size:32px;display:flex;align-items:center;justify-content:center;margin:0 auto 24px}
.confirm-title{font:500 36px/1.1 var(--font-display);margin:0 0 12px;color:var(--ink-900)}
.confirm-sub{color:var(--ink-700);font-size:14px;margin-bottom:32px}
.confirm-details{border:1px solid var(--ink-500);border-radius:8px;overflow:hidden;margin-bottom:24px;text-align:left}
.confirm-detail-row{display:flex;justify-content:space-between;padding:12px 18px;border-bottom:1px solid var(--ink-500)}
.confirm-detail-row:last-child{border-bottom:0}
.detail-lbl{font:500 11px/1 var(--font-mono);color:var(--ink-700);text-transform:uppercase;letter-spacing:.1em}
.detail-val{font:500 14px/1 var(--font-body);color:var(--ink-900)}
.order-number{font:600 16px/1 var(--font-mono);color:var(--gold-500)}
.confirm-note{font-size:13px;color:var(--ink-700);margin-bottom:24px}
.confirm-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* Order Status */
.status-page{padding:60px 24px;display:flex;justify-content:center;min-height:70vh}
.status-box{max-width:640px;width:100%}
.status-title{font:500 36px/1.1 var(--font-display);margin:0 0 8px;color:var(--ink-900)}
.status-sub{color:var(--ink-700);font-size:14px;margin-bottom:32px}
.status-form{background:linear-gradient(160deg,#15151B,#0F0F14);border:1px solid var(--ink-500);border-radius:12px;padding:28px 24px;margin-bottom:32px}
.status-form .field{margin-bottom:14px}
.status-result{background:linear-gradient(160deg,#15151B,#0F0F14);border:1px solid var(--ink-500);border-radius:12px;padding:28px 24px}
.status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.order-num{font:600 18px/1 var(--font-mono);color:var(--gold-500)}
.status-badge{font:600 11px/1 var(--font-body);text-transform:uppercase;letter-spacing:.1em;padding:6px 12px;border-radius:4px;border:1px solid var(--ink-500)}
.badge-pending{color:#f0ad4e;border-color:#f0ad4e}
.badge-approved{color:var(--gold-500);border-color:var(--gold-500)}
.badge-in_production{color:#5bc0de;border-color:#5bc0de}
.badge-completed{color:#5cb85c;border-color:#5cb85c}
.badge-cancelled{color:#d9534f;border-color:#d9534f}
.status-details{margin-bottom:24px}
.status-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.s-lbl{font:500 11px/1 var(--font-mono);color:var(--ink-700);text-transform:uppercase;letter-spacing:.1em}
.s-val{font:400 14px/1 var(--font-body);color:var(--ink-900)}
.s-val a{color:var(--gold-500)}
.messages-section{border-top:1px solid var(--ink-500);padding-top:20px;margin-top:20px}
.messages-h{font:500 16px/1 var(--font-body);color:var(--ink-900);margin:0 0 16px}
.messages-list{max-height:400px;overflow-y:auto;margin-bottom:16px}
.msg-bubble{padding:12px 16px;border-radius:8px;margin-bottom:8px;max-width:85%}
.msg-admin{background:rgba(212,175,55,.1);border:1px solid rgba(212,175,55,.2);margin-right:auto}
.msg-customer{background:rgba(255,255,255,.05);border:1px solid var(--ink-500);margin-left:auto}
.msg-sender{font:600 11px/1 var(--font-body);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-700);margin-bottom:6px}
.msg-body{font:400 14px/1.5 var(--font-body);color:var(--ink-900)}
.msg-time{font:400 10px/1 var(--font-mono);color:var(--ink-700);margin-top:6px}
.no-messages{color:var(--ink-700);font-size:13px;text-align:center;padding:24px}
.msg-form .msg-input-row{display:flex;gap:12px;align-items:flex-end}
.msg-form .textarea{flex:1}
.msg-attach-btn{cursor:pointer;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:6px;border:1px solid var(--ink-500);color:var(--ink-700);transition:all .15s}
.msg-attach-btn:hover{border-color:var(--gold-500);color:var(--gold-500)}
.msg-img{max-width:200px;max-height:200px;border-radius:6px;margin-top:8px;border:1px solid var(--ink-500)}
.msg-attachment{margin-top:4px}
.flash-msg{padding:12px 16px;border-radius:6px;margin-bottom:16px;font-size:13px}
.flash-msg.success{background:rgba(92,184,92,.1);border:1px solid rgba(92,184,92,.3);color:#5cb85c}
.flash-msg.error{background:rgba(217,83,79,.1);border:1px solid rgba(217,83,79,.3);color:#d9534f}

/* Builder additions */
.color-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.color-card{cursor:pointer;text-align:center;transition:transform .2s}
.color-card:hover{transform:translateY(-2px)}
.color-card.sel .color-swatch{border-color:var(--gold-500);box-shadow:0 0 16px rgba(212,175,55,.3)}
.color-swatch{width:100%;aspect-ratio:1;border-radius:10px;border:2px solid var(--ink-500);position:relative;transition:border-color .2s,box-shadow .2s}
.color-name{font:500 13px/1 var(--font-body);color:var(--ink-900);margin-top:10px}
.leather-check{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:32px;height:32px;border-radius:50%;background:var(--gold-500);color:var(--ink-100);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600}
.addon-counter-row{display:flex;align-items:center;gap:16px;padding:14px 16px;border:1px solid var(--ink-500);border-radius:8px;margin-bottom:8px}
.addon-info{flex:1}
.addon-info .addon-name{display:block;font:500 14px/1.3 var(--font-body);color:var(--ink-900)}
.addon-info .addon-desc{display:block;font:400 11px/1 var(--font-body);color:var(--ink-700);margin-top:4px}
.addon-counter{display:flex;align-items:center;gap:0;border:1px solid var(--ink-500);border-radius:6px;overflow:hidden}
.counter-btn{width:32px;height:32px;background:transparent;border:none;color:var(--ink-900);font-size:16px;cursor:pointer;transition:background .15s}
.counter-btn:hover{background:rgba(212,175,55,.15)}
.counter-val{width:32px;text-align:center;font:500 14px/32px var(--font-mono);color:var(--ink-900);border-left:1px solid var(--ink-500);border-right:1px solid var(--ink-500)}
.file-upload-area{border:2px dashed var(--ink-500);border-radius:10px;padding:32px 24px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}
.file-upload-area:hover,.file-upload-area.dragover{border-color:var(--gold-500);background:rgba(212,175,55,.05)}
.file-upload-prompt{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--ink-700)}
.upload-icon{font-size:24px;color:var(--gold-500)}
.upload-hint{font-size:11px;color:var(--ink-600)}
.file-upload-preview{display:flex;align-items:center;gap:12px;justify-content:center}
.file-name{font:500 13px/1 var(--font-mono);color:var(--gold-500)}
.file-remove{background:none;border:none;color:var(--ink-700);font-size:16px;cursor:pointer}
.file-remove:hover{color:#d9534f}
.preview-image-wrap{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:32px}
.preview-placeholder{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--ink-700)}
.placeholder-icon{font-size:48px;color:var(--gold-500);opacity:.4}
.placeholder-text{font:400 13px/1 var(--font-body)}
