/*
Theme Name: TCN Theme
Theme URI: https://thecomission.com
Author: The Comission Network
Description: The Comission Network — cinematic dark theme with department ecosystems, content modal, and access control.
Version: 2.0.0
License: GNU General Public License v2 or later
Text Domain: tcn-theme
Tags: cinematic, dark, premium, network, membership
*/

/* ================================================================
   DESIGN TOKENS
   ================================================================ */
:root {
    --clr-bg: #050505;
    --clr-surface: #0e1117;
    --clr-surface-light: #161b22;
    --clr-primary: #a0f1ea;
    --clr-accent: #ff4d4d;
    --clr-text-main: #ffffff;
    --clr-text-muted: #8e9aaf;
    --clr-border: rgba(255,255,255,0.08);

    --font-main: 'Inter', sans-serif;
    --font-title: 'Dela Gothic One', cursive;

    --sp-xs: 4px; --sp-sm: 12px; --sp-md: 24px; --sp-lg: 48px; --sp-xl: 96px;

    --container-max: 1600px;
    --header-height: 72px;
    --radius-sm: 8px;
    --radius-md: 16px;
    --radius-lg: 24px;

    --transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ================================================================
   RESET & BASE
   ================================================================ */
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--clr-bg);color:var(--clr-text-main);font-family:var(--font-main);overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.dela-title{font-family:var(--font-title);text-transform:uppercase}
a{color:inherit;text-decoration:none;transition:var(--transition)}
button{background:none;border:none;cursor:pointer;font-family:inherit;color:inherit}
img{max-width:100%;height:auto}
.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--sp-md)}

/* ================================================================
   HEADER
   ================================================================ */
.site-header{height:var(--header-height);background:rgba(6,10,28,0.45);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;align-items:center;border-bottom:1px solid rgba(255,255,255,0.06);position:sticky;top:0;z-index:1000;transition:background .3s,border-color .3s}
.header-container{display:flex;justify-content:space-between;align-items:center;width:100%}
.network-logo-wrapper{display:flex;align-items:center;gap:12px}
.network-logo{height:32px;width:32px;border-radius:6px}
.network-logo-banner{height:30px;width:auto;object-fit:contain}
.network-title{font-size:1rem;font-family:var(--font-title);color:#fff;letter-spacing:0.05em}
.main-nav{display:flex;gap:28px;font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--clr-text-muted)}
.main-nav .nav-link:hover,.main-nav .nav-link.active{color:var(--clr-primary)}
.header-actions{display:flex;align-items:center;gap:16px}
.main-access-btn{background:var(--clr-primary);color:#050505;font-size:0.65rem;font-weight:900;padding:8px 18px;border-radius:4px;text-transform:uppercase;letter-spacing:0.08em;clip-path:polygon(8% 0,100% 0,92% 100%,0% 100%);transition:var(--transition)}
.main-access-btn:hover{background:#fff;transform:translateY(-1px);box-shadow:0 4px 20px rgba(160,241,234,0.3)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:4px}
.nav-hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:1px;transition:var(--transition)}

@media(max-width:768px){
    .main-nav{display:none;position:fixed;top:var(--header-height);left:0;right:0;background:rgba(8,10,15,0.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);flex-direction:column;padding:24px;gap:20px;border-bottom:1px solid rgba(255,255,255,0.08);z-index:999}
    .main-nav.open{display:flex}
    .nav-hamburger{display:flex}
    .main-access-btn{display:none}
}

/* ================================================================
   BUTTONS
   ================================================================ */
.fp-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:var(--radius-sm);font-weight:700;font-size:13px;letter-spacing:0.1em;text-transform:uppercase;transition:var(--transition);cursor:pointer;border:none}
.fp-btn--primary{background:var(--clr-primary);color:#050505}
.fp-btn--primary:hover{background:#fff;transform:translateY(-2px);box-shadow:0 8px 32px rgba(160,241,234,0.3)}
.fp-btn--ghost{background:transparent;color:var(--clr-text-main);border:1px solid rgba(255,255,255,0.2)}
.fp-btn--ghost:hover{border-color:var(--clr-primary);color:var(--clr-primary);transform:translateY(-2px)}

/* ================================================================
   CONTENT CARDS (.post-card)
   ================================================================ */
.content-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;padding:var(--sp-md) 0}
.post-card{background:var(--clr-surface);border-radius:var(--radius-md);overflow:hidden;position:relative;border:1px solid var(--clr-border);transition:var(--transition);cursor:pointer}
.post-card:hover{transform:translateY(-4px);border-color:var(--clr-primary);box-shadow:0 12px 40px rgba(160,241,234,0.08)}
.post-thumbnail{aspect-ratio:16/9;background-size:cover;background-position:center;transition:var(--transition)}
.post-meta-overlay{padding:14px 16px}
.post-card-title{font-size:0.8rem;color:#fff;text-transform:uppercase;font-family:var(--font-title);line-height:1.3}
.post-card-date{font-size:0.65rem;color:var(--clr-text-muted);margin-top:4px;text-transform:uppercase;letter-spacing:0.05em}
.post-card .type-badge{position:absolute;top:10px;left:10px;background:rgba(0,0,0,0.75);backdrop-filter:blur(4px);font-size:0.6rem;font-weight:800;padding:4px 10px;border-radius:4px;color:var(--clr-primary);letter-spacing:0.08em;text-transform:uppercase}
.post-card.is-locked .post-thumbnail{filter:grayscale(1) brightness(0.4)}
.post-card.is-locked::after{content:'\1F512';position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);font-size:2rem;opacity:0.8}
.post-card.is-featured{grid-column:span 2}

@media(max-width:768px){
    .content-grid{grid-template-columns:1fr 1fr;gap:12px}
    .post-card.is-featured{grid-column:span 1}
}
@media(max-width:480px){
    .content-grid{grid-template-columns:1fr}
}

/* ================================================================
   LIBRARY GRID (smaller cards)
   ================================================================ */
.tcp-library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}
.library-item-alt{background:var(--clr-surface-light);border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--clr-border);transition:var(--transition);cursor:pointer}
.library-item-alt:hover{border-color:var(--clr-primary);transform:translateY(-3px)}
.lib-item-thumb{aspect-ratio:16/9;background-size:cover;background-position:center;position:relative}
.lib-item-type{position:absolute;top:8px;left:8px;background:rgba(0,0,0,0.7);font-size:0.6rem;font-weight:800;padding:3px 8px;border-radius:4px;color:var(--clr-primary)}
.lib-item-meta{padding:12px}
.lib-item-title{font-size:0.8rem;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--font-title)}
.lib-item-artist{font-size:0.65rem;color:var(--clr-text-muted)}

