/* =========================================================
   PAGES — component + page-level styles
   ========================================================= */

/* ---------- HERO (home) ---------- */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-top: 120px;
  overflow: hidden;
}
.hero__bg {
  position: absolute; inset: -10% -10% 0 -10%;
  z-index: 0;
}
.hero__glow {
  position: absolute; width: 70vw; height: 70vw; max-width: 900px; max-height: 900px;
  top: -20%; left: 50%; transform: translateX(-50%);
  background: radial-gradient(circle, var(--red-glow), transparent 62%);
  filter: blur(40px); opacity: .55; pointer-events: none;
}
.hero__grid { position: absolute; inset: 0; }
.hero__inner { position: relative; z-index: 2; }
.hero__top { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; flex-wrap: wrap; margin-bottom: 38px; }
.hero__display { margin: 6px 0 0; }
.hero__display .line span { background: linear-gradient(180deg, #fff 60%, #cfcfd3); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero__display .accent span { background: linear-gradient(180deg, var(--red-bright), var(--red-deep)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero__foot { display: flex; justify-content: space-between; align-items: flex-end; gap: 30px; flex-wrap: wrap; margin-top: 46px; }
.hero__lead { max-width: 46ch; }
.hero__ctas { display: flex; gap: 14px; flex-wrap: wrap; }
.avail { display: inline-flex; align-items: center; gap: 10px; font-family: var(--mono); font-size: .74rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
.avail .pulse { width: 9px; height: 9px; border-radius: 50%; background: #34d27b; box-shadow: 0 0 0 0 rgba(52,210,123,.6); animation: pulse 2.4s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(52,210,123,.55);} 70%{box-shadow:0 0 0 10px rgba(52,210,123,0);} 100%{box-shadow:0 0 0 0 rgba(52,210,123,0);} }
.scroll-cue { position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%); z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 10px; font-family: var(--mono); font-size: .62rem; letter-spacing: .3em; text-transform: uppercase; color: var(--faint); }
.scroll-cue .bar { width: 1px; height: 46px; background: linear-gradient(var(--red), transparent); position: relative; overflow: hidden; }
.scroll-cue .bar::after { content: ""; position: absolute; top: -50%; left: 0; width: 100%; height: 50%; background: #fff; animation: cue 1.8s var(--ease) infinite; }
@keyframes cue { 0%{transform:translateY(-100%);} 60%,100%{transform:translateY(300%);} }
@media (max-width: 600px) {
  .scroll-cue { display: none; }
  .hero__foot { margin-top: 34px; }
  .hero__foot .stack { align-items: flex-start !important; text-align: left !important; width: 100%; }
}

/* ---------- STAT band ---------- */
.stats-band { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border-block: 1px solid var(--line); }
.stat { background: var(--bg); padding: clamp(28px,4vw,48px) clamp(20px,3vw,40px); }
.stat .num { font-size: clamp(2.4rem, 5vw, 4.2rem); font-weight: 700; letter-spacing: -.04em; line-height: 1; }
.stat .num .red { color: var(--red-ink); }
.stat .lbl { font-family: var(--mono); font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; color: var(--faint); margin-top: 14px; }
@media (max-width: 760px) { .stats-band { grid-template-columns: repeat(2,1fr); } }

/* ---------- section header ---------- */
.sec-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 30px; flex-wrap: wrap; margin-bottom: clamp(40px,6vw,72px); }
.sec-head .h2 { max-width: 18ch; }
.sec-head p { max-width: 42ch; }

/* ---------- WORK cards ---------- */
.work-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(24px,3vw,48px); }
.work-grid--single { grid-template-columns: 1fr; }
@media (max-width: 820px) { .work-grid { grid-template-columns: 1fr; } }

.work-card { display: block; min-width: 0; }
.work-thumb {
  position: relative; border: 1px solid var(--line); border-radius: 8px; overflow: hidden;
  background: #0e0e10; transition: border-color .5s var(--ease), transform .6s var(--ease), box-shadow .6s var(--ease);
}
.work-card:hover .work-thumb { border-color: var(--accent); box-shadow: 0 30px 80px -30px rgba(0,0,0,.8), 0 0 0 1px var(--accent); transform: translateY(-4px); }
.thumb-scaler { position: relative; width: 100%; overflow: hidden; height: 0; }
.thumb-frame { position: absolute; top: 0; left: 0; border: 0; transform-origin: top left; pointer-events: none; background: #fff; }
.thumb-veil { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, rgba(8,8,10,.55)); opacity: 0; transition: opacity .5s var(--ease); }
.work-card:hover .thumb-veil { opacity: 1; }
.thumb-open {
  position: absolute; left: 18px; bottom: 16px; z-index: 2;
  font-family: var(--mono); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: #fff;
  display: inline-flex; align-items: center; gap: 9px; padding: 9px 14px; border-radius: 4px;
  background: var(--accent); opacity: 0; transform: translateY(10px); transition: opacity .5s var(--ease), transform .5s var(--ease);
}
.work-card:hover .thumb-open { opacity: 1; transform: none; }
.thumb-open .arr { transition: transform .35s var(--ease); }
.work-card:hover .thumb-open .arr { transform: translateX(4px); }

.work-meta { padding: 26px 4px 4px; }
.work-head { display: flex; align-items: baseline; gap: 14px; }
.work-idx { color: var(--accent); font-size: .8rem; }
.work-head .h3 { flex: 1; transition: color .4s var(--ease); }
.work-card:hover .work-head .h3 { color: var(--accent); }
.work-year { color: var(--faint); font-size: .8rem; }
.work-cat { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--faint); margin-top: 8px; }
.work-desc { margin-top: 14px; font-size: .98rem; line-height: 1.55; max-width: 52ch; }
.work-tags { margin-top: 18px; }

/* ---------- disciplines ---------- */
.disc-list { border-top: 1px solid var(--line); }
.disc {
  display: grid; grid-template-columns: 80px 1fr auto; gap: 30px; align-items: center;
  padding: clamp(24px,3.5vw,42px) 0; border-bottom: 1px solid var(--line);
  position: relative; transition: padding-left .5s var(--ease);
}
.disc::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 0; background: var(--red-haze); transition: width .5s var(--ease); z-index: -1; }
.disc:hover { padding-left: 22px; }
.disc:hover::before { width: 100%; }
.disc__no { font-family: var(--mono); font-size: .8rem; color: var(--red-ink); }
.disc__name { font-size: clamp(1.5rem,3vw,2.4rem); font-weight: 600; letter-spacing: -.03em; }
.disc__name small { display: block; font-family: var(--mono); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--faint); font-weight: 400; margin-top: 8px; }
.disc__tags { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; max-width: 320px; }
@media (max-width: 760px) { .disc { grid-template-columns: 40px 1fr; } .disc__tags { display: none; } }

