@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../fonts/inter-400.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../fonts/inter-500.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../fonts/inter-600.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../fonts/inter-700.woff2) format("woff2")}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:400;font-display:swap;src:url(../fonts/space-grotesk-400.woff2) format("woff2")}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(../fonts/space-grotesk-500.woff2) format("woff2")}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:600;font-display:swap;src:url(../fonts/space-grotesk-600.woff2) format("woff2")}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:700;font-display:swap;src:url(../fonts/space-grotesk-700.woff2) format("woff2")}@font-face{font-family:Russo One;font-style:normal;font-weight:400;font-display:swap;src:url(../fonts/russo-one-400.woff2) format("woff2")}@font-face{font-family:Anton;font-style:normal;font-weight:400;font-display:swap;src:url(../fonts/anton-400.woff2) format("woff2")}*,: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:rgba(59,130,246,.5);--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:rgba(59,130,246,.5);--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.17 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color: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:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-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::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media (min-width:640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width:768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width:1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width:1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width:1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-x-0{left:0;right:0}.bottom-0{bottom:0}.left-0{left:0}.left-\[12\.5\%\]{left:12.5%}.right-0{right:0}.right-\[12\.5\%\]{right:12.5%}.top-0{top:0}.top-8{top:2rem}.z-10{z-index:10}.z-40{z-index:40}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-auto{margin-left:auto;margin-right:auto}.mb-1\.5{margin-bottom:.375rem}.mb-10{margin-bottom:2.5rem}.mb-12{margin-bottom:3rem}.mb-16{margin-bottom:4rem}.mb-2{margin-bottom:.5rem}.mb-20{margin-bottom:5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-10{margin-top:2.5rem}.mt-12{margin-top:3rem}.mt-14{margin-top:3.5rem}.mt-2{margin-top:.5rem}.mt-2\.5{margin-top:.625rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-7{margin-top:1.75rem}.mt-auto{margin-top:auto}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.aspect-\[4\/3\]{aspect-ratio:4/3}.h-1{height:.25rem}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-20{height:5rem}.h-9{height:2.25rem}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.min-h-screen{min-height:100vh}.w-1{width:.25rem}.w-1\.5{width:.375rem}.w-12{width:3rem}.w-20{width:5rem}.w-9{width:2.25rem}.w-auto{width:auto}.w-full{width:100%}.min-w-0{min-width:0}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-7xl{max-width:80rem}.max-w-\[420px\]{max-width:420px}.max-w-md{max-width:28rem}.max-w-sm{max-width:24rem}.max-w-xl{max-width:36rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}@keyframes ping{75%,to{transform:scale(2);opacity:0}}.animate-ping{animation:ping 1s cubic-bezier(0,0,.2,1) infinite}.resize{resize:both}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-10{gap:2.5rem}.gap-12{gap:3rem}.gap-16{gap:4rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-px{gap:1px}.space-y-10>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(2.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2.5rem*var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem*var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem*var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem*var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem*var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(2rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem*var(--tw-space-y-reverse))}.space-y-px>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1px*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1px*var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.whitespace-nowrap{white-space:nowrap}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-l-2{border-left-width:2px}.border-t{border-top-width:1px}.border-green-700{--tw-border-opacity:1;border-color:rgb(21 128 61/var(--tw-border-opacity,1))}.border-red-600{--tw-border-opacity:1;border-color:rgb(220 38 38/var(--tw-border-opacity,1))}.border-red-700{--tw-border-opacity:1;border-color:rgb(185 28 28/var(--tw-border-opacity,1))}.border-transparent{border-color:transparent}.border-zinc-700{--tw-border-opacity:1;border-color:rgb(63 63 70/var(--tw-border-opacity,1))}.border-zinc-800{--tw-border-opacity:1;border-color:rgb(39 39 42/var(--tw-border-opacity,1))}.border-zinc-900{--tw-border-opacity:1;border-color:rgb(24 24 27/var(--tw-border-opacity,1))}.bg-black\/40{background-color:rgba(0,0,0,.4)}.bg-green-950\/40{background-color:rgba(5,46,22,.4)}.bg-red-600{--tw-bg-opacity:1;background-color:rgb(220 38 38/var(--tw-bg-opacity,1))}.bg-red-950\/40{background-color:rgba(69,10,10,.4)}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-zinc-900{--tw-bg-opacity:1;background-color:rgb(24 24 27/var(--tw-bg-opacity,1))}.bg-zinc-950{--tw-bg-opacity:1;background-color:rgb(9 9 11/var(--tw-bg-opacity,1))}.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-transparent{--tw-gradient-from:transparent var(--tw-gradient-from-position);--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-zinc-800{--tw-gradient-to:rgba(39,39,42,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#27272a var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-zinc-950{--tw-gradient-to:rgba(9,9,11,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#09090b var(--tw-gradient-via-position),var(--tw-gradient-to)}.to-transparent{--tw-gradient-to:transparent var(--tw-gradient-to-position)}.object-cover{-o-object-fit:cover;object-fit:cover}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-8{padding:2rem}.\!px-4{padding-left:1rem!important;padding-right:1rem!important}.\!px-5{padding-left:1.25rem!important;padding-right:1.25rem!important}.\!py-2{padding-top:.5rem!important;padding-bottom:.5rem!important}.\!py-2\.5{padding-top:.625rem!important;padding-bottom:.625rem!important}.\!py-3{padding-top:.75rem!important;padding-bottom:.75rem!important}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-32{padding-top:8rem;padding-bottom:8rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pb-10{padding-bottom:2.5rem}.pb-12{padding-bottom:3rem}.pb-16{padding-bottom:4rem}.pb-24{padding-bottom:6rem}.pb-32{padding-bottom:8rem}.pb-8{padding-bottom:2rem}.pl-6{padding-left:1.5rem}.pl-8{padding-left:2rem}.pt-10{padding-top:2.5rem}.pt-2{padding-top:.5rem}.pt-20{padding-top:5rem}.pt-32{padding-top:8rem}.pt-6{padding-top:1.5rem}.pt-8{padding-top:2rem}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.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-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.leading-\[0\.9\]{line-height:.9}.leading-\[1\.05\]{line-height:1.05}.leading-\[1\.8\]{line-height:1.8}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-snug{line-height:1.375}.leading-tight{line-height:1.25}.tracking-\[0\.08em\]{letter-spacing:.08em}.tracking-\[0\.18em\]{letter-spacing:.18em}.tracking-\[0\.25em\]{letter-spacing:.25em}.tracking-\[0\.2em\]{letter-spacing:.2em}.tracking-wider{letter-spacing:.05em}.text-green-300{--tw-text-opacity:1;color:rgb(134 239 172/var(--tw-text-opacity,1))}.text-red-300{--tw-text-opacity:1;color:rgb(252 165 165/var(--tw-text-opacity,1))}.text-red-600{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-zinc-200{--tw-text-opacity:1;color:rgb(228 228 231/var(--tw-text-opacity,1))}.text-zinc-300{--tw-text-opacity:1;color:rgb(212 212 216/var(--tw-text-opacity,1))}.text-zinc-400{--tw-text-opacity:1;color:rgb(161 161 170/var(--tw-text-opacity,1))}.text-zinc-500{--tw-text-opacity:1;color:rgb(113 113 122/var(--tw-text-opacity,1))}.text-zinc-600{--tw-text-opacity:1;color:rgb(82 82 91/var(--tw-text-opacity,1))}.opacity-60{opacity:.6}.ring{--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(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.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)}.backdrop-blur-sm{--tw-backdrop-blur:blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-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-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.hover\:gap-3:hover{gap:.75rem}.hover\:border-red-600:hover{--tw-border-opacity:1;border-color:rgb(220 38 38/var(--tw-border-opacity,1))}.hover\:bg-red-500:hover{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.hover\:text-red-600:hover{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity,1))}.hover\:underline:hover{text-decoration-line:underline}.hover\:brightness-110:hover{--tw-brightness:brightness(1.1);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)}@media (min-width:640px){.sm\:max-w-\[500px\]{max-width:500px}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:768px){.md\:inline-flex{display:inline-flex}.md\:h-14{height:3.5rem}.md\:h-20{height:5rem}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:1024px){.lg\:order-2{order:2}.lg\:col-span-1{grid-column:span 1/span 1}.lg\:col-span-2{grid-column:span 2/span 2}.lg\:col-span-3{grid-column:span 3/span 3}.lg\:col-span-5{grid-column:span 5/span 5}.lg\:col-span-6{grid-column:span 6/span 6}.lg\:col-span-7{grid-column:span 7/span 7}.lg\:col-span-8{grid-column:span 8/span 8}.lg\:col-span-9{grid-column:span 9/span 9}.lg\:ml-6{margin-left:1.5rem}.lg\:block{display:block}.lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:h-16{height:4rem}.lg\:max-w-\[560px\]{max-width:560px}.lg\:flex-1{flex:1 1 0%}.lg\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:flex-col{flex-direction:column}.lg\:p-12{padding:3rem}.lg\:px-10{padding-left:2.5rem;padding-right:2.5rem}.lg\:text-2xl{font-size:1.5rem;line-height:2rem}.lg\:text-3xl{font-size:1.875rem;line-height:2.25rem}.lg\:text-4xl{font-size:2.25rem;line-height:2.5rem}.lg\:text-5xl{font-size:3rem;line-height:1}.lg\:text-6xl{font-size:3.75rem;line-height:1}}@media (min-width:1280px){.xl\:flex{display:flex}.xl\:gap-4{gap:1rem}.xl\:gap-8{gap:2rem}}:root {
  --bg: #08080a;
  --surface: #111114;
  --surface-2: #1a1a1f;
  --border: #27272a;
  --text: #fafafa;
  --text-dim: #a1a1aa;
  --text-muted: #71717a;
  --accent: #dc2626;
  --accent-2: #ef4444;
  --accent-glow: rgba(220, 38, 38, 0.35);
}

* { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Inter', system-ui, sans-serif;
  overflow-x: hidden;
}

.font-display {
  font-family: 'Russo One', 'Impact', sans-serif;
  letter-spacing: 0.005em;
}

.font-head {
  font-family: 'Space Grotesk', 'Inter', sans-serif;
  letter-spacing: -0.02em;
}

/* Noise texture overlay for industrial feel */
.noise::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.07;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}

/* Hero gradient mesh */
.hero-bg {
  background:
    radial-gradient(ellipse at 20% 0%, rgba(220, 38, 38, 0.15), transparent 50%),
    radial-gradient(ellipse at 80% 100%, rgba(220, 38, 38, 0.08), transparent 50%),
    linear-gradient(180deg, #050506 0%, #0a0a0d 100%);
}

.hero-image {
  background-image:
    linear-gradient(90deg, rgba(5,5,7,0.96) 0%, rgba(5,5,7,0.85) 35%, rgba(5,5,7,0.45) 70%, rgba(5,5,7,0.25) 100%),
    linear-gradient(180deg, rgba(5,5,7,0.4) 0%, rgba(5,5,7,0.7) 70%, rgba(5,5,7,1) 100%),
    url('../img/hero-soodaprits.webp');
  background-size: cover;
  background-position: center right;
}

/* WhatsApp CTA glow */
@keyframes wa-glow-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.45); }
  50% { box-shadow: 0 0 18px 4px rgba(37, 211, 102, 0.55); }
}
.wa-glow { animation: wa-glow-pulse 2.2s ease-in-out infinite; }
.wa-glow:hover { animation: none; box-shadow: 0 0 22px 5px rgba(37, 211, 102, 0.6); }

/* Sparks animation */
@keyframes spark-float {
  0% { transform: translate(0, 0) scale(1); opacity: 0; }
  10% { opacity: 1; }
  100% { transform: translate(var(--dx), var(--dy)) scale(0.3); opacity: 0; }
}

.spark {
  position: absolute;
  width: 3px; height: 3px;
  background: var(--accent);
  border-radius: 50%;
  box-shadow: 0 0 8px var(--accent), 0 0 16px var(--accent-glow);
  animation: spark-float 3.5s ease-out infinite;
}

/* Header */
.site-header {
  transition: background 0.3s ease, backdrop-filter 0.3s ease, border-color 0.3s ease;
}
.site-header.scrolled {
  background: rgba(8, 8, 10, 0.78);
  backdrop-filter: blur(12px);
  border-bottom-color: var(--border);
}

/* Nav link underline */
.nav-link {
  position: relative;
  color: var(--text-dim);
  transition: color 0.2s ease;
}
.nav-link:hover, .nav-link.active { color: var(--text); }
.nav-link::after {
  content: '';
  position: absolute;
  left: 0; right: 100%;
  bottom: -6px;
  height: 1px;
  background: var(--accent);
  transition: right 0.3s ease;
}
.nav-link:hover::after, .nav-link.active::after { right: 0; }

/* Services dropdown (desktop) */
.nav-dropdown { position: relative; }
.nav-dd-trigger { display: inline-flex; align-items: center; gap: 5px; }
.dd-caret { opacity: 0.65; transition: transform 0.25s ease; }
.nav-dropdown:hover .dd-caret, .nav-dropdown:focus-within .dd-caret { transform: rotate(180deg); }
.dropdown-menu {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(10px);
  min-width: 230px;
  background: rgba(12, 12, 14, 0.96);
  backdrop-filter: blur(14px);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.5);
  transition: opacity 0.2s ease, transform 0.28s cubic-bezier(0.16, 1, 0.3, 1);
  z-index: 60;
}
/* invisible bridge so the menu doesn't drop while moving the cursor down */
.dropdown-menu::before {
  content: '';
  position: absolute;
  top: -12px; left: 0; right: 0; height: 12px;
}
.nav-dropdown:hover .dropdown-menu,
.nav-dropdown:focus-within .dropdown-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(4px);
}
.dropdown-item {
  display: block;
  padding: 9px 14px;
  font-size: 13px;
  color: var(--text-dim);
  border-radius: 4px;
  white-space: nowrap;
  transition: background 0.15s ease, color 0.15s ease;
}
.dropdown-item:hover { background: rgba(220, 38, 38, 0.12); color: var(--text); }

/* Mobile services sublist */
.mobile-subnav {
  display: none;
  flex-direction: column;
  gap: 12px;
  padding-left: 16px;
  margin-top: -8px;
  font-size: 1rem;
  overflow: hidden;
}
.mobile-subnav.open { display: flex; }
.mobile-subnav a { color: var(--text-dim); }
.mobile-subnav a:hover { color: var(--accent); }
/* Teenused toggle button */
.mobile-subnav-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  background: none;
  border: none;
  padding: 0;
  color: inherit;
  font: inherit;
  cursor: pointer;
  text-align: left;
}
.mobile-subnav-toggle .caret {
  transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
.mobile-subnav-toggle[aria-expanded="true"] .caret { transform: rotate(180deg); }

/* Buttons */
.btn-primary {
  background: var(--accent);
  color: #0a0a0b;
  font-weight: 600;
  padding: 14px 28px;
  border-radius: 2px;
  transition: all 0.2s ease;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  position: relative;
  overflow: hidden;
  font-family: 'Space Grotesk', sans-serif;
  letter-spacing: 0.02em;
}
.btn-primary:hover {
  background: var(--accent-2);
  transform: translateY(-1px);
  box-shadow: 0 10px 30px -10px var(--accent-glow);
}
.btn-primary::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.3), transparent 70%);
  transform: translateX(-100%);
  transition: transform 0.6s ease;
}
.btn-primary:hover::before { transform: translateX(100%); }

