/* ══════════════════════════════════════════════
   Solar Alternatives Dashboard — Master Stylesheet
   Extracted from original index.html + new dashboard styles
   ══════════════════════════════════════════════ */

/* ── RESET & BASE ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Open Sans',sans-serif;background:#f4f8fa;color:#333432;min-height:100vh;-webkit-font-smoothing:antialiased}

:root{
  --teal:#317c8f;--teal2:#59b7c2;--light-teal:#daeef4;
  --dark-blue:#18305c;--mid-blue:#00669c;
  --yellow:#ffcb05;--orange:#f47920;
  --dark-grey:#333432;--grey:#5b666c;--white:#ffffff;--off-white:#f4f8fa;
  --border:#d0e8ef;--chart-bg:#2a2d2b;
}

/* ── HEADER ── */
.site-header{background:var(--dark-blue);height:70px;display:flex;align-items:center;justify-content:space-between;padding:0 40px;box-shadow:0 3px 14px rgba(24,48,92,.22);position:sticky;top:0;z-index:100}
.logo-wrap{display:flex;align-items:center}
.logo-img{height:112px;width:auto;max-width:400px;object-fit:contain;-webkit-user-drag:none;user-select:none;pointer-events:none}
.logo-link{display:flex;align-items:center;cursor:pointer;text-decoration:none;pointer-events:auto}
.logo-fallback{display:flex;align-items:center;gap:12px}
.logo-sun{width:42px;height:42px;background:var(--yellow);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px}
.logo-copy{line-height:1}
.logo-name{font-family:'Montserrat',sans-serif;font-weight:800;font-size:21px;color:var(--white);letter-spacing:1px}
.logo-tag{font-family:'Montserrat',sans-serif;font-weight:600;font-size:11px;color:var(--teal2);letter-spacing:3px;text-transform:uppercase}
.header-right{display:flex;align-items:center;gap:12px}
.header-pill{background:var(--teal);color:var(--white);font-family:'Montserrat',sans-serif;font-weight:700;font-size:10px;letter-spacing:2px;text-transform:uppercase;padding:7px 16px;border-radius:99px;white-space:nowrap}
.header-nav-link{color:rgba(255,255,255,.7);font-family:'Montserrat',sans-serif;font-weight:700;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;text-decoration:none;padding:6px 12px;border-radius:6px;transition:all .2s}
.header-nav-link:hover{color:var(--white);background:rgba(255,255,255,.1)}
.header-nav-link.admin-link{color:var(--yellow)}
.header-nav-link.admin-link:hover{background:rgba(255,203,5,.15)}
.logout-btn{background:transparent;border:2px solid rgba(255,255,255,.2);border-radius:99px;color:rgba(255,255,255,.7);font-family:'Montserrat',sans-serif;font-weight:700;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;padding:6px 14px;cursor:pointer;transition:all .2s;white-space:nowrap;text-decoration:none}
.logout-btn:hover{border-color:var(--orange);color:var(--white);background:rgba(244,121,32,.15)}

/* ── SCROLL TO TOP FAB ── */
#scrollTopBtn{position:fixed;bottom:28px;right:28px;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--teal) 0%,var(--dark-blue) 100%);border:2px solid rgba(89,183,194,.45);color:var(--white);font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(49,124,143,.4);opacity:0;transform:translateY(16px) scale(.85);transition:opacity .3s ease,transform .3s ease,box-shadow .25s ease;pointer-events:none;z-index:9990}
#scrollTopBtn.visible{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
#scrollTopBtn:hover{background:linear-gradient(135deg,var(--teal2) 0%,var(--teal) 100%);box-shadow:0 8px 26px rgba(89,183,194,.55);transform:translateY(-2px) scale(1.05)}

/* ── HERO ── */
.hero{background:linear-gradient(130deg,var(--teal) 0%,var(--mid-blue) 100%);padding:52px 40px 48px;color:var(--white);text-align:center}
.hero h1{font-family:'Montserrat',sans-serif;font-weight:800;font-size:28px;letter-spacing:.3px;margin-bottom:12px}
.hero p{font-size:15px;line-height:1.75;opacity:.88;max-width:660px;margin:0 auto}

/* ── LAYOUT ── */
.page-wrap{max-width:1040px;margin:0 auto;padding:36px 24px 100px}