/* ---------- services ---------- */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: 8px; overflow: hidden; }
@media (max-width: 900px) { .svc-grid { grid-template-columns: repeat(2,1fr);} }
@media (max-width: 600px) { .svc-grid { grid-template-columns: 1fr;} }
.svc {
  background: var(--bg); padding: clamp(28px,3vw,40px); position: relative; overflow: hidden;
  transition: background .5s var(--ease); min-height: 240px; display: flex; flex-direction: column;
}
.svc:hover { background: var(--surface); }
.svc__no { font-family: var(--mono); font-size: .72rem; color: var(--red-ink); letter-spacing: .14em; }
.svc__icon { width: 40px; height: 40px; margin: 22px 0; border: 1px solid var(--line-2); border-radius: 6px; display: grid; place-items: center; color: var(--red-ink); transition: border-color .4s var(--ease), background .4s var(--ease); }
.svc:hover .svc__icon { border-color: var(--red); background: var(--red-haze); }
.svc h3 { font-size: 1.3rem; margin-bottom: 10px; }
.svc p { color: var(--muted); font-size: .95rem; line-height: 1.55; }
.svc__line { margin-top: auto; padding-top: 20px; font-family: var(--mono); font-size: .7rem; letter-spacing: .14em; text-transform: uppercase; color: var(--faint); }

