@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600;700&display=swap');

:root {
    --bg:#F5F7F5; --bg-card:#FFFFFF; --bg-card-hover:#F0F4F1; --bg-input:#FFFFFF;
    --border:#D4DDD7; --border-focus:#5B9A6B;
    --accent:#3D7A4A; --accent-dim:#5B9A6B; --accent-bright:#2D6B3A;
    --text:#1A2B1E; --text-dim:#4A6B54; --text-muted:#7A9A84;
    --danger:#D4574B; --danger-bg:#FFF0EF; --warm:#B8922E; --warm-bg:#FFF8EC;
    --font:'DM Sans','Segoe UI',system-ui,sans-serif;
    --mono:'JetBrains Mono','Fira Code',monospace;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased}
#app{min-height:100vh;display:flex;flex-direction:column}
a{color:var(--accent);text-decoration:none}

/* Header */
.header{display:flex;align-items:center;justify-content:space-between;padding:14px 28px;border-bottom:1px solid var(--border);background:var(--bg-card);position:sticky;top:0;z-index:100}
.header-brand{display:flex;align-items:center;gap:12px;cursor:pointer}
.header-brand .logo{font-size:24px}
.header-brand .name{font-size:18px;font-weight:800;letter-spacing:-0.02em}
.header-brand .ver{font-size:11px;color:var(--text-muted);font-family:var(--mono)}
.header-nav{display:flex;gap:6px;align-items:center}
.header-user{font-size:13px;color:var(--text-dim);margin-left:16px;padding-left:16px;border-left:1px solid var(--border)}