/* ================================================================
   SECTION LABELS
   ================================================================ */
.section-label{display:flex;align-items:center;gap:8px;font-size:0.7rem;font-weight:900;letter-spacing:0.15em;color:var(--clr-text-muted);margin-bottom:16px;text-transform:uppercase}
.section-label svg{color:var(--clr-primary)}

/* ================================================================
   CINEMATIC MODAL
   ================================================================ */
.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.92);backdrop-filter:blur(20px);z-index:2000;display:none;opacity:0;transition:opacity 0.3s ease;overflow-y:auto;padding:var(--sp-md)}
.modal-overlay.active{display:flex;justify-content:center;align-items:flex-start;padding-top:60px;opacity:1}
.modal-container{width:100%;max-width:900px;background:var(--clr-surface);border-radius:var(--radius-lg);overflow:hidden;position:relative;border:1px solid var(--clr-border);margin-bottom:60px}
.modal-close-btn{position:absolute;top:12px;right:16px;z-index:1001;font-size:28px;color:#fff;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.5);border-radius:50%;border:1px solid var(--clr-border);transition:var(--transition)}
.modal-close-btn:hover{background:var(--clr-accent);border-color:var(--clr-accent)}

/* Modal Header */
.modal-header{padding:20px 24px;border-bottom:1px solid var(--clr-border);display:flex;align-items:center;gap:16px}
.modal-title-group{display:flex;align-items:center;gap:16px;flex:1}
.modal-icon-box{width:48px;height:48px;flex-shrink:0;border-radius:8px;background:var(--clr-surface-light);display:flex;align-items:center;justify-content:center;overflow:hidden}
.modal-icon-box img{width:100%;height:100%;object-fit:cover;border-radius:8px}
.modal-main-title{font-size:1rem;font-family:var(--font-title);letter-spacing:-0.01em;line-height:1.2}
.modal-sub-title{font-size:0.7rem;color:var(--clr-primary);font-weight:700;letter-spacing:0.08em}

/* Modal Player Area */
.modal-audio-main{background:#000}
#twc-yt-wrap{width:100%;aspect-ratio:16/9;background:#000;position:relative}
#twc-audius-wrap{width:100%;aspect-ratio:16/9;background:#0a0a10;overflow:hidden}
#twc-audius-wrap iframe{width:100%;height:100%;border:0}
#twc-audio-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:220px;gap:16px;background:#0a0a10}
.play-overlay-btn{width:80px;height:80px;border-radius:50%;background:rgba(160,241,234,0.15);border:2px solid var(--clr-primary);display:flex;align-items:center;justify-content:center;color:var(--clr-primary);transition:var(--transition)}
.play-overlay-btn:hover{background:rgba(160,241,234,0.25);transform:scale(1.1)}
#twc-nosource-wrap{display:flex;align-items:center;justify-content:center;min-height:180px;color:var(--clr-text-muted);font-size:13px;letter-spacing:0.05em}

/* Player Bar */
.player-footer{padding:12px 24px;background:var(--clr-surface-light);border-top:1px solid var(--clr-border)}
.player-bar-wrapper{display:flex;align-items:center;gap:12px}
.play-pause-small{width:32px;height:32px;border-radius:50%;background:var(--clr-primary);color:#000;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.time-display{font-size:11px;color:var(--clr-text-muted);white-space:nowrap;min-width:80px}
.progress-container{flex:1;height:4px;background:rgba(255,255,255,0.1);border-radius:2px;position:relative;cursor:pointer}
.progress-bar{height:100%;background:var(--clr-primary);border-radius:2px;width:0;transition:width 0.1s linear}
.progress-handle{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:var(--clr-primary);border-radius:50%;left:0;opacity:0;transition:opacity 0.2s}
.progress-container:hover .progress-handle{opacity:1}
.volume-control{display:flex;align-items:center;gap:6px;color:var(--clr-text-muted)}
.volume-control input[type="range"]{width:60px;accent-color:var(--clr-primary)}

/* Metadata Tray */
.metadata-tray{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--clr-border)}
.meta-item{padding:14px 20px;background:var(--clr-surface)}
.meta-label{font-size:0.6rem;color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:0.12em;margin-bottom:4px}
.meta-value{font-size:0.8rem;font-weight:600}

/* Modal Description */
.modal-description{padding:20px 24px;font-size:0.85rem;line-height:1.7;color:var(--clr-text-muted);border-top:1px solid var(--clr-border)}

/* Modal Comments */
.modal-comments-section{padding:20px 24px;border-top:1px solid var(--clr-border)}
.comments-header{font-size:0.7rem;font-weight:800;letter-spacing:0.12em;color:var(--clr-text-muted);margin-bottom:12px}
.comment-input-row{display:flex;align-items:center;gap:12px}
.comment-avatar{width:32px;height:32px;border-radius:50%;background:var(--clr-surface-light);flex-shrink:0}
.comment-input{flex:1;background:var(--clr-surface-light);border:1px solid var(--clr-border);padding:10px 14px;border-radius:8px;color:var(--clr-text-muted);font-size:0.8rem}

/* Modal Footer */
.modal-footer-actions{display:flex;align-items:center;gap:16px;padding:14px 24px;border-top:1px solid var(--clr-border)}
.modal-action-btn{display:flex;align-items:center;gap:6px;font-size:0.75rem;color:var(--clr-text-muted);transition:var(--transition)}
.modal-action-btn:hover{color:var(--clr-primary)}

/* Locked Screen */
#twc-locked-screen{position:absolute;top:0;left:0;width:100%;height:100%;background:var(--clr-bg);z-index:500;display:none;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:var(--sp-lg)}
#twc-locked-screen.active{display:flex}
.lock-icon-lg{font-size:4rem;color:var(--clr-accent);margin-bottom:24px}
.unlock-cta-title{font-family:var(--font-title);font-size:1.5rem;margin-bottom:12px}
.unlock-cta-text{color:var(--clr-text-muted);font-size:0.9rem;margin-bottom:32px;max-width:400px}

/* Download button */
.modal-download-btn{display:inline-flex;align-items:center;gap:6px;margin-left:auto;padding:8px 16px;border-radius:6px;background:rgba(160,241,234,0.12);border:1px solid rgba(160,241,234,0.3);color:var(--clr-primary);font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;white-space:nowrap;transition:var(--transition)}
.modal-download-btn:hover{background:rgba(160,241,234,0.2)}

@media(max-width:768px){
    .metadata-tray{grid-template-columns:repeat(2,1fr)}
    .modal-overlay.active{padding-top:20px}
}

/* ================================================================
   LOCKED CONTENT OVERLAY
   ================================================================ */
.locked-overlay{position:absolute;inset:0;background:rgba(5,5,5,0.85);backdrop-filter:blur(6px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;border-radius:var(--radius-md);gap:8px}
.locked-overlay .lock-emoji{font-size:2rem}
.locked-overlay .lock-text{font-size:0.65rem;color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:0.1em}

/* ================================================================
   CODES BAR
   ================================================================ */
.tcn-codes-bar{background:linear-gradient(135deg,rgba(160,241,234,0.08),rgba(160,241,234,0.03));border:1px solid rgba(160,241,234,0.15);border-radius:var(--radius-md);padding:20px 24px;margin-bottom:32px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.tcn-codes-bar .codes-label{font-size:0.65rem;font-weight:800;text-transform:uppercase;letter-spacing:0.12em;color:var(--clr-text-muted);white-space:nowrap}
.tcn-codes-bar .code-pills{display:flex;gap:10px;flex-wrap:wrap}
.code-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;background:rgba(160,241,234,0.12);border:1px solid rgba(160,241,234,0.25);color:var(--clr-primary);font-size:0.7rem;font-weight:700;letter-spacing:0.08em;cursor:pointer;transition:var(--transition)}
.code-pill:hover{background:rgba(160,241,234,0.2);border-color:var(--clr-primary)}
.code-pill.copied{background:var(--clr-primary);color:#000}
.code-pill svg{width:12px;height:12px}

/* ================================================================
   DEPARTMENT ECOSYSTEM
   ================================================================ */
.tcn-dept-hero{position:relative;padding:60px 0 40px;overflow:hidden}
.tcn-dept-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at top,rgba(160,241,234,0.06),transparent 70%);pointer-events:none}
.dept-hero-inner{position:relative;z-index:1;max-width:var(--container-max);margin:0 auto;padding:0 var(--sp-md)}
.dept-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;background:rgba(160,241,234,0.1);border:1px solid rgba(160,241,234,0.2);color:var(--clr-primary);font-size:0.6rem;font-weight:800;letter-spacing:0.15em;text-transform:uppercase;margin-bottom:16px}
.dept-title{font-size:clamp(2rem,5vw,3.5rem);font-family:var(--font-title);margin-bottom:8px;letter-spacing:-0.02em}
.dept-description{color:var(--clr-text-muted);font-size:0.9rem;max-width:600px;line-height:1.6}
.dept-stats{display:flex;gap:32px;margin-top:24px}
.dept-stat-item .stat-num{font-size:1.5rem;font-weight:800;color:#fff}
.dept-stat-item .stat-label{font-size:0.6rem;color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:0.1em}

.dept-inactive-banner{background:rgba(255,77,77,0.08);border:1px solid rgba(255,77,77,0.2);border-radius:var(--radius-sm);padding:12px 20px;display:flex;align-items:center;gap:12px;margin-bottom:24px}
.dept-inactive-banner svg{color:var(--clr-accent);flex-shrink:0}
.dept-inactive-banner span{font-size:0.75rem;color:var(--clr-accent);font-weight:600}

/* Filter tabs */
.tcn-filter-tabs{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}
.tcn-filter-tab{padding:6px 16px;border-radius:20px;font-size:0.65rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--clr-text-muted);background:var(--clr-surface);border:1px solid var(--clr-border);cursor:pointer;transition:var(--transition)}
.tcn-filter-tab:hover,.tcn-filter-tab.active{color:var(--clr-primary);border-color:var(--clr-primary);background:rgba(160,241,234,0.08)}

/* ================================================================
   FRONT PAGE
   ================================================================ */
.fp-hero{position:relative;min-height:80vh;display:flex;align-items:center;overflow:hidden;padding:var(--sp-xl) 0 var(--sp-lg)}
.fp-hero__bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(160,241,234,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(160,241,234,0.04) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}
.fp-hero__glow{position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:800px;height:600px;background:radial-gradient(ellipse at center,rgba(160,241,234,0.12) 0%,transparent 70%);pointer-events:none}
.fp-hero__bg-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,15,39,0.55) 0%,rgba(13,15,39,0.85) 100%);z-index:0;pointer-events:none}
.fp-hero__content{position:relative;z-index:1}
.fp-hero__eyebrow{font-size:0.7rem;font-weight:800;letter-spacing:0.2em;color:var(--clr-primary);text-transform:uppercase;margin-bottom:16px}
.fp-hero__title{font-size:clamp(2.5rem,6vw,4.5rem);font-family:var(--font-title);line-height:1.05;margin-bottom:24px;letter-spacing:-0.02em}
.fp-hero__sub{font-size:1rem;color:var(--clr-text-muted);max-width:550px;line-height:1.7;margin-bottom:40px}
.fp-hero__actions{display:flex;gap:16px;flex-wrap:wrap}
.fp-hero__stats{display:flex;gap:40px;margin-top:48px}
.fp-hero__stat-val{font-size:2rem;font-weight:800}
.fp-hero__stat-lbl{font-size:0.65rem;color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:0.12em}

