@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;600;700;800&family=Space+Grotesk:wght@600;700&display=swap');

:root {
  
  /* Neo‑brutalist candy palette */
  --bg: #f3e8ff;        /* lavender canvas */
  --bg-2: #e8fff4;      /* mint secondary */
  --fg: #0f0f0f;        /* ink */
  --lime: #d9ff3f;      /* acid lime */
  --grape: #b388ff;     /* purple */
  --cyan: #71e7ff;      /* pop cyan */
  --orange: #ffb65c;    /* warm accent */
  --accent: var(--cyan);
  --accent2: #ff6db6;   /* pink */
  --muted: #4f4f4f;
  --card: #ffffff;
  --border: #000000;
  --shadow: 6px 6px 0 #000;
  --radius: 14px;
  --img-solid: #f1eaff; /* soft lavender for transparent PNGs */
}
/* Dark theme overrides */
:root[data-theme="dark"] {
  /* Apply UI.md dark palette */
  --bg: #000000;         /* primary background */
  --bg-2: #1a1a1a;       /* secondary/badge surface */
  --fg: #ffffff;         /* primary text */
  --card: #1a1a1a;       /* card elements */
  --lime: #ffeb3b;       /* accent 1 (primary highlight/buttons) */
  --accent: var(--lime); /* keep accent mapped to primary */
  --accent2: #f44336;    /* accent 2 (danger/warnings) */
  --cyan: #2196f3;       /* accent 3 (links/alt actions) */
  --grape: #c3a2ff;      /* optional tertiary */
  --orange: #ffb36a;     /* optional tertiary */
  --muted: #bdbdbd;      /* subdued text/icons (brighter for readability) */
  --border: #000000;     /* strong neo-brutal outlines */
  --shadow: 6px 6px 0 #000000;
  --img-solid: #111111;  /* solid fill for transparent PNGs */
}
* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0; color: var(--fg);
  font-family: 'Manrope', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Inter, "Helvetica Neue", Arial, sans-serif;
  background:
    linear-gradient(0deg, transparent 0 49%, rgba(0,0,0,0.04) 50%, transparent 51%) 0 0/100% 40px,
    linear-gradient(90deg, transparent 0 49%, rgba(0,0,0,0.04) 50%, transparent 51%) 0 0/40px 100%,
    var(--bg);
}
/* Dark grid background tone */
:root[data-theme="dark"] body,
:root[data-theme="dark"] html {
  background:
    linear-gradient(0deg, transparent 0 49%, rgba(255,255,255,0.06) 50%, transparent 51%) 0 0/100% 40px,
    linear-gradient(90deg, transparent 0 49%, rgba(255,255,255,0.06) 50%, transparent 51%) 0 0/40px 100%,
    var(--bg);
}

