/* Baseline Resets & Smoothness */
        .no-underline { text-decoration: none; }
        body { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
        .not-italic { font-style: normal; }
        * { scrollbar-width: thin; scrollbar-color: #d4d4d8 transparent; }
        ::-webkit-scrollbar { width: 6px; height: 6px; }
        ::-webkit-scrollbar-track { background: transparent; }
        ::-webkit-scrollbar-thumb { background-color: #d4d4d8; border-radius: 20px; }

        /* Light Mode Liquid Glass / Refraction */
        .glass-panel {
            background: rgba(255, 255, 255, 0.7);
            backdrop-filter: blur(24px);
            -webkit-backdrop-filter: blur(24px);
            border: 1px solid rgba(0, 0, 0, 0.06);
            box-shadow: inset 0 1px 0 0 rgba(255, 255, 255, 0.8), 0 20px 40px -15px rgba(0,0,0,0.05);
        }

        /* Abstract Light Grid Background */
        .bg-grid-pattern {
            background-image: linear-gradient(to right, rgba(0,0,0,0.04) 1px, transparent 1px),
                              linear-gradient(to bottom, rgba(0,0,0,0.04) 1px, transparent 1px);
            background-size: 64px 64px;
            mask-image: radial-gradient(circle at center, black, transparent 80%);
            -webkit-mask-image: radial-gradient(circle at center, black, transparent 80%);
        }

        /* Abstract Geometric Graphic */
        .geo-shape {
            background-image: repeating-linear-gradient(45deg, transparent, transparent 10px, rgba(99, 102, 241, 0.05) 10px, rgba(99, 102, 241, 0.05) 20px);
        }

        /* Spotlight Bento Cards - Light Mode */
        .spotlight-card {
            position: relative;
            background: #ffffff;
            border-radius: 1.5rem;
            overflow: hidden;
            border: 1px solid rgba(0,0,0,0.06);
            box-shadow: 0 4px 20px -10px rgba(0,0,0,0.03);
            transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow 0.3s ease;
        }
        .spotlight-card::before {
            content: "";
            position: absolute;
            inset: 0;
            background: radial-gradient(800px circle at var(--mouse-x) var(--mouse-y), rgba(99, 102, 241, 0.04), transparent 40%);
            opacity: 0;
            transition: opacity 0.5s;
            pointer-events: none;
            z-index: 1;
        }
        .spotlight-card:hover {
            box-shadow: 0 20px 40px -15px rgba(0,0,0,0.08);
            transform: translateY(-2px);
        }
        .spotlight-card:hover::before { opacity: 1; }
        .spotlight-content { position: relative; z-index: 2; height: 100%; display: flex; flex-direction: column; }

        /* Typography Gradients */
        .text-gradient {
            background-clip: text;
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-image: linear-gradient(to right, #18181b, #71717a);
        }
        .text-gradient-indigo {
            background-clip: text;
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-image: linear-gradient(to bottom right, #4f46e5, #0ea5e9);
        }

        /* Custom Input Styling (Light Mode) */
        .math-input-wrapper:focus-within {
            box-shadow: 0 0 0 1px rgba(79, 70, 229, 0.3), 0 20px 50px -15px rgba(79, 70, 229, 0.15);
            border-color: rgba(79, 70, 229, 0.3);
        }

        /* Scroll Reveal Utility */
        .reveal { opacity: 0; transform: translateY(40px); transition: all 0.8s cubic-bezier(0.16, 1, 0.3, 1); }
        .reveal.active { opacity: 1; transform: translateY(0); }
        
        /* Stagger delays */
        .delay-100 { transition-delay: 100ms; }
        .delay-200 { transition-delay: 200ms; }
        .delay-300 { transition-delay: 300ms; }

        /* FAQ Accordion */
        .faq-content { display: grid; grid-template-rows: 0fr; transition: grid-template-rows 0.4s cubic-bezier(0.16, 1, 0.3, 1); }
        .faq-item.open .faq-content { grid-template-rows: 1fr; }
        .faq-inner { overflow: hidden; }
        .faq-icon { transition: transform 0.4s ease; }
        .faq-item.open .faq-icon { transform: rotate(45deg); color: #4f46e5; }

        /* Rating Section */
        .rating-section {
            position: relative;
            overflow: hidden;
            padding: 6rem 1.5rem;
            background: #ffffff;
            border-top: 1px solid #e4e4e7;
        }
        .rating-section::before {
            content: "";
            position: absolute;
            inset: 0;
            background: linear-gradient(135deg, rgba(238, 242, 255, 0.92), rgba(255, 255, 255, 0.88) 48%, rgba(240, 249, 255, 0.9));
            pointer-events: none;
        }
        .rating-grid-bg {
            position: absolute;
            inset: 0;
            background-image: linear-gradient(to right, rgba(24, 24, 27, 0.04) 1px, transparent 1px),
                              linear-gradient(to bottom, rgba(24, 24, 27, 0.04) 1px, transparent 1px);
            background-size: 64px 64px;
            mask-image: radial-gradient(circle at center, black, transparent 78%);
            -webkit-mask-image: radial-gradient(circle at center, black, transparent 78%);
            pointer-events: none;
        }
        .rating-shell {
            position: relative;
            z-index: 1;
            max-width: 1000px;
            margin: 0 auto;
            display: grid;
            grid-template-columns: 1fr 22rem;
            gap: 2rem;
            align-items: center;
            padding: 2rem;
            background: rgba(255, 255, 255, 0.86);
            border: 1px solid rgba(228, 228, 231, 0.9);
            border-radius: 2rem;
            box-shadow: 0 30px 70px -35px rgba(24, 24, 27, 0.32);
            backdrop-filter: blur(18px);
            -webkit-backdrop-filter: blur(18px);
        }
        .rating-copy {
            min-width: 0;
        }
        .rating-kicker {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            min-height: 2rem;
            padding: 0 0.75rem;
            margin-bottom: 1rem;
            border-radius: 9999px;
            background: #eef2ff;
            border: 1px solid #e0e7ff;
            color: #4f46e5;
            font-size: 0.75rem;
            font-weight: 800;
            text-transform: uppercase;
            letter-spacing: 0;
        }
        .rating-kicker i {
            color: #f59e0b;
            font-size: 0.95rem;
        }
        .rating-copy h2 {
            max-width: 34rem;
            color: #18181b;
            font-family: "Cabinet Grotesk", sans-serif;
            font-size: 3rem;
            line-height: 1;
            font-weight: 800;
            letter-spacing: 0;
        }
        .rating-copy h2 span {
            color: #4f46e5;
            white-space: nowrap;
        }
        .rating-copy p {
            max-width: 34rem;
            margin-top: 1rem;
            color: #52525b;
            font-size: 1rem;
            line-height: 1.625;
            font-weight: 500;
        }
        .rating-widget {
            display: flex;
            flex-direction: column;
            align-items: center;
            text-align: center;
            padding: 1.5rem 0 1.5rem 2rem;
            border-left: 1px solid #e4e4e7;
        }
        .rating-widget-title {
            margin-bottom: 1rem;
            color: #18181b;
            font-size: 1rem;
            font-weight: 800;
        }
        .rating-stars {
            display: flex;
            justify-content: center;
            gap: 0.5rem;
        }
        .rating-star {
            width: 3rem;
            height: 3rem;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            border-radius: 1rem;
            border: 1px solid #e4e4e7;
            background: #ffffff;
            color: #d4d4d8;
            box-shadow: 0 12px 24px -18px rgba(24, 24, 27, 0.45);
            transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
        }
        .rating-star:hover,
        .rating-star:focus-visible {
            transform: translateY(-2px) scale(1.04);
            border-color: #c7d2fe;
            background: #f8faff;
            box-shadow: 0 16px 30px -18px rgba(79, 70, 229, 0.55);
            outline: none;
        }
        .rating-star:active {
            transform: translateY(0) scale(0.98);
        }
        .rating-star svg {
            width: 1.75rem;
            height: 1.75rem;
            transition: color 0.2s ease, filter 0.2s ease;
        }
        #rating-stars .rating-star svg.text-yellow-400 {
            color: #f59e0b;
            filter: drop-shadow(0 6px 10px rgba(245, 158, 11, 0.28));
        }
        #rating-stars .rating-star svg.text-gray-300 {
            color: #d4d4d8;
            filter: none;
        }
        .rating-helper {
            margin-top: 1rem;
            color: #71717a;
            font-size: 0.875rem;
            line-height: 1.4;
            font-weight: 500;
        }
        .rating-thanks {
            margin-top: 0.5rem;
            color: #059669;
            font-size: 0.8125rem;
            font-weight: 800;
        }
        @media (max-width: 767px) {
            .rating-section {
                padding: 4.5rem 1rem;
            }
            .rating-shell {
                grid-template-columns: 1fr;
                gap: 1.5rem;
                padding: 1.25rem;
                border-radius: 1.5rem;
            }
            .rating-copy {
                text-align: center;
            }
            .rating-kicker {
                margin-left: auto;
                margin-right: auto;
            }
            .rating-copy h2 {
                font-size: 2.25rem;
            }
            .rating-copy p {
                margin-left: auto;
                margin-right: auto;
            }
            .rating-widget {
                padding: 1.5rem 0 0;
                border-top: 1px solid #e4e4e7;
                border-left: 0;
            }
            .rating-star {
                width: 2.75rem;
                height: 2.75rem;
                border-radius: 0.875rem;
            }
        }

*, ::before, ::after{--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:rgb(59 130 246 / 0.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:rgb(59 130 246 / 0.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-width:0;border-style:solid;border-color:#e5e7eb}::after,::before{--tw-content:''}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:Outfit, sans-serif;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, 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;padding:0}legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}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}.pointer-events-none{pointer-events:none}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0px}.-bottom-16{bottom:-4rem}.-right-12{right:-3rem}.bottom-0{bottom:0px}.bottom-1\/4{bottom:25%}.bottom-8{bottom:2rem}.bottom-\[10\%\]{bottom:10%}.bottom-\[20\%\]{bottom:20%}.left-0{left:0px}.left-1\/2{left:50%}.left-1\/4{left:25%}.left-\[23px\]{left:23px}.left-\[5\%\]{left:5%}.left-\[8\%\]{left:8%}.right-0{right:0px}.right-1\/4{right:25%}.right-\[10\%\]{right:10%}.right-\[5\%\]{right:5%}.top-0{top:0px}.top-1\/4{top:25%}.top-8{top:2rem}.top-\[15\%\]{top:15%}.top-\[40\%\]{top:40%}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.-mx-4{margin-left:-1rem;margin-right:-1rem}.mx-auto{margin-left:auto;margin-right:auto}.-mb-4{margin-bottom:-1rem}.mb-0{margin-bottom:0px}.mb-1{margin-bottom:0.25rem}.mb-10{margin-bottom:2.5rem}.mb-12{margin-bottom:3rem}.mb-16{margin-bottom:4rem}.mb-2{margin-bottom:0.5rem}.mb-3{margin-bottom:0.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-auto{margin-bottom:auto}.ml-1{margin-left:0.25rem}.ml-2{margin-left:0.5rem}.ml-4{margin-left:1rem}.ml-8{margin-left:2rem}.mr-2{margin-right:0.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.h-1{height:0.25rem}.h-1\.5{height:0.375rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-2{height:0.5rem}.h-20{height:5rem}.h-24{height:6rem}.h-3{height:0.75rem}.h-32{height:8rem}.h-4{height:1rem}.h-48{height:12rem}.h-56{height:14rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-8{height:2rem}.h-96{height:24rem}.h-\[500px\]{height:500px}.h-\[600px\]{height:600px}.h-full{height:100%}.h-16{height:4rem}.min-h-\[100dvh\]{min-height:100dvh}.min-h-\[160px\]{min-height:160px}.w-1{width:0.25rem}.w-1\/2{width:50%}.w-1\/3{width:33.333333%}.w-10{width:2.5rem}.w-11\/12{width:91.666667%}.w-12{width:3rem}.w-14{width:3.5rem}.w-2{width:0.5rem}.w-20{width:5rem}.w-24{width:6rem}.w-3{width:0.75rem}.w-3\/4{width:75%}.w-32{width:8rem}.w-4\/5{width:80%}.w-5\/6{width:83.333333%}.w-56{width:14rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-96{width:24rem}.w-\[500px\]{width:500px}.w-\[600px\]{width:600px}.w-full{width:100%}.w-px{width:1px}.min-w-max{min-width:max-content}.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-\[1000px\]{max-width:1000px}.max-w-\[1200px\]{max-width:1200px}.max-w-\[1400px\]{max-width:1400px}.max-w-\[800px\]{max-width:800px}.max-w-md{max-width:28rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x:-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-1\/2{--tw-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))}.rotate-12{--tw-rotate:12deg;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-45{--tw-rotate:45deg;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))}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}100%{opacity:1;transform:translateY(0)}}.animate-fade-in-up{animation:fadeInUp 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards}@keyframes float{0%, 100%{transform:translateY(0) scale(1)}50%{transform:translateY(-15px) scale(1.02)}}.animate-float{animation:float 6s cubic-bezier(0.175, 0.885, 0.32, 1.275) infinite}@keyframes float{0%, 100%{transform:translateY(0) scale(1)}50%{transform:translateY(-15px) scale(1.02)}}.animate-float-slow{animation:float 10s cubic-bezier(0.175, 0.885, 0.32, 1.275) infinite}@keyframes marquee{0%{transform:translateX(0%)}100%{transform:translateX(-50%)}}.animate-marquee{animation:marquee 40s linear infinite}@keyframes marquee-reverse{0%{transform:translateX(-50%)}100%{transform:translateX(0%)}}.animate-marquee-reverse{animation:marquee-reverse 50s linear infinite}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite}@keyframes pulse-glow{0%, 100%{opacity:0.5;transform:scale(1)}50%{opacity:0.8;transform:scale(1.05)}}.animate-pulse-glow{animation:pulse-glow 4s ease-in-out infinite}@keyframes typewriter{0%, 20%{width:0%;opacity:1}80%, 100%{width:100%;opacity:1}}.animate-typewriter{animation:typewriter 4s steps(40) infinite alternate}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.resize-none{resize:none}.auto-rows-\[minmax\(300px\2c auto\)\]{grid-auto-rows:minmax(300px,auto)}.grid-cols-1{grid-template-columns:repeat(1, minmax(0, 1fr))}.flex-col{flex-direction:column}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1\.5{gap:0.375rem}.gap-12{gap:3rem}.gap-16{gap:4rem}.gap-2{gap:0.5rem}.gap-3{gap:0.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-y-3 > :not([hidden]) ~ :not([hidden]){--tw-space-y-reverse:0;margin-top:calc(0.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0.75rem * var(--tw-space-y-reverse))}.space-y-4 > :not([hidden]) ~ :not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-x-hidden{overflow-x:hidden}.scroll-smooth{scroll-behavior:smooth}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:0.25rem}.rounded-2xl{border-radius:1rem}.rounded-3xl{border-radius:1.5rem}.rounded-\[1\.25rem\]{border-radius:1.25rem}.rounded-\[1\.5rem\]{border-radius:1.5rem}.rounded-\[2rem\]{border-radius:2rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:0.5rem}.rounded-md{border-radius:0.375rem}.rounded-xl{border-radius:0.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-x-0{border-left-width:0px;border-right-width:0px}.border-y{border-top-width:1px;border-bottom-width:1px}.border-b{border-bottom-width:1px}.border-b-0{border-bottom-width:0px}.border-r-2{border-right-width:2px}.border-t{border-top-width:1px}.border-t-0{border-top-width:0px}.border-amber-100{--tw-border-opacity:1;border-color:rgb(254 243 199 / var(--tw-border-opacity, 1))}.border-emerald-100{--tw-border-opacity:1;border-color:rgb(209 250 229 / var(--tw-border-opacity, 1))}.border-indigo-100{--tw-border-opacity:1;border-color:rgb(224 231 255 / var(--tw-border-opacity, 1))}.border-indigo-200{--tw-border-opacity:1;border-color:rgb(199 210 254 / var(--tw-border-opacity, 1))}.border-indigo-500{--tw-border-opacity:1;border-color:rgb(99 102 241 / var(--tw-border-opacity, 1))}.border-indigo-600{--tw-border-opacity:1;border-color:rgb(79 70 229 / var(--tw-border-opacity, 1))}.border-purple-100{--tw-border-opacity:1;border-color:rgb(243 232 255 / var(--tw-border-opacity, 1))}.border-sky-100{--tw-border-opacity:1;border-color:rgb(224 242 254 / var(--tw-border-opacity, 1))}.border-white\/50{border-color:rgb(255 255 255 / 0.5)}.border-zinc-100{--tw-border-opacity:1;border-color:rgb(244 244 245 / var(--tw-border-opacity, 1))}.border-zinc-200{--tw-border-opacity:1;border-color:rgb(228 228 231 / var(--tw-border-opacity, 1))}.border-zinc-200\/60{border-color:rgb(228 228 231 / 0.6)}.border-zinc-200\/80{border-color:rgb(228 228 231 / 0.8)}.bg-amber-50{--tw-bg-opacity:1;background-color:rgb(255 251 235 / var(--tw-bg-opacity, 1))}.bg-emerald-50{--tw-bg-opacity:1;background-color:rgb(236 253 245 / var(--tw-bg-opacity, 1))}.bg-indigo-100\/50{background-color:rgb(224 231 255 / 0.5)}.bg-indigo-200\/40{background-color:rgb(199 210 254 / 0.4)}.bg-indigo-50{--tw-bg-opacity:1;background-color:rgb(238 242 255 / var(--tw-bg-opacity, 1))}.bg-indigo-50\/50{background-color:rgb(238 242 255 / 0.5)}.bg-indigo-500{--tw-bg-opacity:1;background-color:rgb(99 102 241 / var(--tw-bg-opacity, 1))}.bg-indigo-600{--tw-bg-opacity:1;background-color:rgb(79 70 229 / var(--tw-bg-opacity, 1))}.bg-purple-50{--tw-bg-opacity:1;background-color:rgb(250 245 255 / var(--tw-bg-opacity, 1))}.bg-sky-200\/30{background-color:rgb(186 230 253 / 0.3)}.bg-sky-50{--tw-bg-opacity:1;background-color:rgb(240 249 255 / var(--tw-bg-opacity, 1))}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-white\/80{background-color:rgb(255 255 255 / 0.8)}.bg-zinc-100{--tw-bg-opacity:1;background-color:rgb(244 244 245 / var(--tw-bg-opacity, 1))}.bg-zinc-200{--tw-bg-opacity:1;background-color:rgb(228 228 231 / var(--tw-bg-opacity, 1))}.bg-zinc-300{--tw-bg-opacity:1;background-color:rgb(212 212 216 / var(--tw-bg-opacity, 1))}.bg-zinc-50{--tw-bg-opacity:1;background-color:rgb(250 250 250 / var(--tw-bg-opacity, 1))}.bg-zinc-50\/40{background-color:rgb(250 250 250 / 0.4)}.bg-zinc-50\/50{background-color:rgb(250 250 250 / 0.5)}.bg-zinc-900{--tw-bg-opacity:1;background-color:rgb(24 24 27 / var(--tw-bg-opacity, 1))}.bg-gradient-to-b{background-image:linear-gradient(to bottom, var(--tw-gradient-stops))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right, var(--tw-gradient-stops))}.bg-gradient-to-l{background-image:linear-gradient(to left, var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right, var(--tw-gradient-stops))}.bg-gradient-to-t{background-image:linear-gradient(to top, var(--tw-gradient-stops))}.from-indigo-50{--tw-gradient-from:#eef2ff var(--tw-gradient-from-position);--tw-gradient-to:rgb(238 242 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-indigo-50\/50{--tw-gradient-from:rgb(238 242 255 / 0.5) var(--tw-gradient-from-position);--tw-gradient-to:rgb(238 242 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-white{--tw-gradient-from:#fff var(--tw-gradient-from-position);--tw-gradient-to:rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-zinc-50{--tw-gradient-from:#fafafa var(--tw-gradient-from-position);--tw-gradient-to:rgb(250 250 250 / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.via-transparent{--tw-gradient-to:rgb(0 0 0 / 0)  var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), transparent var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-white{--tw-gradient-to:rgb(255 255 255 / 0)  var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), #fff var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-sky-50{--tw-gradient-to:#f0f9ff var(--tw-gradient-to-position)}.to-transparent{--tw-gradient-to:transparent var(--tw-gradient-to-position)}.object-cover{object-fit:cover}.p-2{padding:0.5rem}.p-3{padding:0.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-10{padding-left:2.5rem;padding-right:2.5rem}.px-2{padding-left:0.5rem;padding-right:0.5rem}.px-4{padding-left:1rem;padding-right:1rem}.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-0\.5{padding-top:0.125rem;padding-bottom:0.125rem}.py-1{padding-top:0.25rem;padding-bottom:0.25rem}.py-1\.5{padding-top:0.375rem;padding-bottom:0.375rem}.py-2{padding-top:0.5rem;padding-bottom:0.5rem}.py-2\.5{padding-top:0.625rem;padding-bottom:0.625rem}.py-24{padding-top:6rem;padding-bottom:6rem}.py-3{padding-top:0.75rem;padding-bottom:0.75rem}.py-3\.5{padding-top:0.875rem;padding-bottom:0.875rem}.py-32{padding-top:8rem;padding-bottom:8rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.pb-10{padding-bottom:2.5rem}.pb-12{padding-bottom:3rem}.pb-32{padding-bottom:8rem}.pr-1{padding-right:0.25rem}.pr-12{padding-right:3rem}.pt-12{padding-top:3rem}.pt-20{padding-top:5rem}.pt-24{padding-top:6rem}.pt-4{padding-top:1rem}.pt-8{padding-top:2rem}.text-left{text-align:left}.text-center{text-align:center}.align-middle{vertical-align:middle}.font-display{font-family:Cabinet Grotesk, sans-serif}.font-mono{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace}.font-sans{font-family:Outfit, sans-serif}.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-5xl{font-size:3rem;line-height:1}.text-\[10px\]{font-size:10px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:0.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:0.75rem;line-height:1rem}.font-bold{font-weight:700}.font-light{font-weight:300}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.leading-\[0\.9\]{line-height:0.9}.leading-\[1\.1\]{line-height:1.1}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-tight{letter-spacing:-0.025em}.tracking-tighter{letter-spacing:-0.05em}.tracking-wide{letter-spacing:0.025em}.tracking-widest{letter-spacing:0.1em}.text-amber-500{--tw-text-opacity:1;color:rgb(245 158 11 / var(--tw-text-opacity, 1))}.text-amber-600{--tw-text-opacity:1;color:rgb(217 119 6 / var(--tw-text-opacity, 1))}.text-emerald-500{--tw-text-opacity:1;color:rgb(16 185 129 / var(--tw-text-opacity, 1))}.text-emerald-600{--tw-text-opacity:1;color:rgb(5 150 105 / var(--tw-text-opacity, 1))}.text-indigo-200{--tw-text-opacity:1;color:rgb(199 210 254 / var(--tw-text-opacity, 1))}.text-indigo-500{--tw-text-opacity:1;color:rgb(99 102 241 / var(--tw-text-opacity, 1))}.text-indigo-600{--tw-text-opacity:1;color:rgb(79 70 229 / var(--tw-text-opacity, 1))}.text-indigo-700{--tw-text-opacity:1;color:rgb(67 56 202 / var(--tw-text-opacity, 1))}.text-orange-500{--tw-text-opacity:1;color:rgb(249 115 22 / var(--tw-text-opacity, 1))}.text-pink-500{--tw-text-opacity:1;color:rgb(236 72 153 / var(--tw-text-opacity, 1))}.text-purple-500{--tw-text-opacity:1;color:rgb(168 85 247 / var(--tw-text-opacity, 1))}.text-purple-600{--tw-text-opacity:1;color:rgb(147 51 234 / var(--tw-text-opacity, 1))}.text-rose-500{--tw-text-opacity:1;color:rgb(244 63 94 / var(--tw-text-opacity, 1))}.text-sky-500{--tw-text-opacity:1;color:rgb(14 165 233 / var(--tw-text-opacity, 1))}.text-sky-600{--tw-text-opacity:1;color:rgb(2 132 199 / var(--tw-text-opacity, 1))}.text-teal-500{--tw-text-opacity:1;color:rgb(20 184 166 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255 / 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))}.text-zinc-700{--tw-text-opacity:1;color:rgb(63 63 70 / var(--tw-text-opacity, 1))}.text-zinc-900{--tw-text-opacity:1;color:rgb(24 24 27 / var(--tw-text-opacity, 1))}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-0{opacity:0}.opacity-30{opacity:0.3}.opacity-5{opacity:0.05}.opacity-50{opacity:0.5}.opacity-60{opacity:0.6}.opacity-70{opacity:0.7}.opacity-80{opacity:0.8}.mix-blend-multiply{mix-blend-mode:multiply}.shadow-\[0_10px_30px_-5px_rgba\(79\2c 70\2c 229\2c 0\.4\)\]{--tw-shadow:0 10px 30px -5px rgba(79,70,229,0.4);--tw-shadow-colored:0 10px 30px -5px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.shadow-\[0_20px_50px_-15px_rgba\(0\2c 0\2c 0\2c 0\.06\)\]{--tw-shadow:0 20px 50px -15px rgba(0,0,0,0.06);--tw-shadow-colored:0 20px 50px -15px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.shadow-\[0_20px_50px_-15px_rgba\(79\2c 70\2c 229\2c 0\.3\)\]{--tw-shadow:0 20px 50px -15px rgba(79,70,229,0.3);--tw-shadow-colored:0 20px 50px -15px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.shadow-\[0_30px_60px_-15px_rgba\(0\2c 0\2c 0\2c 0\.08\)\]{--tw-shadow:0 30px 60px -15px rgba(0,0,0,0.08);--tw-shadow-colored:0 30px 60px -15px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.shadow-\[0_4px_14px_0_rgba\(79\2c 70\2c 229\2c 0\.39\)\]{--tw-shadow:0 4px 14px 0 rgba(79,70,229,0.39);--tw-shadow-colored:0 4px 14px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.shadow-inner{--tw-shadow:inset 0 2px 4px 0 rgb(0 0 0 / 0.05);--tw-shadow-colored:inset 0 2px 4px 0 var(--tw-shadow-color);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 rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);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 rgb(0 0 0 / 0.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.blur-\[120px\]{--tw-blur:blur(120px);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)}.blur-\[150px\]{--tw-blur:blur(150px);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)}.grayscale{--tw-grayscale:grayscale(100%);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{--tw-backdrop-blur:blur(8px);-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)}.backdrop-blur-\[2px\]{--tw-backdrop-blur:blur(2px);-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)}.backdrop-blur-md{--tw-backdrop-blur:blur(12px);-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-all{transition-property:all;transition-timing-function:cubic-bezier(0.4, 0, 0.2, 1);transition-duration:150ms}.transition-colors{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(0.4, 0, 0.2, 1);transition-duration:150ms}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(0.4, 0, 0.2, 1);transition-duration:150ms}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(0.4, 0, 0.2, 1);transition-duration:150ms}.delay-100{transition-delay:100ms}.delay-200{transition-delay:200ms}.delay-300{transition-delay:300ms}.duration-200{transition-duration:200ms}.duration-300{transition-duration:300ms}.duration-500{transition-duration:500ms}.duration-700{transition-duration:700ms}.selection\:bg-indigo-500\/20 *::selection{background-color:rgb(99 102 241 / 0.2)}.selection\:text-indigo-900 *::selection{--tw-text-opacity:1;color:rgb(49 46 129 / var(--tw-text-opacity, 1))}.selection\:bg-indigo-500\/20::selection{background-color:rgb(99 102 241 / 0.2)}.selection\:text-indigo-900::selection{--tw-text-opacity:1;color:rgb(49 46 129 / var(--tw-text-opacity, 1))}.placeholder\:text-zinc-400::placeholder{--tw-text-opacity:1;color:rgb(161 161 170 / var(--tw-text-opacity, 1))}.hover\:-translate-y-2:hover{--tw-translate-y:-0.5rem;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))}.hover\:border-indigo-200:hover{--tw-border-opacity:1;border-color:rgb(199 210 254 / var(--tw-border-opacity, 1))}.hover\:border-zinc-300:hover{--tw-border-opacity:1;border-color:rgb(212 212 216 / var(--tw-border-opacity, 1))}.hover\:bg-indigo-500:hover{--tw-bg-opacity:1;background-color:rgb(99 102 241 / var(--tw-bg-opacity, 1))}.hover\:bg-indigo-600:hover{--tw-bg-opacity:1;background-color:rgb(79 70 229 / var(--tw-bg-opacity, 1))}.hover\:bg-zinc-100:hover{--tw-bg-opacity:1;background-color:rgb(244 244 245 / var(--tw-bg-opacity, 1))}.hover\:bg-zinc-50:hover{--tw-bg-opacity:1;background-color:rgb(250 250 250 / var(--tw-bg-opacity, 1))}.hover\:text-indigo-600:hover{--tw-text-opacity:1;color:rgb(79 70 229 / var(--tw-text-opacity, 1))}.hover\:text-indigo-700:hover{--tw-text-opacity:1;color:rgb(67 56 202 / var(--tw-text-opacity, 1))}.hover\:text-zinc-900:hover{--tw-text-opacity:1;color:rgb(24 24 27 / var(--tw-text-opacity, 1))}.hover\:shadow-\[0_15px_40px_-5px_rgba\(79\2c 70\2c 229\2c 0\.6\)\]:hover{--tw-shadow:0 15px 40px -5px rgba(79,70,229,0.6);--tw-shadow-colored:0 15px 40px -5px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.hover\:shadow-\[0_6px_20px_rgba\(79\2c 70\2c 229\2c 0\.23\)\]:hover{--tw-shadow:0 6px 20px rgba(79,70,229,0.23);--tw-shadow-colored:0 6px 20px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.hover\:shadow-lg:hover{--tw-shadow:0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.hover\:shadow-xl:hover{--tw-shadow:0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.hover\:\[animation-play-state\:paused\]:hover{animation-play-state:paused}.focus\:ring-4: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(4px + 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)}.focus\:ring-indigo-500\/30:focus{--tw-ring-color:rgb(99 102 241 / 0.3)}.active\:translate-y-\[1px\]:active{--tw-translate-y:1px;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))}.active\:scale-95:active{--tw-scale-x:.95;--tw-scale-y:.95;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))}.active\:scale-\[0\.96\]:active{--tw-scale-x:0.96;--tw-scale-y:0.96;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))}.active\:scale-\[0\.98\]:active{--tw-scale-x:0.98;--tw-scale-y:0.98;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))}.group:hover .group-hover\:-translate-y-1{--tw-translate-y:-0.25rem;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))}.group:hover .group-hover\:-translate-y-4{--tw-translate-y:-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))}.group:hover .group-hover\:rotate-6{--tw-rotate:6deg;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))}.group:hover .group-hover\:scale-105{--tw-scale-x:1.05;--tw-scale-y:1.05;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))}.group:hover .group-hover\:scale-110{--tw-scale-x:1.1;--tw-scale-y:1.1;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))}.group:hover .group-hover\:border-indigo-500{--tw-border-opacity:1;border-color:rgb(99 102 241 / var(--tw-border-opacity, 1))}.group:hover .group-hover\:bg-amber-400{--tw-bg-opacity:1;background-color:rgb(251 191 36 / var(--tw-bg-opacity, 1))}.group:hover .group-hover\:bg-emerald-400{--tw-bg-opacity:1;background-color:rgb(52 211 153 / var(--tw-bg-opacity, 1))}.group:hover .group-hover\:bg-indigo-600{--tw-bg-opacity:1;background-color:rgb(79 70 229 / var(--tw-bg-opacity, 1))}.group:hover .group-hover\:bg-rose-400{--tw-bg-opacity:1;background-color:rgb(251 113 133 / var(--tw-bg-opacity, 1))}.group:hover .group-hover\:bg-zinc-50\/20{background-color:rgb(250 250 250 / 0.2)}.group:hover .group-hover\:text-indigo-600{--tw-text-opacity:1;color:rgb(79 70 229 / var(--tw-text-opacity, 1))}.group:hover .group-hover\:text-white{--tw-text-opacity:1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.group:hover .group-hover\:opacity-10{opacity:0.1}.group:hover .group-hover\:opacity-100{opacity:1}@media (min-width: 640px){.sm\:block{display:block}.sm\:flex{display:flex}}@media (min-width: 768px){.md\:col-span-2{grid-column:span 2 / span 2}.md\:block{display:block}.md\:flex{display:flex}.md\:scale-105{--tw-scale-x:1.05;--tw-scale-y:1.05;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))}.md\:grid-cols-2{grid-template-columns:repeat(2, minmax(0, 1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3, minmax(0, 1fr))}.md\:flex-row{flex-direction:row}.md\:gap-16{gap:4rem}.md\:gap-6{gap:1.5rem}.md\:p-10{padding:2.5rem}.md\:p-12{padding:3rem}.md\:p-3{padding:0.75rem}.md\:text-2xl{font-size:1.5rem;line-height:2rem}.md\:text-5xl{font-size:3rem;line-height:1}.md\:text-7xl{font-size:4.5rem;line-height:1}.md\:text-\[3\.5rem\]{font-size:3.5rem}.md\:text-lg{font-size:1.125rem;line-height:1.75rem}.md\:text-xl{font-size:1.25rem;line-height:1.75rem}}@media (min-width: 1024px){.lg\:sticky{position:sticky}.lg\:top-32{top:8rem}.lg\:col-span-2{grid-column:span 2 / span 2}.lg\:mt-8{margin-top:2rem}.lg\:block{display:block}.lg\:w-1\/3{width:33.333333%}.lg\:w-2\/3{width:66.666667%}.lg\:grid-cols-4{grid-template-columns:repeat(4, minmax(0, 1fr))}.lg\:grid-cols-5{grid-template-columns:repeat(5, minmax(0, 1fr))}.lg\:flex-row{flex-direction:row}.lg\:gap-24{gap:6rem}.lg\:gap-8{gap:2rem}.lg\:text-\[6rem\]{font-size:6rem}}

.border-indigo-300{--tw-border-opacity:1;border-color:rgb(165 180 252 / var(--tw-border-opacity, 1))}.border-indigo-400{--tw-border-opacity:1;border-color:rgb(129 140 248 / var(--tw-border-opacity, 1))}
.text-yellow-400{--tw-text-opacity:1;color:rgb(250 204 21 / var(--tw-text-opacity, 1))}
.text-gray-300{--tw-text-opacity:1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}

/* md:hidden missing from pre-compiled bundle */
@media (min-width: 768px) { .md\:hidden { display: none !important; } }

/* Shared site mobile menu */
.site-mobile-menu-button,
.site-mobile-menu-close {
  width: 2.5rem;
  height: 2.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  color: #18181b;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid #e4e4e7;
  transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.site-mobile-menu-button:hover,
.site-mobile-menu-close:hover {
  background: #f4f4f5;
  color: #4f46e5;
}

.site-mobile-menu-button:active,
.site-mobile-menu-close:active {
  transform: scale(0.96);
}

.site-mobile-menu-button i,
.site-mobile-menu-close i {
  font-size: 1.25rem;
}

.site-mobile-menu-overlay {
  position: fixed;
  inset: 0;
  z-index: 60;
  background: rgba(24, 24, 27, 0.42);
  opacity: 0;
  transition: opacity 0.24s ease;
}

.site-mobile-menu-overlay.is-open {
  opacity: 1;
}

.site-mobile-menu {
  position: fixed;
  inset: 0 auto 0 0;
  z-index: 70;
  width: min(22rem, calc(100vw - 2rem));
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  background: rgba(255, 255, 255, 0.96);
  border-right: 1px solid #e4e4e7;
  box-shadow: 0 24px 70px -24px rgba(24, 24, 27, 0.42);
  transform: translateX(-100%);
  transition: transform 0.28s cubic-bezier(0.16, 1, 0.3, 1);
}

.site-mobile-menu.is-open {
  transform: translateX(0);
}

.site-mobile-menu-header {
  min-height: 5rem;
  padding: 1.25rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  border-bottom: 1px solid #e4e4e7;
}

.site-mobile-menu-body {
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.site-mobile-menu-body .site-mobile-menu-link {
  display: flex;
  align-items: center;
  min-height: 3rem;
  padding: 0 1rem;
  border-radius: 0.875rem;
  color: #3f3f46;
  font-size: 1rem;
  font-weight: 700;
  transition: background-color 0.2s ease, color 0.2s ease;
}

.site-mobile-menu-body .site-mobile-menu-link:hover {
  background: #f4f4f5;
  color: #4f46e5;
}

.site-mobile-menu-actions {
  margin-top: auto;
  padding: 1rem;
  display: grid;
  gap: 0.75rem;
  border-top: 1px solid #e4e4e7;
}

.site-mobile-login-link,
.site-mobile-try-link {
  min-height: 3rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  font-size: 0.95rem;
  font-weight: 700;
  transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.site-mobile-login-link {
  color: #3f3f46;
  background: #fff;
  border: 1px solid #e4e4e7;
}

.site-mobile-login-link:hover {
  background: #f4f4f5;
  color: #18181b;
}

.site-mobile-try-link {
  color: #fff;
  background: #18181b;
  box-shadow: 0 10px 24px -12px rgba(24, 24, 27, 0.6);
}

.site-mobile-try-link:hover {
  background: #4f46e5;
}

.site-mobile-login-link:active,
.site-mobile-try-link:active {
  transform: scale(0.98);
}

.site-menu-open {
  overflow: hidden;
}

/* Demo is display-only — no interaction, no selection */
#demo-shell, #demo-shell * {
    pointer-events: none !important;
    user-select: none !important;
    -webkit-user-select: none !important;
    cursor: default !important;
}

/* Keep the main feature card from overlapping its solution preview. */
.solution-feature-card {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(300px, 1.08fr);
  align-items: stretch;
  column-gap: clamp(1rem, 4vw, 3rem);
  min-height: 340px;
}

.solution-feature-card .solution-feature-copy {
  min-width: 0;
}

.solution-feature-card .solution-feature-copy .max-w-md {
  max-width: 100%;
}

.solution-feature-card .solution-feature-visual {
  position: static;
  display: block;
  width: auto;
  height: auto;
  padding: 3rem 3rem 3rem 0;
  overflow: visible;
  transform-origin: center;
}

.solution-feature-card .solution-feature-visual > div {
  min-height: 100%;
}

.solution-feature-card .solution-feature-visual .ml-4 {
  margin-left: clamp(0.5rem, 3vw, 1rem);
}

.solution-feature-card .solution-feature-visual .ml-8 {
  margin-left: clamp(1rem, 5vw, 2rem);
}

@media (max-width: 1180px) and (min-width: 768px) {
  .features-bento-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .features-bento-grid .solution-feature-card {
    grid-column: span 2 / span 2;
  }

  .features-bento-grid .photo-feature-card {
    min-height: 300px;
  }
}

@media (max-width: 1180px) {
  .solution-feature-card {
    grid-template-columns: minmax(0, 0.88fr) minmax(280px, 1.12fr);
    column-gap: 1rem;
  }

  .solution-feature-card .solution-feature-copy {
    padding-right: 1rem;
  }

  .solution-feature-card .solution-feature-copy p {
    font-size: 1rem;
  }

  .solution-feature-card .solution-feature-visual {
    padding: 2rem 2rem 2rem 0;
  }
}

@media (max-width: 900px) {
  .solution-feature-card {
    grid-template-columns: 1fr;
    row-gap: 1.5rem;
  }

  .solution-feature-card .solution-feature-copy {
    padding-bottom: 0;
    padding-right: 2rem;
  }

  .solution-feature-card .solution-feature-visual {
    padding: 0 2rem 2rem;
  }

  .solution-feature-card .solution-feature-visual > div {
    min-height: 230px;
  }
}

@media (max-width: 767px) {
  .features-bento-grid {
    grid-template-columns: 1fr;
  }

  .solution-feature-card .solution-feature-copy {
    padding: 2rem;
  }

  .solution-feature-card .solution-feature-visual {
    display: none;
  }
}

/* App page */
.app-body {
  overflow: hidden;
  background: #fafafa;
}

.math-app-shell {
  position: fixed;
  inset: 0;
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
  max-height: 100dvh;
  background:
    radial-gradient(circle at 18% 12%, rgba(99, 102, 241, 0.08), transparent 26rem),
    linear-gradient(180deg, #ffffff 0%, #fafafa 42%, #f4f4f5 100%);
}

.app-nav {
  position: relative;
  z-index: 20;
  border-left: 0;
  border-right: 0;
  border-top: 0;
  min-height: 4rem;
}

.app-nav-inner {
  width: 100%;
  max-width: 1400px;
  min-height: 4rem;
  margin: 0 auto;
  padding: 0 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.app-desktop-actions {
  display: flex;
  align-items: center;
  gap: clamp(0.5rem, 1.4vw, 1.5rem);
}

.app-nav-button,
.app-secondary-button,
.app-primary-button,
.app-user-button,
.app-icon-button,
.app-mobile-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  font-weight: 600;
  transition: color 0.2s ease, background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.app-nav-button {
  gap: 0.5rem;
  padding: 0.6rem 0.9rem;
  border-radius: 999px;
  color: #3f3f46;
}

.app-nav-button i {
  font-size: 1.25rem;
}

.app-nav-button:hover,
.app-user-button:hover,
.app-icon-button:hover,
.app-mobile-link:hover {
  color: #18181b;
  background: #f4f4f5;
}

.app-credit-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.6rem 0.75rem;
  border: 1px solid #e4e4e7;
  border-radius: 999px;
  color: #52525b;
  background: #ffffff;
  font-size: 0.9rem;
  font-weight: 600;
  box-shadow: 0 1px 2px rgb(0 0 0 / 0.04);
}

.app-credit-pill i {
  color: #4f46e5;
}

.app-user-button {
  padding: 0.25rem;
  border-radius: 999px;
  color: #ffffff;
  background: transparent;
}

.app-user-button span,
.app-mobile-avatar {
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  background: #4f46e5;
  box-shadow: 0 10px 30px -18px rgba(79, 70, 229, 0.9);
}

.app-auth-actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.app-secondary-button,
.app-primary-button {
  min-height: 2.5rem;
  padding: 0.6rem 1rem;
  border-radius: 999px;
  font-size: 0.875rem;
}

.app-secondary-button {
  color: #52525b;
  border: 1px solid #d4d4d8;
  background: #ffffff;
}

.app-secondary-button:hover {
  color: #18181b;
  border-color: #a1a1aa;
  background: #f4f4f5;
}

.app-primary-button {
  color: #ffffff;
  background: #18181b;
  box-shadow: 0 8px 18px -14px rgba(0, 0, 0, 0.65);
}

.app-primary-button:hover {
  background: #4f46e5;
  box-shadow: 0 12px 26px -16px rgba(79, 70, 229, 0.9);
}

.app-icon-button {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.75rem;
  color: #52525b;
  background: transparent;
  font-size: 1.5rem;
}

.app-menu-toggle,
.app-mobile-new-task {
  display: none;
}

.app-workspace {
  flex: 1;
  width: 100%;
  overflow-y: auto;
  padding: 2rem 1.5rem;
}

.app-chat-area {
  width: min(100%, 48rem);
  min-height: 100%;
  margin: 0 auto;
}

.app-composer {
  width: 100%;
  max-width: 48rem;
  margin: 0 auto;
  padding: 0.25rem 1.5rem 1rem;
  box-sizing: border-box;
}

.app-input-panel {
  position: relative;
  width: 100%;
  box-sizing: border-box;
  min-height: 7.5rem;
  padding: 1rem 0.75rem 2.7rem;
  border: 1px solid #d4d4d8;
  border-radius: 1.25rem;
  color: #18181b;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 20px 50px -24px rgba(0, 0, 0, 0.16);
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.app-input-panel:focus-within {
  background: #ffffff;
}

.app-input-panel textarea {
  display: block;
  width: 100%;
  min-height: 4.1rem;
  max-height: 13rem;
  padding: 0 0.5rem;
  resize: none;
  overflow: auto;
  border: 0;
  outline: 0;
  background: transparent;
  color: #18181b;
  font-size: 1rem;
  line-height: 1.55;
}

.app-input-panel textarea::placeholder {
  color: #a1a1aa;
}

.app-composer-actions {
  position: absolute;
  right: 0.75rem;
  bottom: 0.55rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.app-file-input {
  display: none;
}

.app-upload-button,
.app-submit-button {
  width: 2.1rem;
  height: 2.1rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: color 0.2s ease, background-color 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
}

.app-upload-button {
  color: #71717a;
  cursor: pointer;
  font-size: 1.45rem;
}

.app-upload-button:hover {
  color: #18181b;
  background: #f4f4f5;
}

.app-submit-button {
  border: 0;
  color: #ffffff;
  background: #4f46e5;
  font-size: 1.15rem;
  box-shadow: 0 8px 18px -12px rgba(79, 70, 229, 0.9);
}

.app-submit-button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  box-shadow: none;
}

.app-submit-button:not(:disabled):hover {
  background: #6366f1;
  transform: translateY(-1px);
}

.landing-composer.app-composer {
  max-width: 48rem;
  padding: 0.75rem;
  border: 1px solid #e4e4e7;
  border-radius: 2rem;
  background: #ffffff;
  box-shadow: 0 20px 50px -15px rgba(0, 0, 0, 0.06);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.landing-composer.app-composer:focus-within {
  border-color: rgba(79, 70, 229, 0.3);
  box-shadow: 0 0 0 1px rgba(79, 70, 229, 0.3), 0 20px 50px -15px rgba(79, 70, 229, 0.15);
}

.landing-composer .app-input-panel {
  min-height: 13.4rem;
  padding: 1.5rem 1.5rem 5.4rem;
  border-color: rgba(228, 228, 231, 0.6);
  border-radius: 1.5rem;
  background: #fafafa;
  box-shadow: inset 0 2px 4px 0 rgb(0 0 0 / 0.05);
  overflow: hidden;
}

.landing-composer .app-input-panel:focus-within {
  background: #fafafa;
}

.landing-composer .app-input-panel textarea {
  min-height: 10rem;
  padding: 0;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: clamp(1rem, 1.7vw, 1.125rem);
  line-height: 1.55;
}

.landing-composer .app-composer-actions {
  left: 0;
  right: 0;
  bottom: 0;
  min-height: 4.75rem;
  padding: 1rem;
  justify-content: space-between;
  border-top: 1px solid rgba(228, 228, 231, 0.6);
  background: #ffffff;
}

.landing-composer .app-upload-button {
  width: auto;
  height: 2.75rem;
  gap: 0.5rem;
  padding: 0 1rem;
  color: #71717a;
  font-size: 1.25rem;
  font-weight: 600;
}

.landing-composer .app-upload-button::after {
  content: "Attach file";
  font-size: 0.875rem;
}

.landing-composer .app-submit-button {
  width: auto;
  min-width: 7.25rem;
  height: 3rem;
  gap: 0.5rem;
  padding: 0 2rem;
  font-size: 1rem;
  font-weight: 600;
  box-shadow: 0 4px 14px 0 rgba(79, 70, 229, 0.39);
}

.landing-composer .app-submit-button::before {
  content: "Solve";
  font-size: 0.875rem;
}

.landing-composer .app-submit-button i {
  transform: rotate(45deg);
}

.app-menu-backdrop {
  position: fixed;
  inset: 0;
  z-index: 35;
  background: rgba(24, 24, 27, 0.18);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}

.app-mobile-menu {
  position: fixed;
  inset: 0 auto 0 0;
  z-index: 40;
  width: min(20rem, 86vw);
  overflow-y: auto;
  padding: 1rem;
  background: rgba(255, 255, 255, 0.94);
  border-right: 1px solid #e4e4e7;
  box-shadow: 30px 0 60px -40px rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  transform: translateX(-105%);
  transition: transform 0.3s ease;
}

.app-mobile-menu.open {
  transform: translateX(0);
}

.app-menu-backdrop.open {
  opacity: 1;
  pointer-events: auto;
}

.app-menu-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
}

.app-mobile-menu-inner {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-top: 4.25rem;
}

.app-mobile-auth {
  display: grid;
  gap: 0.75rem;
}

.app-mobile-profile {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 0.25rem;
}

.app-mobile-name {
  display: block;
  min-height: 1rem;
}

.app-plan-badge {
  display: inline-flex;
  padding: 0.2rem 0.45rem;
  border-radius: 0.5rem;
  color: #52525b;
  background: #f4f4f5;
  font-size: 0.8rem;
  font-weight: 600;
}

.app-mobile-credit,
.app-mobile-link,
.app-mobile-links a {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  width: 100%;
  padding: 0.75rem;
  border-radius: 0.75rem;
  color: #52525b;
  font-weight: 600;
}

.app-mobile-credit {
  border: 1px solid #e4e4e7;
  background: #ffffff;
}

.app-mobile-credit i {
  color: #4f46e5;
}

.app-mobile-link {
  justify-content: flex-start;
  background: transparent;
}

.app-mobile-links {
  display: grid;
  gap: 0.25rem;
  padding-top: 0.75rem;
  border-top: 1px solid #e4e4e7;
}

.app-mobile-links a {
  font-weight: 500;
  text-decoration: none;
}

.app-mobile-links a:hover {
  color: #18181b;
  background: #f4f4f5;
}

@media (max-width: 767px) {
  .app-nav-inner {
    justify-content: center;
    padding: 0 0.75rem;
  }

  .app-menu-toggle,
  .app-mobile-new-task {
    position: absolute;
    display: inline-flex;
  }

  .app-menu-toggle {
    left: 0.75rem;
  }

  .app-mobile-new-task {
    right: 0.75rem;
  }

  .app-desktop-actions {
    display: none;
  }

  .app-workspace {
    padding: 1.25rem 1rem;
  }

  .app-composer {
    width: calc(100% - 2rem);
    padding: 0.25rem 0 0.8rem;
  }
}

/* ——— Demo animation ——— */

/* Hide scrollbar inside demo chat areas */
.demo-chat-area {
    scrollbar-width: none;
    overflow-y: auto;
    min-height: 0;
    flex: 1 1 0%;
}
.demo-chat-area::-webkit-scrollbar { display: none; }

/* Blinking cursor in input */
.demo-cursor {
    display: inline;
    color: #4f46e5;
    font-weight: 300;
    animation: demo-blink 1s step-end infinite;
}
@keyframes demo-blink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0; }
}

/* Input panel (desktop) */
.demo-input-panel {
    position: relative;
    background: rgba(255,255,255,0.92);
    border: 1px solid #d4d4d8;
    border-radius: 0.875rem;
    padding: 0.6rem 2.8rem 0.6rem 0.875rem;
    min-height: 2.5rem;
    display: flex;
    align-items: center;
    box-shadow: 0 8px 24px -12px rgba(0,0,0,0.1);
    font-size: 0.875rem;
    color: #18181b;
    line-height: 1.5;
}
.demo-input-panel-sm {
    padding: 0.5rem 2.4rem 0.5rem 0.75rem;
    min-height: 2.15rem;
    font-size: 0.8125rem;
}
.demo-input-text {
    white-space: pre-wrap;
    word-break: break-word;
}

/* Send button */
.demo-send-btn {
    position: absolute;
    right: 0.4rem;
    top: 50%;
    transform: translateY(-50%);
    width: 1.85rem;
    height: 1.85rem;
    border-radius: 999px;
    background: #4f46e5;
    color: #fff;
    border: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    opacity: 0.3;
    transition: opacity 0.2s ease;
    pointer-events: none;
}
.demo-send-btn-sm {
    width: 1.6rem;
    height: 1.6rem;
    right: 0.35rem;
}
.demo-send-btn.active { opacity: 1; }

/* Phone frame */
.demo-phone-outer {
    position: relative;
    width: min(300px, 86vw);
    background: #1c1c1e;
    border-radius: 3rem;
    padding: 10px;
    box-shadow: 0 30px 60px -15px rgba(0,0,0,0.35), inset 0 0 0 1px rgba(255,255,255,0.07);
}
.demo-phone-notch {
    position: absolute;
    top: 10px;
    left: 50%;
    transform: translateX(-50%);
    width: 5rem;
    height: 1.3rem;
    background: #1c1c1e;
    border-radius: 0 0 0.875rem 0.875rem;
    z-index: 5;
}
.demo-phone-screen {
    background: #fff;
    border-radius: 2.5rem;
    overflow: hidden;
    height: 540px;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

/* Chat message: user bubble */
@keyframes demo-msg-in {
    from { opacity: 0; transform: translateY(7px); }
    to   { opacity: 1; transform: translateY(0); }
}
.demo-msg-user {
    display: flex;
    justify-content: flex-end;
    opacity: 0;
    animation: demo-msg-in 0.32s cubic-bezier(0.16,1,0.3,1) forwards;
}
.dm-bubble {
    max-width: 72%;
    background: #18181b;
    color: #fff;
    font-size: 0.875rem;
    line-height: 1.55;
    padding: 0.55rem 0.9rem;
    border-radius: 1.1rem 1.1rem 0.2rem 1.1rem;
}

/* Chat message: AI */
.demo-msg-ai {
    display: flex;
    gap: 0.5rem;
    align-items: flex-start;
    opacity: 0;
    animation: demo-msg-in 0.32s cubic-bezier(0.16,1,0.3,1) forwards;
}
.dm-avatar {
    width: 1.65rem;
    height: 1.65rem;
    background: #eef2ff;
    border: 1px solid #e0e7ff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-top: 0.1rem;
}
.dm-body {
    flex: 1;
    min-width: 0;
    font-size: 0.875rem;
    color: #3f3f46;
    line-height: 1.65;
}
.dm-intro { margin-bottom: 0.45rem; color: #52525b; }

/* Mobile adjustments */
#demo-msgs-m .dm-bubble { font-size: 0.8125rem; }
#demo-msgs-m .dm-body   { font-size: 0.8125rem; }
#demo-msgs-m .dm-avatar { width: 1.45rem; height: 1.45rem; }

/* AI thinking dots */
.demo-thinking {
    display: flex;
    gap: 0.22rem;
    align-items: center;
    padding: 0.2rem 0;
}
.demo-thinking i {
    display: inline-block;
    width: 0.37rem;
    height: 0.37rem;
    background: #a1a1aa;
    border-radius: 50%;
    animation: demo-dot 1.2s ease-in-out infinite;
}
.demo-thinking i:nth-child(2) { animation-delay: 0.18s; }
.demo-thinking i:nth-child(3) { animation-delay: 0.36s; }
@keyframes demo-dot {
    0%, 60%, 100% { transform: translateY(0); opacity: 0.45; }
    30%           { transform: translateY(-4px); opacity: 1; }
}

/* Step cards (initially hidden) */
.demo-step {
    background: #f9f9fb;
    border: 1px solid #e4e4e7;
    border-radius: 0.6rem;
    padding: 0.5rem 0.75rem;
    margin: 0.28rem 0;
    opacity: 0;
    transform: translateY(6px);
    transition: opacity 0.35s ease, transform 0.35s ease;
}
.demo-step.show { opacity: 1; transform: translateY(0); }
.demo-step-label {
    font-size: 0.67rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.055em;
    color: #6366f1;
    margin-bottom: 0.18rem;
}
.demo-step-math {
    font-size: 0.875rem;
    font-weight: 500;
    color: #18181b;
}

/* Answer card */
.demo-answer {
    background: linear-gradient(135deg, #eef2ff 0%, #f0f9ff 100%);
    border: 1px solid #c7d2fe;
    border-radius: 0.6rem;
    padding: 0.55rem 0.875rem;
    margin-top: 0.38rem;
    font-size: 0.9rem;
    font-weight: 700;
    color: #4338ca;
    opacity: 0;
    transform: translateY(6px);
    transition: opacity 0.35s ease, transform 0.35s ease;
}
.demo-answer.show { opacity: 1; transform: translateY(0); }

/* Terms page */
.terms-page {
  background: #ffffff;
}

.terms-hero {
  position: relative;
  padding: 10rem 1.5rem 5rem;
  overflow: hidden;
  border-bottom: 1px solid #e4e4e7;
  background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
}

.terms-hero-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 15%, rgba(99, 102, 241, 0.12), transparent 24rem),
    linear-gradient(to right, rgba(0,0,0,0.035) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(0,0,0,0.035) 1px, transparent 1px);
  background-size: auto, 64px 64px, 64px 64px;
  mask-image: radial-gradient(circle at center, black, transparent 78%);
  -webkit-mask-image: radial-gradient(circle at center, black, transparent 78%);
}

.terms-container {
  position: relative;
  z-index: 1;
  width: min(100%, 900px);
  margin: 0 auto;
  text-align: center;
}

.terms-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 1rem;
  color: #4f46e5;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.terms-hero h1 {
  margin: 0;
  color: #18181b;
  font-family: "Cabinet Grotesk", sans-serif;
  font-size: clamp(3rem, 7vw, 5.5rem);
  font-weight: 800;
  line-height: 0.95;
  letter-spacing: -0.05em;
}

.terms-hero p {
  max-width: 620px;
  margin: 1.5rem auto 0;
  color: #52525b;
  font-size: 1.125rem;
  line-height: 1.7;
}

.terms-section {
  padding: 4rem 1.5rem 7rem;
  background: #fafafa;
}

.terms-card {
  width: min(100%, 980px);
  margin: 0 auto;
  padding: clamp(2rem, 5vw, 4rem);
  border: 1px solid #e4e4e7;
  border-radius: 1.5rem;
  background: #ffffff;
  box-shadow: 0 30px 60px -35px rgba(0, 0, 0, 0.14);
  color: #52525b;
  font-size: 1rem;
  line-height: 1.8;
}

.terms-card strong {
  display: inline-block;
  margin-top: 0.7rem;
  color: #18181b;
  font-family: "Cabinet Grotesk", sans-serif;
  font-size: 1.35rem;
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: -0.025em;
}

.terms-card a {
  color: #4f46e5;
  font-weight: 700;
  text-decoration: none;
}

.terms-card a:hover {
  color: #4338ca;
}

.about-card {
  width: min(100%, 980px);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  padding: clamp(2rem, 5vw, 4rem);
  border: 1px solid #e4e4e7;
  border-radius: 1.5rem;
  background: #ffffff;
  box-shadow: 0 30px 60px -35px rgba(0, 0, 0, 0.14);
}

.about-copy h2 {
  margin: 0 0 1rem;
  color: #18181b;
  font-family: "Cabinet Grotesk", sans-serif;
  font-size: clamp(2rem, 4vw, 3.25rem);
  font-weight: 800;
  line-height: 0.98;
  letter-spacing: -0.045em;
}

.about-copy p {
  color: #52525b;
  font-size: 1.125rem;
  line-height: 1.75;
}

.about-details {
  display: grid;
  gap: 1rem;
}

.about-details > div {
  padding: 1.25rem;
  border: 1px solid #e4e4e7;
  border-radius: 1.25rem;
  background: #fafafa;
}

.about-details span {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0.8rem;
  color: #18181b;
  font-weight: 800;
}

.about-details span i {
  color: #4f46e5;
}

.about-details p {
  color: #52525b;
  font-size: 0.95rem;
  line-height: 1.7;
}

.about-details a {
  color: #4f46e5;
  font-weight: 700;
  text-decoration: none;
}

.about-details a:hover {
  color: #4338ca;
}

.contact-form-card {
  width: min(100%, 980px);
  margin: 1.5rem auto 0;
  padding: clamp(2rem, 5vw, 4rem);
  border: 1px solid #e4e4e7;
  border-radius: 1.5rem;
  background: #ffffff;
  box-shadow: 0 30px 60px -35px rgba(0, 0, 0, 0.14);
}

.contact-form-copy {
  max-width: 620px;
  margin-bottom: 2rem;
}

.contact-form-copy h2 {
  margin: 0 0 0.8rem;
  color: #18181b;
  font-family: "Cabinet Grotesk", sans-serif;
  font-size: clamp(2rem, 4vw, 3.25rem);
  font-weight: 800;
  line-height: 0.98;
  letter-spacing: -0.045em;
}

.contact-form-copy p {
  color: #52525b;
  font-size: 1.05rem;
  line-height: 1.7;
}

.contact-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.contact-form-grid label {
  display: grid;
  gap: 0.45rem;
}

.contact-form-grid label span {
  color: #3f3f46;
  font-size: 0.88rem;
  font-weight: 800;
}

.contact-form-grid input,
.contact-form-grid textarea {
  width: 100%;
  border: 1px solid #d4d4d8;
  border-radius: 1rem;
  background: #fafafa;
  color: #18181b;
  outline: 0;
  padding: 0.9rem 1rem;
  font-size: 1rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.contact-form-grid textarea {
  resize: vertical;
}

.contact-form-grid input:focus,
.contact-form-grid textarea:focus {
  border-color: rgba(79, 70, 229, 0.45);
  background: #ffffff;
  box-shadow: 0 0 0 4px rgba(79, 70, 229, 0.08);
}

.contact-form-message {
  grid-column: 1 / -1;
}

.contact-form-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  margin-top: 1.25rem;
  border: 0;
  border-radius: 999px;
  background: #18181b;
  color: #ffffff;
  font-weight: 800;
  padding: 0.9rem 1.25rem;
  box-shadow: 0 12px 26px -18px rgba(0, 0, 0, 0.7);
  transition: background-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.contact-form-submit:hover {
  background: #4f46e5;
  box-shadow: 0 14px 30px -18px rgba(79, 70, 229, 0.9);
  transform: translateY(-1px);
}

.terms-card ol {
  list-style: decimal;
  padding-left: 1.35rem;
}

.terms-card li {
  margin: 0.65rem 0;
}

@media (max-width: 767px) {
  .terms-hero {
    padding: 8rem 1.25rem 3.5rem;
  }

  .terms-section {
    padding: 2rem 1rem 4rem;
  }

  .terms-card {
    border-radius: 1.25rem;
  }

  .about-card {
    grid-template-columns: 1fr;
    border-radius: 1.25rem;
  }

  .contact-form-card {
    border-radius: 1.25rem;
  }

  .contact-form-grid {
    grid-template-columns: 1fr;
  }
}
