:root{--ink:#17231f;--muted:#6d7974;--green:#123f35;--teal:#238b75;--pale:#edf3f0;--line:#dde6e1;--amber:#b9761c;--red:#ad463e}*{box-sizing:border-box}body{margin:0;background:#f5f7f6;color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif}button,select{font:inherit}button{cursor:pointer}.shell{min-height:100vh;display:grid;grid-template-columns:245px 1fr}aside{position:sticky;top:0;height:100vh;padding:26px 20px;display:flex;flex-direction:column;background:#fff;border-right:1px solid var(--line)}.logo{width:150px}.project-mini{margin:34px 0 24px;padding:15px;background:var(--pale);border-radius:12px}.project-mini strong,.project-mini span{display:block}.project-mini span,.side-foot small{margin-top:4px;color:var(--muted);font-size:12px}nav{display:grid;gap:5px}nav button{padding:11px 13px;text-align:left;border:0;border-radius:8px;color:var(--muted);background:transparent;font-weight:650}nav button.active,nav button:hover{color:var(--green);background:var(--pale)}.side-foot{margin-top:auto;display:flex;gap:9px;align-items:center}.side-foot strong,.side-foot small{display:block}.signal{width:9px;height:9px;border-radius:50%;background:#38a36e;box-shadow:0 0 0 5px #e0f3e9}main{padding:25px 38px 60px;max-width:1600px;width:100%}header,.title-row,.panel-head{display:flex;align-items:center;justify-content:space-between;gap:20px}header{margin-bottom:30px}h1,h2,h3,p{margin-top:0}h1{margin-bottom:3px;font-size:22px}header p,.title-row p{margin:0;color:var(--muted)}.header-actions{display:flex;gap:10px;align-items:center}.mode{display:flex;gap:8px;align-items:center;padding:10px 13px;border:1px solid var(--line);border-radius:8px;font-weight:700}.primary,.panel-head button,.document button{border:0;border-radius:8px;padding:11px 15px;font-weight:750}.primary{color:#fff;background:var(--green)}.hero{display:flex;align-items:center;justify-content:space-between;min-height:280px;padding:38px 45px;color:#fff;background:var(--green);border-radius:18px}.hero h2{margin:18px 0 12px;font-size:48px;line-height:1}.hero p{max-width:580px;color:#c6d8d2}.hero-meta{display:flex;gap:35px;margin-top:35px}.hero-meta b,.hero-meta span{display:block}.status{display:inline-flex;padding:5px 9px;border-radius:99px;background:var(--pale);color:var(--green);font-size:11px;font-weight:850;text-transform:uppercase;letter-spacing:.04em}.status.good{background:#dff2e8}.status.warn{color:#915f17;background:#fff0d8}.progress-ring{width:170px;height:170px;display:grid;place-items:center;border-radius:50%;background:conic-gradient(#70c7ad var(--p),#315c51 0);position:relative}.progress-ring:after{content:"";position:absolute;inset:18px;border-radius:50%;background:var(--green)}.progress-ring div{position:relative;z-index:1;text-align:center}.progress-ring strong{display:block;font-size:42px}.progress-ring span{color:#bcd2ca}.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:14px 0}.metric,.panel,.photo{background:#fff;border:1px solid var(--line);border-radius:14px}.metric{padding:20px}.metric span,.metric small{color:var(--muted);font-size:12px}.metric strong{display:block;margin:13px 0 4px;font-size:25px}.panel{padding:20px;margin-bottom:14px}.panel-head{margin-bottom:18px}.panel-head h3{margin:0}.panel-head span{color:var(--muted);font-size:13px}.panel-head button,.document button{padding:7px 10px;color:var(--green);background:var(--pale)}.split{display:grid;grid-template-columns:1fr 1fr;gap:14px}.rows{display:grid}.row{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;padding:12px 0;border-top:1px solid var(--line)}.row:first-child{border-top:0}.row strong,.row small{display:block}.row small{margin-top:3px;color:var(--muted);font-size:11px}.dot{width:8px;height:8px;border-radius:50%}.risk-icon{display:grid;place-items:center;width:22px;height:22px;border-radius:50%;color:#956116;background:#fff0d8;font-weight:900}.phase-grid{display:grid;grid-template-columns:100px repeat(5,1fr);gap:9px;align-items:center}.phase-grid>b{color:var(--muted);font-size:10px}.phase-grid>strong{font-size:12px}.phase-grid i{height:14px;grid-column:var(--w);background:var(--c);border-radius:20px}.title-row{margin:8px 0 20px}.title-row h2{margin-bottom:3px;font-size:38px}.title-row select{padding:10px;border:1px solid var(--line);border-radius:8px}.gantt{padding:0;overflow:auto}.gantt-head,.gantt-row{min-width:980px;display:grid;grid-template-columns:360px 1fr 55px;align-items:center}.gantt-head{padding:12px 15px;background:var(--pale);grid-template-columns:360px repeat(5,1fr) 55px;font-size:10px;color:var(--muted)}.gantt-row{min-height:65px;padding:8px 15px;border-top:1px solid var(--line)}.gantt-row>div:first-child{display:grid;grid-template-columns:auto 1fr;gap:3px 10px}.gantt-row .dot{grid-row:1/3}.gantt-row strong{font-size:12px}.gantt-row small{color:var(--muted);font-size:10px}.track{height:24px;position:relative;background:repeating-linear-gradient(90deg,transparent 0,transparent 19.8%,#edf1ef 20%)}.track i{position:absolute;top:6px;height:12px;border-radius:20px;opacity:.45}.track em{display:block;height:100%;background:inherit;border-radius:20px;opacity:1}.gantt-row button{border:0;background:var(--pale);border-radius:7px;padding:7px;font-size:11px;font-weight:800}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.photo{overflow:hidden}.photo-placeholder{height:150px;display:grid;place-items:center;background:linear-gradient(145deg,#d8e3df,#829d94);position:relative}.photo-placeholder.p1{background:linear-gradient(145deg,#d8deda,#a4917e)}.photo-placeholder.p2{background:linear-gradient(145deg,#dae3e5,#657f86)}.photo-placeholder:after{content:"SITE PHOTO";font-size:10px;letter-spacing:.2em;color:#fff}.photo-placeholder span{position:absolute;top:10px;left:10px;padding:5px 8px;border-radius:20px;background:#fff;color:var(--green);font-size:10px;font-weight:850}.photo small,.photo h3,.photo p{display:block;margin-left:15px;margin-right:15px}.photo small{margin-top:13px;color:var(--muted)}.photo h3{margin-top:5px;margin-bottom:5px}.photo p{color:var(--muted);font-size:12px}.photo-grid.large .photo-placeholder{height:260px}.update{display:grid;grid-template-columns:130px 1fr;gap:25px;padding:22px 0;border-top:1px solid var(--line)}.update:first-child{border-top:0}.update time{color:var(--muted);font-size:12px}.update h3{margin:12px 0 6px}.update p{color:var(--muted)}.risk-table article{display:grid;grid-template-columns:90px 1fr 170px;gap:20px;padding:18px 0;border-top:1px solid var(--line)}.risk-table article:first-child{border-top:0}.risk-table h3{margin-bottom:5px}.risk-table p,.risk-table small{color:var(--muted)}.document{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:15px 0;border-top:1px solid var(--line)}.document:first-child{border-top:0}.document>span{padding:8px;color:#fff;background:var(--red);border-radius:6px;font-size:10px;font-weight:900}.document strong,.document small{display:block}.document small{margin-top:4px;color:var(--muted)}@media(max-width:900px){.shell{display:block}aside{position:static;height:auto}.project-mini,.side-foot{display:none}nav{grid-template-columns:repeat(3,1fr)}main{padding:20px}.hero{align-items:flex-start;padding:28px}.hero h2{font-size:35px}.progress-ring{width:115px;height:115px}.metrics,.split,.photo-grid{grid-template-columns:1fr 1fr}.phase-grid{overflow:auto}.risk-table article{grid-template-columns:80px 1fr}.risk-table article>strong{display:none}}@media(max-width:600px){header,.hero,.header-actions{align-items:stretch;flex-direction:column}.metrics,.split,.photo-grid{grid-template-columns:1fr}.progress-ring{margin-top:20px}nav{grid-template-columns:1fr 1fr}.hero-meta{gap:15px}.title-row h2{font-size:30px}}
/* Interactive overview refinements */
.metric{padding:20px;text-align:left;position:relative;transition:transform .16s,border-color .16s,box-shadow .16s}
.metric:hover{transform:translateY(-2px);border-color:#91b7ab;box-shadow:0 10px 25px rgba(18,63,53,.08)}
.metric span,.metric small{display:block}
.metric em{display:block;margin-top:13px;color:var(--teal);font-size:10px;font-style:normal;font-weight:800}
.metric.milestone{border-color:#e1a345;background:#fff9ef}
.metric.milestone strong,.metric.milestone small{color:#a25f08}
.row-button{width:100%;text-align:left;background:transparent;border:0}
.row-button:hover{background:var(--pale)}
.panel-head span{display:block;margin-top:4px}
.phase-list{display:grid;gap:9px}
.phase-card{width:100%;display:grid;grid-template-columns:95px minmax(250px,1fr) minmax(220px,.65fr);gap:18px;align-items:center;padding:16px;text-align:left;background:#fff;border:1px solid var(--line);border-radius:11px}
.phase-card:hover{border-color:#91b7ab;background:#f8fbf9}
.phase-number{padding-left:12px;border-left:5px solid var(--phase);font-size:11px;font-weight:900;text-transform:uppercase}
.phase-copy strong,.phase-copy small{display:block}
.phase-copy strong{font-size:16px}
.phase-copy small{margin-top:4px;color:var(--muted);font-size:11px}
.phase-dates{margin-top:7px;color:var(--green);font-size:10px;font-weight:800}
.phase-progress b,.phase-progress small{display:block}
.phase-progress b{font-size:20px}
.phase-progress span{display:block;height:7px;margin:7px 0;background:#e5ece9;border-radius:10px;overflow:hidden}
.phase-progress i{display:block;height:100%;border-radius:10px}
.phase-progress small{color:var(--muted);font-size:10px}
.modal{position:fixed;inset:0;z-index:50;display:none}
.modal.open{display:block}
.scrim{position:absolute;inset:0;background:rgba(10,25,20,.42);backdrop-filter:blur(3px)}
.drawer{position:absolute;top:10px;right:10px;bottom:10px;width:min(560px,calc(100% - 20px));height:auto;overflow:auto;padding:30px;background:#fff;border:0;border-radius:18px;box-shadow:0 25px 80px rgba(10,25,20,.24)}
.drawer h2{margin:25px 0 5px;font-size:30px}
.drawer>p{color:var(--muted)}
.drawer-close{float:right;padding:8px 11px;color:var(--green);background:var(--pale);border:0;border-radius:7px;font-weight:800}
.drawer-body{margin-top:24px}
.drawer-body .rows{max-height:none}
.detail-block{padding:18px;background:var(--pale);border-radius:12px}
.detail-block h4{margin:10px 0 5px}
.detail-block h4:first-child{margin-top:0}
.detail-block p{color:var(--muted);line-height:1.65}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.detail-grid div{padding:16px;background:var(--pale);border-radius:10px}
.detail-grid span,.detail-grid strong{display:block}
.detail-grid span{color:var(--muted);font-size:11px}
.detail-grid strong{margin-top:5px}
@media(max-width:900px){.phase-card{grid-template-columns:75px 1fr}.phase-progress{grid-column:2}}
@media(max-width:600px){.phase-card{grid-template-columns:1fr}.phase-progress{grid-column:1}.detail-grid{grid-template-columns:1fr}}
.project-brand{text-align:center}
.project-brand .logo{display:block;width:150px;margin:auto}
.project-brand strong{display:block;margin-top:5px;color:var(--green);font-size:12px;letter-spacing:.28em}
.programme-actions{display:flex;gap:9px;align-items:center}
.task-clickable{cursor:pointer}
.task-clickable:hover{background:#f7faf8}
.task-form{display:grid;gap:14px;margin-top:25px}
.task-form label{display:grid;gap:6px;color:var(--muted);font-size:11px;font-weight:800}
.task-form input,.task-form select,.task-form textarea{width:100%;padding:11px 12px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:8px;font:inherit}
.task-form textarea{resize:vertical}
.form-pair{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-buttons{display:flex;justify-content:space-between;gap:10px;margin-top:8px}
.delete-button{padding:10px 13px;color:var(--red);background:#fae9e7;border:0;border-radius:8px;font-weight:800}
@media(max-width:600px){.programme-actions,.form-buttons{align-items:stretch;flex-direction:column}.form-pair{grid-template-columns:1fr}}
.progress-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}
.progress-summary button{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;text-align:left;background:#fff;border:1px solid var(--line);border-radius:12px}
.progress-summary button.attention{color:var(--red);border-color:#e6aaa5;background:#fff6f5}
.progress-summary span{font-weight:750}.progress-summary strong{font-size:24px}
.progress-group{padding:0;overflow:hidden}.progress-group .panel-head{padding:18px 20px;margin:0;background:#f8faf9;border-bottom:1px solid var(--line)}
.progress-items{display:grid}.progress-item{display:grid;grid-template-columns:110px minmax(0,1fr) auto;gap:15px;align-items:center;padding:15px 20px;text-align:left;background:#fff;border:0;border-top:1px solid var(--line)}
.progress-item:first-child{border-top:0}.progress-item:hover{background:var(--pale)}.progress-item strong,.progress-item small{display:block}.progress-item small{margin-top:4px;color:var(--muted);font-size:11px}.progress-item p{margin:6px 0 0;color:var(--muted);font-size:11px}.progress-item em{color:var(--green);font-size:11px;font-style:normal;font-weight:800}
.live-status{display:inline-flex;justify-content:center;padding:5px 8px;border-radius:20px;font-size:9px;font-weight:900;text-transform:uppercase}.live-status.complete{color:#236b4c;background:#e0f2e8}.live-status.overdue{color:#a33e37;background:#fbe6e4}.live-status.on-programme{color:#116455;background:#def1eb}.live-status.upcoming{color:#65716c;background:#ebefed}
.empty-state{padding:25px;color:var(--muted);text-align:center;background:#f8faf9;border:1px dashed var(--line);border-radius:10px}
.phase-photo-list{display:grid;gap:14px}.photo-phase .panel-head strong{color:var(--green)}.photo-task-list{display:grid}.photo-task-row{display:grid;grid-template-columns:110px minmax(0,1fr) 45px 90px;gap:15px;align-items:center;width:100%;padding:13px 0;text-align:left;background:transparent;border:0;border-top:1px solid var(--line)}.photo-task-row:first-child{border-top:0}.photo-task-row:hover{background:var(--pale)}.photo-task-row strong,.photo-task-row small{display:block}.photo-task-row small{margin-top:3px;color:var(--muted);font-size:10px}.photo-task-row b{text-align:center;font-size:18px}.photo-task-row em{color:var(--green);font-size:10px;font-style:normal;font-weight:800}
.drawer-section-head{display:flex;align-items:center;justify-content:space-between;gap:15px;margin:24px 0 12px}.drawer-section-head h3,.drawer-section-head p{margin:0}.drawer-section-head p{margin-top:4px;color:var(--muted);font-size:11px}.drawer-section-head button{padding:8px 10px;color:var(--green);background:var(--pale);border:0;border-radius:7px;font-weight:800}
.photo-picker{display:grid;gap:18px}.photo-picker section{padding:15px;background:var(--pale);border-radius:10px}.photo-picker h3{margin-bottom:10px}.photo-picker button{display:flex;justify-content:space-between;gap:10px;width:100%;padding:10px;text-align:left;background:#fff;border:1px solid var(--line);border-radius:7px;margin-top:6px}.photo-picker button span{color:var(--muted);font-size:10px;white-space:nowrap}
@media(max-width:800px){.progress-summary{grid-template-columns:1fr 1fr}.progress-item,.photo-task-row{grid-template-columns:1fr}.progress-item em,.photo-task-row em{justify-self:start}.drawer-section-head{align-items:stretch;flex-direction:column}}
.gantt-row{grid-template-columns:360px 1fr 120px}
.gantt-actions{display:grid;gap:4px}
.gantt-actions button{padding:5px 7px}
.gantt-actions button:first-child{color:var(--muted);background:#fff;border:1px solid var(--line)}
.gantt-actions button.has-photos{color:var(--green);background:#def1eb;border-color:#b8dbd0}
.gantt-actions button:hover{border-color:#7ba99a}
.photo-upload-actions{display:flex;gap:7px;align-items:center}.camera-button{display:inline-flex;align-items:center;justify-content:center;padding:9px 11px;color:#fff;background:var(--teal);border-radius:7px;font-size:11px;font-weight:850;cursor:pointer}.camera-button input{display:none}.mobile-upload-note{margin:0 0 15px;padding:10px 12px;color:var(--green);background:var(--pale);border-radius:8px;font-size:10px}.photo-image{height:150px;background-size:cover;background-position:center;position:relative}.photo-image span{position:absolute;top:10px;left:10px;padding:5px 8px;border-radius:20px;background:#fff;color:var(--green);font-size:10px;font-weight:850}
.photo-preview{display:block;width:100%;padding:0;text-align:inherit;background:transparent;border:0;cursor:zoom-in}.photo-image{overflow:hidden}.photo-image:after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(5,25,20,.62));opacity:0;transition:opacity .18s}.photo-image em{position:absolute;right:12px;bottom:11px;z-index:1;color:#fff;font-size:10px;font-style:normal;font-weight:850;opacity:0;transform:translateY(4px);transition:opacity .18s,transform .18s}.photo-preview:hover .photo-image:after,.photo-preview:focus-visible .photo-image:after,.photo-preview:hover .photo-image em,.photo-preview:focus-visible .photo-image em{opacity:1}.photo-preview:hover .photo-image em,.photo-preview:focus-visible .photo-image em{transform:none}
.photo-lightbox{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:28px}.photo-lightbox-backdrop{position:absolute;inset:0;width:100%;background:rgba(4,17,14,.88);border:0;cursor:zoom-out}.photo-lightbox figure{position:relative;z-index:1;display:grid;grid-template-rows:minmax(0,1fr) auto;width:min(1200px,calc(100vw - 56px));height:min(900px,calc(100vh - 56px));margin:0;overflow:hidden;background:#fff;border-radius:16px;box-shadow:0 30px 90px rgba(0,0,0,.45)}.photo-lightbox img{width:100%;height:100%;min-height:0;object-fit:contain;background:#10231e}.photo-lightbox-close{position:absolute;top:14px;right:14px;z-index:2;padding:9px 12px;color:var(--green);background:#fff;border:0;border-radius:8px;font-weight:850;box-shadow:0 4px 15px rgba(0,0,0,.18)}.photo-lightbox figcaption{padding:15px 20px}.photo-lightbox figcaption strong,.photo-lightbox figcaption span{display:block}.photo-lightbox figcaption span,.photo-lightbox figcaption p{margin:4px 0 0;color:var(--muted);font-size:11px}
@media(max-width:600px){.photo-upload-actions{align-items:stretch;flex-direction:column}.camera-button{min-height:48px;font-size:13px}.drawer{top:0;right:0;bottom:0;width:100%;border-radius:0}.gantt-actions{grid-template-columns:1fr 1fr}.gantt-row{grid-template-columns:1fr;gap:8px}.gantt-row .track{min-height:24px}}
@media(max-width:600px){.photo-image:after,.photo-image em{opacity:1}.photo-image em{transform:none}.photo-lightbox{padding:0}.photo-lightbox figure{width:100vw;height:100vh;border-radius:0}.photo-lightbox img{touch-action:pinch-zoom}.photo-lightbox figcaption{padding:13px 15px}}
.risk-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}.risk-summary-card{display:flex;gap:13px;align-items:center;padding:17px;background:#fff;border:1px solid var(--line);border-radius:12px}.risk-summary-card i,.risk-symbol{display:grid;place-items:center;border-radius:50%;font-style:normal;font-weight:900}.risk-summary-card i{width:35px;height:35px}.risk-summary-card span,.risk-summary-card strong{display:block}.risk-summary-card span{color:var(--muted);font-size:10px}.risk-summary-card strong{margin-top:2px;font-size:23px}.risk-summary-card.hard-gate i,.risk-badge.hard-gate,.risk-symbol{color:#8c5215;background:#ffebcb}.risk-summary-card.high-risk i,.risk-badge.high-risk,.risk-card.high-risk .risk-symbol{color:#a23a34;background:#fbe3e1}.risk-summary-card.medium-risk i,.risk-badge.medium-risk,.risk-card.medium-risk .risk-symbol{color:#87651f;background:#f8edce}.risk-summary-card.removed i,.risk-badge.removed,.risk-card.removed .risk-symbol{color:#276a4d;background:#dff2e8}.risk-list{padding:0;overflow:hidden}.risk-list>.panel-head{padding:19px 20px;margin:0;background:#f8faf9}.risk-card{display:grid;grid-template-columns:42px minmax(0,1fr) auto;gap:16px;padding:20px;border-top:1px solid var(--line);border-left:4px solid #d8e1dd}.risk-card.hard-gate{border-left-color:#d58a2d}.risk-card.high-risk{border-left-color:#cc5c54}.risk-card.medium-risk{border-left-color:#c2a04b}.risk-card.removed{border-left-color:#55a17c;background:#f7fbf9}.risk-symbol{width:34px;height:34px}.risk-card-top{display:flex;gap:10px;align-items:center}.risk-card-top small{color:var(--muted)}.risk-badge{display:inline-flex;padding:5px 8px;border-radius:20px;font-size:9px;font-weight:900;text-transform:uppercase}.risk-card h3{margin:9px 0 5px}.risk-card p{margin:0;color:var(--muted);font-size:12px}.risk-control,.resolution-note{margin-top:12px;padding:10px 12px;background:var(--pale);border-radius:8px;font-size:11px}.risk-control b,.risk-control span{display:block}.risk-control span{margin-top:3px;color:var(--muted)}.resolution-note{color:#276a4d;background:#e5f5ec}.risk-actions{display:grid;gap:6px;align-content:start}.risk-actions button{padding:8px 10px;color:var(--green);background:var(--pale);border:0;border-radius:7px;font-size:10px;font-weight:800}.risk-actions button.resolve{color:#276a4d;background:#dff2e8}.removed-list{margin-top:14px}
@media(max-width:850px){.risk-summary{grid-template-columns:1fr 1fr}.risk-card{grid-template-columns:35px 1fr}.risk-actions{grid-column:2;display:flex;flex-wrap:wrap}}@media(max-width:500px){.risk-summary{grid-template-columns:1fr}.risk-card{padding:15px}}
.risk-filter-bar{display:grid;grid-template-columns:.65fr repeat(4,1fr);gap:10px;margin-bottom:14px}.risk-filter-bar button{cursor:pointer;text-align:left}.risk-filter-bar button:hover,.risk-filter-bar button.selected{transform:translateY(-2px);border-color:#75a697;box-shadow:0 8px 22px rgba(18,63,53,.1)}.risk-filter-bar button.selected{outline:2px solid var(--green);outline-offset:1px}.all-filter{display:flex;align-items:center;justify-content:space-between;padding:17px;background:var(--green);color:#fff;border:1px solid var(--green);border-radius:12px}.all-filter span{font-weight:850}.all-filter strong{font-size:23px}.risk-summary-card{font:inherit}
@media(max-width:1000px){.risk-filter-bar{grid-template-columns:repeat(3,1fr)}}@media(max-width:600px){.risk-filter-bar{grid-template-columns:1fr 1fr}}
.document-access-note{display:flex;gap:15px;align-items:center;padding:15px 18px;margin-bottom:14px;color:var(--green);background:var(--pale);border-radius:11px}.document-access-note span{color:var(--muted);font-size:11px}.document-folders{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.folder-card{display:grid;grid-template-columns:48px 1fr auto;gap:15px;align-items:center;padding:20px;text-align:left;background:#fff;border:1px solid var(--line);border-radius:13px}.folder-card:hover{border-color:#75a697;background:#f9fbfa}.folder-card>span{display:grid;place-items:center;width:45px;height:45px;color:#fff;background:var(--green);border-radius:10px;font-weight:900}.folder-card h3{margin:0}.folder-card p{margin:6px 0;color:var(--muted);font-size:11px}.folder-card small{color:var(--green);font-weight:800}.folder-card b{color:var(--green);font-size:11px}.folder-toolbar{display:grid;grid-template-columns:auto 1fr auto;gap:17px;align-items:center;margin-bottom:14px;padding:16px;background:#fff;border:1px solid var(--line);border-radius:12px}.folder-toolbar button{padding:9px 11px;color:var(--green);background:var(--pale);border:0;border-radius:7px;font-weight:800}.folder-toolbar h3,.folder-toolbar p{margin:0}.folder-toolbar p{margin-top:4px;color:var(--muted);font-size:11px}.document-list{padding:0;overflow:hidden}.document-row{display:grid;grid-template-columns:46px 1fr auto;gap:15px;align-items:center;padding:16px 20px;border-top:1px solid var(--line)}.document-row:first-child{border-top:0}.document-row>span{padding:7px;color:#fff;background:var(--green);border-radius:6px;text-align:center;font-size:9px;font-weight:900}.document-row strong,.document-row small{display:block}.document-row small{margin-top:4px;color:var(--muted);font-size:10px}.document-row>button{padding:7px 9px;color:var(--green);background:var(--pale);border:0;border-radius:7px;font-weight:800}.document-upload-notice{display:grid;gap:4px;padding:13px;color:var(--green);background:var(--pale);border-radius:9px}.document-upload-notice span{color:var(--muted);font-size:11px}
@media(max-width:800px){.document-folders{grid-template-columns:1fr}.folder-toolbar,.document-row{grid-template-columns:1fr}}
.login-screen{min-height:100vh;display:grid;place-items:center;padding:30px;background:linear-gradient(135deg,#f7faf8 0%,#e7f0ec 100%)}.login-card{width:min(1050px,100%);min-height:610px;display:grid;grid-template-columns:.95fr 1.05fr;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:0 30px 80px rgba(18,63,53,.14)}.login-brand{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:55px;color:#fff;text-align:center;background:var(--green)}.login-brand img{width:210px;filter:brightness(0) invert(1)}.login-brand strong{margin-top:10px;font-size:15px;letter-spacing:.4em}.login-brand span{margin-top:28px;color:#c8d9d3;font-size:13px}.login-form{display:flex;flex-direction:column;justify-content:center;padding:65px}.login-kicker{color:var(--teal);font-size:11px;font-weight:850;text-transform:uppercase;letter-spacing:.12em}.login-form h1{margin:14px 0 12px;font-size:42px;line-height:1.08}.login-form>p{color:var(--muted);line-height:1.55}.login-form form{display:grid;gap:13px;margin-top:22px}.login-form label{display:grid;gap:7px;color:var(--muted);font-size:11px;font-weight:800}.login-form input{padding:13px;border:1px solid var(--line);border-radius:9px;font:inherit}.login-message{min-height:20px;margin:12px 0 0;color:var(--muted);font-size:11px}.login-message.error{color:var(--red)}.login-message.success{color:#277458}.portal-user{display:grid;gap:3px;margin-top:auto;padding:13px;background:var(--pale);border-radius:10px}.portal-user strong{font-size:12px}.portal-user span{color:var(--muted);font-size:10px}.portal-user button{margin-top:7px;padding:6px;text-align:left;color:var(--green);background:transparent;border:0;font-weight:800}.access-pill{padding:9px 12px;color:var(--green);background:var(--pale);border-radius:20px;font-size:11px;font-weight:850}.user-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:14px}.user-summary>div{padding:18px;background:#fff;border:1px solid var(--line);border-radius:12px}.user-summary span,.user-summary strong{display:block}.user-summary span{color:var(--muted);font-size:11px}.user-summary strong{margin-top:7px;font-size:25px}.user-list{padding:0;overflow:hidden}.user-list>.panel-head{padding:18px 20px;margin:0;background:#f8faf9}.user-list article{display:grid;grid-template-columns:38px 1fr auto;gap:13px;align-items:center;padding:15px 20px;border-top:1px solid var(--line)}.user-avatar{display:grid;place-items:center;width:36px;height:36px;color:#fff;background:var(--green);border-radius:50%;font-weight:850}.user-list strong,.user-list small{display:block}.user-list small{margin-top:3px;color:var(--muted);font-size:10px}.user-role{padding:6px 9px;color:var(--green);background:var(--pale);border-radius:20px;font-size:9px;font-weight:850;text-transform:uppercase}.user-role.primary-admin{color:#875915;background:#fff0d8}
.login-secondary{padding:9px;color:var(--green);background:transparent;border:0;font-weight:800}
@media(max-width:800px){.login-card{grid-template-columns:1fr}.login-brand{padding:35px}.login-brand img{width:140px}.login-form{padding:35px}.login-form h1{font-size:32px}.user-summary{grid-template-columns:1fr}.portal-user{margin-top:15px}}