/* Component-level dark surfaces to keep contrast high */
:root[data-theme="dark"] .btn-ghost { background: var(--card); color: var(--fg); }
:root[data-theme="dark"] .btn { color: #000; }
:root[data-theme="dark"] .btn.btn-accent { color: #ffffff; }
:root[data-theme="dark"] .btn.btn-ghost { color: var(--fg); }
/* Improve placeholder and subtle text contrast in dark mode */
:root[data-theme="dark"] ::placeholder { color: var(--muted); opacity: 1; }
:root[data-theme="dark"] .input,
:root[data-theme="dark"] select { background: var(--card); color: var(--fg); }
:root[data-theme="dark"] .file-drop { background: var(--card); }
:root[data-theme="dark"] .nft { background: #1f2430; }
:root[data-theme="dark"] .table tbody tr { background: #1f2430; }
:root[data-theme="dark"] .stat { background: var(--card); }
:root[data-theme="dark"] .pill { background: var(--card); color: var(--fg); }
:root[data-theme="dark"] .avatar { background: var(--card); }
:root[data-theme="dark"] .toast .close { background: var(--card); color: var(--fg); }
/* Improve toast readability in dark mode: use dark text on bright toasts */
:root[data-theme="dark"] .toast .title { color: #0f0f0f; }
:root[data-theme="dark"] .toast .msg { color: #0f0f0f; }
/* Keep variant backgrounds but ensure strong contrast */
:root[data-theme="dark"] .toast { border-color: var(--border); }

/* Dark-mode skeleton shimmer */
:root[data-theme="dark"] .skeleton { background: linear-gradient(90deg, #2a2e3a, #222733, #2a2e3a); }

/* Theme toggle compact button */
#themeToggle.btn {
  padding: 8px 10px;
  line-height: 1;
}
.old-standard-tt-regular-italic {
  font-family: "Old Standard TT", serif;
  font-weight: 400;
  font-style: italic;
}
.container { max-width: 1080px; margin: 0 auto; padding: 20px; }
.row { display: flex; }
.between { justify-content: space-between; }
.center { align-items: center; }
.gap { gap: 12px; }
.wrap { flex-wrap: wrap; }
.mt { margin-top: 16px; }
.small { font-size: 12px; }
.muted { color: var(--muted); }
.title { font-size: 32px; margin: 0 0 8px; }
.subtitle { font-size: 22px; margin: 0 0 10px; }
.logo { font-family: "Old Standard TT", serif; font-style: italic; font-size: 26px; margin: 0; padding: 8px 12px; border: 3px solid var(--border); background: var(--lime); box-shadow: var(--shadow); border-radius: var(--radius); letter-spacing: 0.5px; color: #000; }

/* Display face for loud UI elements (keeps logo font untouched) */
h1, h2, h3, .title, .subtitle, .btn, .pill, .badge, .nav-link { font-family: 'Space Grotesk', 'Manrope', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Inter, Arial, sans-serif; }

.nb-header { background: var(--card); border-bottom: 3px solid var(--border); position: sticky; top: 0; z-index: 10; }
.nav { display: flex; gap: 14px; }
.nav-link { text-decoration: none; color: var(--fg); font-weight: 800; padding: 8px 12px; border: 3px solid var(--border); background: var(--card); box-shadow: var(--shadow); border-radius: var(--radius); }
.nav-link:hover { transform: translate(-2px, -2px); }
.nav-link.active { outline: 3px solid var(--border); background: var(--cyan); color: #000; }
:root[data-theme="dark"] .nav-link.active { color: #fff; }
.nav-link-discord { background: #ff4b4b; color: #fff; }
:root[data-theme="dark"] .nav-link-discord { background: #ff4b4b; color: #fff; }
.nav-link-github { background: #1f6feb; color: #fff; }
:root[data-theme="dark"] .nav-link-github { background: #1f6feb; color: #fff; }

/* Simple running text ticker used on Market page */
.ticker {
  margin-top: 8px;
  border: 3px solid var(--border);
  background: #000;
  color: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
  padding: 6px 0;
  font-size: 13px;
  font-weight: 800;
}
.ticker-track {
  display: flex;
  gap: 20px;
  white-space: nowrap;
  animation: ticker-scroll 20s linear infinite;
  width: max-content;
}
.ticker span { letter-spacing: 0.03em; }
@keyframes ticker-scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.badge { display: inline-block; font-size: 12px; padding: 6px 10px; border: 3px solid var(--border); background: var(--bg-2); box-shadow: var(--shadow); border-radius: 999px; }

.btn { border: 3px solid var(--border); background: var(--lime); padding: 12px 16px; font-weight: 900; box-shadow: var(--shadow); cursor: pointer; border-radius: var(--radius); text-decoration: none; color: var(--fg); display: inline-block; }
/* Ensure anchor-buttons never get purple/underlines */
a.btn, a.btn:link, a.btn:visited, a.btn:hover, a.btn:active { color: inherit; text-decoration: none; }
.btn:hover { transform: translate(-2px, -2px); }
.btn:disabled { opacity: 0.6; cursor: not-allowed; }
.btn-ghost { background: #fff; }
.btn-accent { background: var(--accent2); }

/* Focus visibility for keyboard users */
.btn:focus-visible, .nav-link:focus-visible, .close:focus-visible, input:focus-visible, select:focus-visible { outline: 3px dashed var(--accent2); outline-offset: 2px; }

.input, select { border: 3px solid var(--border); padding: 12px 14px; background: #fff; font-weight: 800; min-width: 220px; box-shadow: var(--shadow); border-radius: var(--radius); }
.label { font-size: 12px; color: var(--muted); margin-bottom: 6px; }
.stack { display: flex; flex-direction: column; }
.sr-only { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* Upload drop zone (neo‑brutal) */
.file-drop { display: flex; align-items: center; gap: 10px; border: 3px dashed var(--border); padding: 12px; margin-top: 8px; background: #fff; box-shadow: var(--shadow); border-radius: var(--radius); cursor: pointer; }
.file-drop:hover { transform: translate(-2px, -2px); }
.file-drop.drag { background: var(--cyan); border-style: solid; }

.card { background: var(--card); border: 3px solid var(--border); padding: 22px; margin-top: 16px; box-shadow: var(--shadow); border-radius: var(--radius); position: relative; }
.card .badge-sticker { position: absolute; top: -12px; left: -12px; background: var(--orange); border: 3px solid var(--border); padding: 6px 10px; font-weight: 900; box-shadow: var(--shadow); transform: rotate(-6deg); color: #000; }
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; }
/* Wider card grid used on Manage page to avoid cramped forms */
.grid-320 { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 18px; }
.nft { border: 3px solid var(--border); padding: 12px; background: #eafaff; box-shadow: var(--shadow); border-radius: var(--radius); }
.nft img { width: 100%; aspect-ratio: 1 / 1; object-fit: contain; border: 3px solid var(--border); border-radius: var(--radius);
  /* playful colored checker */
  background:
    linear-gradient(45deg, var(--bg) 25%, transparent 25%) 0 0/16px 16px,
    linear-gradient(45deg, transparent 75%, var(--bg) 75%) 0 0/16px 16px,
    linear-gradient(45deg, transparent 75%, var(--bg) 75%) 8px 8px/16px 16px,
    linear-gradient(45deg, var(--bg) 25%, transparent 25%) 8px 8px/16px 16px,
    radial-gradient(ellipse at 30% 20%, var(--bg-2), transparent 60%);
}
.nft .meta { font-size: 12px; word-break: break-all; margin-top: 8px; }
/* Market card spacing when title sits above image */
.page-market .nft .meta:first-of-type { margin-top: 0; margin-bottom: 8px; }
.page-market .nft img { margin-top: 6px; margin-bottom: 10px; }
/* Emphasize name, de-emphasize symbol + id on market cards */
.page-market .nft .meta:first-of-type strong { font-size: 16px; }
.page-market .nft .meta:first-of-type span { font-size: 12px; color: var(--muted); font-weight: 700; }

/* Mint cards: same header layout as market */
.page-mint .nft .meta:first-of-type { margin-top: 0; margin-bottom: 8px; }
.page-mint .nft img { margin-top: 6px; margin-bottom: 10px; }
.page-mint .nft .meta:first-of-type strong { font-size: 16px; }
.page-mint .nft .meta:first-of-type span { font-size: 12px; color: var(--muted); font-weight: 700; }
/* Remove default link styling for names inside cards */
.page-mint .nft .meta a { color: inherit; text-decoration: none; }
.page-market .nft .meta a { color: inherit; text-decoration: none; }
.hero { width: 280px; height: 180px; object-fit: cover; border: 3px solid #000; box-shadow: var(--shadow); border-radius: var(--radius); }

footer { padding-bottom: 30px; }

@media (max-width: 720px) {
  .row.between { flex-direction: column; align-items: flex-start; gap: 14px; }
  .hero { width: 100%; height: 200px; }
}

/* Neobrutal toasts */
.toast-container { position: fixed; right: 16px; bottom: 16px; display: flex; flex-direction: column; gap: 10px; z-index: 9999; pointer-events: none; }
.toast { pointer-events: auto; border: 3px solid var(--border); background: var(--lime); box-shadow: var(--shadow); padding: 12px 14px; min-width: 280px; max-width: 420px; font-weight: 800; transform: translateY(16px); opacity: 0; animation: toast-in 220ms ease-out forwards; border-radius: var(--radius); }
.toast.success { background: #b7ff8f; }
.toast.error { background: #ffb3ba; }
.toast.info { background: #c6e6ff; }
.toast .title { font-size: 16px; margin: 0 0 6px; }
.toast .msg { font-size: 13px; word-break: break-all; }
.toast .actions { margin-top: 10px; display: flex; gap: 8px; }
.toast .close { position: absolute; top: -10px; right: -10px; border: 3px solid var(--border); background: #fff; width: 28px; height: 28px; border-radius: 50%; font-weight: 900; cursor: pointer; box-shadow: var(--shadow); }

@keyframes toast-in { from { transform: translateY(16px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@keyframes toast-out { from { transform: translateY(0); opacity: 1; } to { transform: translateY(16px); opacity: 0; } }

/* Deploy two-column layout + square preview */
.deploy-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; }
.page-deploy #depPriceUsd { margin-top: 6px; line-height: 1.2; }
.page-deploy #depPriceUsd + label { margin-top: 8px !important; }
.square-frame { position: relative; width: 100%; aspect-ratio: 1 / 1; border: 3px solid var(--border); border-radius: var(--radius);
  background:
    linear-gradient(45deg, var(--bg) 25%, transparent 25%) 0 0/24px 24px,
    linear-gradient(45deg, transparent 75%, var(--bg) 75%) 0 0/24px 24px,
    linear-gradient(45deg, transparent 75%, var(--bg) 75%) 12px 12px/24px 24px,
    linear-gradient(45deg, var(--bg) 25%, transparent 25%) 12px 12px/24px 24px,
    radial-gradient(circle at 70% 30%, var(--bg-2), transparent 50%);
  box-shadow: var(--shadow);
}
.square-frame img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: contain; background: none; }
.square-frame img:not([src]), .square-frame img[src=""] { display: none; }
.square-frame .placeholder { position: absolute; inset: 0; display: grid; place-items: center; text-align: center; padding: 10px; font-weight: 900; color: var(--fg); }
.square-frame .placeholder .mini { font-size: 12px; color: var(--muted); font-weight: 700; margin-top: 6px; }
.deploy-actions { display: flex; gap: 10px; justify-content: flex-end; align-items: center; margin-top: 12px; }
.help { color: var(--muted); font-size: 12px; max-width: 340px; }

/* Skeletons */
.skeleton { background: linear-gradient(90deg, #eee, #f8f8f8, #eee); background-size: 200% 100%; animation: skel 1.2s linear infinite; border: 0; box-shadow: none; border-radius: var(--radius); }
.skeleton.block { height: 160px; }
.skeleton.text { height: 14px; margin-top: 10px; width: 60%; }
@keyframes skel { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* Utility */
.hidden { display: none !important; }
.hide { display: none !important; }
.toast.closing { animation: toast-out 180ms ease-in forwards; }

/* Market tables */
.table { width: 100%; border-collapse: separate; border-spacing: 0; }
.table thead th { text-align: left; font-size: 12px; color: var(--muted); padding: 10px 12px; border-bottom: 3px solid var(--border); }
.table tbody tr { background: #eafaff; }
.table tbody tr + tr td { border-top: 3px solid var(--border); }
.table tbody td { padding: 12px; vertical-align: middle; }
.table .cell-name { display: flex; align-items: center; gap: 10px; }
.avatar { width: 36px; height: 36px; object-fit: cover; border: 3px solid var(--border); background: #fff; border-radius: 50%; }
.pill { display: inline-block; padding: 2px 8px; border: 3px solid var(--border); background: #fff; font-weight: 800; }
.input-search { border: 3px solid var(--border); padding: 8px 10px; font-weight: 700; box-shadow: var(--shadow); width: 100%; max-width: 360px; }
.toolbar { display: flex; gap: 12px; align-items: center; justify-content: space-between; margin-top: 8px; margin-bottom: 8px; }
.toolbar .subtitle { margin: 0; }
/* Market collection layout tune */
.page-market-coll .toolbar { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.page-market-coll #statsRow { margin-top: 8px; }
.page-market-coll #itemsWrap { margin-top: 12px; }
.page-market-coll #collPreviewBox { align-self: flex-start; }
.page-market-coll #collPreviewBox img { width: 100%; height: 100%; object-fit: contain; }
.page-market-coll .coll-hero { position: absolute; top: 22px; right: 22px; width: 290px; height: 290px; border: 3px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); background: var(--img-solid); overflow: hidden; }
.page-market-coll .coll-hero img { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (max-width: 1150px) { .page-market-coll .coll-hero { width: 250px; height: 250px; } }
@media (max-width: 850px) { .page-market-coll .coll-hero { display: none; } }
.page-market-coll #collPreviewBox { position: static; top: auto; }
/* Mint collection toolbar alignment (title + stats left, button top-right) */
.page-mint-coll .toolbar { align-items: flex-start; gap: 16px; }
.page-mint-coll .toolbar > .stack { flex: 1 1 auto; min-width: 0; }
.page-mint-coll #viewMarketBtn { align-self: flex-start; margin-top: 4px; }
@media (max-width: 720px) {
  .page-mint-coll .toolbar { flex-direction: column; align-items: stretch; }
  .page-mint-coll #viewMarketBtn { align-self: flex-start; }
}
/* Stats */
.stats-row { display: grid; grid-template-columns: repeat(3, minmax(140px, 1fr)); gap: 10px; }
.page-mint-coll #statsRow { grid-template-columns: repeat(4, minmax(140px, 1fr)); }
@media (max-width: 860px) { .page-mint-coll #statsRow { grid-template-columns: repeat(2, minmax(140px, 1fr)); } }
.stat { border: 3px solid var(--border); background: #fff; box-shadow: var(--shadow); padding: 10px 12px; }
.stat .label { font-size: 12px; color: var(--muted); font-weight: 800; }
.stat .value { font-size: 16px; font-weight: 900; margin-top: 4px; }
.stat .sub { font-size: 12px; margin-top: 2px; color: var(--muted); }

/* Wallet popover */
.popover { position: absolute; border: 3px solid var(--border); background: var(--card); box-shadow: var(--shadow); padding: 10px 12px; z-index: 10001; min-width: 240px; border-radius: var(--radius); }
.popover .title { font-weight: 900; margin: 0 0 6px; font-size: 14px; }
.popover .row { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.popover .muted { color: var(--muted); }
.popover .addr { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; overflow-wrap: anywhere; }
.popover .actions { display: flex; gap: 8px; margin-top: 10px; justify-content: flex-end; }

/* Wallet hover menu */
.wallet-menu { position: fixed; top: 64px; right: 16px; width: 320px; max-width: calc(100vw - 32px); border: 3px solid var(--border); background: var(--card); box-shadow: var(--shadow); border-radius: var(--radius); z-index: 10002; transform: translateX(16px); opacity: 0; pointer-events: none; }
.wallet-menu.open { animation: slide-in-right 160ms ease-out forwards; pointer-events: auto; }
.wallet-menu.closing { animation: slide-out-right 140ms ease-in forwards; }
.wallet-menu .wm-header { padding: 12px; border-bottom: 3px solid var(--border); display: flex; align-items: center; gap: 10px; }
.wallet-menu .wm-addr { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-weight: 800; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.wallet-menu .wm-copy { margin-left: auto; }
.wallet-menu .wm-section { padding: 12px; }
.wallet-menu .wm-row { display: flex; gap: 10px; }
.wallet-menu .wm-list { list-style: none; margin: 0; padding: 0; }
.wallet-menu .wm-list li { padding: 10px 12px; font-weight: 800; cursor: pointer; border-top: 3px solid var(--border); }
.wallet-menu .wm-list li:hover { background: var(--bg-2); }
.wallet-menu .wm-footer { padding: 12px; border-top: 3px solid var(--border); display: flex; justify-content: flex-end; }

@keyframes slide-in-right { from { transform: translateX(16px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes slide-out-right { from { transform: translateX(0); opacity: 1; } to { transform: translateX(16px); opacity: 0; } }

/* Mint collection layout */
.page-mint-coll .mc-wrap { display: grid; grid-template-columns: minmax(320px, 1fr) 420px; gap: 16px; align-items: start; }
@media (max-width: 980px) { .page-mint-coll .mc-wrap { grid-template-columns: 1fr; } }

/* Manage (owner dashboard) */
.page-manage .cards-grid { margin-top: 12px; }
.page-manage .manage-card { box-shadow: var(--shadow); border: 3px solid var(--border); background: var(--card); border-radius: var(--radius); padding: 14px; display: grid; gap: 12px; }
.page-manage .manage-head { display: flex; gap: 12px; align-items: center; justify-content: space-between; }
.page-manage .manage-left { display: flex; gap: 12px; align-items: center; min-width: 0; }
.page-manage .manage-title { margin: 0; }
.page-manage .manage-sub { font-size: 12px; color: var(--muted); overflow: hidden; text-overflow: ellipsis; }
.page-manage .manage-meta { display: grid; grid-auto-flow: row; gap: 10px; }
.page-manage .form-row { display: flex; gap: 10px; align-items: center; }
.page-manage .form-row > * { flex: 1 1 0; min-width: 0; }
.page-manage .hint { font-size: 12px; color: var(--muted); }
.page-manage .manage-actions { display: flex; justify-content: flex-end; gap: 10px; }
.page-manage .mini-badge { font-size: 11px; padding: 4px 8px; border: 3px solid var(--border); background: var(--bg-2); border-radius: 999px; font-weight: 800; }
.page-manage .square-frame { width: 56px; height: 56px; }
.page-manage input[type="datetime-local"] { width: 100%; }
.page-manage .input { width: 100%; }
.page-mint-coll .media-frame { border: 3px solid var(--border); background: repeating-conic-gradient(#0000 0 15deg, rgba(0,0,0,.08) 0 30deg); border-radius: var(--radius); box-shadow: var(--shadow); padding: 8px; max-height: 520px; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.page-mint-coll #heroImg { width: 100%; height: 100%; object-fit: contain; aspect-ratio: auto; background: var(--img-solid); border: 3px solid var(--border); border-radius: var(--radius); }
.page-mint-coll .mc-thumbs .avatar { width: 56px; height: 56px; }
.page-mint-coll .mc-side .card { position: sticky; top: 84px; }
.page-mint-coll .mc-live { overflow: hidden; }
.page-mint-coll .mc-live .table { width: 100%; }
.page-mint-coll .mc-live .table thead th, .page-mint-coll .mc-live .table tbody td { font-size: 12px; }

/* Modal (neo‑brutalism) */
.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.35); display: flex; align-items: center; justify-content: center; z-index: 10000; opacity: 1; transition: opacity .18s ease-in; }
.modal-overlay.closing { opacity: 0; }
.modal { width: 100%; max-width: 440px; border: 3px solid var(--border); background: var(--card); padding: 18px; box-shadow: var(--shadow); animation: pop-in 140ms ease-out; border-radius: var(--radius); }
.modal .title { font-size: 20px; font-weight: 900; margin: 0 0 8px; }
.modal .actions { justify-content: flex-end; }
.row.right { justify-content: flex-end; }
@keyframes pop-in { from { transform: translateY(8px); opacity: .9; } to { transform: translateY(0); opacity: 1; } }

/* Modal inline error */
.modal .error { margin-top: 8px; font-weight: 800; border: 3px solid var(--border); background: #ffb3ba; padding: 8px 10px; box-shadow: var(--shadow); }

/* Doodles & shapes */
.shape { position: absolute; pointer-events: none; z-index: 0; filter: drop-shadow(6px 6px 0 #000); }
.shape.squiggle { width: 120px; height: 24px; background: repeating-linear-gradient(90deg, var(--lime) 0 18px, var(--grape) 18px 36px); border: 3px solid var(--border); border-radius: 12px; transform: skewX(-8deg); }
.shape.eye { width: 48px; height: 32px; background: #fff; border: 3px solid var(--border); border-radius: 16px; display: grid; place-items: center; }
.shape.eye::after { content: ""; width: 12px; height: 12px; background: #000; border-radius: 50%; transform: translate(4px,2px); }

/* Home hero variations */
.hero-wrap { position: relative; }
.hero-wrap .shape.squiggle { right: -10px; bottom: -12px; }

/* Page-specific image backgrounds */
.page-home .nft img,
.page-mint .nft img,
.page-market .nft img,
.page-market-coll .nft img,
.page-collection .nft img { background: var(--img-solid) !important; }

/* Updates widget */
.updates-list { display: grid; gap: 10px; }
.update-item { border: 3px solid var(--border); background: var(--card); padding: 10px 12px; box-shadow: var(--shadow); border-radius: var(--radius); }

/* Collapsible panel (animated height) */
.collapsible { overflow: hidden; max-height: 0; transition: max-height .22s ease; }
.collapsible.open { max-height: 1200px; }

/* Small button variant for headers */
.btn.btn-small { padding: 6px 10px; font-size: 12px; line-height: 1; }
