:root{--navy: #0B1F3A;--navy-deep: #061429;--navy-light: #16335c;--gold: #C9A227;--gold-light: #E0BE52;--green: #3DBA6E;--green-deep: #2A8F53;--red: #C9462F;--off-white: #F7F6F2;--paper: #FFFFFF;--charcoal: #1C1C1C;--steel: #5A6472;--steel-light: #9AA4B0;--line: #E2E1DA;--font-display: "Archivo", "Arial Narrow", sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--radius: 6px;--sidebar-w: 240px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);color:var(--charcoal);background:var(--off-white);font-size:15px}a{color:inherit;text-decoration:none}button{font-family:inherit}h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;color:var(--navy);line-height:1.2}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--navy-deep);color:var(--off-white);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0}.sidebar-logo{padding:1.4rem 1.2rem;display:flex;align-items:center;gap:.6rem;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo .name{font-family:var(--font-display);font-weight:800;font-size:1.1rem}.sidebar-logo .sub{font-family:var(--font-mono);font-size:.6rem;color:var(--steel-light);letter-spacing:.08em;text-transform:uppercase;display:block}.sidebar-nav{flex:1;padding:1rem .7rem;display:flex;flex-direction:column;gap:.2rem}.sidebar-nav a{display:flex;align-items:center;gap:.7rem;padding:.65rem .8rem;border-radius:var(--radius);color:var(--steel-light);font-size:.88rem;font-weight:500}.sidebar-nav a:hover{background:#ffffff0f;color:var(--off-white)}.sidebar-nav a.active{background:var(--navy-light);color:var(--off-white)}.sidebar-footer{padding:1rem 1.2rem;border-top:1px solid rgba(255,255,255,.08)}.sidebar-user{font-size:.82rem;color:var(--off-white);font-weight:600}.sidebar-role{font-family:var(--font-mono);font-size:.68rem;color:var(--gold-light);text-transform:uppercase;letter-spacing:.05em}.logout-btn{margin-top:.7rem;background:none;border:1px solid rgba(255,255,255,.2);color:var(--steel-light);padding:.45rem .8rem;border-radius:var(--radius);font-size:.78rem;cursor:pointer;width:100%}.logout-btn:hover{border-color:var(--gold);color:var(--gold-light)}.main-content{margin-left:var(--sidebar-w);flex:1;padding:2rem 2.5rem;max-width:1300px}@media (max-width: 860px){.sidebar{width:100%;height:auto;position:relative;flex-direction:row;align-items:center;justify-content:space-between}.sidebar-nav{display:none}.main-content{margin-left:0;padding:1.2rem}}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.6rem;flex-wrap:wrap;gap:1rem}.page-header h1{font-size:1.6rem;text-transform:uppercase}.page-header p{color:var(--steel);margin-top:.3rem;font-size:.92rem}.breadcrumb{font-family:var(--font-mono);font-size:.78rem;color:var(--steel-light);margin-bottom:.5rem}.breadcrumb a:hover{color:var(--navy)}.btn{display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:.88rem;padding:.65rem 1.3rem;border-radius:var(--radius);border:1.5px solid transparent;cursor:pointer;transition:all .15s ease;white-space:nowrap}.btn-primary{background:var(--navy);color:var(--off-white)}.btn-primary:hover{background:var(--navy-light)}.btn-gold{background:var(--gold);color:var(--navy-deep)}.btn-gold:hover{background:var(--gold-light)}.btn-outline{background:transparent;border-color:var(--line);color:var(--navy)}.btn-outline:hover{border-color:var(--navy)}.btn-danger{background:transparent;border-color:var(--red);color:var(--red)}.btn-danger:hover{background:var(--red);color:#fff}.btn-sm{padding:.4rem .85rem;font-size:.78rem}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem}.card+.card{margin-top:1rem}.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.6rem}@media (max-width: 860px){.stat-row{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:var(--radius);padding:1rem 1.2rem}.stat-card .num{font-family:var(--font-mono);font-size:1.6rem;font-weight:700;color:var(--navy);display:block}.stat-card .label{font-size:.78rem;color:var(--steel);text-transform:uppercase;letter-spacing:.03em;margin-top:.2rem}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--steel);padding:.7rem .8rem;border-bottom:1.5px solid var(--line)}.data-table td{padding:.8rem;border-bottom:1px solid var(--line);font-size:.88rem;vertical-align:middle}.data-table tr:hover td{background:#0b1f3a05}.data-table tr.clickable{cursor:pointer}.badge{font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.03em;padding:.25rem .55rem;border-radius:999px;display:inline-block;white-space:nowrap}.badge-planning{background:#5a64721f;color:var(--steel)}.badge-active{background:#3dba6e1f;color:var(--green-deep)}.badge-on_hold{background:#c9a22726;color:#8a6c14}.badge-completed{background:#0b1f3a1a;color:var(--navy)}.badge-cancelled{background:#c9462f1f;color:var(--red)}.badge-not_started{background:#5a64721f;color:var(--steel)}.badge-in_progress{background:#c9a22726;color:#8a6c14}.badge-blocked{background:#c9462f1f;color:var(--red)}.badge-task-completed{background:#3dba6e1f;color:var(--green-deep)}.role-badge{font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;padding:.2rem .5rem;border-radius:999px;background:var(--navy);color:var(--off-white)}.field{margin-bottom:1rem;display:flex;flex-direction:column;gap:.35rem}.field label{font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--navy);font-family:var(--font-mono)}.field input,.field select,.field textarea{font-family:var(--font-body);border:1.5px solid var(--line);border-radius:var(--radius);padding:.6rem .8rem;font-size:.9rem;background:var(--off-white);color:var(--charcoal)}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--navy)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 620px){.form-grid{grid-template-columns:1fr}}.error-msg{background:#c9462f14;color:var(--red);border:1px solid rgba(201,70,47,.3);border-radius:var(--radius);padding:.7rem 1rem;font-size:.85rem;margin-bottom:1rem}.success-msg{background:#3dba6e14;color:var(--green-deep);border:1px solid rgba(61,186,110,.3);border-radius:var(--radius);padding:.7rem 1rem;font-size:.85rem;margin-bottom:1rem}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--navy-deep);padding:2rem}.auth-card{background:var(--paper);border-radius:var(--radius);padding:2.4rem;width:100%;max-width:440px}.auth-logo{display:flex;align-items:center;gap:.6rem;margin-bottom:1.6rem}.auth-logo .name{font-family:var(--font-display);font-weight:800;font-size:1.3rem;color:var(--navy)}.auth-card h2{font-size:1.3rem;text-transform:uppercase;margin-bottom:.4rem}.auth-card p.subtitle{color:var(--steel);font-size:.88rem;margin-bottom:1.4rem}.auth-switch{text-align:center;margin-top:1.2rem;font-size:.85rem;color:var(--steel)}.auth-switch a{color:var(--navy);font-weight:700}.gantt-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper)}.gantt-row{display:flex;border-bottom:1px solid var(--line);min-height:44px}.gantt-row:last-child{border-bottom:none}.gantt-label{width:220px;flex-shrink:0;padding:.6rem .9rem;font-size:.82rem;font-weight:600;color:var(--navy);border-right:1px solid var(--line);display:flex;align-items:center;background:var(--off-white);position:sticky;left:0}.gantt-track{position:relative;flex:1;min-width:600px;display:flex;align-items:center}.gantt-bar{position:absolute;height:20px;border-radius:4px;background:var(--green);display:flex;align-items:center;padding:0 .5rem;font-size:.7rem;color:#fff;white-space:nowrap;overflow:hidden}.gantt-bar.not_started{background:var(--steel-light)}.gantt-bar.in_progress{background:var(--gold);color:var(--navy-deep)}.gantt-bar.blocked{background:var(--red)}.gantt-bar.completed{background:var(--green-deep)}.gantt-milestone{position:absolute;width:14px;height:14px;background:var(--gold);transform:rotate(45deg) translateY(-50%);top:50%}.gantt-phase-header{background:var(--navy);color:var(--off-white);font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;padding:.5rem .9rem}.empty-state{text-align:center;padding:3rem 1.5rem;color:var(--steel)}.empty-state h3{color:var(--steel);margin-bottom:.4rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0614298c;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.modal{background:var(--paper);border-radius:var(--radius);padding:1.8rem;width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.2rem}.modal-close{background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--steel)}.tab-row{display:flex;gap:1.6rem;border-bottom:1.5px solid var(--line);margin-bottom:1.4rem}.tab-btn{background:none;border:none;padding:.6rem 0;font-size:.88rem;font-weight:600;color:var(--steel);cursor:pointer;border-bottom:2px solid transparent}.tab-btn.active{color:var(--navy);border-bottom-color:var(--gold)}.flex-between{display:flex;justify-content:space-between;align-items:center}.text-steel{color:var(--steel)}.text-sm{font-size:.82rem}.mt-1{margin-top:.6rem}.mt-2{margin-top:1.2rem}.loading-spinner{border:2px solid var(--line);border-top-color:var(--navy);border-radius:50%;width:20px;height:20px;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.center-page{display:flex;align-items:center;justify-content:center;min-height:60vh}