/* ---------- about ---------- */
.about-hero { display: grid; grid-template-columns: 1.3fr .9fr; gap: clamp(30px,5vw,70px); align-items: end; }
@media (max-width: 860px) { .about-hero { grid-template-columns: 1fr; } }
.portrait { position: relative; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; aspect-ratio: 4/5; background: repeating-linear-gradient(135deg, #141416, #141416 12px, #17171a 12px, #17171a 24px); display: grid; place-items: center; }
.portrait .ph { font-family: var(--mono); font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--faint); text-align: center; padding: 20px; }
.portrait img { width: 100%; height: 100%; object-fit: cover; }
.portrait::after { content: ""; position: absolute; inset: 0; box-shadow: inset 0 -120px 80px -60px rgba(8,8,10,.9); pointer-events: none; }
.bio p { font-size: clamp(1.05rem,1.5vw,1.25rem); line-height: 1.7; color: #d4d4d8; margin-bottom: 1.1em; }
.bio p .red { color: var(--red-ink); }
.skill-cols { display: grid; grid-template-columns: repeat(2,1fr); gap: 40px; }
@media (max-width: 640px){ .skill-cols { grid-template-columns: 1fr; } }
.skill-cols h4 { font-family: var(--mono); font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--red-ink); margin-bottom: 18px; }
.skill-row { display: flex; justify-content: space-between; padding: 12px 0; border-bottom: 1px solid var(--line); font-size: .98rem; }
.skill-row span:last-child { font-family: var(--mono); font-size: .78rem; color: var(--faint); }

/* ---------- certifications ---------- */
.cert-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: clamp(20px,2.5vw,32px); }
@media (max-width: 760px){ .cert-grid { grid-template-columns: 1fr; } }
.cert-card { border: 1px solid var(--line); border-radius: 8px; overflow: hidden; background: var(--surface); transition: border-color .4s var(--ease), transform .4s var(--ease); }
.cert-card:hover { border-color: var(--line-2); transform: translateY(-3px); }
.cert-img { aspect-ratio: 1/1; background: #0e0e10; overflow: hidden; border-bottom: 1px solid var(--line); display: grid; place-items: center; cursor: zoom-in; }
.cert-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.cert-card:hover .cert-img img { transform: scale(1.03); }
.cert-img .ph { font-family: var(--mono); font-size: .72rem; color: var(--faint); letter-spacing: .14em; text-transform: uppercase; }
.cert-body { padding: 24px; }
.cert-body .issuer { font-family: var(--mono); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--red-ink); }
.cert-body h3 { font-size: 1.35rem; margin: 12px 0 6px; }
.cert-body .meta { color: var(--muted); font-size: .9rem; }
.cert-body .desc { color: var(--faint); font-size: .9rem; margin-top: 14px; line-height: 1.55; }
.cert-body .cred { margin-top: 16px; font-family: var(--mono); font-size: .72rem; color: var(--faint); }

