/* ============================================
   CINEBLACK3 LAYOUTS
   ============================================ */

/* ---- App Layout ---- */
.cb3-app { display: flex; min-height: 100vh; }

/* ---- Sidebar ---- */
.cb3-sidebar {
    position: fixed; top: 0; left: 0; bottom: 0;
    width: var(--cb-sidebar-width);
    background: var(--cb-bg-sidebar);
    border-right: 1px solid var(--cb-border);
    display: flex; flex-direction: column;
    z-index: var(--cb-z-sidebar);
    transition: transform var(--cb-duration-slow) var(--cb-ease);
}
.cb3-sidebar-logo {
    padding: var(--cb-space-lg) var(--cb-space-lg);
    border-bottom: 1px solid var(--cb-border);
}
.cb3-sidebar-nav { flex: 1; overflow-y: auto; padding: var(--cb-space-md) 0; }
.cb3-sidebar-menu { list-style: none; padding: 0; }
.cb3-sidebar-menu .cb3-nav-item { margin: 2px 8px; }
.cb3-sidebar-menu .cb3-nav-link {
    display: flex; align-items: center; gap: 14px;
    padding: 11px 16px; border-radius: var(--cb-radius-sm);
    color: var(--cb-text-secondary); font-weight: 500;
    font-size: var(--cb-font-size-sm);
    transition: all var(--cb-duration) var(--cb-ease);
}
.cb3-sidebar-menu .cb3-nav-link:hover {
    background: var(--cb-bg-hover); color: var(--cb-text-primary);
}
.cb3-sidebar-menu .cb3-nav-item.active .cb3-nav-link {
    background: var(--cb-gold-glow); color: var(--cb-gold);
    border-left: 3px solid var(--cb-gold);
}
.cb3-sidebar-menu .cb3-nav-link svg { flex-shrink: 0; opacity: 0.7; }
.cb3-sidebar-menu .cb3-nav-item.active .cb3-nav-link svg { opacity: 1; }
.cb3-sidebar-bottom {
    padding: var(--cb-space-lg);
    border-top: 1px solid var(--cb-border);
}
.cb3-sidebar-user {
    display: flex; align-items: center; gap: 10px;
    padding: 8px; border-radius: var(--cb-radius-sm);
    transition: background var(--cb-duration) var(--cb-ease);
}
.cb3-sidebar-user:hover { background: var(--cb-bg-hover); }
.cb3-sidebar-user img { border-radius: 50%; }
.cb3-sidebar-user span { font-size: var(--cb-font-size-sm); color: var(--cb-text-secondary); }

