@import url('https://fonts.googleapis.com/css2?family=Merriweather:wght@400;700&family=Poppins:wght@400;500;600;700&display=swap');
:root{
  --bg:#f6f7fb;
  --panel:#ffffff;
  --ink:#1f2937;
  --muted:#6b7280;
  --line:#d9dee8;
  --brand:#30415f;
  --brand-2:#4c6388;
  --danger:#9f2f2f;
  --ok:#24704f;
  --warn:#9a6a12;
  --soft:#eef2f8;
  --radius:7px;
  --shadow:0 8px 24px rgba(25,35,55,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Poppins,Inter,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.5;
  font-size:15px;
}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1180px;margin:0 auto;padding:22px}
.topbar{
  background:#fff;border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:10;
}
.nav{max-width:1180px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:12px 22px;gap:18px}
.brand{font-weight:700;letter-spacing:.2px;color:var(--ink);font-size:18px}
.navlinks{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.navlinks a{color:var(--muted);font-weight:500;font-size:14px}.navlinks a:hover{color:var(--ink);text-decoration:none}
.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin:10px 0 18px}.page-head h1{margin:0;font-size:28px;letter-spacing:-.4px}.page-head p{margin:5px 0 0;color:var(--muted)}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:18px}
.panel.slim{padding:14px}.muted{color:var(--muted)}.small{font-size:13px}.right{text-align:right}.hidden{display:none!important}
.grid{display:grid;gap:14px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px}.stat strong{display:block;font-size:25px}.stat span{color:var(--muted);font-size:13px}
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:#fff}table{border-collapse:collapse;width:100%;min-width:760px}th,td{padding:11px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}th{background:#f1f4f9;color:#445066;font-size:12px;text-transform:uppercase;letter-spacing:.04em}tr:last-child td{border-bottom:0}.actions{display:flex;gap:8px;flex-wrap:wrap}
.btn,button,input[type=submit]{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--brand);color:#fff;border:1px solid var(--brand);border-radius:6px;padding:9px 12px;font-weight:600;font-size:14px;cursor:pointer;text-decoration:none;line-height:1.2}.btn:hover,button:hover,input[type=submit]:hover{background:var(--brand-2);text-decoration:none;color:#fff}.btn.secondary{background:#fff;color:var(--brand);border-color:var(--line)}.btn.secondary:hover{background:var(--soft);color:var(--brand)}.btn.danger{background:#fff;color:var(--danger);border-color:#e0b9b9}.btn.danger:hover{background:#fff2f2}.btn.smallbtn{padding:6px 9px;font-size:12px}
label{display:block;font-weight:600;font-size:13px;color:#374151}input,select,textarea{width:100%;margin-top:6px;border:1px solid #cfd6e2;border-radius:6px;padding:10px 11px;background:#fff;color:var(--ink);font:inherit}textarea{min-height:120px;resize:vertical}input:focus,select:focus,textarea:focus{outline:2px solid rgba(48,65,95,.18);border-color:var(--brand)}.help{font-size:12px;color:var(--muted);margin-top:5px}.form-actions{display:flex;gap:10px;align-items:center;margin-top:16px;flex-wrap:wrap}.compact-row{padding:10px;border:1px solid var(--line);border-radius:6px;background:#fbfcff;margin-bottom:10px}
.flash{padding:12px 14px;border-radius:6px;margin-bottom:14px;border:1px solid}.flash.ok{background:#eef8f3;color:#155b3e;border-color:#bbdfcd}.flash.err{background:#fff1f1;color:#872525;border-color:#efc7c7}.flash.info{background:#eef4ff;color:#27456f;border-color:#c7d6ef}
.badge{display:inline-block;border:1px solid var(--line);background:#f7f8fb;border-radius:6px;padding:3px 8px;font-size:12px;color:#3b4558}.badge.ok{background:#edf8f2;color:var(--ok);border-color:#c6e4d4}.badge.warn{background:#fff8e8;color:var(--warn);border-color:#ead7a3}.badge.danger{background:#fff0f0;color:var(--danger);border-color:#edc4c4}.badge.gray{background:#f2f3f5;color:#596070}.kv{display:grid;grid-template-columns:220px 1fr;gap:8px 14px}.kv div:nth-child(odd){color:var(--muted);font-weight:600}.auth-wrap{max-width:440px;margin:50px auto}.auth-logo{text-align:center;margin-bottom:18px}.auth-logo h1{margin:0;font-size:30px}.auth-logo p{margin:6px 0 0;color:var(--muted)}
.notice{border-left:4px solid var(--brand);padding:12px 14px;background:#f0f4fb;border-radius:0 6px 6px 0;color:#344054}.empty{padding:30px;text-align:center;color:var(--muted);background:#fff;border:1px dashed #cbd5e1;border-radius:6px}.split{display:flex;justify-content:space-between;gap:12px;align-items:center}.client-identity{font-family:Merriweather,Georgia,serif;font-size:22px}
@media (max-width:800px){.container{padding:14px}.nav{padding:12px 14px;align-items:flex-start;flex-direction:column}.page-head{flex-direction:column}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.kv{grid-template-columns:1fr}.kv div:nth-child(even){padding-bottom:10px}.panel{padding:15px}.auth-wrap{margin:22px auto}.page-head h1{font-size:24px}}

/* Client portal layout refresh */

body{background:linear-gradient(180deg,#f7f9fd 0%,#f3f5f9 48%,#eef2f7 100%)}
body.modal-open{overflow:hidden}
.brand{font-family:Merriweather,Georgia,serif;font-weight:700;letter-spacing:.1px}.brand:hover{text-decoration:none}.navlinks a{display:inline-flex;align-items:center;gap:5px}
button i,.btn i,.eyebrow i,.project-meta i{font-size:1.1em;line-height:1}.btn,button,input[type=submit]{transition:transform .16s ease,box-shadow .16s ease,background .16s ease,border-color .16s ease}.btn:hover,button:hover,input[type=submit]:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(34,48,75,.13)}.btn.glow{box-shadow:0 10px 24px rgba(48,65,95,.18)}.btn.glow:hover{box-shadow:0 13px 28px rgba(48,65,95,.25)}

.client-hero,.project-hero{position:relative;overflow:hidden;display:flex;justify-content:space-between;align-items:flex-end;gap:24px;background:linear-gradient(135deg,#fff 0%,#f5f8fc 62%,#edf3fb 100%);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);padding:28px;margin-bottom:18px}.client-hero:after,.project-hero:after{content:"";position:absolute;right:-70px;top:-90px;width:260px;height:260px;border:1px solid rgba(48,65,95,.10);border-radius:50%;background:radial-gradient(circle,rgba(48,65,95,.08),transparent 62%);pointer-events:none}.client-hero h1,.project-hero h1{font-family:Merriweather,Georgia,serif;font-size:34px;letter-spacing:-.5px;margin:8px 0}.client-hero p{max-width:650px;color:var(--muted);margin:0}.hero-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:flex-end;position:relative;z-index:1}.eyebrow{display:inline-flex;align-items:center;gap:7px;color:var(--brand);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.back-link{display:inline-flex;align-items:center;gap:3px;color:var(--muted);font-size:13px;margin-bottom:8px}.metric-row{margin:0 0 18px}.icon-stat{position:relative;overflow:hidden}.icon-stat>i{position:absolute;right:14px;top:14px;font-size:30px;color:#d2dae7}.icon-stat strong{font-family:Merriweather,Georgia,serif}

.section-title{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:16px}.section-title h2{font-size:22px;letter-spacing:-.2px;margin:4px 0 0}.section-title p{margin:5px 0 0}.project-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.project-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:17px;min-height:205px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 6px 16px rgba(35,48,73,.05);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.project-card:hover{transform:translateY(-3px);border-color:#c4cfdd;box-shadow:0 14px 28px rgba(35,48,73,.10)}.project-card-top,.record-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.project-icon{width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:#f0f4fa;border:1px solid #dfe6f0;border-radius:7px;color:var(--brand);font-size:22px}.project-card h3{font-family:Merriweather,Georgia,serif;font-size:19px;line-height:1.35;margin:18px 0 10px}.project-meta{display:flex;flex-direction:column;gap:7px;color:var(--muted);font-size:13px}.project-meta span{display:flex;align-items:center;gap:7px}.project-meta.big{flex-direction:row;flex-wrap:wrap;margin-top:10px}.project-card-actions{margin-top:16px}.project-card-actions .btn{width:100%}

.project-detail-grid{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:18px;align-items:stretch}.side-panel{align-self:stretch}.stack-actions{display:grid;gap:9px;margin-top:14px}.stack-actions .btn{justify-content:flex-start}.detail-card-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.detail-tile{background:#f9fbfe;border:1px solid var(--line);border-radius:7px;padding:14px;min-height:120px}.detail-tile i{font-size:25px;color:var(--brand);display:block;margin-bottom:12px}.detail-tile span{display:block;color:var(--muted);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.detail-tile strong{display:block;margin-top:5px;font-size:17px}.clean-kv{display:grid;gap:10px}.clean-kv>div{display:grid;grid-template-columns:220px 1fr;gap:14px;padding:12px 0;border-bottom:1px solid var(--line)}.clean-kv>div:last-child{border-bottom:0}.clean-kv span{color:var(--muted);font-size:13px;font-weight:700}.clean-kv strong{font-weight:500;white-space:pre-wrap}.clean-kv.mini>div{grid-template-columns:110px 1fr;padding:8px 0}.breakdown-list{display:grid;gap:10px}.breakdown-item{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;background:#fbfcff;border:1px solid var(--line);border-radius:7px;padding:14px}.breakdown-item p{margin:4px 0 0;color:var(--muted)}.breakdown-item span{font-weight:700;color:var(--brand);white-space:nowrap}.record-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.record-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:16px;box-shadow:0 6px 16px rgba(35,48,73,.05)}.record-card h3{font-family:Merriweather,Georgia,serif;margin:14px 0 8px;font-size:18px}.record-card-head>i{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:7px;background:#f0f4fa;color:var(--brand);font-size:21px}.empty i{font-size:28px;color:#b9c4d3;margin-bottom:7px}

.modal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:20px}.modal.is-open{display:flex}.modal-backdrop{position:absolute;inset:0;background:rgba(17,24,39,.50);backdrop-filter:blur(3px)}.modal-card{position:relative;z-index:1;width:min(760px,100%);max-height:90vh;overflow:auto;background:#fff;border:1px solid #d9dee8;border-radius:8px;box-shadow:0 24px 70px rgba(11,18,32,.30);padding:20px;animation:modalIn .18s ease-out}.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:16px}.modal-head h2{font-family:Merriweather,Georgia,serif;margin:4px 0 0}.icon-btn{width:36px;height:36px;padding:0;background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:6px;font-size:24px}.icon-btn:hover{background:#f5f7fb;color:var(--ink)}.client-form{margin:0}.client-form textarea{min-height:110px}

.reveal{animation:fadeLift .34s ease both}.project-card.reveal:nth-child(2){animation-delay:.04s}.project-card.reveal:nth-child(3){animation-delay:.08s}.project-card.reveal:nth-child(4){animation-delay:.12s}.project-card.reveal:nth-child(5){animation-delay:.16s}.project-card.reveal:nth-child(6){animation-delay:.20s}@keyframes fadeLift{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes modalIn{from{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}

@media (max-width:1000px){.project-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.project-detail-grid{grid-template-columns:1fr}.detail-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.record-card-grid{grid-template-columns:1fr}.client-hero,.project-hero{align-items:flex-start;flex-direction:column}.hero-actions{justify-content:flex-start}}
@media (max-width:650px){.section-title{flex-direction:column}.project-card-grid,.detail-card-grid{grid-template-columns:1fr}.clean-kv>div,.clean-kv.mini>div{grid-template-columns:1fr;gap:4px}.client-hero h1,.project-hero h1{font-size:28px}.hero-actions,.hero-actions .btn,.section-title .btn{width:100%}.modal{padding:12px}.modal-card{padding:16px}.project-meta.big{flex-direction:column}.breakdown-item{flex-direction:column}.breakdown-item span{white-space:normal}}