/* ── CARD ── */
.card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:30px 34px;margin-bottom:26px;box-shadow:0 2px 10px rgba(49,124,143,.08);transition:box-shadow .3s ease,transform .3s ease}
.card:hover{box-shadow:0 8px 32px rgba(49,124,143,.14);transform:translateY(-2px)}
.card-title{font-family:'Montserrat',sans-serif;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:2.5px;color:var(--teal);margin-bottom:22px;display:flex;align-items:center;gap:10px}
.card-title::after{content:'';flex:1;height:2px;background:var(--light-teal)}

/* ── FORM ── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.full{grid-column:1/-1}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--grey)}
.input-wrap{position:relative}
.input-prefix{position:absolute;left:13px;top:50%;transform:translateY(-50%);font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;color:var(--teal);pointer-events:none}
.input-suffix{position:absolute;right:13px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--grey);pointer-events:none}
input[type="number"],input[type="text"],input[type="email"],input[type="password"],select{width:100%;border:2px solid var(--border);border-radius:9px;background:#fafcfd;color:var(--dark-grey);font-family:'Montserrat',sans-serif;font-weight:600;font-size:16px;padding:13px 13px 13px 34px;outline:none;transition:border-color .22s ease,box-shadow .22s ease,background .22s ease;-moz-appearance:textfield;appearance:none}
input[type="number"]::-webkit-inner-spin-button{-webkit-appearance:none}
input[type="number"]:focus,input[type="text"]:focus,input[type="email"]:focus,input[type="password"]:focus,select:focus{border-color:var(--teal);box-shadow:0 0 0 4px rgba(49,124,143,.14),0 2px 8px rgba(49,124,143,.1);background:var(--white)}
select{padding-left:13px;cursor:pointer}
input[type="file"]{font-family:'Open Sans',sans-serif;font-size:14px;padding:10px;border:2px solid var(--border);border-radius:9px;background:#fafcfd;cursor:pointer;width:100%}
.info-box{background:var(--light-teal);border-left:4px solid var(--teal2);border-radius:0 9px 9px 0;padding:13px 18px;font-size:13px;color:var(--dark-blue);line-height:1.7}
.info-box strong{color:var(--teal)}

/* ── GENERATE BUTTON ── */
.generate-btn{margin-top:26px;width:100%;background:linear-gradient(135deg,var(--yellow) 0%,#ffd93d 100%);border:none;border-radius:9px;color:var(--dark-blue);font-family:'Montserrat',sans-serif;font-weight:800;font-size:14px;letter-spacing:2px;text-transform:uppercase;padding:18px 24px;cursor:pointer;transition:background .22s ease,transform .18s ease,box-shadow .22s ease;box-shadow:0 4px 20px rgba(255,203,5,.42);display:flex;align-items:center;justify-content:center;gap:10px;position:relative;overflow:hidden}
.generate-btn::after{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.25) 50%,transparent 70%);transform:translateX(-100%);transition:transform .5s ease}
.generate-btn:hover::after{transform:translateX(100%)}
.generate-btn:hover{background:linear-gradient(135deg,var(--orange) 0%,#ff9a3c 100%);color:var(--white);transform:translateY(-3px);box-shadow:0 10px 30px rgba(244,121,32,.42)}
.generate-btn:active{transform:translateY(-1px);box-shadow:0 4px 14px rgba(244,121,32,.3)}

/* ── SUMMARY CARDS ── */
.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:26px}
.sum-card{background:var(--white);border-radius:13px;padding:22px 20px;position:relative;overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,.07);border:1px solid var(--border);transition:box-shadow .28s ease,transform .28s ease}
.sum-card:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(0,0,0,.1)}
.sum-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px}
.sum-card.utility::before{background:var(--orange)}
.sum-card.solar::before{background:var(--teal)}
.sum-card.savings::before{background:var(--yellow)}
.sum-card.utility:hover{box-shadow:0 10px 30px rgba(244,121,32,.18)}
.sum-card.solar:hover{box-shadow:0 10px 30px rgba(49,124,143,.18)}
.sum-card.savings:hover{box-shadow:0 10px 30px rgba(255,203,5,.18)}
.sum-label{font-family:'Montserrat',sans-serif;font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--grey);margin-bottom:10px}
.sum-value{font-family:'Montserrat',sans-serif;font-weight:800;font-size:32px;line-height:1}
.sum-value.orange{color:var(--orange)}
.sum-value.teal{color:var(--teal)}
.sum-value.navy{color:var(--dark-blue)}
.sum-sub{font-size:12px;color:var(--grey);margin-top:8px;line-height:1.5}
.sum-sub b{color:var(--teal)}

