@tailwind base;@tailwind components;@tailwind utilities;*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:#0f172a;color:#e2e8f0}#root{min-height:100vh}:root{--bg: #0b0f19;--surface: #111827;--card: #1f2937;--border: #374151;--text: #f9fafb;--text-dim: #9ca3af;--primary: #6366f1}.app-shell{min-height:100vh;background:linear-gradient(180deg,#0a1020,#0b1223)}.app-body{display:flex}.app-main{flex:1;margin-left:260px;margin-top:72px;padding:24px;min-height:calc(100vh - 72px)}.topbar{position:fixed;top:0;left:0;right:0;height:72px;background:#111827eb;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:60;display:flex;align-items:center;justify-content:space-between;padding:0 24px 0 20px}.topbar-left{display:flex;align-items:center;gap:18px}.mobile-menu-btn{display:none;width:36px;height:36px;border:1px solid var(--border);border-radius:9px;background:#0f172a;color:var(--text);font-size:17px;line-height:1}.brand{color:var(--text);font-size:30px;line-height:1;font-weight:700;letter-spacing:-.02em}.topbar-search-wrap{width:min(420px,36vw)}.topbar-search{width:100%;height:38px;border-radius:10px;border:1px solid var(--border);background:#0f172a;color:var(--text);padding:0 12px;outline:none}.topbar-search:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f13d}.topbar-right{display:flex;align-items:center;gap:12px}.mobile-menu{position:absolute;top:72px;left:12px;right:12px;border:1px solid var(--border);border-radius:12px;background:#0f172a;box-shadow:0 20px 40px #02061780;padding:8px;z-index:75;display:none;gap:6px;flex-wrap:wrap}.mobile-menu-link{border:1px solid #253042;border-radius:8px;padding:8px 10px;color:#dbeafe;text-decoration:none;font-size:13px}.icon-btn{width:36px;height:36px;border:1px solid var(--border);border-radius:9px;background:#0f172a;color:var(--text)}.user-chip{display:flex;align-items:center;gap:10px;border:1px solid var(--border);border-radius:12px;background:#0f172a;padding:6px 10px}.avatar-dot{width:28px;height:28px;border-radius:999px;background:linear-gradient(135deg,#6366f1,#22c55e)}.user-name{font-size:13px;line-height:1.2;color:var(--text);font-weight:600}.user-meta{font-size:11px;color:var(--text-dim)}.logout-btn{height:36px;border:1px solid var(--border);border-radius:9px;background:#111827;color:var(--text);padding:0 12px;font-weight:600}.logout-btn:hover{border-color:#4b5563}.sidebar{position:fixed;left:0;top:72px;bottom:0;width:260px;border-right:1px solid var(--border);background:linear-gradient(180deg,#111827,#0f172a);overflow-y:auto}.sidebar-nav{display:grid;gap:6px;padding:16px}.sidebar-link{display:block;border-radius:10px;padding:10px 12px;text-decoration:none;transition:all .18s ease;border:1px solid transparent;font-size:14px}.sidebar-link-idle{color:var(--text-dim)}.sidebar-link-idle:hover{color:var(--text);background:#111827;border-color:#2f3b4d}.sidebar-link-active{color:#fff;background:#6366f12e;border-color:#6366f18c}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;background:radial-gradient(1200px 600px at 15% -10%,rgba(59,130,246,.18),transparent 60%),radial-gradient(900px 450px at 90% 110%,rgba(16,185,129,.16),transparent 60%),#0b1326}.login-card{width:100%;max-width:460px;padding:36px 30px;border:1px solid rgba(148,163,184,.25);border-radius:18px;background:#0f172adb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 20px 50px #02061773;position:relative;z-index:2}.login-kicker{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#94a3b8;margin-bottom:10px}.login-title{font-size:34px;line-height:1.1;font-weight:700;color:#f8fafc;margin-bottom:8px}.login-subtitle{color:#94a3b8;margin-bottom:22px}.login-form{display:grid;gap:12px}.login-label{font-size:13px;color:#cbd5e1}.login-input{width:100%;border:1px solid #334155;background:#0f172a;color:#f8fafc;border-radius:10px;padding:11px 12px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.login-input::-moz-placeholder{color:#64748b}.login-input::placeholder{color:#64748b}.login-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f640}.login-button{margin-top:8px;border:0;border-radius:10px;padding:12px 14px;font-weight:600;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;cursor:pointer;transition:transform .15s ease,filter .2s ease}.login-button:hover{filter:brightness(1.08)}.login-button:active{transform:translateY(1px)}.login-button:disabled{opacity:.6;cursor:default}.login-glow{width:380px;height:380px;position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(59,130,246,.22) 0%,rgba(59,130,246,.02) 62%,transparent 70%);filter:blur(8px);top:8%;right:8%;z-index:1;pointer-events:none}.page-wrap{width:min(1200px,100%);margin:0 auto}.page-head{margin-bottom:20px}.page-title{font-size:42px;line-height:1.05;letter-spacing:-.02em;color:var(--text);font-weight:700}.page-subtitle{margin-top:8px;color:var(--text-dim)}.page-loading{color:var(--text-dim);text-align:center;padding:32px}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}.metric-card{border:1px solid var(--border);background:var(--surface);border-radius:14px;padding:14px}.dashboard-kpis .metric-card{min-height:122px;display:flex;flex-direction:column;justify-content:space-between}.metric-card-accent-green{box-shadow:inset 0 0 0 1px #22c55e29}.metric-card-accent-blue{box-shadow:inset 0 0 0 1px #3b82f633}.metric-card-accent-indigo{box-shadow:inset 0 0 0 1px #6366f13d}.metric-label{font-size:12px;color:var(--text-dim)}.metric-value{display:block;margin-top:6px;color:var(--text);font-size:26px;font-weight:700}.split-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:14px}.surface-card{border:1px solid var(--border);background:var(--surface);border-radius:14px;padding:14px}.section-head{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:12px}.section-head h2,.section-title{color:var(--text);font-size:20px;font-weight:700}.ui-input,.ui-select{width:100%;border:1px solid var(--border);border-radius:10px;height:40px;background:#0f172a;color:var(--text);padding:0 12px;outline:none}.ui-input:focus,.ui-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f133}.ui-btn-primary{border:0;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border-radius:10px;height:40px;font-weight:600;cursor:pointer}.ui-btn-primary:disabled{opacity:.6;cursor:default}.table-wrap{overflow-x:auto}.ui-table{width:100%;border-collapse:separate;border-spacing:0}.ui-table th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);font-weight:600;padding:12px 10px;border-bottom:1px solid var(--border)}.ui-table td{padding:12px 10px;border-bottom:1px solid #253042;color:#d1d5db;font-size:14px}.ui-table tr:hover td{background:#6366f10d}.table-user strong{display:block;color:var(--text)}.table-user span{font-size:12px;color:var(--text-dim)}.table-empty{text-align:center;color:var(--text-dim);padding:24px}.chip{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:999px;padding:2px 9px;font-size:12px;color:var(--text-dim);background:#0f172a}.chip-success{border-color:#22c55e80;color:#86efac}.chip-warning{border-color:#f59e0b80;color:#fcd34d}.cell-muted{color:var(--text-dim);font-size:12px}.ui-select-sm{height:30px;border-radius:8px;border:1px solid var(--border);background:#0f172a;color:var(--text);padding:0 8px;width:100%}.admin-user-actions{display:grid;gap:8px;min-width:170px}.points-editor{display:grid;grid-template-columns:1fr auto;gap:6px;align-items:center}.points-editor .ui-input,.points-editor .ui-btn-ghost{height:32px;padding:0 10px}.invite-form{margin-top:10px;display:grid;gap:10px}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.invite-list{margin-top:18px;border-top:1px solid var(--border);padding-top:12px}.invite-list h3{font-size:14px;color:var(--text);margin-bottom:8px}.invite-item{display:flex;justify-content:space-between;align-items:center;gap:8px;border:1px solid #2b3647;border-radius:10px;padding:10px;margin-bottom:8px}.invite-item strong{color:var(--text);display:block;font-size:13px}.invite-item p{color:var(--text-dim);font-size:12px}.password-wrap{position:relative}.password-wrap .login-input{padding-right:84px}.password-toggle{position:absolute;top:50%;right:10px;transform:translateY(-50%);border:1px solid #334155;background:#111827;color:#cbd5e1;border-radius:8px;padding:5px 10px;font-size:12px;cursor:pointer}.login-link{border:0;background:transparent;color:#93c5fd;text-align:left;font-size:13px;cursor:pointer}.notifications-wrap{position:relative}.notif-badge{position:absolute;top:-6px;right:-6px;min-width:16px;height:16px;border-radius:999px;background:#ef4444;color:#fff;font-size:10px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px}.notifications-popover{position:absolute;top:44px;right:0;width:min(380px,calc(100vw - 20px));border:1px solid var(--border);border-radius:12px;background:#111827;box-shadow:0 20px 40px #02061773;padding:10px;z-index:80}.notifications-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.notifications-head strong{font-size:14px;color:var(--text)}.notifications-list{display:grid;gap:8px;max-height:340px;overflow-y:auto}.notification-item{border:1px solid #2f3b4d;border-radius:10px;padding:10px}.notification-title{font-size:13px;font-weight:700;color:#f8fafc}.notification-message{margin-top:2px;font-size:12px;color:#cbd5e1}.notification-date{margin-top:4px;font-size:11px;color:#94a3b8}.ui-textarea{min-height:110px;padding-top:10px;resize:vertical}.ui-btn-ghost{border:1px solid var(--border);background:transparent;color:#cbd5e1;border-radius:10px;height:40px;font-weight:600;cursor:pointer}.ui-btn-danger{border:1px solid rgba(239,68,68,.45);background:#ef44441a;color:#fca5a5;border-radius:10px;height:34px;padding:0 12px;font-weight:600;cursor:pointer}.check-row{display:flex;gap:8px;align-items:center;font-size:14px;color:#d1d5db}.mission-layout{grid-template-columns:1fr 1.6fr}.mission-list{display:grid;gap:10px}.mission-item{border:1px solid #2f3b4d;border-radius:12px;background:#0f172a;padding:12px}.mission-item-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.mission-item-head h3{color:#f8fafc;font-size:16px;margin-bottom:4px}.mission-item-head p{color:#9ca3af;font-size:13px}.mission-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.mission-actions{margin-top:12px;display:flex;gap:8px}.mission-link-btn{display:inline-flex;align-items:center;justify-content:center;padding:0 16px;text-decoration:none}.empty-block h3{color:var(--text);font-size:19px;margin-bottom:6px}.empty-block p{color:var(--text-dim);margin-bottom:12px}.mission-action-grid{margin-top:8px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.mission-action-chip{border:1px solid #334155;background:#0f172a;color:#cbd5e1;border-radius:10px;height:36px;font-size:13px;font-weight:600}.mission-action-chip-active{border-color:#6366f1b3;background:#6366f12e;color:#fff}.mission-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.mission-card{display:block;border:1px solid var(--border);border-radius:14px;padding:14px;background:var(--surface);text-decoration:none;transition:transform .15s ease,border-color .2s ease}.mission-card:hover{transform:translateY(-1px);border-color:#6366f1}.mission-cta{margin-top:12px;display:inline-block;color:#a5b4fc;font-weight:600;font-size:13px}.profile-layout{grid-template-columns:1.1fr .9fr}.profile-stats{margin-top:12px}.proof-filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.proof-filter-btn{border:1px solid #334155;background:#0f172a;color:#cbd5e1;border-radius:8px;padding:8px 11px;font-size:13px;font-weight:600}.proof-filter-btn-active{border-color:#6366f199;background:#6366f12e;color:#fff}.proof-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.proof-card{border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:12px}.proof-card-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.proof-card-head h3{color:#f8fafc;font-size:16px}.proof-reason{margin-top:10px;border:1px solid rgba(239,68,68,.45);background:#ef44441a;border-radius:10px;padding:10px;color:#fecaca;font-size:13px}.proof-review-layout{display:grid;grid-template-columns:360px 1fr;gap:12px}.proof-list-panel{min-height:420px}.proof-admin-list{display:grid;gap:8px;max-height:520px;overflow-y:auto}.proof-admin-item{border:1px solid #2f3b4d;border-radius:10px;background:#0f172a;color:#fff;text-align:left;padding:10px;display:flex;justify-content:space-between;align-items:center;gap:8px}.proof-admin-item strong{font-size:13px;display:block}.proof-admin-item p{color:#9ca3af;font-size:12px}.proof-admin-item-active{border-color:#6366f1;background:#6366f129}.proof-admin-images{margin-top:12px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.proof-detail-error{display:flex;flex-direction:column;gap:10px;align-items:flex-start}.proof-admin-image{width:100%;aspect-ratio:4 / 3;-o-object-fit:cover;object-fit:cover;border-radius:10px;border:1px solid #2f3b4d}.upload-widget{width:100%}.upload-dropzone{border:2px dashed #334155;border-radius:14px;padding:22px;text-align:center;cursor:pointer;background:#0f172a;transition:border-color .2s ease,background .2s ease}.upload-dropzone:hover{border-color:#4b5563}.upload-dropzone-active{border-color:#6366f1;background:#6366f11f}.upload-title{color:#e2e8f0;font-size:14px;font-weight:600}.upload-subtitle{margin-top:6px;color:#94a3b8;font-size:12px}.upload-preview-panel{margin-top:14px;border:1px solid #2f3b4d;border-radius:12px;background:#0f172a;padding:12px}.upload-preview-grid{margin-top:10px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;max-height:380px;overflow-y:auto;padding-right:4px}.upload-preview-item{position:relative;border-radius:10px;border:1px solid #334155;overflow:hidden;background:#111827}.upload-preview-image{width:100%;aspect-ratio:1 / 1;-o-object-fit:cover;object-fit:cover;display:block}.upload-remove-btn{position:absolute;top:6px;right:6px;width:24px;height:24px;border:0;border-radius:8px;background:#ef4444e6;color:#fff;font-size:13px;cursor:pointer}.upload-submit-btn{width:100%;margin-top:12px}.reject-modal{width:min(520px,100%)}@media (max-width: 1024px){.app-main{margin-left:0}.sidebar{display:none}.mobile-menu-btn{display:inline-flex;align-items:center;justify-content:center}.mobile-menu{display:flex}.proof-review-layout{grid-template-columns:1fr}}@media (max-width: 840px){.proof-grid,.proof-admin-images{grid-template-columns:1fr}.upload-preview-grid,.mission-action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 640px){.app-main{margin-left:0;margin-top:64px;padding:12px;min-height:calc(100vh - 64px)}.topbar{padding:0 12px;height:64px}.brand{font-size:22px}.topbar-search-wrap,.user-chip{display:none}.login-card{padding:28px 20px;border-radius:14px}.login-title{font-size:28px}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.split-grid,.mission-layout,.profile-layout,.mission-grid,.proof-grid,.proof-admin-images{grid-template-columns:1fr}.upload-preview-grid{grid-template-columns:repeat(2,minmax(0,1fr));max-height:320px}.topbar-right{gap:6px}.icon-btn,.logout-btn,.mobile-menu-btn{height:34px}.logout-btn{padding:0 10px;font-size:12px}.page-title{font-size:30px}.mobile-menu{top:64px}}.container{@apply max-w-7xl mx-auto px-4 sm:px-6 lg:px-8;}.card{@apply bg-slate-800 rounded-lg p-6 shadow-lg border border-slate-700;}.btn{@apply px-4 py-2 rounded-lg font-medium transition-all duration-200;}.btn-primary{@apply bg-blue-600 text-white hover:bg-blue-700;}.btn-secondary{@apply bg-slate-700 text-white hover:bg-slate-600;}.btn-success{@apply bg-green-600 text-white hover:bg-green-700;}.btn-danger{@apply bg-red-600 text-white hover:bg-red-700;}.input{@apply w-full px-4 py-2 bg-slate-700 border border-slate-600 rounded-lg text-white focus:outline-none focus:border-blue-500;}.badge{@apply inline-block px-3 py-1 rounded-full text-sm font-medium;}.badge-success{@apply bg-green-500 bg-opacity-20 text-green-400;}.badge-pending{@apply bg-yellow-500 bg-opacity-20 text-yellow-400;}.badge-rejected{@apply bg-red-500 bg-opacity-20 text-red-400;}
