@import url("https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500&family=Inter:wght@300;400;500;600&display=swap");*{box-sizing:border-box;margin:0;padding:0}:root{--charcoal:#2c2c2c;--charcoal-dark:#1e1e1e;--teal:#0f9baa;--teal-light:#e6f7f9;--teal-mid:#0d8898;--sand:#f5f0e8;--sand-bg:#f0ede8;--border:#e2ddd8;--muted:#666;--s0b:#fdecea;--s0t:#a32d2d;--s1b:#fff3cd;--s1t:#7a4a0a;--s2b:#eaf3de;--s2t:#27500a;--s3b:#c8f5da;--s3t:#085041;--secA:#0a6b77;--secB:#0f9baa;--secC:#3dbdcc;--secD:#5ecfda}body{font-family:Inter,Arial,sans-serif;font-size:13px;color:var(--charcoal);background:var(--sand-bg);line-height:1.5}.playfair{font-family:Playfair Display,Georgia,serif}.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;flex-shrink:0;background:var(--charcoal-dark);position:-webkit-sticky;position:sticky;top:0;height:100vh;overflow:hidden;display:flex;flex-direction:column}.sidebar-logo{padding:14px 18px 10px;border-bottom:1px solid hsla(0,0%,100%,.08)}.sidebar-logo h1{font-family:Playfair Display,serif;font-size:28px;font-weight:500;color:#f5f0e8;line-height:1}.sidebar-logo h1 .dot{color:var(--teal)}.sidebar-logo p{font-size:9px;color:hsla(0,0%,100%,.3);margin-top:4px;letter-spacing:.1em;text-transform:uppercase}.sidebar-nav{padding:4px 0;flex:1 1;overflow-y:auto}.nav-section{padding:7px 18px 2px;font-size:9px;font-weight:600;color:hsla(0,0%,100%,.25);letter-spacing:.12em;text-transform:uppercase}.nav-item{padding:6px 18px;font-size:12px;color:hsla(0,0%,100%,.55);cursor:pointer;border-left:3px solid transparent;display:flex;justify-content:space-between;align-items:center;gap:6px;transition:all .12s;text-decoration:none;line-height:1.4}.nav-item:hover{background:hsla(0,0%,100%,.06);color:hsla(0,0%,100%,.85)}.nav-item.active{background:rgba(15,155,170,.12);color:#fff;border-left-color:var(--teal);font-weight:500}.nav-item span:first-child{flex:1 1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-badge{font-size:10px;padding:2px 8px;border-radius:10px;font-weight:600;white-space:nowrap;min-width:38px;text-align:center;flex-shrink:0}.nav-badge-empty{background:hsla(0,0%,100%,.08);color:hsla(0,0%,100%,.3)}.nav-badge-A{background:var(--secA);color:#fff}.nav-badge-B{background:var(--secB);color:#fff}.nav-badge-C{background:var(--secC);color:#fff}.nav-badge-D{background:var(--secD);color:#fff}.nav-action{background:rgba(15,155,170,.15);border-left:3px solid var(--teal);color:var(--teal);font-weight:600}.sidebar-footer{padding:14px 18px;border-top:1px solid hsla(0,0%,100%,.08)}.footer-label{font-size:9px;color:hsla(0,0%,100%,.3);display:flex;justify-content:space-between;margin-bottom:6px;letter-spacing:.04em}.footer-bar{height:3px;background:hsla(0,0%,100%,.1);border-radius:2px;overflow:hidden}.footer-fill{height:100%;background:var(--teal);border-radius:2px;transition:width .4s}.main-content{flex:1 1;min-width:0;padding:24px 28px;background:var(--sand-bg);overflow-y:auto}.page-title{font-family:Playfair Display,serif;font-size:22px;font-weight:500;color:var(--charcoal);margin-bottom:18px;padding-bottom:12px;border-bottom:2px solid var(--teal)}.card{background:#fff;border:1px solid var(--border);border-radius:10px;margin-bottom:14px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.04)}.card-header{background:var(--charcoal);color:#fff;padding:12px 18px;display:flex;justify-content:space-between;align-items:center}.card-header h2{font-size:12px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:#f5f0e8}.card-body{padding:18px}.form-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-size:9px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.08em}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:12px;font-family:Inter,Arial,sans-serif;color:#333;background:#fff;outline:none;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--teal);box-shadow:0 0 0 2px rgba(15,155,170,.1)}.form-group textarea{resize:vertical;min-height:68px;line-height:1.55}.btn{border:none;padding:9px 18px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;font-family:Inter,sans-serif;letter-spacing:.03em;transition:opacity .15s}.btn:hover{opacity:.85}.btn-teal{background:var(--teal);color:#fff}.btn-charcoal{background:var(--charcoal);color:#fff}.btn-outline{background:#fff;color:var(--charcoal);border:1px solid var(--charcoal)}.metrics{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:8px;gap:8px;margin-bottom:12px}.metric{background:#fff;border:1px solid var(--border);border-radius:8px;padding:12px;text-align:center}.metric-label{font-size:9px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}.metric-value{font-size:22px;font-weight:600;color:var(--teal)}.metric-sub{font-size:10px;color:var(--muted);margin-top:2px}.progress-wrap{background:#fff;border:1px solid var(--border);border-radius:8px;padding:12px 16px;margin-bottom:12px}.progress-meta{display:flex;justify-content:space-between;font-size:10px;color:var(--muted);margin-bottom:6px}.progress-bar{height:6px;background:#e8e3dc;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--teal);border-radius:3px;transition:width .35s}.col-header{display:grid;grid-template-columns:1fr 68px 100px 128px;background:#f8f5f0;border-top:1px solid #e8e3dc;border-bottom:1px solid #e8e3dc}.col-header span{padding:5px 8px;font-size:9px;font-weight:600;color:#888;text-align:center;letter-spacing:.08em;text-transform:uppercase;border-left:1px solid #e8e3dc}.col-header span:first-child{text-align:left;padding-left:14px;border-left:none}.ind-row{display:grid;grid-template-columns:1fr 68px 100px 128px;border-top:1px solid #f0f0f0}.ind-row:hover{background:#fafaf8}.ind-text{padding:7px 14px;font-size:12px;line-height:1.4;color:#333}.ind-num{color:#ccc;margin-right:3px;font-size:11px}.ind-priority,.ind-score,.ind-status{border-left:1px solid #ebebeb;display:flex;align-items:center;justify-content:center;padding:5px 6px}.ind-score select{width:50px;font-size:13px}.ind-priority select,.ind-score select{font-weight:600;border:none;background:transparent;cursor:pointer;text-align:center}.ind-priority select{width:86px;font-size:10px;border-radius:10px;padding:2px 4px}.score-empty{background:#f9f9f9}.score-empty select{color:#ccc}.score-0{background:var(--s0b)}.score-0 select{color:var(--s0t)}.score-1{background:var(--s1b)}.score-1 select{color:var(--s1t)}.score-2{background:var(--s2b)}.score-2 select{color:var(--s2t)}.score-3{background:var(--s3b)}.score-3 select{color:var(--s3t)}.score-na{background:#f5f5f5}.score-na select{color:#aaa}.pri-High select{background:var(--s0b);color:var(--s0t)}.pri-Medium select{background:var(--s1b);color:var(--s1t)}.pri-Low select{background:var(--s2b);color:var(--s2t)}.pri-NA select{background:#f0f0f0;color:#999}.status-text{font-size:10px;font-weight:600}.sc-table{width:100%;border-collapse:collapse;font-size:12px}.sc-table th{background:#f8f5f0;padding:8px 10px;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:#888;border-bottom:2px solid var(--border);text-align:left}.sc-table td{padding:7px 10px;border-bottom:1px solid #f4f2ef;vertical-align:middle}.sc-table tr:hover td{background:#fafaf8}.at-table{width:100%;border-collapse:collapse;font-size:12px}.at-table th{background:var(--charcoal);color:#f5f0e8;padding:9px 10px;font-size:9px;font-weight:600;text-align:left;letter-spacing:.08em;text-transform:uppercase}.at-table td{padding:7px 9px;border-bottom:1px solid #f0f0f0;vertical-align:top}.at-phase td{background:#e6f7f9;font-weight:600;color:#0d5f6b;font-size:11px;padding:5px 9px}.priority-badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:9px;white-space:nowrap;display:inline-block}.priority-High{background:var(--s0b);color:var(--s0t)}.priority-Medium{background:var(--s1b);color:var(--s1t)}.priority-Low{background:var(--s2b);color:var(--s2t)}.alert{padding:10px 14px;border-radius:6px;font-size:11px;margin-bottom:11px;line-height:1.6}.alert-info{background:#e6f7f9;color:#0d5f6b;border:1px solid #9fd8df}.alert-success{background:var(--s3b);color:var(--s3t);border:1px solid #9fe1cb}.alert-warning{background:var(--s1b);color:var(--s1t);border:1px solid #fac775}.tracker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));grid-gap:7px;gap:7px;margin-top:10px}.tracker-item{border-radius:6px;padding:7px 10px;font-size:11px;font-weight:600;border:1px solid transparent;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:opacity .12s}.tracker-item:hover{opacity:.8}.tracker-done{background:var(--s3b);color:var(--s3t);border-color:#9fe1cb}.tracker-partial{background:var(--s1b);color:var(--s1t);border-color:#fac775}.tracker-empty{background:#f4f1ec;color:#aaa;border-color:#e8e3dc}.roadmap-action{background:#fff;border:1px solid var(--border);border-radius:9px;padding:14px 16px;display:flex;gap:12px;align-items:flex-start;margin-bottom:8px;transition:opacity .2s,border-color .2s}.roadmap-action.done{opacity:.55;border-color:#c8f5da;background:#fafcfa}.action-check{width:22px;height:22px;border:2px solid #d0cbc3;border-radius:50%;cursor:pointer;flex-shrink:0;margin-top:1px;transition:all .15s;display:flex;align-items:center;justify-content:center;font-size:12px;color:transparent;background:transparent}.action-check.ticked{background:var(--teal);border-color:var(--teal);color:#fff}.section-pill{width:24px;height:24px;border-radius:50%;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;margin-top:1px}.login-wrap,.section-pill{display:flex;align-items:center;justify-content:center}.login-wrap{min-height:100vh;background:var(--charcoal-dark)}.login-card{background:#fff;border-radius:12px;padding:40px;width:380px;text-align:center}.login-logo{font-family:Playfair Display,serif;font-size:36px;font-weight:500;color:var(--charcoal);margin-bottom:8px}.login-logo .dot{color:var(--teal)}.login-sub{font-size:12px;color:var(--muted);margin-bottom:28px;letter-spacing:.04em;text-transform:uppercase}.client-wrap{min-height:100vh;background:var(--sand-bg)}.client-header{background:var(--charcoal);padding:16px 28px;display:flex;align-items:center;justify-content:space-between}.client-header-logo{font-family:Playfair Display,serif;font-size:22px;color:#f5f0e8}.client-header-logo .dot{color:var(--teal)}.client-nav{display:flex;gap:4px;background:hsla(0,0%,100%,.06);border-radius:8px;padding:4px}.client-nav-btn{padding:7px 14px;border:none;background:transparent;color:hsla(0,0%,100%,.55);border-radius:6px;cursor:pointer;font-size:12px;font-family:Inter,sans-serif;transition:all .15s}.client-nav-btn.active{background:rgba(15,155,170,.2);color:#fff}.client-main{max-width:900px;margin:0 auto;padding:28px 28px 60px}.save-banner{position:fixed;top:16px;right:16px;padding:10px 20px;border-radius:8px;font-size:12px;font-weight:600;z-index:9999;box-shadow:0 4px 12px rgba(0,0,0,.2);animation:fadeInOut 4s forwards}@keyframes fadeInOut{0%{opacity:0;transform:translateY(-8px)}10%{opacity:1;transform:translateY(0)}80%{opacity:1}to{opacity:0}}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:16px;gap:16px;margin-top:20px}.client-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:18px 20px;cursor:pointer;transition:border-color .15s,box-shadow .15s;text-decoration:none;color:inherit;display:block}.client-card:hover{border-color:var(--teal);box-shadow:0 2px 8px rgba(15,155,170,.12)}.client-card-name{font-family:Playfair Display,serif;font-size:16px;font-weight:500;color:var(--charcoal);margin-bottom:4px}.client-card-meta{font-size:11px;color:var(--muted);margin-bottom:12px}.client-card-scores{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:6px;gap:6px;margin-bottom:12px}.score-chip{text-align:center;padding:6px 4px;border-radius:6px}.score-chip-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.score-chip-value{font-size:14px;font-weight:600;margin-top:2px}.overall-bar{height:4px;background:#e8e3dc;border-radius:2px;overflow:hidden}.overall-fill{height:100%;background:var(--teal);border-radius:2px}@media (max-width:768px){.sidebar{display:none}.form-grid{grid-template-columns:1fr}.metrics{grid-template-columns:repeat(2,1fr)}}