.btn-ghost {
  border: 1px solid var(--border);
  color: var(--text);
  font-weight: 500;
  padding: 13px 26px;
  border-radius: 2px;
  transition: all 0.2s ease;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Space Grotesk', sans-serif;
  letter-spacing: 0.02em;
}
.btn-ghost:hover {
  border-color: var(--accent);
  color: var(--accent);
}

/* Service card */
.service-card {
  background: var(--surface);
  border: 1px solid var(--border);
  padding: 32px;
  position: relative;
  overflow: hidden;
  transition: all 0.3s ease;
  cursor: pointer;
}
.service-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 0; height: 2px;
  background: var(--accent);
  transition: width 0.4s ease;
}
.service-card:hover {
  border-color: var(--surface-2);
  background: var(--surface-2);
  transform: translateY(-4px);
}
.service-card:hover::before { width: 100%; }
.service-card .icon {
  color: var(--accent);
  margin-bottom: 24px;
  transition: transform 0.3s ease;
}
.service-card:hover .icon { transform: scale(1.1) rotate(-5deg); }

/* Stat numbers */
.stat-number {
  font-family: 'Russo One', sans-serif;
  font-size: clamp(48px, 6vw, 84px);
  line-height: 1;
  background: linear-gradient(180deg, #fff 0%, #71717a 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Reveal on scroll */
.reveal { opacity: 0; transform: translateY(30px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* Before/after slider */
.ba-slider {
  position: relative;
  overflow: hidden;
  user-select: none;
  border: 1px solid var(--border);
  background: var(--surface);
}
.ba-slider img { display: block; width: 100%; height: 100%; object-fit: cover; }
.ba-slider .after-wrap {
  position: absolute;
  inset: 0;
  width: 50%;
  overflow: hidden;
}
.ba-slider .after-wrap img {
  width: 200%;
  max-width: none;
}
.ba-slider .handle {
  position: absolute;
  top: 0; bottom: 0;
  left: 50%;
  width: 2px;
  background: var(--accent);
  transform: translateX(-50%);
  cursor: ew-resize;
  z-index: 2;
}
.ba-slider .handle::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--accent);
  box-shadow: 0 0 20px var(--accent-glow);
}
.ba-slider .handle-knob {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--accent);
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 24px var(--accent-glow);
}
.ba-slider .label {
  position: absolute;
  top: 16px;
  padding: 6px 12px;
  background: rgba(0,0,0,0.7);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  z-index: 1;
}
.ba-slider .label.before { left: 16px; }
.ba-slider .label.after { right: 16px; }

/* Gallery card */
.gallery-card {
  position: relative;
  overflow: hidden;
  background: var(--surface);
  border: 1px solid var(--border);
  aspect-ratio: 4/3;
}
.gallery-card img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.7s ease;
}
.gallery-card:hover img { transform: scale(1.05); }
.gallery-card .overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,0.9));
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 24px;
}
.gallery-card .tag {
  display: inline-block;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 8px;
}