/* lightbox */
.lightbox { position: fixed; inset: 0; z-index: 400; background: rgba(4,4,6,.92); backdrop-filter: blur(8px); display: none; place-items: center; padding: 5vw; }
.lightbox.open { display: grid; }
.lightbox img { max-width: 90vw; max-height: 90vh; border: 1px solid var(--line-2); border-radius: 6px; }
.lightbox .close { position: absolute; top: 24px; right: 28px; font-family: var(--mono); color: #fff; font-size: .9rem; }

/* ---------- contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(30px,5vw,64px); }
@media (max-width: 820px){ .contact-grid { grid-template-columns: 1fr; } }
.field { margin-bottom: 22px; }
.field label { display: block; font-family: var(--mono); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin-bottom: 10px; }
.field input, .field textarea, .field select {
  width: 100%; background: var(--surface); border: 1px solid var(--line-2); color: var(--text);
  padding: 15px 16px; border-radius: 5px; font-family: var(--display); font-size: 1rem; transition: border-color .3s var(--ease), background .3s var(--ease);
}
.field textarea { resize: vertical; min-height: 130px; }
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--red); background: var(--surface-2); }
.field input::placeholder, .field textarea::placeholder { color: var(--faint); }
.contact-list a { display: flex; justify-content: space-between; align-items: center; gap: 14px; padding: 20px 0; border-bottom: 1px solid var(--line); transition: padding-left .4s var(--ease), color .3s var(--ease); }
.contact-list a:hover { padding-left: 12px; color: var(--red-ink); }
.contact-list .k { font-family: var(--mono); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--faint); flex-shrink: 0; }
.contact-list .v { font-size: 1.05rem; min-width: 0; overflow-wrap: anywhere; }
.form-note { font-family: var(--mono); font-size: .74rem; color: var(--faint); margin-top: 6px; }
.form-ok { display: none; padding: 16px; border: 1px solid #2a5d3f; background: rgba(52,210,123,.08); color: #6fe0a0; border-radius: 6px; font-family: var(--mono); font-size: .82rem; margin-top: 18px; }
.form-ok.show { display: block; }

/* ---------- page hero (inner pages) ---------- */
.page-hero { padding-top: 150px; padding-bottom: clamp(40px,6vw,72px); position: relative; }
.page-hero .grid-bg { position: absolute; inset: 0; z-index: 0; opacity: .6; }
.page-hero > .wrap { position: relative; z-index: 1; }
.page-hero .title { font-size: clamp(2.6rem,7vw,6rem); font-weight: 700; letter-spacing: -.045em; line-height: .95; margin: 18px 0 0; }
.crumbs { font-family: var(--mono); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--faint); }
.crumbs a:hover { color: var(--red-ink); }

/* ---------- LIVE PREVIEW viewer ---------- */
.pv-head { padding-top: 130px; padding-bottom: 26px; border-bottom: 1px solid var(--line); }
.pv-head .top { display: flex; justify-content: space-between; align-items: flex-start; gap: 24px; flex-wrap: wrap; }
.pv-title { font-size: clamp(1.8rem,4vw,3rem); font-weight: 700; letter-spacing: -.03em; line-height: 1; }
.pv-sub { font-family: var(--mono); font-size: .74rem; letter-spacing: .14em; text-transform: uppercase; color: var(--red-ink); margin-bottom: 14px; }
.pv-desc { color: var(--muted); max-width: 60ch; margin-top: 16px; line-height: 1.6; }
.pv-tags { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 18px; }

/* toolbar */
.pv-toolbar { position: sticky; top: 64px; z-index: 60; background: rgba(8,8,10,.82); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
.pv-toolbar .inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; height: 60px; flex-wrap: wrap; }
.seg { display: inline-flex; border: 1px solid var(--line-2); border-radius: 6px; overflow: hidden; }
.seg button { background: transparent; border: 0; color: var(--muted); font-family: var(--mono); font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; padding: 10px 16px; transition: background .25s var(--ease), color .25s var(--ease); border-right: 1px solid var(--line-2); }
.seg button:last-child { border-right: 0; }
.seg button.active { background: var(--red); color: #fff; }
.seg button:hover:not(.active) { color: var(--text); background: var(--surface-2); }
.pv-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.pv-actions button, .pv-actions a { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); border: 1px solid var(--line-2); background: transparent; padding: 10px 14px; border-radius: 6px; transition: color .25s var(--ease), border-color .25s var(--ease); }
.pv-actions button:hover, .pv-actions a:hover { color: var(--text); border-color: var(--red); }