/* ── RESULTS ── */
.results-section{display:none}
.results-section.visible{display:block;animation:fadeUp .5s cubic-bezier(.22,1,.36,1) both}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

/* ── EXPORT BAR ── */
.export-bar{background:linear-gradient(135deg,#18305c 0%,#1e4a7a 100%);border:1px solid rgba(89,183,194,.2);border-radius:14px;padding:20px 28px;margin-bottom:26px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;transition:box-shadow .3s,border-color .3s}
.export-bar:hover{box-shadow:0 8px 28px rgba(49,124,143,.22);border-color:rgba(89,183,194,.45)}
.export-bar-label{font-family:'Montserrat',sans-serif;font-weight:700;font-size:13px;color:var(--white)}
.export-bar-label span{color:var(--teal2);font-size:12px;font-weight:400;margin-left:6px;font-family:'Open Sans',sans-serif}
.export-btn{background:linear-gradient(135deg,var(--yellow) 0%,#ffd93d 100%);border:none;border-radius:8px;color:var(--dark-blue);font-family:'Montserrat',sans-serif;font-weight:800;font-size:13px;letter-spacing:1px;text-transform:uppercase;padding:12px 24px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .22s,transform .18s,box-shadow .22s;box-shadow:0 3px 14px rgba(255,203,5,.35);position:relative;overflow:hidden}
.export-btn::after{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.22) 50%,transparent 70%);transform:translateX(-100%);transition:transform .45s}
.export-btn:hover::after{transform:translateX(100%)}
.export-btn:hover{background:linear-gradient(135deg,var(--orange) 0%,#ff9a3c 100%);color:var(--white);transform:translateY(-2px);box-shadow:0 8px 24px rgba(244,121,32,.42)}

/* ── NET METERING ── */
.nm-toggle-wrap{grid-column:1/-1;background:var(--dark-blue);border-radius:12px;padding:20px 24px;display:flex;flex-direction:column;gap:14px}
.nm-toggle-label{font-family:'Montserrat',sans-serif;font-weight:800;font-size:13px;color:var(--yellow);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.nm-toggle-label span{font-weight:400;color:rgba(255,255,255,.7);font-size:12px;text-transform:none;letter-spacing:0;font-family:'Open Sans',sans-serif;margin-left:8px}
.parish-btns{display:flex;gap:10px;flex-wrap:wrap}
.parish-btn{padding:10px 20px;border-radius:8px;border:2px solid rgba(255,255,255,.15);background:rgba(255,255,255,.07);color:rgba(255,255,255,.65);font-family:'Montserrat',sans-serif;font-weight:700;font-size:12px;cursor:pointer;transition:all .22s cubic-bezier(.4,0,.2,1);letter-spacing:.5px}
.parish-btn:hover{border-color:var(--teal2);color:var(--white);background:rgba(89,183,194,.15);transform:translateY(-1px);box-shadow:0 4px 14px rgba(89,183,194,.2)}
.parish-btn.active-orleans{background:var(--teal);border-color:var(--teal2);color:var(--white)}
.parish-btn.active-gulf{background:rgba(244,121,32,.25);border-color:var(--orange);color:var(--white)}
.parish-btn.active-none{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.4);color:var(--white)}
.parish-info{display:none;border-radius:8px;padding:14px 18px;font-size:13px;line-height:1.7}
.parish-info.visible{display:block}
.parish-info.orleans-style{background:rgba(89,183,194,.12);border:1px solid rgba(89,183,194,.3);color:#daeef4}
.parish-info.gulf-style{background:rgba(244,121,32,.1);border:1px solid rgba(244,121,32,.3);color:#ffe0c0}
.parish-info.none-style{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.8)}
.parish-info strong{color:var(--yellow)}
.nm-rate-badge{display:inline-block;background:var(--yellow);color:var(--dark-blue);font-family:'Montserrat',sans-serif;font-weight:800;font-size:13px;padding:3px 10px;border-radius:4px;margin:0 3px}
.nm-impact{display:none;background:linear-gradient(135deg,rgba(49,124,143,.12),rgba(89,183,194,.08));border:2px solid var(--teal2);border-radius:13px;padding:20px 24px;margin-bottom:26px}
.nm-impact.gulf-warning{background:linear-gradient(135deg,rgba(244,121,32,.08),rgba(255,100,0,.04));border-color:var(--orange)}
.nm-impact.gulf-warning h4{color:var(--orange)}
.nm-impact.gulf-warning .nm-stat .val{color:var(--orange)}
.nm-impact.visible{display:block}
.nm-arrow{font-size:10px;margin-right:8px;color:var(--teal2);transition:transform .3s;display:inline-block}
.nm-impact h4{font-family:'Montserrat',sans-serif;font-weight:800;font-size:13px;color:var(--teal);text-transform:uppercase;letter-spacing:1px;margin-bottom:0;cursor:pointer;display:flex;align-items:center;user-select:none}
.nm-impact.open .nm-arrow{transform:rotate(180deg)}
.nm-impact-content{display:none;margin-top:14px}
.nm-impact.open .nm-impact-content{display:block}
.nm-impact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:14px}
.nm-stat{text-align:center}
.nm-stat .val{font-family:'Montserrat',sans-serif;font-weight:800;font-size:26px;color:var(--dark-blue)}
.nm-stat .lbl{font-size:11px;color:var(--grey);margin-top:4px}
.nm-note{font-size:12px;color:var(--grey);line-height:1.65;border-top:1px solid var(--border);padding-top:12px}

/* ── CHART ── */
.chart-container{background:var(--chart-bg);border-radius:10px;padding:22px 22px 16px;margin-top:6px}
.chart-legend{display:flex;gap:22px;flex-wrap:wrap;margin-bottom:16px}
.legend-item{display:flex;align-items:center;gap:8px;font-family:'Montserrat',sans-serif;font-weight:600;font-size:11px;color:#d0d8d6}
.legend-line{width:22px;height:4px;border-radius:2px;flex-shrink:0}
.chart-wrap{position:relative}
canvas{display:block;width:100%!important;border-radius:6px}
.chart-tooltip{position:absolute;background:#1c201e;border:1px solid rgba(89,183,194,.4);border-radius:10px;padding:11px 15px;font-size:12px;font-family:'Open Sans',sans-serif;color:#e8eeed;pointer-events:none;display:none;z-index:30;min-width:180px;line-height:2;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.tt-year{font-family:'Montserrat',sans-serif;font-weight:700;font-size:13px;color:var(--yellow);margin-bottom:2px}
.chart-fs-btn{position:absolute;right:0;top:50%;transform:translateY(-50%);background:rgba(49,124,143,.12);border:2px solid var(--teal2);border-radius:8px;color:var(--teal);font-size:16px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,color .2s,transform .2s;line-height:1}
.chart-fs-btn:hover{background:var(--teal);color:var(--white);transform:translateY(-50%) scale(1.1)}
#chartFullscreenOverlay{display:none;position:fixed;inset:0;background:#1a1d1b;z-index:9995;flex-direction:column;padding:20px}
#chartFullscreenOverlay.open{display:flex}
.chart-fs-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-shrink:0}
.chart-fs-title{font-family:'Montserrat',sans-serif;font-weight:800;font-size:15px;color:var(--teal2);text-transform:uppercase;letter-spacing:1.5px}
.chart-fs-close{background:rgba(244,121,32,.15);border:2px solid var(--orange);border-radius:8px;color:var(--orange);font-size:20px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,color .2s}
.chart-fs-close:hover{background:var(--orange);color:var(--white)}
.chart-fs-body{flex:1;display:flex;align-items:center;justify-content:center;min-height:0}
.chart-fs-body canvas{width:100%!important;max-height:calc(100vh - 120px);border-radius:8px}

/* ── DRIVERS ── */
.drivers-box{background:linear-gradient(135deg,#18305c 0%,#1e4075 100%);border-radius:14px;padding:30px 34px;margin-bottom:26px;color:var(--white)}
.drivers-box h3{font-family:'Montserrat',sans-serif;font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:1.5px;color:var(--yellow);margin-bottom:20px}
.drivers-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.driver-item{padding:16px 18px;background:rgba(255,255,255,.07);border-radius:10px;border-left:3px solid var(--orange);transition:background .22s,transform .22s,box-shadow .22s}
.driver-item:hover{background:rgba(255,255,255,.11);transform:translateX(3px);box-shadow:-3px 0 0 0 var(--orange),2px 4px 16px rgba(0,0,0,.2)}
.driver-pct{font-family:'Montserrat',sans-serif;font-weight:800;font-size:30px;color:var(--yellow);line-height:1}
.driver-desc{font-size:12px;color:rgba(255,255,255,.75);margin-top:6px;line-height:1.6}

/* ── SAVINGS BANNER ── */
.savings-banner{background:linear-gradient(135deg,var(--teal) 0%,#2a8fa3 100%);border-radius:14px;padding:30px 34px;margin-bottom:26px;color:var(--white);transition:box-shadow .3s,transform .3s}
.savings-banner:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(49,124,143,.3)}
.savings-banner h3{font-family:'Montserrat',sans-serif;font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:1.5px;color:var(--yellow);margin-bottom:20px}
.savings-stats{display:flex;justify-content:space-around;flex-wrap:wrap;gap:20px}
.stat-block{text-align:center}
.stat-val{font-family:'Montserrat',sans-serif;font-weight:800;font-size:34px;color:var(--white);line-height:1}
.stat-lbl{font-family:'Montserrat',sans-serif;font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.65);margin-top:6px}

/* ── TABLE (dark) ── */
.table-card{background:var(--chart-bg);border:none;border-radius:14px;padding:30px 34px;margin-bottom:26px;box-shadow:0 2px 10px rgba(0,0,0,.15);transition:box-shadow .3s,transform .3s}
.table-card:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(0,0,0,.28)}
.table-card .card-title{color:#59b7c2}
.table-card .card-title::after{background:rgba(89,183,194,.2)}
.table-scroll{overflow-x:auto}
.data-table{width:100%;border-collapse:collapse;font-size:13px;font-family:'Open Sans',sans-serif}
.data-table th{text-align:left;padding:11px 14px;font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--white);background:rgba(255,255,255,.1);white-space:nowrap}
.data-table th:first-child{border-radius:8px 0 0 0}
.data-table th:last-child{border-radius:0 8px 0 0}
.data-table td{padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.06);color:#c8d0ce;white-space:nowrap}
.data-table tr:nth-child(even) td{background:rgba(255,255,255,.03)}
.data-table tr{transition:background .18s}
.data-table tr:hover td{background:rgba(89,183,194,.1);color:#daeef4}
.t-navy{color:#e0e8ea!important;font-weight:700}
.t-orange{color:#f47920!important;font-weight:600}
.t-teal{color:#59b7c2!important;font-weight:600}
.t-pos{color:#6ee8c8!important;font-weight:700}
.t-neg{color:#f47920!important;font-weight:600}

/* ── FOOTER ── */
.site-footer{text-align:center;padding:28px 24px;margin-top:20px;border-top:2px solid var(--light-teal);font-size:11px;color:var(--grey);line-height:1.9}
.site-footer strong{font-family:'Montserrat',sans-serif;color:var(--teal)}

/* ── LOGIN SCREEN ── */
.login-overlay{position:fixed;inset:0;background:linear-gradient(145deg,#0d1b3e 0%,#18305c 40%,#1a4a6e 100%);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .4s,visibility .4s}
.login-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}
.login-card{background:rgba(255,255,255,.06);border:1px solid rgba(89,183,194,.25);border-radius:20px;padding:44px 40px 38px;width:100%;max-width:400px;margin:20px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 24px 64px rgba(0,0,0,.4);text-align:center}
.login-logo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}
.login-logo-sun{width:44px;height:44px;background:var(--yellow);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px}
.login-logo-text{text-align:left}
.login-logo-name{font-family:'Montserrat',sans-serif;font-weight:800;font-size:22px;color:var(--white);letter-spacing:1px}
.login-logo-tag{font-family:'Montserrat',sans-serif;font-weight:600;font-size:11px;color:var(--teal2);letter-spacing:3px;text-transform:uppercase}
.login-subtitle{font-family:'Open Sans',sans-serif;font-size:13px;color:rgba(255,255,255,.5);margin:16px 0 28px;line-height:1.5}
.login-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;text-align:left}
.login-field label{font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.5)}
.login-field input{width:100%;border:2px solid rgba(89,183,194,.25);border-radius:9px;background:rgba(255,255,255,.07);color:var(--white);font-family:'Montserrat',sans-serif;font-weight:600;font-size:15px;padding:13px 16px;outline:none;transition:border-color .2s,box-shadow .2s}
.login-field input::placeholder{color:rgba(255,255,255,.25)}
.login-field input:focus{border-color:var(--teal2);box-shadow:0 0 0 4px rgba(89,183,194,.15);background:rgba(255,255,255,.10)}
.login-btn{width:100%;margin-top:10px;background:var(--yellow);border:none;border-radius:9px;color:var(--dark-blue);font-family:'Montserrat',sans-serif;font-weight:800;font-size:14px;letter-spacing:2px;text-transform:uppercase;padding:16px;cursor:pointer;transition:background .18s,transform .15s,box-shadow .15s;box-shadow:0 4px 18px rgba(255,203,5,.3)}
.login-btn:hover{background:var(--orange);color:var(--white);transform:translateY(-2px);box-shadow:0 8px 26px rgba(244,121,32,.35)}
.login-error{color:var(--orange);font-family:'Montserrat',sans-serif;font-weight:700;font-size:12px;margin-top:14px;min-height:18px;opacity:0;transition:opacity .2s}
.login-error.visible{opacity:1}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-10px)}40%{transform:translateX(10px)}60%{transform:translateX(-6px)}80%{transform:translateX(6px)}}
.login-card.shake{animation:shake .4s ease}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(10,20,40,.75);z-index:999;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--white);border-radius:16px;padding:36px 40px;width:100%;max-width:460px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal-box h2{font-family:'Montserrat',sans-serif;font-weight:800;font-size:20px;color:var(--dark-blue);margin-bottom:6px}
.modal-box p{font-size:13px;color:var(--grey);margin-bottom:24px;line-height:1.6}
.modal-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.modal-field label{font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--grey)}
.modal-field input[type="text"],.modal-field input[type="email"],.modal-field input[type="number"],.modal-field select{border:2px solid var(--border);border-radius:9px;background:#fafcfd;padding:12px 14px;font-size:15px;font-family:'Montserrat',sans-serif;font-weight:600;color:var(--dark-grey);outline:none;width:100%}
.modal-field input[type="text"]:focus,.modal-field input[type="email"]:focus,.modal-field input[type="number"]:focus,.modal-field select:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(49,124,143,.12)}
.modal-radio-group{display:flex;gap:12px;flex-wrap:wrap;margin-top:2px}
.modal-radio-option{display:flex;align-items:center;gap:7px;font-family:'Montserrat',sans-serif;font-size:13px;font-weight:600;color:var(--dark-grey);cursor:pointer;background:#f0f7fa;border:2px solid var(--border);border-radius:8px;padding:8px 14px;transition:border-color .15s,background .15s}
.modal-radio-option input{accent-color:var(--teal);width:16px;height:16px;flex-shrink:0}
.modal-radio-option:has(input:checked){border-color:var(--teal);background:#daeef4}
.modal-advanced-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--teal);padding:10px 0 6px;border-top:1px solid var(--border);margin-top:4px}
.modal-advanced-toggle .adv-arrow{display:inline-block;transition:transform .25s;font-size:13px}
.modal-advanced-toggle.open .adv-arrow{transform:rotate(180deg)}
.modal-advanced-body{display:none;flex-direction:column;gap:16px;margin-top:4px}
.modal-advanced-body.open{display:flex}
.modal-section-label{font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--grey);margin-bottom:2px}
.modal-required{font-size:11px;color:var(--orange);margin-left:4px}
.modal-actions{display:flex;gap:12px;margin-top:24px}
.modal-confirm{flex:1;background:var(--yellow);border:none;border-radius:9px;color:var(--dark-blue);font-family:'Montserrat',sans-serif;font-weight:800;font-size:14px;letter-spacing:1px;text-transform:uppercase;padding:14px;cursor:pointer;transition:background .15s}
.modal-confirm:hover{background:var(--orange);color:var(--white)}
.modal-cancel{background:none;border:2px solid var(--border);border-radius:9px;color:var(--grey);font-family:'Montserrat',sans-serif;font-weight:700;font-size:13px;padding:14px 20px;cursor:pointer;transition:border-color .15s}
.modal-cancel:hover{border-color:var(--grey)}
.modal-clear{background:none;border:none;color:var(--grey);font-family:'Montserrat',sans-serif;font-weight:600;font-size:13px;padding:14px 10px;cursor:pointer;text-decoration:underline;transition:color .15s}
.modal-clear:hover{color:var(--orange)}

/* ══════ NEW DASHBOARD STYLES ══════ */

/* ── Flash Messages ── */
.flash-message{position:fixed;top:80px;right:20px;padding:14px 24px;border-radius:10px;font-family:'Montserrat',sans-serif;font-size:13px;font-weight:600;z-index:9998;box-shadow:0 8px 24px rgba(0,0,0,.2);transition:opacity .3s,transform .3s;max-width:400px}
.flash-success{background:var(--dark-blue);border:1px solid var(--teal2);color:var(--teal2)}
.flash-error{background:var(--dark-blue);border:1px solid var(--orange);color:var(--orange)}

/* ── Module Buttons Grid ── */
.button-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}
.module-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 16px;background:var(--off-white);border:2px solid var(--border);border-radius:12px;text-decoration:none;color:var(--dark-grey);font-family:'Montserrat',sans-serif;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:1px;transition:all .22s}
.module-btn:hover{border-color:var(--teal2);background:var(--light-teal);transform:translateY(-2px);box-shadow:0 6px 20px rgba(49,124,143,.15)}
.module-icon{font-size:28px}
.module-label{text-align:center}

/* ── Dashboard Table (light) ── */
.dash-table{width:100%;border-collapse:collapse;font-size:13px;font-family:'Open Sans',sans-serif}
.dash-table th{text-align:left;padding:12px 16px;font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--grey);background:var(--light-teal);white-space:nowrap;border-bottom:2px solid var(--border)}
.dash-table th:first-child{border-radius:8px 0 0 0}
.dash-table th:last-child{border-radius:0 8px 0 0}
.dash-table td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--dark-grey);vertical-align:middle}
.dash-table tr:hover td{background:rgba(49,124,143,.04)}
.file-icon{margin-right:6px}