/* Buttons */
.btn{padding:10px 24px;border-radius:10px;border:none;cursor:pointer;font-size:14px;font-weight:700;font-family:var(--font);transition:all .2s;display:inline-flex;align-items:center;gap:8px}
.btn-primary{background:var(--accent);color:var(--bg)} .btn-primary:hover{background:var(--accent-bright)}
.btn-secondary{background:transparent;border:1px solid var(--border);color:var(--text-dim)} .btn-secondary:hover{border-color:var(--accent-dim);color:var(--text)}
.btn-sm{padding:7px 14px;font-size:12px}
.btn-ghost{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px 8px;font-size:14px} .btn-ghost:hover{color:var(--text)}
.nav-btn{padding:7px 16px;border-radius:8px;border:none;cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font);background:transparent;color:var(--text-dim);transition:all .2s}
.nav-btn:hover{background:#3D7A4A22;color:var(--text)} .nav-btn.active{background:#3D7A4A44;color:var(--accent-bright)} .nav-btn:disabled{color:var(--text-muted);cursor:default}

/* Inputs */
.input,.select,.textarea{width:100%;padding:10px 14px;background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:8px;font-size:14px;font-family:var(--font);outline:none;transition:border-color .2s}
.input:focus,.select:focus,.textarea:focus{border-color:var(--border-focus)}
.textarea{resize:vertical;min-height:72px} .select{cursor:pointer}
.field-group{margin-bottom:20px}
.field-label{display:block;margin-bottom:6px;font-size:13.5px;font-weight:500;color:var(--text);line-height:1.4}
.field-label .req{color:var(--danger);margin-left:4px}
.field-label .ref{margin-left:8px;font-size:11px;color:var(--text-muted);font-family:var(--mono)}

/* Yes/No */
.yesno-group{display:flex;gap:10px}
.yesno-btn{flex:1;padding:10px 0;border:1.5px solid var(--border);border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font);background:transparent;color:var(--text-dim);transition:all .2s}
.yesno-btn.active{border-color:var(--accent);background:#3D7A4A33;color:var(--accent-bright)}

/* Multicheck */
.mc-group{display:flex;flex-wrap:wrap;gap:8px}
.mc-btn{padding:8px 16px;border:1.5px solid var(--border);border-radius:8px;cursor:pointer;font-size:13px;font-family:var(--font);font-weight:500;background:transparent;color:var(--text-dim);transition:all .2s}
.mc-btn.active{border-color:var(--accent);background:#3D7A4A33;color:var(--accent-bright)}

/* Divider */
.section-divider{margin:28px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.section-divider span{font-size:13px;font-weight:700;color:var(--accent-bright);letter-spacing:.06em;text-transform:uppercase;font-family:var(--mono)}

/* Badge */
.badge{display:inline-block;padding:2px 10px;border-radius:99px;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-family:var(--mono)}
.badge-ok{color:var(--accent);background:#3D7A4A22;border:1px solid #6BBF7B33}
.badge-wip{color:var(--warm);background:var(--warm-bg);border:1px solid #D4A44B33}
.badge-new{color:var(--danger);background:var(--danger-bg);border:1px solid #D4574B33}

/* Card */
.card{background:var(--bg-card);border-radius:14px;padding:24px;border:1px solid var(--border)}
.card-hover{transition:all .2s} .card-hover:hover{border-color:var(--accent-dim);background:var(--bg-card-hover);cursor:pointer}

/* Progress bar */
.pbar{height:4px;border-radius:2px;background:var(--border);overflow:hidden;margin-top:10px}
.pbar-fill{height:100%;border-radius:2px;background:var(--accent);transition:width .4s ease}

/* Layout */
.list-wrap{max-width:900px;margin:0 auto;padding:40px 28px}
.list-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}
.list-head h2{font-size:26px;font-weight:800}
.list-empty{text-align:center;padding:60px;color:var(--text-muted)}
.list-empty .ico{font-size:48px;margin-bottom:16px}

.wizard{display:flex;flex:1;overflow:hidden}
.sidebar{width:270px;min-width:270px;border-right:1px solid var(--border);background:var(--bg-card);overflow-y:auto;padding:20px 0}
.sb-summary{padding:0 20px 16px;border-bottom:1px solid var(--border);margin-bottom:12px}
.sb-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 20px;border:none;cursor:pointer;background:transparent;border-left:3px solid transparent;transition:all .15s;text-align:left}
.sb-item:hover{background:#3D7A4A11}
.sb-item.active{background:#3D7A4A22;border-left-color:var(--accent)}
.sb-item .ico{font-size:16px;width:24px;text-align:center}
.sb-item .lbl{font-size:13px;font-weight:500;color:var(--text-dim);flex:1}
.sb-item.active .lbl{font-weight:700;color:var(--text)}
.sb-item .pct{font-size:10px;font-family:var(--mono);font-weight:600;color:var(--text-muted)}

.main-content{flex:1;overflow-y:auto;padding:32px 48px 80px}
.main-inner{max-width:680px;margin:0 auto}
.sec-head{display:flex;align-items:center;gap:14px;margin-bottom:8px}
.sec-head .ico{font-size:32px}
.sec-head .step{font-size:11px;color:var(--text-muted);font-family:var(--mono);font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.sec-head h2{font-size:22px;font-weight:800;margin-top:2px}
.sep{height:1px;background:var(--border);margin:20px 0 28px}
.wiz-nav{display:flex;justify-content:space-between;margin-top:36px;padding-top:20px;border-top:1px solid var(--border)}

/* Review */
.review-wrap{max-width:800px;margin:0 auto;padding:32px 28px 80px}
.review-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;flex-wrap:wrap;gap:16px}
.review-sec{margin-bottom:16px}
.review-row{display:flex;justify-content:space-between;align-items:baseline;padding:6px 0;border-bottom:1px solid #2A403022}
.review-q{font-size:13px;color:var(--text-dim);flex:1;margin-right:12px}
.review-a{font-size:13px;color:var(--text);font-weight:500;max-width:55%;text-align:right;word-break:break-word}
.review-a.empty{color:var(--text-muted);font-weight:400}

/* Dashboard */
.dash-wrap{max-width:900px;margin:0 auto;padding:32px 28px 80px}
.dash-grid{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:28px}
.dash-card{background:var(--bg-card);border-radius:14px;padding:20px 22px;border:1px solid var(--border);min-width:160;flex:1}
.dash-card .lbl{font-size:11px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-family:var(--mono)}
.dash-card .val{font-size:28px;font-weight:800;color:var(--accent-bright);font-family:var(--mono)}
.dash-card .sub{font-size:12px;color:var(--text-dim);margin-top:4px}
.indicator-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.indicator{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:8px;background:var(--bg-input)}
.indicator .lbl{font-size:13px;color:var(--text-dim)}
.indicator .val{font-size:12px;font-weight:700;font-family:var(--mono)}
.indicator .val.yes{color:var(--accent)} .indicator .val.no{color:var(--danger)} .indicator .val.na{color:var(--text-muted)}
.sec-bar-row{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.sec-bar-row .ico{font-size:14px;width:24px;text-align:center}
.sec-bar-row .lbl{font-size:13px;color:var(--text-dim);width:180px;flex-shrink:0}
.sec-bar{flex:1;height:6px;border-radius:3px;background:var(--border);overflow:hidden}
.sec-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}
.sec-bar-pct{font-size:11px;font-family:var(--mono);font-weight:600;color:var(--text-dim);width:36px;text-align:right}

/* Login */
.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}
.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:48px 40px;width:100%;max-width:400px;text-align:center}
.login-card .logo{font-size:48px;margin-bottom:16px}
.login-card h1{font-size:24px;font-weight:800;margin-bottom:4px}
.login-card .sub{color:var(--text-dim);font-size:14px;margin-bottom:32px}
.login-card .field{margin-bottom:16px;text-align:left}
.login-card .field label{display:block;font-size:13px;font-weight:600;color:var(--text-dim);margin-bottom:6px}
.login-err{background:var(--danger-bg);border:1px solid var(--danger);color:var(--danger);padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:16px}

/* Responsive */
@media(max-width:768px){
    .sidebar{display:none}
    .main-content{padding:20px 16px 60px}
    .header{padding:12px 16px}
    .indicator-grid{grid-template-columns:1fr}
    .dash-grid{flex-direction:column}
}

/* Animations */
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeIn .3s ease}

/* ─── List Table Styles (Effort 1 — add to end of app.css) ─── */

table tbody tr { transition: background .15s; }
table tbody tr:hover { background: var(--bg-card-hover); }
table tbody td { padding: 12px 12px; border-bottom: 1px solid var(--border); font-size: 14px; }
table thead th { white-space: nowrap; }

/* Card grid responsive */
@media(max-width:900px) {
    div[style*="grid-template-columns:repeat(3"] {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}
@media(max-width:600px) {
    div[style*="grid-template-columns:repeat(3"],
    div[style*="grid-template-columns:repeat(2"] {
        grid-template-columns: 1fr !important;
    }
}


/* ═══════════════════════════════════════════════════════════════
   Urban Wood Potentials — Dashboard Styles
   ═══════════════════════════════════════════════════════════════ */

.uwp-page { max-width:1100px; margin:24px auto; padding:0 24px; }
.uwp-container {
    background:var(--bg-card); border-radius:16px; border:1px solid var(--border);
    position:relative; overflow:hidden;
}
.uwp-city-label {
    position:absolute; left:0; top:0; bottom:0; width:56px;
    background:#3c5a11; display:flex; align-items:center; justify-content:center;
}
.uwp-city-name {
    writing-mode:vertical-lr; transform:rotate(180deg);
    font-size:26px; font-weight:800; letter-spacing:0.12em;
    color:#fff; text-transform:uppercase; white-space:nowrap;
}
.uwp-state {
    position:absolute; top:16px; font-size:11px; font-weight:700;
    color:rgba(255,255,255,0.6); writing-mode:vertical-lr;
    transform:rotate(180deg); letter-spacing:0.08em;
}
.uwp-body { margin-left:76px; padding:32px 36px 24px; }

.uwp-header { display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:24px; }
.uwp-title-block {}
.uwp-subtitle {
    font-size:10px; font-weight:700; letter-spacing:0.14em;
    text-transform:uppercase; color:var(--text-muted); font-family:var(--mono);
}
.uwp-title {
    font-size:22px; font-weight:800; letter-spacing:0.04em;
    color:var(--text); text-transform:uppercase; margin-top:2px;
}

.uwp-banner {
    display:flex; align-items:center; justify-content:space-between;
    background:#3c5a11; border-radius:12px; padding:16px 28px;
    margin-bottom:24px; color:#fff;
}
.uwp-banner-label {
    font-size:12px; font-weight:600; letter-spacing:0.1em;
    text-transform:uppercase; opacity:0.8;
}
.uwp-banner-value { font-size:32px; font-weight:800; font-family:var(--mono); }

.uwp-flow {
    display:grid; grid-template-columns:1fr 1fr 1fr;
    gap:20px; margin-bottom:20px;
}
.uwp-metric {
    background:var(--bg); border:1px solid var(--border); border-radius:14px;
    padding:24px; text-align:center; transition:all 0.2s;
}
.uwp-metric:hover { border-color:#3c5a11; box-shadow:0 4px 20px rgba(60,90,17,0.08); }
.uwp-metric-value { font-size:36px; font-weight:800; line-height:1.1; margin-bottom:2px; }
.uwp-metric-label {
    font-size:13px; font-weight:600; color:var(--text-muted);
    text-transform:uppercase; letter-spacing:0.06em;
}
.uwp-green { color:#3c5a11; }
.uwp-gold { color:#B8922E; }

.uwp-hub { display:grid; grid-template-columns:1fr 1fr 1fr; gap:20px; margin-top:20px; margin-bottom:24px; }
.uwp-hub-card {
    background:linear-gradient(135deg, var(--bg) 0%, var(--bg-card-hover) 100%);
    border:2px solid #3c5a11; border-radius:16px; padding:28px 20px;
    text-align:center; display:flex; flex-direction:column; align-items:center;
}
.uwp-hub-value { font-size:42px; font-weight:800; color:#3c5a11; }
.uwp-hub-label {
    font-size:14px; color:#4a7030; font-weight:700;
    text-transform:uppercase; letter-spacing:0.06em;
}
.uwp-carbon-line {
    margin-top:auto; padding-top:12px; font-size:13px;
    font-weight:700; letter-spacing:0.06em; text-transform:uppercase;
    color:#B8922E; white-space:nowrap;
}

.uwp-info-bar {
    display:grid; grid-template-columns:1fr 1fr 1fr 1fr; gap:16px;
    padding-top:20px; border-top:1px solid var(--border);
}
.uwp-info-item { font-size:12px; line-height:1.4; }
.uwp-info-label {
    font-family:var(--mono); font-size:10px; font-weight:700;
    letter-spacing:0.1em; text-transform:uppercase; color:var(--text-muted);
}
.uwp-info-value { font-weight:600; color:var(--text-dim); }

/* ─── Print Styles ───────────────────────────────────────────── */
@media print {
    body { background:#fff !important; padding:0 !important; }
    .header, .no-print { display:none !important; }
    .uwp-page { margin:0; padding:0; max-width:100%; }
    .uwp-container { border:none; border-radius:0; box-shadow:none; }
    .uwp-metric:hover { box-shadow:none; border-color:var(--border); }
    @page { margin:0.5in; size:landscape; }
}
