/* ============================================================
   CardsCloud — Apple-inspired design system
   Single shared stylesheet for layout shell + all child pages.
   Light + dark tokens, components, motion utilities.
   ============================================================ */

/* ---------- Tokens (light, default) ---------- */
:root {
    /* surfaces */
    --cc-bg:          #fbfbfd;
    --cc-surface:     #ffffff;
    --cc-surface-2:   #f5f5f7;
    --cc-surface-3:   #ececf0;

    /* ink */
    --cc-ink:         #1d1d1f;
    --cc-ink-2:       #515154;
    --cc-ink-3:       #86868b;
    --cc-ink-mute:    #a1a1a6;

    /* lines + glass */
    --cc-line:        rgba(0,0,0,0.10);
    --cc-line-soft:   rgba(0,0,0,0.06);
    --cc-glass:       rgba(255,255,255,0.72);
    --cc-glass-line:  rgba(0,0,0,0.08);

    /* accents */
    --cc-accent:      #0071e3;
    --cc-accent-deep: #0058b0;
    --cc-accent-2:    #bf4800;
    --cc-poke-red:    #d70015;
    --cc-success:     #1f8a4e;
    --cc-warning:     #b25e09;
    --cc-danger:      #d70015;

    /* shadows */
    --cc-shadow-sm:   0 1px 2px rgba(0,0,0,.05), 0 1px 1px rgba(0,0,0,.04);
    --cc-shadow:      0 8px 24px -12px rgba(0,0,0,.12);
    --cc-shadow-md:   0 20px 60px -20px rgba(0,0,0,.18);
    --cc-shadow-lg:   0 30px 80px -30px rgba(0,0,0,.25);

    /* radii */
    --cc-r-sm:        10px;
    --cc-r-md:        14px;
    --cc-r-lg:        20px;
    --cc-r-xl:        28px;
    --cc-r-pill:      999px;

    /* spacing scale */
    --cc-s-1:         4px;
    --cc-s-2:         8px;
    --cc-s-3:         12px;
    --cc-s-4:         16px;
    --cc-s-5:         20px;
    --cc-s-6:         24px;
    --cc-s-8:         32px;
    --cc-s-10:        40px;
    --cc-s-12:        48px;
    --cc-s-16:        64px;
    --cc-s-20:        80px;

    /* type */
    --cc-font: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", "Segoe UI", system-ui, sans-serif;
    --cc-font-mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace;

    /* motion */
    --cc-ease:        cubic-bezier(.4, 0, .2, 1);
    --cc-ease-soft:   cubic-bezier(.25, .1, .25, 1);
    --cc-dur-fast:    160ms;
    --cc-dur:         260ms;
    --cc-dur-slow:    560ms;

    /* layout */
    --cc-nav-h:       56px;
    --cc-max:         1180px;
}

/* ---------- Dark tokens ---------- */
[data-theme="dark"] {
    --cc-bg:          #000000;
    --cc-surface:     #161617;
    --cc-surface-2:   #1d1d1f;
    --cc-surface-3:   #2a2a2c;

    --cc-ink:         #f5f5f7;
    --cc-ink-2:       #d2d2d7;
    --cc-ink-3:       #a1a1a6;
    --cc-ink-mute:    #6e6e73;

    --cc-line:        rgba(255,255,255,0.12);
    --cc-line-soft:   rgba(255,255,255,0.06);
    --cc-glass:       rgba(22,22,23,0.72);
    --cc-glass-line:  rgba(255,255,255,0.10);

    --cc-accent:      #2997ff;
    --cc-accent-deep: #66b2ff;
    --cc-accent-2:    #ff8a3d;
    --cc-poke-red:    #ff453a;
    --cc-success:     #30d158;
    --cc-warning:     #ffb340;
    --cc-danger:      #ff453a;

    --cc-shadow-sm:   0 1px 2px rgba(0,0,0,.3);
    --cc-shadow:      0 8px 24px -12px rgba(0,0,0,.5);
    --cc-shadow-md:   0 20px 60px -20px rgba(0,0,0,.6);
    --cc-shadow-lg:   0 30px 80px -30px rgba(0,0,0,.75);
}

/* Auto dark if user prefers and no override */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) {
        --cc-bg:          #000000;
        --cc-surface:     #161617;
        --cc-surface-2:   #1d1d1f;
        --cc-surface-3:   #2a2a2c;
        --cc-ink:         #f5f5f7;
        --cc-ink-2:       #d2d2d7;
        --cc-ink-3:       #a1a1a6;
        --cc-ink-mute:    #6e6e73;
        --cc-line:        rgba(255,255,255,0.12);
        --cc-line-soft:   rgba(255,255,255,0.06);
        --cc-glass:       rgba(22,22,23,0.72);
        --cc-glass-line:  rgba(255,255,255,0.10);
        --cc-accent:      #2997ff;
        --cc-accent-deep: #66b2ff;
        --cc-accent-2:    #ff8a3d;
        --cc-poke-red:    #ff453a;
        --cc-success:     #30d158;
        --cc-warning:     #ffb340;
        --cc-danger:      #ff453a;
    }
}

/* ---------- Base ---------- */
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
    margin: 0;
    background: var(--cc-bg);
    color: var(--cc-ink);
    font-family: var(--cc-font);
    font-size: 16px;
    line-height: 1.5;
    letter-spacing: -0.011em;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
img { display: block; max-width: 100%; }
a { color: var(--cc-accent); text-decoration: none; transition: color var(--cc-dur-fast) var(--cc-ease); }
a:hover { color: var(--cc-accent-deep); }
button { font-family: inherit; cursor: pointer; }
input, select, textarea, button { font-family: inherit; color: inherit; }

::selection { background: color-mix(in oklab, var(--cc-accent) 30%, transparent); color: var(--cc-ink); }
:focus-visible { outline: 2px solid var(--cc-accent); outline-offset: 2px; border-radius: 6px; }

