/* ===== RESET + BASE ===== */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'DM Sans',system-ui,-apple-system,sans-serif;
  background:#F1ECDF;color:#1A2535;font-size:14px;line-height:1.5;
  -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(at 12% 8%, rgba(166,90,58,.05) 0, transparent 55%),
    radial-gradient(at 88% 92%, rgba(26,37,53,.05) 0, transparent 55%);
  min-height:100vh;
}
button{font-family:inherit;font-size:inherit;background:none;border:none;padding:0;cursor:pointer;color:inherit}
input,select,textarea{font-family:inherit;font-size:inherit}
table{border-collapse:collapse}
h1,h2,h3,h4,h5,h6,p,ul,ol{margin:0;padding:0;font-weight:inherit}
ul,ol{list-style:none}
a{color:inherit;text-decoration:none;cursor:pointer}
.font-display{font-family:'Fraunces',Georgia,serif;font-optical-sizing:auto;font-weight:500}
.hidden{display:none !important}
.muted{color:var(--muted)}

/* ===== TOKENS — North Star brand ===== */
:root{
  --primary:#1A2535;        /* deep navy */
  --primary-dark:#0F1A28;
  --accent:#A65A3A;         /* terracotta */
  --accent-soft:#C97A55;    /* lighter terracotta for hover */
  --accent-dark:#7E4129;
  --sage:#E2DDCB;           /* warm beige (sage-replacement) */
  --sage-soft:#EBE6D5;
  --cream:#F1ECDF;          /* page bg */
  --ink:#1A2535;
  --muted:#6E6A5C;
  --border:#D6CFBC;
  --success:#4F8A6B;
  --warning:#C58A2D;
  --danger:#B0523F;
  --info:#3B5980;
  --star:#F6E9D6;
}