/* ---- Main Content Wrap ---- */
.cb3-main-wrap {
    flex: 1;
    margin-left: var(--cb-sidebar-width);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* ---- Header ---- */
.cb3-header {
    position: sticky; top: 0;
    height: var(--cb-header-height);
    background: var(--cb-bg-glass);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border-bottom: 1px solid var(--cb-border);
    z-index: var(--cb-z-header);
    transition: background var(--cb-duration) var(--cb-ease);
}
.cb3-header.scrolled { background: rgba(10,10,10,0.95); }
.cb3-header-inner {
    display: flex; align-items: center; justify-content: space-between;
    height: 100%; padding: 0 var(--cb-space-xl);
}
.cb3-header-left { display: flex; align-items: center; gap: 16px; }
.cb3-mobile-menu-btn {
    display: none; background: none; border: none;
    color: var(--cb-text-primary); cursor: pointer;
    padding: 8px; border-radius: var(--cb-radius-sm);
}
.cb3-header-logo-mobile { display: none; }
.cb3-header-nav { flex: 1; display: flex; justify-content: center; }
.cb3-top-menu {
    display: flex; gap: 8px; list-style: none; padding: 0;
}
.cb3-top-menu .cb3-nav-link {
    padding: 8px 16px; border-radius: var(--cb-radius-full);
    font-size: var(--cb-font-size-sm); font-weight: 500;
    color: var(--cb-text-secondary);
    transition: all var(--cb-duration) var(--cb-ease);
}
.cb3-top-menu .cb3-nav-link:hover { color: var(--cb-text-primary); background: var(--cb-bg-hover); }
.cb3-top-menu .active .cb3-nav-link { color: var(--cb-gold); }
.cb3-header-right { display: flex; align-items: center; gap: 8px; }

/* Search */
.cb3-search-wrap { position: relative; }
.cb3-search-panel {
    position: absolute; top: 50%; right: 0;
    transform: translateY(-50%);
    width: 0; opacity: 0; overflow: hidden;
    transition: all var(--cb-duration) var(--cb-ease);
}
.cb3-search-wrap.active .cb3-search-panel {
    width: 340px; opacity: 1;
}
.cb3-search-input {
    width: 100%; padding: 10px 16px;
    background: var(--cb-bg-elevated);
    border: 1px solid var(--cb-border-light);
    border-radius: var(--cb-radius-full);
    color: var(--cb-text-primary); font-size: var(--cb-font-size-sm);
}
.cb3-search-input:focus { outline: none; border-color: var(--cb-gold); }
.cb3-search-results {
    position: absolute; top: calc(100% + 8px); right: 0;
    width: 380px; max-height: 400px; overflow-y: auto;
    background: var(--cb-bg-elevated); border: 1px solid var(--cb-border-light);
    border-radius: var(--cb-radius-md); box-shadow: var(--cb-shadow-xl);
    display: none; z-index: 10;
}
.cb3-search-item {
    display: flex; gap: 12px; padding: 10px 14px;
    transition: background var(--cb-duration) var(--cb-ease);
}
.cb3-search-item:hover { background: var(--cb-bg-hover); }
.cb3-search-thumb { width: 50px; height: 50px; border-radius: var(--cb-radius-sm); overflow: hidden; flex-shrink: 0; }
.cb3-search-thumb img { width: 100%; height: 100%; object-fit: cover; }
.cb3-search-info { flex: 1; display: flex; flex-direction: column; justify-content: center; }
.cb3-search-title { font-size: var(--cb-font-size-sm); font-weight: 600; }
.cb3-search-meta { font-size: var(--cb-font-size-xs); color: var(--cb-text-muted); }
.cb3-search-empty { padding: 20px; text-align: center; color: var(--cb-text-muted); }
.cb3-user-avatar img { border-radius: 50%; width: 32px; height: 32px; }

/* ---- Logo ---- */
.cb3-logo-text-link { font-family: var(--cb-font-display); font-size: 20px; font-weight: 900; letter-spacing: 2px; display: flex; }
.cb3-logo-cine { color: var(--cb-text-primary); }
.cb3-logo-black { color: var(--cb-gold); }

/* ---- Footer ---- */
.cb3-footer {
    background: var(--cb-bg-secondary);
    border-top: 1px solid var(--cb-border);
    margin-top: auto;
}
.cb3-footer-inner { max-width: var(--cb-content-max); margin: 0 auto; padding: var(--cb-space-3xl) var(--cb-space-xl) var(--cb-space-xl); }
.cb3-footer-top { display: grid; grid-template-columns: 1fr 3fr; gap: var(--cb-space-3xl); margin-bottom: var(--cb-space-2xl); }
.cb3-footer-brand .cb3-logo-text-link { font-size: 24px; margin-bottom: var(--cb-space-md); }
.cb3-footer-tagline { color: var(--cb-text-muted); font-size: var(--cb-font-size-sm); }
.cb3-footer-columns { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--cb-space-xl); }
.cb3-footer-widget-title { font-size: var(--cb-font-size-sm); color: var(--cb-text-muted); text-transform: uppercase; letter-spacing: 1px; margin-bottom: var(--cb-space-md); }
.cb3-footer-links { list-style: none; padding: 0; }
.cb3-footer-links li { margin-bottom: 8px; }
.cb3-footer-links a { color: var(--cb-text-secondary); font-size: var(--cb-font-size-sm); transition: color var(--cb-duration) var(--cb-ease); }
.cb3-footer-links a:hover { color: var(--cb-gold); }
.cb3-footer-social { display: flex; gap: 12px; justify-content: center; margin-bottom: var(--cb-space-xl); }
.cb3-social-link {
    width: 40px; height: 40px; border-radius: 50%;
    background: var(--cb-bg-hover); display: flex;
    align-items: center; justify-content: center;
    color: var(--cb-text-muted);
    transition: all var(--cb-duration) var(--cb-ease);
}
.cb3-social-link:hover { background: var(--cb-gold); color: #0a0a0a; }
.cb3-footer-devices { display: flex; gap: 12px; justify-content: center; margin-bottom: var(--cb-space-xl); }
.cb3-device-badge {
    padding: 6px 16px; border-radius: var(--cb-radius-full);
    background: var(--cb-bg-hover); color: var(--cb-text-muted);
    font-size: var(--cb-font-size-xs);
}
.cb3-footer-bottom { text-align: center; padding-top: var(--cb-space-xl); border-top: 1px solid var(--cb-border); }
.cb3-footer-bottom p { font-size: var(--cb-font-size-xs); color: var(--cb-text-dim); }

/* ---- Mobile Bottom Nav ---- */
.cb3-mobile-nav {
    display: none; position: fixed; bottom: 0; left: 0; right: 0;
    height: var(--cb-mobile-nav-height);
    background: var(--cb-bg-glass); backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-top: 1px solid var(--cb-border);
    z-index: var(--cb-z-header);
    justify-content: space-around; align-items: center;
}
.cb3-mobile-nav-item {
    display: flex; flex-direction: column; align-items: center;
    gap: 4px; font-size: 10px; color: var(--cb-text-muted);
    transition: color var(--cb-duration) var(--cb-ease);
}
.cb3-mobile-nav-item.active { color: var(--cb-gold); }

/* ---- Overlay ---- */
.cb3-menu-overlay {
    display: none; position: fixed; inset: 0;
    background: rgba(0,0,0,0.5); z-index: calc(var(--cb-z-sidebar) - 1);
}
.cb3-menu-open .cb3-menu-overlay { display: block; }

/* ---- Dashboard Layout ---- */
.cb3-dashboard { display: flex; gap: var(--cb-space-xl); padding: var(--cb-space-xl); }
.cb3-dash-sidebar {
    width: 260px; flex-shrink: 0;
    background: var(--cb-bg-card); border: 1px solid var(--cb-border);
    border-radius: var(--cb-radius-lg); padding: var(--cb-space-xl);
    height: fit-content; position: sticky; top: calc(var(--cb-header-height) + var(--cb-space-xl));
}
.cb3-dash-user { text-align: center; margin-bottom: var(--cb-space-xl); }
.cb3-dash-avatar img { border-radius: 50%; margin: 0 auto var(--cb-space-md); }
.cb3-dash-name { font-size: var(--cb-font-size-lg); }
.cb3-dash-plan {
    display: inline-block; padding: 4px 14px; border-radius: var(--cb-radius-full);
    background: var(--cb-gold-glow); color: var(--cb-gold);
    font-size: var(--cb-font-size-xs); font-weight: 600; margin-top: 8px;
}
.cb3-dash-nav { margin-top: var(--cb-space-md); }
.cb3-dash-nav-item {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 14px; border-radius: var(--cb-radius-sm);
    font-size: var(--cb-font-size-sm); color: var(--cb-text-secondary);
    margin-bottom: 2px; transition: all var(--cb-duration) var(--cb-ease);
}
.cb3-dash-nav-item:hover { background: var(--cb-bg-hover); color: var(--cb-text-primary); }
.cb3-dash-nav-item.active { background: var(--cb-gold-glow); color: var(--cb-gold); }
.cb3-nav-logout { color: var(--cb-accent-red); margin-top: var(--cb-space-md); }
.cb3-dash-content { flex: 1; min-width: 0; }
.cb3-dash-content h2 { margin-bottom: var(--cb-space-xl); }

/* Dashboard Stats */
.cb3-dash-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--cb-space-md); margin-bottom: var(--cb-space-xl); }
.cb3-stat-card {
    background: var(--cb-bg-card); border: 1px solid var(--cb-border);
    border-radius: var(--cb-radius-md); padding: var(--cb-space-lg); text-align: center;
}
.cb3-stat-card .cb3-stat-icon { font-size: 28px; }
.cb3-stat-card .cb3-stat-value { display: block; font-size: var(--cb-font-size-xl); font-weight: 700; color: var(--cb-gold); margin: 8px 0 4px; }
.cb3-stat-card .cb3-stat-label { font-size: var(--cb-font-size-xs); color: var(--cb-text-muted); }

