:root{--bg:#f8f9fa;--bg-card:#ffffff;--text:#1a1a2e;--text-muted:#6c757d;--primary:#0d6e3e;--primary-light:#e8f5e9;--border:#dee2e6;--sidebar-w:240px;--danger:#dc3545}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}a{color:inherit;text-decoration:none}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--text);color:#fff;padding:1.5rem 0;position:fixed;top:0;left:0;bottom:0;display:flex;flex-direction:column;z-index:100;transition:transform .25s ease}.sidebar-brand{padding:0 1.25rem 1.5rem;font-size:1.25rem;font-weight:700;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:.5rem}.sidebar-nav{list-style:none;flex:1 1}.sidebar-nav li a{display:flex;align-items:center;gap:.75rem;padding:.625rem 1.25rem;color:rgba(255,255,255,.7);transition:background .15s,color .15s;font-size:.9rem}.sidebar-nav li a.active,.sidebar-nav li a:hover{background:rgba(255,255,255,.1);color:#fff}.main-content{margin-left:var(--sidebar-w);flex:1 1;padding:2rem;min-width:0}.page-header{margin-bottom:1.5rem}.page-header h1{font-size:1.5rem;font-weight:600}.page-header p{color:var(--text-muted);font-size:.9rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1.25rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1.25rem;gap:1rem}.stat-card,.stat-icon{display:flex;align-items:center}.stat-icon{justify-content:center;width:44px;height:44px;border-radius:10px;background:var(--primary-light);color:var(--primary);flex-shrink:0}.stat-card .stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-card .stat-value{font-size:1.75rem;font-weight:700;margin-top:.25rem}.table-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;overflow-x:auto;-webkit-overflow-scrolling:touch}.table-card table{width:100%;border-collapse:collapse;min-width:500px}.table-card td,.table-card th{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.table-card th{background:var(--bg);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.badge{display:inline-block;padding:.2em .6em;border-radius:4px;font-size:.75rem;font-weight:600}.badge-draft{background:#fff3cd;color:#856404}.badge-published{background:#d4edda;color:#155724}.badge-completed{background:#d1ecf1;color:#0c5460}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border-radius:6px;border:1px solid var(--border);background:var(--bg-card);color:var(--text);font-size:.875rem;cursor:pointer;transition:background .15s;width:100%}.btn:hover{background:var(--bg)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:#0a5c33}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{background:#c82333}.btn-sm{padding:.3rem .625rem;font-size:.8rem;width:auto}.btn-row{display:flex;gap:.5rem}.page-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem}.page-header-row .page-header{margin-bottom:0}.form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1.5rem;max-width:600px}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.3rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.9rem;font-family:inherit;background:var(--bg);transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-group textarea{min-height:80px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem;gap:1rem}.form-actions{display:flex;gap:.5rem;margin-top:1.25rem}.form-actions .btn{width:auto}.checkbox-list{display:flex;flex-direction:column;gap:.4rem;padding:.5rem 0}.checkbox-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;cursor:pointer}.checkbox-item input[type=checkbox]{width:auto}.inline-input{padding:.3rem .5rem;border:1px solid var(--border);border-radius:4px;font-size:.85rem;font-family:inherit;background:var(--bg);flex:1 1;min-width:100px}.inline-input:focus{outline:none;border-color:var(--primary)}.alert{padding:.75rem 1rem;border-radius:6px;font-size:.875rem;margin-bottom:1rem}.alert-success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.alert-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.bar-chart{display:flex;flex-direction:column;gap:.5rem}.bar-chart-row{display:flex;align-items:center;gap:.75rem}.bar-chart-label{width:80px;font-size:.8rem;color:var(--text-muted);text-align:right;flex-shrink:0}.bar-chart-track{flex:1 1;height:20px;background:var(--bg);border-radius:4px;overflow:hidden}.bar-chart-fill{height:100%;border-radius:4px;min-width:2px;transition:width .3s ease}.bar-chart-value{width:60px;font-size:.8rem;font-weight:600;flex-shrink:0}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-state p{margin-top:.5rem}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem}.login-card{width:100%;max-width:400px}.login-card h1{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.login-card>p{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem}.login-card form{display:flex;flex-direction:column;gap:.75rem}.login-card label{font-size:.85rem;font-weight:600}.login-card input{width:100%;padding:.625rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:1rem;font-family:inherit;background:var(--bg);transition:border-color .15s}.login-card input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-error{color:var(--danger);font-size:.85rem}.form-hint{font-size:.8rem;color:var(--text-muted)}.mobile-menu-toggle{display:none;position:fixed;top:.75rem;left:.75rem;z-index:200;background:var(--text);color:#fff;border:none;border-radius:6px;padding:.5rem .625rem;font-size:1.25rem;cursor:pointer;line-height:1}.sidebar-overlay{display:none}@media (max-width:768px){.mobile-menu-toggle{display:block}.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:99}.sidebar-overlay.open{display:block}.main-content{margin-left:0;padding:3.5rem 1rem 1rem}.stats-grid{grid-template-columns:1fr}.stat-card .stat-value{font-size:1.5rem}.page-header h1{font-size:1.25rem}.table-card td,.table-card th{padding:.5rem .75rem;font-size:.85rem}}@media (max-width:480px){.stats-grid{gap:.75rem}.login-card{padding:1rem}}