/* Department Cards */
.dept-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin:32px 0}
.dept-card{position:relative;background:var(--clr-surface);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--clr-border);transition:var(--transition)}
.dept-card:hover{transform:translateY(-4px);border-color:var(--clr-primary)}
.dept-card__img{aspect-ratio:16/9;background-size:cover;background-position:center;position:relative}
.dept-card__img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(5,5,5,0.8),transparent)}
.dept-card__meta{padding:16px;position:relative}
.dept-card__name{font-family:var(--font-title);font-size:0.9rem;margin-bottom:4px}
.dept-card__status{font-size:0.6rem;color:var(--clr-primary);font-weight:700;letter-spacing:0.1em;text-transform:uppercase}
.dept-card.is-inactive{opacity:0.4;filter:grayscale(0.5)}
.dept-card.is-inactive .dept-card__status{color:var(--clr-text-muted)}

/* ================================================================
   CHANNEL PAGE
   ================================================================ */
.channel-hero{text-align:center;padding:60px 0 40px}
.channel-avatar{width:80px;height:80px;border-radius:50%;border:2px solid var(--clr-primary);margin:0 auto 16px;background:var(--clr-surface);display:flex;align-items:center;justify-content:center;font-family:var(--font-title);font-size:1.5rem;overflow:hidden}
.channel-avatar img{width:100%;height:100%;object-fit:cover}
.channel-name{font-family:var(--font-title);font-size:1.5rem;margin-bottom:4px}
.channel-handle{font-size:0.75rem;color:var(--clr-primary);letter-spacing:0.08em}
.channel-nav{display:flex;justify-content:center;gap:32px;margin-top:24px;padding-bottom:16px;border-bottom:1px solid var(--clr-border)}
.channel-nav a{font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--clr-text-muted);padding-bottom:16px;border-bottom:2px solid transparent;transition:var(--transition)}
.channel-nav a:hover,.channel-nav a.active{color:var(--clr-primary);border-bottom-color:var(--clr-primary)}