/* Process step */
.step-num {
  font-family: 'Russo One', sans-serif;
  font-size: 56px;
  line-height: 1;
  color: var(--accent);
  opacity: 0.4;
}

/* Section heading eyebrow */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: var(--accent);
  font-family: 'Space Grotesk', sans-serif;
  font-size: 12px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
}
.eyebrow::before {
  content: '';
  display: inline-block;
  width: 32px; height: 1px;
  background: var(--accent);
}

/* Mobile menu */
.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--bg);
  z-index: 50;
  display: flex;
  flex-direction: column;
  padding: 24px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  transform: translateX(100%);
  opacity: 0;
  visibility: hidden;
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.4s ease, visibility 0.5s;
}
.mobile-menu.open { transform: translateX(0); opacity: 1; visibility: visible; }
/* subtle red sheen sweeping in behind the panel */
.mobile-menu::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 80% 0%, rgba(220,38,38,0.14), transparent 55%);
  pointer-events: none;
}
/* staggered nav link entrance */
.mobile-menu nav a {
  opacity: 0;
  transform: translateX(40px);
  transition: opacity 0.4s ease, transform 0.55s cubic-bezier(0.16, 1, 0.3, 1);
}
.mobile-menu.open nav a { opacity: 1; transform: translateX(0); }
.mobile-menu.open nav a:nth-child(1) { transition-delay: 0.12s; }
.mobile-menu.open nav a:nth-child(2) { transition-delay: 0.18s; }
.mobile-menu.open nav a:nth-child(3) { transition-delay: 0.24s; }
.mobile-menu.open nav a:nth-child(4) { transition-delay: 0.30s; }
.mobile-menu.open nav a:nth-child(5) { transition-delay: 0.36s; }
.mobile-menu.open nav a:nth-child(6) { transition-delay: 0.42s; }
/* hamburger -> X morph (when menu open) */
.menu-open [data-menu-open] { transform: rotate(90deg); transition: transform 0.4s cubic-bezier(0.16,1,0.3,1); }
[data-menu-open] { transition: transform 0.4s ease; }