/* Dashboard CTA */
.cb3-dash-cta {
    padding: var(--cb-space-2xl); border-radius: var(--cb-radius-lg);
    background: linear-gradient(135deg, rgba(212,168,65,0.1), transparent);
    border: 1px solid var(--cb-border-gold); text-align: center;
    margin-top: var(--cb-space-xl);
}
.cb3-dash-cta h3 { margin-bottom: var(--cb-space-sm); }
.cb3-dash-cta p { margin-bottom: var(--cb-space-lg); }

/* Subscription Card */
.cb3-sub-card {
    background: var(--cb-bg-card); border: 1px solid var(--cb-border);
    border-radius: var(--cb-radius-lg); padding: var(--cb-space-2xl);
}
.cb3-sub-card.active { border-color: var(--cb-gold); }
.cb3-sub-status { font-weight: 600; color: var(--cb-accent-green); margin-bottom: var(--cb-space-md); }
.cb3-sub-amount { font-size: var(--cb-font-size-3xl); font-weight: 900; margin-bottom: var(--cb-space-sm); }
.cb3-sub-amount span { font-size: var(--cb-font-size-base); color: var(--cb-text-muted); font-weight: 400; }
.cb3-sub-period { color: var(--cb-text-muted); margin-bottom: var(--cb-space-xl); }
.cb3-cancel-sub { margin-top: var(--cb-space-md); }