/* ================================================================
   COCKPIT PLAYER (single audio/video)
   ================================================================ */
.cinematic-container{max-width:1200px;margin:40px auto;padding:0 20px}
.player-cockpit{background:#000;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--clr-border);box-shadow:0 40px 100px rgba(0,0,0,0.5)}
.cockpit-view{aspect-ratio:16/9;background:#050505}
.cockpit-controls{padding:24px 32px;display:flex;justify-content:space-between;align-items:flex-end;background:linear-gradient(to top,#0f1117,#0a0a0f)}
.cockpit-title-pnl h1{font-size:1.3rem;margin-bottom:4px;letter-spacing:-0.02em}
.cockpit-artist{color:var(--clr-primary);font-size:0.75rem;font-weight:800;letter-spacing:0.1em}
.cockpit-actions{display:flex;gap:12px}
.cockpit-actions button{padding:8px 16px;border-radius:6px;font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;border:1px solid var(--clr-border);color:var(--clr-text-muted);transition:var(--transition)}
.cockpit-actions button:hover{border-color:var(--clr-primary);color:var(--clr-primary)}

@media(max-width:768px){
    .cockpit-controls{flex-direction:column;align-items:flex-start;gap:16px;padding:16px 20px}
}

/* ================================================================
   DASHBOARD / ACCOUNT
   ================================================================ */
.stats-tray{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:24px}
.stat-box{background:var(--clr-surface);padding:28px;border-radius:var(--radius-md);text-align:center;border:1px solid var(--clr-border)}
.stat-val{font-size:2rem;color:#fff;margin-bottom:6px}
.stat-lbl{font-size:0.7rem;color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:0.1em}

.panel-card{background:var(--clr-surface);border-radius:var(--radius-md);border:1px solid var(--clr-border);overflow:hidden;margin-bottom:24px}
.panel-header{padding:14px 24px;border-bottom:1px solid var(--clr-border);display:flex;align-items:center;gap:12px}
.panel-title{font-size:0.8rem;color:var(--clr-primary);font-weight:700;letter-spacing:0.08em;text-transform:uppercase}
.panel-body{padding:24px}

.code-item{background:#000;padding:16px;border-radius:8px;display:flex;justify-content:space-between;align-items:center;border-left:4px solid var(--clr-primary);transition:var(--transition);margin-bottom:8px}
.code-item:hover{background:var(--clr-surface-light)}
.code-name{font-weight:900;font-size:0.9rem}
.code-target{font-size:0.7rem;color:var(--clr-text-muted)}
.role-badge{background:rgba(160,241,234,0.1);color:var(--clr-primary);padding:6px 14px;border-radius:20px;font-size:0.65rem;font-weight:700;text-transform:uppercase;border:1px solid rgba(160,241,234,0.2)}

.redeem-form{display:flex;gap:12px;max-width:400px}
.redeem-input{flex-grow:1;background:#000;border:1px solid var(--clr-border);padding:12px;color:#fff;border-radius:4px;font-size:0.85rem}
.redeem-btn{background:var(--clr-primary);color:#000;padding:0 20px;border-radius:4px;font-weight:800;text-transform:uppercase;font-size:0.75rem}

/* ================================================================
   SIDE CART
   ================================================================ */
.side-cart-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);z-index:10000;display:none}
.side-cart-overlay.active{display:block}
.side-cart-panel{position:fixed;top:0;right:-400px;width:400px;height:100%;background:var(--clr-bg);z-index:10001;transition:right 0.4s cubic-bezier(0.4,0,0.2,1);border-left:1px solid var(--clr-border);display:flex;flex-direction:column}
.side-cart-panel.active{right:0}
.side-cart-header{padding:var(--sp-md);border-bottom:1px solid var(--clr-border);display:flex;justify-content:space-between;align-items:center}
.side-cart-body{flex-grow:1;overflow-y:auto;padding:var(--sp-md)}
.side-cart-footer{padding:var(--sp-md);border-top:1px solid var(--clr-border)}

@media(max-width:768px){
    .stats-tray{grid-template-columns:1fr}
    .side-cart-panel{width:100%}
}

/* ================================================================
   FOOTER
   ================================================================ */
.site-footer{padding:48px 0 24px;border-top:1px solid var(--clr-border)}
.footer-inner{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:32px;margin-bottom:32px}
.footer-brand .footer-title{font-family:var(--font-title);font-size:1.2rem;margin-bottom:8px}
.footer-brand p{font-size:0.75rem;color:var(--clr-text-muted);max-width:280px;line-height:1.6}
.footer-links{display:flex;gap:40px}
.footer-links-col h4{font-size:0.65rem;font-weight:800;letter-spacing:0.12em;text-transform:uppercase;color:var(--clr-text-muted);margin-bottom:12px}
.footer-links-col a{display:block;font-size:0.8rem;color:var(--clr-text-muted);margin-bottom:8px;transition:var(--transition)}
.footer-links-col a:hover{color:var(--clr-primary)}
.footer-bottom{text-align:center;font-size:0.7rem;color:var(--clr-text-muted);padding-top:24px;border-top:1px solid var(--clr-border)}

/* ================================================================
   EMPTY STATE
   ================================================================ */
.empty-state{text-align:center;padding:48px 24px;background:rgba(255,255,255,0.02);border-radius:var(--radius-md);border:1px dashed var(--clr-border);grid-column:1/-1}
.empty-state p{font-size:0.85rem;color:var(--clr-text-muted);margin-bottom:12px}

/* ================================================================
   WP OVERRIDES
   ================================================================ */
.wp-block-embed__wrapper{max-width:100%}
.wp-block-embed iframe{max-width:100%}
#wpadminbar{opacity:0.3;transition:opacity 0.3s}
#wpadminbar:hover{opacity:1}

/* ── Sitewide hero background pass-through ── */
/* Make hero/top sections transparent so the header.php ::before bg image shows */
.tcn-arc-hero{background:transparent!important}
.tcn-single-hero{background-color:transparent!important}
.tsshop-wrap{background:transparent!important}
.tcn-dept-hero{background:transparent!important}
body:not(.home) .site-main>*:first-child{background-color:transparent!important}

.site-header--scrolled{background:rgba(6,10,28,0.70);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom-color:rgba(255,255,255,0.08)}
.main-nav .menu-item a{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--clr-text-muted);text-decoration:none;transition:color .2s}
.main-nav .menu-item a:hover{color:var(--clr-primary)}
.main-nav .menu{display:flex;gap:28px;list-style:none;margin:0;padding:0}

/* ═══════════════════════════════════════════════
   MOBILE BOTTOM NAV
   ═══════════════════════════════════════════════ */
.tcn-bottom-nav {
    display:none; /* hidden on desktop */
    position:fixed;
    bottom:0;
    left:0;
    right:0;
    z-index:9999;
    background:rgba(10,14,23,0.95);
    backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    border-top:1px solid rgba(160,241,234,0.08);
    padding:6px 0 env(safe-area-inset-bottom, 8px);
    transition:transform .3s ease;
}
@media (max-width:768px) {
    .tcn-bottom-nav { display:flex !important; justify-content:space-around; align-items:center; }
    body { padding-bottom:72px; } /* space for nav */
    .site-footer { padding-bottom:80px; }
}
.tcn-bottom-nav.bnav-hidden { transform:translateY(100%); }
.bnav-item {
    display:flex; flex-direction:column; align-items:center; gap:2px;
    padding:6px 12px; color:rgba(255,255,255,0.45); text-decoration:none;
    font-size:0.6rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase;
    transition:color .2s;
    -webkit-tap-highlight-color:transparent;
}
.bnav-item svg { transition:all .2s; }
.bnav-item.bnav-active,
.bnav-item:hover { color:#A0F1EA; }
.bnav-item.bnav-active svg { filter:drop-shadow(0 0 6px rgba(160,241,234,0.4)); }
.bnav-center-icon {
    width:48px; height:48px; border-radius:50%;
    background:linear-gradient(135deg,#A0F1EA,#00c088);
    display:flex; align-items:center; justify-content:center;
    margin-top:-20px; box-shadow:0 4px 20px rgba(160,241,234,0.3);
    transition:all .2s;
}
.bnav-center-icon svg { color:#000; stroke:#000; }
.bnav-center:hover .bnav-center-icon,
.bnav-center.bnav-active .bnav-center-icon { box-shadow:0 4px 28px rgba(160,241,234,0.5); transform:scale(1.05); }
.bnav-center span { margin-top:2px; }

/* ═══════════════════════════════════════════════
   PWA INSTALL BANNER
   ═══════════════════════════════════════════════ */
.tcn-install-banner {
    position:fixed; bottom:80px; left:12px; right:12px;
    z-index:10000; animation:slideUp .4s ease;
}
@media (min-width:769px) {
    .tcn-install-banner { bottom:20px; left:auto; right:20px; max-width:360px; }
}
.install-inner {
    display:flex; align-items:center; gap:12px;
    background:rgba(20,26,40,0.96); backdrop-filter:blur(16px);
    border:1px solid rgba(160,241,234,0.15); border-radius:16px;
    padding:14px 16px; box-shadow:0 8px 32px rgba(0,0,0,0.5);
}
.install-icon { width:40px; height:40px; border-radius:10px; }
.install-text { flex:1; display:flex; flex-direction:column; }
.install-text strong { color:#fff; font-size:0.85rem; }
.install-text span { color:rgba(255,255,255,0.5); font-size:0.7rem; }
.install-btn {
    background:#A0F1EA; color:#000; border:none; border-radius:8px;
    padding:8px 16px; font-weight:800; font-size:0.7rem; letter-spacing:0.06em;
    cursor:pointer; white-space:nowrap;
}
.install-close {
    background:none; border:none; color:rgba(255,255,255,0.4);
    font-size:1.2rem; cursor:pointer; padding:4px;
}
@keyframes slideUp {
    from { transform:translateY(100px); opacity:0; }
    to { transform:translateY(0); opacity:1; }
}

/* ══════════════════════════════════════════════════════════
   WOOCOMMERCE CHECKOUT — Dark Theme
   ══════════════════════════════════════════════════════════ */
.woocommerce-checkout .tcn-wc-page {
  max-width: 720px;
  margin: 0 auto;
  padding: 40px 20px 80px;
}
.woocommerce-checkout .tcn-wc-page-title {
  font-size: clamp(1.4rem, 4vw, 2rem);
  font-weight: 900;
  color: #fff;
  letter-spacing: -0.02em;
  margin-bottom: 28px;
  text-align: center;
}
/* WC notices */
.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .woocommerce-message {
  background: rgba(160,241,234,0.06) !important;
  border: 1px solid rgba(160,241,234,0.15) !important;
  border-radius: 10px !important;
  color: rgba(255,255,255,0.7) !important;
  padding: 14px 20px !important;
  margin-bottom: 16px !important;
  font-size: 0.85rem;
}
.woocommerce-checkout .woocommerce-info a,
.woocommerce-checkout .woocommerce-message a {
  color: var(--clr-primary, #A0F1EA) !important;
  font-weight: 700;
}
.woocommerce-checkout .woocommerce-info::before,
.woocommerce-checkout .woocommerce-message::before {
  color: var(--clr-primary, #A0F1EA) !important;
}
.woocommerce-checkout .woocommerce-error {
  background: rgba(239,68,68,0.08) !important;
  border: 1px solid rgba(239,68,68,0.2) !important;
  border-radius: 10px !important;
  color: #ff6b6b !important;
  padding: 14px 20px !important;
  list-style: none !important;
}
/* Form layout */
.woocommerce-checkout .col2-set {
  display: block !important;
}
.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 {
  float: none !important;
  width: 100% !important;
  max-width: 100% !important;
}
.woocommerce-checkout h3 {
  font-size: 1rem !important;
  font-weight: 800 !important;
  color: var(--clr-primary, #A0F1EA) !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  margin: 28px 0 16px !important;
}
.woocommerce-checkout h3:first-child {
  margin-top: 0 !important;
}
/* Input fields */
.woocommerce-checkout .form-row {
  margin-bottom: 14px !important;
  padding: 0 !important;
}
.woocommerce-checkout .form-row label {
  color: rgba(255,255,255,0.5) !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  margin-bottom: 6px !important;
  display: block !important;
}
.woocommerce-checkout .form-row label .required {
  color: var(--clr-primary, #A0F1EA) !important;
}
.woocommerce-checkout input.input-text,
.woocommerce-checkout select,
.woocommerce-checkout textarea {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  border-radius: 8px !important;
  color: #fff !important;
  padding: 12px 16px !important;
  font-size: 0.9rem !important;
  width: 100% !important;
  box-sizing: border-box !important;
  outline: none !important;
  transition: border-color 0.2s !important;
}
.woocommerce-checkout input.input-text:focus,
.woocommerce-checkout select:focus,
.woocommerce-checkout textarea:focus {
  border-color: var(--clr-primary, #A0F1EA) !important;
}
.woocommerce-checkout select option {
  background: #0d0f18 !important;
  color: #fff !important;
}
/* Two-column name fields */
.woocommerce-checkout .form-row-first,
.woocommerce-checkout .form-row-last {
  width: 48% !important;
  display: inline-block !important;
  vertical-align: top !important;
}
.woocommerce-checkout .form-row-first { margin-right: 4% !important; }
/* Order review / table */
.woocommerce-checkout .woocommerce-checkout-review-order {
  background: rgba(255,255,255,0.03) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 12px !important;
  padding: 24px !important;
  margin-top: 24px !important;
}
.woocommerce-checkout .shop_table {
  border: none !important;
  border-collapse: collapse !important;
  width: 100% !important;
}
.woocommerce-checkout .shop_table th,
.woocommerce-checkout .shop_table td {
  border: none !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  padding: 12px 0 !important;
  color: rgba(255,255,255,0.7) !important;
  font-size: 0.85rem !important;
}
.woocommerce-checkout .shop_table thead th {
  color: rgba(255,255,255,0.4) !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
}
.woocommerce-checkout .shop_table .order-total th,
.woocommerce-checkout .shop_table .order-total td {
  color: #fff !important;
  font-weight: 800 !important;
  font-size: 1.1rem !important;
  border-bottom: none !important;
}
.woocommerce-checkout .shop_table .amount {
  color: var(--clr-primary, #A0F1EA) !important;
  font-weight: 800 !important;
}
/* Payment methods */
.woocommerce-checkout #payment {
  background: transparent !important;
  border-radius: 12px !important;
}
.woocommerce-checkout #payment ul.payment_methods {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 16px !important;
  border: none !important;
}
.woocommerce-checkout #payment ul.payment_methods li {
  background: rgba(255,255,255,0.03) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 10px !important;
  padding: 16px !important;
  margin-bottom: 8px !important;
}
.woocommerce-checkout #payment ul.payment_methods li label {
  color: #fff !important;
  font-weight: 700 !important;
  cursor: pointer !important;
}
.woocommerce-checkout #payment .payment_box {
  background: rgba(255,255,255,0.02) !important;
  color: rgba(255,255,255,0.5) !important;
  border-radius: 8px !important;
  padding: 12px !important;
  margin-top: 10px !important;
  font-size: 0.8rem !important;
}
.woocommerce-checkout #payment .payment_box::before {
  display: none !important;
}
/* Place order button */
.woocommerce-checkout #place_order {
  background: var(--clr-primary, #A0F1EA) !important;
  color: #000 !important;
  border: none !important;
  border-radius: 10px !important;
  padding: 16px 32px !important;
  font-weight: 900 !important;
  font-size: 1rem !important;
  letter-spacing: 0.05em !important;
  width: 100% !important;
  cursor: pointer !important;
  transition: opacity 0.2s !important;
}
.woocommerce-checkout #place_order:hover {
  opacity: 0.85 !important;
}
/* WC checkout privacy text */
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
  color: rgba(255,255,255,0.35) !important;
  font-size: 0.75rem !important;
  margin-bottom: 16px !important;
}
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper a {
  color: var(--clr-primary, #A0F1EA) !important;
}
/* Select2 dropdowns (WC uses these for country/state) */
.woocommerce-checkout .select2-container--default .select2-selection--single {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  border-radius: 8px !important;
  height: auto !important;
  padding: 8px 12px !important;
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: #fff !important;
  line-height: 1.5 !important;
  padding: 0 !important;
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
  top: 50% !important;
  transform: translateY(-50%) !important;
}
.select2-dropdown {
  background: #0d0f18 !important;
  border: 1px solid rgba(255,255,255,0.15) !important;
  border-radius: 8px !important;
}
.select2-results__option {
  color: rgba(255,255,255,0.7) !important;
  padding: 10px 14px !important;
}
.select2-results__option--highlighted {
  background: rgba(160,241,234,0.15) !important;
  color: #fff !important;
}
.select2-search--dropdown .select2-search__field {
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  border-radius: 6px !important;
  color: #fff !important;
  padding: 8px 12px !important;
}
/* Coupon field */
.woocommerce-checkout .checkout_coupon {
  background: rgba(255,255,255,0.03) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 10px !important;
  padding: 16px !important;
}
.woocommerce-checkout .checkout_coupon .form-row-first {
  width: 65% !important;
}
.woocommerce-checkout .checkout_coupon .form-row-last {
  width: 30% !important;
}
.woocommerce-checkout .checkout_coupon .button {
  background: var(--clr-primary, #A0F1EA) !important;
  color: #000 !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 12px 20px !important;
  font-weight: 800 !important;
  cursor: pointer !important;
}
/* WC Cart page similar styling */
.woocommerce-cart .tcn-wc-page {
  max-width: 720px;
  margin: 0 auto;
  padding: 40px 20px 80px;
}
.woocommerce-cart .shop_table {
  border: none !important;
  width: 100% !important;
}
.woocommerce-cart .shop_table th,
.woocommerce-cart .shop_table td {
  border: none !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  padding: 14px 8px !important;
  color: rgba(255,255,255,0.7) !important;
}
.woocommerce-cart .button {
  background: var(--clr-primary, #A0F1EA) !important;
  color: #000 !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 12px 24px !important;
  font-weight: 800 !important;
  cursor: pointer !important;
}

/* ══════════════════════════════════════════════════
   SHOP PAGE FIX — hide old Elementor content bleed
   ══════════════════════════════════════════════════ */
.page-id-1473 .site-main {
    position: relative;
}
.page-id-1473 .site-main > .entry-content > *:not(.tsshop-wrap):not(script):not(style) {
    display: none !important;
}
.page-id-1473 .tsshop-wrap {
    position: relative;
    z-index: 2;
    background: #050505;
}
.page-id-1473 .site-main::before {
    display: none !important;
}