/* Form */
.input {
  width: 100%;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 14px 16px;
  font-family: inherit;
  transition: border-color 0.2s ease;
  border-radius: 2px;
}
.input:focus { outline: none; border-color: var(--accent); }
.input::placeholder { color: var(--text-muted); }

textarea.input { resize: vertical; min-height: 140px; }

/* Lang toggle */
.lang-toggle {
  display: flex;
  border: 1px solid var(--border);
  border-radius: 2px;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 12px;
  letter-spacing: 0.1em;
}
.lang-toggle button {
  padding: 8px 13px;
  color: var(--text-dim);
  transition: all 0.2s ease;
}
.lang-toggle button.active {
  background: var(--accent);
  color: #fff;
  font-weight: 600;
}

/* Marquee */
.marquee {
  display: flex;
  gap: 64px;
  animation: marquee 30s linear infinite;
  white-space: nowrap;
}
@keyframes marquee { to { transform: translateX(-50%); } }
.marquee-item {
  font-family: 'Russo One', sans-serif;
  font-size: 48px;
  color: var(--surface-2);
  display: flex;
  align-items: center;
  gap: 64px;
}
.marquee-item::after {
  content: '';
  width: 8px; height: 8px;
  background: var(--accent);
  border-radius: 50%;
}

/* Page hero (interior) */
.page-hero {
  padding: 140px 0 80px;
  position: relative;
}
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(220, 38, 38, 0.12), transparent 60%);
  pointer-events: none;
}

