:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#e5e7eb;background:#080b14;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{min-height:100vh;background:radial-gradient(circle at 15% 0%,rgba(99,102,241,.2),transparent 34%),radial-gradient(circle at 90% 15%,rgba(20,184,166,.12),transparent 28%),linear-gradient(180deg,#0b1020,#111827)}button,input,select{font:inherit}button{-webkit-tap-highlight-color:transparent}.app-shell{position:relative;min-height:100vh;overflow-x:hidden}.background-glow{position:fixed;width:520px;height:520px;border-radius:999px;filter:blur(110px);opacity:.5;pointer-events:none}.glow-1{top:-160px;left:-140px;background:#6366f138}.glow-2{right:-160px;bottom:-160px;background:#10b98124}.page{position:relative;z-index:1;width:min(1180px,calc(100% - 32px));margin:0 auto;padding:40px 0 64px}.hero{margin-bottom:26px}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:7px 11px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#c7d2fe;background:#6366f124;border:1px solid rgba(129,140,248,.24);margin-bottom:16px}.hero h1{margin:0;max-width:820px;font-size:clamp(32px,5vw,56px);line-height:.98;letter-spacing:-.055em;color:#f8fafc}.hero p{margin:16px 0 0;max-width:720px;color:#9ca3af;font-size:16px}.logout-btn{margin-top:18px;border:1px solid rgba(148,163,184,.18);border-radius:999px;padding:10px 14px;background:#02061770;color:#cbd5e1;cursor:pointer;transition:.18s ease}.logout-btn:hover{background:#ffffff12;border-color:#94a3b847}.tabs{display:inline-flex;gap:6px;padding:6px;border-radius:18px;background:#0f172aa8;border:1px solid rgba(148,163,184,.13);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);margin-bottom:22px;box-shadow:inset 0 1px #ffffff0a}.tab{border:0;border-radius:13px;padding:11px 16px;background:transparent;color:#94a3b8;cursor:pointer;font-weight:700;transition:.2s ease;white-space:nowrap}.tab:hover{color:#e2e8f0;background:#ffffff0b}.tab.active{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;box-shadow:0 10px 28px #4f46e552}.panel{background:#0f172abd;border:1px solid rgba(148,163,184,.14);border-radius:30px;padding:24px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 24px 90px #00000057,inset 0 1px #ffffff09}.panel-header{display:flex;justify-content:space-between;gap:16px;margin-bottom:20px}.panel-header h2{margin:0;font-size:24px;letter-spacing:-.02em;color:#f8fafc}.panel-header p{margin:7px 0 0;color:#94a3b8}.grid{display:grid;gap:16px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.four{grid-template-columns:repeat(4,minmax(0,1fr));margin-top:16px}.field-card{display:flex;flex-direction:column;gap:10px;min-width:0;background:#0206176b;border:1px solid rgba(148,163,184,.12);border-radius:22px;padding:18px;transition:.18s ease}.field-card:hover{border-color:#94a3b838;background:#02061785}.upload-card{min-height:150px;justify-content:center}label{font-size:13px;font-weight:800;color:#e2e8f0}input[type=file]{color:#cbd5e1;max-width:100%}input[type=file]::file-selector-button{border:0;border-radius:12px;padding:10px 14px;margin-right:12px;font-weight:700;background:#334155db;color:#f8fafc;cursor:pointer;transition:.18s ease}input[type=file]::file-selector-button:hover{background:#475569f2}input[type=number],select,.login-form input{width:100%;border:1px solid rgba(148,163,184,.18);border-radius:15px;padding:12px 14px;background:#0206179e;color:#f8fafc;outline:none;transition:.18s ease}select{cursor:pointer}input[type=number]:focus,select:focus,.login-form input:focus{border-color:#6366f194;box-shadow:0 0 0 4px #6366f124}input:disabled,select:disabled{opacity:.55;cursor:not-allowed}.field-hint{font-size:12px;color:#94a3b8}.file-pill{display:inline-flex;align-self:flex-start;max-width:100%;margin-top:4px;padding:8px 12px;border-radius:999px;font-size:12px;font-weight:700;color:#dbeafe;background:#3b82f621;border:1px solid rgba(96,165,250,.22);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.action-row{display:flex;justify-content:flex-start;margin-top:20px}.primary-btn{border:0;border-radius:15px;padding:13px 18px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;font-weight:800;cursor:pointer;transition:transform .15s ease,box-shadow .18s ease,opacity .18s ease;box-shadow:0 14px 34px #4f46e54d}.primary-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 18px 42px #4f46e561}.primary-btn:active:not(:disabled){transform:translateY(0)}.primary-btn:disabled{opacity:.48;cursor:not-allowed;box-shadow:none}.progress-card{margin-top:18px;padding:16px;border-radius:20px;background:#0206178c;border:1px solid rgba(148,163,184,.14)}.progress-header{display:flex;justify-content:space-between;gap:16px;margin-bottom:10px;color:#cbd5e1;font-size:14px}.progress-header strong{color:#f8fafc}.progress-track{width:100%;height:10px;border-radius:999px;background:#94a3b829;overflow:hidden}.progress-fill{height:100%;border-radius:999px;background:linear-gradient(135deg,#6366f1,#22c55e);transition:width .25s ease}.result-section{margin-top:24px;display:flex;flex-direction:column;gap:18px}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.stat-card{padding:18px;border-radius:22px;background:#02061785;border:1px solid rgba(148,163,184,.1)}.stat-card span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;margin-bottom:10px;font-weight:800}.stat-card strong{font-size:30px;line-height:1;color:#f8fafc;letter-spacing:-.03em}.stat-card.accent{background:linear-gradient(135deg,#6366f133,#4f46e51a);border-color:#818cf842}.save-card{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:20px;border-radius:24px;background:#0206178a;border:1px solid rgba(148,163,184,.12)}.save-card h3{margin:0 0 6px;color:#f8fafc}.save-card p{margin:0;color:#94a3b8;word-break:break-word}.download-group{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.solar-requirements{display:flex;flex-direction:column;gap:8px}.solar-requirements span{display:inline-flex;align-self:flex-start;padding:8px 12px;border-radius:999px;font-size:13px;font-weight:800;background:#10b98124;color:#bbf7d0;border:1px solid rgba(74,222,128,.22)}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:100%;max-width:440px;padding:30px;border-radius:30px;background:#0f172acc;border:1px solid rgba(148,163,184,.14);box-shadow:0 24px 90px #00000057;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.login-card h1{margin:0;font-size:38px;line-height:1;letter-spacing:-.045em;color:#f8fafc}.login-card p{color:#94a3b8;margin:12px 0 22px}.login-form{display:flex;flex-direction:column;gap:12px}@media (max-width: 1040px){.grid.three,.grid.four,.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.page{width:min(100% - 28px,1180px)}}@media (max-width: 760px){.page{width:min(100% - 22px,1180px);padding:24px 0 44px}.hero{margin-bottom:20px}.hero p{font-size:15px}.tabs{display:grid;grid-template-columns:1fr;width:100%}.tab{width:100%;justify-content:center;padding:12px 14px}.panel{border-radius:24px;padding:18px}.panel-header h2{font-size:22px}.grid.two,.grid.three,.grid.four,.stats-grid{grid-template-columns:1fr}.field-card{border-radius:19px;padding:16px}.upload-card{min-height:auto}.action-row,.primary-btn{width:100%}.primary-btn{justify-content:center}.save-card{flex-direction:column;align-items:stretch;border-radius:21px}.download-group{flex-direction:column;width:100%}.stat-card strong{font-size:28px}input[type=file]::file-selector-button{display:block;width:100%;margin:0 0 10px}}@media (max-width: 420px){.page{width:min(100% - 16px,1180px)}.hero h1{font-size:31px}.panel{padding:14px;border-radius:22px}.login-card{padding:22px;border-radius:24px}.login-card h1{font-size:32px}.premium-progress{position:relative;overflow:hidden;padding:18px;border-radius:22px;background:linear-gradient(135deg,#0f172ae6,#020617b8),radial-gradient(circle at top left,rgba(99,102,241,.18),transparent 34%);border:1px solid rgba(148,163,184,.16);box-shadow:0 18px 50px #00000038,inset 0 1px #ffffff0a}.premium-progress:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.035) 45%,transparent 70%);transform:translate(-100%);animation:progress-sheen 2.4s infinite;pointer-events:none}.progress-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px}.progress-status{display:flex;align-items:center;gap:12px;min-width:0}.progress-status p{margin:0 0 3px;font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#818cf8}.progress-status strong{display:block;color:#f8fafc;font-size:14px;line-height:1.35;word-break:break-word}.pulse-dot{width:11px;height:11px;flex:0 0 auto;border-radius:999px;background:#22c55e;box-shadow:0 0 #22c55e73;animation:pulse-dot 1.5s infinite}.progress-percent{flex:0 0 auto;padding:8px 11px;border-radius:999px;background:#6366f129;border:1px solid rgba(129,140,248,.22);color:#e0e7ff;font-weight:900;font-size:13px}.premium-track{height:12px;border-radius:999px;background:#94a3b829;overflow:hidden;box-shadow:inset 0 1px 4px #00000059}.premium-fill{position:relative;height:100%;border-radius:999px;background:linear-gradient(90deg,#6366f1,#22c55e);transition:width .35s ease;overflow:hidden}.premium-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(45deg,rgba(255,255,255,.22) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.22) 50%,rgba(255,255,255,.22) 75%,transparent 75%,transparent);background-size:18px 18px;animation:progress-stripes .8s linear infinite;opacity:.35}.progress-meta{display:flex;justify-content:space-between;gap:12px;margin-top:10px;color:#94a3b8;font-size:12px}@keyframes pulse-dot{0%{box-shadow:0 0 #22c55e73}70%{box-shadow:0 0 0 9px #22c55e00}to{box-shadow:0 0 #22c55e00}}@keyframes progress-stripes{0%{background-position:0 0}to{background-position:18px 0}}@keyframes progress-sheen{0%{transform:translate(-100%)}55%{transform:translate(100%)}to{transform:translate(100%)}}@media (max-width: 640px){.progress-top{flex-direction:column}.progress-percent{align-self:flex-start}.progress-meta{flex-direction:column;gap:4px}}}
