*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0f1117;--surface: #1a1d27;--surface-elevated: #202432;--surface-hover: #22263a;--border: #2a2e3f;--text: #e4e6ec;--text-muted: #8b8fa4;--accent: #6c8cff;--accent-hover: #8aa4ff;--danger: #f55;--radius: 8px;--sidebar-w: 240px}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}.gate{display:flex;align-items:center;justify-content:center;height:100%;padding:24px}.gate-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:40px 32px;text-align:center;max-width:380px;width:100%}.gate-card h2{margin-bottom:16px;font-size:20px;font-weight:600}.error-text{color:var(--text-muted)}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;margin:0 auto 16px;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.layout{display:flex;height:100%}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}.sidebar-brand{padding:20px 16px 12px;border-bottom:1px solid var(--border)}.sidebar-brand h1{font-size:18px;font-weight:700;letter-spacing:.5px}.sidebar-subtitle{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.sidebar-nav{flex:1;padding:8px;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:none;border-radius:var(--radius);background:transparent;color:var(--text-muted);font-size:14px;cursor:pointer;text-align:left;width:100%;transition:background .15s,color .15s}.nav-item:hover{background:var(--surface-hover);color:var(--text)}.nav-item.active{background:var(--surface-hover);color:var(--accent)}.nav-icon{font-size:16px;width:22px;text-align:center}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border)}.admin-info{display:flex;flex-direction:column;margin-bottom:8px}.admin-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-role{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.logout-btn{width:100%;padding:6px 0;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-muted);font-size:13px;cursor:pointer;transition:color .15s,border-color .15s}.logout-btn:hover{color:var(--danger);border-color:var(--danger)}.main-content{flex:1;display:flex;flex-direction:column;overflow-y:auto}.topbar{padding:16px 24px;border-bottom:1px solid var(--border)}.topbar h2{font-size:18px;font-weight:600}.mobile-menu-btn{display:none}.page-content{flex:1;padding:24px}.placeholder-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.placeholder-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.placeholder-card h3{font-size:13px;color:var(--text-muted);font-weight:500;margin-bottom:8px}.placeholder-value{font-size:28px;font-weight:700;margin-bottom:4px}.placeholder-hint{font-size:12px;color:var(--text-muted)}.dashboard-meta{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.status-pill{font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.5px}.status-live{background:#4caf5026;color:#6fcf97}.status-reconnecting{background:#ffc10726;color:#f2c94c}.status-polling{background:#6c8cff26;color:var(--accent)}.dashboard-updated{font-size:12px;color:var(--text-muted)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:28px}.metric-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.metric-card h3{font-size:12px;color:var(--text-muted);font-weight:500;margin-bottom:8px}.metric-value{font-size:26px;font-weight:700;line-height:1.2}.metric-hint{display:block;font-size:11px;color:var(--text-muted);margin-top:6px}.dashboard-section{margin-bottom:24px}.dashboard-section h3{font-size:14px;font-weight:600;margin-bottom:12px}.dashboard-columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.table-wrap .data-table{min-width:760px}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th,.data-table td{padding:8px 10px;text-align:left;border-bottom:1px solid var(--border)}.data-table th{color:var(--text-muted);font-weight:500}.muted{color:var(--text-muted);font-size:13px}.filter-form{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:20px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.filter-form label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-muted)}.filter-form input,.filter-form select{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:13px;min-width:120px}.btn-primary{padding:8px 16px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:13px;font-weight:600;cursor:pointer}.btn-primary:hover{background:var(--accent-hover)}.list-page{min-height:200px}.list-loading,.list-empty,.list-error{padding:40px 20px;text-align:center;color:var(--text-muted)}.list-error{color:var(--danger)}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.pagination button{padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);cursor:pointer}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination span{font-size:13px;color:var(--text-muted)}.row-clickable{cursor:pointer}.row-clickable:hover{background:var(--surface-hover)}.row-selected{background:#6c8cff1f}.text-positive{color:#6fcf97}.text-negative{color:#eb5757}.status-badge{font-size:11px;padding:2px 8px;border-radius:4px;text-transform:lowercase}.status-confirmed{background:#4caf5026;color:#6fcf97}.status-pending{background:#ffc10726;color:#f2c94c}.status-failed{background:#eb575726;color:#eb5757}.data-table-compact{font-size:12px}.split-page{display:flex;gap:20px;align-items:flex-start}.split-main{flex:1;min-width:0}.detail-panel{width:320px;flex-shrink:0;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);position:sticky;top:0;max-height:calc(100vh - 120px);overflow-y:auto}.detail-panel h3{font-size:16px;margin-bottom:4px}.detail-panel h4{font-size:13px;margin:16px 0 8px}.detail-close{float:right;border:none;background:transparent;color:var(--text-muted);font-size:20px;cursor:pointer;line-height:1}.detail-stats{display:grid;grid-template-columns:1fr auto;gap:6px 12px;font-size:13px;margin:12px 0}.detail-stats dt{color:var(--text-muted)}.detail-stats dd{text-align:right;font-weight:600}@media (max-width: 900px){.split-page{flex-direction:column}.detail-panel{width:100%;position:static;max-height:none}}.page-toolbar{margin-bottom:12px}.btn-secondary{margin-top:8px;padding:8px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-elevated);color:var(--text);cursor:pointer;font-size:13px}.btn-secondary:hover{border-color:var(--accent)}.detail-form label{display:block;font-size:12px;color:var(--text-muted);margin-bottom:10px}.detail-form input,.detail-form textarea,.detail-form select{display:block;width:100%;margin-top:4px;padding:8px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13px}.checkbox-label{display:flex!important;align-items:center;gap:8px;flex-direction:row}.checkbox-label input{width:auto;margin:0}.detail-meta{font-size:12px;color:var(--text-muted);margin-bottom:12px}.tracking-link-block{margin-bottom:16px}.tracking-link-block label{font-size:12px;color:var(--text-muted)}.tracking-link-input{width:100%;margin-top:4px;padding:8px;font-size:11px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg);color:var(--text)}.copy-hint{margin-left:8px;font-size:12px;color:var(--accent)}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.stat-box{padding:8px;border-radius:var(--radius);background:var(--bg);border:1px solid var(--border);font-size:11px}.stat-box span{display:block;color:var(--text-muted);margin-bottom:4px}.stat-box strong{font-size:16px}.gifts-page{display:flex;flex-direction:column;gap:12px}.gifts-tools-grid{display:grid;grid-template-columns:repeat(2,minmax(300px,1fr));gap:12px}.gift-card{display:flex;flex-direction:column;gap:8px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.gift-card h3{font-size:14px;font-weight:600}.gift-card input,.gift-card textarea{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:13px}.gift-card textarea{resize:vertical;min-height:90px}.gift-notice{padding:8px 10px;border-radius:var(--radius);font-size:13px}.gift-notice-success{border:1px solid rgba(76,175,80,.35);background:#4caf501f;color:#6fcf97}.gift-notice-error{border:1px solid rgba(235,87,87,.35);background:#eb57571f;color:#eb5757}.gift-bulk-result{padding:10px 12px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);font-size:13px}.gift-bulk-result ul{margin-top:8px;margin-left:18px}.gift-bulk-result li{color:#eb5757;font-size:12px}.gifts-table th,.gifts-table td{vertical-align:top}.gift-preview-image{width:56px;height:56px;border-radius:8px;border:1px solid var(--border);object-fit:cover;display:block}.gift-preview-placeholder{width:56px;height:56px;border-radius:8px;border:1px dashed var(--border);color:var(--text-muted);font-size:11px;display:flex;align-items:center;justify-content:center}.gift-cell-main{font-weight:600;font-size:12px}.gift-cell-sub{margin-top:2px;color:var(--text-muted);font-size:11px;word-break:break-word}.gift-status-badge{font-size:11px;font-weight:600;text-transform:lowercase;border-radius:999px;padding:2px 8px;display:inline-block}.gift-status-ready{background:#4caf5029;color:#6fcf97}.gift-status-pending{background:#ffc10729;color:#f2c94c}.gift-status-failed{background:#eb575729;color:#eb5757}.gift-status-disabled{background:#8b8fa433;color:var(--text-muted)}.gift-status-finished{background:#6c8cff29;color:#8aa4ff}.gift-status-cancelled{background:#eb575729;color:#eb5757}.gift-error-text{margin-top:4px;color:#eb5757;font-size:11px;line-height:1.3;max-width:260px;word-break:break-word}.gift-active-badge{font-size:11px;font-weight:600;border-radius:999px;padding:2px 8px;text-transform:lowercase;display:inline-block}.gift-active-yes{background:#4caf5029;color:#6fcf97}.gift-active-no{background:#8b8fa433;color:var(--text-muted)}.gift-actions{display:flex;flex-direction:column;align-items:flex-start;gap:6px;min-width:132px}.gift-actions .btn-secondary{margin-top:0;padding:6px 10px;font-size:12px}.gwars-matches-page{display:flex;flex-direction:column;gap:12px}.gwars-create-card{padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);display:flex;flex-direction:column;gap:10px}.gwars-create-card h3{font-size:14px;font-weight:600}.gwars-create-grid{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:10px}.gwars-create-grid label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-muted)}.gwars-create-grid input,.gwars-create-grid select{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:13px}.gwars-selected-gift{display:flex;flex-direction:column;gap:2px;font-size:12px}.gwars-selected-gift span{color:var(--text-muted)}.gwars-selected-gift strong{font-weight:600}.placeholder-page{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60%;text-align:center}.placeholder-page p{font-size:18px;font-weight:600;margin-bottom:8px}.placeholder-page span{color:var(--text-muted);font-size:14px}@media (max-width: 760px){:root{--sidebar-w: 280px}.layout{display:block;height:100%}.sidebar{position:fixed;inset:0 auto 0 0;z-index:60;width:min(82vw,300px);min-width:0;transform:translate(-105%);transition:transform .2s ease;box-shadow:16px 0 40px #00000059}.sidebar.sidebar-open{transform:translate(0)}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;border:0;background:#00000080}.mobile-menu-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:20px;cursor:pointer}.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:12px;padding:calc(12px + env(safe-area-inset-top,0px)) 14px 12px;background:var(--bg)}.topbar h2{font-size:16px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.main-content{min-height:100%;overflow-y:visible}.page-content{padding:14px}.table-wrap{margin:0 -2px}.table-wrap .data-table{min-width:820px}.data-table th,.data-table td{padding:8px;font-size:12px}.filter-form{display:grid;grid-template-columns:1fr;gap:10px;padding:12px}.filter-form label,.filter-form input,.filter-form select{width:100%;min-width:0}.users-filter-form,.users-filter-grid{display:grid;grid-template-columns:1fr;gap:10px;width:100%}.users-filter-form label,.users-filter-grid label,.users-filter-form input,.users-filter-grid input,.users-filter-form select,.users-filter-grid select{width:100%;min-width:0}.gift-card,.gwars-create-card{padding:12px}.gifts-tools-grid,.gwars-create-grid{grid-template-columns:1fr}.gift-card input,.gift-card textarea,.gwars-create-grid input,.gwars-create-grid select{min-height:42px;font-size:16px}.filter-form input,.filter-form select,.detail-form input,.detail-form textarea,.detail-form select{font-size:16px}.btn-primary,.btn-secondary{min-height:42px}.pagination{gap:10px;flex-wrap:wrap}.pagination button{flex:1;min-width:120px;min-height:42px}.pagination span{order:-1;width:100%;text-align:center}.detail-panel{width:100%;position:static;padding:12px;max-height:none}.users-split-page{display:grid;grid-template-columns:1fr;gap:12px}.users-detail-panel{width:100%;min-width:0;max-width:100%;max-height:none;position:static;overflow:visible}.user-detail-form,.user-detail-grid{display:grid;grid-template-columns:1fr;gap:10px;width:100%}.user-detail-form label,.user-detail-grid label{display:grid;gap:6px;width:100%;min-width:0}.user-detail-form input,.user-detail-form select,.user-detail-form textarea,.user-detail-grid input,.user-detail-grid select,.user-detail-grid textarea{width:100%;min-width:0;max-width:100%;box-sizing:border-box;min-height:42px;font-size:16px}.user-actions-row{display:grid;grid-template-columns:1fr;gap:8px;width:100%}.user-actions-row button{width:100%;min-height:42px}.sidebar-brand h1,.sidebar-subtitle,.nav-item span:not(.nav-icon),.admin-info,.logout-btn{display:initial}.sidebar-brand{padding:20px 16px 12px;text-align:left}.nav-item{justify-content:flex-start;padding:10px 12px}.nav-icon{font-size:16px}.sidebar-footer{display:block}.gift-preview-image,.gift-preview-placeholder{width:48px;height:48px}.gift-actions{min-width:120px}}
