*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.18 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}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{text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background:0 0% 100%;--foreground:210 40% 15%;--card:0 0% 100%;--card-foreground:210 40% 15%;--popover:0 0% 100%;--popover-foreground:210 40% 15%;--primary:209 47% 23%;--primary-foreground:0 0% 98%;--secondary:210 40% 96.1%;--secondary-foreground:209 47% 23%;--muted:210 40% 96.1%;--muted-foreground:215 20% 45%;--accent:209 47% 23%;--accent-foreground:0 0% 98%;--destructive:0 84.2% 60.2%;--destructive-foreground:0 0% 98%;--border:214 32% 91%;--input:214 32% 91%;--ring:209 47% 23%;--radius:0.5rem}.dark{--background:210 40% 10%;--foreground:0 0% 98%;--card:210 40% 12%;--card-foreground:0 0% 98%;--popover:210 40% 10%;--popover-foreground:0 0% 98%;--primary:0 0% 98%;--primary-foreground:209 47% 23%;--secondary:215 20% 20%;--secondary-foreground:0 0% 98%;--muted:215 20% 20%;--muted-foreground:215 20% 65%;--accent:215 20% 20%;--accent-foreground:0 0% 98%;--destructive:0 62.8% 30.6%;--destructive-foreground:0 0% 98%;--border:215 20% 20%;--input:215 20% 20%;--ring:0 0% 83.1%}*{border-color:#e1e7ef;border-color:hsl(var(--border))}body{background-color:#fff;background-color:hsl(var(--background));color:#172636;color:hsl(var(--foreground))}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.visible{visibility:visible}.invisible{visibility:hidden}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-x-0{left:0;right:0}.inset-y-0{bottom:0;top:0}.-bottom-12{bottom:-3rem}.-left-12{left:-3rem}.-right-12{right:-3rem}.-top-12{top:-3rem}.bottom-0{bottom:0}.left-0{left:0}.left-1{left:.25rem}.left-1\/2{left:50%}.left-2{left:.5rem}.left-\[50\%\]{left:50%}.right-0{right:0}.right-1{right:.25rem}.right-2{right:.5rem}.right-4{right:1rem}.top-0{top:0}.top-1{top:.25rem}.top-1\/2{top:50%}.top-4{top:1rem}.top-\[1px\]{top:1px}.top-\[50\%\]{top:50%}.top-\[60\%\]{top:60%}.top-full{top:100%}.z-10{z-index:10}.z-50{z-index:50}.z-\[100\]{z-index:100}.z-\[1\]{z-index:1}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-bottom:.25rem;margin-top:.25rem}.-ml-4{margin-left:-1rem}.-mt-4{margin-top:-1rem}.mb-1{margin-bottom:.25rem}.ml-1{margin-left:.25rem}.ml-auto{margin-left:auto}.mr-2{margin-right:.5rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-24{margin-top:6rem}.mt-4{margin-top:1rem}.mt-auto{margin-top:auto}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.table-row{display:table-row}.grid{display:grid}.hidden{display:none}.aspect-square{aspect-ratio:1/1}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[1px\]{height:1px}.h-\[var\(--radix-navigation-menu-viewport-height\)\]{height:var(--radix-navigation-menu-viewport-height)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.max-h-\[--radix-context-menu-content-available-height\]{max-height:var(--radix-context-menu-content-available-height)}.max-h-\[--radix-select-content-available-height\]{max-height:var(--radix-select-content-available-height)}.max-h-\[300px\]{max-height:300px}.max-h-\[var\(--radix-dropdown-menu-content-available-height\)\]{max-height:var(--radix-dropdown-menu-content-available-height)}.max-h-screen{max-height:100vh}.min-h-\[60px\]{min-height:60px}.w-10{width:2.5rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-3\/4{width:75%}.w-4{width:1rem}.w-64{width:16rem}.w-7{width:1.75rem}.w-72{width:18rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-\[100px\]{width:100px}.w-\[1px\]{width:1px}.w-full{width:100%}.w-max{width:-webkit-max-content;width:max-content}.w-px{width:1px}.min-w-0{min-width:0}.min-w-10{min-width:2.5rem}.min-w-8{min-width:2rem}.min-w-9{min-width:2.25rem}.min-w-\[12rem\]{min-width:12rem}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.max-w-lg{max-width:32rem}.max-w-max{max-width:-webkit-max-content;max-width:max-content}.flex-1{flex:1 1}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.grow-0{flex-grow:0}.basis-full{flex-basis:100%}.caption-bottom{caption-side:bottom}.border-collapse{border-collapse:collapse}.origin-\[--radix-context-menu-content-transform-origin\]{transform-origin:var(--radix-context-menu-content-transform-origin)}.origin-\[--radix-dropdown-menu-content-transform-origin\]{transform-origin:var(--radix-dropdown-menu-content-transform-origin)}.origin-\[--radix-hover-card-content-transform-origin\]{transform-origin:var(--radix-hover-card-content-transform-origin)}.origin-\[--radix-menubar-content-transform-origin\]{transform-origin:var(--radix-menubar-content-transform-origin)}.origin-\[--radix-popover-content-transform-origin\]{transform-origin:var(--radix-popover-content-transform-origin)}.origin-\[--radix-select-content-transform-origin\]{transform-origin:var(--radix-select-content-transform-origin)}.origin-\[--radix-tooltip-content-transform-origin\]{transform-origin:var(--radix-tooltip-content-transform-origin)}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.-translate-y-1\/2{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-1\/2{--tw-translate-y:-50%}.translate-x-\[-50\%\]{--tw-translate-x:-50%}.translate-x-\[-50\%\],.translate-y-\[-50\%\]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-\[-50\%\]{--tw-translate-y:-50%}.rotate-45{--tw-rotate:45deg}.rotate-45,.rotate-90{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-90{--tw-rotate:90deg}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.select-none{-webkit-user-select:none;user-select:none}.resize{resize:both}.list-none{list-style-type:none}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.25rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.25rem*var(--tw-space-x-reverse))}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.25rem*var(--tw-space-y-reverse));margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.375rem*var(--tw-space-y-reverse));margin-top:calc(.375rem*(1 - var(--tw-space-y-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.5rem*var(--tw-space-y-reverse));margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1rem*var(--tw-space-y-reverse));margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.whitespace-nowrap{white-space:nowrap}.break-words{overflow-wrap:break-word}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem;border-radius:var(--radius)}.rounded-md{border-radius:calc(.5rem - 2px);border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(.5rem - 4px);border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:.75rem}.rounded-t-\[10px\]{border-top-left-radius:10px;border-top-right-radius:10px}.rounded-tl-sm{border-top-left-radius:calc(.5rem - 4px);border-top-left-radius:calc(var(--radius) - 4px)}.border{border-width:1px}.border-2{border-width:2px}.border-y{border-top-width:1px}.border-b,.border-y{border-bottom-width:1px}.border-l{border-left-width:1px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-destructive{border-color:#ef4444;border-color:hsl(var(--destructive))}.border-destructive\/50{border-color:#ef444480;border-color:hsl(var(--destructive)/.5)}.border-input{border-color:#e1e7ef;border-color:hsl(var(--input))}.border-primary{border-color:#1f3c56;border-color:hsl(var(--primary))}.border-primary\/50{border-color:#1f3c5680;border-color:hsl(var(--primary)/.5)}.border-transparent{border-color:#0000}.border-l-transparent{border-left-color:#0000}.border-t-transparent{border-top-color:#0000}.bg-accent{background-color:#1f3c56;background-color:hsl(var(--accent))}.bg-background{background-color:#fff;background-color:hsl(var(--background))}.bg-black\/80{background-color:#000c}.bg-border{background-color:#e1e7ef;background-color:hsl(var(--border))}.bg-card{background-color:#fff;background-color:hsl(var(--card))}.bg-destructive{background-color:#ef4444;background-color:hsl(var(--destructive))}.bg-foreground{background-color:#172636;background-color:hsl(var(--foreground))}.bg-muted{background-color:#f1f5f9;background-color:hsl(var(--muted))}.bg-muted\/50{background-color:#f1f5f980;background-color:hsl(var(--muted)/.5)}.bg-popover{background-color:#fff;background-color:hsl(var(--popover))}.bg-primary{background-color:#1f3c56;background-color:hsl(var(--primary))}.bg-primary\/10{background-color:#1f3c561a;background-color:hsl(var(--primary)/.1)}.bg-primary\/20{background-color:#1f3c5633;background-color:hsl(var(--primary)/.2)}.bg-secondary{background-color:#f1f5f9;background-color:hsl(var(--secondary))}.bg-transparent{background-color:initial}.fill-current{fill:currentColor}.fill-primary{fill:#1f3c56;fill:hsl(var(--primary))}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-\[1px\]{padding:1px}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-bottom:.125rem;padding-top:.125rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-1\.5{padding-bottom:.375rem;padding-top:.375rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-4{padding-bottom:1rem;padding-top:1rem}.py-6{padding-bottom:1.5rem;padding-top:1.5rem}.pb-4{padding-bottom:1rem}.pl-2{padding-left:.5rem}.pl-2\.5{padding-left:.625rem}.pl-4{padding-left:1rem}.pl-8{padding-left:2rem}.pr-2{padding-right:.5rem}.pr-2\.5{padding-right:.625rem}.pr-6{padding-right:1.5rem}.pr-8{padding-right:2rem}.pt-0{padding-top:0}.pt-1{padding-top:.25rem}.pt-4{padding-top:1rem}.text-left{text-align:left}.align-middle{vertical-align:middle}.text-\[0\.8rem\]{font-size:.8rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.italic{font-style:italic}.leading-none{line-height:1}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-accent-foreground{color:#fafafa;color:hsl(var(--accent-foreground))}.text-card-foreground{color:#172636;color:hsl(var(--card-foreground))}.text-current{color:currentColor}.text-destructive{color:#ef4444;color:hsl(var(--destructive))}.text-destructive-foreground{color:#fafafa;color:hsl(var(--destructive-foreground))}.text-foreground{color:#172636;color:hsl(var(--foreground))}.text-foreground\/50{color:#17263680;color:hsl(var(--foreground)/.5)}.text-muted-foreground{color:#5c6f8a;color:hsl(var(--muted-foreground))}.text-popover-foreground{color:#172636;color:hsl(var(--popover-foreground))}.text-primary{color:#1f3c56;color:hsl(var(--primary))}.text-primary-foreground{color:#fafafa;color:hsl(var(--primary-foreground))}.text-secondary-foreground{color:#1f3c56;color:hsl(var(--secondary-foreground))}.underline{-webkit-text-decoration-line:underline;text-decoration-line:underline}.underline-offset-4{text-underline-offset:4px}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-90{opacity:.9}.shadow{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.shadow,.shadow-lg{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-md{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-md,.shadow-sm{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.outline-none{outline:2px solid #0000;outline-offset:2px}.outline{outline-style:solid}.ring-0{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-0,.ring-1{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-1{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-ring{--tw-ring-color:hsl(var(--ring))}.ring-offset-background{--tw-ring-offset-color:hsl(var(--background))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,-webkit-text-decoration-color;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,-webkit-text-decoration-color;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-opacity{transition-duration:.15s;transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-duration:.15s;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-1000{transition-duration:1s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}@keyframes enter{0%{opacity:1;opacity:var(--tw-enter-opacity,1);transform:translateZ(0) scaleX(1) rotate(0);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0) scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1)) rotate(var(--tw-enter-rotate,0))}}@keyframes exit{to{opacity:1;opacity:var(--tw-exit-opacity,1);transform:translateZ(0) scaleX(1) rotate(0);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0) scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1)) rotate(var(--tw-exit-rotate,0))}}.animate-in{--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial;animation-duration:.15s;animation-name:enter}.fade-in-0{--tw-enter-opacity:0}.zoom-in-95{--tw-enter-scale:.95}.duration-1000{animation-duration:1s}.duration-200{animation-duration:.2s}.duration-300{animation-duration:.3s}.ease-in-out{animation-timing-function:cubic-bezier(.4,0,.2,1)}.running{animation-play-state:running}:root{--tarc-navy:#1a3d5c;--tarc-blue:#2c5f8d;--tarc-light-blue:#4a7ba7;--tarc-dark:#0f1e2e;--tarc-white:#fff;--tarc-cream:#f5f1e8;--tarc-gray:#64748b;--tarc-light-gray:#e2e8f0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.file\:border-0::-webkit-file-upload-button{border-width:0}.file\:border-0::file-selector-button{border-width:0}.file\:bg-transparent::-webkit-file-upload-button{background-color:initial}.file\:bg-transparent::file-selector-button{background-color:initial}.file\:text-sm::-webkit-file-upload-button{font-size:.875rem;line-height:1.25rem}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::-webkit-file-upload-button{font-weight:500}.file\:font-medium::file-selector-button{font-weight:500}.file\:text-foreground::-webkit-file-upload-button{color:#172636;color:hsl(var(--foreground))}.file\:text-foreground::file-selector-button{color:#172636;color:hsl(var(--foreground))}.placeholder\:text-muted-foreground::placeholder{color:#5c6f8a;color:hsl(var(--muted-foreground))}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:inset-y-0:after{bottom:0;content:var(--tw-content);top:0}.after\:left-1\/2:after{content:var(--tw-content);left:50%}.after\:w-1:after{content:var(--tw-content);width:.25rem}.after\:-translate-x-1\/2:after{--tw-translate-x:-50%;content:var(--tw-content);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.first\:rounded-l-md:first-child{border-bottom-left-radius:calc(.5rem - 2px);border-bottom-left-radius:calc(var(--radius) - 2px);border-top-left-radius:calc(.5rem - 2px);border-top-left-radius:calc(var(--radius) - 2px)}.first\:border-l:first-child{border-left-width:1px}.last\:rounded-r-md:last-child{border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.focus-within\:relative:focus-within{position:relative}.focus-within\:z-20:focus-within{z-index:20}.hover\:bg-accent:hover{background-color:#1f3c56;background-color:hsl(var(--accent))}.hover\:bg-destructive\/80:hover{background-color:#ef4444cc;background-color:hsl(var(--destructive)/.8)}.hover\:bg-destructive\/90:hover{background-color:#ef4444e6;background-color:hsl(var(--destructive)/.9)}.hover\:bg-muted:hover{background-color:#f1f5f9;background-color:hsl(var(--muted))}.hover\:bg-muted\/50:hover{background-color:#f1f5f980;background-color:hsl(var(--muted)/.5)}.hover\:bg-primary:hover{background-color:#1f3c56;background-color:hsl(var(--primary))}.hover\:bg-primary\/80:hover{background-color:#1f3c56cc;background-color:hsl(var(--primary)/.8)}.hover\:bg-primary\/90:hover{background-color:#1f3c56e6;background-color:hsl(var(--primary)/.9)}.hover\:bg-secondary:hover{background-color:#f1f5f9;background-color:hsl(var(--secondary))}.hover\:bg-secondary\/80:hover{background-color:#f1f5f9cc;background-color:hsl(var(--secondary)/.8)}.hover\:text-accent-foreground:hover{color:#fafafa;color:hsl(var(--accent-foreground))}.hover\:text-foreground:hover{color:#172636;color:hsl(var(--foreground))}.hover\:text-muted-foreground:hover{color:#5c6f8a;color:hsl(var(--muted-foreground))}.hover\:text-primary-foreground:hover{color:#fafafa;color:hsl(var(--primary-foreground))}.hover\:underline:hover{-webkit-text-decoration-line:underline;text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.focus\:bg-accent:focus{background-color:#1f3c56;background-color:hsl(var(--accent))}.focus\:bg-primary:focus{background-color:#1f3c56;background-color:hsl(var(--primary))}.focus\:text-accent-foreground:focus{color:#fafafa;color:hsl(var(--accent-foreground))}.focus\:text-primary-foreground:focus{color:#fafafa;color:hsl(var(--primary-foreground))}.focus\:opacity-100:focus{opacity:1}.focus\:outline-none:focus{outline:2px solid #0000;outline-offset:2px}.focus\:ring-1:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-1:focus,.focus\:ring-2:focus{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-ring:focus{--tw-ring-color:hsl(var(--ring))}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.focus-visible\:outline-none:focus-visible{outline:2px solid #0000;outline-offset:2px}.focus-visible\:ring-1:focus-visible{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color:hsl(var(--ring))}.focus-visible\:ring-offset-1:focus-visible{--tw-ring-offset-width:1px}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color:hsl(var(--background))}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:opacity-100{opacity:1}.group.destructive .group-\[\.destructive\]\:border-muted\/40{border-color:#f1f5f966;border-color:hsl(var(--muted)/.4)}.group.toaster .group-\[\.toaster\]\:border-border{border-color:#e1e7ef;border-color:hsl(var(--border))}.group.toast .group-\[\.toast\]\:bg-muted{background-color:#f1f5f9;background-color:hsl(var(--muted))}.group.toast .group-\[\.toast\]\:bg-primary{background-color:#1f3c56;background-color:hsl(var(--primary))}.group.toaster .group-\[\.toaster\]\:bg-background{background-color:#fff;background-color:hsl(var(--background))}.group.destructive .group-\[\.destructive\]\:text-red-300{--tw-text-opacity:1;color:#fca5a5;color:rgb(252 165 165/var(--tw-text-opacity,1))}.group.toast .group-\[\.toast\]\:text-muted-foreground{color:#5c6f8a;color:hsl(var(--muted-foreground))}.group.toast .group-\[\.toast\]\:text-primary-foreground{color:#fafafa;color:hsl(var(--primary-foreground))}.group.toaster .group-\[\.toaster\]\:text-foreground{color:#172636;color:hsl(var(--foreground))}.group.toaster .group-\[\.toaster\]\:shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.group.destructive .group-\[\.destructive\]\:hover\:border-destructive\/30:hover{border-color:#ef44444d;border-color:hsl(var(--destructive)/.3)}.group.destructive .group-\[\.destructive\]\:hover\:bg-destructive:hover{background-color:#ef4444;background-color:hsl(var(--destructive))}.group.destructive .group-\[\.destructive\]\:hover\:text-destructive-foreground:hover{color:#fafafa;color:hsl(var(--destructive-foreground))}.group.destructive .group-\[\.destructive\]\:hover\:text-red-50:hover{--tw-text-opacity:1;color:#fef2f2;color:rgb(254 242 242/var(--tw-text-opacity,1))}.group.destructive .group-\[\.destructive\]\:focus\:ring-destructive:focus{--tw-ring-color:hsl(var(--destructive))}.group.destructive .group-\[\.destructive\]\:focus\:ring-red-400:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(248 113 113/var(--tw-ring-opacity,1))}.group.destructive .group-\[\.destructive\]\:focus\:ring-offset-red-600:focus{--tw-ring-offset-color:#dc2626}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.has-\[\:disabled\]\:opacity-50:has(:disabled){opacity:.5}.aria-selected\:bg-accent[aria-selected=true]{background-color:#1f3c56;background-color:hsl(var(--accent))}.aria-selected\:bg-accent\/50[aria-selected=true]{background-color:#1f3c5680;background-color:hsl(var(--accent)/.5)}.aria-selected\:text-accent-foreground[aria-selected=true]{color:#fafafa;color:hsl(var(--accent-foreground))}.aria-selected\:text-muted-foreground[aria-selected=true]{color:#5c6f8a;color:hsl(var(--muted-foreground))}.aria-selected\:opacity-100[aria-selected=true]{opacity:1}.data-\[disabled\=true\]\:pointer-events-none[data-disabled=true],.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[panel-group-direction\=vertical\]\:h-px[data-panel-group-direction=vertical]{height:1px}.data-\[panel-group-direction\=vertical\]\:w-full[data-panel-group-direction=vertical]{width:100%}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:0.25rem}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom],.data-\[side\=left\]\:-translate-x-1[data-side=left]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:-0.25rem}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:0.25rem}.data-\[side\=right\]\:translate-x-1[data-side=right],.data-\[side\=top\]\:-translate-y-1[data-side=top]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:-0.25rem}.data-\[state\=checked\]\:translate-x-4[data-state=checked]{--tw-translate-x:1rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked],.data-\[swipe\=cancel\]\:translate-x-0[data-swipe=cancel]{--tw-translate-x:0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[swipe\=end\]\:translate-x-\[var\(--radix-toast-swipe-end-x\)\][data-swipe=end]{--tw-translate-x:var(--radix-toast-swipe-end-x)}.data-\[swipe\=end\]\:translate-x-\[var\(--radix-toast-swipe-end-x\)\][data-swipe=end],.data-\[swipe\=move\]\:translate-x-\[var\(--radix-toast-swipe-move-x\)\][data-swipe=move]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[swipe\=move\]\:translate-x-\[var\(--radix-toast-swipe-move-x\)\][data-swipe=move]{--tw-translate-x:var(--radix-toast-swipe-move-x)}@keyframes accordion-up{0%{height:var(--radix-accordion-content-height)}to{height:0}}.data-\[state\=closed\]\:animate-accordion-up[data-state=closed]{animation:accordion-up .2s ease-out}@keyframes accordion-down{0%{height:0}to{height:var(--radix-accordion-content-height)}}.data-\[state\=open\]\:animate-accordion-down[data-state=open]{animation:accordion-down .2s ease-out}.data-\[panel-group-direction\=vertical\]\:flex-col[data-panel-group-direction=vertical]{flex-direction:column}.data-\[selected\=true\]\:bg-accent[data-selected=true]{background-color:#1f3c56;background-color:hsl(var(--accent))}.data-\[state\=active\]\:bg-background[data-state=active]{background-color:#fff;background-color:hsl(var(--background))}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:#1f3c56;background-color:hsl(var(--primary))}.data-\[state\=on\]\:bg-accent[data-state=on],.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:#1f3c56;background-color:hsl(var(--accent))}.data-\[state\=open\]\:bg-accent\/50[data-state=open]{background-color:#1f3c5680;background-color:hsl(var(--accent)/.5)}.data-\[state\=open\]\:bg-secondary[data-state=open]{background-color:#f1f5f9;background-color:hsl(var(--secondary))}.data-\[state\=selected\]\:bg-muted[data-state=selected]{background-color:#f1f5f9;background-color:hsl(var(--muted))}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:#e1e7ef;background-color:hsl(var(--input))}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{color:#5c6f8a;color:hsl(var(--muted-foreground))}.data-\[selected\=true\]\:text-accent-foreground[data-selected=true]{color:#fafafa;color:hsl(var(--accent-foreground))}.data-\[state\=active\]\:text-foreground[data-state=active]{color:#172636;color:hsl(var(--foreground))}.data-\[state\=checked\]\:text-primary-foreground[data-state=checked]{color:#fafafa;color:hsl(var(--primary-foreground))}.data-\[state\=on\]\:text-accent-foreground[data-state=on],.data-\[state\=open\]\:text-accent-foreground[data-state=open]{color:#fafafa;color:hsl(var(--accent-foreground))}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:#5c6f8a;color:hsl(var(--muted-foreground))}.data-\[disabled\=true\]\:opacity-50[data-disabled=true],.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=active\]\:shadow[data-state=active]{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.data-\[swipe\=move\]\:transition-none[data-swipe=move]{transition-property:none}.data-\[state\=closed\]\:duration-300[data-state=closed]{transition-duration:.3s}.data-\[state\=open\]\:duration-500[data-state=open]{transition-duration:.5s}.data-\[motion\^\=from-\]\:animate-in[data-motion^=from-],.data-\[state\=open\]\:animate-in[data-state=open],.data-\[state\=visible\]\:animate-in[data-state=visible]{--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial;animation-duration:.15s;animation-name:enter}.data-\[motion\^\=to-\]\:animate-out[data-motion^=to-],.data-\[state\=closed\]\:animate-out[data-state=closed],.data-\[state\=hidden\]\:animate-out[data-state=hidden],.data-\[swipe\=end\]\:animate-out[data-swipe=end]{--tw-exit-opacity:initial;--tw-exit-scale:initial;--tw-exit-rotate:initial;--tw-exit-translate-x:initial;--tw-exit-translate-y:initial;animation-duration:.15s;animation-name:exit}.data-\[motion\^\=from-\]\:fade-in[data-motion^=from-]{--tw-enter-opacity:0}.data-\[motion\^\=to-\]\:fade-out[data-motion^=to-],.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=closed\]\:fade-out-80[data-state=closed]{--tw-exit-opacity:0.8}.data-\[state\=hidden\]\:fade-out[data-state=hidden]{--tw-exit-opacity:0}.data-\[state\=open\]\:fade-in-0[data-state=open],.data-\[state\=visible\]\:fade-in[data-state=visible]{--tw-enter-opacity:0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}.data-\[state\=open\]\:zoom-in-90[data-state=open]{--tw-enter-scale:.9}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale:.95}.data-\[motion\=from-end\]\:slide-in-from-right-52[data-motion=from-end]{--tw-enter-translate-x:13rem}.data-\[motion\=from-start\]\:slide-in-from-left-52[data-motion=from-start]{--tw-enter-translate-x:-13rem}.data-\[motion\=to-end\]\:slide-out-to-right-52[data-motion=to-end]{--tw-exit-translate-x:13rem}.data-\[motion\=to-start\]\:slide-out-to-left-52[data-motion=to-start]{--tw-exit-translate-x:-13rem}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y:-0.5rem}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x:0.5rem}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x:-0.5rem}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y:0.5rem}.data-\[state\=closed\]\:slide-out-to-bottom[data-state=closed]{--tw-exit-translate-y:100%}.data-\[state\=closed\]\:slide-out-to-left[data-state=closed]{--tw-exit-translate-x:-100%}.data-\[state\=closed\]\:slide-out-to-left-1\/2[data-state=closed]{--tw-exit-translate-x:-50%}.data-\[state\=closed\]\:slide-out-to-right-full[data-state=closed],.data-\[state\=closed\]\:slide-out-to-right[data-state=closed]{--tw-exit-translate-x:100%}.data-\[state\=closed\]\:slide-out-to-top[data-state=closed]{--tw-exit-translate-y:-100%}.data-\[state\=closed\]\:slide-out-to-top-\[48\%\][data-state=closed]{--tw-exit-translate-y:-48%}.data-\[state\=open\]\:slide-in-from-bottom[data-state=open]{--tw-enter-translate-y:100%}.data-\[state\=open\]\:slide-in-from-left[data-state=open]{--tw-enter-translate-x:-100%}.data-\[state\=open\]\:slide-in-from-left-1\/2[data-state=open]{--tw-enter-translate-x:-50%}.data-\[state\=open\]\:slide-in-from-right[data-state=open]{--tw-enter-translate-x:100%}.data-\[state\=open\]\:slide-in-from-top[data-state=open]{--tw-enter-translate-y:-100%}.data-\[state\=open\]\:slide-in-from-top-\[48\%\][data-state=open]{--tw-enter-translate-y:-48%}.data-\[state\=open\]\:slide-in-from-top-full[data-state=open]{--tw-enter-translate-y:-100%}.data-\[state\=closed\]\:duration-300[data-state=closed]{animation-duration:.3s}.data-\[state\=open\]\:duration-500[data-state=open]{animation-duration:.5s}.data-\[panel-group-direction\=vertical\]\:after\:left-0[data-panel-group-direction=vertical]:after{content:var(--tw-content);left:0}.data-\[panel-group-direction\=vertical\]\:after\:h-1[data-panel-group-direction=vertical]:after{content:var(--tw-content);height:.25rem}.data-\[panel-group-direction\=vertical\]\:after\:w-full[data-panel-group-direction=vertical]:after{content:var(--tw-content);width:100%}.data-\[panel-group-direction\=vertical\]\:after\:-translate-y-1\/2[data-panel-group-direction=vertical]:after{--tw-translate-y:-50%;content:var(--tw-content);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[panel-group-direction\=vertical\]\:after\:translate-x-0[data-panel-group-direction=vertical]:after{--tw-translate-x:0px;content:var(--tw-content);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=open\]\:focus\:bg-accent:focus[data-state=open],.data-\[state\=open\]\:hover\:bg-accent:hover[data-state=open]{background-color:#1f3c56;background-color:hsl(var(--accent))}.group[data-state=open] .group-data-\[state\=open\]\:rotate-180{--tw-rotate:180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.dark\:border-destructive:is(.dark *){border-color:#ef4444;border-color:hsl(var(--destructive))}@media (min-width:640px){.sm\:bottom-0{bottom:0}.sm\:right-0{right:0}.sm\:top-auto{top:auto}.sm\:mt-0{margin-top:0}.sm\:max-w-sm{max-width:24rem}.sm\:flex-row{flex-direction:row}.sm\:flex-col{flex-direction:column}.sm\:justify-end{justify-content:flex-end}.sm\:gap-2\.5{gap:.625rem}.sm\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.sm\:space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1rem*var(--tw-space-x-reverse))}.sm\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(0px*var(--tw-space-y-reverse));margin-top:calc(0px*(1 - var(--tw-space-y-reverse)))}.sm\:rounded-lg{border-radius:.5rem;border-radius:var(--radius)}.sm\:text-left{text-align:left}.data-\[state\=open\]\:sm\:slide-in-from-bottom-full[data-state=open]{--tw-enter-translate-y:100%}}@media (min-width:768px){.md\:absolute{position:absolute}.md\:w-\[var\(--radix-navigation-menu-viewport-width\)\]{width:var(--radix-navigation-menu-viewport-width)}.md\:w-auto{width:auto}.md\:max-w-\[420px\]{max-width:420px}.md\:text-sm{font-size:.875rem;line-height:1.25rem}}.\[\&\+div\]\:text-xs+div{font-size:.75rem;line-height:1rem}.\[\&\:has\(\>\.day-range-end\)\]\:rounded-r-md:has(>.day-range-end){border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\>\.day-range-start\)\]\:rounded-l-md:has(>.day-range-start){border-bottom-left-radius:calc(.5rem - 2px);border-bottom-left-radius:calc(var(--radius) - 2px);border-top-left-radius:calc(.5rem - 2px);border-top-left-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\)\]\:rounded-md:has([aria-selected]){border-radius:calc(.5rem - 2px);border-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\)\]\:bg-accent:has([aria-selected]){background-color:#1f3c56;background-color:hsl(var(--accent))}.first\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-l-md:has([aria-selected]):first-child{border-bottom-left-radius:calc(.5rem - 2px);border-bottom-left-radius:calc(var(--radius) - 2px);border-top-left-radius:calc(.5rem - 2px);border-top-left-radius:calc(var(--radius) - 2px)}.last\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-r-md:has([aria-selected]):last-child{border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\.day-outside\)\]\:bg-accent\/50:has([aria-selected].day-outside){background-color:#1f3c5680;background-color:hsl(var(--accent)/.5)}.\[\&\:has\(\[aria-selected\]\.day-range-end\)\]\:rounded-r-md:has([aria-selected].day-range-end){border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0:has([role=checkbox]){padding-right:0}.\[\&\>\[role\=checkbox\]\]\:translate-y-\[2px\]>[role=checkbox]{--tw-translate-y:2px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\>span\]\:line-clamp-1>span{-webkit-box-orient:vertical;-webkit-line-clamp:1;display:-webkit-box;overflow:hidden}.\[\&\>svg\+div\]\:translate-y-\[-3px\]>svg+div{--tw-translate-y:-3px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\>svg\]\:absolute>svg{position:absolute}.\[\&\>svg\]\:left-4>svg{left:1rem}.\[\&\>svg\]\:top-4>svg{top:1rem}.\[\&\>svg\]\:size-4>svg{height:1rem;width:1rem}.\[\&\>svg\]\:h-3\.5>svg{height:.875rem}.\[\&\>svg\]\:w-3\.5>svg{width:.875rem}.\[\&\>svg\]\:shrink-0>svg{flex-shrink:0}.\[\&\>svg\]\:text-destructive>svg{color:#ef4444;color:hsl(var(--destructive))}.\[\&\>svg\]\:text-foreground>svg{color:#172636;color:hsl(var(--foreground))}.\[\&\>svg\~\*\]\:pl-7>svg~*{padding-left:1.75rem}.\[\&\>tr\]\:last\:border-b-0:last-child>tr{border-bottom-width:0}.\[\&\[data-panel-group-direction\=vertical\]\>div\]\:rotate-90[data-panel-group-direction=vertical]>div{--tw-rotate:90deg}.\[\&\[data-panel-group-direction\=vertical\]\>div\]\:rotate-90[data-panel-group-direction=vertical]>div,.\[\&\[data-state\=open\]\>svg\]\:rotate-180[data-state=open]>svg{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\[data-state\=open\]\>svg\]\:rotate-180[data-state=open]>svg{--tw-rotate:180deg}.\[\&_\[cmdk-group-heading\]\]\:px-2 [cmdk-group-heading]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-group-heading\]\]\:py-1\.5 [cmdk-group-heading]{padding-bottom:.375rem;padding-top:.375rem}.\[\&_\[cmdk-group-heading\]\]\:text-xs [cmdk-group-heading]{font-size:.75rem;line-height:1rem}.\[\&_\[cmdk-group-heading\]\]\:font-medium [cmdk-group-heading]{font-weight:500}.\[\&_\[cmdk-group-heading\]\]\:text-muted-foreground [cmdk-group-heading]{color:#5c6f8a;color:hsl(var(--muted-foreground))}.\[\&_\[cmdk-group\]\:not\(\[hidden\]\)_\~\[cmdk-group\]\]\:pt-0 [cmdk-group]:not([hidden])~[cmdk-group]{padding-top:0}.\[\&_\[cmdk-group\]\]\:px-2 [cmdk-group]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-input-wrapper\]_svg\]\:h-5 [cmdk-input-wrapper] svg{height:1.25rem}.\[\&_\[cmdk-input-wrapper\]_svg\]\:w-5 [cmdk-input-wrapper] svg{width:1.25rem}.\[\&_\[cmdk-input\]\]\:h-12 [cmdk-input]{height:3rem}.\[\&_\[cmdk-item\]\]\:px-2 [cmdk-item]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-item\]\]\:py-3 [cmdk-item]{padding-bottom:.75rem;padding-top:.75rem}.\[\&_\[cmdk-item\]_svg\]\:h-5 [cmdk-item] svg{height:1.25rem}.\[\&_\[cmdk-item\]_svg\]\:w-5 [cmdk-item] svg{width:1.25rem}.\[\&_p\]\:leading-relaxed p{line-height:1.625}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{height:1rem;width:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_tr\:last-child\]\:border-0 tr:last-child{border-width:0}.\[\&_tr\]\:border-b tr{border-bottom-width:1px}*{box-sizing:border-box;margin:0;padding:0}.App{display:flex;flex-direction:column;min-height:100vh}.App,body{background:#0f172a}body{color:#e2e8f0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}.container{margin:0 auto;max-width:1400px;padding:0 24px}.page-wrapper{flex:1 1}a{color:inherit;text-decoration:none;transition:color .3s ease}a:hover{color:#2c5f8d}button{cursor:pointer;font-family:inherit;transition:all .3s ease}img{display:block;height:auto;max-width:100%}.glass-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #ffffff4d;box-shadow:0 8px 32px #1a3d5c1a}html{scroll-behavior:smooth}.genie-lamp-icon{display:inline-block;vertical-align:middle}.genie-lamp-icon.animated{animation:gentleFloat 3s ease-in-out infinite}.genie-lamp-icon.animated:hover{animation:gentleFloat 1.5s ease-in-out infinite,pulseGlow 1.5s ease-in-out infinite;filter:url(#glow)}@keyframes gentleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes pulseGlow{0%,to{filter:drop-shadow(0 0 2px rgba(251,191,36,.4))}50%{filter:drop-shadow(0 0 8px rgba(251,191,36,.8))}}.sparkle{animation:sparkleFloat 3s ease-in-out infinite}@keyframes sparkleFloat{0%,to{transform:translate(0)}25%{transform:translate(-2px,-3px)}50%{transform:translate(1px,-5px)}75%{transform:translate(-1px,-3px)}}.header{background:#fff;border-bottom:2px solid #e2e8f0;box-shadow:0 4px 12px #1a3d5c14;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-container{gap:20px;justify-content:space-between;margin:0 auto;max-width:1400px;padding:16px 40px}.header-container,.logo{align-items:center;display:flex}.logo{gap:16px;transition:transform .3s ease}.logo:hover{transform:translateY(-2px)}.logo-image{border-radius:8px;height:56px;object-fit:contain;width:56px}.logo-text-group{display:flex;flex-direction:column;gap:2px}.logo-text-main{color:#1a3d5c;font-size:24px;font-weight:800;letter-spacing:1px;line-height:1}.logo-text-sub{color:#64748b;font-size:12px;font-weight:500;letter-spacing:.5px}.logo-genie{filter:drop-shadow(0 2px 4px rgba(245,158,11,.3));margin-left:16px;transition:all .3s ease}.logo:hover .logo-genie{filter:drop-shadow(0 4px 8px rgba(245,158,11,.5));transform:scale(1.15)}.nav{align-items:center;display:flex;gap:30px}.nav-link{background:none;border:none;color:#475569;font-size:14px;font-weight:600;letter-spacing:.3px;padding:10px 0;position:relative;transition:all .3s ease}.nav-link.active,.nav-link:hover{color:#1a3d5c}.nav-link.active:after{background:#2c5f8d;border-radius:2px 2px 0 0;bottom:0;content:"";height:3px;left:0;position:absolute;right:0}.cta-btn{align-items:center;background:linear-gradient(135deg,#2c5f8d,#1a3d5c);border:none;border-radius:8px;box-shadow:0 4px 12px #2c5f8d33;color:#fff;display:none;flex-shrink:0;font-size:13px;font-weight:600;gap:6px;padding:10px 18px;transition:all .3s ease;white-space:nowrap}.cta-btn:hover{background:linear-gradient(135deg,#1a3d5c,#0f1e2e);box-shadow:0 6px 20px #2c5f8d4d;transform:translateY(-2px)}@media (min-width:969px){.cta-btn{display:flex}}.mobile-menu-btn{background:none;border:none;color:#475569;cursor:pointer;display:none;padding:8px;z-index:1001}@media (max-width:968px){.nav{background:#fff;box-shadow:0 8px 16px #00000026;flex-direction:column;left:0;max-height:0;opacity:0;overflow-y:auto;padding:0;position:fixed;right:0;top:80px;transition:all .3s ease;z-index:999}.nav.mobile-open{max-height:calc(100vh - 80px);opacity:1}.nav-link{border-bottom:1px solid #f1f5f9;display:block;font-size:16px;padding:18px 24px;text-align:center;width:100%}.nav-link:last-child{border-bottom:none}.nav-link:hover{background:#f8fafc}.mobile-menu-btn{align-items:center;display:flex;justify-content:center}.header-container{padding:15px 20px}.logo-text-main{font-size:18px}.logo-text-sub{font-size:11px}.logo-image{height:44px;width:44px}.logo{gap:12px}.mobile-login{border-top:2px solid #e2e8f0;margin-top:8px;padding-top:16px}.mobile-login-btn{background:linear-gradient(135deg,#2c5f8d,#1a3d5c);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:14px;transition:all .3s ease;width:100%}.mobile-login-btn:active{transform:scale(.98)}.mobile-user-info{display:flex;flex-direction:column;gap:12px}.user-name{color:#1a3d5c}.mobile-logout-btn,.user-name{font-size:15px;font-weight:600}.mobile-logout-btn{align-items:center;background:#fff;border:2px solid #dc2626;border-radius:8px;color:#dc2626;cursor:pointer;display:flex;gap:8px;justify-content:center;padding:14px;transition:all .3s ease;width:100%}.mobile-logout-btn:active{background:#dc2626;color:#fff;transform:scale(.98)}}.desktop-user-menu{align-items:center;display:flex;gap:16px}.user-greeting{color:#1a3d5c;font-size:14px;font-weight:600}.logout-btn{align-items:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .3s ease;width:36px}.logout-btn:hover{background:#fee2e2;border-color:#dc2626;color:#dc2626}.nav-dropdown{position:relative}.dropdown-trigger{align-items:center;background:none;border:none;color:#475569;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;letter-spacing:.3px;padding:10px 0;transition:all .3s ease}.dropdown-trigger.active,.dropdown-trigger:hover{color:#1a3d5c}.dropdown-trigger.active:after{background:#2c5f8d;border-radius:2px 2px 0 0;bottom:0;content:"";height:3px;left:0;position:absolute;right:0}.chevron{transition:transform .3s ease}.chevron.open{transform:rotate(180deg)}.dropdown-menu{animation:dropdownFadeIn .2s ease;background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 8px 24px #1a3d5c1f;min-width:260px;padding:8px;position:absolute;right:0;top:calc(100% + 10px);z-index:1000}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-category{margin-bottom:4px}.dropdown-category:last-child{margin-bottom:0}.dropdown-category-label{border-bottom:1px solid #f1f5f9;color:#94a3b8;font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:4px;padding:8px 16px 6px;text-transform:uppercase}.dropdown-item{align-items:center;border-radius:8px;color:#475569;display:flex;font-size:14px;font-weight:600;gap:10px;padding:12px 16px;transition:all .2s ease;white-space:nowrap}.dropdown-item:hover{background:#f1f5f9;color:#1a3d5c}.dropdown-item.active{background:#e0f2fe;color:#0369a1}.mobile-category{border-top:1px solid #e2e8f0;margin-top:12px;padding-top:12px}.mobile-category:first-child{border-top:none;margin-top:0;padding-top:0}.mobile-category-label{color:#94a3b8;font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:4px;padding:8px 24px 6px;text-transform:uppercase}.mobile-category .nav-link{align-items:center;display:flex;gap:10px}.desktop-only{display:flex}.mobile-only{display:none}@media (max-width:968px){.desktop-only{display:none}.mobile-only{display:flex;flex-direction:column;width:100%}}.footer{background:#0f1e2e;border-top:3px solid #2c5f8d;margin-top:0}.footer-content{grid-gap:60px;display:grid;gap:60px;grid-template-columns:1.5fr 1fr 1fr;margin:0 auto;max-width:1400px;padding:60px 40px}.footer-logo{align-items:center;display:flex;gap:16px;margin-bottom:20px}.footer-logo-img{border-radius:8px;height:50px;object-fit:contain;width:50px}.footer-brand{display:flex;flex-direction:column;gap:2px}.footer-logo-text{color:#fff;font-size:24px;font-weight:800;letter-spacing:1px}.footer-tagline-small{color:#94a3b8;font-size:12px;font-weight:500}.footer-description{color:#94a3b8;font-size:14px;line-height:1.7;max-width:350px}.footer-center h3,.footer-right h3{color:#fff;font-size:16px;font-weight:700;letter-spacing:1px;margin-bottom:20px;text-transform:uppercase}.contact-info p{color:#94a3b8;font-size:14px;line-height:1.6;margin-bottom:10px}.contact-info strong{color:#cbd5e1}.footer-links{display:flex;flex-direction:column;gap:12px}.footer-links a{color:#94a3b8;font-size:14px;text-decoration:none;transition:color .3s ease}.footer-links a:hover{color:#fff}.footer-bottom{background:#0a1522;border-top:1px solid #1e293b;padding:24px 0}.footer-bottom-content{align-items:center;display:flex;font-size:13px;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 40px}.copyright{color:#64748b}.social-links{display:flex;gap:12px}.social-link{align-items:center;background:#1e293b;border-radius:8px;color:#94a3b8;display:flex;height:36px;justify-content:center;transition:all .3s ease;width:36px}.social-link:hover{background:#2c5f8d;color:#fff;transform:translateY(-2px)}@media (max-width:968px){.footer-content{gap:40px;grid-template-columns:1fr;padding:40px 20px}.footer-bottom-content{flex-direction:column;gap:15px;padding:0 20px;text-align:center}}.home-page{background:#f8fafc;min-height:100vh}.hero-section{background:linear-gradient(135deg,#1a3d5c,#2c5f8d);overflow:hidden;padding:100px 20px 120px;position:relative}.hero-section:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='rgba(255,255,255,0.05)' d='M0 0h1v1H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.hero-genie-decoration{animation:heroGenieFloat 6s ease-in-out infinite;opacity:.15;pointer-events:none;position:absolute;right:10%;top:50%;transform:translateY(-50%);z-index:0}@keyframes heroGenieFloat{0%,to{transform:translateY(-50%) rotate(0deg)}50%{transform:translateY(-55%) rotate(5deg)}}.hero-content{grid-gap:80px;align-items:center;display:grid;gap:80px;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1400px;position:relative;z-index:1}.hero-badge{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #fff3;border-radius:20px;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:8px 16px}.hero-badge,.hero-text h1{color:#fff;margin-bottom:24px}.hero-text h1{font-size:56px;font-weight:800;line-height:1.1}.gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#f5f1e8,#fff);-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:#ffffffe6;font-size:18px;line-height:1.7;margin-bottom:36px;max-width:540px}.hero-buttons{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:48px}.btn{font-size:15px}.btn-primary{background:#fff;color:#1a3d5c}.btn-primary:hover{box-shadow:0 8px 24px #ffffff4d}.btn-secondary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #ffffff4d;color:#fff}.btn-secondary:hover{background:#fff3;border-color:#ffffff80}.btn-large{font-size:16px;padding:16px 32px}.hero-stats{display:flex;gap:48px}.stat{text-align:left}.stat-number{color:#fff;font-size:36px;font-weight:800;line-height:1;margin-bottom:8px}.stat-label{color:#ffffffb3;font-weight:500}.hero-image-wrapper{border-radius:16px;box-shadow:0 24px 64px #0000004d;overflow:hidden;position:relative}.hero-image-wrapper img{display:block;height:auto;width:100%}.floating-card{align-items:center;animation:float 3s ease-in-out infinite;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;color:#1a3d5c;display:flex;font-size:14px;font-weight:600;gap:10px;padding:12px 20px;position:absolute}.card-1{animation-delay:0s;right:20px;top:20px}.card-2{animation-delay:1.5s;bottom:20px;left:20px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.floating-card svg{color:#2c5f8d}.features-section{background:#fff;padding:100px 20px}.section-header{margin:0 auto 60px;max-width:700px;text-align:center}.section-header h2{color:#1a3d5c;font-size:42px;font-weight:800;margin-bottom:16px}.section-header p{color:#64748b;font-size:18px}.features-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:0 auto;max-width:1400px}.feature-card{background:#f8fafc;border:2px solid #e2e8f0;border-radius:16px;padding:36px;transition:all .3s ease}.feature-card:hover{border-color:#2c5f8d;box-shadow:0 12px 32px #1a3d5c26;transform:translateY(-8px)}.feature-icon{align-items:center;background:linear-gradient(135deg,#2c5f8d,#1a3d5c);border-radius:12px;color:#fff;display:flex;height:64px;justify-content:center;margin-bottom:24px;width:64px}.feature-card h3{color:#1a3d5c;font-size:22px;font-weight:700;margin-bottom:12px}.feature-card p{color:#64748b;font-size:15px;line-height:1.7}.how-it-works{background:linear-gradient(180deg,#f8fafc 0,#fff);padding:100px 20px}.steps-grid{grid-gap:48px;display:grid;gap:48px;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:1400px}.step-item{text-align:center}.step-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2c5f8d,#1a3d5c);-webkit-background-clip:text;background-clip:text;font-size:72px;font-weight:900;line-height:1;margin-bottom:16px;opacity:.2}.step-item h3{color:#1a3d5c;font-size:24px;font-weight:700;margin-bottom:12px}.step-item p{color:#64748b;font-size:15px;line-height:1.7}.benefits-section{background:#fff;padding:100px 20px}.benefits-content{grid-gap:80px;align-items:center;display:grid;gap:80px;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1400px}.benefits-image{border-radius:16px;box-shadow:0 24px 64px #00000026;overflow:hidden}.benefits-image img{display:block;height:auto;width:100%}.benefits-text h2{color:#1a3d5c;font-size:38px;font-weight:800;line-height:1.2;margin-bottom:20px}.benefits-text>p{color:#64748b;font-size:16px;line-height:1.8;margin-bottom:32px}.benefits-list{list-style:none;margin-bottom:36px}.benefits-list li{align-items:center;color:#475569;display:flex;font-size:15px;font-weight:500;gap:12px;margin-bottom:14px}.benefits-list svg{color:#2c5f8d;flex-shrink:0}.cta-section{background:linear-gradient(135deg,#1a3d5c,#2c5f8d);overflow:hidden;padding:100px 20px;position:relative}.cta-section:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='rgba(255,255,255,0.05)' d='M0 0h1v1H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.cta-content{margin:0 auto;max-width:800px;position:relative;text-align:center;z-index:1}.cta-content h2{color:#fff;font-size:42px;font-weight:800;margin-bottom:16px}.cta-content>p{color:#ffffffe6;font-size:18px;margin-bottom:40px}.btn-cta{background:#fff;color:#1a3d5c;font-size:16px;padding:16px 32px}.btn-cta:hover{box-shadow:0 12px 32px #ffffff4d;transform:translateY(-3px)}.btn-cta-outline{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #ffffff4d;color:#fff;font-size:16px;padding:16px 32px}.btn-cta-outline:hover{background:#fff3;border-color:#ffffff80;transform:translateY(-3px)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f1e2ecc}.modal-content{box-shadow:0 24px 64px #0000004d;padding:48px;position:relative}.modal-close{align-items:center;background:#f1f5f9;border-radius:8px;color:#64748b;display:flex;height:40px;justify-content:center;right:20px;top:20px;transition:all .3s ease;width:40px}.modal-close:hover{background:#e2e8f0;color:#1a3d5c}.modal-content h2{font-size:32px;font-weight:800;margin-bottom:12px}.modal-description{font-size:16px;margin-bottom:32px}.trial-form{gap:20px}.trial-form,.trial-form .form-group{display:flex;flex-direction:column}.trial-form label{color:#1a3d5c;font-size:14px;font-weight:600;margin-bottom:8px}.trial-form input{border:2px solid #e2e8f0;border-radius:8px;color:#1a3d5c;font-size:15px;padding:12px 16px;transition:all .3s ease}.trial-form input:focus{border-color:#2c5f8d;box-shadow:0 0 0 3px #2c5f8d1a;outline:none}.trial-form input:disabled{cursor:not-allowed;opacity:.6}.btn-full{margin-top:12px}.status-message{border-radius:8px;font-size:14px;margin-bottom:24px;padding:14px 18px}.status-message.success{background:#d1fae5;border:1px solid #6ee7b7;color:#065f46}.status-message.error{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b}@media (max-width:968px){.benefits-content,.hero-content{gap:48px;grid-template-columns:1fr}.hero-text h1{font-size:40px}.cta-content h2,.section-header h2{font-size:32px}.steps-grid{gap:32px;grid-template-columns:1fr}.modal-content{padding:32px 24px}.modal-content h2{font-size:26px}}.tools-section{background:linear-gradient(135deg,#f8fafc,#e7f2f8);padding:80px 20px}.tools-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(3,1fr);margin-left:auto;margin-right:auto;margin-top:50px;max-width:1400px}.tool-card{background:#fff;border-radius:20px;box-shadow:0 4px 20px #2c5f8d14;color:inherit;display:flex;flex-direction:column;overflow:hidden;padding:40px 32px;position:relative;text-decoration:none;transition:all .3s ease}.tool-card:before{content:"";height:4px;left:0;position:absolute;right:0;top:0;transition:height .3s ease}.tool-card-primary:before{background:linear-gradient(135deg,#2c5f8d,#4a7ba7)}.tool-card-secondary:before{background:linear-gradient(135deg,#f59e0b,#f97316)}.tool-card-tertiary:before{background:linear-gradient(135deg,#10b981,#059669)}.tool-card:hover{box-shadow:0 12px 40px #2c5f8d26;transform:translateY(-8px)}.tool-card:hover:before{height:8px}.tool-icon{align-items:center;border-radius:20px;display:flex;height:80px;justify-content:center;margin-bottom:24px;transition:all .3s ease;width:80px}.tool-card-primary .tool-icon{background:linear-gradient(135deg,#e0f2fe,#bae6fd);color:#0369a1}.tool-card-secondary .tool-icon{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}.tool-card-tertiary .tool-icon{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857}.tool-card:hover .tool-icon{transform:scale(1.1) rotate(5deg)}.tool-card h3{color:#1e293b;font-size:26px;font-weight:700;margin-bottom:12px}.tool-card>p{color:#64748b;flex-grow:1;font-size:15px;line-height:1.6;margin-bottom:24px}.tool-features{list-style:none;margin:0 0 28px;padding:0}.tool-features li{align-items:center;color:#475569;display:flex;font-size:14px;font-weight:500;gap:10px;padding:8px 0}.tool-features li svg{color:#10b981;flex-shrink:0}.tool-cta{align-items:center;border-radius:12px;display:flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;margin-top:auto;padding:16px 24px;transition:all .3s ease}.tool-card-primary .tool-cta{background:linear-gradient(135deg,#2c5f8d,#1a3d5c);color:#fff}.tool-card-secondary .tool-cta{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.tool-card-tertiary .tool-cta{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.tool-card-quaternary:before{background:linear-gradient(135deg,#8b5cf61a,#7c3aed1a)}.tool-card-quaternary{border-color:#8b5cf64d}.tool-card-quaternary .tool-cta,.tool-card-quaternary .tool-icon{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.tool-card-quinary:before{background:linear-gradient(135deg,#06b6d41a,#0891b21a)}.tool-card-quinary{border-color:#06b6d44d}.tool-card-quinary .tool-cta,.tool-card-quinary .tool-icon{background:linear-gradient(135deg,#06b6d4,#0891b2);color:#fff}.tool-card-senary:before{background:linear-gradient(135deg,#ef44441a,#dc26261a)}.tool-card-senary{border-color:#ef44444d}.tool-card-senary .tool-icon{background:linear-gradient(135deg,#fecaca,#fca5a5);color:#dc2626}.tool-card-senary .tool-cta{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.tool-card-septenary:before{background:linear-gradient(135deg,#14b8a61a,#0d94881a)}.tool-card-septenary{border-color:#14b8a64d}.tool-card-septenary .tool-icon{background:linear-gradient(135deg,#ccfbf1,#99f6e4);color:#0d9488}.tool-card-septenary .tool-cta{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff}.tool-card-octonary:before{background:linear-gradient(135deg,#6366f11a,#4f46e51a)}.tool-card-octonary{border-color:#6366f14d}.tool-card-octonary .tool-icon{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#4f46e5}.tool-card-octonary .tool-cta{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff}.tool-card-nonary:before{background:linear-gradient(135deg,#eab3081a,#ca8a041a)}.tool-card-nonary{border-color:#eab3084d}.tool-card-nonary .tool-icon{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#ca8a04}.tool-card-nonary .tool-cta{background:linear-gradient(135deg,#eab308,#ca8a04);color:#fff}.tool-card:hover .tool-cta{transform:translateX(5px)}@media (max-width:1200px){.tools-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.tools-section{padding:60px 20px}.tools-grid{gap:24px;grid-template-columns:1fr}.tool-card{padding:32px 24px}.tool-icon{height:64px;width:64px}.tool-card h3{font-size:22px}}.page-template{background:#f8fafc;min-height:100vh}.page-header{padding:80px 20px}.page-header h1{font-weight:800;margin-bottom:12px}.page-content{padding:80px 20px}.content-box{background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014;margin:0 auto 40px;max-width:800px;padding:48px}.content-box:last-child{margin-bottom:0}.content-box h2{color:#1a3d5c;font-size:32px;font-weight:700;margin-bottom:20px}.content-box p{color:#64748b;font-size:16px;line-height:1.8}.feature-list{list-style:none;margin:0;padding:0}.feature-list li{border-bottom:1px solid #e2e8f0;color:#475569;font-size:16px;line-height:1.7;padding:16px 0}.feature-list li:last-child{border-bottom:none}.feature-list li strong{color:#2c5f8d;display:block;font-weight:600;margin-bottom:6px}.feature-list li{align-items:flex-start;display:flex;gap:12px}.feature-list li svg{flex-shrink:0;margin-top:2px}.cta-button{fontWeight:600;background:#2c5f8d;border-radius:8px;color:#fff;display:inline-block;padding:12px 28px;text-decoration:none;transition:all .3s ease}.cta-button:hover{background:#1a3d5c;box-shadow:0 4px 12px #2c5f8d4d;transform:translateY(-2px)}@media (max-width:768px){.page-header h1{font-size:32px}.page-header{padding:60px 20px}.content-box{padding:32px 24px}}.pricing-page{background:#f8fafc;min-height:100vh}.pricing-header{background:linear-gradient(135deg,#2c5f8d,#1a3d5c);color:#fff;padding:80px 20px 60px;text-align:center}.pricing-header h1{font-size:48px;font-weight:800;margin-bottom:16px}.pricing-header p{font-size:20px;margin-bottom:40px;opacity:.95}.billing-toggle{background:#ffffff1a;border-radius:12px;display:inline-flex;gap:6px;padding:6px}.billing-toggle button{background:#0000;border:none;border-radius:8px;color:#ffffffb3;cursor:pointer;font-size:16px;font-weight:600;padding:12px 32px;position:relative;transition:all .3s ease}.billing-toggle button:hover{color:#fff}.billing-toggle button.active{background:#fff;color:#2c5f8d}.savings-badge{background:#10b981;border-radius:12px;color:#fff;font-size:11px;font-weight:700;padding:4px 8px;position:absolute;right:-8px;top:-8px}.pricing-plans{padding:80px 20px}.plans-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;max-width:1400px}.pricing-card{background:#fff;border-radius:16px;border-top:4px solid #2c5f8d;box-shadow:0 4px 24px #00000014;display:flex;flex-direction:column;padding:40px 32px;position:relative;transition:all .3s ease}.pricing-card:hover{box-shadow:0 12px 40px #00000026;transform:translateY(-8px)}.pricing-card.popular{border-top-width:6px;box-shadow:0 8px 32px #0000001f}.popular-badge{background:linear-gradient(135deg,#10b981,#059669);border-radius:20px;color:#fff;font-size:13px;font-weight:700;left:50%;letter-spacing:.5px;padding:6px 20px;position:absolute;text-transform:uppercase;top:-16px;transform:translateX(-50%)}.card-header{margin-bottom:32px;text-align:center}.plan-icon{align-items:center;border-radius:20px;display:flex;height:80px;justify-content:center;margin:0 auto 20px;width:80px}.card-header h3{color:#1a3d5c;font-size:28px;font-weight:700;margin-bottom:8px}.plan-description{color:#64748b;font-size:15px;margin-bottom:12px}.plan-users{align-items:center;background:#f1f5f9;border-radius:20px;color:#475569;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:6px 16px}.card-pricing{border-bottom:2px solid #e2e8f0;border-top:2px solid #e2e8f0;margin-bottom:32px;padding:24px 0;text-align:center}.price{align-items:baseline;display:flex;gap:4px;justify-content:center;margin-bottom:8px}.currency{color:#64748b;font-size:24px;font-weight:600}.amount{color:#1a3d5c;font-size:56px;font-weight:800;line-height:1}.period{color:#64748b;font-size:18px;font-weight:500}.annual-savings{background:#d1fae5;border-radius:20px;color:#065f46;display:inline-block;font-size:13px;font-weight:700;padding:6px 16px}.monthly-note{color:#94a3b8;font-size:13px;margin-top:4px}.custom-pricing{display:flex;flex-direction:column;gap:8px}.price-text{color:#1a3d5c;font-size:32px;font-weight:700}.price-subtext{color:#64748b;font-size:14px}.card-features{flex:1 1;margin-bottom:32px}.card-features h4{color:#475569;font-size:14px;font-weight:700;letter-spacing:.5px;margin-bottom:16px;text-transform:uppercase}.features-list,.limitations-list{list-style:none;margin:0;padding:0}.features-list li,.limitations-list li{align-items:flex-start;color:#475569;display:flex;font-size:14px;gap:12px;line-height:1.6;padding:10px 0}.check-icon{color:#10b981}.check-icon,.x-icon{flex-shrink:0;margin-top:2px}.x-icon{color:#94a3b8}.limitations-list li{opacity:.7}.card-action{margin-top:auto}.btn{border:2px solid #0000;border-radius:12px;display:block;padding:16px 32px;text-align:center;text-decoration:none;width:100%}.btn-primary:hover{box-shadow:0 6px 20px #2c5f8d4d}.btn-outline{background:#fff;border-color:#2c5f8d;color:#2c5f8d}.btn-outline:hover{background:#2c5f8d;color:#fff}.pricing-faq{background:#fff;padding:80px 20px}.pricing-faq h2{color:#1a3d5c;font-size:42px;font-weight:700;margin-bottom:60px;text-align:center}.faq-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin:0 auto;max-width:1200px}.faq-item{background:#f8fafc;border-left:4px solid #2c5f8d;border-radius:12px;padding:32px}.faq-item h3{color:#1a3d5c;font-size:20px;font-weight:700;margin-bottom:12px}.faq-item p{color:#64748b;font-size:15px;line-height:1.7;margin:0}.pricing-cta{background:linear-gradient(135deg,#2c5f8d,#1a3d5c);padding:80px 20px}.cta-box{color:#fff;margin:0 auto;max-width:800px;text-align:center}.cta-box h2{font-size:42px;font-weight:700;margin-bottom:16px}.cta-box p{font-size:20px;margin-bottom:32px;opacity:.95}.cta-buttons{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.btn-light{background:#fff;color:#2c5f8d;padding:16px 40px}.btn-light:hover{box-shadow:0 6px 20px #ffffff4d;transform:translateY(-2px)}@media (max-width:768px){.pricing-header h1{font-size:36px}.pricing-header p{font-size:16px}.billing-toggle button{font-size:14px;padding:10px 20px}.plans-grid{grid-template-columns:1fr}.pricing-card{padding:32px 24px}.amount{font-size:48px}.faq-grid{grid-template-columns:1fr}.cta-box h2{font-size:32px}.cta-buttons{flex-direction:column}.btn-light,.btn-primary{width:100%}}.contact-page{min-height:100vh}.page-header{text-align:center}.page-header h1{font-size:42px;font-weight:700;margin-bottom:15px}.page-header p{font-size:18px;opacity:.95}.contact-section{background:#fff;padding:80px 20px}.contact-layout{grid-gap:60px;display:grid;gap:60px;grid-template-columns:1fr 1.2fr;margin:0 auto;max-width:1200px}.contact-info h2{color:#333;font-size:32px;font-weight:700;margin-bottom:20px}.contact-info>p{color:#666;font-size:16px;line-height:1.8;margin-bottom:40px}.info-items{display:flex;flex-direction:column;gap:30px}.info-item{align-items:flex-start;display:flex;gap:20px}.info-icon{color:#2c5f8d;flex-shrink:0;margin-top:5px}.info-item h3{color:#333;font-size:18px;font-weight:600;margin-bottom:8px}.info-item p{color:#666;font-size:15px;line-height:1.7}.contact-form-wrapper{background:#f9f9f9;border:2px solid #e0e0e0;border-radius:12px;padding:40px}.status-message{border-radius:6px;font-size:15px;font-weight:500;margin-bottom:20px;padding:15px}.status-message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.status-message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.contact-form{display:flex;flex-direction:column;gap:20px}.form-group label{color:#333}.form-group input,.form-group textarea{background:#fff;border:2px solid #e0e0e0;border-radius:6px;color:#333;font-family:inherit;font-size:15px;padding:12px 16px;transition:all .3s ease}.form-group input:disabled,.form-group textarea:disabled{cursor:not-allowed;opacity:.6}.form-group input:focus,.form-group textarea:focus{border-color:#2c5f8d;box-shadow:0 0 0 3px #2c5f8d1a}.form-group textarea{min-height:120px}.btn-submit{align-items:center;background:#2c5f8d;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:16px;font-weight:600;gap:10px;justify-content:center;margin-top:10px;padding:14px 32px;transition:all .3s ease}.btn-submit:hover:not(:disabled){background:#1a3d5c;box-shadow:0 4px 12px #2c5f8d4d;transform:translateY(-2px)}.btn-submit:disabled{cursor:not-allowed;opacity:.6}@media (max-width:968px){.contact-layout{gap:40px;grid-template-columns:1fr}.page-header h1{font-size:32px}.contact-info h2{font-size:28px}.contact-form-wrapper{padding:30px 20px}}.auth-page{align-items:center;background:linear-gradient(135deg,#1a3d5c,#2c5f8d);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-container{max-width:480px;width:100%}.auth-box{background:#fff;border-radius:16px;box-shadow:0 24px 64px #0000004d;padding:48px}.auth-header{margin-bottom:32px;text-align:center}.auth-icon{color:#2c5f8d;margin:0 auto 20px}.auth-header h1{color:#1a3d5c;font-size:28px;font-weight:800;margin-bottom:8px}.auth-header p{color:#64748b;font-size:15px}.error-message{align-items:center;background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;color:#991b1b;display:flex;font-size:14px;gap:12px;margin-bottom:24px;padding:14px 16px}.auth-form{gap:20px}.auth-form,.auth-form .form-group{display:flex;flex-direction:column}.auth-form label{align-items:center;color:#1a3d5c;display:flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:8px}.auth-form input{border:2px solid #e2e8f0;border-radius:8px;color:#1a3d5c;font-size:15px;padding:12px 16px;transition:all .3s ease}.auth-form input:focus{border-color:#2c5f8d;box-shadow:0 0 0 3px #2c5f8d1a;outline:none}.auth-form input:disabled{background:#f8fafc;cursor:not-allowed;opacity:.6}.btn-full{font-size:16px;justify-content:center;margin-top:8px;padding:14px}.btn-primary{background:linear-gradient(135deg,#2c5f8d,#1a3d5c);transition:all .3s ease}.btn-primary:hover:not(:disabled){box-shadow:0 8px 24px #2c5f8d4d}.auth-footer{border-top:1px solid #e2e8f0;margin-top:24px;padding-top:24px;text-align:center}.auth-footer p{color:#64748b;font-size:14px}.auth-link{color:#2c5f8d;font-weight:600;text-decoration:none}.auth-link:hover{text-decoration:underline}.success-message{align-items:center;background:#d1fae5;border:1px solid #6ee7b7;border-radius:8px;color:#065f46;display:flex;font-size:14px;gap:12px;margin-bottom:24px;padding:14px 16px}.forgot-password-link{background:none;border:none;color:#2c5f8d;cursor:pointer;display:block;font-size:14px;font-weight:600;margin-bottom:16px;text-decoration:none}.forgot-password-link:hover{text-decoration:underline}.back-to-login{align-items:center;background:none;border:none;color:#2c5f8d;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:0}.back-to-login:hover{text-decoration:underline}@media (max-width:576px){.auth-box{padding:32px 24px}.auth-header h1{font-size:24px}}.genie-step{margin:0 auto;max-width:1200px;padding:40px 20px}.step-header{margin-bottom:40px;text-align:center}.step-header h2{color:#f1f5f9;font-size:28px;font-weight:800;margin-bottom:10px}.step-header p{color:#64748b;font-size:15px}.success-badge{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;box-shadow:0 4px 16px #10b9814d;color:#fff;display:flex;height:72px;justify-content:center;margin:0 auto 24px;width:72px}.step-content{margin-bottom:28px;padding:36px}.genie-step .step-actions{display:flex;gap:12px;justify-content:center}.genie-step .controls-actions .btn,.genie-step .estimate-actions .btn,.genie-step .step-actions .btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.genie-step .btn-primary,.genie-step .estimate-actions .btn-primary{background:#3b82f6!important;border:none!important;color:#fff!important}.genie-step .btn-primary:hover,.genie-step .estimate-actions .btn-primary:hover{background:#2563eb!important;box-shadow:0 4px 16px #3b82f659;transform:translateY(-1px)}.genie-step .btn-secondary,.genie-step .estimate-actions .btn-secondary{background:#0f172a!important;border:1px solid #334155!important;color:#94a3b8!important}.genie-step .btn-secondary:hover,.genie-step .estimate-actions .btn-secondary:hover{background:#1e293b!important;border-color:#64748b!important;color:#e2e8f0!important}.genie-step .btn-secondary.btn-share{background:#10b981!important;border-color:#10b981!important;color:#fff!important}.genie-step .btn-secondary.btn-share:hover{background:#059669!important;border-color:#059669!important}.genie-step .btn-large{font-size:15px;padding:16px 28px}.upload-zone{background:#0f172a80;border:2px dashed #475569;border-radius:14px;cursor:pointer;padding:72px 40px;text-align:center;transition:all .3s ease}.upload-zone.drag-active,.upload-zone:hover{background:#3b82f60d;border-color:#3b82f6}.upload-icon{color:#3b82f6;margin:0 auto 20px}.upload-zone h3{color:#e2e8f0;font-size:22px;font-weight:700;margin-bottom:8px}.upload-zone p{color:#64748b;font-size:15px;margin-bottom:20px}.upload-formats{background:#0f172a;border:1px solid #334155;border-radius:8px;color:#64748b;display:inline-block;font-size:13px;padding:8px 16px}.uploading{color:#3b82f6;font-weight:600;margin-top:16px}.image-preview{border:1px solid #334155;border-radius:12px;overflow:hidden;position:relative}.image-preview img{display:block;height:auto;width:100%}.remove-btn{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ef4444e6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:12px;top:12px;transition:all .2s ease;width:36px}.remove-btn:hover{background:#dc2626}.image-info{align-items:center;background:#3b82f614;color:#60a5fa;display:flex;font-size:14px;font-weight:600;gap:12px;padding:14px 16px}.upload-mode-toggle{display:flex;gap:12px;margin-bottom:24px}.mode-btn{align-items:center;background:#1e293b80;border:2px solid #33415566;border-radius:12px;color:#94a3b8;cursor:pointer;display:flex;flex:1 1;font-size:15px;font-weight:600;gap:10px;justify-content:center;padding:18px 24px;transition:all .3s ease}.mode-btn:hover{border-color:#8b5cf64d;color:#cbd5e1}.mode-btn.active{background:#8b5cf61f;border-color:#8b5cf680;color:#c4b5fd}.satellite-search-section{padding:40px;text-align:center}.sat-search-inner h3{color:#f1f5f9;font-size:20px;margin:0 0 8px}.sat-search-inner>p{color:#94a3b8;font-size:14px;margin:0 0 24px}.sat-address-wrap{margin:0 auto;max-width:500px;position:relative}.sat-input-icon{color:#64748b;left:16px;position:absolute;top:50%;transform:translateY(-50%)}.sat-address-input{background:#1e293bcc;border:1px solid #47556980;border-radius:10px;box-sizing:border-box;color:#f1f5f9;font-size:15px;outline:none;padding:14px 18px 14px 46px;width:100%}.sat-address-input:focus{border-color:#8b5cf699}.sat-address-input::placeholder{color:#64748b}.sat-input-spinner{color:#8b5cf6;position:absolute;right:14px;top:50%;transform:translateY(-50%)}.spin-icon{animation:spin-anim .8s linear infinite}.sat-autocomplete-dropdown{background:#1e293b;border:1px solid #475569;border-radius:10px;box-shadow:0 12px 32px #00000080;left:0;margin-top:4px;overflow:hidden;position:absolute;right:0;top:100%;z-index:100}.sat-autocomplete-item{align-items:center;background:#0000;border:none;border-bottom:1px solid #4755694d;color:#e2e8f0;cursor:pointer;display:flex;font-size:14px;gap:10px;padding:12px 16px;text-align:left;transition:background .12s;width:100%}.sat-autocomplete-item:last-child{border-bottom:none}.sat-autocomplete-item:hover{background:#8b5cf61a}.sat-autocomplete-item svg{color:#8b5cf6;flex-shrink:0}.sat-selected-addr{background:#22c55e14;border:1px solid #22c55e33;border-radius:8px;color:#86efac;display:inline-flex;gap:8px;padding:8px 14px}.sat-err,.sat-selected-addr{align-items:center;font-size:13px;margin-top:12px}.sat-err{background:#ef444414;border:1px solid #ef444433;border-radius:8px;color:#fca5a5;display:flex;flex-wrap:wrap;gap:12px;padding:10px 14px}.sat-retry-btn{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:6px 16px;transition:background .2s;white-space:nowrap}.sat-retry-btn:hover{background:#2563eb}.satellite-analyzing{align-items:center;display:flex;flex-direction:column;gap:16px;padding:60px 20px}.sat-spin{animation:sat-spin-anim .8s linear infinite;border:3px solid #8b5cf633;border-radius:50%;border-top-color:#8b5cf6;height:48px;width:48px}@keyframes sat-spin-anim{to{transform:rotate(1turn)}}.satellite-analyzing p{color:#94a3b8;font-size:15px}.sat-spin-sub{color:#64748b!important;font-size:13px!important}.satellite-results-preview{background:#22c55e0a;border:1px solid #22c55e33;border-radius:12px;overflow:hidden}.sat-preview-header{align-items:center;padding:14px 18px}.sat-remove-btn{background:none;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;margin-left:auto;padding:4px}.sat-remove-btn:hover{background:#ef44441a;color:#ef4444}.sat-image-preview{max-height:300px;overflow:hidden}.sat-image-preview img{display:block;height:auto;object-fit:cover;width:100%}.sat-preview-stats{grid-gap:1px;background:#3341554d;border-top:1px solid #3341554d;display:grid;gap:1px;grid-template-columns:repeat(4,1fr)}.sat-stat{align-items:center;background:#0f172a99;display:flex;flex-direction:column;padding:14px 8px}.sat-stat-label{color:#94a3b8;font-size:11px;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.sat-stat-value{color:#f1f5f9;font-size:18px;font-weight:700}.sat-preview-note{border-top:1px solid #3341554d;color:#94a3b8;font-size:13px;padding:12px 18px;text-align:center}.sat-map-section{background:#0f172a;border:1px solid #47556966;border-radius:12px;overflow:hidden}.sat-map-toolbar{background:#0f172af2;border-bottom:1px solid #4755694d;color:#94a3b8;font-size:13px;padding:10px 16px}.sat-analyze-btn{align-items:center;background:linear-gradient(135deg,#8b5cf6,#6d28d9);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 22px;transition:transform .15s,box-shadow .2s}.sat-analyze-btn:hover{box-shadow:0 4px 16px #8b5cf666;transform:translateY(-1px)}.sat-map-embed{height:400px;width:100%}.sat-preview-header{align-items:flex-start;border-bottom:1px solid #3341554d;color:#86efac;display:flex;font-size:15px;font-weight:600;gap:10px;justify-content:space-between;padding:18px 20px}.sat-preview-header h3{font-size:16px;margin:0}.sat-addr-badge{font-weight:400;gap:5px;margin-top:4px}.sat-addr-badge,.sat-reset-btn{align-items:center;color:#94a3b8;display:inline-flex;font-size:12px}.sat-reset-btn{background:#4755694d;border:1px solid #47556966;border-radius:6px;cursor:pointer;gap:6px;padding:6px 14px;transition:all .15s;white-space:nowrap}.sat-reset-btn:hover{background:#47556980;color:#f1f5f9}.sat-results-grid{grid-gap:1px;background:#3341554d;gap:1px;grid-template-columns:repeat(4,1fr)}.sat-faces-breakdown{display:flex;flex-wrap:wrap;gap:8px;padding:14px 20px}.sat-face-chip{align-items:center;background:#1e293bcc;border:1px solid #4755694d;border-radius:20px;color:#cbd5e1;display:inline-flex;font-size:12px;gap:6px;padding:5px 12px}.sat-face-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.sat-ai-notes{border-top:1px solid #3341554d;color:#94a3b8;font-size:13px;line-height:1.5;padding:12px 20px}.sat-ai-notes strong{color:#cbd5e1}.satellite-flow{display:flex;flex-direction:column;gap:20px}.sat-section{border-top:1px solid #3341554d;padding:0 20px 16px}.sat-section-title{color:#64748b;font-size:13px;font-weight:600;letter-spacing:.5px;margin:14px 0 10px;text-transform:uppercase}.sat-faces-table{display:flex;flex-direction:column;gap:6px}.sat-face-row{align-items:center;background:#0f172a99;border-radius:6px;color:#cbd5e1;display:flex;font-size:13px;gap:10px;padding:6px 10px}.sat-face-name{flex:1 1;font-weight:500}.sat-face-detail{color:#94a3b8;font-size:12px;min-width:70px;text-align:right}.sat-measurements-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.sat-meas{background:#0f172a99;border-radius:6px;color:#cbd5e1;display:flex;font-size:13px;justify-content:space-between;padding:6px 10px}.sat-meas span:first-child{color:#94a3b8}.sat-meas span:last-child{font-weight:600}.sat-boq-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.sat-boq-group h5{color:#8b5cf6;font-size:12px;font-weight:600;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.sat-boq-row{border-bottom:1px solid #33415526;color:#cbd5e1;display:flex;font-size:13px;justify-content:space-between;padding:4px 0}.sat-boq-row span:first-child{color:#94a3b8}.sat-boq-row span:last-child{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:600}.nett-qty-table{display:flex;flex-direction:column;gap:0}.nett-qty-header{border-bottom:1px solid #33415566;color:#64748b;font-size:11px;font-weight:700;letter-spacing:.5px;padding:8px 12px;text-transform:uppercase}.nett-qty-header,.nett-qty-row{display:flex;justify-content:space-between}.nett-qty-row{border-bottom:1px solid #33415526;font-size:13px;padding:7px 12px}.nett-qty-row span:first-child{color:#cbd5e1}.nett-qty-row span:last-child{font-feature-settings:"tnum";color:#e2e8f0;font-variant-numeric:tabular-nums;font-weight:600}.cutting-list-table{display:flex;flex-direction:column;gap:0}.cutting-list-header{border-bottom:1px solid #33415566;color:#64748b;font-size:11px;font-weight:700;letter-spacing:.5px;padding:8px 12px;text-transform:uppercase}.cutting-list-header,.cutting-list-row{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1.2fr .8fr 1fr}.cutting-list-row{border-bottom:1px solid #33415526;color:#cbd5e1;font-size:13px;padding:7px 12px}.cutting-list-row span:last-child{font-feature-settings:"tnum";color:#e2e8f0;font-variant-numeric:tabular-nums;font-weight:600}.sat-disclaimer{border-top:1px solid #3341554d;color:#64748b;font-size:11px;font-style:italic;padding:10px 20px;text-align:center}.canvas-toolbar{align-items:flex-start;background:#0f172a;border:1px solid #334155;border-radius:12px;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:20px;padding:16px 20px}.toolbar-section{display:flex;flex-direction:column;gap:6px}.toolbar-label{color:#64748b;font-size:10px;font-weight:700;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.toolbar-buttons{display:flex;gap:6px}.tool-btn{align-items:center;background:#1e293b;border:1px solid #334155;border-radius:50%;color:#94a3b8;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;position:relative;transition:all .2s ease;width:40px}.tool-btn:hover:not(:disabled){background:#3b82f614;border-color:#3b82f6;color:#60a5fa}.tool-btn.active{background:#3b82f6;border-color:#3b82f6;box-shadow:0 0 8px #3b82f64d;color:#fff}.tool-btn:disabled{cursor:not-allowed;opacity:.3}.toolbar-divider{background:#334155;height:52px;margin:0 4px;width:1px}.canvas-container{align-items:center;background:#f5f5f5;border:1px solid #334155;border-radius:12px;display:flex;justify-content:center;overflow:hidden}.canvas-info{background:#0f172a;border:1px solid #334155;border-radius:10px;display:flex;flex-direction:column;gap:10px;margin-top:20px;padding:14px 18px}.info-row{color:#94a3b8;font-size:13px;gap:16px}.info-row span{align-items:center;display:flex;gap:6px}.measurement-hint,.panning-hint{background:#1e293b;border-left:3px solid #f59e0b;border-radius:6px;color:#94a3b8;font-size:13px;padding:8px 12px}.panning-hint{border-left-color:#3b82f6}.btn-link{background:none;border:none;color:#60a5fa;cursor:pointer;font-size:13px;font-weight:600;padding:0;text-decoration:underline}.btn-link:hover{color:#93c5fd}.model-content{grid-gap:32px;display:grid;gap:32px;grid-template-columns:1.5fr 1fr}.model-viewer{background:#0f172a;border:1px solid #334155;border-radius:12px;height:500px;overflow:hidden;position:relative}.model-controls-hint{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172ae6;border-radius:8px;bottom:16px;color:#94a3b8;left:50%;padding:10px 20px;transform:translateX(-50%)}.model-controls-hint,.model-info-badge{align-items:center;border:1px solid #334155;display:flex;font-size:12px;gap:8px;position:absolute;z-index:10}.model-info-badge{background:#1e293bf2;border-radius:8px;color:#e2e8f0;font-weight:600;left:16px;padding:10px 16px;top:16px}.model-controls h3{color:#e2e8f0;font-size:18px;font-weight:700;margin-bottom:20px}.control-group{display:flex;flex-direction:column;gap:8px;position:relative}.control-group label{color:#94a3b8;display:block;font-size:13px;font-weight:600;margin-bottom:6px}.roof-type-description{background:#3b82f60f;border-left:3px solid #3b82f6;border-radius:4px;color:#94a3b8;font-size:12px;line-height:1.5;margin-top:8px;padding:8px 12px}.control-group input[type=number],.control-group select{background:#0f172a;border:1px solid #334155;border-radius:8px;color:#e2e8f0;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.control-group input[type=number]:focus,.control-group select:focus{border-color:#3b82f6;outline:none}.control-group input[type=range]{accent-color:#3b82f6;margin:8px 0;width:100%}.range-labels{color:#64748b;display:flex;font-size:12px;justify-content:space-between}.material-picker-btn{align-items:center;background:#0f172a;border:1px solid #334155;border-radius:8px;color:#e2e8f0;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:12px;padding:12px 14px;transition:all .2s ease;width:100%}.material-picker-btn:hover{border-color:#3b82f6}.material-picker-btn .arrow{color:#64748b;font-size:12px;margin-left:auto}.material-picker-dropdown{background:#1e293b;border:1px solid #3b82f6;border-radius:12px;box-shadow:0 8px 32px #0006;left:0;max-height:300px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 8px);z-index:10}.material-option{align-items:center;background:#0000;border:none;border-bottom:1px solid #334155;cursor:pointer;display:flex;gap:12px;padding:12px 16px;text-align:left;transition:background .15s ease;width:100%}.material-info-text{display:flex;flex:1 1;flex-direction:column;gap:3px}.material-info-text .material-name{color:#e2e8f0;font-size:14px;font-weight:600}.material-info-text .material-desc{color:#64748b;font-size:12px;line-height:1.4}.material-option:last-child{border-bottom:none}.material-option:hover{background:#3b82f60f}.material-option.selected{background:#3b82f61a}.material-swatch{border:1px solid #475569;border-radius:6px;flex-shrink:0;height:32px;width:32px}.material-option .check{color:#3b82f6;font-weight:700;margin-left:auto}.area-display{background:linear-gradient(135deg,#1e3a5f,#1e293b);border:1px solid #334155;border-radius:12px;color:#fff;margin-top:20px;padding:20px;text-align:center}.area-display h4{color:#94a3b8;font-size:13px;font-weight:600;margin-bottom:6px}.area-value{color:#f1f5f9;font-size:30px;font-weight:800}.measurements-panel{background:#0f172a;border:1px solid #334155;border-radius:12px;margin-top:20px;padding:20px}.measurements-panel h4{color:#e2e8f0;font-size:15px;font-weight:700;margin-bottom:14px}.measurements-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.measurement-item{align-items:center;background:#1e293b;border:1px solid #334155;border-radius:6px;display:flex;font-size:13px;justify-content:space-between;padding:10px 12px}.measurement-item .label{color:#94a3b8;font-weight:500}.measurement-item .value{color:#60a5fa;font-weight:700}.materials-toolbar{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:28px}.filter-box,.search-box{align-items:center;background:#0f172a;border:1px solid #334155;border-radius:8px;display:flex;flex:1 1;gap:10px;min-width:200px;padding:10px 14px}.filter-box select,.search-box input{background:#0000;border:none;color:#e2e8f0;flex:1 1;font-size:14px;outline:none}.search-box input::placeholder{color:#475569}.filter-box select option{background:#1e293b;color:#e2e8f0}.materials-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:24px}.material-card{background:#0f172a;border:1px solid #334155;cursor:pointer;padding:22px;transition:all .25s ease}.material-card:hover{border-color:#475569;box-shadow:0 8px 24px #00000040;transform:translateY(-3px)}.material-card.selected{background:#3b82f60f;border-color:#3b82f6}.material-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.material-header h3{color:#e2e8f0;flex:1 1;font-size:16px;font-weight:700}.selection-indicator{color:#3b82f6}.material-type{background:#3b82f6;border-radius:10px;color:#fff;display:inline-block;font-size:11px;font-weight:600;margin-bottom:10px;padding:3px 10px;text-transform:uppercase}.material-description{color:#94a3b8;font-size:13px;line-height:1.6;margin-bottom:14px}.material-pricing{border-top:1px solid #334155;gap:14px;padding-top:14px}.price-item{display:flex;flex:1 1;flex-direction:column;gap:3px}.price-item .label{color:#64748b;font-size:11px}.price-item .value{color:#e2e8f0;font-size:14px;font-weight:700}.materials-summary{background:#3b82f60f;border:1px solid #334155;border-radius:8px;color:#60a5fa;font-size:15px;font-weight:600;padding:14px;text-align:center}.estimate-content{margin:0 auto}.estimate-card{background:linear-gradient(135deg,#1e3a5f,#1e293b);border:1px solid #334155;border-radius:16px;color:#fff;margin-bottom:28px;min-height:160px;overflow:hidden;padding:36px;position:relative}.estimate-card:before{background:radial-gradient(circle,#3b82f614 0,#0000 70%);content:"";height:300px;pointer-events:none;position:absolute;right:-20%;top:-40%;width:300px}.estimate-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:28px}.estimate-header h3{color:#e2e8f0;font-size:20px;font-weight:700}.total-cost{align-items:center;display:flex;gap:12px}.total-cost .amount{color:#f1f5f9;font-size:clamp(28px,5vw,40px);font-weight:800;line-height:1.2;word-break:break-all}.estimate-detail{display:flex;flex-direction:column;gap:12px}.estimate-card .detail-item{background:#0000;border-bottom:1px solid #ffffff1a;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding:14px 0}.estimate-card .detail-item:last-child{border-bottom:none}.estimate-card .detail-item .label{color:#ffffffb3;font-size:14px}.estimate-card .detail-item .value{color:#f1f5f9;font-size:15px;font-weight:700}.estimate-breakdown{background:#1e293b;border:1px solid #334155;border-radius:14px;margin-bottom:24px;padding:28px}.estimate-breakdown h3{color:#e2e8f0;font-size:18px;font-weight:700;margin-bottom:20px}.breakdown-table{display:flex;flex-direction:column;gap:8px}.table-header,.table-row{grid-gap:16px;align-items:center;display:grid;gap:16px;grid-template-columns:2fr 1fr 1fr 1fr;padding:14px 18px}.table-header{background:#0f172a;font-size:12px;font-weight:700;letter-spacing:.3px;text-transform:uppercase}.table-header,.table-row{border:1px solid #334155;border-radius:8px;color:#94a3b8}.table-row{background:#0f172a66;font-size:14px}.material-name{color:#e2e8f0;font-size:14px;font-weight:600}.row-total{color:#60a5fa;font-size:14px;font-weight:700}.labor-details{background:#1e293b;border:1px solid #334155;border-radius:14px;gap:12px;padding:24px}.labor-details .detail-item{background:#0000;border-color:#334155}.labor-details .detail-item .label{color:#94a3b8}.labor-details .detail-item .value{color:#e2e8f0}.estimate-actions{display:flex;gap:12px;justify-content:center}.cost-controls-panel{background:#1e293b;border:1px solid #334155;border-radius:14px;margin-bottom:28px;overflow:hidden}.cost-controls-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:18px 24px;transition:background .2s ease}.cost-controls-header:hover{background:#3b82f60a}.cost-controls-header h3{color:#e2e8f0;font-size:16px;font-weight:700;margin:0}.toggle-btn{background:#0f172a;border:1px solid #334155;border-radius:8px;color:#94a3b8;font-size:13px;transition:all .2s ease}.toggle-btn:hover{background:#1e293b;border-color:#475569;color:#e2e8f0}.cost-controls-content{background:#0f172a;border-top:1px solid #334155;padding:24px}.controls-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));margin-bottom:20px}.control-item{gap:6px}.control-item,.control-item label{display:flex;flex-direction:column}.control-item label{color:#94a3b8;font-size:13px;font-weight:600;gap:3px}.help-text{color:#64748b;font-size:12px;font-weight:400}.control-input-group{align-items:center;background:#1e293b;border:1px solid #334155;border-radius:8px;display:flex;gap:8px;padding:0 12px;transition:border-color .2s ease}.control-input-group:focus-within{background:#1e293b;border-color:#3b82f6}.control-input-group input{background:#0000;border:none;color:#e2e8f0;flex:1 1;font-size:15px;font-weight:600;outline:none;padding:10px 0}.control-input-group .unit{color:#64748b;font-size:14px;font-weight:600}.controls-actions{border-top:1px solid #334155;display:flex;gap:12px;justify-content:flex-end;padding-top:16px}.cost-adjustments-summary{background:#0f172a;border:1px solid #334155;border-radius:10px;margin-top:20px;padding:20px}.cost-adjustments-summary h4{color:#e2e8f0;font-size:15px;font-weight:700;margin-bottom:14px}.adjustment-row{align-items:center;border-bottom:1px solid #334155;color:#94a3b8}.adjustment-row.discount span:last-child{color:#ef4444}.adjustment-row.total{border-top:2px solid #3b82f6;color:#f1f5f9;font-size:16px;margin-top:10px;padding-top:14px}.share-modal{background:#1e293b;border:1px solid #334155;border-radius:16px;max-width:600px;padding:32px;width:90%}.share-modal h3{color:#f1f5f9;font-size:22px;font-weight:700;margin-bottom:12px}.modal-description{font-size:14px;line-height:1.6;margin-bottom:24px}.share-link-box{display:flex;gap:8px;margin-bottom:24px}.share-link-input{background:#0f172a;border:1px solid #334155;border-radius:8px;color:#e2e8f0;flex:1 1;font-family:monospace;font-size:13px;padding:12px}.btn-icon{background:#3b82f6;color:#fff;padding:12px 16px;transition:background .2s ease}.btn-icon:hover{background:#2563eb}.share-actions{display:flex;gap:12px}.btn-share{background:#10b981!important;color:#fff!important}.btn-share:hover{background:#059669!important}.empty-state,.error-state,.loading-state{color:#64748b;padding:60px 20px;text-align:center}.spinner{animation:spin 1s linear infinite;border:3px solid #334155;border-radius:50%;border-top-color:#3b82f6;height:44px;margin:0 auto 20px;width:44px}.materials-layout{grid-gap:24px;display:grid;gap:24px;grid-template-columns:2fr 1fr;margin-bottom:24px}.materials-selection{background:#1e293b;border:1px solid #334155;border-radius:14px;padding:24px}.view-toggle{border:1px solid #334155}.view-toggle .toggle-btn{background:#0000;border:none;border-radius:0;color:#64748b;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s}.view-toggle .toggle-btn:hover{background:#3b82f60f}.view-toggle .toggle-btn.active{background:#3b82f6;color:#fff}.category-tabs{border-bottom:1px solid #334155;display:flex;flex-wrap:wrap;gap:8px;margin:16px 0;padding-bottom:16px}.category-tab{background:#0000;border:1px solid #334155;border-radius:8px;color:#64748b;cursor:pointer;font-size:13px;font-weight:600;padding:6px 14px;transition:all .2s}.category-tab:hover{background:#3b82f60f;border-color:#475569;color:#94a3b8}.category-tab.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.materials-list{display:flex;flex-direction:column;max-height:500px;overflow-y:auto}.material-item{background:#0f172a;border:1px solid #334155;border-radius:10px;justify-content:space-between;padding:14px;transition:all .2s}.material-item:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f614}.material-info h4{color:#e2e8f0;font-size:14px;font-weight:600;margin:0 0 3px}.material-category{color:#64748b;font-size:12px;margin:0 0 8px}.material-price{align-items:center;display:flex;gap:8px}.price-label{color:#64748b;font-size:13px}.price-value{color:#10b981;font-size:14px;font-weight:700}.btn-add-material{align-items:center;background:#3b82f6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:34px;justify-content:center;min-height:34px;min-width:34px;transition:all .2s;width:34px}.btn-add-material:hover{background:#2563eb;transform:scale(1.1)}.materials-cart{background:#1e293b;border:1px solid #334155;border-radius:14px;max-height:calc(100vh - 48px);overflow-y:auto;padding:24px;position:-webkit-sticky;position:sticky;top:24px}.materials-cart h3{border-bottom:1px solid #334155;color:#e2e8f0;font-size:17px;font-weight:700;margin:0 0 16px;padding-bottom:16px}.cart-empty{color:#64748b;padding:28px;text-align:center}.cart-empty p{font-weight:600;margin:0 0 6px}.cart-items{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.cart-item{background:#0f172a;border:1px solid #334155;border-radius:10px;padding:14px}.cart-item-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.cart-item-header h4{color:#e2e8f0;flex:1 1;font-size:13px;font-weight:600;margin:0}.btn-remove{align-items:center;background:#ef44441f;border:none;border-radius:50%;color:#ef4444;cursor:pointer;display:flex;height:24px;justify-content:center;transition:all .15s;width:24px}.btn-remove:hover{background:#ef4444;color:#fff}.cart-item-category{color:#64748b;font-size:11px;margin:0 0 10px}.quantity-controls{align-items:center;display:flex;gap:8px;margin-bottom:10px}.quantity-controls button{align-items:center;background:#1e293b;border:1px solid #334155;border-radius:9999px;box-sizing:border-box;color:#94a3b8;cursor:pointer;display:inline-flex;flex-shrink:0;height:30px;justify-content:center;line-height:1;max-height:30px;max-width:30px;min-height:30px;min-width:30px;padding:0;transition:all .15s;width:30px}.quantity-controls button:hover{background:#3b82f6;border-color:#3b82f6;color:#fff}.quantity-controls input{background:#0f172a;border:1px solid #334155;border-radius:6px;color:#e2e8f0;font-size:13px;font-weight:600;padding:5px;text-align:center;width:56px}.quantity-controls .unit{color:#64748b;font-size:13px}.cart-item-total{align-items:center;border-top:1px solid #334155;display:flex;justify-content:space-between;padding-top:10px}.cart-item-total .label{color:#64748b;font-size:13px}.cart-item-total .value{color:#10b981;font-size:14px;font-weight:700}.cart-summary{background:#10b9810f;border:1px solid #10b98133;border-radius:10px;margin-top:12px;padding:14px}.summary-row{align-items:center;color:#94a3b8;display:flex;font-size:15px;justify-content:space-between}.summary-row strong{color:#10b981;font-size:20px}.summary-note{color:#64748b;font-size:11px;font-style:italic;margin:6px 0 0}.roof-area-info{color:#10b981;font-size:14px;margin-top:8px}.roof-area-input{align-items:center;background:#10b9810f;border:1px solid #10b98133;border-radius:8px;display:flex;margin-top:12px;padding:14px}.roof-area-input label{color:#10b981;font-weight:600}.accuracy-panel{background:#1e293b;border:1px solid #334155;border-radius:14px;margin:20px 0}.accuracy-header{align-items:center;border-bottom:1px solid #334155;cursor:pointer;display:flex;justify-content:space-between;padding:18px 24px;transition:background .2s}.accuracy-header:hover{background:#3b82f60a}.accuracy-header h3{color:#60a5fa;font-size:16px;font-weight:700;margin:0}.accuracy-content{padding:24px}.validation-section{border-radius:10px;margin-bottom:20px;padding:16px}.validation-section.warnings{background:#ef44440f;border-left:3px solid #ef4444}.validation-section.recommendations{background:#3b82f60f;border-left:3px solid #3b82f6}.validation-section h4{align-items:center;color:#e2e8f0;display:flex;font-size:15px;font-weight:600;gap:8px;margin:0 0 12px}.validation-section ul{list-style:none;margin:0;padding:0}.validation-section li{font-size:13px;line-height:1.6;padding:8px 0}.warning-item{color:#fca5a5}.rec-item{color:#93c5fd}.additional-materials-section,.labor-complexity-section,.measurements-section,.waste-factor-info{background:#0f172a;border:1px solid #334155;border-radius:10px;margin-bottom:20px;padding:16px}.additional-materials-section h4,.labor-complexity-section h4,.measurements-section h4,.waste-factor-info h4{color:#e2e8f0;font-size:15px;font-weight:600;margin:0 0 14px}.additional-materials-grid,.measurements-grid,.waste-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.additional-item,.measurement-item,.waste-item{background:#1e293b;border:1px solid #334155;border-radius:6px;display:flex;justify-content:space-between;padding:10px 12px}.item-name,.measurement-label,.waste-type{color:#94a3b8;font-size:13px;font-weight:600}.item-qty,.measurement-value,.waste-range{color:#60a5fa;font-size:13px;font-weight:700}.complexity-selector{margin-bottom:16px}.complexity-selector label{color:#94a3b8;display:block;font-size:13px;font-weight:600;margin-bottom:8px}.complexity-select{background:#0f172a;border:1px solid #334155;border-radius:8px;color:#e2e8f0;cursor:pointer;font-size:14px;padding:10px 14px;transition:border-color .2s;width:100%}.complexity-select:focus{border-color:#3b82f6;outline:none}.labor-breakdown{display:flex;flex-direction:column;gap:8px}.labor-item{background:#1e293b;border:1px solid #334155;border-radius:6px;color:#94a3b8;display:flex;font-size:13px;justify-content:space-between;padding:10px 14px}.labor-item.total{background:#3b82f614;border-color:#3b82f6;color:#f1f5f9;font-weight:700}.percentage-input input{font-size:14px;padding:10px}.percentage-input input,.tool-btn:hover:after{background:#0f172a;border:1px solid #334155;color:#e2e8f0}.tool-btn:hover:after{border-radius:6px;bottom:-32px;content:attr(title);font-size:11px;left:50%;padding:6px 10px;pointer-events:none;position:absolute;transform:translateX(-50%);white-space:nowrap;z-index:1000}.tool-btn.active{box-shadow:0 0 0 2px #3b82f666}.canvas-container canvas{cursor:crosshair;touch-action:none}.canvas-container canvas.panning{cursor:grab}.canvas-container canvas.panning:active{cursor:grabbing}@keyframes pulse{0%,to{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.7;transform:translate(-50%,-50%) scale(1.3)}}.snap-indicator{animation:pulse .3s ease-out}.satellite-trace-layout{grid-gap:20px;align-items:start;display:grid;gap:20px;grid-template-columns:1fr 300px}.satellite-canvas-area{display:flex;flex-direction:column;gap:12px;min-width:0}.satellite-toolbar{align-items:center;background:#0f172a;border:1px solid #334155;border-radius:10px;display:flex;flex-wrap:wrap;gap:8px;padding:10px 14px}.sat-tool-group{align-items:center;display:flex;gap:5px}.sat-tool-divider{background:#334155;height:28px;margin:0 2px;width:1px}.sat-tool-btn{align-items:center;background:#1e293b;border:1px solid #334155;border-radius:7px;color:#94a3b8;cursor:pointer;display:inline-flex;font-size:12px;font-weight:600;gap:5px;height:34px;justify-content:center;padding:0 10px;transition:all .15s ease;white-space:nowrap}.sat-tool-btn:hover:not(:disabled){background:#3b82f614;border-color:#3b82f6;color:#60a5fa}.sat-tool-btn.active{background:#3b82f6;border-color:#3b82f6;box-shadow:0 0 6px #3b82f64d;color:#fff}.sat-tool-btn:disabled{cursor:not-allowed;opacity:.35}.sat-tool-btn.danger{color:#fca5a5}.sat-tool-btn.danger:hover:not(:disabled){background:#ef44441f;border-color:#ef4444;color:#ef4444}.vertex-edit-hint{background:#8b5cf614;border:1px solid #8b5cf640;border-radius:8px;color:#c4b5fd}.add-face-hint,.vertex-edit-hint{align-items:center;display:flex;font-size:13px;font-weight:500;gap:8px;padding:10px 14px}.add-face-hint{background:#10b98114;border:1px solid #10b98140;border-radius:8px;color:#86efac}.face-panel{background:#0f172a;border:1px solid #334155;border-radius:12px;display:flex;flex-direction:column;max-height:760px;overflow:hidden}.face-panel-header{background:#1e293b80;border-bottom:1px solid #334155;padding:14px 16px}.face-panel-header h3{color:#e2e8f0;font-size:15px;font-weight:700;margin:0 0 2px}.face-panel-header p{color:#64748b;font-size:12px;margin:0}.face-summary{grid-gap:1px;background:#334155;border-bottom:1px solid #334155;display:grid;gap:1px;grid-template-columns:1fr 1fr}.face-summary-item{background:#0f172a;padding:12px 10px;text-align:center}.face-summary-item .summary-label{color:#64748b;display:block;font-size:10px;letter-spacing:.5px;margin-bottom:3px;text-transform:uppercase}.face-summary-item .summary-value{color:#f1f5f9;font-size:20px;font-weight:800}.face-list{flex:1 1;overflow-y:auto;padding:6px}.face-list-item{align-items:center;border:1px solid #0000;border-radius:8px;cursor:pointer;display:flex;gap:10px;padding:9px 10px;transition:all .15s}.face-list-item:hover{background:#3b82f60f}.face-list-item.selected{background:#3b82f61a;border-color:#3b82f64d}.face-color-dot{border-radius:3px;flex-shrink:0;height:12px;width:12px}.face-list-info{flex:1 1;min-width:0}.face-list-name{color:#e2e8f0;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.face-list-area{color:#64748b;font-size:11px}.face-panel-empty{color:#64748b;font-size:13px;padding:24px 12px;text-align:center}.face-detail{background:#1e293b4d;border-top:1px solid #334155;padding:14px}.face-detail-title{color:#64748b;font-size:11px;font-weight:700;letter-spacing:.5px;margin:0 0 10px;text-transform:uppercase}.face-detail-fields{gap:8px}.face-detail-fields,.face-field{display:flex;flex-direction:column}.face-field{gap:3px}.face-field label{color:#64748b;font-size:11px;font-weight:600}.face-field input{background:#1e293b;border:1px solid #334155;border-radius:6px;color:#e2e8f0;font-size:13px;outline:none;padding:7px 10px;transition:border-color .15s}.face-field input:focus{border-color:#3b82f6}.face-area-display{background:#1e293b;border:1px solid #334155;border-radius:6px;color:#60a5fa;font-size:13px;font-weight:600;padding:7px 10px}.face-detail-actions{display:flex;gap:6px;margin-top:10px}.face-action-btn{align-items:center;background:#1e293b;border:1px solid #334155;border-radius:6px;color:#94a3b8;cursor:pointer;display:flex;flex:1 1;font-size:12px;font-weight:600;gap:5px;justify-content:center;padding:7px;transition:all .15s}.face-action-btn:hover{background:#3b82f614;border-color:#3b82f6;color:#60a5fa}.face-action-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.face-action-btn.danger:hover{background:#ef444414;border-color:#ef4444;color:#ef4444}@media (max-width:1024px){.materials-layout{grid-template-columns:1fr}.materials-cart{max-height:none;position:static}.satellite-trace-layout{grid-template-columns:1fr}.face-panel{max-height:400px}}@media (max-width:968px){.genie-step{padding:20px 16px}.step-header h2{font-size:22px}.step-content{padding:24px 18px}.model-content{gap:24px;grid-template-columns:1fr}.model-viewer{height:380px;order:1}.model-controls{order:2}.measurements-grid{grid-template-columns:1fr}.materials-toolbar{flex-direction:column}.materials-grid{grid-template-columns:1fr}.estimate-card{padding:24px}.estimate-header{align-items:flex-start;flex-direction:column;gap:14px}.total-cost{justify-content:space-between;width:100%}.total-cost .amount{font-size:clamp(24px,8vw,36px)}.estimate-breakdown{padding:20px}.table-header,.table-row{gap:6px;grid-template-columns:1fr;padding:12px 16px}.table-header span{display:none}.table-row span:before{color:#64748b;content:attr(data-label);display:inline-block;font-weight:600;margin-right:8px}.canvas-toolbar{gap:10px;padding:12px}.toolbar-section{width:100%}.toolbar-buttons{flex-wrap:wrap;gap:6px}.tool-btn{height:42px;width:42px}.toolbar-divider{display:none}.canvas-container{overflow-x:auto}.canvas-container canvas{min-width:600px!important}.upload-zone{padding:40px 20px}.upload-zone h3{font-size:18px}.step-actions{flex-direction:column;width:100%}.step-actions .btn{justify-content:center;width:100%}.estimate-actions{flex-direction:column;padding:0 16px;width:100%}.estimate-actions .btn{width:100%}}@media (max-width:768px){.additional-materials-grid,.measurements-grid,.waste-grid{grid-template-columns:1fr}.accuracy-header{padding:14px}.accuracy-content{padding:16px}}@media (max-width:480px){.genie-step{padding:16px 12px}.step-header h2{font-size:18px}.step-content{padding:18px 12px}.estimate-card{padding:16px 12px}.estimate-breakdown{padding:14px 10px}.canvas-container canvas{min-width:100%!important}}.review-toolbar{background:#1e293b;border:1px solid #334155;border-radius:10px;justify-content:space-between;margin-bottom:20px;padding:12px 20px}.review-toolbar,.review-toolbar-left{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.review-addr-badge,.review-pitch-badge,.review-type-badge{align-items:center;background:#0f172a;border:1px solid #334155;border-radius:6px;color:#94a3b8;display:inline-flex;font-size:13px;gap:6px;padding:5px 12px}.review-addr-badge{color:#60a5fa}.review-toolbar-right{display:flex;gap:8px}.btn-sm{font-size:12px!important;padding:6px 14px!important}.review-content{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.review-section{background:#1e293b;border:1px solid #334155;border-radius:10px;overflow:hidden}.review-section-header{align-items:center;background:#0f172a66;cursor:pointer;display:flex;justify-content:space-between;padding:14px 20px;transition:background .15s;-webkit-user-select:none;user-select:none}.review-section-header:hover{background:#0f172ab3}.review-section-title-row{align-items:center;color:#e2e8f0;display:flex;gap:8px}.review-section-title-row h3{color:#f1f5f9;font-size:15px;font-weight:700;margin:0}.review-edit-toggle{align-items:center;background:#0f172a;border:1px solid #475569;border-radius:6px;color:#94a3b8;cursor:pointer;display:inline-flex;font-size:12px;gap:5px;padding:4px 12px;transition:all .15s}.review-edit-toggle:hover{border-color:#60a5fa;color:#e2e8f0}.review-edit-toggle.active{background:#1e40af;border-color:#3b82f6;color:#fff}.review-stats-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));padding:16px 20px}.review-stat{background:#0f172a;border:1px solid #334155;border-radius:8px;padding:12px;text-align:center}.review-stat-label{color:#64748b;display:block;font-size:11px;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.review-stat-value{color:#f1f5f9;display:block;font-size:18px;font-weight:700}.review-sat-image-wrap{display:flex;justify-content:center;padding:16px 20px}.review-sat-image{border:1px solid #334155;border-radius:8px;max-height:320px;max-width:100%;object-fit:contain}.review-table-wrap{overflow-x:auto;padding:0 12px 12px}.review-table{border-collapse:collapse;font-size:14px;width:100%}.review-table th{background:#0f172a;border-bottom:1px solid #334155;color:#94a3b8;font-size:12px;font-weight:600;letter-spacing:.5px;padding:10px 14px;text-align:left;text-transform:uppercase}.review-table td{border-bottom:1px solid #33415580;color:#e2e8f0;padding:10px 14px}.review-table tbody tr:hover{background:#3b82f60d}.review-table-total td{background:#3b82f614;border-top:2px solid #3b82f6}.review-face-dot{border-radius:50%;display:inline-block;height:12px;vertical-align:middle;width:12px}.review-inline-input{background:#0f172a;border:1px solid #3b82f6;border-radius:6px;color:#f1f5f9;font-size:13px;outline:none;padding:5px 10px;transition:border-color .15s;width:100%}.review-inline-input:focus{border-color:#60a5fa;box-shadow:0 0 0 2px #3b82f633}.review-num-input{text-align:right;width:100px}.review-disclaimer{background:#f59e0b14;border:1px solid #f59e0b40;border-radius:8px;color:#fbbf24;font-size:12px;margin-top:8px;padding:12px 16px;text-align:center}.review-floor-plan-preview{padding:20px;text-align:center}@media (max-width:640px){.review-toolbar{align-items:flex-start;flex-direction:column}.review-stats-grid{grid-template-columns:repeat(2,1fr)}.review-num-input{width:80px}}.btn-reanalyze{background:#1e40af!important;border:1px solid #3b82f6!important;color:#93c5fd!important}.btn-reanalyze:hover:not(:disabled){background:#1d4ed8!important;box-shadow:0 2px 10px #3b82f64d;color:#fff!important}.btn-reanalyze:disabled{cursor:not-allowed;opacity:.7}.spin-icon{animation:spin-anim 1s linear infinite}@keyframes spin-anim{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.review-reanalyze-overlay{background:#0f172aeb;border:1px solid #334155;border-radius:12px;margin-bottom:20px;padding:40px 24px;text-align:center}.review-reanalyze-spinner{animation:spin-anim .8s linear infinite;border:3px solid #334155;border-radius:50%;border-top-color:#3b82f6;height:40px;margin:0 auto 16px;width:40px}.review-reanalyze-overlay p{color:#e2e8f0;font-size:16px;font-weight:600;margin-bottom:6px}.review-reanalyze-overlay span{color:#64748b;font-size:13px}.review-reanalyze-error{align-items:center;background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#fca5a5;display:flex;font-size:13px;justify-content:space-between;margin-bottom:16px;padding:12px 16px}.crew-labor-section{background:#1e293b;border:1px solid #334155;border-radius:10px;margin-top:8px;overflow:hidden}.crew-labor-header{align-items:center;background:#0f172a66;border-bottom:1px solid #334155;display:flex;justify-content:space-between;padding:14px 20px}.crew-labor-header h4{color:#f1f5f9;font-size:15px;font-weight:700;margin:0}.crew-labor-body{gap:18px;padding:16px 20px}.crew-labor-body,.crew-presets{display:flex;flex-direction:column}.crew-presets{gap:8px}.crew-label{color:#94a3b8;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.crew-preset-btns{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,1fr)}.crew-preset-btn{background:#0f172a;border:1px solid #334155;border-radius:8px;cursor:pointer;padding:10px 12px;text-align:center;transition:all .15s}.crew-preset-btn strong{color:#e2e8f0;display:block;font-size:13px;margin-bottom:2px}.crew-preset-btn span{color:#64748b;display:block;font-size:11px}.crew-preset-btn:hover{background:#3b82f60f;border-color:#3b82f6}.crew-preset-btn.active{background:#3b82f61f;border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f64d}.crew-preset-btn.active strong{color:#60a5fa}.crew-globals{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}.crew-global-item{display:flex;flex-direction:column;gap:4px}.crew-global-item label{color:#94a3b8;font-size:12px;font-weight:600}.crew-global-item input{background:#0f172a;border:1px solid #475569;border-radius:6px;color:#f1f5f9;font-size:14px;font-weight:600;outline:none;padding:8px 10px;width:100%}.crew-global-item input:focus{border-color:#3b82f6}.crew-unit{color:#64748b;font-size:11px}.crew-rate-input{align-items:center;display:flex;gap:4px}.crew-dollar{color:#64748b;font-size:14px}.crew-rate-input input{background:#0f172a;border:1px solid #475569;border-radius:6px;color:#f1f5f9;font-size:14px;font-weight:600;outline:none;padding:8px 10px;width:80px}.crew-rate-input input:focus{border-color:#3b82f6}.crew-phases{overflow-x:auto}.crew-phase-table{border-collapse:collapse;font-size:13px;width:100%}.crew-phase-table th{background:#0f172a;border-bottom:1px solid #334155;color:#94a3b8;font-size:11px;font-weight:600;letter-spacing:.5px;padding:8px 12px;text-align:left;text-transform:uppercase}.crew-phase-table td{border-bottom:1px solid #33415566;color:#e2e8f0;padding:8px 12px;vertical-align:middle}.crew-phase-table input[type=checkbox]{accent-color:#3b82f6;cursor:pointer;height:16px;width:16px}.phase-name{font-weight:500;min-width:180px}.phase-disabled td{opacity:.4}.crew-days-input{background:#0f172a;border:1px solid #475569;border-radius:5px;color:#f1f5f9;font-size:13px;outline:none;padding:5px 8px;text-align:center;width:60px}.crew-days-input:focus{border-color:#3b82f6}.crew-days-input:disabled{opacity:.3}.phase-num{font-family:monospace;font-size:13px;text-align:right}.crew-total-row td{background:#3b82f60f;border-top:2px solid #3b82f6;color:#f1f5f9;padding:10px 12px}.crew-recalc-btn{align-items:center;display:flex;gap:8px;justify-content:center;margin-top:4px;width:100%}@media (max-width:768px){.crew-preset-btns{grid-template-columns:repeat(2,1fr)}.crew-globals{grid-template-columns:1fr}}.genie-page{background:#0f172a;flex:1 1;min-height:100vh;width:100%}.genie-header{background:#1e293b;border-bottom:1px solid #334155;padding:20px 20px 28px}.genie-header .container{margin:0 auto;max-width:1200px}.genie-header h1{color:#f1f5f9;font-size:22px;font-weight:700;letter-spacing:-.3px;margin-bottom:28px}.steps-progress{align-items:flex-start;display:flex;justify-content:space-between;max-width:1100px;position:relative}.steps-progress:before{background:#334155;content:"";height:3px;left:22px;position:absolute;right:22px;top:22px;z-index:0}.step-item{flex:1 1;flex-direction:column;gap:10px;position:relative;z-index:1}.step-circle,.step-item{align-items:center;display:flex}.step-circle{background:#1e293b;border:3px solid #475569;border-radius:50%;color:#64748b;flex-shrink:0;height:44px;justify-content:center;transition:all .3s ease;width:44px}.step-circle svg{height:18px;width:18px}.step-circle.active{background:#3b82f6;border-color:#3b82f6;box-shadow:0 0 12px #3b82f64d;color:#fff}.step-circle.current{border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f633,0 0 16px #3b82f626;transform:scale(1.08)}.step-circle.clickable{cursor:pointer}.step-item:hover .step-circle.clickable{box-shadow:0 0 16px #3b82f659;transform:scale(1.12)}.step-label{text-align:center}.step-name{color:#94a3b8;font-size:12px;font-weight:600;line-height:1.3}.step-desc{color:#64748b;font-size:10px;line-height:1.3;margin-top:2px}.step-arrow{display:none}.genie-content{padding:40px 20px}.genie-content .container{margin:0 auto;max-width:1200px}.genie-steps-content{margin:0 auto;max-width:1000px}.new-project-modal{background:#1e293b;border:1px solid #334155;border-radius:14px;margin:0 auto;max-width:520px;padding:48px 40px;text-align:center}.new-project-modal h2{color:#f1f5f9;font-size:26px;font-weight:700;margin-bottom:10px}.new-project-modal>p{color:#64748b;font-size:14px;margin-bottom:28px}.new-project-modal .form-group{margin-bottom:24px;text-align:left}.new-project-modal label{color:#94a3b8;display:block;font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.new-project-modal input{background:#0f172a;border:1px solid #334155;border-radius:8px;color:#e2e8f0;font-size:15px;padding:12px 14px;transition:all .2s ease;width:100%}.new-project-modal input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626;outline:none}.step-content{background:#1e293b;border:1px solid #334155;border-radius:14px;padding:40px;text-align:center}.step-content h2{color:#f1f5f9;font-size:24px;font-weight:700;margin-bottom:6px}.step-content>p{color:#64748b;font-size:14px;margin-bottom:32px}.canvas-area,.estimate-area,.materials-area,.model-area,.upload-area{align-items:center;border:2px dashed #475569;border-radius:12px;color:#64748b;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:360px;transition:all .25s ease}.canvas-area:hover,.estimate-area:hover,.materials-area:hover,.model-area:hover,.upload-area:hover{background:#3b82f60a;border-color:#3b82f6}.genie-page .btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;letter-spacing:.1px;padding:12px 24px;transition:all .2s ease}.genie-page .btn-primary{background:#3b82f6;color:#fff}.genie-page .btn-primary:hover{background:#2563eb;box-shadow:0 4px 16px #3b82f659;transform:translateY(-1px)}.genie-page .btn-secondary{background:#0000;border:1px solid #334155;color:#94a3b8}.genie-page .btn-secondary:hover{border-color:#64748b;color:#e2e8f0}.dashboard-wrapper{margin:0 auto;max-width:1100px}.dash-topbar{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:28px}.dash-stats{display:flex;gap:32px}.dash-stat{align-items:center;display:flex;flex-direction:column}.dash-stat-num{color:#f1f5f9;font-size:30px;font-weight:700;line-height:1}.dash-stat-label{color:#64748b;font-size:11px;font-weight:600;letter-spacing:.5px;margin-top:4px;text-transform:uppercase}.dash-create-form{align-items:center;background:#1e293b;border:1px solid #334155;border-radius:12px;display:flex;gap:10px;margin-bottom:24px;padding:16px 20px}.dash-create-form input{background:#0f172a;border:1px solid #334155;border-radius:8px;color:#e2e8f0;flex:1 1;font-size:14px;padding:10px 14px}.dash-create-form input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626;outline:none}.dash-create-form input::placeholder{color:#475569}.dash-empty{color:#64748b;padding:80px 20px;text-align:center}.dash-empty h3{color:#94a3b8;font-size:20px;margin:16px 0 6px}.dash-empty p{color:#64748b;font-size:14px;margin-bottom:24px}.dash-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.dash-card{background:#1e293b;border:1px solid #334155;border-radius:12px;cursor:pointer;overflow:hidden;transition:all .25s ease}.dash-card:hover{border-color:#3b82f6;box-shadow:0 4px 24px #3b82f61f;transform:translateY(-3px)}.dash-card-thumb{align-items:center;background:#0f172a;display:flex;height:120px;justify-content:center;overflow:hidden;position:relative}.dash-card-thumb img{height:100%;object-fit:cover;width:100%}.dash-card-placeholder{color:#334155}.dash-card-badge{border-radius:20px;color:#fff;font-size:10px;font-weight:600;letter-spacing:.3px;padding:3px 10px;position:absolute;right:8px;text-transform:uppercase;top:8px}.dash-card-body{padding:14px 16px 8px}.dash-card-title{color:#e2e8f0;font-size:14px;font-weight:600;margin:0 0 6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-card-meta{align-items:center;color:#64748b;display:flex;font-size:11px;gap:6px}.dash-card-cost{color:#10b981;font-size:13px;font-weight:700;margin-left:auto}.dash-card-progress{align-items:center;display:flex;gap:8px;margin-top:10px}.dash-progress-track{background:#334155;border-radius:4px;flex:1 1;height:4px;overflow:hidden}.dash-progress-fill{border-radius:4px;height:100%;transition:width .4s ease}.dash-progress-label{color:#64748b;font-size:10px;font-weight:600;min-width:28px;text-align:right}.dash-card-actions{align-items:center;display:flex;gap:8px;padding:8px 16px 14px}.dash-btn-resume{align-items:center;background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:12px;font-weight:600;gap:5px;justify-content:center;padding:8px 14px;transition:all .2s ease}.dash-btn-resume:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f64d}.dash-btn-delete{align-items:center;background:#0000;border:1px solid #334155;border-radius:8px;color:#64748b;cursor:pointer;display:flex;padding:8px 10px;transition:all .15s ease}.dash-btn-delete:hover{background:#ef44441a;border-color:#ef4444;color:#ef4444}@media (max-width:968px){.genie-header{padding:14px 16px 22px}.genie-header h1{font-size:18px;margin-bottom:18px}.steps-progress{gap:0}.steps-progress:before{left:18px;right:18px;top:18px}.step-circle{height:36px;width:36px}.step-circle svg{height:15px;width:15px}.step-label{display:none}.genie-content,.new-project-modal{padding:20px}.new-project-modal h2{font-size:20px}.btn{font-size:14px;padding:12px 18px}.dash-grid{grid-template-columns:1fr}.dash-stats{gap:16px}.dash-stat-num{font-size:22px}.dash-create-form{flex-direction:column}.dash-create-form input{width:100%}}@media (max-width:480px){.genie-page{overflow-x:hidden}.genie-header{padding:12px 12px 18px}.genie-header h1{font-size:16px}.genie-content{padding:16px 12px}.dash-stat-num{font-size:20px}.dash-stat-label{font-size:10px}}.projects-page{background:#f5f5f5;min-height:100vh}.page-header{background:linear-gradient(135deg,#2c5f8d,#1a3d5c);color:#fff;padding:60px 20px}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px}.header-content h1{font-size:36px;font-weight:700;margin-bottom:10px}.header-content p{font-size:16px;opacity:.95}.projects-section{padding:60px 20px}.projects-controls{align-items:center;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:32px;margin-left:auto;margin-right:auto;max-width:1400px}.search-container{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;display:flex;flex:1 1;gap:12px;min-width:300px;padding:12px 16px;position:relative;transition:all .2s}.search-container:focus-within{border-color:#2c5f8d;box-shadow:0 0 0 3px #2c5f8d1a}.search-container svg{color:#64748b;flex-shrink:0}.search-input{background:#0000;border:none;color:#1a3d5c;flex:1 1;font-size:15px;outline:none}.search-input::placeholder{color:#94a3b8}.filter-container{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;display:flex;gap:12px;padding:12px 16px;transition:all .2s}.filter-container:focus-within{border-color:#2c5f8d;box-shadow:0 0 0 3px #2c5f8d1a}.filter-container svg{color:#64748b;flex-shrink:0}.filter-select{background:#0000;border:none;color:#1a3d5c;cursor:pointer;font-size:15px;font-weight:500;outline:none}.results-count{background:#f8fafc;font-size:14px;padding:12px 20px;white-space:nowrap}.empty-state,.loading-state{padding:80px 20px;text-align:center}.empty-state svg{color:#ccc;margin-bottom:20px}.empty-state h2{color:#333;font-size:28px;font-weight:700;margin-bottom:10px}.empty-state p{color:#666;font-size:16px;margin-bottom:30px}.projects-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin:0 auto;max-width:1400px}.project-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000000d;overflow:hidden;padding:24px;transition:all .3s ease}.project-card:hover{border-color:#2c5f8d;box-shadow:0 8px 24px #0000001f;transform:translateY(-4px)}.project-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.project-title-row{align-items:center;display:flex;flex:1 1;gap:10px}.project-title-row svg{flex-shrink:0}.project-header h3{color:#1e293b;font-size:18px;font-weight:600;line-height:1.4;margin:0}.project-actions{display:flex;gap:8px}.action-btn{align-items:center;background:#f5f5f5;border:none;border-radius:6px;color:#666;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .3s ease;width:32px}.action-btn:hover{background:#2c5f8d;color:#fff}.action-btn.delete:hover{background:#dc3545}.project-meta{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.project-type{align-items:center;border-radius:16px;display:inline-flex;font-size:12px;font-weight:600;padding:4px 12px;text-transform:capitalize}.project-date{align-items:center;color:#64748b;display:flex;font-size:13px;font-weight:500;gap:6px}.project-date svg{color:#94a3b8}.project-details{margin-top:12px}.project-address{color:#64748b;font-size:14px;line-height:1.5;margin-bottom:8px}.project-stats{display:flex;flex-wrap:wrap;gap:16px;margin-top:8px}.project-stats span{background:#f1f5f9;border-radius:6px;color:#475569;font-size:13px;font-weight:600;padding:6px 12px}.project-estimation{background:#f9f9f9;border-radius:8px;margin-bottom:16px;padding:16px}.estimation-item{display:flex;font-size:14px;justify-content:space-between;margin-bottom:8px}.estimation-item:last-child{margin-bottom:0}.estimation-item .label{color:#666}.estimation-item .value{color:#333;font-weight:600}.estimation-item .value.cost{color:#2c5f8d;font-size:16px;word-break:break-word}.btn{border-radius:6px;font-size:14px;gap:8px;justify-content:center;padding:12px 24px;transition:all .3s ease}.btn-secondary{border:2px solid #ddd;color:#333}.btn-secondary:hover{border-color:#2c5f8d;color:#2c5f8d}.btn-full{width:100%}.project-buttons{display:flex;gap:.75rem;margin-top:1rem}.project-buttons .btn{flex:1 1;font-size:.875rem;justify-content:center;padding:.625rem 1rem}.project-buttons .btn:disabled{cursor:not-allowed;opacity:.6}.modal-overlay{padding:1rem}.modal-content{box-shadow:0 20px 40px #0003}.modal-content h2{margin:0 0 .5rem}.modal-description{color:#64748b;font-size:.875rem;margin-bottom:1.5rem}.client-select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#1e293b;cursor:pointer;font-size:1rem;padding:.75rem;transition:all .2s;width:100%}.client-select:focus{border-color:#ff6b35;box-shadow:0 0 0 3px #ff6b351a;outline:none}.no-clients-message{background:#fef3c7;border:2px solid #fde68a;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.no-clients-message p{color:#92400e;font-size:.875rem;margin:0 0 1rem}.modal-actions .btn{padding:.75rem 1.5rem}@media (max-width:768px){.header-content{align-items:flex-start;flex-direction:column;gap:20px}.projects-controls{flex-direction:column;gap:12px}.search-container{min-width:100%;width:100%}.filter-container,.filter-select{width:100%}.results-count{text-align:center;width:100%}.projects-grid{grid-template-columns:1fr}.project-card{padding:20px}.project-header h3{font-size:16px}.project-stats{flex-direction:column;gap:8px}.project-stats span{display:block}.estimation-item{font-size:13px}.estimation-item .value.cost{font-size:14px}}.project-card-actions{border-top:1px solid #eee;display:flex;gap:8px;margin-top:16px;padding-top:16px}.project-card-actions .btn-sm{align-items:center;border-radius:6px;display:flex;flex:1 1;font-size:12px;gap:4px;justify-content:center;padding:8px 12px;transition:all .2s}.project-card-actions .btn-outline{background:#0000;border:1px solid #ddd;color:#666}.project-card-actions .btn-outline:hover{background:#f0f0f0;border-color:#bbb;color:#333}.detail-modal{max-height:90vh;max-width:700px;overflow-y:auto;width:95%}.modal-close{background:none;border:none;border-radius:50%;color:#666;cursor:pointer;padding:8px;position:absolute;right:16px;top:16px;transition:all .2s}.modal-close:hover{background:#f0f0f0;color:#333}.detail-header{gap:16px;margin-bottom:20px}.detail-header h2{font-size:24px;margin:0 0 4px}.detail-type{border-radius:20px;display:inline-block;font-size:12px;font-weight:500;padding:4px 12px}.detail-meta{border-bottom:1px solid #eee;color:#666;display:flex;font-size:14px;gap:16px;margin-bottom:24px;padding-bottom:16px}.detail-meta span{align-items:center;display:flex;gap:6px}.detail-content{margin-bottom:24px}.detail-grid{grid-gap:12px;gap:12px;grid-template-columns:repeat(2,1fr);margin-bottom:20px}.detail-item{background:#f8f9fa;border-radius:8px;padding:12px}.detail-item strong{color:#555;display:block;font-size:12px;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.detail-pricing{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;margin-top:20px;padding:20px}.detail-pricing h4{color:#333;font-size:16px;margin:0 0 16px}.pricing-row{color:#555;display:flex;font-size:14px;justify-content:space-between;padding:8px 0}.pricing-row.total{border-top:2px solid #ddd;color:#2c5f8d;font-size:18px;font-weight:700;margin-top:12px;padding-top:12px}.detail-actions{border-top:1px solid #eee;gap:12px;padding-top:20px}.detail-actions .btn{align-items:center;border-radius:8px;display:flex;flex:1 1;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:12px 16px;transition:all .2s}.detail-actions .btn-secondary{background:#f0f0f0;border:1px solid #ddd;color:#333}.detail-actions .btn-secondary:hover{background:#e0e0e0}.detail-actions .btn-primary{background:linear-gradient(135deg,#f59e0b,#d97706);border:none;color:#fff}.detail-actions .btn-primary:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-1px)}@media (max-width:600px){.detail-grid{grid-template-columns:1fr}.detail-actions{flex-direction:column}.project-card-actions{flex-wrap:wrap}.project-card-actions .btn-sm{min-width:calc(50% - 4px)}}.materials-management{margin:0 auto;max-width:1400px;padding:40px}.materials-header{display:flex;justify-content:space-between;margin-bottom:32px}.header-actions,.materials-header{align-items:center}.view-toggle{border:2px solid #e2e8f0;border-radius:8px;display:flex;gap:0;overflow:hidden}.toggle-btn{background:#fff;border:none;color:#64748b;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s}.toggle-btn:hover{background:#f8fafc}.toggle-btn.active{background:#ff6b35;color:#fff}.materials-grouped{display:flex;flex-direction:column;gap:2rem}.category-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:1.5rem}.category-title{align-items:center;border-bottom:3px solid #ff6b35;color:#1e293b;display:flex;font-size:1.5rem;font-weight:700;gap:.75rem;margin:0 0 1.5rem;padding-bottom:1rem}.category-count{background:#f1f5f9;border-radius:12px;color:#64748b;font-size:1rem;font-weight:500;padding:.25rem .75rem}.materials-header h1{color:#1a3d5c;font-size:32px;font-weight:700}.materials-filters{align-items:center;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:32px}.search-box{gap:12px;padding:12px 16px;position:relative}.search-box input{color:#1a3d5c;font-size:15px}.filter-box{gap:12px;padding:12px 16px}.filter-box select{color:#1a3d5c;font-size:15px}.materials-stats{background:#f8fafc;border-radius:8px;color:#64748b;font-size:14px;font-weight:600;padding:12px 20px}.materials-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.material-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;overflow:hidden;transition:all .3s ease}.material-card:hover{border-color:#2c5f8d;box-shadow:0 8px 24px #2c5f8d26;transform:translateY(-2px)}.material-image{background-color:#f8fafc;background-position:50%;background-size:cover;height:180px;width:100%}.material-info{padding:20px}.material-header-row{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:8px}.material-card h3{color:#1a3d5c;font-size:18px;font-weight:700;margin:0}.status-badge{font-size:11px;padding:4px 10px}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.material-category{color:#2c5f8d;font-size:13px;font-weight:600;margin:0 0 12px}.material-color,.material-supplier{color:#64748b;font-size:13px;margin:4px 0}.material-pricing{align-items:baseline;border-bottom:1px solid #e2e8f0;border-top:1px solid #e2e8f0;display:flex;gap:6px;margin:16px 0;padding:12px 0}.material-pricing .price{color:#2c5f8d;font-size:24px;font-weight:700}.material-pricing .unit{color:#64748b;font-size:14px}.material-details{color:#64748b;display:flex;flex-direction:column;font-size:13px;gap:6px}.material-actions{background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:8px;padding:16px 20px}.btn-icon{display:flex;flex:1 1;padding:10px;transition:all .2s ease}.btn-icon:hover{background:#f0f7ff;border-color:#2c5f8d;color:#2c5f8d}.btn-icon.danger:hover{background:#fee2e2;border-color:#dc2626;color:#dc2626}.empty-state{font-size:16px;padding:80px 20px}.modal-content{padding:32px}.modal-content h2{color:#1a3d5c;font-size:24px;font-weight:700;margin-bottom:24px}.form-grid{grid-template-columns:1fr 1fr;margin-bottom:24px}.form-group label{color:#1a3d5c}.form-group input,.form-group select,.form-group textarea{color:#1a3d5c;padding:12px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#2c5f8d}.checkbox-group label{align-items:center;cursor:pointer;display:flex;gap:12px}.checkbox-group input[type=checkbox]{cursor:pointer;height:20px;width:20px}.modal-actions{border-top:1px solid #e2e8f0;gap:12px;padding-top:24px}.loading{font-size:18px}@media (max-width:768px){.materials-management{padding:16px}.materials-header{align-items:stretch;flex-direction:column;gap:12px;margin-bottom:24px}.materials-header h1{font-size:24px}.header-actions{flex-direction:column;gap:8px;width:100%}.header-actions .btn,.header-actions label.btn{justify-content:center;padding:12px 16px;width:100%}.materials-filters{flex-direction:column;gap:12px;margin-bottom:24px;width:100%}.search-box{min-width:0}.filter-box,.search-box{padding:10px 12px;width:100%}.filter-box select{font-size:14px;width:100%}.view-toggle{justify-content:center;width:100%}.toggle-btn{flex:1 1;font-size:13px;padding:10px 12px}.materials-stats{font-size:13px;padding:10px 16px;text-align:center}.materials-grid{gap:16px;grid-template-columns:1fr}.category-section{padding:16px}.category-title{flex-wrap:wrap;font-size:1.25rem}.material-card h3{font-size:16px}.material-pricing .price{font-size:20px}.form-grid{grid-template-columns:1fr}.modal-content{margin:10px;padding:20px}.modal-content h2{font-size:20px;margin-bottom:20px}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.location-selector{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;display:flex;gap:10px;padding:8px 16px}.location-label{color:#475569;font-size:14px;font-weight:600;white-space:nowrap}.location-select{background:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;color:#1e293b;cursor:pointer;font-size:14px;font-weight:500;padding:6px 12px;transition:all .2s}.location-select:focus{background:#fff;border-color:#0369a1;outline:none}.location-select:hover{border-color:#94a3b8}.location-price-badge{align-items:center;background:#dcfce7;border-radius:4px;color:#166534;display:inline-flex;font-size:11px;font-weight:600;gap:4px;margin-left:8px;padding:4px 8px}.public-estimate-container{background:#f8fafc;min-height:100vh}.public-header{align-items:center;background:linear-gradient(135deg,#2c5f8d,#1a3d5c);color:#fff;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;padding:40px 20px}.company-logo h1{font-size:48px;font-weight:900;letter-spacing:2px;margin:0}.company-logo p{font-size:14px;margin:5px 0 0;opacity:.9}.company-contact{display:flex;flex-direction:column;gap:8px}.contact-item{font-size:14px;gap:8px}.estimate-content{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001f;margin:-30px auto 40px;max-width:1000px;padding:40px}.estimate-header{border-bottom:2px solid #e2e8f0;margin-bottom:30px;padding-bottom:30px;text-align:center}.estimate-header h2{color:#1a3d5c;font-size:32px;font-weight:700;margin-bottom:10px}.project-name{color:#2c5f8d;font-size:20px;font-weight:600;margin:5px 0}.estimate-date{color:#64748b;font-size:14px;margin:5px 0}.total-cost-banner{background:linear-gradient(135deg,#2c5f8d,#1a3d5c);border-radius:12px;color:#fff;margin-bottom:40px;padding:40px;text-align:center}.total-cost-banner h3{font-size:18px;font-weight:600;margin-bottom:10px;opacity:.9}.total-amount{font-size:56px;font-weight:900;margin:10px 0}.validity{font-size:14px;margin-top:10px;opacity:.8}.cost-breakdown{margin-bottom:40px}.cost-breakdown>h3{color:#1a3d5c;font-size:24px;font-weight:700;margin-bottom:20px}.breakdown-section{background:#f8fafc;border-radius:12px;margin-bottom:30px;padding:20px}.breakdown-section h4{color:#1a3d5c;font-size:18px;font-weight:700;margin-bottom:15px}.materials-table{border-collapse:collapse;margin-bottom:15px;width:100%}.materials-table th{background:#e2e8f0;color:#1a3d5c;font-size:14px}.materials-table td{border-bottom:1px solid #e2e8f0;color:#475569;font-size:14px}.materials-table tbody tr:hover{background:#f1f5f9}.subtotal{align-items:center;background:#fff;border-radius:8px;color:#1a3d5c;display:flex;font-size:16px;font-weight:700;justify-content:space-between;margin-top:10px;padding:15px}.labor-details{display:flex;flex-direction:column;gap:10px;margin-bottom:15px}.detail-row{background:#fff;border-radius:6px;font-size:14px;padding:10px 15px}.adjustments-section{background:#f8fafc;border-radius:12px;margin-top:20px;padding:20px}.adjustment-row{border-bottom:1px solid #e2e8f0;color:#475569;display:flex;font-size:14px;justify-content:space-between;padding:10px 0}.adjustment-row:last-child{border-bottom:none}.actions-section{display:flex;flex-direction:column;gap:30px;margin-bottom:40px}.approval-section{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;padding:30px}.approval-section h3{color:#1a3d5c;font-size:20px;font-weight:700;margin-bottom:15px}.approval-section textarea{border:2px solid #e2e8f0;border-radius:8px;font-family:inherit;font-size:15px;margin-bottom:20px;padding:15px;resize:vertical;width:100%}.approval-buttons{display:flex;flex-wrap:wrap;gap:15px}.btn{font-size:16px;gap:10px;padding:14px 28px;transition:all .2s ease}.btn-primary{background:#2c5f8d}.btn-primary:hover{background:#1a3d5c;box-shadow:0 4px 12px #2c5f8d4d}.btn-danger,.btn-success{flex:1 1}.btn-danger:hover{background:#dc2626}.status-banner{align-items:center;border-radius:12px;display:flex;font-size:18px;font-weight:600;gap:15px;padding:20px 30px}.status-banner.approved{background:#d1fae5;border:2px solid #10b981;color:#065f46}.status-banner.rejected{background:#fee2e2;border:2px solid #ef4444;color:#991b1b}.terms-section{background:#f8fafc;border-radius:12px;margin-bottom:20px;padding:30px}.terms-section h4{color:#1a3d5c;font-size:18px;font-weight:700;margin-bottom:15px}.terms-section ul{list-style:none;margin:0;padding:0}.terms-section li{color:#475569;font-size:14px;line-height:1.6;padding:8px 0 8px 25px;position:relative}.terms-section li:before{color:#2c5f8d;content:"•";font-size:18px;font-weight:700;left:0;position:absolute}.public-footer{background:#1a3d5c;color:#fff;padding:30px 20px;text-align:center}.public-footer p{font-size:14px;margin:5px 0;opacity:.9}.error-state,.loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px;padding:40px;text-align:center}.error-state h2{color:#1a3d5c;font-size:28px;margin-bottom:10px}.error-state p{color:#64748b;font-size:16px}@media (max-width:768px){.public-header{align-items:flex-start;flex-direction:column}.estimate-content{margin:-20px 15px 20px;padding:20px}.total-amount{font-size:40px}.materials-table{font-size:12px}.materials-table td,.materials-table th{padding:8px}.approval-buttons{flex-direction:column}.btn-danger,.btn-success{width:100%}}.settings-container{background:#f8fafc;min-height:100vh;padding:2rem}.settings-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;justify-content:space-between;margin:0 auto 2rem;max-width:1200px;padding:2rem}.settings-header h1{color:#1e293b;font-size:2rem;font-weight:700;margin:0}.settings-content{margin:0 auto;max-width:1200px}.settings-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:2rem;padding:2rem}.section-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;gap:.75rem;margin-bottom:2rem;padding-bottom:1rem}.section-header svg{color:#ff6b35}.section-header h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0}.form-row{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:1.5rem}.form-group{gap:.5rem}.form-group label{font-size:.875rem}.form-group input,.form-group textarea{border:2px solid #e2e8f0;border-radius:8px;color:#1e293b;font-size:1rem;padding:.75rem 1rem;transition:all .2s}.form-group input:focus,.form-group textarea:focus{border-color:#ff6b35;box-shadow:0 0 0 3px #ff6b351a;outline:none}.form-group textarea{min-height:100px}.logo-upload-section{margin-bottom:2rem}.logo-upload-section label{color:#475569;display:block;font-size:.875rem;font-weight:600;letter-spacing:.5px;margin-bottom:1rem;text-transform:uppercase}.logo-preview{align-items:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;display:flex;height:200px;justify-content:center;margin-bottom:1rem;overflow:hidden;width:200px}.logo-preview img{max-height:100%;max-width:100%;object-fit:contain}.upload-progress{background:#eff6ff;border:1px solid #3b82f6;border-radius:8px;margin-top:1rem;padding:1rem}.progress-bar{background:#dbeafe;border-radius:4px;height:8px;margin-bottom:.5rem;overflow:hidden;width:100%}.progress-fill{animation:progress 2s ease-in-out infinite;background:linear-gradient(90deg,#3b82f6,#2563eb);height:100%}@keyframes progress{0%{width:0}30%{width:40%}70%{width:80%}to{width:95%}}.upload-progress p{color:#1e40af;font-size:.875rem;font-weight:500;margin:0;text-align:center}.upload-label.uploading{cursor:not-allowed;opacity:.6}.upload-box{background:#f8fafc;border:2px dashed #cbd5e1;border-radius:12px;cursor:pointer;padding:2rem;text-align:center;transition:all .2s}.upload-box:hover{background:#fff7ed;border-color:#ff6b35}.upload-label{align-items:center;color:#64748b;cursor:pointer;display:flex;flex-direction:column;gap:.75rem}.upload-label svg{color:#ff6b35}.upload-label span{color:#1e293b;font-size:1rem;font-weight:600}.upload-label small{color:#64748b;font-size:.875rem}.color-input-group{align-items:center;display:flex;gap:.75rem}.color-input-group input[type=color]{border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;height:50px;padding:4px;width:60px}.color-input-group input[type=text]{flex:1 1}.btn-primary:hover:not(:disabled){background:#e55a2b;box-shadow:0 4px 12px #ff6b354d;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:#e2e8f0}.btn-secondary:hover{background:#cbd5e1;transform:translateY(-2px)}.preview-section{margin-top:2rem}.preview-card{align-items:center;border-radius:12px;color:#fff;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:300px;padding:2rem;text-align:center}.preview-logo{background:#fff3;border-radius:12px;height:120px;margin-bottom:1rem;object-fit:contain;padding:1rem;width:120px}.preview-card h3{font-size:2rem;font-weight:700;margin:0}.preview-card p{font-size:1rem;margin:.25rem 0}.preview-button{border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:1rem;padding:.75rem 2rem;transition:transform .2s}.preview-button:hover{transform:scale(1.05)}@media (max-width:768px){.settings-container{padding:1rem}.settings-header{align-items:flex-start;flex-direction:column;gap:1.5rem}.header-actions{flex-direction:column;width:100%}.header-actions .btn{justify-content:center;width:100%}.form-row{grid-template-columns:1fr}.settings-header h1{font-size:1.5rem}}.default-settings-section{border-top:2px solid #e2e8f0;margin-top:2rem;padding-top:2rem}.default-settings-section h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin-bottom:1rem}.percentage-inputs{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.percentage-input{display:flex;flex-direction:column;gap:.5rem}.percentage-input label{color:#475569;font-size:.875rem;font-weight:500}.percentage-input input{border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:.75rem}textarea[data-testid=terms-textarea]::placeholder{color:#94a3b8}textarea[data-testid=terms-textarea]:focus{border-color:#3b82f6;outline:none}.sub-section{border:1px solid #334155!important}.sub-current-plan{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.sub-plan-badge-wrap{align-items:center;display:flex;gap:10px}.sub-plan-badge{border-radius:8px;font-size:16px;font-weight:700;padding:6px 16px}.sub-plan-badge.tier-free{background:#64748b26;border:1px solid #475569;color:#94a3b8}.sub-plan-badge.tier-pro{background:#3b82f626;border:1px solid #3b82f6;color:#60a5fa}.sub-plan-badge.tier-enterprise{background:#f59e0b26;border:1px solid #f59e0b;color:#fbbf24}.sub-since{color:#64748b;font-size:12px}.sub-usage-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(3,1fr);margin-bottom:24px}.sub-meter{background:#0f172a;border:1px solid #334155;border-radius:10px;padding:14px 16px}.sub-meter.over-limit{background:#ef44440d;border-color:#ef4444}.sub-meter-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.sub-meter-label{color:#94a3b8;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.sub-meter-value{color:#e2e8f0;font-size:14px;font-weight:700}.unlimited-icon{color:#10b981;font-size:12px}.sub-meter-bar{background:#1e293b;border-radius:3px;height:6px;overflow:hidden}.sub-meter-fill{background:#3b82f6;border-radius:3px;height:100%;transition:width .5s ease}.over-limit .sub-meter-fill{background:#ef4444}.sub-tiers{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.sub-tier-card{background:#0f172a;border:1px solid #334155;border-radius:12px;padding:20px;position:relative;text-align:center;transition:all .2s}.sub-tier-card:hover{border-color:#475569}.sub-tier-card.current{border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f64d}.sub-tier-card.recommended{border-color:#3b82f6}.sub-recommended-tag{background:#3b82f6;border-radius:4px;color:#fff;font-size:10px;font-weight:700;left:50%;letter-spacing:.5px;padding:3px 12px;position:absolute;text-transform:uppercase;top:-10px;transform:translateX(-50%)}.sub-tier-card h4{color:#f1f5f9;font-size:18px;font-weight:700;margin:0 0 4px}.sub-tier-price{color:#e2e8f0;font-size:28px;font-weight:800;margin-bottom:16px}.sub-tier-features{list-style:none;margin:0 0 20px;padding:0;text-align:left}.sub-tier-features li{align-items:center;color:#94a3b8;display:flex;font-size:13px;gap:8px;padding:5px 0}.sub-tier-features li svg{color:#10b981;flex-shrink:0}.sub-tier-btn{padding:10px 16px!important;width:100%}@media (max-width:768px){.sub-tiers,.sub-usage-grid{grid-template-columns:1fr}}.role-current{margin-bottom:20px}.role-label{color:#94a3b8;display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.role-selector{display:flex;gap:10px}.role-btn{align-items:center;background:#0f172a;border:1px solid #334155;border-radius:8px;color:#94a3b8;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .15s}.role-btn:hover{border-color:#475569;color:#e2e8f0}.role-btn.active{background:#3b82f61f;border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f64d;color:#60a5fa}.role-perms-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr)}.role-perm-group{background:#0f172a;border:1px solid #334155;border-radius:10px;padding:14px}.role-perm-group h4{color:#e2e8f0;font-size:13px;font-weight:700;letter-spacing:.5px;margin:0 0 10px;text-transform:uppercase}.role-perm-list{display:flex;flex-direction:column;gap:6px}.role-perm-item{align-items:center;display:flex;font-size:12px;gap:6px;padding:4px 0;text-transform:capitalize}.role-perm-item.granted,.role-perm-item.granted svg{color:#10b981}.role-perm-item.denied{color:#475569;text-decoration:line-through}.role-perm-item.denied svg{color:#334155}@media (max-width:768px){.role-perms-grid{grid-template-columns:repeat(2,1fr)}.role-selector{flex-direction:column}}.clients-page{background:#0f172a!important;color:#e2e8f0!important;margin:0 auto;max-width:1400px;min-height:100vh;padding:2rem}.clients-page .stats-dashboard{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:2rem}.clients-page .stat-card{align-items:center;background:#1e293b!important;border:1px solid #334155;border-radius:10px;color:#e2e8f0;display:flex;gap:1rem;padding:1.25rem}.clients-page .stat-icon{align-items:center;border-radius:10px;display:flex;height:48px;justify-content:center;width:48px}.clients-page .stat-info h3{color:#f1f5f9;font-size:1.75rem;font-weight:700;margin:0}.clients-page .stat-info p{color:#94a3b8;font-size:.8rem;margin:.2rem 0 0}.clients-page .clients-header{align-items:center;background:#1e293b;border:1px solid #334155;border-radius:10px;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:1.25rem 1.5rem}.clients-page .clients-header h2{color:#f1f5f9;font-size:1.5rem;font-weight:700;margin:0}.clients-page .btn-add-client{align-items:center;background:#c8a951;border:none;border-radius:8px;color:#0f172a;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.65rem 1.5rem;transition:all .2s}.clients-page .btn-add-client:hover{background:#d4b95e;transform:translateY(-1px)}.clients-page .clients-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.clients-page .search-box{flex:1 1;min-width:250px;position:relative}.clients-page .search-box svg{color:#64748b;left:14px;position:absolute;top:50%;transform:translateY(-50%)}.clients-page .search-box input{background:#0f172a!important;border:1px solid #334155;border-radius:8px;color:#e2e8f0!important;font-size:.9rem;outline:none;padding:.65rem .65rem .65rem 2.5rem;width:100%}.clients-page .search-box input:focus{border-color:#3b82f6}.clients-page .search-box input::placeholder{color:#64748b}.clients-page .filter-select{align-items:center;background:#0f172a;border:1px solid #334155;border-radius:8px;color:#e2e8f0;display:flex;font-size:.9rem;gap:.5rem;padding:.65rem 1rem}.clients-page .filter-select select{background:#0000;border:none;color:#e2e8f0;font-size:.9rem;outline:none}.clients-page .client-count{background:#1e293b;border:1px solid #334155;border-radius:8px;color:#94a3b8;font-size:.85rem;padding:.5rem 1rem}.clients-page .clients-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.clients-page .client-card{background:#1e293b;border:1px solid #334155;border-radius:10px;cursor:pointer;padding:1.25rem;transition:all .2s}.clients-page .client-card:hover{border-color:#475569;box-shadow:0 4px 12px #0000004d;transform:translateY(-2px)}.clients-page .client-header{align-items:center;display:flex;gap:.75rem;margin-bottom:.75rem}.clients-page .client-avatar{align-items:center;background:#c8a95126;border-radius:10px;color:#c8a951;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:40px;justify-content:center;width:40px}.clients-page .client-info h3{color:#f1f5f9;font-size:1rem;font-weight:600;margin:0}.clients-page .client-details{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.75rem}.clients-page .detail-row{align-items:center;background:#0000;border-bottom:none;color:#94a3b8;display:flex;font-size:.85rem;gap:.5rem;padding:0}.clients-page .detail-row span{color:#94a3b8}.clients-page .detail-row svg{color:#64748b;flex-shrink:0}.clients-page .client-actions{border-top:1px solid #334155;display:flex;gap:.5rem;padding-top:.75rem}.clients-page .btn-icon{align-items:center;background:#0000;border:1px solid #334155;border-radius:8px;color:#94a3b8;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .15s;width:36px}.clients-page .btn-icon:hover{border-color:#3b82f6;color:#60a5fa}.clients-page .btn-icon.danger:hover{border-color:#ef4444;color:#f87171}.clients-page .empty-state{background:#1e293b!important;border:1px solid #334155;border-radius:10px;color:#e2e8f0;padding:3rem 2rem;text-align:center}.clients-page .empty-state svg{color:#475569}.clients-page .empty-state h3{color:#e2e8f0}.clients-page .empty-state p{color:#64748b}.clients-page .modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3}.clients-page .modal-content{background:#1e293b!important;border:1px solid #334155;color:#e2e8f0}.clients-page .modal-content h2,.clients-page .modal-content h3{color:#f1f5f9}.clients-page .form-group label{color:#94a3b8}.clients-page .form-group input,.clients-page .form-group select,.clients-page .form-group textarea{background:#0f172a!important;border:1px solid #334155;color:#e2e8f0!important}.clients-page .form-group input:focus,.clients-page .form-group select:focus,.clients-page .form-group textarea:focus{border-color:#3b82f6}@media (max-width:768px){.clients-page{padding:1rem}.stats-dashboard{grid-template-columns:repeat(2,1fr)}.clients-grid{grid-template-columns:1fr}.clients-toolbar{flex-direction:column}}.breadcrumb{flex-wrap:wrap;font-size:14px;gap:8px;padding:16px 0}.breadcrumb,.breadcrumb-item{align-items:center;display:flex}.breadcrumb-item{color:#64748b;font-weight:500;gap:6px;text-decoration:none;transition:color .2s}.breadcrumb-item:hover{color:#2c5f8d}.breadcrumb-item.active{color:#1e293b;font-weight:600}.breadcrumb-separator{color:#cbd5e1}@media (max-width:768px){.breadcrumb{font-size:13px;padding:12px 0}.breadcrumb-item svg{height:14px;width:14px}.breadcrumb-separator{height:12px;width:12px}}.client-detail-page{background:#0f172a;color:#e2e8f0;margin:0 auto;max-width:1400px;min-height:100vh;padding:2rem}.btn-back{background:#1e293b;border:1px solid #334155;color:#94a3b8;font-size:.9rem;padding:.65rem 1.25rem;transition:all .15s}.btn-back:hover{border-color:#475569;color:#e2e8f0}.detail-actions{display:flex;gap:.75rem}.btn-delete,.btn-edit{align-items:center;border:1px solid #0000;border-radius:8px;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:.5rem;padding:.65rem 1.25rem;transition:all .15s}.btn-edit{background:#1e40af;border-color:#3b82f6;color:#93c5fd}.btn-edit:hover{background:#1d4ed8;color:#fff}.btn-delete{background:#0000;border-color:#ef4444;color:#f87171}.btn-delete:hover{background:#ef444426}.detail-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr}.detail-card{background:#1e293b;border:1px solid #334155;border-radius:10px;padding:1.5rem}.detail-card h3{align-items:center;color:#f1f5f9;display:flex;font-size:1rem;font-weight:700;gap:.5rem;margin:0 0 1rem}.detail-card h3 svg{color:#c8a951}.info-row{align-items:center;border-bottom:1px solid #33415580;display:flex;justify-content:space-between;padding:.6rem 0}.info-row:last-child{border-bottom:none}.info-label{color:#64748b;font-size:.85rem}.info-value{color:#e2e8f0;font-size:.9rem;font-weight:600}.detail-status-badge{align-items:center;border-radius:6px;display:inline-flex;font-size:.75rem;font-weight:600;gap:.4rem;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.projects-list{display:flex;flex-direction:column;gap:.75rem}.project-item{align-items:center;background:#0f172a;border:1px solid #334155;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;padding:.75rem 1rem;transition:all .15s}.project-item:hover{border-color:#3b82f6}.project-item-name{color:#e2e8f0;font-size:.9rem;font-weight:600}.project-item-date{color:#64748b;font-size:.8rem}.comm-timeline{display:flex;flex-direction:column;gap:1rem}.comm-item{background:#0f172a;border:1px solid #334155;border-radius:8px;padding:.75rem 1rem}.comm-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.4rem}.comm-type{color:#60a5fa;font-size:.75rem;font-weight:600;text-transform:uppercase}.comm-date{color:#64748b;font-size:.75rem}.comm-notes{color:#94a3b8;font-size:.85rem;line-height:1.4}.add-comm-form textarea{min-height:60px;resize:vertical}.btn-add-comm{font-size:.85rem;transition:all .15s}.btn-add-comm:hover{background:#d4b95e}.detail-card.full-width{grid-column:1/-1}.loading-spinner{align-items:center;color:#64748b;display:flex;font-size:1rem;justify-content:center;min-height:300px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3}.modal-content{background:#1e293b;border:1px solid #334155;border-radius:12px}.modal-content h3{color:#f1f5f9;font-size:1.25rem;font-weight:700;margin:0 0 1.5rem}.form-group{margin-bottom:1rem}.form-group label{font-size:.8rem;letter-spacing:.5px;margin-bottom:.4rem}.form-group input,.form-group select,.form-group textarea{font-size:.9rem;outline:none;padding:.6rem .8rem}.client-detail-header{align-items:center;background:#1e293b;border:1px solid #334155;border-radius:10px;display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:1.5rem;padding:1.5rem}.client-avatar-large{align-items:center;background:#c8a95126;border-radius:12px;color:#c8a951;display:flex;flex-shrink:0;font-size:28px;font-weight:700;height:64px;justify-content:center;width:64px}.client-main-info h1{color:#f1f5f9;font-size:1.5rem;font-weight:700;margin:0 0 .4rem}.status-dropdown select{background:#0f172a;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:600;outline:none;padding:4px 12px}.client-contact-info{display:flex;flex-wrap:wrap;gap:1rem;margin-left:auto}.contact-item{align-items:center;color:#94a3b8;display:flex;font-size:.85rem;gap:.4rem}.contact-item a{color:#60a5fa;text-decoration:none}.contact-item a:hover{text-decoration:underline}.client-stats-overview{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem}.stat-box{background:#1e293b;border:1px solid #334155;gap:1rem;padding:1rem}.stat-box,.stat-box .stat-icon{align-items:center;border-radius:10px;display:flex}.stat-box .stat-icon{height:48px;justify-content:center;width:48px}.stat-content h3{color:#f1f5f9;font-size:1.5rem;font-weight:700;margin:0}.stat-content p{color:#94a3b8;font-size:.8rem;margin:0}.client-detail-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr}.detail-section{background:#1e293b;border:1px solid #334155;border-radius:10px;padding:1.5rem}.detail-section h2{align-items:center;color:#f1f5f9;display:flex;font-size:1rem;font-weight:700;gap:.5rem;margin:0 0 1rem}.detail-section h2 svg{color:#c8a951}.detail-section.full-width{grid-column:1/-1}.project-list-item{align-items:center;background:#0f172a;border:1px solid #334155;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:.75rem 1rem;transition:all .15s}.project-list-item:hover{border-color:#3b82f6}.project-list-item h4{color:#e2e8f0;font-size:.9rem;margin:0}.project-list-item span{color:#64748b;font-size:.8rem}.status-badge{border-radius:6px;font-size:.7rem;padding:3px 10px}.comm-log-item{background:#0f172a;border:1px solid #334155;border-radius:8px;margin-bottom:.5rem;padding:.75rem 1rem}.comm-log-item .comm-type{color:#60a5fa;font-size:.75rem;font-weight:600;text-transform:uppercase}.comm-log-item .comm-date{color:#64748b;font-size:.75rem}.comm-log-item .comm-notes{color:#94a3b8;font-size:.85rem;margin-top:.3rem}.add-comm-form{border-top:1px solid #334155;display:flex;flex-direction:column;gap:.75rem;margin-top:1rem;padding-top:1rem}.add-comm-form select,.add-comm-form textarea{background:#0f172a;border:1px solid #334155;border-radius:8px;color:#e2e8f0;font-size:.85rem;outline:none;padding:.6rem .8rem}.add-comm-form select:focus,.add-comm-form textarea:focus{border-color:#3b82f6}.btn-add-comm{align-self:flex-end;background:#c8a951;border:none;color:#0f172a;padding:.5rem 1rem}.btn-action,.btn-add-comm{border-radius:8px;cursor:pointer;font-weight:600}.btn-action{align-items:center;background:#1e293b;border:1px solid #334155;color:#94a3b8;display:flex;font-size:.85rem;gap:.5rem;padding:.65rem 1.25rem;transition:all .15s}.btn-action:hover{border-color:#475569;color:#e2e8f0}.btn-action.primary{background:#1e40af;border-color:#3b82f6;color:#93c5fd}.btn-action.danger{border-color:#ef4444;color:#f87171}.btn-action.danger:hover{background:#ef444426}@media (max-width:768px){.client-stats-overview{grid-template-columns:repeat(2,1fr)}.client-detail-grid{grid-template-columns:1fr}}.modal-actions{gap:.75rem;margin-top:1.5rem}.btn-cancel{background:#0000;border:1px solid #475569;border-radius:8px;color:#94a3b8}.btn-cancel,.btn-save{cursor:pointer;font-weight:600;padding:.6rem 1.25rem}.btn-save{background:#c8a951;border:none;border-radius:8px;color:#0f172a}.empty-state{color:#64748b;padding:2rem}@media (max-width:768px){.client-detail-page{padding:1rem}.detail-grid{grid-template-columns:1fr}}.client-detail-page .detail-tabs{border-bottom:1px solid #334155;display:flex;gap:0;margin-bottom:1.5rem}.client-detail-page .detail-tabs button{align-items:center;background:#0000;border:none;border-bottom:2px solid #0000;color:#94a3b8;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.75rem 1.25rem;transition:all .15s}.client-detail-page .detail-tabs button:hover{color:#e2e8f0}.client-detail-page .detail-tabs button.active{border-bottom-color:#c8a951;color:#c8a951}.client-detail-page .tab-content{min-height:300px}.client-detail-page .overview-tab{display:flex;flex-direction:column;gap:1.5rem}.client-detail-page .overview-section{background:#1e293b;border:1px solid #334155;border-radius:10px;padding:1.5rem}.client-detail-page .overview-section h3{color:#f1f5f9;font-size:1rem;font-weight:700;margin:0 0 1rem}.client-detail-page .overview-section p{color:#94a3b8;font-size:.9rem;line-height:1.5}.client-detail-page .empty-text{color:#64748b;font-style:italic}.client-detail-page .project-item{align-items:center;background:#0f172a;border:1px solid #334155;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;margin-bottom:.5rem;padding:.75rem 1rem;transition:all .15s}.client-detail-page .project-item:hover{border-color:#3b82f6}.client-detail-page .project-item svg{color:#64748b;flex-shrink:0}.client-detail-page .project-info h4{color:#e2e8f0;font-size:.9rem;font-weight:600;margin:0}.client-detail-page .project-date{color:#64748b;font-size:.75rem}.client-detail-page .project-value{color:#10b981;font-size:.9rem;font-weight:700;margin-left:auto}.client-detail-page .comm-item{background:#0f172a;border:1px solid #334155;border-radius:8px;display:flex;gap:.75rem;margin-bottom:.5rem;padding:.75rem 1rem}.client-detail-page .comm-item svg{color:#64748b;flex-shrink:0;margin-top:2px}.client-detail-page .comm-content{flex:1 1}.client-detail-page .comm-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.3rem}.client-detail-page .comm-header strong{color:#e2e8f0;font-size:.85rem}.client-detail-page .comm-content .comm-date{color:#64748b;font-size:.75rem}.client-detail-page .comm-content p{color:#94a3b8;font-size:.85rem;margin:0}.client-detail-page .comm-author{color:#64748b;display:block;font-size:.75rem;margin-top:.3rem}.client-detail-page .tab-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.client-detail-page .tab-header h2{color:#f1f5f9;font-size:1.25rem;font-weight:700;margin:0}.client-detail-page .projects-list{display:flex;flex-direction:column;gap:.75rem}.client-detail-page .project-card{background:#1e293b;border:1px solid #334155;border-radius:10px;cursor:pointer;padding:1.25rem;transition:all .15s}.client-detail-page .project-card:hover{border-color:#475569;transform:translateY(-1px)}.client-detail-page .project-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.client-detail-page .project-header h3{color:#e2e8f0;font-size:1rem;font-weight:600;margin:0}.client-detail-page .project-amount{color:#10b981;font-size:1rem;font-weight:700}.client-detail-page .project-meta{align-items:center;color:#64748b;display:flex;font-size:.8rem;gap:1rem}.client-detail-page .project-meta span{align-items:center;display:flex;gap:.3rem}.client-detail-page .communications-timeline{display:flex;flex-direction:column;gap:1rem}.client-detail-page .timeline-item{display:flex;gap:1rem;position:relative}.client-detail-page .timeline-icon{align-items:center;background:#60a5fa1f;border-radius:10px;color:#60a5fa;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.client-detail-page .timeline-content{background:#1e293b;border:1px solid #334155;border-radius:10px;flex:1 1;padding:1rem 1.25rem}.client-detail-page .timeline-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.client-detail-page .timeline-header h4{color:#e2e8f0;font-size:.9rem;font-weight:600;margin:0}.client-detail-page .timeline-date{color:#64748b;font-size:.75rem}.client-detail-page .timeline-content p{color:#94a3b8;font-size:.85rem;line-height:1.5;margin:0}.client-detail-page .timeline-author{color:#64748b;display:block;font-size:.75rem;margin-top:.5rem}.client-detail-page .client-info-card{align-items:center;background:#1e293b;border:1px solid #334155;border-radius:10px;display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:1.5rem;padding:1.5rem}.client-detail-page .header-actions{display:flex;gap:.75rem}.client-detail-page .btn{align-items:center;border:1px solid #0000;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:600;gap:.5rem;padding:.6rem 1.25rem;transition:all .15s}.client-detail-page .btn-primary{background:#c8a951;border-color:#c8a951;color:#0f172a}.client-detail-page .btn-primary:hover{background:#d4b95e}.client-detail-page .btn-secondary{background:#1e293b;border-color:#334155;color:#94a3b8}.client-detail-page .btn-secondary:hover{border-color:#475569;color:#e2e8f0}.client-detail-page .btn-danger{background:#0000;border-color:#ef4444;color:#f87171}.client-detail-page .btn-danger:hover{background:#ef444426}.client-detail-page .empty-state{background:#1e293b;border:1px solid #334155;border-radius:10px;color:#e2e8f0;padding:3rem 2rem;text-align:center}.client-detail-page .empty-state svg{color:#475569;margin-bottom:1rem}.client-detail-page .empty-state h3{color:#e2e8f0;margin:0 0 .5rem}.client-detail-page .empty-state p{color:#64748b;margin:0 0 1rem}.client-detail-page .modal-content h2{color:#f1f5f9;font-size:1.25rem;font-weight:700;margin:0 0 1.5rem}.project-detail-page{margin:0 auto;max-width:1400px;padding:2rem}.detail-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.btn-back{border:1px solid #e5e7eb;color:#374151;font-size:.95rem}.btn-back:hover{background:#f9fafb;border-color:#d1d5db}.header-actions{display:flex;gap:1rem}.project-info-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem;padding:2rem}.project-main-info{margin-bottom:1.5rem}.project-main-info h1{color:#1e293b;font-size:2rem;margin:0 0 1rem}.status-selector{align-items:center;display:flex;gap:.75rem}.status-selector label{color:#64748b;font-weight:600}.status-selector select{border-radius:20px;cursor:pointer;font-size:.9rem;font-weight:600;padding:.5rem 1rem;transition:all .2s}.status-selector select:hover{opacity:.9}.project-meta-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.meta-item{align-items:center;background:#f8fafc;border-radius:8px;display:flex;gap:1rem;padding:1rem}.meta-item svg{color:#3b82f6}.meta-label{color:#64748b;display:block;font-size:.85rem}.meta-value{color:#1e293b;display:block;font-weight:600;margin-top:.25rem}.meta-value.clickable{color:#3b82f6;cursor:pointer}.meta-value.clickable:hover{text-decoration:underline}.project-stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{box-shadow:0 1px 3px #0000001a}.stat-card h3{color:#1e293b;font-size:1.75rem;margin:0}.stat-card p{color:#64748b;font-size:.9rem;margin:.25rem 0 0}.detail-tabs{border-bottom:2px solid #e5e7eb;display:flex;gap:.5rem;margin-bottom:2rem}.detail-tabs button{align-items:center;background:#0000;border:none;border-bottom:3px solid #0000;color:#64748b;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.5rem;margin-bottom:-2px;padding:1rem 1.5rem;transition:all .2s}.detail-tabs button:hover{background:#f9fafb;color:#1e293b}.detail-tabs button.active{border-bottom-color:#3b82f6;color:#3b82f6}.tab-content{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;min-height:400px;padding:2rem}.tab-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.tab-header h2{color:#1e293b;margin:0}.overview-tab{display:flex;flex-direction:column;gap:2rem}.overview-section h3{color:#1e293b;margin-bottom:1rem}.estimation-summary{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.est-item{align-items:center;background:#f8fafc;border-radius:8px;display:flex;justify-content:space-between;padding:1rem}.est-item.total{background:#dbeafe;border:2px solid #3b82f6}.est-item span{color:#64748b}.est-item strong{color:#1e293b;font-size:1.125rem}.photo-grid-small{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.photo-thumb{aspect-ratio:1;border-radius:8px;overflow:hidden;position:relative}.photo-thumb img{height:100%;object-fit:cover;width:100%}.photo-type{background:#000c;border-radius:12px;bottom:.5rem;color:#fff;font-size:.75rem;left:.5rem;padding:.25rem .75rem;position:absolute;text-transform:capitalize}.notes-list-small{display:flex;flex-direction:column;gap:1rem}.note-preview{background:#f8fafc;border-left:4px solid #3b82f6;border-radius:8px;padding:1rem}.note-preview p{color:#475569;margin:0 0 .5rem}.note-meta{color:#94a3b8;font-size:.85rem}.photos-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.photo-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:all .2s}.photo-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f626;transform:translateY(-2px)}.photo-card img{height:250px;object-fit:cover;width:100%}.photo-info{padding:1rem}.photo-badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;margin-bottom:.75rem;padding:.25rem .75rem;text-transform:capitalize}.photo-badge.before{background:#fef3c7;color:#92400e}.photo-badge.during{background:#dbeafe;color:#1e40af}.photo-badge.after{background:#d1fae5;color:#065f46}.photo-badge.inspection{background:#ede9fe;color:#5b21b6}.photo-badge.other{background:#f3f4f6;color:#374151}.photo-info h4{color:#1e293b;margin:0 0 .5rem}.photo-info p{color:#64748b;font-size:.9rem;margin:.5rem 0}.photo-uploaded{color:#94a3b8;display:block;font-size:.85rem;margin-top:.75rem}.notes-timeline{padding-left:2rem;position:relative}.notes-timeline:before{background:#e5e7eb;bottom:0;content:"";left:12px;position:absolute;top:0;width:2px}.note-item{gap:1rem;padding-bottom:2rem}.note-icon,.note-item{display:flex;position:relative}.note-icon{align-items:center;background:#fff;border:3px solid #3b82f6;border-radius:50%;color:#3b82f6;flex-shrink:0;height:40px;justify-content:center;margin-left:-28px;width:40px;z-index:1}.note-content{background:#f8fafc;border-radius:12px;flex:1 1;padding:1.5rem}.note-content p{color:#475569;line-height:1.6;margin:0 0 .75rem}.empty-state svg{opacity:.5}.empty-state h3{color:#64748b;margin-bottom:.5rem}.empty-state p{margin-bottom:2rem}.empty-text{color:#94a3b8;font-style:italic;padding:2rem;text-align:center}.modal-overlay{background:#00000080}.modal-content{max-width:600px}.form-group label{font-weight:500}.form-group input,.form-group select,.form-group textarea{border:1px solid #d1d5db}.btn{font-weight:500}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#3b82f6}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}@media (max-width:768px){.project-detail-page{padding:1rem}.estimation-summary,.photos-grid,.project-meta-grid,.project-stats-grid{grid-template-columns:1fr}.detail-tabs{overflow-x:auto}}.invoices-page{background:#f8fafc;margin:0 auto;max-width:1600px;min-height:100vh;padding:2rem}.stats-dashboard{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{background:#fff;box-shadow:0 2px 8px #00000014;gap:1rem;padding:1.5rem}.stat-card,.stat-icon{align-items:center;display:flex}.stat-icon{border-radius:12px;height:56px;justify-content:center;width:56px}.stat-info h3{color:#1e293b;font-size:2rem;font-weight:700;margin:0}.stat-info p{color:#64748b;font-size:.875rem;margin:.25rem 0 0}.invoices-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem}.invoices-header h1{color:#1e293b;font-size:2rem;font-weight:700;margin:0}.invoices-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.search-box{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px #0000000a;display:flex;flex:1 1;gap:.75rem;min-width:300px;padding:.75rem 1rem}.search-box svg{color:#64748b}.search-box input{border:none;color:#1e293b;flex:1 1;font-size:1rem;outline:none}.filter-box{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px #0000000a;display:flex;gap:.75rem;padding:.75rem 1rem}.filter-box svg{color:#64748b}.filter-box select{background:#0000;border:none;color:#1e293b;cursor:pointer;font-size:1rem;outline:none}.results-count{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#64748b;display:flex;font-weight:600;padding:.75rem 1.5rem}.invoices-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.invoices-table{border-collapse:collapse;width:100%}.invoices-table thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.invoices-table th{color:#475569;font-size:.875rem;font-weight:700;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase}.invoices-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background .2s}.invoices-table tbody tr:hover{background:#f8fafc}.invoices-table tbody tr.overdue-row{background:#fef2f2}.invoices-table td{color:#1e293b;font-size:.875rem;padding:1rem}.invoice-number{color:#ff6b35;font-weight:700}.client-name{font-weight:600}.amount,.balance-amount,.paid-amount{font-weight:600;text-align:right}.overdue-date{color:#dc2626;font-weight:600}.overdue-badge{background:#dc2626;border-radius:4px;color:#fff;display:inline-block;font-size:.625rem;font-weight:700;margin-left:.5rem;padding:.125rem .5rem}.status-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:.75rem;font-weight:600;gap:.375rem;letter-spacing:.5px;padding:.375rem .75rem;text-transform:uppercase}.actions{text-align:center}.btn-icon{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;display:inline-flex;justify-content:center;padding:.5rem}.btn-icon:hover{background:#f8fafc;border-color:#cbd5e1;color:#ff6b35}.empty-state{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:4rem 2rem}.empty-state svg{margin-bottom:1rem}.empty-state h3{color:#1e293b;font-size:1.5rem;font-weight:700;margin:1rem 0 .5rem}.empty-state p{color:#64748b;margin-bottom:1.5rem}.btn{display:inline-flex}@media (max-width:1200px){.invoices-table-container{overflow-x:auto}.invoices-table{min-width:1000px}}@media (max-width:768px){.invoices-page{padding:1rem}.invoices-header{align-items:stretch;flex-direction:column;gap:1rem}.invoices-header h1{font-size:24px}.invoices-header .btn{justify-content:center;width:100%}.stats-dashboard{gap:1rem;grid-template-columns:1fr}.stat-card{padding:1rem}.stat-info h3{font-size:1.5rem}.invoices-table{display:none}.invoices-list{display:flex;flex-direction:column;gap:1rem}.invoice-mobile-card{background:#fff;border-left:4px solid #3b82f6;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:1rem}.invoice-mobile-header{align-items:start;display:flex;justify-content:space-between;margin-bottom:.75rem}.invoice-mobile-number{color:#1e293b;font-size:1.1rem;font-weight:700}.invoice-mobile-amount{color:#10b981;font-size:1.1rem;font-weight:700}.invoice-mobile-details{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.invoice-mobile-row{display:flex;font-size:.9rem;justify-content:space-between}.invoice-mobile-label{color:#64748b}.invoice-mobile-value{color:#1e293b;font-weight:500}}.invoice-detail-page{background:#f8fafc;margin:0 auto;max-width:1200px;min-height:100vh;padding:2rem}.invoice-header{justify-content:space-between;margin-bottom:2rem}.btn-back,.invoice-header{align-items:center;display:flex}.btn-back{background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.btn-back:hover{background:#f8fafc;border-color:#cbd5e1;color:#1e293b}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.btn-primary{background:#ff6b35}.btn-primary:hover{background:#e55a2b;box-shadow:0 4px 12px #ff6b354d}.invoice-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:3rem}.invoice-title-section{align-items:flex-start;border-bottom:3px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:3rem;padding-bottom:2rem}.invoice-title-section h1{color:#1e293b;font-size:2.5rem;font-weight:700;margin:0}.invoice-number{color:#64748b;font-size:1.125rem;margin:.5rem 0 0}.status-badge-large{border-radius:8px;font-size:1rem;font-weight:700;letter-spacing:1px;padding:.75rem 1.5rem;text-transform:uppercase}.invoice-info-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:3rem}.info-card{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem}.info-card h3{align-items:center;color:#475569;display:flex;gap:.5rem;letter-spacing:.5px;margin:0 0 1rem;text-transform:uppercase}.client-name,.info-card h3{font-size:1.125rem;font-weight:700}.client-name{color:#1e293b;margin-bottom:.5rem}.info-card p{color:#64748b;margin:.25rem 0}.detail-row{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:.5rem 0}.detail-row:last-child{border-bottom:none}.detail-row span{color:#64748b}.detail-row strong{color:#1e293b}.invoice-items{margin-bottom:3rem}.invoice-items h3{color:#1e293b;font-size:1.25rem;font-weight:700;margin:0 0 1rem}.items-table{border-collapse:collapse;margin-top:1rem;width:100%}.items-table thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.items-table th{color:#475569;font-size:.875rem;font-weight:700;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase}.items-table tbody tr{border-bottom:1px solid #f1f5f9}.items-table td{color:#1e293b;padding:1rem}.text-center{text-align:center}.text-right{text-align:right}.invoice-totals{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;margin-left:auto;max-width:400px;padding:1.5rem}.totals-row{border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:.75rem 0}.totals-row:last-child{border-bottom:none}.totals-row span{color:#64748b}.totals-row strong{color:#1e293b;font-size:1.125rem}.totals-row.total{border-top:2px solid #cbd5e1;margin-top:.5rem;padding-top:1rem}.totals-row.total span,.totals-row.total strong{color:#1e293b;font-size:1.25rem;font-weight:700}.totals-row.paid strong{color:#10b981}.totals-row.balance{border-top:2px solid #cbd5e1;margin-top:.5rem;padding-top:1rem}.totals-row.balance strong{color:#ef4444;font-size:1.25rem}.invoice-notes,.invoice-terms{background:#fef3c7;border:2px solid #fde68a;border-radius:12px;margin-top:2rem;padding:1.5rem}.invoice-notes h3,.invoice-terms h3{color:#92400e;font-size:1rem;font-weight:700;letter-spacing:.5px;margin:0 0 .75rem;text-transform:uppercase}.invoice-notes p,.invoice-terms p{color:#78350f;line-height:1.6;margin:0}.loading{align-items:center;color:#64748b;display:flex;font-size:1.25rem;justify-content:center;min-height:400px}@media (max-width:768px){.invoice-detail-page{padding:1rem}.invoice-container{margin:0;padding:1rem}.invoice-header{flex-direction:column;gap:.75rem}.invoice-header .btn,.invoice-header .btn-back{font-size:14px;justify-content:center;padding:.625rem 1rem;width:100%}.invoice-title-section{flex-direction:column;gap:.75rem}.invoice-title-section h1{font-size:20px}.invoice-parties{flex-direction:column;gap:1rem}.invoice-dates{gap:1rem}.items-table{display:block;font-size:.8rem;min-width:500px;overflow-x:auto}.items-table td,.items-table th{padding:.5rem .25rem;white-space:nowrap}.invoice-summary{font-size:.9rem}.summary-row{padding:.5rem 0}.payment-actions-section{flex-direction:column;padding:1rem}.payment-actions-section .btn{width:100%}}.payment-actions-section{background:#f0f9ff;border:2px solid #0ea5e9;border-radius:12px;display:flex;gap:1rem;margin-top:2rem;padding:1.5rem}.btn-success{background:#10b981}.btn-success:hover{background:#059669}.payment-history-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-top:2rem;padding:1.5rem}.payment-history-section h3{color:#1e293b;font-size:1.25rem;margin:0 0 1rem}.payments-list{display:flex;flex-direction:column;gap:1rem}.payment-record{background:#f8fafc;border-left:4px solid #10b981;border-radius:8px;padding:1rem}.payment-info{align-items:center;display:flex;gap:1rem;margin-bottom:.5rem}.payment-info strong{color:#1e293b;font-size:1.125rem}.payment-method{background:#dbeafe;border-radius:12px;color:#1e40af;display:inline-block;font-size:.875rem;margin-left:1rem;padding:.25rem .75rem;text-transform:capitalize}.payment-meta{align-items:center;color:#64748b;display:flex;font-size:.875rem;gap:1rem;margin-bottom:.5rem}.payment-ref{background:#f1f5f9;border-radius:4px;font-family:monospace;padding:.25rem .5rem}.payment-notes{background:#fff;border-radius:6px;color:#475569;font-size:.9rem;font-style:italic;margin:.5rem 0 0;padding:.75rem}.modal-content{max-width:500px;padding:2rem;width:90%}.modal-content h2{color:#1e293b;font-size:1.5rem;margin:0 0 1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{border:2px solid #e5e7eb;font-size:1rem;padding:.75rem;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{box-shadow:0 0 0 3px #3b82f61a}.form-group small{color:#64748b;margin-top:.5rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}@media (max-width:768px){.invoice-detail-page{padding:1rem}.invoice-header{align-items:stretch;flex-direction:column;gap:1rem}.header-actions{display:flex;flex-direction:column;gap:.75rem}.invoice-title-section{align-items:flex-start;flex-direction:column;gap:1rem}.invoice-info-grid{grid-template-columns:1fr}.items-table{font-size:.85rem}.items-table td,.items-table th{padding:8px}.modal-content{max-width:400px;padding:1.5rem;width:95%}.payment-history-section{padding:1rem}}.quick-estimator-page{background:#0f172a;flex:1 1;min-height:100vh;padding:0 0 60px;width:100%}.qe-container{margin:0 auto;max-width:1280px;padding:0 20px}.qe-header{padding:36px 0 28px;text-align:left}.qe-header h1{align-items:center;color:#f1f5f9;display:flex;font-size:28px;font-weight:700;gap:12px;margin:0 0 6px}.qe-header p{color:#64748b;font-size:15px;margin:0}.qe-layout{grid-gap:28px;align-items:start;display:grid;gap:28px;grid-template-columns:420px 1fr}.qe-inputs-panel,.qe-results-panel{display:flex;flex-direction:column;gap:20px}.qe-card{background:#1e293b;border:1px solid #334155;border-radius:14px;padding:24px}.qe-card h2{color:#e2e8f0;font-size:17px;font-weight:700;margin:0 0 20px}.qe-card h3{align-items:center;color:#cbd5e1;display:flex;font-size:15px;font-weight:600;gap:8px;margin:0 0 16px}.qe-field{margin-bottom:16px}.qe-field label{align-items:center;color:#94a3b8;display:flex;font-size:13px;font-weight:600;gap:6px;letter-spacing:.4px;margin-bottom:8px;text-transform:uppercase}.qe-field input[type=number],.qe-field select{background:#0f172a;border:1px solid #334155;border-radius:8px;box-sizing:border-box;color:#e2e8f0;font-size:15px;padding:10px 14px;transition:border-color .2s;width:100%}.qe-field input[type=number]:focus,.qe-field select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626;outline:none}.qe-field input::placeholder{color:#475569}.qe-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr 1fr}.qe-row .qe-field{margin-bottom:0}.qe-row.qe-row-2col{grid-template-columns:1fr 1fr}.qe-roof-types{display:flex;flex-wrap:wrap;gap:8px}.qe-type-btn{background:#0f172a;border:1px solid #334155;border-radius:8px;color:#94a3b8;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s}.qe-type-btn:hover{border-color:#3b82f6;color:#e2e8f0}.qe-type-btn.active{background:#3b82f6;border-color:#3b82f6;box-shadow:0 2px 8px #3b82f659;color:#fff}.qe-complexity{gap:8px}.qe-complexity,.qe-complexity-btn{display:flex;flex-direction:column}.qe-complexity-btn{background:#0f172a;border:1px solid #334155;border-radius:8px;cursor:pointer;gap:2px;padding:10px 14px;text-align:left;transition:all .2s}.qe-complexity-btn strong{color:#94a3b8;font-size:13px}.qe-complexity-btn span{color:#475569;font-size:12px}.qe-complexity-btn:hover{border-color:#3b82f6}.qe-complexity-btn:hover strong{color:#e2e8f0}.qe-complexity-btn.active{background:#3b82f61a;border-color:#3b82f6}.qe-complexity-btn.active strong{color:#60a5fa}.qe-complexity-btn.active span{color:#94a3b8}.qe-slider-group{align-items:center;display:flex;gap:12px}.qe-slider-group input[type=range]{-webkit-appearance:none;appearance:none;background:#334155;border-radius:3px;flex:1 1;height:6px;outline:none}.qe-slider-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:#3b82f6;border:2px solid #1e293b;border-radius:50%;cursor:pointer;height:18px;width:18px}.qe-margin-val{color:#3b82f6;font-size:18px;font-weight:700;min-width:45px;text-align:right}.qe-actions{border-top:1px solid #334155;display:flex;gap:10px;margin-top:8px;padding-top:16px}.qe-btn-primary{align-items:center;background:#3b82f6;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 20px;transition:all .2s}.qe-btn-primary:hover{background:#2563eb;box-shadow:0 4px 16px #3b82f659;transform:translateY(-1px)}.qe-btn-ghost{align-items:center;background:#0000;border:1px solid #334155;border-radius:10px;color:#94a3b8;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:12px 16px;transition:all .2s}.qe-btn-ghost:hover{border-color:#64748b;color:#e2e8f0}.qe-btn-secondary{align-items:center;background:#0000;border:1px solid #334155;border-radius:10px;color:#94a3b8;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 20px;transition:all .2s}.qe-btn-secondary:hover{background:#ffffff08;border-color:#64748b;color:#e2e8f0}.qe-diagram-card{text-align:center}.qe-diagram-card svg{filter:drop-shadow(0 2px 8px rgba(0,0,0,.3))}.qe-saved-list{display:flex;flex-direction:column;gap:6px}.qe-saved-item{align-items:center;background:#0f172a;border:1px solid #334155;border-radius:8px;display:flex;justify-content:space-between;padding:8px 12px;transition:border-color .2s}.qe-saved-item:hover{border-color:#475569}.qe-saved-link{background:none;border:none;color:#60a5fa;cursor:pointer;flex:1 1;font-size:13px;font-weight:500;overflow:hidden;padding:0;text-align:left;text-overflow:ellipsis;white-space:nowrap}.qe-saved-link:hover{color:#93c5fd;text-decoration:underline}.qe-btn-icon-sm{align-items:center;background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;height:28px;justify-content:center;transition:all .15s;width:28px}.qe-btn-icon-sm:hover{background:#ef444426;color:#ef4444}.qe-placeholder{align-items:center;color:#475569;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:400px;text-align:center}.qe-placeholder h3{color:#64748b;font-size:18px;justify-content:center;margin:0}.qe-placeholder p{color:#475569;font-size:14px;margin:0;max-width:280px}.qe-summary-card{background:linear-gradient(135deg,#1e3a5f,#1e293b);border:1px solid #334155;border-radius:14px;overflow:hidden;padding:28px;position:relative}.qe-summary-card:before{background:radial-gradient(circle,#3b82f614 0,#0000 70%);content:"";height:300px;pointer-events:none;position:absolute;right:-30%;top:-50%;width:300px}.qe-summary-top{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.qe-summary-label{color:#64748b;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.qe-summary-price{color:#f1f5f9;font-size:36px;font-weight:800;letter-spacing:-1px}.qe-summary-meta{display:flex;flex-wrap:wrap;gap:8px}.qe-summary-meta span{background:#ffffff0f;border-radius:6px;color:#94a3b8;font-size:12px;font-weight:500;padding:4px 10px}.qe-metrics{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr)}.qe-metric{background:#1e293b;border:1px solid #334155;border-radius:10px;padding:16px 12px;text-align:center}.qe-metric-val{color:#f1f5f9;display:block;font-size:22px;font-weight:700;line-height:1.2}.qe-metric-label{color:#64748b;display:block;font-size:11px;font-weight:600;letter-spacing:.3px;margin-top:4px;text-transform:uppercase}.qe-comparison-table{margin:0 -8px;overflow-x:auto}.qe-comparison-table table{border-collapse:collapse;font-size:13px;width:100%}.qe-comparison-table thead th{border-bottom:1px solid #334155;color:#64748b;font-size:11px;font-weight:700;letter-spacing:.3px;padding:10px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.qe-comparison-table tbody td{border-bottom:1px solid #33415580;color:#94a3b8;padding:10px 12px;white-space:nowrap}.qe-comparison-table tbody tr:hover{background:#ffffff05}.qe-row-highlight{background:#3b82f60f}.qe-row-highlight td{color:#e2e8f0!important}.qe-mat-name{color:#cbd5e1!important;font-weight:600}.qe-client-price strong{color:#3b82f6}.qe-accessories-table{border-collapse:collapse;font-size:13px;width:100%}.qe-accessories-table td{border-bottom:1px solid #33415566;color:#94a3b8;padding:8px 12px}.qe-accessories-table td:first-child{color:#cbd5e1;font-weight:500}.qe-accessories-table td:last-child{font-weight:600;text-align:right}.qe-row-total td{border-bottom:none;border-top:2px solid #334155;padding-top:12px}.qe-row-total td:last-child{color:#f1f5f9}.qe-export-actions{display:flex;flex-direction:column;gap:14px}.qe-save-row{display:flex;gap:10px}.qe-save-input{background:#0f172a;border:1px solid #334155;border-radius:8px;color:#e2e8f0;flex:1 1;font-size:14px;padding:10px 14px}.qe-save-input:focus{border-color:#3b82f6;outline:none}.qe-save-input::placeholder{color:#475569}.qe-btn-save{align-items:center;background:#10b981;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;padding:10px 18px;transition:all .2s;white-space:nowrap}.qe-btn-save:hover{background:#059669;box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.qe-export-row{display:flex;gap:10px}@media (max-width:960px){.qe-layout{grid-template-columns:1fr}.qe-row{grid-template-columns:1fr 1fr}.qe-metrics{grid-template-columns:repeat(2,1fr)}.qe-summary-price{font-size:28px}}@media (max-width:560px){.qe-row{grid-template-columns:1fr}.qe-metrics{grid-template-columns:repeat(2,1fr)}.qe-summary-meta{flex-direction:column;gap:4px}.qe-comparison-table table{font-size:12px}.qe-comparison-table thead th{font-size:9px;padding:8px 6px}.qe-comparison-table tbody td{font-size:11px;padding:8px 6px}.qe-comparison-table{margin:0 -12px}.qe-summary-card{padding:20px 16px}.qe-summary-price{font-size:28px}.qe-metric-val{font-size:18px}.qe-metric{padding:12px 8px}.qe-section{padding:20px 16px}.qe-card{padding:20px 14px}.qe-accessories-table td{font-size:12px;padding:6px 8px}.qe-header h1{font-size:24px}.quick-estimator-page{overflow-x:hidden}.qe-container{padding:0 12px}.qe-btn-primary,.qe-btn-secondary{box-sizing:border-box;font-size:13px;padding:10px 14px;width:100%}.qe-export-row{flex-direction:column}.qe-card.qe-export-actions,.qe-results-panel{overflow:hidden}.qe-save-row{flex-direction:column}}.panel-optimizer-page{background:linear-gradient(180deg,#f8fafc 0,#e0e7ef);min-height:100vh}.panel-optimizer-header{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:40px 30px}.panel-optimizer-header .container{margin:0 auto;max-width:1200px}.panel-optimizer-header .header-content{align-items:center;display:flex;gap:24px}.panel-optimizer-header h1{font-size:36px;font-weight:700;margin:0 0 8px}.panel-optimizer-header p{font-size:16px;margin:0;opacity:.95}.panel-optimizer-content{padding:40px 20px 80px}.panel-optimizer-content .container{margin:0 auto;max-width:1200px}.optimizer-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:400px 1fr}.cuts-list{background:#f8fafc;border-radius:8px;margin:24px 0;padding:16px}.cuts-list h4{color:#64748b;font-size:14px;font-weight:700;margin:0 0 12px}.cut-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;display:flex;justify-content:space-between;margin-bottom:8px;padding:10px 12px}.cut-item span{color:#1e293b;font-size:14px;font-weight:600}.btn-icon-small{background:#fee2e2;border-radius:4px;color:#dc2626;padding:6px;transition:all .2s}.btn-icon-small:hover{background:#dc2626;color:#fff}.stats-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:32px}.stat-card{background:linear-gradient(135deg,#f0f7ff,#e0f2fe);border:2px solid #bae6fd;border-radius:12px;padding:20px;text-align:center}.stat-label{color:#64748b;font-size:13px;font-weight:600;margin-bottom:8px}.stat-value{color:#2c5f8d;font-size:32px;font-weight:800}.cutting-schedule{margin-top:32px}.cutting-schedule h3{color:#1a3d5c;font-size:20px;font-weight:700;margin-bottom:20px}.sheet-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;margin-bottom:16px;padding:20px}.sheet-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.sheet-header strong{color:#1e293b;font-size:16px}.efficiency-badge{background:#dcfce7;border-radius:12px;color:#166534;font-size:13px;font-weight:600;padding:4px 12px}.sheet-cuts{background:#f8fafc;border-radius:6px;color:#475569;font-size:14px;margin-bottom:12px;padding:12px}.sheet-stats{color:#64748b;display:flex;font-size:13px;gap:24px;margin-bottom:12px}.sheet-visual{background:#f1f5f9;border-radius:6px;display:flex;height:32px;overflow:hidden}.used-bar,.waste-bar{align-items:center;color:#fff;display:flex;font-size:11px;font-weight:700;justify-content:center;transition:width .3s ease}.optimization-notes{background:#fffbeb;border-left:4px solid #f59e0b;border-radius:8px;margin-top:32px;padding:20px}.optimization-notes h4{color:#92400e;font-size:16px;font-weight:700;margin:0 0 12px}.optimization-notes ul{margin:0;padding-left:20px}.optimization-notes li{color:#78350f;font-size:14px;line-height:1.6;margin-bottom:8px}@media (max-width:968px){.optimizer-grid{grid-template-columns:1fr}.stats-cards{grid-template-columns:repeat(2,1fr)}.input-section,.results-section{padding:24px}.header-content{align-items:flex-start;flex-direction:column;gap:16px}.header-content h1{font-size:32px}}.btn-success{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.btn-success:hover:not(:disabled){box-shadow:0 4px 12px #10b9814d;transform:translateY(-2px)}.btn-success:disabled{cursor:not-allowed;opacity:.5}.saved-calculations{border-top:1px solid #e2e8f0;padding-top:24px}.saved-calculations h3{align-items:center;color:#1a3d5c;display:flex;font-size:16px;font-weight:600;gap:8px;margin:0 0 16px}.saved-list{gap:8px}.saved-item{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;justify-content:space-between;padding:12px 16px;transition:all .2s ease}.saved-item:hover{background:#f1f5f9;border-color:#cbd5e1}.saved-info{display:flex;flex-direction:column;gap:4px}.saved-name{color:#1a3d5c;font-size:14px;font-weight:600}.saved-date{color:#64748b;font-size:12px}.saved-actions{display:flex;gap:8px}.btn-icon-small{align-items:center;background:#fff;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.btn-icon-small:hover{background:#e2e8f0;color:#2c5f8d}.btn-icon-small.danger:hover{background:#fee2e2;color:#dc2626}.export-buttons{align-items:center;display:flex;gap:12px}.pricing-section h2{border-bottom:2px solid #ec4899}.quote-header{background:#fdf2f8}.quote-table .total-row{background:#ec4899}.quote-summary{background:linear-gradient(135deg,#fdf2f8,#fce7f3)}.summary-item strong{color:#be185d}.analytics-page{margin:0 auto;max-width:1400px;padding:30px}.analytics-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.analytics-header h1{color:#1f2937;font-size:32px;margin:0}.period-selector{display:flex;gap:10px}.period-selector button{background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;font-weight:500;padding:8px 20px;transition:all .2s}.period-selector button.active{background:#2c5f8d;border-color:#2c5f8d;color:#fff}.period-selector button:hover{border-color:#2c5f8d}.metrics-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.metric-card{background:#fff;box-shadow:0 1px 3px #0000001a;gap:16px;padding:24px}.metric-card,.metric-icon{align-items:center;border-radius:12px;display:flex}.metric-icon{flex-shrink:0;height:48px;justify-content:center;width:48px}.metric-content{flex:1 1}.metric-label{color:#6b7280;font-size:14px;margin:0 0 8px}.metric-value{color:#1f2937;font-size:28px;font-weight:700;margin:0 0 4px}.metric-growth{font-size:14px;font-weight:600;margin:0}.metric-detail{color:#6b7280;font-size:13px;margin:0}.chart-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:30px;padding:24px}.chart-section h3{color:#1f2937;margin:0 0 24px}.revenue-chart{align-items:flex-end;display:flex;gap:16px;height:240px;justify-content:space-between;overflow-x:auto;padding:20px 0}.chart-bar-container{align-items:center;display:flex;flex-direction:column;gap:8px;min-width:60px}.chart-bar{background:linear-gradient(0deg,#2c5f8d,#4a7ba7);border-radius:6px 6px 0 0;cursor:pointer;min-height:20px;position:relative;transition:all .3s;width:40px}.chart-bar:hover{opacity:.8}.bar-value{color:#374151;font-size:11px;font-weight:600;left:50%;position:absolute;top:-24px;transform:translateX(-50%);white-space:nowrap}.bar-label{color:#6b7280;font-size:11px;text-align:center;writing-mode:horizontal-tb}.two-column-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:30px}.status-breakdown,.top-clients{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.status-breakdown h3,.top-clients h3{color:#1f2937;margin:0 0 20px}.clients-list,.status-list{display:flex;flex-direction:column;gap:12px}.client-item,.status-item{align-items:center;background:#f9fafb;border-radius:8px;display:flex;justify-content:space-between;padding:12px}.client-info,.status-info{display:flex;flex-direction:column;gap:4px}.client-name,.status-name{color:#1f2937;font-weight:600;text-transform:capitalize}.client-projects,.status-count{color:#6b7280;font-size:13px}.client-revenue,.status-value{color:#2c5f8d;font-weight:700}.client-rank{align-items:center;background:#2c5f8d;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-weight:700;height:32px;justify-content:center;width:32px}.invoice-metrics{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:30px;padding:24px}.invoice-metrics h3{color:#1f2937;margin:0 0 20px}.invoice-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.invoice-stat{align-items:center;background:#f9fafb;border-radius:8px;display:flex;gap:12px;padding:16px}.invoice-stat p{color:#6b7280;font-size:13px;margin:0 0 4px}.invoice-stat h4{color:#1f2937;font-size:20px;margin:0}.materials-section{box-shadow:0 1px 3px #0000001a;padding:24px}.materials-section h3{color:#1f2937;margin:0 0 20px}.materials-table table{border-collapse:collapse;width:100%}.materials-table th{background:#f9fafb;border-bottom:2px solid #e5e7eb;color:#6b7280;font-size:13px;font-weight:600;padding:12px;text-align:left}.materials-table td{border-bottom:1px solid #e5e7eb;color:#374151;padding:12px}.materials-table tr:hover td{background:#f9fafb}@media (max-width:768px){.analytics-page{padding:20px}.analytics-header{align-items:flex-start;flex-direction:column;gap:16px}.metrics-grid,.two-column-grid{grid-template-columns:1fr}.revenue-chart{height:200px}.chart-bar-container{min-width:40px}.chart-bar{width:30px}}.flashing-designer{background:#0f172a;flex:1 1;margin:0 auto;min-height:100vh;padding:0 0 60px;width:100%}.designer-header{background:#1e293b;border-bottom:1px solid #334155;border-radius:0;margin-bottom:0;padding:36px 30px 28px;text-align:center}.designer-header h1{color:#f1f5f9;font-size:28px;font-weight:700;margin:0 0 8px}.designer-header p{color:#64748b;font-size:15px;margin:0}.designer-navigation{background:#0f172a;border-bottom:1px solid #334155;display:flex;flex-wrap:nowrap;gap:0;justify-content:center;margin:0;overflow-x:auto;padding:0 20px}.designer-navigation button{background:#0000;border:none;border-bottom:3px solid #0000;border-radius:0;color:#64748b;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:.2px;padding:14px 24px;transition:all .2s ease;white-space:nowrap}.designer-navigation button:hover{background:#3b82f60a;color:#94a3b8}.designer-navigation button.active{background:#3b82f60f;border-bottom-color:#3b82f6;color:#3b82f6}.designer-content{background:#0000;border-radius:0;box-shadow:none;margin:0 auto;max-width:1300px;padding:28px 20px}.section-panel h2{color:#f1f5f9;font-size:22px;font-weight:700;margin:0 0 8px}.section-panel>p{color:#64748b;font-size:14px;margin:0 0 24px}.mud-map-section{background:#0f172a80;border:2px dashed #475569;border-radius:12px;margin-top:28px;padding:24px;transition:all .25s ease}.mud-map-section:hover{background:#3b82f60a;border-color:#3b82f6}.mud-map-section h3{color:#e2e8f0;font-size:16px;font-weight:600;margin:0 0 12px}.mud-map-section input[type=file]{background:#0f172a;border:1px solid #334155;border-radius:8px;color:#e2e8f0;cursor:pointer;max-width:400px;padding:10px;width:100%}.mud-map-preview{border:1px solid #334155;border-radius:10px;margin-top:16px;max-width:600px;overflow:hidden}.mud-map-preview img{display:block;height:auto;width:100%}.products-section{margin-bottom:28px}.products-section h3{border-bottom:2px solid #3b82f6;color:#e2e8f0;font-size:18px;font-weight:700;margin:0 0 16px;padding-bottom:12px}.mud-map-hint{background:#f59e0b14;border-left:3px solid #f59e0b;border-radius:6px;color:#fbbf24;font-size:14px;margin:0 0 20px;padding:14px 16px}.products-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-top:16px}.product-card{background:#1e293b;border:1px solid #334155;border-radius:12px;cursor:pointer;overflow:hidden;padding:0;transition:all .25s ease}.product-card:hover{border-color:#3b82f6;box-shadow:0 8px 24px #3b82f61f;transform:translateY(-3px)}.product-card.selected{background:#3b82f614;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.product-image{background:#0f172a;height:180px;overflow:hidden;width:100%}.product-image img{height:100%;object-fit:cover;width:100%}.product-card h4{color:#e2e8f0;font-size:15px;font-weight:600;margin:14px 16px 6px}.product-card p{color:#64748b;font-size:13px;margin:0 16px 10px}.product-card .specs{display:flex;flex-wrap:wrap;gap:8px;padding:0 16px 16px}.product-card .specs span{background:#0f172a;border:1px solid #334155;border-radius:6px;color:#94a3b8;font-size:12px;font-weight:500;padding:4px 10px}.mud-map-upload-section{background:#3b82f60a;border:2px dashed #475569;border-radius:12px;margin-bottom:20px;padding:24px;transition:all .25s ease}.mud-map-upload-section:hover{border-color:#3b82f6}.mud-map-upload-section h3{color:#60a5fa;font-size:16px;font-weight:600;margin:0 0 14px}.file-input{background:#0f172a;border:1px solid #334155;border-radius:8px;color:#e2e8f0;cursor:pointer;max-width:400px;padding:10px;width:100%}.upload-success{background:#10b9811a;border-left:3px solid #10b981;border-radius:6px;color:#34d399;font-size:14px;font-weight:600;margin-top:14px;padding:12px 16px}.flashing-designer .canvas-toolbar{align-items:center;background:#0f172a;border:1px solid #334155;border-radius:12px;display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;padding:14px 18px}.flashing-designer .toolbar-section{align-items:center;display:flex;gap:5px}.flashing-designer .toolbar-divider{background:#334155;height:32px;margin:0 6px;width:1px}.flashing-designer .canvas-toolbar button{align-items:center;background:#1e293b;border:1px solid #334155;border-radius:8px;color:#94a3b8;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s ease}.flashing-designer .canvas-toolbar button:hover:not(:disabled){background:#3b82f61a;border-color:#3b82f6;color:#60a5fa}.flashing-designer .canvas-toolbar button.active{background:#3b82f6;border-color:#3b82f6;box-shadow:0 0 8px #3b82f64d;color:#fff}.flashing-designer .canvas-toolbar button:disabled{cursor:not-allowed;opacity:.35}.flashing-designer .canvas-info{background:#1e293b;border:1px solid #334155;border-radius:8px;color:#94a3b8;display:flex;flex-direction:row;flex-wrap:wrap;font-size:13px;gap:16px;margin-bottom:10px;padding:10px 14px}.flashing-designer .canvas-info span{align-items:center;display:flex;gap:5px}.flashing-designer .canvas-container{background:#fff;border:1px solid #334155;border-radius:12px;box-shadow:0 2px 8px #00000026;display:flex;justify-content:center;overflow:hidden;width:100%}.flashing-designer .canvas-container canvas{display:block;height:auto;max-width:100%}.colorbond-palette-section{background:#1e293b;border:1px solid #334155;border-radius:14px;margin-bottom:32px;padding:24px}.colorbond-palette-section h3{color:#e2e8f0;font-size:18px;font-weight:700;margin:0 0 6px}.colorbond-palette-section p{color:#64748b;font-size:14px;margin:0 0 20px}.color-palette-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.color-palette-item{align-items:center;background:#0f172a;border:1px solid #334155;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;padding:10px;transition:all .2s ease}.color-palette-item:hover{border-color:#475569;box-shadow:0 4px 12px #0000004d;transform:translateY(-2px)}.color-swatch{border:1px solid #475569;border-radius:8px;box-shadow:inset 0 2px 4px #0003;height:60px;margin-bottom:8px;width:100%}.color-name{color:#e2e8f0;font-size:12px;font-weight:600;margin-bottom:2px;text-align:center}.color-finish{color:#64748b;font-size:11px;text-transform:capitalize}.flashing-detail-form{background:#1e293b;border:1px solid #334155;border-radius:12px;margin-bottom:16px;padding:24px}.flashing-detail-form h3{border-bottom:1px solid #334155;color:#e2e8f0;font-size:16px;font-weight:600;margin:0 0 20px;padding-bottom:12px}.form-row{grid-gap:16px;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:16px}.form-group label{color:#94a3b8;font-size:13px;letter-spacing:.3px;margin-bottom:6px;text-transform:uppercase}.form-group input,.form-group select,.form-group textarea{background:#0f172a;border:1px solid #334155;color:#e2e8f0;font-size:14px;padding:10px 14px;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61f}.form-group input::placeholder,.form-group textarea::placeholder{color:#475569}.form-group select option{background:#1e293b;color:#e2e8f0}.form-group textarea{min-height:80px}.color-preview{border:1px solid #475569;border-radius:8px;height:36px;margin-top:8px;width:100%}.total-summary{background:linear-gradient(135deg,#1e3a5f,#1e293b);border:1px solid #334155;border-radius:12px;margin-top:28px;padding:20px;text-align:center}.total-summary h3{color:#f1f5f9;font-size:22px;font-weight:700;margin:0}.order-type-selector{background:#1e293b;border:1px solid #334155;border-radius:10px;display:flex;gap:20px;margin-bottom:24px;padding:16px 20px}.order-type-selector label{align-items:center;color:#94a3b8;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:10px}.order-type-selector input[type=radio]{accent-color:#3b82f6;cursor:pointer;height:18px;width:18px}.contact-form,.delivery-method,.site-details-form{margin-bottom:24px}.contact-form h3,.delivery-method h3,.site-details-form h3{border-bottom:1px solid #334155;color:#e2e8f0;font-size:17px;font-weight:700;margin:0 0 16px;padding-bottom:12px}.delivery-method{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:20px}.delivery-method label{align-items:center;color:#94a3b8;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:10px;margin-bottom:10px}.delivery-method input[type=radio]{accent-color:#3b82f6;cursor:pointer;height:18px;width:18px}.order-actions{margin-top:32px;text-align:center}.pricing-section{background:#1e293b;border:1px solid #334155;border-radius:14px;margin-top:28px;padding:28px}.pricing-section h2{border-bottom:2px solid #3b82f6;color:#f1f5f9;font-size:20px;font-weight:700;padding-bottom:14px}.quote-header{background:#0f172a;border:1px solid #334155;border-radius:10px}.quote-header p{color:#94a3b8;font-size:14px}.quote-header p strong{color:#e2e8f0}.quote-table th{background:#0f172a;border-bottom:1px solid #334155;color:#94a3b8;font-size:12px;font-weight:700;letter-spacing:.3px;padding:12px;text-transform:uppercase}.quote-table td{border-bottom:1px solid #33415580;color:#94a3b8;padding:12px}.quote-table tr:hover{background:#3b82f608}.quote-table .subtotal-row{background:#3b82f60a}.quote-table .subtotal-row td{color:#e2e8f0}.quote-table .total-row{background:#3b82f6}.quote-table .total-row td{color:#fff;padding:14px 12px}.quote-summary{background:#3b82f60f;border:1px solid #3b82f626;border-radius:10px}.summary-item strong{color:#60a5fa;font-weight:700}.pricing-buttons{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}.flashing-designer .btn-danger,.flashing-designer .btn-primary,.flashing-designer .btn-secondary{align-items:center;border:none;border-radius:10px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s ease}.flashing-designer .btn-primary{background:#3b82f6!important;color:#fff!important}.flashing-designer .btn-primary:hover{background:#2563eb!important;box-shadow:0 4px 16px #3b82f659;transform:translateY(-1px)}.flashing-designer .btn-primary:disabled{background:#475569!important;box-shadow:none;cursor:not-allowed;transform:none}.flashing-designer .btn-secondary{background:#0f172a!important;border:1px solid #334155!important;color:#94a3b8!important}.flashing-designer .btn-secondary:hover{background:#1e293b!important;border-color:#475569!important;color:#e2e8f0!important}.flashing-designer .btn-danger{background:#ef44441a!important;border:1px solid #ef444440!important;color:#ef4444!important}.flashing-designer .btn-danger:hover{background:#ef4444!important;color:#fff!important}.flashing-designer .btn-large{font-size:15px;font-weight:700;padding:14px 32px}@media (max-width:968px){.designer-header h1{font-size:22px}.designer-navigation{-webkit-overflow-scrolling:touch;justify-content:flex-start;overflow-x:auto;padding:0 12px;scrollbar-width:none}.designer-navigation::-webkit-scrollbar{display:none}.designer-navigation button{font-size:13px;min-width:-webkit-max-content;min-width:max-content;padding:12px 16px}.designer-content{padding:20px 14px}.form-row,.products-grid{grid-template-columns:1fr}.flashing-designer .canvas-toolbar{flex-direction:column;gap:8px}.flashing-designer .canvas-toolbar button{justify-content:center;width:100%}.pricing-buttons{flex-direction:column}.pricing-buttons .btn-primary,.pricing-buttons .btn-secondary{justify-content:center;width:100%}.color-palette-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.quote-summary{flex-direction:column;gap:12px}}@media (max-width:480px){.flashing-designer{overflow-x:hidden}.designer-header{padding:24px 16px 20px}.designer-header h1{font-size:20px}.designer-header p{font-size:13px}.designer-navigation button{font-size:12px;padding:10px 14px}.designer-content{padding:16px 12px}.section-panel h2{font-size:18px}.mud-map-section{padding:16px}}.gutter-calculator{margin:0 auto;max-width:1400px;min-height:calc(100vh - 100px);padding:20px}.gutter-header{align-items:center;background:linear-gradient(135deg,#06b6d4,#0891b2)!important;border-radius:12px;color:#fff;display:flex;gap:24px;margin-bottom:30px;padding:40px 30px}.calculator-header{background:linear-gradient(135deg,#06b6d4,#0891b2);border-radius:12px}.calculator-content{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 350px}.calculator-main{display:flex;flex-direction:column;gap:30px}.input-section,.results-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:30px}.input-section h2,.results-section h2{border-bottom:3px solid #06b6d4;color:#1f2937;font-size:1.6rem;margin:0 0 25px;padding-bottom:15px}.form-group{margin-bottom:20px}.form-group label{color:#374151;display:block;font-size:.95rem;margin-bottom:8px}.form-group input,.form-group select{border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;padding:12px;transition:border-color .2s;width:100%}.form-group input:focus,.form-group select:focus{border-color:#06b6d4;box-shadow:0 0 0 3px #06b6d41a;outline:none}.form-group small{color:#6b7280;display:block;font-size:.875rem;margin-top:6px}.form-row{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr;margin-bottom:20px}.btn-calculate{background:linear-gradient(135deg,#06b6d4,#0891b2)}.btn-calculate:hover{box-shadow:0 4px 12px #06b6d44d}.results-section{animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.result-card{background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;margin-bottom:20px;padding:20px}.result-card.highlight{background:linear-gradient(135deg,#ecfeff,#cffafe);border-color:#06b6d4}.result-card h3{color:#0891b2;font-size:1.2rem;margin:0 0 10px}.result-card h4{color:#374151;font-size:1rem;margin:0 0 10px}.result-card p{color:#6b7280;font-size:.95rem;margin:5px 0 0}.result-value{color:#0891b2;font-size:2.5rem;margin:10px 0}.results-grid{grid-gap:15px;gap:15px;grid-template-columns:repeat(2,1fr);margin-bottom:20px}.results-grid .result-card{margin-bottom:0;text-align:center}.results-grid .result-value{font-size:1.8rem}.position-list{list-style:none;margin:15px 0 0;padding:0}.position-list li{background:#fff;border-left:4px solid #06b6d4;border-radius:4px;margin-bottom:8px;padding:10px 15px}.action-buttons{gap:15px;margin-top:25px}.btn-save,.btn-secondary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:1rem;font-weight:600;gap:8px;justify-content:center;padding:14px 20px;transition:all .2s}.btn-save{background:#10b981}.btn-save:hover{background:#059669}.btn-save:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.btn-secondary{background:#f3f4f6;border:2px solid #e5e7eb;color:#374151}.btn-secondary:hover{background:#e5e7eb}.saved-calculations{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;height:-webkit-fit-content;height:fit-content;padding:25px;position:-webkit-sticky;position:sticky;top:20px}.saved-calculations h2{border-bottom:2px solid #e5e7eb;color:#1f2937;font-size:1.3rem;margin:0 0 20px;padding-bottom:12px}.calculations-list{display:flex;flex-direction:column;gap:12px}.saved-item:hover{border-color:#06b6d4}.saved-item h4{color:#1f2937;font-size:1rem;font-weight:600;margin:0}.saved-item p{font-size:.875rem;margin:0 0 12px}.btn-load{background:#06b6d4}.btn-load:hover{background:#0891b2}@media (max-width:1200px){.calculator-content{grid-template-columns:1fr}.saved-calculations{position:static}}@media (max-width:768px){.gutter-calculator{padding:10px}.calculator-header{flex-direction:column;padding:20px;text-align:center}.calculator-header h1{font-size:1.6rem}.form-row,.results-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}}.pricing-section h2{border-bottom:2px solid #06b6d4}.quote-table .section-header{background:#f1f5f9}.quote-table .section-header td{color:#1a3d5c;font-size:13px;padding:8px}.quote-table .total-row{background:#06b6d4}.quote-summary{background:linear-gradient(135deg,#f0fdfa,#ecfeff);margin-bottom:20px}.summary-item strong{color:#0d9488}.quote-notes{background:#fffbeb;border-left:4px solid #f59e0b}.quote-notes h4{color:#92400e}.quote-notes li{color:#78350f}@media (max-width:768px){.quote-table{font-size:12px}.quote-table td,.quote-table th{padding:8px 4px}.quote-summary{flex-direction:column;gap:16px}}.pitch-calculator{margin:0 auto;max-width:1400px;min-height:calc(100vh - 100px);padding:20px}.pitch-calculator .calculator-header{align-items:center;background:linear-gradient(135deg,#ef4444,#dc2626)!important;border-radius:12px;color:#fff;display:flex;gap:24px;margin-bottom:30px;padding:40px 30px}.input-method-selector{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,1fr);margin-top:10px}.input-method-selector button{background:#fff;border:2px solid #e5e7eb;border-radius:6px;color:#374151;cursor:pointer;font-size:.95rem;font-weight:500;padding:12px;transition:all .2s}.input-method-selector button:hover{border-color:#ef4444;color:#ef4444}.input-method-selector button.active{background:#ef4444;border-color:#ef4444;color:#fff}.pitch-visual{align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;display:flex;justify-content:center;margin-bottom:25px;padding:30px}.pitch-diagram{height:auto;max-width:100%}.conversions-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(4,1fr);margin-bottom:25px}.conversion-card{background:linear-gradient(135deg,#fecaca,#fca5a5);border:2px solid #ef4444;border-radius:8px;padding:20px;text-align:center}.conversion-card h4{color:#991b1b;font-size:.95rem;font-weight:600;margin:0 0 10px;text-transform:uppercase}.conversion-value{color:#dc2626;font-size:2rem;font-weight:700}.walkability-safe{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#10b981}.walkability-safe h4{color:#065f46}.walkability-safe .conversion-value{color:#10b981;text-transform:capitalize}.walkability-caution{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b}.walkability-caution h4{color:#92400e}.walkability-caution .conversion-value{color:#f59e0b;text-transform:capitalize}.walkability-dangerous{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#ef4444}.walkability-dangerous h4{color:#991b1b}.walkability-dangerous .conversion-value{color:#ef4444;text-transform:capitalize}.rafter-results{background:linear-gradient(135deg,#ecfeff,#cffafe);border:2px solid #06b6d4;border-radius:12px;margin-bottom:25px;padding:25px}.rafter-results h3{color:#0891b2;font-size:1.3rem;margin:0 0 20px}.result-item{background:#fff;border-radius:8px;padding:15px}.result-item label{color:#6b7280;display:block;font-size:.9rem;font-weight:500;margin-bottom:8px}.result-item .value{color:#0891b2;font-size:1.8rem;font-weight:700}.materials-section{background:#fff;border:2px solid #e5e7eb;border-radius:12px;margin-bottom:25px;padding:25px}.materials-section h3{color:#10b981;font-size:1.2rem;margin:0 0 15px}.materials-hint{color:#6b7280;font-size:.95rem;margin:0 0 15px}.materials-list{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.material-item{align-items:center;background:#f0fdf4;border-left:4px solid #10b981;border-radius:6px;color:#065f46;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:10px;padding:12px 16px;transition:all .2s ease;-webkit-user-select:none;user-select:none}.material-item:hover{background:#dcfce7;transform:translateX(3px)}.material-item.selected{background:#d1fae5;border-left-color:#059669;box-shadow:0 2px 4px #05966933}.material-item input[type=checkbox]{accent-color:#10b981;cursor:pointer;height:18px;width:18px}.material-item span{flex:1 1}.selected-materials-summary{background:#dbeafe;border-left:4px solid #3b82f6;border-radius:6px;color:#1e40af;font-size:.95rem;margin-top:15px;padding:12px 16px}.selected-materials-summary strong{color:#1e3a8a}.warning{background:#fee2e2;border-left:4px solid #ef4444;border-radius:6px;color:#991b1b;font-weight:600;margin-top:15px;padding:15px}.btn-calculate{background:linear-gradient(135deg,#ef4444,#dc2626);margin-top:10px}.btn-calculate:hover{box-shadow:0 4px 12px #f59e0b4d}.saved-item:hover{border-color:#ef4444}.btn-load{background:#ef4444}.btn-load:hover{background:#dc2626}@media (max-width:1200px){.calculator-content{grid-template-columns:1fr}}@media (max-width:768px){.pitch-calculator{padding:10px}.calculator-header{flex-direction:column;padding:20px;text-align:center}.calculator-header h1{font-size:1.6rem}.conversions-grid,.input-method-selector{grid-template-columns:repeat(2,1fr)}.materials-list{grid-template-columns:1fr}}.pricing-section h2{border-bottom:2px solid #f97316}.quote-header{background:#fff7ed}.quote-table .total-row{background:#f97316}.quote-summary{background:linear-gradient(135deg,#fff7ed,#ffedd5)}.summary-item strong{color:#ea580c}.quote-notes{background:#fff7ed;border-left:4px solid #f97316}.quote-notes h4{color:#c2410c}.quote-notes li{color:#ea580c}.ventilation-calculator{background:#f8fafc;min-height:100vh;padding-bottom:60px}.ventilation-calculator .calculator-header{align-items:center;background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;display:flex;gap:24px;margin-bottom:30px;padding:40px 30px}.ventilation-calculator .calculator-header h1{font-size:36px;font-weight:700;margin:0}.ventilation-calculator .calculator-header p{font-size:16px;margin:5px 0 0;opacity:.95}.input-group input:focus,.input-group select:focus{border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a61a}.ventilation-calculator .btn-calculate{align-items:center;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;gap:10px;justify-content:center;margin-top:24px;padding:16px;transition:transform .2s;width:100%}.ventilation-calculator .btn-calculate:hover{box-shadow:0 6px 20px #14b8a64d;transform:translateY(-2px)}.ventilation-calculator .btn-calculate:disabled{cursor:not-allowed;opacity:.6}.compliance-badge.non-compliant{background:#fef3c7;border:2px solid #f59e0b;color:#92400e}.results-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.result-card{background:linear-gradient(135deg,#ccfbf1,#99f6e4);border:2px solid #14b8a6}.result-card h4{color:#134e4a}.result-value{color:#0d9488}.result-note{color:#115e59}.products-list{background:#f8fafc;border-radius:12px;margin-bottom:24px;padding:20px}.product-item{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:12px;padding:16px}.product-item:last-child{margin-bottom:0}.product-name{color:#1e293b;font-size:15px;font-weight:600}.product-qty{color:#14b8a6;font-size:18px;font-weight:700}.btn-save{background:#14b8a6}.btn-save:hover{background:#0d9488}.btn-export{border:2px solid #14b8a6;color:#14b8a6}.btn-export:hover{background:#14b8a6}.saved-item:hover{border-color:#14b8a6}.btn-load{background:#14b8a6}.btn-load:hover{background:#0d9488}@media (max-width:768px){.ventilation-calculator .calculator-header{flex-direction:column;padding:24px;text-align:center}.ventilation-calculator .calculator-header h1{font-size:24px}.input-section,.results-section,.saved-section{padding:24px 20px}.input-grid,.results-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}.btn-export,.btn-save{width:100%}.saved-item{flex-direction:column;gap:16px}.saved-actions{width:100%}.btn-delete,.btn-load{flex:1 1}}.pricing-section h2{border-bottom:2px solid #10b981}.quote-header{background:#f8fafc}.quote-table .total-row{background:#10b981}.quote-notes{background:#f0fdf4;border-left:4px solid #10b981}.quote-notes h4{color:#166534}.quote-notes li{color:#15803d}.weather-calculator{background:#f8fafc;min-height:100vh;padding-bottom:60px}.calculator-header{align-items:center;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;display:flex;gap:24px;margin-bottom:30px;padding:40px 30px}.calculator-header h1{font-size:36px;font-weight:700;margin:0}.calculator-header p{font-size:16px;margin:5px 0 0;opacity:.95}.calculator-content{margin:0 auto;max-width:1200px;padding:0 20px}.input-section{background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014;margin-bottom:32px;padding:32px}.input-section h2{color:#1a3d5c;font-size:24px;font-weight:700;margin:0 0 24px}.input-section h3{border-bottom:2px solid #e2e8f0;color:#475569;font-size:18px;font-weight:600;margin:32px 0 16px;padding-bottom:8px}.input-group{margin-bottom:20px}.input-group label{color:#475569;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.input-group input,.input-group select{border:2px solid #e2e8f0;border-radius:8px;font-size:15px;padding:12px 16px;transition:all .2s;width:100%}.input-group input:focus,.input-group select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.input-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-notice{align-items:start;background:#eff6ff;border-left:4px solid #6366f1;border-radius:8px;display:flex;gap:12px;margin:16px 0 24px;padding:16px}.info-notice svg{color:#6366f1;flex-shrink:0;margin-top:2px}.info-notice p{color:#1e40af;font-size:14px;line-height:1.5;margin:0}.snow-details{background:#f0f9ff;border:2px solid #bae6fd;border-radius:12px;margin-top:16px;padding:20px}.input-group small{color:#64748b;display:block;font-size:12px;font-style:italic;margin-top:6px}.checkbox-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:24px 0}.checkbox-label{align-items:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:16px;transition:all .2s}.checkbox-label:hover{background:#eef2ff;border-color:#6366f1}.checkbox-label input[type=checkbox]{cursor:pointer;height:20px;width:20px}.checkbox-label span{color:#475569;font-size:15px;font-weight:600}.btn-calculate{align-items:center;background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;gap:10px;justify-content:center;margin-top:24px;padding:16px;transition:transform .2s;width:100%}.btn-calculate:hover{box-shadow:0 6px 20px #6366f14d;transform:translateY(-2px)}.btn-calculate:disabled{cursor:not-allowed;opacity:.6}.results-section{background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014;margin-bottom:32px;padding:32px}.results-section h2{color:#1a3d5c;font-size:24px;font-weight:700;margin:0 0 24px}.results-section h3{color:#475569;font-size:18px;font-weight:600;margin:32px 0 16px}.warning-box{align-items:flex-start;background:#fef3c7;border:2px solid #f59e0b;border-radius:12px;color:#92400e;display:flex;gap:12px;margin-bottom:24px;padding:16px 20px}.warning-box strong{display:block;margin-bottom:8px}.warning-box ul{margin:0;padding-left:20px}.warning-box li{margin:4px 0}.compliance-badge{align-items:center;border-radius:12px;display:flex;font-weight:600;gap:12px;margin-bottom:24px;padding:16px 20px}.compliance-badge.compliant{background:#d1fae5;border:2px solid #10b981;color:#065f46}.compliance-badge.non-compliant{background:#fee2e2;border:2px solid #ef4444;color:#991b1b}.results-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:32px}.result-card{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border:2px solid #6366f1;border-radius:12px;padding:24px;text-align:center}.result-card h4{color:#312e81;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.result-value{color:#4f46e5;font-size:32px;font-weight:700;margin-bottom:8px}.result-note{color:#4338ca;font-size:13px;margin:0}.recommendations-box{background:#f8fafc;border-radius:12px;margin-bottom:24px;padding:20px}.recommendation-item{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:12px;padding:16px}.recommendation-item:last-child{margin-bottom:0}.recommendation-item strong{color:#1e293b;font-size:15px}.recommendation-item span{color:#6366f1;font-size:15px;font-weight:600}.recommendation-item span.required{color:#ef4444;font-weight:700}.recommendation-item span.not-required{color:#10b981}.action-buttons{display:flex;flex-wrap:wrap;gap:16px}.btn-export,.btn-save{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:16px;font-weight:600;gap:8px;justify-content:center;min-width:200px;padding:14px 24px;transition:all .2s}.btn-save{background:#6366f1;color:#fff}.btn-save:hover{background:#4f46e5;transform:translateY(-2px)}.btn-export{background:#fff;border:2px solid #6366f1;color:#6366f1}.btn-export:hover{background:#6366f1;color:#fff;transform:translateY(-2px)}.saved-section{background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014;padding:32px}.saved-section h2{color:#1a3d5c;font-size:24px;font-weight:700;margin:0 0 24px}.saved-list{gap:12px}.saved-item,.saved-list{display:flex;flex-direction:column}.saved-item{background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;padding:15px;transition:border-color .2s}.saved-item:hover{border-color:#6366f1}.saved-item-header{align-items:start;display:flex;justify-content:space-between;margin-bottom:8px}.saved-item-header h4{color:#1f2937;font-size:1rem;font-weight:600;margin:0}.saved-item p{color:#6b7280;font-size:.9rem;margin:0 0 10px}.btn-delete{align-items:center;background:#fee2e2;border:none;border-radius:6px;color:#dc2626;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:6px;justify-content:center;margin-top:16px;padding:8px 12px;transition:background .2s;width:100%}.btn-delete:hover{background:#fecaca}.btn-load{background:#6366f1;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 12px;transition:background .2s;width:100%}.btn-load:hover{background:#4f46e5}@media (max-width:768px){.calculator-header{flex-direction:column;padding:24px;text-align:center}.calculator-header h1{font-size:24px}.input-section,.results-section,.saved-section{padding:24px 20px}.checkbox-grid,.input-grid,.results-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}.btn-export,.btn-save{width:100%}.saved-item{flex-direction:column;gap:16px}.saved-actions{width:100%}.btn-delete,.btn-load{flex:1 1}}.pricing-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-top:32px;padding:24px}.pricing-section h2{border-bottom:2px solid #6366f1;color:#1a3d5c;font-size:24px;margin-bottom:20px;padding-bottom:12px}.quote-header{background:#eef2ff;border-radius:8px;margin-bottom:24px;padding:16px}.quote-header p{color:#475569;margin:4px 0}.quote-table{border-collapse:collapse;font-size:14px;margin-bottom:24px;width:100%}.quote-table th{background:#1a3d5c;color:#fff;font-weight:600;padding:12px 8px;text-align:left}.quote-table td:last-child,.quote-table th:last-child{text-align:right}.quote-table td{border-bottom:1px solid #e2e8f0;padding:10px 8px}.quote-table tr:hover{background:#f8fafc}.quote-table .subtotal-row{background:#f8fafc;font-weight:500}.quote-table .total-row{background:#6366f1;color:#fff;font-size:16px}.quote-table .total-row td{border:none;padding:14px 8px}.quote-summary{background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-radius:8px;display:flex;gap:32px;margin-bottom:16px;padding:16px}.summary-item{display:flex;flex-direction:column;gap:4px}.summary-item span{color:#64748b;font-size:13px}.summary-item strong{color:#4f46e5;font-size:20px}.quote-notes{background:#eef2ff;border-left:4px solid #6366f1;border-radius:8px;padding:16px}.quote-notes h4{color:#3730a3;font-size:14px;margin:0 0 8px}.quote-notes ul{margin:0;padding-left:20px}.quote-notes li{color:#4338ca;font-size:13px;margin:4px 0}.job-scheduler{background:#f8fafc;min-height:100vh;padding-bottom:60px}.scheduler-header{align-items:center;background:linear-gradient(135deg,#eab308,#ca8a04);color:#fff;display:flex;gap:24px;margin-bottom:0;padding:40px 30px}.scheduler-header h1{font-size:36px;font-weight:700;margin:0}.scheduler-header p{font-size:16px;margin:5px 0 0;opacity:.95}.scheduler-tabs{background:#fff;border-bottom:2px solid #e2e8f0;display:flex;padding:0 20px}.scheduler-tabs button{align-items:center;background:#0000;border:none;border-bottom:3px solid #0000;color:#64748b;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;padding:16px 24px;transition:all .2s}.scheduler-tabs button:hover{background:#fef9c3;color:#eab308}.scheduler-tabs button.active{border-bottom-color:#eab308;color:#eab308}.scheduler-content{margin:0 auto;max-width:1400px;padding:32px 20px}.calendar-header,.view-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.calendar-header h2,.view-header h2{color:#1a3d5c;font-size:24px;font-weight:700;margin:0}.btn-primary{align-items:center;background:linear-gradient(135deg,#eab308,#ca8a04);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s}.btn-primary:hover{box-shadow:0 4px 12px #eab3084d;transform:translateY(-2px)}.btn-secondary{background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#475569;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .2s}.btn-secondary:hover{border-color:#eab308;color:#eab308}.btn-icon{background:#0000;border:none;border-radius:6px;color:#64748b;cursor:pointer;padding:8px;transition:all .2s}.btn-icon:hover{background:#f1f5f9;color:#eab308}.btn-icon.btn-danger:hover{background:#fee2e2;color:#ef4444}.day-schedule{background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014;padding:32px}.day-schedule h3{color:#1a3d5c;font-size:20px;font-weight:700;margin:0 0 24px}.jobs-list{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.empty-state{color:#94a3b8;padding:60px 20px;text-align:center}.empty-state svg{color:#cbd5e1;margin-bottom:16px}.empty-state p{font-size:18px;margin-bottom:20px}.job-card{background:#fff;border:2px solid #e2e8f0;border-left-width:6px;border-radius:12px;padding:20px;transition:all .2s}.job-card:hover{box-shadow:0 4px 12px #0000001a}.job-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.job-card-header h4{color:#1e293b;font-size:18px;font-weight:700;margin:0 0 6px}.client-name{color:#64748b;font-size:14px;margin:0}.job-status{border-radius:16px;color:#fff;font-size:12px;font-weight:700;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.job-card-details{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:16px}.detail-item{align-items:center;color:#475569;display:flex;font-size:14px;gap:8px}.detail-item svg{color:#94a3b8;flex-shrink:0}.job-card-actions{border-top:1px solid #e2e8f0;display:flex;gap:8px;justify-content:flex-end;padding-top:12px}.date-picker{background:#fef9c3;border:2px solid #eab308;border-radius:12px;padding:20px}.date-picker input[type=date]{border:2px solid #e2e8f0;border-radius:8px;font-size:15px;padding:12px;width:100%}.crew-grid,.jobs-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.crew-card{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:12px;display:flex;gap:16px;padding:24px;transition:all .2s}.crew-card:hover{border-color:#eab308;box-shadow:0 4px 12px #eab3081a}.crew-avatar{align-items:center;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:50%;color:#ca8a04;display:flex;flex-shrink:0;font-size:24px;font-weight:700;height:60px;justify-content:center;width:60px}.crew-info{flex:1 1}.crew-info h4{color:#1e293b;font-size:16px;font-weight:700;margin:0 0 6px}.crew-role{color:#eab308;font-size:14px;font-weight:600;margin:0 0 4px}.crew-email,.crew-phone{color:#64748b;font-size:13px;margin:2px 0}.crew-rate{color:#10b981;font-size:15px;font-weight:700;margin:8px 0 0}.modal-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:800px;overflow-y:auto;width:100%}.modal-content.modal-small{max-width:500px}.modal-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;padding:24px 32px}.modal-header h2{color:#1a3d5c;font-size:24px;font-weight:700;margin:0}.btn-close{background:#0000;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;padding:8px;transition:all .2s}.btn-close:hover{background:#f1f5f9;color:#475569}.modal-body{padding:32px}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}.form-group{display:flex;flex-direction:column;gap:8px}.form-group.full-width{grid-column:1/-1}.form-group label{color:#475569;font-size:14px;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:2px solid #e2e8f0;border-radius:8px;font-size:15px;padding:12px 16px;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#eab308;box-shadow:0 0 0 3px #eab3081a;outline:none}.form-group textarea{font-family:inherit;resize:vertical}.modal-footer{border-top:2px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:24px 32px}@media (max-width:768px){.scheduler-header{flex-direction:column;padding:24px;text-align:center}.scheduler-header h1{font-size:24px}.scheduler-tabs{overflow-x:auto}.scheduler-tabs button{font-size:14px;padding:12px 16px}.calendar-header,.view-header{align-items:flex-start;flex-direction:column;gap:16px}.btn-primary,.btn-secondary{width:100%}.crew-grid,.form-grid,.jobs-grid{grid-template-columns:1fr}.crew-card{flex-direction:column;text-align:center}.modal-content{border-radius:0;max-height:100vh}}.blog-page{background:#0f172a;flex:1 1;min-height:100vh;width:100%}.blog-hero{background:#1e293b;border-bottom:1px solid #334155;padding:48px 20px 40px;text-align:center}.blog-hero-inner{margin:0 auto;max-width:700px}.blog-hero h1{color:#f1f5f9;font-size:32px;font-weight:800;letter-spacing:-.5px;margin:0 0 10px}.blog-hero p{color:#64748b;font-size:16px;margin:0 0 24px}.blog-search{align-items:center;background:#0f172a;border:1px solid #334155;border-radius:10px;color:#64748b;display:flex;gap:10px;margin:0 auto;max-width:420px;padding:10px 16px;transition:border-color .2s}.blog-search:focus-within{border-color:#3b82f6}.blog-search input{background:#0000;border:none;color:#e2e8f0;flex:1 1;font-size:15px;outline:none}.blog-search input::placeholder{color:#475569}.blog-container{margin:0 auto;max-width:1100px;padding:28px 20px 60px}.blog-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}.filter-chip{background:#0000;border:1px solid #334155;border-radius:8px;color:#94a3b8;cursor:pointer;font-size:13px;font-weight:600;padding:7px 16px;transition:all .2s}.filter-chip:hover{border-color:#3b82f6;color:#e2e8f0}.filter-chip.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.blog-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.blog-card{background:#1e293b;border:1px solid #334155;border-radius:14px;display:flex;flex-direction:column;overflow:hidden;text-decoration:none;transition:all .25s ease}.blog-card:hover{border-color:#3b82f6;box-shadow:0 8px 32px #3b82f61f;transform:translateY(-4px)}.blog-card-accent{height:4px;width:100%}.blog-card-body{display:flex;flex:1 1;flex-direction:column;padding:22px 24px 20px}.blog-card-cat{font-size:12px;font-weight:700;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.blog-card-body h2{color:#f1f5f9;font-size:18px;font-weight:700;line-height:1.35;margin:0 0 10px}.blog-card-body>p{color:#94a3b8;flex:1 1;font-size:14px;line-height:1.6;margin:0 0 16px}.blog-card-footer{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:14px}.blog-card-date,.blog-card-tags{align-items:center;color:#64748b;display:flex;font-size:12px;gap:5px}.blog-card-read{align-items:center;color:#3b82f6;display:flex;font-size:14px;font-weight:600;gap:6px;margin-top:auto}.blog-card:hover .blog-card-read{color:#60a5fa}.blog-loading{display:flex;justify-content:center;padding:80px 0}.blog-loading .spinner{animation:spin .8s linear infinite;border:3px solid #334155;border-radius:50%;border-top-color:#3b82f6;height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.blog-empty{color:#64748b;font-size:16px;padding:60px 20px;text-align:center}.article-header{background:linear-gradient(135deg,#1e3a5f,#1e293b);border-bottom:1px solid #334155;padding:40px 20px}.article-header-inner{margin:0 auto;max-width:800px}.article-back{align-items:center;color:#60a5fa;display:inline-flex;font-size:14px;font-weight:600;gap:6px;margin-bottom:16px;text-decoration:none}.article-back:hover{color:#93c5fd}.article-cat{background:#3b82f626;border-radius:6px;color:#60a5fa;display:inline-block;font-size:12px;font-weight:700;letter-spacing:.4px;margin-bottom:14px;padding:4px 12px;text-transform:uppercase}.article-header h1{color:#f1f5f9;font-size:32px;font-weight:800;letter-spacing:-.5px;line-height:1.25;margin:0 0 16px}.article-meta{color:#94a3b8;display:flex;flex-wrap:wrap;font-size:14px;gap:20px}.article-meta span{align-items:center;display:flex;gap:6px}.article-container{grid-gap:36px;align-items:start;display:grid;gap:36px;grid-template-columns:1fr 280px;margin:0 auto;max-width:1100px;padding:36px 20px 60px}.article-content{background:#1e293b;border:1px solid #334155;border-radius:14px;padding:36px 40px}.article-content h1{color:#f1f5f9;font-size:28px;font-weight:800;margin:36px 0 16px}.article-content h2{color:#e2e8f0;font-size:22px;font-weight:700;margin:32px 0 14px}.article-content h3{color:#cbd5e1;font-size:18px;font-weight:700;margin:28px 0 12px}.article-content p{color:#94a3b8;font-size:15px;line-height:1.75;margin:0 0 6px}.article-content li{color:#94a3b8;font-size:15px;line-height:1.7;list-style:disc;margin:4px 0 4px 20px;padding-left:4px}.article-content li strong{color:#e2e8f0}.article-content a{color:#60a5fa;text-decoration:underline;text-underline-offset:2px}.article-content a:hover{color:#93c5fd}.article-content strong{color:#e2e8f0}.article-note{background:#3b82f60f;border-left:3px solid #3b82f6;border-radius:4px;font-style:italic;padding:10px 16px}.article-table-wrap{border:1px solid #334155;border-radius:10px;margin:16px 0;overflow-x:auto}.article-table{border-collapse:collapse;font-size:14px;width:100%}.article-table th{background:#0f172a;border-bottom:1px solid #334155;font-size:12px;font-weight:700;letter-spacing:.3px;text-align:left;text-transform:uppercase}.article-table td,.article-table th{color:#94a3b8;padding:10px 14px;white-space:nowrap}.article-table td{border-bottom:1px solid #33415566}.article-table tr:hover td{background:#3b82f608}.article-sidebar{display:flex;flex-direction:column;gap:20px;position:-webkit-sticky;position:sticky;top:24px}.sidebar-card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:20px}.sidebar-card h4{align-items:center;color:#e2e8f0;display:flex;font-size:15px;font-weight:700;gap:8px;margin:0 0 14px}.sidebar-tags{display:flex;flex-wrap:wrap;gap:6px}.sidebar-tag{background:#0f172a;border:1px solid #334155;border-radius:6px;color:#94a3b8;font-size:12px;padding:4px 10px}.sidebar-cta{background:linear-gradient(135deg,#1e3a5f,#1e293b)}.sidebar-cta-btn{background:#3b82f6;border-radius:8px;color:#fff;display:block;font-size:14px;font-weight:600;margin-bottom:8px;padding:10px 16px;text-align:center;text-decoration:none;transition:all .2s}.sidebar-cta-btn:hover{background:#2563eb;transform:translateY(-1px)}.sidebar-cta-btn.sidebar-cta-secondary{background:#0000;border:1px solid #334155;color:#94a3b8}.sidebar-cta-btn.sidebar-cta-secondary:hover{border-color:#3b82f6;color:#e2e8f0}.admin-editor{background:#1e293b;border:1px solid #334155;border-radius:14px;margin-bottom:36px;padding:28px}.admin-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:16px}.admin-field{display:flex;flex-direction:column;margin-bottom:16px}.admin-field-wide{grid-column:span 2}.admin-field label{color:#64748b;font-size:12px;font-weight:700;letter-spacing:.4px;margin-bottom:6px;text-transform:uppercase}.admin-field input,.admin-field select,.admin-field textarea{background:#0f172a;border:1px solid #334155;border-radius:8px;color:#e2e8f0;font-family:inherit;font-size:14px;padding:10px 14px;transition:border-color .2s}.admin-field input:focus,.admin-field select:focus,.admin-field textarea:focus{border-color:#3b82f6;outline:none}.admin-field textarea{line-height:1.6;min-height:120px;resize:vertical}.admin-actions{border-top:1px solid #334155;gap:12px;padding-top:16px}.admin-actions,.admin-toggle{align-items:center;display:flex}.admin-toggle{color:#94a3b8;cursor:pointer;font-size:14px;font-weight:600;gap:8px;margin-right:auto}.admin-toggle input{accent-color:#3b82f6;height:18px;width:18px}.admin-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;padding:10px 20px;transition:all .2s}.admin-btn-primary{background:#3b82f6;color:#fff}.admin-btn-primary:hover{background:#2563eb}.admin-btn-ghost{background:#0000;border:1px solid #334155;color:#94a3b8}.admin-section-title{color:#e2e8f0;font-size:18px;font-weight:700;margin-bottom:16px}.admin-posts-list{display:flex;flex-direction:column;gap:8px}.admin-post-row{align-items:center;background:#1e293b;border:1px solid #334155;border-radius:10px;display:flex;gap:16px;justify-content:space-between;padding:14px 18px}.admin-post-info h3{color:#e2e8f0;font-size:15px;font-weight:600;margin:0 0 4px}.admin-post-meta{color:#64748b;display:flex;font-size:12px;gap:12px}.admin-post-cat{color:#3b82f6;font-weight:600}.admin-post-actions{display:flex;gap:6px}.admin-btn-sm{align-items:center;background:#0000;border:1px solid #334155;border-radius:6px;color:#94a3b8;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .15s;width:32px}.admin-btn-sm:hover{background:#3b82f61a;border-color:#3b82f6;color:#60a5fa}.admin-btn-sm-danger:hover{background:#ef44441a;border-color:#ef4444;color:#ef4444}@media (max-width:860px){.article-container{grid-template-columns:1fr}.article-sidebar{flex-direction:row;flex-wrap:wrap;gap:12px;position:static}.sidebar-card{flex:1 1;min-width:220px}.article-content{padding:24px 20px}.blog-grid{grid-template-columns:1fr}.admin-field-wide{grid-column:span 1}}@media (max-width:480px){.blog-page{overflow-x:hidden}.article-header{padding:28px 16px}.article-header h1{font-size:24px}.article-meta{font-size:12px;gap:10px}.article-container{padding:20px 16px 40px}.article-content{overflow-wrap:break-word;overflow-x:hidden;padding:20px 16px;word-break:break-word}.article-content h1{font-size:22px}.article-content h2{font-size:18px}.article-content h3{font-size:16px}.article-content li,.article-content p{font-size:14px}.article-table-wrap{border-left:none;border-radius:0;border-right:none;margin-left:-16px;margin-right:-16px}.article-table th{font-size:10px;padding:8px 10px}.article-table td{font-size:12px;padding:8px 10px}.sidebar-card{min-width:0;min-width:auto}.blog-hero h1{font-size:24px}.blog-hero p{font-size:14px}.admin-editor{padding:16px}.admin-post-row{align-items:flex-start;flex-direction:column;gap:10px}.admin-actions{flex-wrap:wrap}}.satellite-estimator{background:#0a0e17;color:#e2e8f0;min-height:100vh}.sat-header{background:linear-gradient(180deg,#0f1423f2,#0a0e17fa);border-bottom:1px solid #8b5cf626;padding:28px 32px 20px}.sat-header h1{color:#f1f5f9;font-size:28px;font-weight:700;letter-spacing:-.5px;margin:0 0 4px}.sat-header p{color:#94a3b8;font-size:14px;margin:0}.sat-content{margin:0 auto;max-width:1400px;padding:24px 28px}.sat-steps{display:flex;gap:8px;margin-bottom:24px}.sat-step{align-items:center;background:#1e293b80;border:1px solid #3341554d;border-radius:10px;color:#64748b;display:flex;font-size:13px;font-weight:600;gap:8px;padding:10px 18px;transition:all .3s ease}.sat-step.active{background:#8b5cf61f;border-color:#8b5cf666;color:#c4b5fd}.sat-step.completed{background:#22c55e1a;border-color:#22c55e4d;color:#86efac}.sat-step-num{align-items:center;background:#33415580;border-radius:50%;color:#94a3b8;display:flex;font-size:12px;font-weight:700;height:24px;justify-content:center;width:24px}.sat-step.active .sat-step-num{background:#8b5cf64d;color:#e9d5ff}.sat-step.completed .sat-step-num{background:#22c55e4d;color:#86efac}.sat-search-section{margin-bottom:24px}.sat-search-card{background:#0f172a99;border:1px solid #33415566;border-radius:14px;padding:24px}.sat-search-card h2{color:#e2e8f0;font-size:17px;font-weight:600;margin:0 0 16px}.sat-search-input-wrap{position:relative}.sat-search-input-wrap input{background:#1e293bcc;border:1px solid #47556966;border-radius:10px;box-sizing:border-box;color:#f1f5f9;font-size:15px;outline:none;padding:14px 18px 14px 44px;transition:border-color .2s;width:100%}.sat-search-input-wrap input:focus{border-color:#8b5cf699}.sat-search-input-wrap input::placeholder{color:#64748b}.sat-search-icon{color:#64748b;font-size:18px;left:14px;position:absolute;top:50%;transform:translateY(-50%)}.sat-address-info{align-items:center;background:#22c55e14;border:1px solid #22c55e33;border-radius:8px;color:#86efac;display:flex;font-size:13px;gap:10px;margin-top:12px;padding:10px 14px}.sat-map-section{margin-bottom:24px}.sat-map-card{background:#0f172a99;border:1px solid #33415566;border-radius:14px;overflow:hidden}.sat-map-toolbar{align-items:center;border-bottom:1px solid #3341554d;display:flex;justify-content:space-between;padding:14px 20px}.sat-map-toolbar h3{color:#e2e8f0;font-size:15px;font-weight:600;margin:0}.sat-map-actions{display:flex;gap:8px}.sat-map-container{height:500px;position:relative;width:100%}.sat-map-container .gm-style{border-radius:0 0 14px 14px}.sat-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s}.sat-btn-primary{background:linear-gradient(135deg,#7c3aed,#6d28d9);color:#fff}.sat-btn-primary:hover{background:linear-gradient(135deg,#8b5cf6,#7c3aed);transform:translateY(-1px)}.sat-btn-primary:disabled{cursor:not-allowed;opacity:.4;transform:none}.sat-btn-secondary{background:#1e293bcc;border:1px solid #47556966;color:#cbd5e1}.sat-btn-secondary:hover{border-color:#8b5cf666;color:#e2e8f0}.sat-btn-success{background:linear-gradient(135deg,#059669,#047857);color:#fff}.sat-btn-success:hover{background:linear-gradient(135deg,#10b981,#059669)}.sat-analysis-section{margin-bottom:24px}.sat-analysis-card{background:#0f172a99;border:1px solid #33415566;border-radius:14px;padding:24px}.sat-analysis-card h2{color:#e2e8f0;font-size:17px;font-weight:600;margin:0 0 16px}.sat-analyzing{align-items:center;display:flex;flex-direction:column;gap:16px;padding:40px 0}.sat-spinner{animation:sat-spin .8s linear infinite;border:3px solid #8b5cf633;border-radius:50%;border-top-color:#8b5cf6;height:48px;width:48px}@keyframes sat-spin{to{transform:rotate(1turn)}}.sat-analyzing p{color:#94a3b8;font-size:15px;text-align:center}.sat-results-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.sat-result-card{background:#1e293b66;border:1px solid #3341554d;border-radius:12px;padding:20px}.sat-result-card h3{color:#94a3b8;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.sat-result-value{color:#f1f5f9;font-size:28px;font-weight:700;line-height:1.2}.sat-result-unit{color:#64748b;font-size:14px;font-weight:400}.sat-roof-details{margin-top:20px}.sat-detail-row{border-bottom:1px solid #33415533;display:flex;font-size:14px;justify-content:space-between;padding:10px 0}.sat-detail-label{color:#94a3b8}.sat-detail-value{color:#e2e8f0;font-weight:600}.sat-canvas-overlay{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:5}.sat-canvas-overlay.drawing{cursor:crosshair;pointer-events:auto}.sat-faces-list{display:flex;flex-direction:column;gap:8px;margin-top:12px}.sat-face-item{background:#1e293b80;border:1px solid #3341554d;border-radius:8px;font-size:13px;justify-content:space-between;padding:10px 14px}.sat-face-item,.sat-face-name{align-items:center;display:flex}.sat-face-name{color:#e2e8f0;gap:8px}.sat-face-color{border-radius:3px;height:12px;width:12px}.sat-face-area{color:#94a3b8;font-weight:600}.sat-error{background:#ef444414;border:1px solid #ef444433;border-radius:10px;color:#fca5a5;font-size:14px;margin-top:12px;padding:14px 18px}.pac-container{background:#1e293b!important;border:1px solid #47556980!important;border-radius:0 0 10px 10px!important;box-shadow:0 8px 32px #0006!important;font-family:inherit!important;z-index:10000!important}.pac-item{border-top:1px solid #3341554d!important;color:#e2e8f0!important;cursor:pointer!important;font-size:14px!important;line-height:1.4!important;padding:10px 16px!important}.pac-item-selected,.pac-item:hover{background:#8b5cf61f!important}.pac-item-query{color:#f1f5f9!important;font-size:14px!important}.pac-matched{color:#c4b5fd!important;font-weight:600!important}.pac-icon{display:none!important}.pac-item span:last-child{color:#94a3b8!important;font-size:12px!important}@media (max-width:968px){.sat-results-grid{grid-template-columns:1fr}.sat-steps{flex-wrap:wrap}.sat-map-container{height:400px}}@media (max-width:480px){.satellite-estimator{overflow-x:hidden}.sat-header{padding:20px 16px 16px}.sat-header h1{font-size:22px}.sat-content{padding:16px 14px}.sat-analysis-card,.sat-search-card{padding:18px 14px}.sat-map-container{height:350px}.sat-map-toolbar{align-items:flex-start;flex-direction:column;gap:10px}.sat-map-actions{width:100%}.sat-map-actions .sat-btn{flex:1 1;justify-content:center}.sat-steps{gap:6px}.sat-step{font-size:11px;padding:8px 12px}}
/*# sourceMappingURL=main.d8f3691d.css.map*/