.sr-only {
    position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* Tabular numerics */
.tabnum, .cc-num { font-variant-numeric: tabular-nums; font-feature-settings: "tnum"; }

/* ---------- Typography ---------- */
h1, h2, h3, h4 { margin: 0; font-weight: 600; letter-spacing: -0.022em; line-height: 1.1; }
h1 { font-weight: 700; letter-spacing: -0.03em; }
.cc-display { font-size: clamp(40px, 6vw, 76px); font-weight: 700; letter-spacing: -0.04em; line-height: 1.05; }
.cc-h1 { font-size: clamp(28px, 3.5vw, 44px); font-weight: 700; letter-spacing: -0.025em; }
.cc-h2 { font-size: clamp(22px, 2.4vw, 32px); font-weight: 700; letter-spacing: -0.02em; }
.cc-h3 { font-size: clamp(18px, 1.6vw, 22px); font-weight: 600; }
.cc-lede { font-size: clamp(17px, 1.4vw, 21px); line-height: 1.45; color: var(--cc-ink-2); }
.cc-eyebrow {
    display: inline-block;
    font-size: 12px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.12em;
    color: var(--cc-accent); margin-bottom: 12px;
}
.cc-muted { color: var(--cc-ink-3); }
.cc-mute2 { color: var(--cc-ink-2); }

/* ---------- Layout containers ---------- */
.cc-page { background: var(--cc-bg); color: var(--cc-ink); min-height: 100vh; }
.cc-shell { max-width: var(--cc-max); margin: 0 auto; padding: 0 22px; }
.cc-section { padding: clamp(48px, 6vw, 88px) 22px; }
.cc-section-tight { padding: clamp(24px, 3vw, 40px) 22px; }

/* ---------- Header / Nav ---------- */
.cc-header {
    position: sticky; top: 0; z-index: 1000;
    background: var(--cc-glass);
    -webkit-backdrop-filter: saturate(180%) blur(20px);
    backdrop-filter: saturate(180%) blur(20px);
    border-bottom: 1px solid var(--cc-glass-line);
}
.cc-header-inner {
    max-width: var(--cc-max); margin: 0 auto;
    height: var(--cc-nav-h); padding: 0 22px;
    display: flex; align-items: center; gap: 14px;
}
.cc-brand {
    display: inline-flex; align-items: center; gap: 8px;
    color: var(--cc-ink); font-weight: 600; font-size: 17px;
    letter-spacing: -0.015em;
    flex-shrink: 0;
}
.cc-brand-mark {
    width: 26px; height: 26px;
    background: linear-gradient(135deg, var(--cc-poke-red), var(--cc-accent));
    border-radius: 7px;
    display: inline-grid; place-items: center;
    color: #fff;
}
.cc-brand-mark svg { width: 16px; height: 16px; }
.cc-brand:hover { color: var(--cc-ink); }

.cc-nav {
    display: flex; align-items: center; gap: 2px;
    margin-left: auto;
    flex: 1; justify-content: flex-end;
}
.cc-nav a {
    display: inline-flex; align-items: center; gap: 6px;
    height: 36px; padding: 0 12px;
    color: var(--cc-ink-2); font-size: 14px; font-weight: 500;
    border-radius: 8px;
    transition: background var(--cc-dur-fast) var(--cc-ease), color var(--cc-dur-fast) var(--cc-ease);
}
.cc-nav a:hover { background: var(--cc-surface-2); color: var(--cc-ink); }
.cc-nav a.is-active { color: var(--cc-ink); background: var(--cc-surface-2); }
.cc-nav a svg { width: 16px; height: 16px; opacity: .85; }
.cc-nav .cc-nav-cta {
    color: #fff; background: var(--cc-accent);
    padding: 0 14px;
}
.cc-nav .cc-nav-cta:hover { background: var(--cc-accent-deep); color: #fff; }
.cc-nav .cc-nav-ghost { color: var(--cc-ink-3); }

.cc-theme-toggle {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px;
    border-radius: 999px;
    border: 0; background: transparent;
    color: var(--cc-ink-2); cursor: pointer;
    transition: background var(--cc-dur-fast) var(--cc-ease), color var(--cc-dur-fast) var(--cc-ease);
}
.cc-theme-toggle:hover { background: var(--cc-surface-2); color: var(--cc-ink); }
.cc-theme-toggle svg { width: 18px; height: 18px; }
[data-theme="dark"] .cc-theme-toggle .sun { display: none; }
.cc-theme-toggle .moon { display: none; }
[data-theme="dark"] .cc-theme-toggle .moon { display: inline; }
:root:not([data-theme="dark"]) .cc-theme-toggle .sun { display: inline; }

.cc-burger {
    display: none;
    width: 36px; height: 36px; border-radius: 999px;
    background: transparent; border: 0; color: var(--cc-ink);
    align-items: center; justify-content: center;
    cursor: pointer;
    transition: background var(--cc-dur-fast) var(--cc-ease);
}
.cc-burger:hover { background: var(--cc-surface-2); }

/* Mobile-only theme toggle, sits next to the burger in the header.
   Hidden on desktop where the in-nav toggle is always visible. */
.cc-theme-toggle--mobile { display: none; margin-left: auto; }

@media (max-width: 820px) {
    .cc-burger { display: inline-flex; }
    .cc-theme-toggle--mobile { display: inline-flex; }
    /* The in-nav toggle becomes a duplicate inside the drawer on mobile.
       Keep it visible there so users can also toggle from the menu, but
       give it a proper full-width label-style treatment. */
    .cc-nav {
        position: fixed; top: var(--cc-nav-h); left: 0; right: 0;
        flex-direction: column; align-items: stretch;
        background: var(--cc-surface);
        border-bottom: 1px solid var(--cc-line);
        box-shadow: 0 20px 40px -20px rgba(0,0,0,.18);
        padding: 12px 16px 16px; gap: 4px;
        transform: translateY(-12px); opacity: 0; pointer-events: none;
        transition: transform var(--cc-dur) var(--cc-ease), opacity var(--cc-dur) var(--cc-ease);
        max-height: calc(100vh - var(--cc-nav-h));
        overflow-y: auto;
    }
    .cc-nav.is-open { transform: translateY(0); opacity: 1; pointer-events: auto; }
    .cc-nav a { height: 44px; border-radius: 999px; padding: 0 16px; }
    .cc-nav .cc-theme-toggle {
        align-self: flex-start;
        width: 44px; height: 44px;
        margin-top: 4px;
    }
}

/* ---------- Footer ---------- */
.cc-footer {
    border-top: 1px solid var(--cc-line);
    padding: 56px 22px 32px;
    background: var(--cc-surface-2);
    color: var(--cc-ink-2);
    margin-top: 64px;
}
.cc-footer-inner {
    max-width: var(--cc-max); margin: 0 auto;
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px;
}
.cc-footer h4 {
    font-size: 12px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--cc-ink); margin-bottom: 12px;
}
.cc-footer p, .cc-footer li { font-size: 13px; line-height: 1.55; color: var(--cc-ink-3); }
.cc-footer ul { list-style: none; padding: 0; margin: 0; }
.cc-footer li { margin-bottom: 6px; }
.cc-footer a { color: var(--cc-ink-2); }
.cc-footer a:hover { color: var(--cc-ink); }
.cc-footer-bottom {
    max-width: var(--cc-max); margin: 32px auto 0;
    padding-top: 24px; border-top: 1px solid var(--cc-line);
    font-size: 12px; color: var(--cc-ink-mute);
    display: flex; flex-wrap: wrap; gap: 16px; justify-content: space-between;
}
@media (max-width: 720px) {
    .cc-footer-inner { grid-template-columns: 1fr 1fr; gap: 24px; }
}

/* ---------- Buttons ---------- */
.cc-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    height: 44px; padding: 0 22px;
    border-radius: var(--cc-r-pill);
    border: 1px solid transparent;
    font-size: 15px; font-weight: 500; letter-spacing: -0.005em;
    cursor: pointer; user-select: none;
    transition: transform var(--cc-dur-fast) var(--cc-ease),
                background var(--cc-dur-fast) var(--cc-ease),
                color var(--cc-dur-fast) var(--cc-ease),
                box-shadow var(--cc-dur-fast) var(--cc-ease),
                border-color var(--cc-dur-fast) var(--cc-ease);
    white-space: nowrap;
}
.cc-btn--sm { height: 36px; padding: 0 16px; font-size: 13px; }
.cc-btn--lg { height: 52px; padding: 0 28px; font-size: 17px; }
.cc-btn--block { width: 100%; }
.cc-btn:active { transform: scale(0.98); }
.cc-btn svg { width: 16px; height: 16px; }

