.login-container{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background-color:#fff;padding:20px}.login-card{background:#fff;width:100%;max-width:450px;border-radius:16px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;border:1px solid #e5e7eb;overflow:hidden;padding:0}.login-header{text-align:center;background-color:#000;padding:40px 40px 30px;margin-bottom:30px}.login-logo{height:60px;width:auto;margin:0 auto 20px;display:block}.login-title{font-size:24px;font-weight:700;color:#fff;margin-bottom:8px}.login-subtitle{font-size:14px;color:#9ca3af}.login-body{padding:0 40px 40px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:12px;color:#9ca3af;pointer-events:none}.form-input{width:100%;padding:12px 16px 12px 40px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;color:#111827;transition:all .2s;background-color:#fff}.form-input:focus{outline:none;border-color:#f97316;box-shadow:0 0 0 3px #f973161a}.submit-button{width:100%;padding:12px;background-color:#000;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s;display:flex;justify-content:center;align-items:center;gap:8px;margin-top:8px}.submit-button:hover{background-color:#333}.submit-button:disabled{opacity:.7;cursor:not-allowed}.error-message{background-color:#fef2f2;border-left:4px solid #ef4444;padding:12px;border-radius:4px;color:#b91c1c;font-size:14px;margin-bottom:20px}.copyright-text{margin-top:32px;text-align:center;font-size:12px;color:#9ca3af;line-height:1.5}@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-space-y-reverse:0;--tw-space-x-reverse:0;--tw-divide-y-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-duration:initial;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-50:oklch(97.1% .013 17.38);--color-red-100:oklch(93.6% .032 17.717);--color-red-200:oklch(88.5% .062 18.334);--color-red-400:oklch(70.4% .191 22.216);--color-red-600:oklch(57.7% .245 27.325);--color-red-700:oklch(50.5% .213 27.518);--color-red-800:oklch(44.4% .177 26.899);--color-orange-50:oklch(98% .016 73.684);--color-orange-200:oklch(90.1% .076 70.697);--color-orange-600:oklch(64.6% .222 41.116);--color-orange-700:oklch(55.3% .195 38.402);--color-orange-800:oklch(47% .157 37.304);--color-yellow-50:oklch(98.7% .026 102.212);--color-yellow-100:oklch(97.3% .071 103.193);--color-yellow-200:oklch(94.5% .129 101.54);--color-yellow-500:oklch(79.5% .184 86.047);--color-yellow-600:oklch(68.1% .162 75.834);--color-yellow-700:oklch(55.4% .135 66.442);--color-yellow-800:oklch(47.6% .114 61.907);--color-green-50:oklch(98.2% .018 155.826);--color-green-100:oklch(96.2% .044 156.743);--color-green-200:oklch(92.5% .084 155.995);--color-green-500:oklch(72.3% .219 149.579);--color-green-600:oklch(62.7% .194 149.214);--color-green-700:oklch(52.7% .154 150.069);--color-green-800:oklch(44.8% .119 151.328);--color-emerald-50:oklch(97.9% .021 166.113);--color-emerald-200:oklch(90.5% .093 164.15);--color-emerald-600:oklch(59.6% .145 163.225);--color-emerald-700:oklch(50.8% .118 165.612);--color-emerald-800:oklch(43.2% .095 166.913);--color-teal-50:oklch(98.4% .014 180.72);--color-teal-200:oklch(91% .096 180.426);--color-teal-600:oklch(60% .118 184.704);--color-teal-700:oklch(51.1% .096 186.391);--color-teal-800:oklch(43.7% .078 188.216);--color-cyan-50:oklch(98.4% .019 200.873);--color-cyan-200:oklch(91.7% .08 205.041);--color-cyan-600:oklch(60.9% .126 221.723);--color-cyan-700:oklch(52% .105 223.128);--color-cyan-800:oklch(45% .085 224.283);--color-blue-50:oklch(97% .014 254.604);--color-blue-100:oklch(93.2% .032 255.585);--color-blue-200:oklch(88.2% .059 254.128);--color-blue-300:oklch(80.9% .105 251.813);--color-blue-500:oklch(62.3% .214 259.815);--color-blue-600:oklch(54.6% .245 262.881);--color-blue-800:oklch(42.4% .199 265.638);--color-blue-900:oklch(37.9% .146 265.522);--color-indigo-50:oklch(96.2% .018 272.314);--color-indigo-200:oklch(87% .065 274.039);--color-indigo-600:oklch(51.1% .262 276.966);--color-indigo-700:oklch(45.7% .24 277.023);--color-indigo-800:oklch(39.8% .195 277.366);--color-purple-50:oklch(97.7% .014 308.299);--color-purple-100:oklch(94.6% .033 307.174);--color-purple-200:oklch(90.2% .063 306.703);--color-purple-500:oklch(62.7% .265 303.9);--color-purple-600:oklch(55.8% .288 302.321);--color-purple-700:oklch(49.6% .265 301.924);--color-purple-800:oklch(43.8% .218 303.724);--color-rose-50:oklch(96.9% .015 12.422);--color-rose-200:oklch(89.2% .058 10.001);--color-rose-600:oklch(58.6% .253 17.585);--color-rose-700:oklch(51.4% .222 16.935);--color-rose-800:oklch(45.5% .188 13.697);--color-gray-50:oklch(98.5% .002 247.839);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-300:oklch(87.2% .01 258.338);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-700:oklch(37.3% .034 259.733);--color-gray-800:oklch(27.8% .033 256.848);--color-gray-900:oklch(21% .034 264.665);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-md:28rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--text-3xl:1.875rem;--text-3xl--line-height: 1.2 ;--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5/2.25);--text-6xl:3.75rem;--text-6xl--line-height:1;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--radius-lg:.5rem;--radius-xl:.75rem;--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4,0,.6,1)infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::-moz-placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.top-0{top:calc(var(--spacing)*0)}.top-full{top:100%}.right-0{right:calc(var(--spacing)*0)}.left-0{left:calc(var(--spacing)*0)}.z-10{z-index:10}.z-50{z-index:50}.mx-auto{margin-inline:auto}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-3{margin-top:calc(var(--spacing)*3)}.mt-4{margin-top:calc(var(--spacing)*4)}.mt-8{margin-top:calc(var(--spacing)*8)}.mt-auto{margin-top:auto}.mr-2{margin-right:calc(var(--spacing)*2)}.mr-3{margin-right:calc(var(--spacing)*3)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-3{margin-bottom:calc(var(--spacing)*3)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.mb-8{margin-bottom:calc(var(--spacing)*8)}.-ml-1{margin-left:calc(var(--spacing)*-1)}.ml-2{margin-left:calc(var(--spacing)*2)}.flex{display:flex}.grid{display:grid}.hidden{display:none}.table{display:table}.table-cell{display:table-cell}.table-row{display:table-row}.h-3{height:calc(var(--spacing)*3)}.h-4{height:calc(var(--spacing)*4)}.h-5{height:calc(var(--spacing)*5)}.h-8{height:calc(var(--spacing)*8)}.h-12{height:calc(var(--spacing)*12)}.h-96{height:calc(var(--spacing)*96)}.h-full{height:100%}.max-h-60{max-height:calc(var(--spacing)*60)}.max-h-\[600px\]{max-height:600px}.w-3{width:calc(var(--spacing)*3)}.w-4{width:calc(var(--spacing)*4)}.w-5{width:calc(var(--spacing)*5)}.w-8{width:calc(var(--spacing)*8)}.w-12{width:calc(var(--spacing)*12)}.w-full{width:100%}.max-w-md{max-width:var(--container-md)}.min-w-\[140px\]{min-width:140px}.min-w-\[180px\]{min-width:180px}.min-w-\[300px\]{min-width:300px}.flex-1{flex:1}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-pointer{cursor:pointer}.list-inside{list-style-position:inside}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing)*1)}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}.gap-6{gap:calc(var(--spacing)*6)}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*2)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*4)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*6)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*6)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-8>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*8)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*8)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-x-4>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*4)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-x-reverse)))}:where(.divide-y>:not(:last-child)){--tw-divide-y-reverse:0;border-bottom-style:var(--tw-border-style);border-top-style:var(--tw-border-style);border-top-width:calc(1px*var(--tw-divide-y-reverse));border-bottom-width:calc(1px*calc(1 - var(--tw-divide-y-reverse)))}:where(.divide-gray-100>:not(:last-child)){border-color:var(--color-gray-100)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-blue-200{border-color:var(--color-blue-200)}.border-blue-300{border-color:var(--color-blue-300)}.border-cyan-200{border-color:var(--color-cyan-200)}.border-emerald-200{border-color:var(--color-emerald-200)}.border-gray-50{border-color:var(--color-gray-50)}.border-gray-200{border-color:var(--color-gray-200)}.border-gray-300{border-color:var(--color-gray-300)}.border-gray-700\/50{border-color:#36415380}@supports (color:color-mix(in lab,red,red)){.border-gray-700\/50{border-color:color-mix(in oklab,var(--color-gray-700)50%,transparent)}}.border-green-200{border-color:var(--color-green-200)}.border-indigo-200{border-color:var(--color-indigo-200)}.border-orange-200{border-color:var(--color-orange-200)}.border-purple-200{border-color:var(--color-purple-200)}.border-red-200{border-color:var(--color-red-200)}.border-rose-200{border-color:var(--color-rose-200)}.border-teal-200{border-color:var(--color-teal-200)}.border-yellow-200{border-color:var(--color-yellow-200)}.bg-blue-50{background-color:var(--color-blue-50)}.bg-blue-100{background-color:var(--color-blue-100)}.bg-blue-500{background-color:var(--color-blue-500)}.bg-cyan-50{background-color:var(--color-cyan-50)}.bg-emerald-50{background-color:var(--color-emerald-50)}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-50\/30{background-color:#f9fafb4d}@supports (color:color-mix(in lab,red,red)){.bg-gray-50\/30{background-color:color-mix(in oklab,var(--color-gray-50)30%,transparent)}}.bg-gray-100{background-color:var(--color-gray-100)}.bg-gray-500{background-color:var(--color-gray-500)}.bg-green-50{background-color:var(--color-green-50)}.bg-green-100{background-color:var(--color-green-100)}.bg-green-500{background-color:var(--color-green-500)}.bg-indigo-50{background-color:var(--color-indigo-50)}.bg-orange-50{background-color:var(--color-orange-50)}.bg-purple-50{background-color:var(--color-purple-50)}.bg-purple-600{background-color:var(--color-purple-600)}.bg-red-50{background-color:var(--color-red-50)}.bg-red-100{background-color:var(--color-red-100)}.bg-rose-50{background-color:var(--color-rose-50)}.bg-teal-50{background-color:var(--color-teal-50)}.bg-white{background-color:var(--color-white)}.bg-yellow-50{background-color:var(--color-yellow-50)}.bg-yellow-100{background-color:var(--color-yellow-100)}.bg-yellow-500{background-color:var(--color-yellow-500)}.bg-gradient-to-r{--tw-gradient-position:to right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-purple-600{--tw-gradient-from:var(--color-purple-600);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.to-blue-600{--tw-gradient-to:var(--color-blue-600);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.p-2{padding:calc(var(--spacing)*2)}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.p-6{padding:calc(var(--spacing)*6)}.p-8{padding:calc(var(--spacing)*8)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-6{padding-inline:calc(var(--spacing)*6)}.py-1{padding-block:calc(var(--spacing)*1)}.py-2{padding-block:calc(var(--spacing)*2)}.py-3{padding-block:calc(var(--spacing)*3)}.py-4{padding-block:calc(var(--spacing)*4)}.py-12{padding-block:calc(var(--spacing)*12)}.pt-2{padding-top:calc(var(--spacing)*2)}.pt-3{padding-top:calc(var(--spacing)*3)}.text-center{text-align:center}.text-left{text-align:left}.font-mono{font-family:var(--font-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.whitespace-nowrap{white-space:nowrap}.text-black{color:var(--color-black)}.text-blue-600{color:var(--color-blue-600)}.text-blue-800{color:var(--color-blue-800)}.text-blue-900{color:var(--color-blue-900)}.text-cyan-600{color:var(--color-cyan-600)}.text-cyan-700{color:var(--color-cyan-700)}.text-cyan-800{color:var(--color-cyan-800)}.text-emerald-600{color:var(--color-emerald-600)}.text-emerald-700{color:var(--color-emerald-700)}.text-emerald-800{color:var(--color-emerald-800)}.text-gray-300{color:var(--color-gray-300)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-gray-800{color:var(--color-gray-800)}.text-gray-900{color:var(--color-gray-900)}.text-green-600{color:var(--color-green-600)}.text-green-700{color:var(--color-green-700)}.text-green-800{color:var(--color-green-800)}.text-indigo-600{color:var(--color-indigo-600)}.text-indigo-700{color:var(--color-indigo-700)}.text-indigo-800{color:var(--color-indigo-800)}.text-orange-600{color:var(--color-orange-600)}.text-orange-700{color:var(--color-orange-700)}.text-orange-800{color:var(--color-orange-800)}.text-purple-100{color:var(--color-purple-100)}.text-purple-600{color:var(--color-purple-600)}.text-purple-700{color:var(--color-purple-700)}.text-purple-800{color:var(--color-purple-800)}.text-red-400{color:var(--color-red-400)}.text-red-600{color:var(--color-red-600)}.text-red-700{color:var(--color-red-700)}.text-red-800{color:var(--color-red-800)}.text-rose-600{color:var(--color-rose-600)}.text-rose-700{color:var(--color-rose-700)}.text-rose-800{color:var(--color-rose-800)}.text-teal-600{color:var(--color-teal-600)}.text-teal-700{color:var(--color-teal-700)}.text-teal-800{color:var(--color-teal-800)}.text-white{color:var(--color-white)}.text-yellow-600{color:var(--color-yellow-600)}.text-yellow-700{color:var(--color-yellow-700)}.text-yellow-800{color:var(--color-yellow-800)}.opacity-20{opacity:.2}.opacity-25{opacity:.25}.opacity-75{opacity:.75}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a),0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a),0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}@media(hover:hover){.group-hover\:scale-110:is(:where(.group):hover *){--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x)var(--tw-scale-y)}}.last\:border-0:last-child{border-style:var(--tw-border-style);border-width:0}@media(hover:hover){.hover\:border:hover{border-style:var(--tw-border-style);border-width:1px}.hover\:border-gray-300:hover{border-color:var(--color-gray-300)}.hover\:border-gray-700:hover{border-color:var(--color-gray-700)}.hover\:bg-gray-50:hover{background-color:var(--color-gray-50)}.hover\:bg-gray-800:hover{background-color:var(--color-gray-800)}.hover\:bg-purple-700:hover{background-color:var(--color-purple-700)}.hover\:text-white:hover{color:var(--color-white)}.hover\:underline:hover{text-decoration-line:underline}}.focus\:border-black:focus{border-color:var(--color-black)}.focus\:border-purple-500:focus{border-color:var(--color-purple-500)}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-black:focus{--tw-ring-color:var(--color-black)}.focus\:ring-purple-500:focus{--tw-ring-color:var(--color-purple-500)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}@media(min-width:48rem){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:64rem){.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}}@keyframes fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:.6s ease-out fade-in}.animate-slide-up{animation:.5s ease-out slide-up}.animate-scale-in{animation:.4s ease-out scale-in}.backdrop-blur-fallback{background-color:#ffffffe6}@supports (backdrop-filter:blur(8px)){.backdrop-blur-fallback{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#fffc}}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-divide-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-duration{syntax:"*";inherits:false}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f3f4f6;color:#111827}.layout-container{min-height:100vh;display:flex}.sidebar{width:256px;background-color:#000;color:#fff;padding:24px;display:flex;flex-direction:column}.sidebar-header{display:flex;flex-direction:column;align-items:center;gap:16px;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #333333;text-align:center}.sidebar-logo{flex-shrink:0;width:100%;display:flex;justify-content:center;margin-bottom:12px}.logo-image{height:auto;width:100%;max-width:160px;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 4px 6px rgba(0,0,0,.1))}.sidebar-title{flex:1;min-width:0}.sidebar h2{font-size:18px;font-weight:700;margin-bottom:4px;line-height:1.2}.sidebar p{font-size:12px;color:#9ca3af;margin-bottom:0;line-height:1.3}.sidebar nav{flex-grow:1}.sidebar nav a{display:flex;align-items:center;width:100%;padding:12px;border-radius:8px;text-decoration:none;color:#d1d5db;transition:background-color .2s;margin-bottom:4px}.sidebar nav a:hover,.sidebar nav a.active{background-color:#333;color:#fff}.sidebar nav a svg{margin-right:12px}.main-content{flex:1;padding:40px;background-color:#fff}.building-selector{margin-bottom:24px;border-bottom:1px solid #374151;padding-bottom:24px}.building-selector-header{display:flex;align-items:center;margin-bottom:16px;color:#9ca3af;font-size:14px;font-weight:500}.building-selector-header svg{margin-right:8px}.error-icon{color:#ef4444;margin-left:auto}.error-message{margin-top:8px;padding:8px;background-color:#7f1d1d;border-radius:4px;color:#fca5a5;font-size:12px}.building-dropdown{position:relative}.building-dropdown-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:#374151;border:1px solid #4b5563;border-radius:8px;color:#fff;cursor:pointer;transition:all .2s;font-size:14px}.building-dropdown-trigger:hover{background-color:#4b5563;border-color:#6b7280}.building-dropdown-trigger:disabled{opacity:.6;cursor:not-allowed}.building-dropdown-trigger.open{border-color:#2563eb;background-color:#4b5563}.chevron{transition:transform .2s}.chevron.rotated{transform:rotate(180deg)}.building-dropdown-menu{position:absolute;top:100%;left:0;right:0;background-color:#374151;border:1px solid #4b5563;border-radius:8px;margin-top:4px;max-height:300px;overflow-y:auto;z-index:1000;box-shadow:0 10px 25px #0000004d}.building-dropdown-item{padding:16px;cursor:pointer;border-bottom:1px solid #4b5563;transition:background-color .2s}.building-dropdown-item:hover{background-color:#4b5563}.building-dropdown-item:last-child{border-bottom:none}.building-address{font-weight:600;color:#fff;margin-bottom:4px}.building-client{color:#d1d5db;font-size:14px;margin-bottom:4px}.building-details{color:#9ca3af;font-size:12px}.card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:24px}.card-header{display:flex;align-items:center;margin-bottom:16px}.card-icon{margin-right:12px;color:#111827}.card-title{font-size:18px;font-weight:600;color:#111827}.card-value{font-size:32px;font-weight:700;color:#111827;margin-bottom:8px}.card-description{font-size:14px;color:#6b7280}.section-title{font-size:28px;font-weight:700;color:#111827;margin-bottom:24px}.test-box{background-color:#ef4444;color:#fff;padding:16px;margin-bottom:16px;border-radius:8px}.client-details{background:#fff;border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.client-details h2{font-size:24px;font-weight:700;color:#111827;margin-bottom:20px}.client-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.client-detail-item{display:flex;flex-direction:column}.client-detail-label{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.client-detail-value{font-size:16px;color:#111827;font-weight:500}.client-details-modern{background:#fff;border-radius:16px;padding:32px;margin-bottom:32px;box-shadow:0 4px 24px #0000000f;border:1px solid #f3f4f6;position:relative;overflow:hidden}.client-details-modern:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,#1f2937,#111827)}.client-details-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:20px;border-bottom:2px solid #f3f4f6}.client-details-title{display:flex;align-items:center;gap:12px}.client-details-title h2{font-size:24px;font-weight:700;color:#111827;margin:0;background:#111827;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.client-details-empty{text-align:center;padding:48px 24px;color:#6b7280}.client-details-empty svg{color:#9ca3af;margin-bottom:16px}.client-details-empty h3{font-size:20px;font-weight:600;color:#374151;margin:0 0 8px}.client-details-empty p{font-size:16px;line-height:1.5;margin:0}.loading-indicator{display:flex;align-items:center;gap:8px;color:#6b7280;font-size:14px}.error-banner{display:flex;align-items:center;gap:12px;padding:16px 20px;margin-bottom:24px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:12px;color:#1f2937;font-weight:500}.detail-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:20px;overflow:hidden;transition:all .2s ease}.detail-section:hover{box-shadow:0 4px 12px #0000000d;border-color:#cbd5e1}.detail-section-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;cursor:pointer;background:#fff;border-bottom:1px solid #e2e8f0;transition:all .2s ease}.detail-section-header:hover{background:#f8fafc}.section-title{display:flex;align-items:center;gap:12px;margin:0}.section-title h3{font-size:16px;font-weight:600;color:#374151;margin:0}.detail-section-content{padding:24px;background:#fff}.detail-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:20px}.detail-row:last-child{margin-bottom:0}.detail-item{display:flex;flex-direction:column;gap:8px}.detail-label{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:15px;color:#111827;font-weight:500;line-height:1.4;word-break:break-word}.meter-number{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;background:#f1f5f9;padding:8px 12px;border-radius:8px;border:1px solid #e2e8f0;font-size:14px;font-weight:600}.contact-link{color:#111827;text-decoration:none;font-weight:600;transition:color .2s ease}.contact-link:hover{color:#374151;text-decoration:underline}.electricity-page{max-width:1400px;margin:0 auto;padding:0}.page-header{margin-bottom:32px}.page-header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:24px}.page-title{font-size:32px;font-weight:700;margin:0 0 8px;color:#111827}.page-subtitle{font-size:16px;color:#6b7280;margin:0;font-weight:400}.page-actions{display:flex;gap:12px}.building-info-card{background:#fff;border-radius:16px;padding:24px;margin-bottom:32px;color:#111827;box-shadow:0 4px 6px -1px #0000000d;border:1px solid #e5e7eb}.building-info-content{display:flex;justify-content:space-between;align-items:center}.building-name{font-size:24px;font-weight:700;margin:0 0 8px;color:#111827}.building-meta{display:flex;gap:24px;align-items:center}.meter-id,.building-type{font-size:14px;color:#6b7280;font-weight:500}.building-icon{padding:16px;background:#f3f4f6;border-radius:12px}.controls-panel{background:#fff;border-radius:16px;padding:24px;margin-bottom:32px;box-shadow:0 4px 24px #0000000f;border:1px solid #f3f4f6}.controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;align-items:end}.control-group{display:flex;flex-direction:column}.control-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#374151;margin-bottom:8px}.control-input{padding:12px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:14px;font-weight:500;transition:all .2s ease;background:#fff}.control-input:disabled{background:#f9fafb;color:#9ca3af;cursor:not-allowed}.control-hint{font-size:12px;color:#6b7280;margin-top:4px;font-style:italic}.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:12px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s ease;cursor:pointer;border:none;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#111827;color:#fff;box-shadow:0 4px 6px #0000001a}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 12px #00000026;background:#000}.btn-secondary{background:#f8fafc;color:#475569;border:2px solid #e2e8f0}.btn-secondary:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.alert{display:flex;align-items:flex-start;gap:12px;padding:16px 20px;border-radius:12px;margin-bottom:24px;border:1px solid}.alert h4{margin:0 0 4px;font-size:14px;font-weight:600}.alert p{margin:0;font-size:14px}.alert-error{background:#fef2f2;border-color:#fecaca;color:#991b1b}.alert-info{background:#eff6ff;border-color:#bfdbfe;color:#1e40af}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:32px}.metric-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 24px #0000000f;border:1px solid #f3f4f6;display:flex;align-items:center;gap:16px;transition:all .2s ease}.metric-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #0000001a}.metric-icon{padding:16px;border-radius:12px;display:flex;align-items:center;justify-content:center}.metric-card-start .metric-icon{background:#f3f4f6;color:#111827}.metric-card-end .metric-icon{background:#f3f4f6;color:#374151}.metric-card-total .metric-icon{background:#f3f4f6;color:#1f2937}.metric-card-demand .metric-icon{background:#e0e7ff;color:#3730a3}.metric-content{flex:1}.metric-label{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin-bottom:4px}.metric-value{font-size:24px;font-weight:700;color:#111827}.metric-unit{font-size:14px;color:#9ca3af;margin-left:4px}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:24px;margin-bottom:32px}.chart-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 24px #0000000f;border:1px solid #f3f4f6;height:400px;display:flex;flex-direction:column}.chart-header{margin-bottom:16px}.chart-title{font-size:18px;font-weight:600;color:#111827;margin:0;display:flex;align-items:center;gap:8px}.chart-container{flex:1;position:relative;min-height:0}.data-table-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 24px #0000000f;border:1px solid #f3f4f6}.data-table-header{margin-bottom:24px}.data-table-title{font-size:18px;font-weight:600;color:#111827;margin:0;display:flex;align-items:center;gap:8px}.data-table-container{overflow-x:auto;border:1px solid #e5e7eb;border-radius:12px}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #f3f4f6}.data-table th{background:#f9fafb;font-size:12px;font-weight:600;text-transform:uppercase;color:#6b7280;white-space:nowrap}.data-table td{font-size:14px;color:#374151}.data-table tr:hover{background:#f9fafb}.data-table tr:last-child td{border-bottom:none}.table-date{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;color:#6b7280;font-size:13px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;text-align:center;background:#fff;border-radius:16px;border:2px dashed #e5e7eb}.empty-state-icon{width:80px;height:80px;background:#f3f4f6;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:24px;color:#9ca3af}.empty-state-title{font-size:20px;font-weight:600;color:#111827;margin:0 0 8px}.empty-state-description{color:#6b7280;max-width:480px;margin:0;line-height:1.5}.login-page{display:flex;min-height:100vh;background-color:#f3f4f6}.login-container{margin:auto;width:100%;max-width:400px;padding:2rem;background:#fff;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:24px;font-weight:700;color:#111827;margin-bottom:.5rem}.login-header p{color:#6b7280;font-size:14px}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:14px;font-weight:500;color:#374151}.form-input{padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s}.form-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.login-button{background-color:#2563eb;color:#fff;padding:.75rem;border:none;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer;transition:background-color .2s}.login-button:hover{background-color:#1d4ed8}.login-error{background-color:#fee2e2;border:1px solid #fecaca;color:#dc2626;padding:.75rem;border-radius:6px;font-size:14px;text-align:center}@media(max-width:768px){.sidebar{position:fixed;top:0;left:0;bottom:0;transform:translate(-100%);transition:transform .3s ease-in-out;z-index:50}.sidebar.open{transform:translate(0)}.main-content{padding:20px}}.spinner{border:2px solid rgba(0,0,.1);border-left-color:#3b82f6;border-radius:50%;width:16px;height:16px;animation:spin 1s linear infinite;display:inline-block;vertical-align:middle;margin-right:8px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.billing-page{padding:2rem;max-width:1200px;margin:0 auto}.billing-header{margin-bottom:2rem}.billing-controls{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;align-items:end}.control-group{display:flex;flex-direction:column;gap:.5rem}.control-label{font-size:.875rem;font-weight:500;color:#374151}.control-input{padding:.5rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem}.control-input:focus{outline:none;border-color:#111827;box-shadow:0 0 0 3px #0000001a}.generate-btn{background-color:#111827;color:#fff;padding:.5rem 1rem;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.generate-btn:hover{background-color:#374151}.generate-btn:disabled{opacity:.5;cursor:not-allowed}.invoice-preview{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a}.invoice-header{display:flex;justify-content:space-between;margin-bottom:2rem;border-bottom:2px solid #e5e7eb;padding-bottom:1rem}.invoice-title{font-size:1.5rem;font-weight:700;color:#111827}.invoice-meta{text-align:right}.invoice-date{color:#6b7280;font-size:.875rem}.building-info-section{background:#f9fafb;padding:1.5rem;border-radius:8px;margin-bottom:2rem;border:1px solid #e5e7eb}.building-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}.info-group{display:flex;flex-direction:column;gap:.25rem}.info-label{font-size:.75rem;font-weight:600;text-transform:uppercase;color:#6b7280}.info-value{font-weight:500;color:#111827}.service-info{background:#f0f9ff;padding:1rem;border-radius:8px;margin-bottom:1rem;border-left:4px solid #111827}.service-info p{margin:0;color:#1e40af;font-weight:500}.billing-table{width:100%;border-collapse:collapse;margin-bottom:2rem}.table-header-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;background:linear-gradient(135deg,#1f2937,#111827);color:#fff}.table-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;border-bottom:1px solid #e5e7eb}.table-header-cell{padding:1rem;font-weight:600;text-align:left}.table-row.total-bill-row{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:2px solid #111827}.table-cell{padding:1rem;text-align:left;display:flex;align-items:center}.total-label{font-weight:700;color:#111827}.total-amount{font-weight:700;color:#059669;font-size:1.125rem}.final-total{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:2px solid #9ca3af}.total-summary{display:flex;justify-content:flex-end;margin-top:2rem}.summary-card{background:#f3f4f6;padding:1.5rem;border-radius:8px;min-width:300px}.summary-row{display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #d1d5db}.summary-row:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.summary-label{color:#4b5563}.summary-value{font-weight:600;color:#111827}.grand-total{margin-top:1rem;padding-top:1rem;border-top:2px solid #111827}.grand-total .summary-value{font-size:1.25rem;font-weight:700;color:#059669}.payment-info{background:#f8fafc;border:2px solid #111827}.payment-details{margin-top:1rem}.payment-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:1.5rem}.payment-column{background:#fff;padding:1.25rem;border-radius:8px;box-shadow:0 1px 3px #0000001a}.payment-subtitle{font-size:1rem;font-weight:600;color:#1e293b;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.payment-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #f1f5f9}.payment-item:last-child{border-bottom:none}.payment-label{font-weight:500;color:#374151;font-size:.875rem}.payment-value{font-weight:600;color:#1f2937;font-size:.875rem}.mixed-season-badge{background:linear-gradient(135deg,#4b5563,#1f2937);color:#fff;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;display:inline-block}.single-season-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;display:inline-block;background:#e5e7eb;color:#111827}.mixed-season-indicator{color:#374151;font-weight:500;font-size:.875rem}.season-summary{margin-bottom:1.5rem;padding:1rem;background:#fffbeb;border:1px solid #fed7aa;border-radius:8px;color:#92400e;font-size:.875rem}.season-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.season-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a;border:2px solid transparent;transition:all .2s}.season-card:hover{transform:translateY(-2px);box-shadow:0 8px 15px -3px #0000001a}.season-card.high-season{border-color:#111827;background:#f9fafb}.season-card.low-season{border-color:#9ca3af;background:#f3f4f6}.season-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.season-title{font-size:1.125rem;font-weight:600;margin:0}.high-season .season-title{color:#111827}.low-season .season-title{color:#374151}.season-days{background:#0000001a;color:#374151;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600}.season-consumption{margin-bottom:1rem}.consumption-item{display:flex;justify-content:space-between;align-items:center;padding:.375rem 0;font-size:.875rem}.consumption-total{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;font-weight:600;border-top:1px solid #e5e7eb;margin-top:.5rem}.consumption-label{color:#6b7280}.consumption-value{font-weight:500;color:#1f2937}.season-cost{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#ffffffb3;border-radius:8px;font-weight:600}.cost-label{color:#374151}.cost-value{color:#059669;font-size:1.125rem}.season-segments{margin-top:2rem}.segments-title{font-size:1rem;font-weight:600;color:#1f2937;margin:0 0 1rem}.season-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;display:inline-block}.season-badge.high{background:#111827;color:#fff}.season-badge.low{background:#6b7280;color:#fff}.high-season-row{background:#fef2f2}.low-season-row{background:#ecfdf5}.payment-notes{background:#fff;padding:1.25rem;border-radius:8px;box-shadow:0 1px 3px #0000001a}.payment-list{margin:.75rem 0 0;padding-left:1.25rem;list-style-type:disc}.payment-list li{margin-bottom:.5rem;color:#475569;font-size:.875rem;line-height:1.5}.download-actions{text-align:center;background:linear-gradient(135deg,#fefce8,#fef3c7);border:2px solid #f59e0b}.download-buttons{display:flex;justify-content:center;gap:1rem}.download-pdf-btn{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#000,#333);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;transition:all .2s;box-shadow:0 4px 6px -1px #0000004d}.download-pdf-btn:hover{transform:translateY(-1px);box-shadow:0 6px 8px -1px #dc262666}.download-pdf-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.download-icon{width:16px;height:16px}.error-message{display:flex;align-items:center;gap:.5rem;background:#fef2f2;color:#dc2626;padding:.75rem;border-radius:8px;border:1px solid #fecaca;margin-top:1rem;font-size:.875rem}@media(max-width:768px){.billing-page{padding:1rem}.controls-grid,.payment-grid{grid-template-columns:1fr;gap:1rem}.building-info-content{flex-direction:column;gap:1rem;text-align:center}.table-header-row,.table-row{grid-template-columns:1fr;gap:.5rem}.table-header-cell,.table-cell{text-align:left;padding:.5rem}}.season-segments-table .table-header-row{display:grid;grid-template-columns:2fr 2fr 1fr 1.5fr 1.5fr;background:linear-gradient(135deg,#1f2937,#111827);color:#fff}.season-segments-table .table-row{display:grid;grid-template-columns:2fr 2fr 1fr 1.5fr 1.5fr;border-bottom:1px solid #f1f5f9}.season-segments-table .table-header-cell{padding:.75rem;font-weight:600;font-size:.875rem;text-align:center;display:flex;align-items:center;justify-content:center}.season-segments-table .table-cell{padding:.75rem;display:flex;align-items:center;font-size:.875rem}.season-segments-table .table-cell:nth-child(1){justify-content:flex-start}.season-segments-table .table-cell:nth-child(2){justify-content:flex-start}.season-segments-table .table-cell:nth-child(3){justify-content:center}.season-segments-table .table-cell:nth-child(4){justify-content:flex-end}.season-segments-table .table-cell:nth-child(5){justify-content:flex-end;font-weight:500;color:#059669}.tou-single-season .table-header-row{display:grid;grid-template-columns:2fr 1fr 1.5fr 1.5fr 1fr;background:linear-gradient(135deg,#1f2937,#111827);color:#fff}.tou-single-season .table-row{display:grid;grid-template-columns:2fr 1fr 1.5fr 1.5fr 1fr;border-bottom:1px solid #f1f5f9}.tou-mixed-season .table-header-row{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr 1.5fr 1fr;background:linear-gradient(135deg,#1f2937,#111827);color:#fff}.tou-mixed-season .table-row{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr 1.5fr 1fr;border-bottom:1px solid #f1f5f9}.consumption-charges .table-header-cell{padding:.75rem;font-weight:600;font-size:.875rem;text-align:center;display:flex;align-items:center;justify-content:center}.consumption-charges .table-cell{padding:.75rem;display:flex;align-items:center;font-size:.875rem}.consumption-charges .table-cell:nth-child(1){justify-content:flex-start}.consumption-charges .table-cell:nth-child(2){justify-content:center}.consumption-charges .table-cell:nth-child(3){justify-content:flex-end}.tou-single-season .table-cell:nth-child(4){justify-content:center}.tou-single-season .table-cell:nth-child(5){justify-content:flex-end;font-weight:500;color:#059669}.tou-mixed-season .table-cell:nth-child(4),.tou-mixed-season .table-cell:nth-child(5){justify-content:flex-end}.tou-mixed-season .table-cell:nth-child(6){justify-content:center}.tou-mixed-season .table-cell:nth-child(7){justify-content:flex-end;font-weight:500;color:#059669}.additional-charges-table .table-header-row{display:grid;grid-template-columns:3fr 1.5fr 1.5fr 2fr;background:linear-gradient(135deg,#1f2937,#111827);color:#fff}.additional-charges-table .table-row{display:grid;grid-template-columns:3fr 1.5fr 1.5fr 2fr;border-bottom:1px solid #f1f5f9}.additional-charges-table .table-header-cell{padding:.75rem;font-weight:600;font-size:.875rem;text-align:center;display:flex;align-items:center;justify-content:center}.additional-charges-table .table-cell{padding:.75rem;display:flex;align-items:center;font-size:.875rem}.additional-charges-table .table-cell:nth-child(1){justify-content:flex-start}.additional-charges-table .table-cell:nth-child(2){justify-content:center}.additional-charges-table .table-cell:nth-child(3){justify-content:flex-end}.additional-charges-table .table-cell:nth-child(4){justify-content:flex-end;font-weight:500;color:#059669}.dual-rates{display:flex;flex-direction:column;align-items:center;gap:.2rem;font-size:.8rem}.rate-line{font-weight:500}.rate-line.high-season{color:#111827}.rate-line.low-season{color:#6b7280}.dual-charges{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem;font-size:.8rem}.charge-line{font-weight:500}.charge-line.high-season{color:#111827}.charge-line.low-season{color:#6b7280}.classification-badge{padding:4px 12px;border-radius:9999px;font-size:12px;font-weight:600;background-color:#f3f4f6!important;color:#1f2937!important;border:1px solid #e5e7eb}.classification-badge.business,.classification-badge.residential,.classification-badge.commercial{background-color:#f3f4f6!important;color:#1f2937!important;border:1px solid #d1d5db}.under-construction-icon{color:#374151!important;background-color:#f3f4f6!important;padding:16px;border-radius:50%;display:inline-flex;margin-bottom:16px}.overview-notice{background-color:#f8fafc!important;border:1px solid #e2e8f0!important;color:#64748b!important}.overview-notice svg{color:#94a3b8!important}.insight-label{color:#6b7280!important}.insight-value{color:#111827!important}
