.protected-loading{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-primary)}.protected-loading-inner{display:flex;flex-direction:column;align-items:center;gap:12px}.protected-loading-text{font-size:14px;color:var(--text-secondary)}.app-layout{display:flex;min-height:100vh;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans)}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0;z-index:50;transition:all var(--transition-normal)}.sidebar.collapsed{width:68px}.sidebar.mobile-hidden{transform:translate(-100%)}.sidebar-logo{padding:16px 20px;display:flex;align-items:center;justify-content:space-between}.sidebar-logo.collapsed{justify-content:center;padding:16px 8px}.sidebar-logo-link{display:flex;align-items:center;gap:10px;color:var(--accent);transition:color var(--transition-fast)}.sidebar-logo-link:hover{color:var(--accent-hover)}.sidebar-logo-text{font-size:18px;font-weight:700;letter-spacing:-.02em}.sidebar-collapse-btn{display:none;padding:4px;border-radius:6px;border:none;background:none;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.sidebar-collapse-btn:hover{color:var(--text-secondary);background:var(--bg-hover)}.sidebar-nav{flex:1;padding:0 12px}.sidebar-nav.collapsed{padding:0 8px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:14px;font-weight:500;transition:all var(--transition-fast);margin-bottom:2px;border-left:3px solid transparent}.nav-item.collapsed{justify-content:center;gap:0;padding:10px;border-left:none}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--bg-active);color:var(--accent);border-left-color:var(--accent)}.nav-item.active.collapsed{border-left-color:transparent}.nav-icon{width:20px;height:20px;flex-shrink:0;opacity:.7;transition:all var(--transition-fast)}.nav-item.active .nav-icon,.nav-item:hover .nav-icon{opacity:1}.nav-item.active .nav-icon{color:var(--accent)}.sidebar-expand{padding:8px}.sidebar-expand-btn{display:none;width:100%;align-items:center;justify-content:center;padding:8px;border-radius:var(--radius-sm);border:none;background:none;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.sidebar-expand-btn:hover{color:var(--text-secondary);background:var(--bg-hover)}.sidebar-user{padding:16px;border-top:1px solid var(--border-color)}.sidebar-user.collapsed{padding:16px 8px}.user-info{display:flex;align-items:center;gap:12px}.user-info.collapsed{justify-content:center;gap:0}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0;box-shadow:0 0 0 1px #f5a62333}.user-details{min-width:0;flex:1}.user-name{font-size:14px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{margin-top:12px;background:none;border:none;color:var(--text-muted);font-size:13px;cursor:pointer;padding:4px 0;display:flex;align-items:center;gap:6px;transition:color var(--transition-fast)}.logout-btn:hover{color:var(--danger)}.sidebar-backdrop{display:none;position:fixed;inset:0;background:#00000080;z-index:40}.main-area{margin-left:var(--sidebar-width);flex:1;display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition-normal)}.main-area.collapsed{margin-left:68px}.topbar{height:var(--topbar-height);border-bottom:1px solid var(--border-color);display:flex;align-items:center;padding:0 24px;gap:12px;position:sticky;top:0;background:var(--bg-card);z-index:30}.hamburger-btn{display:none;padding:6px;margin-left:-4px;border:none;background:none;color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast)}.hamburger-btn:hover{color:var(--text-primary)}.search-box{flex:1;max-width:400px;position:relative}.search-box input{width:100%;padding:8px 12px 8px 36px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:14px;outline:none;transition:border-color var(--transition-fast)}.search-box input::placeholder{color:var(--text-muted)}.search-box input:focus{border-color:var(--accent)}.search-box .search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);width:16px;height:16px}.topbar-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.icon-btn{width:36px;height:36px;border-radius:var(--radius-sm);border:none;background:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-primary{padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background var(--transition-fast);box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-md)}.content{flex:1;padding:24px}@media(min-width:1024px){.sidebar-collapse-btn,.sidebar-expand-btn{display:flex}}@media(max-width:1023px){.sidebar{transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.sidebar-backdrop.visible{display:block}.main-area,.main-area.collapsed{margin-left:0}.hamburger-btn{display:flex}.btn-primary.hide-mobile{display:none}.content{padding:16px}.topbar{padding:0 16px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f5f7,#e8e8ed,#f0eefc);position:relative;overflow:hidden;padding:16px}.login-page .circle-1{position:absolute;width:600px;height:600px;border-radius:50%;top:-20%;right:-10%;opacity:.07;background:radial-gradient(circle,#F5A623 0%,transparent 70%)}.login-page .circle-2{position:absolute;width:500px;height:500px;border-radius:50%;bottom:-20%;left:-10%;opacity:.05;background:radial-gradient(circle,#4A90D9 0%,transparent 70%)}.login-content{width:100%;max-width:380px;position:relative;z-index:1}.login-header{text-align:center;margin-bottom:32px}.login-icon{width:56px;height:56px;background:var(--accent-light);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.login-icon svg{width:28px;height:28px;color:var(--accent)}.login-title{font-size:30px;font-weight:700;color:#1d1d1f;margin:0;letter-spacing:-.02em}.login-subtitle{font-size:15px;color:#86868b;margin:8px 0 0}.login-card{background:#fff;border:1px solid rgba(229,229,231,.6);border-radius:var(--radius-lg);padding:32px;box-shadow:0 2px 20px #00000014}.google-btn{width:100%;padding:14px 20px;border:1px solid #dadce0;border-radius:var(--radius-md);background:#fff;color:#3c4043;font-size:15px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:all var(--transition-normal)}.google-btn:hover{background:#f8f9fa;border-color:#d2d2d2;box-shadow:0 1px 3px #00000014}.google-btn svg{width:20px;height:20px;flex-shrink:0}.login-footer{margin-top:24px;font-size:13px;color:#aeaeb2;text-align:center}.deck-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.deck-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:all var(--transition-normal);box-shadow:var(--shadow-sm);position:relative}.deck-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent)}.deck-card-thumbnail{aspect-ratio:16/9;overflow:hidden;position:relative}.deck-card-thumbnail img{width:100%;height:100%;object-fit:cover}.deck-card-thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:24px;opacity:.8}.deck-card-thumbnail-text{color:#ffffffe6;font-size:18px;font-weight:600;text-align:center;line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;text-shadow:0 1px 2px rgba(0,0,0,.15)}.deck-card-body{padding:16px}.deck-card-title{font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color var(--transition-fast)}.deck-card:hover .deck-card-title{color:var(--accent)}.deck-card-meta{display:flex;align-items:center;gap:8px}.deck-card-date{font-size:13px;color:var(--text-secondary)}.deck-card-badge{font-size:11px;font-weight:500;padding:2px 8px;border-radius:100px;background:var(--bg-hover);color:var(--text-muted)}.deck-card-badge.public{background:#4a90d926;color:#4a90d9}.deck-card-menu-wrapper{position:absolute;top:10px;right:10px;opacity:0;transition:opacity var(--transition-fast)}.deck-card:hover .deck-card-menu-wrapper{opacity:1}.deck-card-menu-btn{padding:6px;border-radius:var(--radius-sm);background:var(--bg-card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;box-shadow:var(--shadow-sm);transition:color var(--transition-fast);display:flex;align-items:center;justify-content:center}.deck-card-menu-btn:hover{color:var(--text-primary)}.deck-card-dropdown{position:absolute;right:0;margin-top:4px;width:192px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:4px 0;z-index:10;overflow:hidden}.deck-card-dropdown-divider{border-top:1px solid var(--border-color);margin:4px 0}.menu-item{width:100%;display:flex;align-items:center;gap:10px;padding:8px 12px;border:none;background:none;font-size:14px;cursor:pointer;color:var(--text-primary);transition:background var(--transition-fast)}.menu-item:hover{background:var(--bg-hover)}.menu-item .menu-item-icon{color:var(--text-muted)}.menu-item.danger,.menu-item.danger .menu-item-icon{color:var(--danger)}.menu-item.danger:hover{background:#ff3b3014}.deck-card-skeleton{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color);overflow:hidden}.deck-card-skeleton .skeleton-thumb{aspect-ratio:16/9}.deck-card-skeleton .skeleton-body{padding:16px;display:flex;flex-direction:column;gap:10px}.deck-card-skeleton .skeleton-title{height:16px;width:75%;border-radius:4px}.deck-card-skeleton .skeleton-meta-row{display:flex;gap:8px}.deck-card-skeleton .skeleton-date{height:12px;width:64px;border-radius:4px}.deck-card-skeleton .skeleton-badge{height:12px;width:48px;border-radius:100px}.share-overlay{position:fixed;inset:0;background:#00000080;z-index:50;display:flex;align-items:center;justify-content:center;padding:16px}.share-modal{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);width:100%;max-width:512px;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.share-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.share-modal-header h2{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.share-modal-close{padding:4px;border-radius:var(--radius-sm);border:none;background:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.share-modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.share-modal-close svg{width:20px;height:20px}.share-tabs{display:flex;border-bottom:1px solid var(--border-color)}.share-tab{flex:1;padding:10px 0;font-size:14px;font-weight:500;border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;color:var(--text-secondary);transition:color var(--transition-fast)}.share-tab:hover{color:var(--text-primary)}.share-tab.active{border-bottom-color:var(--accent);color:var(--accent)}.share-modal-body{flex:1;overflow-y:auto;padding:20px}.share-search-row{display:flex;gap:8px}.share-search-input{flex:1;padding:8px 12px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;color:var(--text-primary);outline:none;transition:border-color var(--transition-fast)}.share-search-input::placeholder{color:var(--text-muted)}.share-search-input:focus{border-color:var(--accent)}.share-search-btn{padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.share-search-btn:hover{background:var(--accent-hover)}.share-search-btn:disabled{opacity:.5;cursor:not-allowed}.share-section{margin-top:16px}.share-section-title{font-size:12px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.share-list{border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.share-list-item{display:flex;align-items:center;justify-content:space-between;padding:12px;transition:background var(--transition-fast)}.share-list-item:hover{background:var(--bg-hover)}.share-list-item+.share-list-item{border-top:1px solid var(--border-color)}.share-user-info{display:flex;align-items:center;gap:10px}.share-user-avatar{width:28px;height:28px;border-radius:50%;box-shadow:0 0 0 1px var(--border-color)}.share-user-avatar-placeholder{width:28px;height:28px;border-radius:50%;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}.share-user-name{font-size:14px;font-weight:500;color:var(--text-primary)}.share-user-email{font-size:12px;color:var(--text-muted)}.share-add-btn{padding:6px 12px;font-size:12px;font-weight:500;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.share-add-btn:hover{background:var(--accent-hover)}.share-item-actions{display:flex;align-items:center;gap:8px}.share-permission-badge{font-size:12px;color:var(--text-muted);background:var(--bg-hover);padding:2px 8px;border-radius:100px}.share-remove-btn{font-size:12px;font-weight:500;color:var(--danger);background:none;border:none;cursor:pointer;transition:color var(--transition-fast)}.share-remove-btn:hover{color:#c0392b}.share-link-form{display:flex;flex-direction:column;gap:12px}.share-link-input{width:100%;padding:8px 12px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;color:var(--text-primary);outline:none;transition:border-color var(--transition-fast)}.share-link-input::placeholder{color:var(--text-muted)}.share-link-input:focus{border-color:var(--accent)}.share-link-options{display:flex;align-items:center;gap:8px}.share-link-options label{font-size:14px;color:var(--text-secondary)}.share-link-options select{padding:6px 10px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;color:var(--text-primary)}.share-create-btn{margin-left:auto;padding:6px 16px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.share-create-btn:hover{background:var(--accent-hover)}.share-create-btn:disabled{opacity:.5;cursor:not-allowed}.share-link-item{display:flex;align-items:center;justify-content:space-between;padding:12px;gap:8px;transition:background var(--transition-fast)}.share-link-item:hover{background:var(--bg-hover)}.share-link-item+.share-link-item{border-top:1px solid var(--border-color)}.share-link-url{font-size:14px;color:var(--text-primary);font-family:var(--font-mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-link-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.share-link-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.share-copy-btn{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;padding:6px 10px;background:var(--bg-hover);color:var(--text-primary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.share-copy-btn:hover{background:var(--border-color)}.share-copy-btn svg{width:14px;height:14px}.share-revoke-btn{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;padding:6px 10px;background:#ff3b301a;color:var(--danger);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.share-revoke-btn:hover{background:#ff3b3033}.status-active{color:var(--success)}.status-inactive{color:var(--text-muted)}.dashboard-header{margin-bottom:24px}.dashboard-header h1{font-size:24px;font-weight:600;color:var(--text-primary);letter-spacing:-.02em;margin:0}.dashboard-header .search-info{font-size:14px;color:var(--text-secondary);margin-top:4px}.dashboard-error{text-align:center;padding:80px 20px}.dashboard-error-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:#ff3b301a;margin-bottom:12px}.dashboard-error-icon svg{width:24px;height:24px;color:var(--danger)}.dashboard-error p{color:var(--text-secondary);font-weight:500}.dashboard-error .retry-btn{margin-top:12px;background:none;border:none;font-size:14px;color:var(--accent);cursor:pointer;transition:color var(--transition-fast)}.dashboard-error .retry-btn:hover{color:var(--accent-hover)}.empty-state{text-align:center;padding:96px 20px}.empty-state-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:var(--radius-lg);background:var(--bg-hover);margin-bottom:16px}.empty-state-icon svg{width:32px;height:32px;color:var(--text-muted)}.empty-state-title{font-size:18px;font-weight:500;color:var(--text-secondary);margin:0 0 6px}.empty-state-desc{font-size:14px;color:var(--text-muted);margin:0 0 20px}.empty-state .btn-primary{display:inline-flex;margin-top:4px}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:32px}.pagination button{padding:8px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.pagination button:hover:not(:disabled){background:var(--bg-hover)}.pagination button:disabled{opacity:.3;cursor:not-allowed}.pagination .page-info{font-size:14px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.deck-view-loading{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-primary)}.deck-view-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:var(--bg-primary);gap:16px}.deck-view-error p{color:var(--text-secondary)}.deck-view-error a{color:var(--accent)}.deck-view-error a:hover{text-decoration:underline}.deck-view-back{position:fixed;top:16px;left:16px;z-index:50;display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-sm);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);color:var(--text-secondary);font-size:14px;transition:color var(--transition-fast)}.deck-view-back:hover{color:var(--text-primary)}.deck-view-back svg{width:16px;height:16px}.shared-link-page{min-height:100vh;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;padding:16px}.shared-link-content{width:100%;max-width:380px}.shared-link-header{text-align:center;margin-bottom:32px}.shared-link-header .emoji{font-size:40px;margin-bottom:12px}.shared-link-header h1{font-size:24px;font-weight:700;color:var(--text-primary);margin:0}.shared-link-header p{font-size:14px;color:var(--text-secondary);margin:4px 0 0}.shared-link-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:24px}.shared-link-form{display:flex;flex-direction:column;gap:16px}.shared-link-form input{width:100%;padding:12px 16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;outline:none;transition:border-color var(--transition-fast)}.shared-link-form input::placeholder{color:var(--text-muted)}.shared-link-form input:focus{border-color:var(--accent)}.shared-link-form .submit-btn{width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.shared-link-form .submit-btn:hover{background:var(--accent-hover)}.shared-link-form .submit-btn:disabled{opacity:.5;cursor:not-allowed}.shared-link-form .error-msg{color:var(--danger);font-size:14px;text-align:center}.admin-page{max-width:960px}.admin-page h1{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:24px;letter-spacing:-.02em}.admin-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid var(--border-color)}.admin-tab{padding:0 12px 10px;font-size:14px;font-weight:500;border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;color:var(--text-secondary);text-transform:capitalize;transition:color var(--transition-fast)}.admin-tab:hover{color:var(--text-primary)}.admin-tab.active{border-bottom-color:var(--accent);color:var(--accent)}.admin-table-container{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color);overflow-x:auto}.admin-table{width:100%;font-size:14px;border-collapse:collapse}.admin-table thead tr{border-bottom:1px solid var(--border-color)}.admin-table th{padding:14px 20px;font-size:13px;font-weight:500;color:var(--text-secondary);text-align:left;text-transform:uppercase;letter-spacing:.05em}.admin-table tbody tr{border-bottom:1px solid var(--border-color);transition:background var(--transition-fast)}.admin-table tbody tr:last-child{border-bottom:none}.admin-table tbody tr:hover{background:var(--bg-hover)}.admin-table tbody tr.alt{background:#00000005}.dark .admin-table tbody tr.alt{background:#ffffff05}.admin-table td{padding:14px 20px}.admin-user-cell{display:flex;align-items:center;gap:12px}.admin-avatar{width:32px;height:32px;border-radius:50%;box-shadow:0 0 0 1px var(--border-color)}.admin-avatar-placeholder{width:32px;height:32px;border-radius:50%;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;box-shadow:0 0 0 1px #f5a62333}.admin-user-name{font-weight:500;color:var(--text-primary)}.admin-user-email{font-size:12px;color:var(--text-muted)}.admin-badge{display:inline-flex;align-items:center;font-size:12px;font-weight:500;padding:4px 10px;border-radius:100px;background:var(--bg-hover);color:var(--text-secondary)}.admin-badge.admin-role{background:var(--accent-light);color:var(--accent)}.admin-badge.public-vis{background:#4a90d926;color:#4a90d9}.admin-status{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500}.admin-status.active{color:var(--success)}.admin-status.inactive{color:var(--danger)}.admin-status-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.admin-actions{display:flex;gap:8px}.admin-action-btn{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;padding:6px 10px;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:background var(--transition-fast);background:var(--bg-hover);color:var(--text-primary)}.admin-action-btn:hover{background:var(--border-color)}.admin-action-btn.danger{background:#ff3b301a;color:var(--danger)}.admin-action-btn.danger:hover{background:#ff3b3033}.admin-action-btn.success{background:#34c7591a;color:var(--success)}.admin-action-btn.success:hover{background:#34c75933}.admin-action-btn svg{width:14px;height:14px}.admin-skeleton{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color);padding:32px}.admin-skeleton-rows{display:flex;flex-direction:column;gap:16px}.admin-skeleton-row{display:flex;align-items:center;gap:12px}.admin-skeleton-row .skeleton-circle{width:32px;height:32px;border-radius:50%}.admin-skeleton-row .skeleton-lines{flex:1;display:flex;flex-direction:column;gap:8px}.admin-skeleton-row .skeleton-line-short{height:12px;width:128px;border-radius:4px}.admin-skeleton-row .skeleton-line-long{height:8px;width:192px;border-radius:4px}.tabular-nums{font-variant-numeric:tabular-nums;color:var(--text-secondary)}:root{--bg-primary: #f5f5f7;--bg-card: #ffffff;--bg-sidebar: #ffffff;--bg-hover: #f0f0f2;--bg-active: rgba(245, 166, 35, .08);--border-color: #e5e5e7;--border-hover: #d1d1d3;--text-primary: #1d1d1f;--text-secondary: #6e6e73;--text-muted: #aeaeb2;--accent: #F5A623;--accent-hover: #E09510;--accent-light: rgba(245, 166, 35, .12);--danger: #ff3b30;--success: #34c759;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.12);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", monospace;--sidebar-width: 240px;--topbar-height: 56px;--transition-fast: .15s ease;--transition-normal: .2s ease}.dark{--bg-primary: #0f0f17;--bg-card: #1a1a2e;--bg-sidebar: #12121e;--bg-hover: #222236;--bg-active: rgba(245, 166, 35, .12);--border-color: #2a2a3e;--border-hover: #3a3a50;--text-primary: #f0f0f0;--text-secondary: #8888a0;--text-muted: #55556a;--shadow-sm: 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 4px 12px rgba(0,0,0,.3);--shadow-lg: 0 8px 24px rgba(0,0,0,.4)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);overflow:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none;color:inherit}button,input,select,textarea{font-family:inherit}@keyframes shimmer{0%{opacity:.5}50%{opacity:1}to{opacity:.5}}.skeleton{background:var(--bg-hover);animation:shimmer 1.5s infinite;border-radius:6px}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:pageFadeIn .3s ease-out both}@keyframes modalBackdropIn{0%{opacity:0}to{opacity:1}}@keyframes modalContentIn{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-backdrop{animation:modalBackdropIn .2s ease-out both}.modal-content{animation:modalContentIn .25s ease-out both}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:32px;height:32px;border:2px solid var(--accent);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.anim-fadeIn{animation-name:fadeIn}.anim-fadeInLeft{animation-name:fadeInLeft}.anim-fadeInRight{animation-name:fadeInRight}.anim-fadeInUp{animation-name:fadeInUp}.animate-enter{animation-fill-mode:both;animation-timing-function:ease-out}#root.mode-scroll{overflow-y:auto;scroll-behavior:smooth;background:#000}#root.mode-snap{overflow-y:auto;scroll-snap-type:y mandatory;scroll-behavior:smooth;background:#000}#root.mode-present{overflow:hidden}.mode-toolbar{position:fixed;top:16px;right:16px;z-index:1000;display:flex;gap:4px;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;padding:4px;opacity:0;transition:opacity .3s}.mode-toolbar:hover,.mode-toolbar:focus-within{opacity:1}.mode-toolbar button{background:transparent;border:1px solid rgba(255,255,255,.15);color:#aaa;padding:6px 14px;border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s}.mode-toolbar button:hover{background:#ffffff14;color:#fff}.mode-toolbar button.active{background:var(--accent);color:#111;border-color:var(--accent);font-weight:600}.back-link{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid rgba(255,255,255,.15);color:#aaa;border-radius:6px;font-size:16px;text-decoration:none;transition:all .2s;margin-right:2px}.back-link:hover{background:#ffffff14;color:#fff}.slides-container{width:100%;height:100%}.slide{position:relative;width:min(100vw,calc(100vh * 16 / 9));height:min(100vh,56.25vw);margin:0 auto;overflow:hidden;scroll-snap-align:start;flex-shrink:0}.mode-snap .slide{margin-top:calc((100vh - min(100vh,100vw * 9 / 16))/2);margin-bottom:calc((100vh - min(100vh,100vw * 9 / 16))/2);scroll-snap-align:center}.mode-snap .slide:first-child{margin-top:calc((100vh - min(100vh,100vw * 9 / 16))/2)}.mode-snap .slide:last-child{margin-bottom:calc((100vh - min(100vh,100vw * 9 / 16))/2)}.mode-present .slide{width:min(100vw,calc(100vh * 16 / 9));height:100vh;display:flex;align-items:center;justify-content:center}.slide-grid{position:absolute;inset:0;display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:repeat(8,1fr);padding:3% 4%;gap:0;z-index:2}.slide-title{position:absolute;top:3%;left:4%;font-size:clamp(18px,2.2vw,32px);font-weight:700;color:var(--accent);z-index:10}.grid-component{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center;padding:.4em}.slide-bg{position:absolute;inset:0;z-index:0}.slide-bg+.slide-bg{z-index:1}.slide-bg img{width:100%;height:100%;object-fit:cover}.nav-arrow{position:fixed;top:50%;transform:translateY(-50%);z-index:1000;background:#0000004d;color:#ffffffb3;border:none;font-size:48px;width:56px;height:80px;cursor:pointer;border-radius:8px;opacity:0;transition:opacity .3s,background .2s;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.mode-present:hover .nav-arrow{opacity:1}.nav-arrow:hover{background:#0009;color:#fff}.nav-arrow-left{left:16px}.nav-arrow-right{right:16px}.slide-indicator{position:fixed;bottom:16px;left:50%;transform:translate(-50%);z-index:1000;display:flex;gap:6px;opacity:0;transition:opacity .3s}.mode-present:hover .slide-indicator{opacity:1}.slide-indicator-dot{width:8px;height:8px;border-radius:50%;background:#ffffff4d;transition:all .3s}.slide-indicator-dot.active{background:var(--accent);transform:scale(1.3)}.text-block{display:flex;flex-direction:column;justify-content:center;gap:.2em;padding:.5em}.text-line-h1{font-size:clamp(24px,3.5vw,56px);font-weight:800;line-height:1.15}.text-line-h2{font-size:clamp(18px,2.2vw,36px);font-weight:700;line-height:1.25}.text-line-h3{font-size:clamp(14px,1.6vw,26px);font-weight:600;line-height:1.3;margin-top:.4em}.text-line-body{font-size:clamp(12px,1.2vw,20px);font-weight:400;line-height:1.5}.text-line-caption{font-size:clamp(10px,1vw,16px);font-weight:400;line-height:1.4}.image-block{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.image-block img{max-width:100%;max-height:100%}.image-block img .slide img{-webkit-user-drag:none;user-drag:none}.table-block{width:100%;height:100%;overflow:auto;display:flex;flex-direction:column;justify-content:center}.table-block table{width:100%;border-collapse:collapse;font-size:clamp(10px,1.1vw,16px)}.table-block th{padding:.5em .8em;font-weight:600;border-bottom:2px solid var(--surface-border);white-space:nowrap}.table-block td{padding:.5em .8em;color:var(--text-primary);border-bottom:1px solid var(--surface-bg)}.table-block tbody tr.alt-row{background:var(--surface-bg)}.table-block tbody tr:hover{background:var(--surface-hover)}.chart-block{width:100%;height:100%}.gantt-block{width:100%;height:100%;display:flex;flex-direction:column;gap:0;font-size:clamp(11px,1.2vw,16px)}.gantt-row{display:grid;position:relative;min-height:5em;align-items:center}.gantt-header{border-bottom:2px solid var(--surface-border)}.gantt-col-header{text-align:center;font-weight:600;color:var(--text-secondary);padding:.4em}.gantt-label{font-weight:600;padding:.4em .8em;color:var(--text-primary);white-space:nowrap}.gantt-cell{border-left:1px solid var(--surface-bg);height:100%}.gantt-bar{border-radius:6px;display:flex;align-items:center;justify-content:center;padding:.3em .8em;margin:.3em .2em;z-index:1}.gantt-bar-text{color:#fff;font-size:1em;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.3);text-align:center;line-height:1.5;white-space:pre-line}.ad-demo-block{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4em;padding:.5em;box-sizing:border-box;overflow:hidden;min-height:0}.ad-demo-phone{position:relative;flex:1 1 0;min-height:0;max-width:100%;margin:0 auto;aspect-ratio:478 / 914}.ad-demo-content,.ad-demo-iframe-wrapper{position:absolute;top:3.5%;left:10.5%;width:79.5%;height:89.3%;border:none;border-radius:1.2em;z-index:1;background:#000}.ad-demo-content{object-fit:cover}.ad-demo-frame{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2;object-fit:contain}.ad-demo-no-frame{position:relative;width:100%;flex:1 1 auto;min-height:0;max-height:calc(100% - 6em)}.ad-demo-no-frame .ad-demo-content,.ad-demo-no-frame .ad-demo-iframe-wrapper{position:relative;width:100%;height:100%;top:auto;left:auto;border-radius:.5em}.ad-demo-toggle{background:var(--surface-bg);color:var(--text-primary);border:1px solid var(--surface-border);border-radius:999px;padding:.15em .8em;font-size:clamp(9px,.9vw,14px);cursor:pointer;white-space:nowrap;flex-shrink:0}.ad-demo-qr-label{color:var(--text-secondary);font-size:clamp(9px,.9vw,14px);flex-shrink:0}@media(max-width:768px){.text-line-h1{font-size:clamp(16px,3.5vw,56px)}.text-line-h2{font-size:clamp(12px,2.2vw,36px)}.text-line-h3{font-size:clamp(10px,1.6vw,26px)}.text-line-body{font-size:clamp(8px,1.2vw,20px)}.text-line-caption{font-size:clamp(7px,1vw,16px)}.slide-grid{padding:2% 3%}}.ad-demo-iframe-wrapper{overflow:hidden;touch-action:none}.ad-demo-iframe-scaled{width:390px;height:844px;border:none;transform-origin:top left}.ad-demo-qr-group{display:flex;flex-direction:column;align-items:center;gap:.3em;flex-shrink:0}.ad-demo-layout-right{flex-direction:column;align-items:center;position:relative}.ad-demo-layout-right .ad-demo-left{display:flex;flex-direction:column;align-items:center;width:100%;flex:1 1 0;min-height:0;gap:.4em}.ad-demo-layout-right .ad-demo-right{position:absolute;right:0;bottom:0;display:flex;flex-direction:column;align-items:center}