/* ============== LIGHT THEME ============== */
[data-theme="light"] {
  --bg: #f8f8f7;
  --surface: #ffffff;
  --surface-2: #f1f1ef;
  --border: #e4e4e2;
  --text: #18181b;
  --text-dim: #52525b;
  --text-muted: #71717a;
}

[data-theme="light"] body { background: var(--bg); color: var(--text); }

/* Background swaps */
[data-theme="light"] .bg-zinc-950 { background-color: #ffffff !important; }
[data-theme="light"] .bg-zinc-900 { background-color: #f1f1ef !important; }
[data-theme="light"] .bg-black\/40 { background-color: rgba(255,255,255,0.6) !important; }

/* Text swaps */
[data-theme="light"] .text-white { color: #18181b !important; }
[data-theme="light"] .text-zinc-300 { color: #3f3f46 !important; }
[data-theme="light"] .text-zinc-400 { color: #52525b !important; }
[data-theme="light"] .text-zinc-500 { color: #71717a !important; }
[data-theme="light"] .text-zinc-600 { color: #a1a1aa !important; }

/* Border swaps */
[data-theme="light"] .border-zinc-900 { border-color: #e4e4e2 !important; }
[data-theme="light"] .border-zinc-800 { border-color: #e4e4e2 !important; }
[data-theme="light"] .bg-zinc-900.space-y-px,
[data-theme="light"] .space-y-px.bg-zinc-900 { background-color: #e4e4e2 !important; }
[data-theme="light"] .gap-px.bg-zinc-900 { background-color: #e4e4e2 !important; }

/* Hero on light theme */
[data-theme="light"] .hero-image {
  background-image:
    linear-gradient(180deg, rgba(248,248,247,0.55) 0%, rgba(248,248,247,0.85) 60%, rgba(248,248,247,1) 100%),
    url('../img/hero-light.webp');
}
[data-theme="light"] .hero-bg {
  background:
    radial-gradient(ellipse at 20% 0%, rgba(220, 38, 38, 0.12), transparent 50%),
    radial-gradient(ellipse at 80% 100%, rgba(220, 38, 38, 0.06), transparent 50%),
    linear-gradient(180deg, #fafaf9 0%, #ffffff 100%);
}

/* Header */
[data-theme="light"] .site-header.scrolled {
  background: rgba(255, 255, 255, 0.85);
  border-bottom-color: #e4e4e2;
}
[data-theme="light"] .nav-link { color: #52525b; }
[data-theme="light"] .nav-link:hover, [data-theme="light"] .nav-link.active { color: #18181b; }
[data-theme="light"] .dropdown-menu { background: rgba(255, 255, 255, 0.97); border-color: #e4e4e2; box-shadow: 0 24px 60px rgba(0, 0, 0, 0.12); }
[data-theme="light"] .dropdown-item { color: #52525b; }
[data-theme="light"] .dropdown-item:hover { background: rgba(220, 38, 38, 0.10); color: #18181b; }
[data-theme="light"] .mobile-subnav a { color: #71717a; }

/* Lang + theme toggle */
[data-theme="light"] .lang-toggle,
[data-theme="light"] .theme-toggle { border-color: #d4d4d2; }
[data-theme="light"] .lang-toggle button { color: #71717a; }

/* Buttons */
[data-theme="light"] .btn-ghost { color: #18181b; border-color: #d4d4d2; }
[data-theme="light"] .btn-ghost:hover { color: var(--accent); border-color: var(--accent); }

/* Service card */
[data-theme="light"] .service-card { background: #ffffff; border-color: #e4e4e2; color: #18181b; }
[data-theme="light"] .service-card:hover { background: #f8f8f7; border-color: #d4d4d2; }
[data-theme="light"] .service-card .text-zinc-400 { color: #52525b !important; }

/* Stat numbers */
[data-theme="light"] .stat-number {
  background: linear-gradient(180deg, #18181b 0%, #71717a 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Marquee */
[data-theme="light"] .marquee-item { color: #e4e4e2; }

/* Inputs */
[data-theme="light"] .input { background: #ffffff; border-color: #d4d4d2; color: #18181b; }
[data-theme="light"] .input::placeholder { color: #a1a1aa; }

/* Mobile menu */
[data-theme="light"] .mobile-menu { background: #ffffff; color: #18181b; }

/* Before/after slider bg */
[data-theme="light"] .ba-slider { background: #f1f1ef; border-color: #e4e4e2; }
[data-theme="light"] .ba-slider .label { background: rgba(255,255,255,0.85); border-color: #e4e4e2; color: #18181b; }

/* Gallery card */
[data-theme="light"] .gallery-card { background: #f1f1ef; border-color: #e4e4e2; }
[data-theme="light"] .gallery-card .overlay {
  background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,0.75));
}
[data-theme="light"] .gallery-card .overlay h3 { color: #fff; }

/* Hero text in light theme */
[data-theme="light"] .hero h1 .text-zinc-500 { color: #a1a1aa !important; }

/* Eyebrow lines stay orange — no change needed */

/* Headings explicitly set to white via .text-white already handled */

/* Footer */
[data-theme="light"] footer .text-zinc-600 { color: #a1a1aa !important; }

/* Theme toggle button */
.theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 28px;
  border: 1px solid var(--border);
  border-radius: 2px;
  color: var(--text-dim);
  transition: all 0.2s ease;
  background: transparent;
}
.theme-toggle:hover { color: var(--accent); border-color: var(--accent); }
.theme-toggle .icon-sun { display: none; }
.theme-toggle .icon-moon { display: block; }
[data-theme="light"] .theme-toggle .icon-sun { display: block; }
[data-theme="light"] .theme-toggle .icon-moon { display: none; }

/* Logo swap */
.logo-light { display: none; }
[data-theme="light"] .logo-dark { display: none; }
[data-theme="light"] .logo-light { display: block; }

/* ===== Floating contact button (FAB) ===== */
.fab-wrap { position: fixed; right: 22px; bottom: 22px; z-index: 60; display: flex; flex-direction: column; align-items: flex-end; gap: 12px; }
.fab-actions { display: flex; flex-direction: column; gap: 12px; opacity: 0; transform: translateY(10px) scale(0.9); pointer-events: none; transition: all 0.25s ease; }
.fab-wrap.open .fab-actions { opacity: 1; transform: translateY(0) scale(1); pointer-events: auto; }
.fab-action { display: flex; align-items: center; gap: 10px; padding: 10px 16px 10px 14px; border-radius: 999px; color: #fff; font-family: 'Space Grotesk', sans-serif; font-size: 14px; font-weight: 500; box-shadow: 0 8px 24px rgba(0,0,0,0.4); white-space: nowrap; transition: transform 0.15s ease; }
.fab-action:hover { transform: translateX(-3px); }
.fab-action.wa { background: #25D366; }
.fab-action.call { background: var(--accent); color: #0a0a0b; }
.fab-action svg { flex-shrink: 0; }
.fab-toggle { position: relative; width: 58px; height: 58px; border-radius: 50%; background: var(--accent); color: #0a0a0b; display: flex; align-items: center; justify-content: center; box-shadow: 0 8px 28px var(--accent-glow); transition: transform 0.25s ease, background 0.2s ease; }
.fab-toggle:hover { background: var(--accent-2); }
.fab-wrap.open .fab-toggle { transform: rotate(135deg); }
.fab-pulse::after { content: ''; position: absolute; inset: 0; border-radius: 50%; background: var(--accent); animation: fab-pulse 2.4s ease-out infinite; z-index: -1; }
.fab-wrap.open .fab-pulse::after { animation: none; }
@keyframes fab-pulse { 0% { transform: scale(1); opacity: 0.45; } 70% { opacity: 0; } 100% { transform: scale(1.35); opacity: 0; } }

/* ===== Cookie banner ===== */
.cookie-banner { position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 70; max-width: 520px; background: var(--surface-2); border: 1px solid var(--border); border-radius: 6px; padding: 20px 22px; box-shadow: 0 16px 48px rgba(0,0,0,0.5); transform: translateY(150%); transition: transform 0.45s cubic-bezier(0.16,1,0.3,1); }
.cookie-banner.show { transform: translateY(0); }
.cookie-banner p { color: var(--text-dim); font-size: 14px; line-height: 1.6; margin-bottom: 14px; }
.cookie-banner .row { display: flex; gap: 10px; }

/* ===== Lightbox ===== */
.lightbox { position: fixed; inset: 0; z-index: 90; background: rgba(5,5,7,0.95); backdrop-filter: blur(6px); display: none; align-items: center; justify-content: center; }
.lightbox.open { display: flex; }
.lightbox img { max-width: 92vw; max-height: 86vh; object-fit: contain; border: 1px solid var(--border); }
.lightbox .lb-close { position: absolute; top: 24px; right: 28px; color: #fff; cursor: pointer; }
.lightbox .lb-nav { position: absolute; top: 50%; transform: translateY(-50%); color: #fff; cursor: pointer; padding: 16px; opacity: 0.7; transition: opacity 0.2s; }
.lightbox .lb-nav:hover { opacity: 1; }
.lightbox .lb-prev { left: 12px; }
.lightbox .lb-next { right: 12px; }
.gallery-card { cursor: pointer; }

/* ===== Price estimator ===== */
.estimator { background: var(--surface); border: 1px solid var(--border); }
.est-field label { display: block; font-family: 'Space Grotesk', sans-serif; font-size: 11px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 10px; }
.est-select, .est-range { width: 100%; }
.est-result { background: var(--bg); border: 1px solid var(--border); }
.est-price { font-family: 'Anton', 'Russo One', sans-serif; font-size: clamp(36px, 5vw, 56px); line-height: 1; color: var(--accent); }
input[type=range].est-range { -webkit-appearance: none; appearance: none; height: 4px; background: var(--border); border-radius: 2px; outline: none; }
input[type=range].est-range::-webkit-slider-thumb { -webkit-appearance: none; width: 22px; height: 22px; border-radius: 50%; background: var(--accent); cursor: pointer; box-shadow: 0 0 12px var(--accent-glow); }
input[type=range].est-range::-moz-range-thumb { width: 22px; height: 22px; border: none; border-radius: 50%; background: var(--accent); cursor: pointer; }

/* ===== FAQ accordion ===== */
.faq-item { border-bottom: 1px solid var(--border); }
.faq-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 24px 0; text-align: left; font-family: 'Space Grotesk', sans-serif; font-size: 18px; font-weight: 600; color: var(--text); transition: color 0.2s; }
.faq-q:hover { color: var(--accent); }
.faq-q .faq-icon { flex-shrink: 0; width: 22px; height: 22px; position: relative; transition: transform 0.3s; }
.faq-q .faq-icon::before, .faq-q .faq-icon::after { content: ''; position: absolute; background: var(--accent); transition: transform 0.3s; }
.faq-q .faq-icon::before { top: 10px; left: 0; width: 22px; height: 2px; }
.faq-q .faq-icon::after { top: 0; left: 10px; width: 2px; height: 22px; }
.faq-item.open .faq-icon::after { transform: scaleY(0); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height 0.35s ease; }
.faq-a-inner { padding-bottom: 24px; color: var(--text-dim); line-height: 1.7; }

/* ===== Map embed ===== */
.map-embed { display: block; width: 100%; height: 100%; min-height: 260px; border: 1px solid var(--border); border-radius: 12px; }
[data-theme="dark"] .map-embed { filter: invert(0.92) hue-rotate(180deg) brightness(0.95) contrast(0.9); }

/* ===== File input ===== */
.file-input { padding: 10px 14px; cursor: pointer; color: var(--text-dim); font-size: 14px; }
.file-input::file-selector-button { background: var(--surface-2); color: var(--text); border: 1px solid var(--border); padding: 8px 14px; border-radius: 2px; margin-right: 14px; cursor: pointer; font-family: 'Space Grotesk', sans-serif; font-size: 13px; transition: all .2s ease; }
.file-input::file-selector-button:hover { border-color: var(--accent); color: var(--accent); }
[data-theme="light"] .file-input::file-selector-button { background: #f1f1ef; }