.cc-btn--primary { background: var(--cc-accent); color: #fff; border-color: var(--cc-accent); }
.cc-btn--primary:hover { background: var(--cc-accent-deep); border-color: var(--cc-accent-deep); color:#fff; }

.cc-btn--accent { background: var(--cc-poke-red); color: #fff; border-color: var(--cc-poke-red); }
.cc-btn--accent:hover { filter: brightness(0.92); color: #fff; }

.cc-btn--outline { background: transparent; color: var(--cc-ink); border-color: var(--cc-line); }
.cc-btn--outline:hover { background: var(--cc-surface-2); color: var(--cc-ink); }

.cc-btn--ghost { background: transparent; color: var(--cc-ink); }
.cc-btn--ghost:hover { background: var(--cc-surface-2); }

.cc-btn--danger { background: var(--cc-danger); color: #fff; border-color: var(--cc-danger); }
.cc-btn--danger:hover { filter: brightness(0.92); color: #fff; }

.cc-btn[disabled], .cc-btn--disabled { opacity: 0.45; pointer-events: none; }

.cc-link {
    display: inline-flex; align-items: center; gap: 4px;
    color: var(--cc-accent); font-weight: 500;
    transition: color var(--cc-dur-fast) var(--cc-ease);
}
.cc-link:hover { color: var(--cc-accent-deep); }
.cc-link .chevron { transition: transform var(--cc-dur-fast) var(--cc-ease); }
.cc-link:hover .chevron { transform: translateX(2px); }

/* ---------- Form fields ---------- */
.cc-field { display: block; margin-bottom: 16px; }
.cc-label {
    display: block;
    font-size: 13px; font-weight: 500;
    color: var(--cc-ink-2); margin-bottom: 6px;
}
.cc-input, .cc-select, .cc-textarea {
    width: 100%;
    height: 44px; padding: 0 14px;
    border-radius: 12px;
    background: var(--cc-surface);
    color: var(--cc-ink);
    border: 1px solid var(--cc-line);
    font-size: 15px; font-family: inherit;
    transition: border-color var(--cc-dur-fast) var(--cc-ease), box-shadow var(--cc-dur-fast) var(--cc-ease);
}
.cc-textarea { height: auto; min-height: 100px; padding: 12px 14px; line-height: 1.5; resize: vertical; }
.cc-input:focus, .cc-select:focus, .cc-textarea:focus {
    outline: none;
    border-color: var(--cc-accent);
    box-shadow: 0 0 0 3px color-mix(in oklab, var(--cc-accent) 18%, transparent);
}
.cc-input::placeholder, .cc-textarea::placeholder { color: var(--cc-ink-mute); }
.cc-hint { font-size: 12px; color: var(--cc-ink-3); margin-top: 4px; }
.cc-error-text { font-size: 13px; color: var(--cc-danger); margin-top: 4px; }

.cc-search {
    position: relative;
}
.cc-search .cc-input { padding-left: 44px; }
.cc-search svg {
    position: absolute; left: 14px; top: 50%;
    transform: translateY(-50%);
    width: 18px; height: 18px; color: var(--cc-ink-3);
    pointer-events: none;
}
.cc-kbd {
    display: inline-flex; align-items: center; justify-content: center;
    height: 22px; min-width: 22px; padding: 0 6px;
    border-radius: 6px;
    background: var(--cc-surface-2); color: var(--cc-ink-3);
    font-family: var(--cc-font-mono); font-size: 11px; font-weight: 500;
    border: 1px solid var(--cc-line);
}

.cc-checkbox { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; color: var(--cc-ink-2); cursor: pointer; }
.cc-checkbox input { accent-color: var(--cc-accent); width: 16px; height: 16px; }

/* Segmented control */
.cc-seg {
    display: inline-flex; padding: 2px;
    background: var(--cc-surface-2);
    border: 1px solid var(--cc-line);
    border-radius: var(--cc-r-pill);
}
.cc-seg button {
    background: transparent; border: 0; color: var(--cc-ink-2);
    padding: 6px 14px; border-radius: var(--cc-r-pill);
    font-size: 13px; font-weight: 500; cursor: pointer;
    transition: background var(--cc-dur-fast) var(--cc-ease), color var(--cc-dur-fast) var(--cc-ease);
    display: inline-flex; align-items: center; gap: 6px;
}
.cc-seg button:hover { color: var(--cc-ink); }
.cc-seg button.is-active { background: var(--cc-surface); color: var(--cc-ink); box-shadow: var(--cc-shadow-sm); }

/* ---------- Cards / surfaces ---------- */
.cc-card {
    background: var(--cc-surface);
    border: 1px solid var(--cc-line-soft);
    border-radius: var(--cc-r-lg);
    box-shadow: var(--cc-shadow-sm);
    transition: transform var(--cc-dur) var(--cc-ease), box-shadow var(--cc-dur) var(--cc-ease), border-color var(--cc-dur) var(--cc-ease);
}
.cc-card--hover:hover {
    transform: translateY(-4px);
    box-shadow: var(--cc-shadow-md);
    border-color: var(--cc-line);
}
.cc-card--padded { padding: 20px; }
.cc-card--frost {
    background: var(--cc-glass);
    -webkit-backdrop-filter: saturate(180%) blur(20px);
    backdrop-filter: saturate(180%) blur(20px);
    border-color: var(--cc-glass-line);
}

/* Chips / badges */
.cc-chip {
    display: inline-flex; align-items: center; gap: 6px;
    height: 28px; padding: 0 12px;
    border-radius: var(--cc-r-pill);
    background: var(--cc-surface-2);
    color: var(--cc-ink-2);
    font-size: 12px; font-weight: 500;
    border: 1px solid transparent;
    transition: background var(--cc-dur-fast) var(--cc-ease), color var(--cc-dur-fast) var(--cc-ease), border-color var(--cc-dur-fast) var(--cc-ease);
    cursor: pointer; user-select: none;
}
.cc-chip:hover { background: var(--cc-surface-3); color: var(--cc-ink); }
.cc-chip.is-active { background: var(--cc-accent); color: #fff; }
.cc-chip svg { width: 12px; height: 12px; }

.cc-badge {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 3px 10px; border-radius: 999px;
    background: var(--cc-surface-2); color: var(--cc-ink-2);
    font-size: 11px; font-weight: 600; letter-spacing: 0.02em;
}
.cc-badge--accent { background: color-mix(in oklab, var(--cc-accent) 14%, transparent); color: var(--cc-accent-deep); }
.cc-badge--success { background: color-mix(in oklab, var(--cc-success) 14%, transparent); color: var(--cc-success); }
.cc-badge--warning { background: color-mix(in oklab, var(--cc-warning) 16%, transparent); color: var(--cc-warning); }
.cc-badge--red { background: color-mix(in oklab, var(--cc-poke-red) 14%, transparent); color: var(--cc-poke-red); }

[data-theme="dark"] .cc-badge--accent { color: var(--cc-accent); }
[data-theme="dark"] .cc-badge--success { color: var(--cc-success); }

/* Tabs */
.cc-tabs {
    display: inline-flex; gap: 4px;
    border-bottom: 1px solid var(--cc-line);
    width: 100%;
}
.cc-tabs button {
    background: transparent; border: 0;
    padding: 12px 16px;
    color: var(--cc-ink-2); font-size: 14px; font-weight: 500;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    cursor: pointer;
    transition: color var(--cc-dur-fast) var(--cc-ease), border-color var(--cc-dur-fast) var(--cc-ease);
    display: inline-flex; align-items: center; gap: 6px;
}
.cc-tabs button:hover { color: var(--cc-ink); }
.cc-tabs button.is-active { color: var(--cc-ink); border-bottom-color: var(--cc-accent); }

/* ---------- Pokémon-card style tiles ---------- */
.cc-card-tile {
    position: relative;
    background: var(--cc-surface);
    border: 1px solid var(--cc-line-soft);
    border-radius: var(--cc-r-md);
    overflow: hidden;
    transition: transform var(--cc-dur) var(--cc-ease), box-shadow var(--cc-dur) var(--cc-ease), border-color var(--cc-dur) var(--cc-ease);
    color: var(--cc-ink);
    display: flex; flex-direction: column;
}
.cc-card-tile:hover {
    transform: translateY(-6px);
    box-shadow: var(--cc-shadow-md);
    border-color: var(--cc-line);
}
.cc-card-tile-art {
    position: relative;
    aspect-ratio: 245 / 342;
    background: linear-gradient(135deg, var(--cc-surface-2), var(--cc-surface-3));
    display: grid; place-items: center;
    overflow: hidden;
}
.cc-card-tile-art img {
    width: 100%; height: 100%; object-fit: contain;
    transition: transform var(--cc-dur-slow) var(--cc-ease);
}
.cc-card-tile:hover .cc-card-tile-art img { transform: scale(1.04); }
.cc-card-tile-body { padding: 12px 14px 14px; }
.cc-card-tile-title { font-size: 14px; font-weight: 600; color: var(--cc-ink); margin: 0 0 4px; }
.cc-card-tile-meta { font-size: 12px; color: var(--cc-ink-3); margin-bottom: 6px; display: flex; gap: 8px; flex-wrap: wrap; }
.cc-card-tile-price { font-size: 14px; font-weight: 600; color: var(--cc-ink); font-variant-numeric: tabular-nums; }
.cc-card-tile-add {
    position: absolute; top: 8px; right: 8px;
    width: 32px; height: 32px;
    border-radius: 999px;
    background: var(--cc-glass);
    -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
    border: 1px solid var(--cc-glass-line);
    display: inline-grid; place-items: center;
    color: var(--cc-ink); cursor: pointer;
    opacity: 0; transform: translateY(-4px);
    transition: opacity var(--cc-dur-fast) var(--cc-ease), transform var(--cc-dur-fast) var(--cc-ease);
}
.cc-card-tile:hover .cc-card-tile-add { opacity: 1; transform: translateY(0); }
.cc-card-tile-add svg { width: 16px; height: 16px; }
.cc-card-tile-num {
    position: absolute; top: 8px; left: 8px;
    padding: 3px 8px; border-radius: 999px;
    background: var(--cc-glass);
    -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
    font-size: 11px; font-weight: 600; color: var(--cc-ink);
    border: 1px solid var(--cc-glass-line);
    font-variant-numeric: tabular-nums;
}

/* ---------- Hero ---------- */
.cc-hero {
    text-align: center;
    padding: clamp(56px, 7vw, 96px) 22px clamp(48px, 6vw, 80px);
}
.cc-hero h1 { margin-bottom: 16px; }
.cc-hero .cc-lede { max-width: 680px; margin: 0 auto 28px; }
.cc-hero-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* ---------- Page header (sub-pages) ---------- */
.cc-page-head {
    padding: clamp(40px, 5vw, 64px) 22px 16px;
    max-width: var(--cc-max); margin: 0 auto;
}
.cc-page-head h1 { margin-bottom: 8px; }
.cc-page-head .cc-lede { max-width: 720px; margin: 0; }
.cc-breadcrumb {
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
    color: var(--cc-ink-3); font-size: 13px;
    margin-bottom: 16px;
}
.cc-breadcrumb a { color: var(--cc-ink-3); }
.cc-breadcrumb a:hover { color: var(--cc-ink); }
.cc-breadcrumb .sep { color: var(--cc-ink-mute); }

/* ---------- Stats ---------- */
.cc-stats-row {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
    margin-top: 24px;
}
.cc-stat {
    padding: 18px 18px;
    background: var(--cc-surface);
    border: 1px solid var(--cc-line-soft);
    border-radius: var(--cc-r-md);
}
.cc-stat-num { font-size: clamp(22px, 2.4vw, 32px); font-weight: 700; letter-spacing: -0.02em; color: var(--cc-ink); font-variant-numeric: tabular-nums; }
.cc-stat-label { font-size: 12px; font-weight: 500; color: var(--cc-ink-3); text-transform: uppercase; letter-spacing: 0.06em; margin-top: 4px; }
@media (max-width: 720px) { .cc-stats-row { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Empty states ---------- */
.cc-empty {
    text-align: center;
    padding: 64px 22px;
    max-width: 560px; margin: 0 auto;
}
.cc-empty-glyph {
    width: 64px; height: 64px;
    margin: 0 auto 20px;
    border-radius: 999px;
    background: var(--cc-surface-2);
    display: grid; place-items: center;
    color: var(--cc-ink-3);
}
.cc-empty-glyph svg { width: 28px; height: 28px; }
.cc-empty h2 { font-size: 22px; margin-bottom: 8px; }
.cc-empty p { color: var(--cc-ink-3); margin: 0 0 24px; }
.cc-empty img { margin: 0 auto 20px; border-radius: var(--cc-r-lg); max-width: 360px; }

/* ---------- Modals / sheets ---------- */
.cc-overlay {
    position: fixed; inset: 0; z-index: 5000;
    background: rgba(0,0,0,.45);
    -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
    display: grid; place-items: center;
    opacity: 0; pointer-events: none;
    transition: opacity var(--cc-dur) var(--cc-ease);
}
.cc-overlay.is-open { opacity: 1; pointer-events: auto; }
.cc-modal {
    background: var(--cc-surface);
    border: 1px solid var(--cc-line);
    border-radius: var(--cc-r-lg);
    box-shadow: var(--cc-shadow-lg);
    max-width: 520px; width: calc(100% - 32px);
    transform: translateY(12px) scale(.98);
    transition: transform var(--cc-dur) var(--cc-ease);
}
.cc-overlay.is-open .cc-modal { transform: translateY(0) scale(1); }
.cc-modal-head { padding: 20px 22px; border-bottom: 1px solid var(--cc-line-soft); display: flex; align-items: center; justify-content: space-between; }
.cc-modal-body { padding: 22px; }
.cc-modal-foot { padding: 14px 22px; border-top: 1px solid var(--cc-line-soft); display: flex; gap: 8px; justify-content: flex-end; }

/* ---------- Toasts ---------- */
.cc-toast {
    position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(20px);
    z-index: 5500;
    background: var(--cc-glass);
    -webkit-backdrop-filter: saturate(180%) blur(16px); backdrop-filter: saturate(180%) blur(16px);
    border: 1px solid var(--cc-glass-line);
    border-radius: 14px;
    padding: 12px 18px;
    font-size: 14px; font-weight: 500;
    color: var(--cc-ink);
    box-shadow: var(--cc-shadow-md);
    opacity: 0; pointer-events: none;
    transition: opacity var(--cc-dur) var(--cc-ease), transform var(--cc-dur) var(--cc-ease);
}
.cc-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); pointer-events: auto; }

/* ---------- Scroll reveal utility ---------- */
.cc-reveal {
    opacity: 0; transform: translateY(16px);
    transition: opacity var(--cc-dur-slow) var(--cc-ease), transform var(--cc-dur-slow) var(--cc-ease);
}
.cc-reveal.is-in { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
    .cc-reveal { opacity: 1; transform: none; transition: none; }
    * { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* ---------- Grids ---------- */
.cc-grid { display: grid; gap: 16px; }
.cc-grid--sets { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }
.cc-grid--cards { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
.cc-grid--small { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); }
@media (max-width: 540px) {
    .cc-grid--sets { grid-template-columns: repeat(2, 1fr); }
    .cc-grid--cards { grid-template-columns: repeat(2, 1fr); }
    .cc-grid--small { grid-template-columns: repeat(2, 1fr); }
}

/* ---------- Set tile (Apple-style) ---------- */
.cc-set-tile {
    background: var(--cc-surface);
    border: 1px solid var(--cc-line-soft);
    border-radius: var(--cc-r-md);
    padding: 18px;
    color: var(--cc-ink);
    display: flex; flex-direction: column; gap: 12px;
    transition: transform var(--cc-dur) var(--cc-ease), box-shadow var(--cc-dur) var(--cc-ease), border-color var(--cc-dur) var(--cc-ease);
    min-height: 220px;
}
.cc-set-tile:hover {
    transform: translateY(-4px) rotate(-.25deg);
    box-shadow: var(--cc-shadow-md);
    border-color: var(--cc-line);
    color: var(--cc-ink);
}
.cc-set-tile-logo {
    height: 80px;
    display: grid; place-items: center;
    background: var(--cc-surface-2);
    border-radius: 12px;
    overflow: hidden;
    padding: 8px;
}
.cc-set-tile-logo img { max-height: 64px; max-width: 100%; object-fit: contain; }
.cc-set-tile-logo .placeholder { color: var(--cc-ink-mute); }
.cc-set-tile-name { font-size: 15px; font-weight: 600; color: var(--cc-ink); margin: 0; line-height: 1.2; }
.cc-set-tile-meta { font-size: 12px; color: var(--cc-ink-3); display: flex; gap: 8px; flex-wrap: wrap; }
.cc-set-tile-progress {
    height: 6px; border-radius: 999px; background: var(--cc-surface-2);
    overflow: hidden;
}
.cc-set-tile-progress > span {
    display: block; height: 100%;
    background: linear-gradient(90deg, var(--cc-accent), var(--cc-poke-red));
    border-radius: 999px;
}
.cc-set-tile-foot {
    display: flex; justify-content: space-between; align-items: center;
    margin-top: auto;
    font-size: 12px; color: var(--cc-ink-3);
}

/* ---------- Filter bar / toolbar ---------- */
.cc-toolbar {
    display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
    margin: 16px 0 20px;
}
.cc-toolbar .cc-search { flex: 1; min-width: 220px; max-width: 360px; }
.cc-toolbar .spacer { flex: 1; }

.cc-chip-row { display: flex; gap: 8px; flex-wrap: wrap; }

/* ---------- Card detail layout ---------- */
.cc-card-detail {
    display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr); gap: 48px;
    max-width: var(--cc-max); margin: 0 auto;
    padding: 24px 22px 48px;
}
@media (max-width: 900px) { .cc-card-detail { grid-template-columns: 1fr; gap: 24px; } }
.cc-card-photo {
    position: relative;
    display: grid; place-items: center;
    padding: 24px;
}
.cc-card-photo::before {
    content: ''; position: absolute; inset: -10% 5%;
    background: radial-gradient(closest-side, color-mix(in oklab, var(--type-color, var(--cc-accent)) 35%, transparent), transparent 70%);
    filter: blur(40px);
    z-index: 0;
}
.cc-card-photo img {
    position: relative; z-index: 1;
    max-width: 100%; max-height: 600px;
    border-radius: 16px;
    box-shadow: var(--cc-shadow-lg);
    cursor: zoom-in;
    transition: transform var(--cc-dur) var(--cc-ease);
}
.cc-card-photo img:hover { transform: scale(1.02); }

/* ---------- Energy type icons (color tokens) ---------- */
.cc-energy {
    display: inline-grid; place-items: center;
    width: 22px; height: 22px;
    border-radius: 999px;
    font-size: 11px; font-weight: 700;
    color: #fff;
    box-shadow: inset 0 -2px 4px rgba(0,0,0,.2);
}
.cc-energy--grass     { background: #5fbd58; }
.cc-energy--fire      { background: #ee8130; }
.cc-energy--water     { background: #5ea4ee; }
.cc-energy--lightning { background: #f6c93f; color: #6a4a00; }
.cc-energy--psychic   { background: #c068b6; }
.cc-energy--fighting  { background: #cc6e54; }
.cc-energy--darkness  { background: #4a3a30; }
.cc-energy--metal     { background: #8da0b2; }
.cc-energy--dragon    { background: #6f57e0; }
.cc-energy--fairy     { background: #ed98c9; }
.cc-energy--colorless { background: #b9b6a8; }

.cc-type-pill {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 10px; border-radius: 999px;
    font-size: 11px; font-weight: 600;
    color: #fff;
}
.cc-type-pill.cc-energy--lightning { color: #6a4a00; }

/* ---------- Sections inside detail ---------- */
.cc-info-section {
    margin-bottom: 28px;
}
.cc-info-section h3 {
    font-size: 13px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--cc-ink-3);
    margin-bottom: 12px;
}
.cc-data-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 12px; }
.cc-data-cell {
    background: var(--cc-surface);
    border: 1px solid var(--cc-line-soft);
    border-radius: 12px;
    padding: 14px;
}
.cc-data-cell-label { font-size: 11px; color: var(--cc-ink-3); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 4px; }
.cc-data-cell-value { font-size: 16px; font-weight: 600; color: var(--cc-ink); }

.cc-attack {
    background: var(--cc-surface);
    border: 1px solid var(--cc-line-soft);
    border-radius: 14px;
    padding: 16px 18px;
    margin-bottom: 10px;
}
.cc-attack-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 6px; }
.cc-attack-name { font-size: 16px; font-weight: 600; color: var(--cc-ink); }
.cc-attack-cost { display: inline-flex; gap: 4px; }
.cc-attack-dmg { font-size: 22px; font-weight: 700; color: var(--cc-ink); font-variant-numeric: tabular-nums; }
.cc-attack-text { font-size: 14px; color: var(--cc-ink-2); line-height: 1.5; }

.cc-flavor {
    font-style: italic;
    color: var(--cc-ink-2);
    border-left: 3px solid var(--cc-line);
    padding: 8px 16px;
    line-height: 1.6;
}

/* ---------- Pixelate accessibility setting ---------- */
body.is-pixelated img { image-rendering: pixelated; image-rendering: -moz-crisp-edges; }

/* ---------- Hide neo-brutalist legacy chrome on Apple pages ---------- */
body .background-grid, body .grain-overlay, body .header-marquee,
body .footer:not(.cc-footer), body #cc-theme-btn,
body .header:not(.cc-header), body .search-dock { display: none !important; }

/* tinyblue widgets — keep network bar at bottom but hide auth (we have our own) */
#tba-btn, #ait-toolbar, #nw-widget, #cc-ai-btn, #ait-hover-tip { display: none !important; }
#tbn-bar { z-index: 9990 !important; bottom: 0 !important; }

/* ---------- Utility classes ---------- */
.cc-stack > * + * { margin-top: 16px; }
.cc-stack-sm > * + * { margin-top: 8px; }
.cc-stack-lg > * + * { margin-top: 24px; }
.cc-row { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.cc-row--end { justify-content: flex-end; }
.cc-row--between { justify-content: space-between; }
.cc-center { text-align: center; }
.cc-hidden { display: none !important; }
.cc-mt-4 { margin-top: 16px; } .cc-mt-6 { margin-top: 24px; } .cc-mt-8 { margin-top: 32px; }
.cc-mb-4 { margin-bottom: 16px; } .cc-mb-6 { margin-bottom: 24px; } .cc-mb-8 { margin-bottom: 32px; }

/* ---------- PWA install banner ---------- */
/* Anchored bottom-right (out of content's way); never covers the page center.
   Body padding reserves space if the cross-site network-bar is also present. */
.cc-pwa-banner {
    position: fixed; bottom: max(140px, env(safe-area-inset-bottom, 0px) + 140px);
    right: 20px; left: auto; transform: translateY(20px);
    background: var(--cc-glass);
    -webkit-backdrop-filter: saturate(180%) blur(20px);
    backdrop-filter: saturate(180%) blur(20px);
    border: 1px solid var(--cc-glass-line);
    border-radius: 14px;
    padding: 12px 16px;
    box-shadow: var(--cc-shadow-md);
    display: flex; align-items: center; gap: 12px;
    opacity: 0; pointer-events: none; z-index: 5000;
    transition: opacity var(--cc-dur) var(--cc-ease), transform var(--cc-dur) var(--cc-ease);
    max-width: min(420px, calc(100vw - 40px));
}
.cc-pwa-banner.show { opacity: 1; transform: translateY(0); pointer-events: auto; }
@media (max-width: 520px) {
    .cc-pwa-banner { left: 20px; right: 20px; max-width: none; bottom: max(120px, env(safe-area-inset-bottom, 0px) + 120px); }
}
.cc-pwa-icon { width: 36px; height: 36px; border-radius: 8px; background: linear-gradient(135deg, var(--cc-poke-red), var(--cc-accent)); display: grid; place-items: center; color: #fff; }
.cc-pwa-text strong { display: block; font-size: 14px; font-weight: 600; color: var(--cc-ink); }
.cc-pwa-text p { margin: 0; font-size: 12px; color: var(--cc-ink-3); }

/* ---------- Offline indicator ---------- */
.cc-offline {
    position: fixed; bottom: 24px; right: 24px;
    background: var(--cc-warning); color: #fff;
    padding: 8px 14px; border-radius: 999px;
    font-size: 13px; font-weight: 500;
    box-shadow: var(--cc-shadow);
    opacity: 0; pointer-events: none; z-index: 5000;
    transition: opacity var(--cc-dur) var(--cc-ease);
}
.cc-offline.show { opacity: 1; }

/* ---------- Glyph sprite usage ---------- */
/* Class is applied to the <svg> directly (e.g. <svg class="cc-glyph"><use ../></svg>),
   so size + stroke must target the .cc-glyph element itself, not a nested svg. */
.cc-glyph { width: 1em; height: 1em; flex-shrink: 0; display: inline-block;
            fill: none; stroke: currentColor; stroke-width: 1.8;
            stroke-linecap: round; stroke-linejoin: round;
            vertical-align: -.15em; }
.cc-glyph svg { width: 1em; height: 1em; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
/* Filled variants (heart-f, star-f, sparkles, bolt, …) override per-symbol with fill="currentColor" stroke="none". */

/* ---------- Spark / micro-chart ---------- */
.cc-spark { width: 100%; height: 80px; }
.cc-spark path { fill: none; stroke: var(--cc-accent); stroke-width: 2; stroke-linejoin: round; stroke-linecap: round; }
.cc-spark .area { fill: color-mix(in oklab, var(--cc-accent) 14%, transparent); stroke: none; }

/* ---------- Auth ---------- */
.cc-auth-wrap {
    min-height: calc(100vh - var(--cc-nav-h) - 240px);
    display: grid; place-items: center;
    padding: 48px 22px;
}
.cc-auth-card {
    background: var(--cc-surface);
    border: 1px solid var(--cc-line-soft);
    border-radius: var(--cc-r-lg);
    padding: 40px;
    max-width: 420px; width: 100%;
    box-shadow: var(--cc-shadow-md);
}
.cc-auth-mark {
    width: 56px; height: 56px;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--cc-poke-red), var(--cc-accent));
    display: grid; place-items: center;
    color: #fff; margin: 0 auto 20px;
}
.cc-auth-mark svg { width: 28px; height: 28px; }
.cc-auth-title { text-align: center; font-size: 26px; font-weight: 700; letter-spacing: -0.02em; margin-bottom: 6px; }
.cc-auth-sub { text-align: center; color: var(--cc-ink-3); margin-bottom: 28px; font-size: 14px; }

/* ---------- Codex Apple pass: viewport law + mobile polish ---------- */
html,
body,
.cc-page {
    width: 100%;
    max-width: 100%;
    overflow-x: clip;
}

.cc-page,
.cc-shell,
.cc-section,
.cc-section-tight,
.cc-grid,
.cc-card,
.cc-table-wrap,
.cc-set-tile,
.cc-feature {
    min-width: 0;
}

.cc-btn,
.cc-nav a,
.cc-theme-toggle,
.cc-burger,
button,
input[type="submit"] {
    min-height: 44px;
}

.cc-btn,
.cc-nav a {
    min-width: 44px;
}

.cc-table-wrap,
.cc-data-table-wrap {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

@media (max-width: 520px) {
    .cc-shell,
    .cc-section,
    .cc-section-tight,
    .cc-header-inner {
        padding-inline: 18px;
    }
    .cc-display {
        font-size: clamp(38px, 12vw, 58px);
        line-height: 1.03;
    }
    .cc-lede {
        font-size: 19px;
        line-height: 1.36;
    }
    .cc-btn--lg {
        height: 54px;
        padding-inline: 24px;
    }
}
.cc-auth-foot {
    margin-top: 24px; padding-top: 20px;
    border-top: 1px solid var(--cc-line-soft);
    text-align: center; font-size: 14px; color: var(--cc-ink-3);
}
.cc-auth-error {
    background: color-mix(in oklab, var(--cc-danger) 12%, transparent);
    color: var(--cc-danger);
    border: 1px solid color-mix(in oklab, var(--cc-danger) 30%, transparent);
    border-radius: 12px;
    padding: 12px 14px;
    font-size: 13px;
    margin-bottom: 16px;
}
.cc-auth-error ul { margin: 6px 0 0; padding-left: 18px; }

/* Password strength bar */
.cc-strength { margin-top: 6px; }
.cc-strength-track { height: 4px; border-radius: 999px; background: var(--cc-surface-2); overflow: hidden; }
.cc-strength-fill { height: 100%; width: 0; transition: width var(--cc-dur) var(--cc-ease), background var(--cc-dur) var(--cc-ease); border-radius: 999px; }
.cc-strength-fill.weak   { width: 33%; background: var(--cc-danger); }
.cc-strength-fill.medium { width: 66%; background: var(--cc-warning); }
.cc-strength-fill.strong { width: 100%; background: var(--cc-success); }
.cc-strength-label { font-size: 12px; color: var(--cc-ink-3); margin-top: 6px; }

/* ---------- Settings sidebar layout ---------- */
.cc-settings {
    display: grid; grid-template-columns: 220px 1fr; gap: 32px;
    max-width: var(--cc-max); margin: 0 auto;
    padding: 32px 22px 64px;
}
.cc-settings-nav {
    display: flex; flex-direction: column; gap: 2px;
    position: sticky; top: calc(var(--cc-nav-h) + 16px);
    align-self: start;
}
@media (max-width: 760px) {
    .cc-settings { grid-template-columns: 1fr; gap: 16px; }
    .cc-settings-nav {
        position: static; top: auto;
        flex-direction: row; flex-wrap: wrap;
        gap: 4px;
        padding-bottom: 8px;
        border-bottom: 1px solid var(--cc-line);
        margin-bottom: 8px;
    }
    .cc-settings-nav a { padding: 8px 12px; font-size: 13px; }
}
.cc-settings-nav a {
    padding: 10px 14px; border-radius: 10px;
    color: var(--cc-ink-2); font-size: 14px; font-weight: 500;
    display: inline-flex; align-items: center; gap: 8px;
}
.cc-settings-nav a:hover { background: var(--cc-surface-2); color: var(--cc-ink); }
.cc-settings-nav a.is-active { background: var(--cc-surface-2); color: var(--cc-ink); }

.cc-prefs {
    background: var(--cc-surface);
    border: 1px solid var(--cc-line-soft);
    border-radius: var(--cc-r-lg);
    overflow: hidden;
}
.cc-pref {
    padding: 18px 22px;
    display: flex; align-items: center; justify-content: space-between; gap: 16px;
    border-bottom: 1px solid var(--cc-line-soft);
}
.cc-pref:last-child { border-bottom: 0; }
.cc-pref-title { font-size: 15px; font-weight: 500; color: var(--cc-ink); margin: 0 0 2px; }
.cc-pref-desc  { font-size: 13px; color: var(--cc-ink-3); margin: 0; }

/* ---------- Dashboard / collection grid ---------- */
.cc-dashboard {
    display: grid; grid-template-columns: 1fr; gap: 24px;
    max-width: var(--cc-max); margin: 0 auto;
    padding: 24px 22px 64px;
}
.cc-welcome {
    background: linear-gradient(135deg, color-mix(in oklab, var(--cc-accent) 8%, var(--cc-surface)), var(--cc-surface));
    border: 1px solid var(--cc-line-soft);
    border-radius: var(--cc-r-lg);
    padding: 28px 32px;
}
.cc-welcome h1 { font-size: clamp(24px, 3vw, 36px); margin-bottom: 4px; }
.cc-welcome p { color: var(--cc-ink-2); margin: 0; }

.cc-dash-row {
    display: grid; grid-template-columns: 2fr 1fr; gap: 20px;
}
@media (max-width: 900px) { .cc-dash-row { grid-template-columns: 1fr; } }
.cc-dash-card {
    background: var(--cc-surface);
    border: 1px solid var(--cc-line-soft);
    border-radius: var(--cc-r-lg);
    padding: 22px;
}
.cc-dash-card h2 { font-size: 18px; font-weight: 600; margin-bottom: 14px; display: flex; align-items: center; gap: 8px; }

/* Activity list */
.cc-activity { list-style: none; padding: 0; margin: 0; }
.cc-activity li {
    padding: 12px 0;
    border-bottom: 1px solid var(--cc-line-soft);
    display: grid; grid-template-columns: 1fr auto; gap: 4px 12px;
}
.cc-activity li:last-child { border-bottom: 0; }
.cc-activity-msg { font-size: 14px; color: var(--cc-ink); }
.cc-activity-time { font-size: 12px; color: var(--cc-ink-3); }

/* Set completion bars */
.cc-prog-row { margin-bottom: 16px; }
.cc-prog-row:last-child { margin-bottom: 0; }
.cc-prog-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 6px; font-size: 13px; }
.cc-prog-head .name { color: var(--cc-ink); font-weight: 500; }
.cc-prog-head .num { color: var(--cc-ink-3); font-variant-numeric: tabular-nums; }
.cc-prog-track { height: 6px; border-radius: 999px; background: var(--cc-surface-2); overflow: hidden; }
.cc-prog-fill { height: 100%; background: linear-gradient(90deg, var(--cc-accent), var(--cc-poke-red)); border-radius: 999px; transition: width var(--cc-dur-slow) var(--cc-ease); }
.cc-prog-fill.is-complete { background: var(--cc-success); }

/* Welcome stat tiles */
.cc-welcome-stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-top: 20px; }
@media (max-width: 720px) { .cc-welcome-stats { grid-template-columns: repeat(2,1fr); } }

/* Collection-card preview strip */
.cc-collection-card {
    background: var(--cc-surface);
    border: 1px solid var(--cc-line-soft);
    border-radius: var(--cc-r-lg);
    padding: 18px;
    transition: transform var(--cc-dur) var(--cc-ease), box-shadow var(--cc-dur) var(--cc-ease), border-color var(--cc-dur) var(--cc-ease);
    cursor: pointer;
    color: var(--cc-ink);
}
.cc-collection-card:hover { transform: translateY(-4px); box-shadow: var(--cc-shadow-md); border-color: var(--cc-line); color: var(--cc-ink); }
.cc-collection-card h3 { font-size: 17px; font-weight: 600; margin: 0 0 12px; }
.cc-collection-preview { display: flex; gap: 6px; margin: 12px 0; }
.cc-collection-preview-thumb {
    width: 44px; aspect-ratio: 245/342;
    background: var(--cc-surface-2);
    border-radius: 6px; overflow: hidden;
    flex-shrink: 0;
}
.cc-collection-preview-thumb img { width: 100%; height: 100%; object-fit: cover; }
.cc-collection-preview-more {
    display: inline-grid; place-items: center;
    width: 44px; aspect-ratio: 245/342;
    background: var(--cc-surface-2);
    color: var(--cc-ink-3);
    font-size: 12px; font-weight: 600;
    border-radius: 6px;
}

/* Set header (cards list page) */
.cc-set-banner {
    text-align: center;
    padding: 48px 22px 24px;
    max-width: var(--cc-max); margin: 0 auto;
}
.cc-set-banner-logo {
    height: 96px; margin: 0 auto 16px;
    display: grid; place-items: center;
}
.cc-set-banner-logo img { max-height: 96px; max-width: 320px; object-fit: contain; }
.cc-set-banner h1 { margin-bottom: 8px; }
.cc-set-banner .cc-row { justify-content: center; }

/* ---------- Error pages ---------- */
.cc-error-page {
    text-align: center;
    padding: 96px 22px;
    max-width: 560px; margin: 0 auto;
}
.cc-error-code { font-size: clamp(72px, 12vw, 128px); font-weight: 700; letter-spacing: -0.04em; color: var(--cc-ink); line-height: 1; margin-bottom: 8px; }
.cc-error-page h1 { font-size: 26px; margin-bottom: 12px; }
.cc-error-page p { color: var(--cc-ink-3); margin-bottom: 24px; }
.cc-error-page img { max-width: 320px; margin: 0 auto 28px; border-radius: var(--cc-r-lg); }

/* ---------- Table (admin / data) ---------- */
.cc-table { width: 100%; border-collapse: collapse; }
.cc-table th, .cc-table td {
    padding: 12px 16px; text-align: left;
    border-bottom: 1px solid var(--cc-line-soft);
    font-size: 13px;
}
.cc-table th { font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--cc-ink-3); font-weight: 600; }
.cc-table tr:hover { background: var(--cc-surface-2); }

/* Print friendliness */
@media print {
    .cc-header, .cc-footer, .cc-toolbar, .cc-pwa-banner, .cc-offline { display: none !important; }
}