/* stage */
.pv-stage { background: repeating-linear-gradient(45deg, #0a0a0c, #0a0a0c 14px, #0c0c0f 14px, #0c0c0f 28px); padding: clamp(20px,4vw,48px) 0 clamp(48px,7vw,90px); min-height: 60vh; }
.pv-device { margin: 0 auto; max-width: 100%; transition: max-width .45s var(--ease); }
.pv-device[data-w="desktop"] { max-width: 1180px; }
.pv-device[data-w="tablet"] { max-width: 800px; }
.pv-device[data-w="mobile"] { max-width: 400px; }
.pv-frame-wrap { position: relative; border: 1px solid var(--line-2); border-radius: 10px; overflow: hidden; background: #fff; box-shadow: 0 40px 100px -40px rgba(0,0,0,.9); }
.pv-bar { display: flex; align-items: center; gap: 7px; padding: 12px 16px; background: #161619; border-bottom: 1px solid var(--line); }
.pv-bar i { width: 11px; height: 11px; border-radius: 50%; background: #32323a; }
.pv-bar i:nth-child(1) { background: #ff5f57; } .pv-bar i:nth-child(2) { background: #febc2e; } .pv-bar i:nth-child(3) { background: #28c840; }
.pv-bar .url { margin-left: 14px; flex: 1; font-family: var(--mono); font-size: .72rem; color: var(--faint); background: #0e0e10; border-radius: 5px; padding: 7px 12px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.pv-frame { display: block; width: 100%; height: 70vh; min-height: 460px; border: 0; background: #fff; }
.pv-device[data-w="mobile"] .pv-frame, .pv-device[data-w="tablet"] .pv-frame { height: 74vh; }

/* fullscreen */
.pv-device.is-full { position: fixed; inset: 0; z-index: 500; max-width: none; padding: 0; background: #fff; border-radius: 0; }
.pv-device.is-full .pv-frame-wrap { height: 100vh; border: 0; border-radius: 0; box-shadow: none; }
.pv-device.is-full .pv-frame { height: calc(100vh - 45px); }
.pv-exit-full { display: none; position: fixed; top: 16px; right: 16px; z-index: 510; font-family: var(--mono); font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; background: var(--red); color: #fff; border: 0; padding: 11px 18px; border-radius: 6px; }
.pv-device.is-full ~ .pv-exit-full, body.pv-fullscreen .pv-exit-full { display: inline-flex; }

/* code panel */
.pv-code { display: none; margin-top: 28px; border: 1px solid var(--line); border-radius: 10px; overflow: hidden; background: var(--surface); }
.pv-code.open { display: block; }
.pv-code .ch { display: flex; justify-content: space-between; align-items: center; padding: 14px 18px; border-bottom: 1px solid var(--line); }
.pv-code .ch span { font-family: var(--mono); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--faint); }
.pv-code pre { margin: 0; padding: 20px; overflow: auto; max-height: 520px; font-family: var(--mono); font-size: .8rem; line-height: 1.6; color: #cdd0d6; }
.pv-code pre::-webkit-scrollbar { width: 10px; height: 10px; } .pv-code pre::-webkit-scrollbar-thumb { background: var(--line-2); border-radius: 6px; }
.pv-notfound { padding: 100px 0; text-align: center; }

/* ---------- ADMIN ---------- */
.admin-login { max-width: 520px; margin: 0 auto; }
.admin-app[hidden], .admin-login[hidden] { display: none !important; }
.pin-card { max-width: 430px; margin-inline: auto; text-align: center; box-shadow: 0 24px 80px -44px var(--red-glow); }
.pin-card h3 { font-family: var(--mono); letter-spacing: .16em; text-transform: uppercase; }
.pin-form { display: grid; gap: 18px; }
.pin-input { position: absolute; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.pin-dots { display: flex; justify-content: center; gap: 12px; margin: 4px 0 8px; }
.pin-dots span {
  width: 13px; height: 13px; border-radius: 50%;
  border: 1px solid var(--line-2); background: var(--bg-2);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.02);
  transition: background .2s var(--ease), border-color .2s var(--ease), box-shadow .2s var(--ease), transform .2s var(--ease);
}
.pin-dots span.filled { background: var(--red); border-color: var(--red); box-shadow: 0 0 20px var(--red-glow); transform: scale(1.05); }
.pin-pad { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.pin-key {
  min-height: 62px; aspect-ratio: 1 / 1; border: 1px solid var(--line-2); border-radius: 8px;
  background: linear-gradient(180deg, var(--surface-2), var(--bg-2)); color: var(--text);
  font-family: var(--mono); font-size: 1.1rem; font-weight: 700;
  transition: transform .18s var(--ease), border-color .18s var(--ease), background .18s var(--ease), color .18s var(--ease), box-shadow .18s var(--ease);
}
.pin-key:hover, .pin-key:focus-visible { border-color: var(--red); color: #fff; box-shadow: 0 0 24px -12px var(--red); outline: none; }
.pin-key:active { transform: scale(.96); background: var(--red); }
.pin-key--soft { color: var(--faint); font-size: .72rem; letter-spacing: .12em; }
.pin-submit { width: 100%; justify-content: center; margin-top: 2px; }
.admin-tabs { display: flex; gap: 6px; flex-wrap: wrap; border-bottom: 1px solid var(--line); margin-bottom: 40px; }
.admin-lock-row { display: flex; justify-content: flex-end; margin: -24px 0 34px; }
.admin-tabs button { background: transparent; border: 0; color: var(--muted); font-family: var(--mono); font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; padding: 14px 18px; position: relative; transition: color .25s var(--ease); }
.admin-tabs button::after { content: ""; position: absolute; left: 14px; right: 14px; bottom: -1px; height: 2px; background: var(--red); transform: scaleX(0); transition: transform .3s var(--ease); }
.admin-tabs button.active { color: var(--text); } .admin-tabs button.active::after { transform: scaleX(1); }
.admin-tabs button:hover { color: var(--text); }
.admin-panel { display: none; } .admin-panel.active { display: block; }
.admin-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: start; }
@media (max-width: 900px){ .admin-grid { grid-template-columns: 1fr; } }
.admin-card { border: 1px solid var(--line); border-radius: 10px; background: var(--surface); padding: 28px; }
.admin-card h3 { font-size: 1.15rem; margin-bottom: 6px; }
.admin-card .hint { color: var(--faint); font-size: .85rem; margin-bottom: 22px; font-family: var(--mono); }
.admin-list { display: flex; flex-direction: column; gap: 12px; }
.admin-item { display: flex; align-items: center; gap: 14px; border: 1px solid var(--line); border-radius: 8px; padding: 14px 16px; background: var(--bg-2); transition: border-color .25s var(--ease); }
.admin-item:hover { border-color: var(--line-2); }
.admin-item .sw { width: 30px; height: 30px; border-radius: 6px; flex-shrink: 0; border: 1px solid var(--line-2); background: #333; overflow: hidden; }
.admin-item .sw img { width: 100%; height: 100%; object-fit: cover; }
.admin-item .info { flex: 1; min-width: 0; }
.admin-item .info b { display: block; font-size: .98rem; }
.admin-item .info small { color: var(--faint); font-family: var(--mono); font-size: .72rem; }
.admin-item .acts { display: flex; gap: 6px; }
.icon-btn { width: 34px; height: 34px; border: 1px solid var(--line-2); background: transparent; color: var(--muted); border-radius: 6px; display: grid; place-items: center; font-size: .85rem; transition: color .25s var(--ease), border-color .25s var(--ease); }
.icon-btn:hover { color: var(--text); border-color: var(--red); }
.icon-btn.danger:hover { color: #fff; border-color: var(--red); background: var(--red); }
.field code-area, .code-area { font-family: var(--mono); font-size: .82rem; min-height: 220px; line-height: 1.5; white-space: pre; }
.swatches { display: flex; gap: 8px; flex-wrap: wrap; }
.swatches button { width: 32px; height: 32px; border-radius: 6px; border: 2px solid transparent; cursor: pointer; }
.swatches button.sel { border-color: #fff; }
.admin-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 22px; }
.admin-note { font-family: var(--mono); font-size: .76rem; color: var(--faint); line-height: 1.6; }
.admin-toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(120%); background: var(--red); color: #fff; font-family: var(--mono); font-size: .78rem; letter-spacing: .06em; padding: 14px 22px; border-radius: 8px; z-index: 600; transition: transform .4s var(--ease); box-shadow: 0 20px 50px -20px rgba(0,0,0,.8); }
.admin-toast.show { transform: translateX(-50%) translateY(0); }
.mini-preview { border: 1px solid var(--line); border-radius: 8px; overflow: hidden; background: #fff; margin-top: 12px; }
.mini-preview iframe { width: 100%; height: 220px; border: 0; display: block; }
.btn-row { display: flex; gap: 10px; flex-wrap: wrap; }