/* Toggles */
.cb3-settings-group { display: flex; flex-direction: column; gap: var(--cb-space-md); }
.cb3-toggle-setting {
    display: flex; align-items: center; justify-content: space-between;
    padding: var(--cb-space-md); background: var(--cb-bg-card);
    border: 1px solid var(--cb-border); border-radius: var(--cb-radius-sm);
    cursor: pointer;
}
.cb3-toggle-setting span:first-child { font-size: var(--cb-font-size-sm); color: var(--cb-text-secondary); }

/* Help */
.cb3-help-links { display: grid; grid-template-columns: 1fr 1fr; gap: var(--cb-space-md); }
.cb3-help-card {
    padding: var(--cb-space-xl); background: var(--cb-bg-card);
    border: 1px solid var(--cb-border); border-radius: var(--cb-radius-md);
    text-align: center; transition: all var(--cb-duration) var(--cb-ease);
}
.cb3-help-card:hover { border-color: var(--cb-border-gold); transform: translateY(-2px); }
.cb3-help-card span { font-size: 32px; display: block; margin-bottom: var(--cb-space-md); }
.cb3-help-card h4 { margin-bottom: var(--cb-space-sm); }
.cb3-help-card p { font-size: var(--cb-font-size-sm); color: var(--cb-text-muted); }

/* ---- Page Content ---- */
.cb3-page-content { padding: var(--cb-space-2xl) var(--cb-space-xl); max-width: 900px; }
.cb3-page-title { font-size: var(--cb-font-size-3xl); margin-bottom: var(--cb-space-xl); }
.cb3-page-body { color: var(--cb-text-secondary); line-height: 1.8; }
.cb3-page-body h2, .cb3-page-body h3 { color: var(--cb-text-primary); margin: var(--cb-space-xl) 0 var(--cb-space-md); }
.cb3-page-body p { margin-bottom: var(--cb-space-md); }
.cb3-page-body ul, .cb3-page-body ol { padding-left: var(--cb-space-lg); margin-bottom: var(--cb-space-md); color: var(--cb-text-secondary); }

/* ---- Article ---- */
.cb3-article-header { margin-bottom: var(--cb-space-xl); }
.cb3-article-meta { color: var(--cb-text-muted); font-size: var(--cb-font-size-sm); }
.cb3-article-thumb { margin-bottom: var(--cb-space-xl); border-radius: var(--cb-radius-md); overflow: hidden; }
.cb3-article-content { color: var(--cb-text-secondary); line-height: 1.8; }