/* ===== TOPNAV ===== */
.topnav{
  background:#1A2535;color:#fff;position:sticky;top:0;z-index:40;
  box-shadow:0 1px 3px rgba(0,0,0,.18);
  background-image:
    radial-gradient(circle at 18% 60%, rgba(201,122,85,.18) 0, transparent 38%),
    radial-gradient(circle at 80% 40%, rgba(246,233,214,.08) 0, transparent 30%),
    radial-gradient(1px 1px at 22% 30%, rgba(255,255,255,.6) 50%, transparent 51%),
    radial-gradient(1px 1px at 64% 70%, rgba(255,255,255,.5) 50%, transparent 51%),
    radial-gradient(1px 1px at 88% 25%, rgba(255,255,255,.45) 50%, transparent 51%);
}
.topnav-inner{max-width:1280px;margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:24px}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{width:34px;height:34px;flex-shrink:0;background:#F1ECDF;border-radius:50%;padding:3px;display:flex;align-items:center;justify-content:center}
.brand-mark img,.brand-mark svg{width:100%;height:100%;display:block}
.brand-name{font-family:'Fraunces',serif;font-size:15px;color:#fff;letter-spacing:.28em;text-transform:uppercase;font-weight:500}
.nav-links{display:flex;gap:6px;flex:1}
.nav-link{padding:8px 14px;border-radius:999px;color:rgba(255,255,255,.75);font-size:14px;cursor:pointer;transition:background .15s, color .15s}
.nav-link:hover{background:rgba(255,255,255,.1);color:#fff}
.nav-link.active{background:rgba(255,255,255,.18);color:#fff;font-weight:500}
.topnav-right{display:flex;align-items:center;gap:10px}
.user-chip{font-size:12px;background:rgba(255,255,255,.12);padding:5px 10px;border-radius:999px;color:rgba(255,255,255,.85)}
.btn-ghost{color:rgba(255,255,255,.75);padding:6px 10px;border-radius:6px;font-size:13px}
.btn-ghost:hover{background:rgba(255,255,255,.1);color:#fff}
.mobile-toggle{display:none;color:#fff;padding:6px}
@media (max-width:860px){
  .nav-links{display:none;position:absolute;top:64px;left:0;right:0;background:var(--primary);flex-direction:column;padding:12px;border-top:1px solid rgba(255,255,255,.15)}
  .nav-links.open{display:flex}
  .mobile-toggle{display:block}
  .user-chip{display:none}
}

/* ===== VIEW ROOT ===== */
.view-root{max-width:1280px;margin:0 auto;padding:32px 24px}
@media (max-width:640px){.view-root{padding:20px 16px}}

/* ===== TYPOGRAPHY ===== */
.page-title{font-family:'Fraunces',serif;font-size:36px;font-weight:500;color:var(--primary);line-height:1.1;letter-spacing:-.01em}
.page-title.italic{font-style:italic;color:var(--accent)}
@media (max-width:640px){.page-title{font-size:28px}}
.page-sub{color:var(--muted);font-size:14px;margin-top:4px}
.section-title{font-family:'Fraunces',serif;font-size:18px;font-weight:500}
.label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}
.uppercase-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}

/* ===== CARD ===== */
.card{background:#FFFCF6;border:1px solid var(--border);border-radius:14px;box-shadow:0 1px 3px rgba(26,37,53,.04)}
.card.warm{background:var(--sage-soft)}
.card.terracotta{background:var(--accent);color:#FFF8EE;border-color:transparent}
.card.terracotta .card-header,.card.terracotta .card-body{color:#FFF8EE}
.card-header{padding:18px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-body{padding:20px}
.card-pad-sm{padding:14px 16px}

/* ===== BUTTONS ===== */
.btn-primary{background:var(--accent);color:#FFF8EE;padding:9px 18px;border-radius:999px;font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:6px;transition:background .15s}
.btn-primary:hover{background:var(--accent-dark)}
.btn-navy{background:var(--primary);color:#fff;padding:9px 18px;border-radius:999px;font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:6px}
.btn-navy:hover{background:var(--primary-dark)}
.btn-secondary{background:#FFFCF6;color:var(--ink);padding:8px 14px;border:1px solid var(--border);border-radius:999px;font-size:13px;display:inline-flex;align-items:center;gap:6px}
.btn-secondary:hover{background:var(--sage)}
.btn-danger{background:#FFFCF6;color:var(--danger);padding:8px 14px;border:1px solid #E5BBB1;border-radius:999px;font-size:13px}
.btn-block{width:100%;justify-content:center}
.btn-link{color:var(--accent);font-size:13px;text-decoration:underline;cursor:pointer}
.btn-link:hover{color:var(--accent-dark)}

/* ===== FORM ===== */
input[type="text"],input[type="email"],input[type="password"],input[type="number"],input[type="date"],input[type="tel"],select,textarea{
  width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--ink);outline:none;transition:border-color .15s}
input:focus,select:focus,textarea:focus{border-color:var(--primary)}
textarea{resize:vertical;min-height:80px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row.cols-1{grid-template-columns:1fr}
.form-row.cols-3{grid-template-columns:1fr 1fr 1fr}
@media (max-width:640px){.form-row,.form-row.cols-3{grid-template-columns:1fr}}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.form-error{color:var(--danger);font-size:12px;margin-top:6px;min-height:1em}
.helper{font-size:12px;color:var(--muted);margin-top:4px}

/* ===== PILLS / BADGES ===== */
.pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:500;line-height:1.6}
.pill-sage{background:var(--sage);color:var(--muted)}
/* phase chips */
.phase-discovery{background:#CFE5E2;color:#2C6E66}
.phase-design{background:#E5DDF1;color:#5B4A8C}
.phase-build{background:#DCE7F3;color:#2F5E8C}
.phase-test{background:#F5E5C0;color:#8C6A1F}
.phase-launch{background:#D5EBC9;color:#3B7A2F}
.phase-support{background:#E5E5DD;color:#6E7A6F}
/* deal stages */
.stage-lead{background:#E8EDE6;color:#6E7A6F}
.stage-qualified{background:#DCE7F3;color:#2F5E8C}
.stage-proposing{background:#F2D9C4;color:#9C5A26}
.stage-negotiating{background:#F5E5C0;color:#8C6A1F}
.stage-won{background:#D5EBC9;color:#3B7A2F}
.stage-lost{background:#F4D2D2;color:#A03333}
.stage-on_hold{background:#E5E5DD;color:#6E7A6F}
/* task statuses */
.status-backlog{background:#E8EDE6;color:#6E7A6F}
.status-todo{background:#DCE7F3;color:#2F5E8C}
.status-doing{background:#F5E5C0;color:#8C6A1F}
.status-blocked{background:#F4D2D2;color:#A03333}
.status-done{background:#D5EBC9;color:#3B7A2F}
/* lifecycle */
.lc-idea{background:#E8EDE6;color:#6E7A6F}
.lc-in_development{background:#DCE7F3;color:#2F5E8C}
.lc-live{background:#D5EBC9;color:#3B7A2F}
.lc-sunset{background:#E5E5DD;color:#6E7A6F}
/* type chips */
.type-custom{background:#DCE7F3;color:#2F5E8C}
.type-saas{background:#E5DDF1;color:#5B4A8C}
.type-both{background:#F2D9C4;color:#9C5A26}

/* ===== STATS ===== */
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:24px}
.stat{background:#fff;border:1px solid var(--border);border-radius:14px;padding:16px 18px;cursor:pointer;transition:box-shadow .15s, transform .15s}
.stat:hover{box-shadow:0 4px 10px rgba(0,0,0,.06);transform:translateY(-1px)}
.stat-num{font-family:'Fraunces',serif;font-size:30px;font-weight:500;color:var(--accent);line-height:1}
.stat-label{font-size:12px;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.06em}

/* ===== KANBAN ===== */
.kanban{display:grid;grid-template-columns:repeat(7,minmax(220px,1fr));gap:12px;overflow-x:auto;padding-bottom:8px}
@media (max-width:1100px){.kanban{grid-template-columns:repeat(4,260px)}}
.kanban-col{background:rgba(255,252,246,.7);border:1px solid var(--border);border-radius:14px;min-height:300px;display:flex;flex-direction:column}
.kanban-col-head{padding:10px 14px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.kanban-col-head .count{background:var(--sage);color:var(--muted);font-size:11px;padding:1px 8px;border-radius:999px}
.kanban-col-body{padding:10px;display:flex;flex-direction:column;gap:10px;flex:1}
.kanban-col.drop-target{background:rgba(166,90,58,.06);border-color:var(--accent)}
.deal-card{background:#FFFCF6;border:1px solid var(--border);border-radius:10px;padding:12px;cursor:pointer;transition:box-shadow .15s}
.deal-card:hover{box-shadow:0 3px 8px rgba(0,0,0,.08)}
.deal-card .name{font-weight:500;font-size:13px;color:var(--ink);line-height:1.35}
.deal-card .sub{font-size:12px;color:var(--muted);margin-top:3px}
.deal-card .row{display:flex;justify-content:space-between;align-items:center;margin-top:10px}

/* ===== TABLE ===== */
.tbl{width:100%;font-size:14px}
.tbl th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:600;padding:10px 14px;background:rgba(232,237,230,.4)}
.tbl td{padding:11px 14px;border-top:1px solid var(--border);vertical-align:middle}
.tbl tbody tr:hover{background:rgba(250,249,244,.6);cursor:pointer}
.tbl-flat td{border:none;padding:8px 12px}

/* ===== MATRIX ===== */
.matrix-table{width:100%;font-size:14px}
.matrix-table th{padding:10px 12px;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);background:rgba(250,249,244,.5);text-align:right;font-weight:600}
.matrix-table th:first-child{text-align:left}
.matrix-table th .rate{display:block;font-size:10px;color:var(--muted);text-transform:none;letter-spacing:0;font-weight:400;margin-top:2px}
.matrix-table td{padding:8px 10px;border-top:1px solid var(--border)}
.matrix-table td input{width:100%;text-align:right;padding:6px 8px;border:1px solid transparent;background:transparent;border-radius:6px}
.matrix-table td input:focus{border-color:var(--primary);background:#fff}
.matrix-table .subtotal{text-align:right;font-weight:500;background:rgba(232,237,230,.3)}
.matrix-table tfoot td,.matrix-table .totals-row td{background:rgba(232,237,230,.55);font-weight:600;text-align:right;font-size:13px;color:var(--ink)}
.matrix-table .totals-row td:first-child{text-align:left;text-transform:uppercase;font-size:11px;letter-spacing:.06em;color:var(--muted)}
.matrix-table .grand{font-family:'Fraunces',serif;font-size:16px;color:var(--accent)}

/* ===== COSTING SUMMARY ===== */
.cost-summary{background:#fff;border:1px solid var(--border);border-radius:14px;padding:20px;position:sticky;top:88px}
.cost-line{display:flex;justify-content:space-between;padding:6px 0;font-size:13px}
.cost-line.total{border-top:1px solid var(--border);margin-top:8px;padding-top:10px;font-weight:600}
.cost-line.fee{border-top:2px solid var(--accent);margin-top:10px;padding-top:12px;font-family:'Fraunces',serif;font-size:18px;color:var(--accent)}
.cost-line .label{margin:0;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em}
.cost-line .val{font-variant-numeric:tabular-nums}

/* ===== PHASE BOARD (project detail) ===== */
.phase-board{display:flex;flex-direction:column;gap:16px}
.phase-section{background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden}
.phase-section-head{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.phase-section-head .meta{font-size:12px;color:var(--muted)}
.phase-section-head .meta .var-good{color:var(--success)}
.phase-section-head .meta .var-bad{color:var(--danger)}
.task-cols{display:grid;grid-template-columns:repeat(5,minmax(160px,1fr));gap:0;}
@media (max-width:900px){.task-cols{grid-template-columns:repeat(2,1fr)}}
.task-col{padding:10px;border-right:1px solid var(--border);min-height:100px}
.task-col:last-child{border-right:none}
.task-col-head{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600;padding:6px 4px;display:flex;justify-content:space-between}
.task-card{background:#fff;border:1px solid var(--border);border-radius:8px;padding:9px 11px;margin-bottom:8px;cursor:pointer;transition:box-shadow .15s}
.task-card:hover{box-shadow:0 2px 6px rgba(0,0,0,.06)}
.task-card .title{font-size:13px;font-weight:500;color:var(--ink);line-height:1.35}
.task-card .row{display:flex;align-items:center;justify-content:space-between;margin-top:6px;font-size:11px;color:var(--muted)}

/* ===== CAPACITY BAR ===== */
.cap-bar{height:8px;background:var(--sage);border-radius:999px;overflow:hidden;margin-top:6px}
.cap-bar > div{height:100%;border-radius:999px;transition:width .3s}
.cap-good{background:var(--success)}
.cap-warn{background:var(--warning)}
.cap-over{background:var(--danger)}
.cap-row{margin-bottom:14px}
.cap-row .top{display:flex;justify-content:space-between;font-size:13px}
.cap-row .lbl{color:var(--ink);font-weight:500}
.cap-row .val{color:var(--muted);font-size:12px}

/* ===== TABS ===== */
.tabs{display:flex;gap:24px;border-bottom:1px solid var(--border);margin-bottom:24px;overflow-x:auto}
.tab{padding:10px 0;font-size:14px;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--accent);font-weight:600;border-bottom-color:var(--accent)}

/* ===== MODAL ===== */
.modal-backdrop{position:fixed;inset:0;background:rgba(26,37,32,.42);display:flex;align-items:center;justify-content:center;z-index:60;padding:20px;animation:fadein .15s ease}
.modal{background:#fff;border-radius:16px;max-width:640px;width:100%;max-height:90vh;overflow:auto;box-shadow:0 20px 50px rgba(0,0,0,.18);animation:popin .18s ease}
.modal-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:#fff;border-radius:16px 16px 0 0}
.modal-title{font-family:'Fraunces',serif;font-size:22px;font-weight:500}
.modal-body{padding:22px}
.modal-foot{padding:16px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;background:rgba(250,249,244,.6);position:sticky;bottom:0;border-radius:0 0 16px 16px}
.close-x{color:var(--muted);font-size:22px;line-height:1;padding:4px 10px;border-radius:8px}
.close-x:hover{background:var(--sage);color:var(--ink)}
@keyframes fadein{from{opacity:0}to{opacity:1}}
@keyframes popin{from{opacity:0;transform:scale(.96) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}

/* ===== TOAST ===== */
#toast-root{position:fixed;bottom:24px;right:24px;z-index:80;display:flex;flex-direction:column;gap:8px}
.toast{background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px 16px;box-shadow:0 6px 18px rgba(0,0,0,.1);font-size:13px;animation:popin .2s ease;max-width:340px}
.toast.success{border-left:4px solid var(--success)}
.toast.error{border-left:4px solid var(--danger)}

/* ===== EMPTY STATE ===== */
.empty{padding:36px 20px;text-align:center;color:var(--muted);font-size:13px}

/* ===== LOGIN ===== */
.login-overlay{
  position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  z-index:90;padding:20px;color:#FFF8EE;
  background:
    radial-gradient(ellipse at 18% 70%, rgba(201,122,85,.45) 0, transparent 45%),
    radial-gradient(ellipse at 82% 30%, rgba(166,90,58,.18) 0, transparent 50%),
    radial-gradient(1px 1px at 12% 18%, rgba(255,255,255,.7) 50%, transparent 51%),
    radial-gradient(1px 1px at 28% 62%, rgba(255,255,255,.55) 50%, transparent 51%),
    radial-gradient(1px 1px at 47% 28%, rgba(255,255,255,.6) 50%, transparent 51%),
    radial-gradient(1.5px 1.5px at 71% 18%, rgba(255,255,255,.85) 50%, transparent 51%),
    radial-gradient(1px 1px at 84% 78%, rgba(255,255,255,.6) 50%, transparent 51%),
    radial-gradient(1px 1px at 92% 42%, rgba(255,255,255,.5) 50%, transparent 51%),
    linear-gradient(135deg, #0F1A28 0%, #1A2535 50%, #2B2030 100%);
}
.login-overlay::before,.login-overlay::after{
  content:"";position:absolute;background:url("icons/sparkle.svg") center/contain no-repeat;opacity:.7;pointer-events:none;
}
.login-overlay::before{ width:90px;height:90px;top:14%;right:18%; }
.login-overlay::after{ width:60px;height:60px;bottom:18%;left:12%; opacity:.5;}
.login-card{background:rgba(255,252,246,.97);border:1px solid var(--border);border-radius:18px;padding:40px 36px;max-width:420px;width:100%;box-shadow:0 18px 50px rgba(0,0,0,.35);text-align:center;color:var(--ink);position:relative;z-index:1}
.login-card form{text-align:left}
.login-card label{color:var(--muted)}
.login-logo{width:88px;height:88px;margin:0 auto 18px;display:block}
.login-title{font-family:'Fraunces',serif;font-size:30px;color:var(--primary);margin-bottom:4px;letter-spacing:.18em;text-transform:uppercase;font-weight:500}
.login-tagline{font-family:'Fraunces',serif;font-style:italic;font-size:13px;color:var(--accent);margin-bottom:22px}
.login-sub{color:var(--muted);margin-bottom:24px;font-size:13px}
.login-hint{margin-top:20px;font-size:11px;color:var(--muted)}
.login-card label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px;margin-top:14px}
.login-hint{margin-top:18px;font-size:11px;color:var(--muted)}
.login-hint code{background:var(--sage);padding:1px 5px;border-radius:4px;font-size:11px}

/* ===== UTIL ===== */
.row{display:flex;align-items:center;gap:10px}
.row.between{justify-content:space-between}
.row.wrap{flex-wrap:wrap}
.spacer{flex:1}
.divider{height:1px;background:var(--border);margin:14px 0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
@media (max-width:740px){.grid-2,.grid-3{grid-template-columns:1fr}}
.text-right{text-align:right}
.text-success{color:var(--success)}
.text-danger{color:var(--danger)}
.text-warn{color:var(--warning)}
.text-primary{color:var(--primary)}
.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}
.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}
.tabular{font-variant-numeric:tabular-nums}
.avatar{width:24px;height:24px;border-radius:50%;background:var(--accent);color:var(--primary-dark);font-size:10px;font-weight:600;display:inline-flex;align-items:center;justify-content:center}

/* progress strip */
.phase-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;margin:10px 0}
.phase-strip .seg{height:6px;background:var(--sage);border-radius:3px;overflow:hidden;position:relative}
.phase-strip .seg .fill{height:100%;background:var(--accent)}

/* settings sub-nav */
.subnav{display:flex;gap:6px;margin-bottom:18px;flex-wrap:wrap}
.subnav a{padding:6px 12px;border-radius:999px;font-size:13px;color:var(--muted);cursor:pointer}
.subnav a.active{background:var(--sage);color:var(--ink);font-weight:500}
.subnav a:hover{background:var(--sage)}