/* ── Action Buttons ── */
.action-btn{display:inline-block;padding:5px 12px;border-radius:6px;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;text-decoration:none;cursor:pointer;transition:all .2s;border:none;background:none;letter-spacing:.5px}
.view-btn{color:var(--teal);background:rgba(49,124,143,.1)}
.view-btn:hover{background:var(--teal);color:var(--white)}
.download-btn{color:var(--dark-blue);background:rgba(24,48,92,.08)}
.download-btn:hover{background:var(--dark-blue);color:var(--white)}
.delete-btn{color:var(--orange);background:rgba(244,121,32,.08)}
.delete-btn:hover{background:var(--orange);color:var(--white)}

/* ── Role Badge ── */
.role-badge{display:inline-block;padding:3px 10px;border-radius:6px;font-family:'Montserrat',sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px}
.role-admin{background:rgba(255,203,5,.15);color:#b8930a;border:1px solid rgba(255,203,5,.3)}
.role-user{background:rgba(49,124,143,.1);color:var(--teal);border:1px solid rgba(49,124,143,.2)}

/* ── Empty State ── */
.empty-state{text-align:center;padding:40px 20px}
.empty-icon{font-size:48px;margin-bottom:12px;opacity:.6}
.empty-state h3{font-family:'Montserrat',sans-serif;font-weight:800;font-size:16px;color:var(--dark-blue);margin-bottom:8px}
.empty-state p{font-size:13px;color:var(--grey);line-height:1.6;max-width:400px;margin:0 auto}

/* ── Upload Area ── */
.upload-area{border:2px dashed var(--border);border-radius:12px;padding:32px 20px;text-align:center;cursor:pointer;transition:all .22s;position:relative}
.upload-area:hover,.upload-area.drag-over{border-color:var(--teal2);background:var(--light-teal)}
.upload-area.file-selected{border-color:var(--teal);background:rgba(49,124,143,.05)}
.upload-area input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer}
.upload-icon{font-size:36px;margin-bottom:8px}
.upload-area p{font-family:'Montserrat',sans-serif;font-size:13px;font-weight:600;color:var(--grey)}
.upload-hint{font-size:11px!important;color:#aaa!important;margin-top:4px}
.selected-file-name{font-family:'Montserrat',sans-serif;font-size:13px;font-weight:600;color:var(--teal);padding:8px 0}

/* ── PRINT STYLES ── */
.print-header{display:none;align-items:center;justify-content:space-between;padding:14px 0 20px;border-bottom:3px solid var(--teal);margin-bottom:20px}
.print-name-block{display:block}
.print-prepared{font-size:10px;color:var(--grey);text-transform:uppercase;letter-spacing:2px;font-family:'Montserrat',sans-serif;font-weight:600}
.print-name{font-family:'Montserrat',sans-serif;font-weight:800;font-size:22px;color:var(--dark-blue);margin-top:2px}
.print-date{font-size:11px;color:var(--grey);margin-top:3px}
.print-logo-area{text-align:right}
.print-logo-area img{height:44px;width:auto}

@media print{
  *{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}
  body{background:white!important;font-size:11px}
  .site-header{position:relative!important;box-shadow:none!important}
  .modal-overlay,.export-bar,.generate-btn,.chart-tooltip,.site-footer,.flash-message,.logout-btn,.header-nav-link{display:none!important}
  .page-wrap{padding:16px 24px 24px;max-width:100%}
  .card,.table-card,.drivers-box,.savings-banner,.nm-impact,.nm-toggle-wrap{break-inside:avoid}
  .results-section{display:block!important}
  .print-header{display:flex!important}
  canvas{max-width:100%}
  @page{size:A4;margin:12mm 14mm}
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:7px;height:7px}
::-webkit-scrollbar-track{background:var(--off-white)}
::-webkit-scrollbar-thumb{background:var(--teal2);border-radius:4px}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .summary-grid{grid-template-columns:1fr 1fr}
  .sum-value{font-size:26px}
  .drivers-grid{grid-template-columns:1fr}
  .stat-val{font-size:28px}
  .button-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
}
@media(max-width:700px){
  .site-header{padding:0 16px;height:60px}
  .logo-img{height:85px;max-width:260px}
  .header-pill{font-size:9px;padding:5px 12px}
  .header-nav-link{font-size:8px;padding:4px 8px}
  .hero{padding:30px 20px 28px}
  .hero h1{font-size:22px}
  .hero p{font-size:14px}
  .page-wrap{padding:20px 14px 70px}
  .card{padding:22px 18px}
  .table-card{padding:22px 14px}
  .form-grid{grid-template-columns:1fr;gap:16px}
  .summary-grid{grid-template-columns:1fr;gap:14px}
  .sum-value{font-size:28px}
  .export-bar{padding:16px 18px;flex-direction:column;align-items:stretch;text-align:center}
  .export-btn{width:100%;justify-content:center}
  .generate-btn{font-size:13px;padding:16px 20px}
  .parish-btns{gap:8px}
  .parish-btn{padding:8px 14px;font-size:11px}
  .nm-impact-grid{grid-template-columns:1fr 1fr;gap:10px}
  .modal-box{padding:28px 22px;margin:16px;max-width:calc(100vw - 32px)}
  .modal-actions{flex-direction:column-reverse}
  .button-grid{grid-template-columns:1fr 1fr;gap:10px}
}
@media(max-width:480px){
  .site-header{padding:0 12px;height:54px}
  .logo-img{height:70px;max-width:200px}
  .header-pill{font-size:8px;padding:4px 10px}
  .hero{padding:24px 16px 22px}
  .hero h1{font-size:19px}
  .page-wrap{padding:16px 10px 60px}
  .card{padding:18px 14px;border-radius:12px}
  .form-grid{gap:14px}
  input[type="number"],input[type="text"],input[type="email"],input[type="password"],select{font-size:15px;padding:11px 11px 11px 30px}
  select{padding-left:13px}
  .summary-grid{gap:10px}
  .sum-value{font-size:26px}
  .nm-impact-grid{grid-template-columns:1fr;gap:12px}
  .parish-btns{flex-direction:column;gap:6px}
  .parish-btn{width:100%;text-align:center}
  .drivers-box{padding:18px 14px;border-radius:12px}
  .savings-banner{padding:18px 14px;border-radius:12px}
  .savings-stats{flex-direction:column;gap:16px;align-items:center}
  .stat-val{font-size:30px}
  .generate-btn{font-size:12px;padding:15px 16px;border-radius:10px}
  .login-card{padding:32px 24px 28px;margin:16px;border-radius:16px}
  .login-logo-name{font-size:19px}
  .login-field input{font-size:14px;padding:12px 14px}
  .login-btn{font-size:13px;padding:14px}
  .button-grid{grid-template-columns:1fr}
}
