.skills-section{padding:64px 24px;max-width:1024px;margin:0 auto}.skills-title{font-size:1.5rem;font-weight:600;margin-bottom:32px;color:#ffffffeb}.skills-groups{display:flex;flex-direction:column;gap:32px}.skills-category{font-size:1.125rem;font-weight:500;margin-bottom:12px;color:#60a5fa}.skills-chips{display:flex;flex-wrap:wrap;gap:10px}.skill-chip{border:1px solid rgba(38,38,38,1);background:#171717d9;color:#e5e7ebe6;font-size:.875rem;padding:10px 14px;border-radius:12px;cursor:default;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease}.skill-chip:hover{transform:translateY(-3px);border-color:#a78bfa99;background:#262626bf;box-shadow:0 14px 30px #00000059,0 0 0 1px #a78bfa1a}.skill-chip:focus-visible{outline:2px solid rgba(167,139,250,.65);outline-offset:2px}.pc-card{border:1px solid rgba(38,38,38,1);background:#171717d9;border-radius:18px;padding:18px;display:flex;flex-direction:column;gap:12px;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.pc-card:hover{transform:translateY(-4px);border-color:#a78bfa8c;box-shadow:0 18px 40px #00000073}.pc-top{display:flex;align-items:center;justify-content:flex-end;min-height:30px}.pc-topSpacer{flex:1}.pc-result{font-size:.75rem;padding:6px 10px;border-radius:999px;border:1px solid rgba(63,63,70,.75);background:#00000040;color:#e5e7ebe6;white-space:nowrap}.pc-media{position:relative}.pc-mediaBtn{width:100%;padding:0;border:0;background:transparent;cursor:zoom-in}.pc-image{width:100%;height:170px;-o-object-fit:cover;object-fit:cover;border-radius:14px;border:1px solid rgba(63,63,70,.6)}.pc-nav{position:absolute;top:50%;transform:translateY(-50%);background:#00000073;border:1px solid rgba(63,63,70,.7);color:#ffffffd9;border-radius:12px;padding:8px 12px;cursor:pointer;transition:background .16s ease,border-color .16s ease}.pc-nav:hover{background:#000000a6;border-color:#a78bfa80}.pc-navLeft{left:10px}.pc-navRight{right:10px}.pc-dots{position:absolute;bottom:10px;left:50%;transform:translate(-50%);display:flex;gap:6px}.pc-dot{width:6px;height:6px;border-radius:999px;background:#ffffff40}.pc-dot.isActive{background:#ffffffbf}.pc-title{margin:2px 0 0;font-size:1.25rem;font-weight:700;letter-spacing:-.02em;color:#ffffffeb}.pc-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px}.pc-tag{font-size:.75rem;padding:6px 10px;border-radius:999px;border:1px solid rgba(38,38,38,1);background:#0000002e;color:#e5e7ebd1}.pc-desc{margin:2px 0 0;color:#ffffff9e;line-height:1.55}.pc-links{display:flex;flex-wrap:wrap;gap:16px;margin-top:6px}.pc-link{font-size:.875rem;color:#60a5fa;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:transform .16s ease,color .16s ease}.pc-link:hover{transform:translateY(-1px);color:#a78bfaf2}.pc-modalOverlay{position:fixed;inset:0;z-index:50;background:#000000b8;display:flex;align-items:center;justify-content:center;padding:16px}.pc-modal{position:relative;width:100%;max-width:1024px}.pc-modalImage{width:100%;max-height:80vh;-o-object-fit:contain;object-fit:contain;border-radius:16px;border:1px solid rgba(63,63,70,.8);background:#030712e6}.pc-close{position:absolute;top:-10px;right:-10px;width:38px;height:38px;border-radius:999px;background:#171717e6;border:1px solid rgba(63,63,70,.8);color:#ffffffd9;cursor:pointer}.pc-modalNav{position:absolute;top:50%;transform:translateY(-50%);background:#00000073;border:1px solid rgba(63,63,70,.8);color:#ffffffe6;border-radius:12px;padding:10px 14px;cursor:pointer}.pc-modalNavLeft{left:10px}.pc-modalNavRight{right:10px}.pc-counter{margin-top:10px;text-align:center;font-size:.75rem;color:#e5e7ebcc}.contact-wrap{max-width:980px}.contact-hero{text-align:center;padding:28px 0 22px}.contact-title{font-size:1.875rem;font-weight:600;margin:0;color:#ffffffeb}.contact-subtitle{margin:8px 0 0;font-size:1.15rem;font-weight:400;color:#ffffffa6}.contact-card{max-width:900px;margin:28px auto 0;padding:22px;border-radius:18px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);box-shadow:0 18px 40px #00000073,0 1px #ffffff0d inset;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.contact-form{display:flex;flex-direction:column;gap:18px}.contact-input,.contact-textarea{width:100%;border-radius:14px;border:1px solid rgba(255,255,255,.1);background:#00000040;color:#ffffffe6;padding:18px;font-size:1.05rem;outline:none;transition:border-color .15s ease,background .15s ease,transform .15s ease}.contact-textarea{min-height:220px;resize:vertical}.contact-input::-moz-placeholder,.contact-textarea::-moz-placeholder{color:#fff6}.contact-input::placeholder,.contact-textarea::placeholder{color:#fff6}.contact-input:focus,.contact-textarea:focus{border-color:#a78bfa8c;background:#00000052}.contact-submit{align-self:center;margin-top:8px;border:0;cursor:pointer;padding:18px 44px;border-radius:22px;font-size:1.35rem;font-weight:750;color:#ffffffeb;background:linear-gradient(135deg,#8b5cf68c,#6366f180);box-shadow:0 14px 30px #00000059,0 1px #ffffff1a inset;transition:transform .15s ease,filter .15s ease}.contact-submit:hover{transform:translateY(-1px);filter:brightness(1.05)}.contact-submit:active{transform:translateY(0)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.projects-section{padding:80px 24px;max-width:1152px;margin:0 auto}.projects-title{font-size:1.875rem;font-weight:600;margin-bottom:12px;color:#ffffffeb}.projects-subtitle{color:#ffffff8c;margin-bottom:40px}.projects-toolbar{display:flex;flex-direction:column;gap:16px;margin-bottom:32px}@media(min-width:768px){.projects-toolbar{flex-direction:row;align-items:center;justify-content:space-between}}.projects-search{width:100%;max-width:500px;background:#171717d9;border:1px solid rgba(38,38,38,1);border-radius:12px;padding:10px 16px;font-size:.875rem;color:#ffffffe6;outline:none;transition:border-color .16s ease,box-shadow .16s ease}.projects-search:focus{border-color:#a78bfa99;box-shadow:0 0 0 1px #a78bfa33}.projects-source-buttons,.projects-tags{display:flex;flex-wrap:wrap;gap:8px}.projects-tags{margin-bottom:32px}.projects-pill{font-size:.75rem;padding:6px 14px;border-radius:999px;border:1px solid rgba(38,38,38,1);background:#171717d9;color:#a3a3a3;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background .16s ease,color .16s ease,box-shadow .16s ease}.projects-pill:hover{transform:translateY(-2px);border-color:#a78bfa99;background:#262626cc;color:#ffffffe6;box-shadow:0 8px 20px #00000059}.projects-pill.active{border-color:#a78bfab3;color:#a78bfa;background:#581c8726}.projects-grid{display:grid;gap:32px}@media(min-width:768px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.projects-grid{grid-template-columns:repeat(3,1fr)}}.projects-empty{color:#ffffff80}.resume-page{max-width:900px;margin:0 auto;padding:60px 20px;color:#e5e5e5;background:transparent;line-height:1.6}.resume-name{font-size:3rem;text-align:center;font-weight:700;margin-bottom:10px;color:#f5f5f5}.resume-contact-row{text-align:center;font-size:.95rem;margin-bottom:50px;color:#b5b5b5}.resume-contact-row a{color:#cfcfcf;text-decoration:none}.resume-contact-row a:hover{text-decoration:underline}.divider{margin:0 8px;color:#555}.resume-section{margin-bottom:55px}.section-title{font-size:1.6rem;font-weight:700;margin-bottom:10px;color:#f0f0f0}.section-divider{width:100%;height:2px;background:#333;margin-bottom:25px}.resume-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:35px;gap:40px}.item-title{font-size:1.1rem;font-weight:600;margin-bottom:8px;color:#eaeaea}.item-sub{font-size:.95rem;color:#bfbfbf;margin-bottom:4px}.date-text{white-space:nowrap;font-size:.95rem;color:#bcbcbc}.bullet-list{list-style:none;padding-left:0;margin-top:6px;color:#d0d0d0}.bullet-list li{position:relative;padding-left:18px;margin-bottom:8px}.bullet-list li:before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:#60a5fa}.skills-line{margin-bottom:8px;color:#d2d2d2;font-size:1rem}strong{color:#f0f0f0}*,: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 / .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 / .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: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,ui-sans-serif,system-ui,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,samp,pre{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,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,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{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}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.fixed{position:fixed}.relative{position:relative}.bottom-24{bottom:6rem}.bottom-6{bottom:1.5rem}.left-6{left:1.5rem}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.mb-3{margin-bottom:.75rem}.mb-6{margin-bottom:1.5rem}.mt-16{margin-top:4rem}.mt-6{margin-top:1.5rem}.flex{display:flex}.grid{display:grid}.h-12{height:3rem}.h-\[32rem\]{height:32rem}.min-h-screen{min-height:100vh}.w-12{width:3rem}.w-80{width:20rem}.max-w-2xl{max-width:42rem}.max-w-6xl{max-width:72rem}.flex-1{flex:1 1 0%}.flex-col{flex-direction:column}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.rounded-2xl{border-radius:1rem}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-neutral-700{--tw-border-opacity: 1;border-color:rgb(64 64 64 / var(--tw-border-opacity, 1))}.border-neutral-900{--tw-border-opacity: 1;border-color:rgb(23 23 23 / var(--tw-border-opacity, 1))}.bg-black{--tw-bg-opacity: 1;background-color:rgb(0 0 0 / var(--tw-bg-opacity, 1))}.bg-neutral-900\/90{background-color:#171717e6}.bg-neutral-950{--tw-bg-opacity: 1;background-color:rgb(10 10 10 / var(--tw-bg-opacity, 1))}.object-contain{-o-object-fit:contain;object-fit:contain}.p-4{padding:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-20{padding-top:5rem;padding-bottom:5rem}.py-24{padding-top:6rem;padding-bottom:6rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.text-center{text-align:center}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.text-accent{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity, 1))}.text-neutral-200{--tw-text-opacity: 1;color:rgb(229 229 229 / var(--tw-text-opacity, 1))}.text-neutral-400{--tw-text-opacity: 1;color:rgb(163 163 163 / var(--tw-text-opacity, 1))}.text-neutral-600{--tw-text-opacity: 1;color:rgb(82 82 82 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.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)}:root{color-scheme:dark}body{margin:0;color:#fff;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(1000px 600px at 20% 0%,rgba(139,92,246,.18),transparent 65%),radial-gradient(900px 600px at 80% 10%,rgba(99,102,241,.14),transparent 65%),linear-gradient(135deg,#0a0a16,#0d1020,#0b0f1c)}.text-accent{color:#60a5fa}.muted{color:#ffffffb8}.hr{height:1px;background:#ffffff1a;border:0;margin:18px 0}.scroll-top-button{position:fixed;right:2.4rem;bottom:17rem;z-index:9999;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);padding:12px;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;transition:background .2s ease,transform .2s ease}.scroll-top-button:hover{background:#ffffff26;transform:translateY(-2px)}.page{min-height:100vh;padding:56px 16px;color:#ffffffeb;background:transparent}.container{max-width:980px;margin:0 auto}.card{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 10px 30px #00000073,0 1px #ffffff0d inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.cardPad{padding:28px}.hero{margin-bottom:18px}.heroTitle{font-size:34px;margin:0 0 8px;letter-spacing:-.02em}.heroSub{margin:0;max-width:70ch}.grid2{display:grid;grid-template-columns:1fr;gap:18px}@media(min-width:900px){.grid2{grid-template-columns:.9fr 1.1fr;align-items:start}}.pillList{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.pill{font-size:13px;padding:8px 10px;border-radius:999px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:#ffffffd9}@media(min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:text-5xl{font-size:3rem;line-height:1}}@media(min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}.floating-icons{position:fixed;bottom:24px;right:24px;z-index:50;display:flex;flex-direction:column;gap:16px;padding:16px;border-radius:20px;background:#171717bf;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(63,63,70,.8);box-shadow:0 20px 40px #00000073,0 0 0 1px #ffffff08 inset;transition:transform .2s ease}.floating-icon{display:flex;align-items:center;justify-content:center;padding:10px;border-radius:14px;color:#d1d5dbe6;transition:transform .16s ease,background .16s ease,box-shadow .16s ease,color .16s ease}.floating-icon:hover{transform:translateY(-4px);background:#262626cc;box-shadow:0 10px 25px #0006,0 0 0 1px #a78bfa26}.accent-blue{color:#60a5fa}.accent-green{color:#34d399}.floating-icons{animation:floatFadeIn .4s ease-out}@keyframes floatFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes chatbot-slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.chatbot-window{animation:chatbot-slide-up .25s ease-out forwards;box-shadow:0 8px 20px #00000080;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.chatbot-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding-bottom:10px;margin-bottom:10px;border-bottom:1px solid rgba(255,255,255,.1)}.chatbot-title{font-size:15px;font-weight:700;color:#ffffffeb;line-height:1.2}.chatbot-subtitle{font-size:12px;color:#ffffffa6;margin-top:2px;line-height:1.2}.chatbot-close{background:transparent;border:1px solid rgba(255,255,255,.12);color:#ffffffbf;width:30px;height:30px;border-radius:10px;cursor:pointer;transition:background .15s ease,transform .15s ease}.chatbot-close:hover{background:#ffffff0f;transform:translateY(-1px)}.chatbot-close:focus-visible{outline:2px solid rgba(96,165,250,.7);outline-offset:2px}.chatbot-empty{padding:12px;border-radius:14px;border:1px dashed rgba(255,255,255,.18);background:#ffffff08;margin-bottom:12px}.chatbot-empty-title{font-size:12px;color:#ffffffb8;margin-bottom:10px}.chatbot-empty-pills{display:flex;flex-wrap:wrap;gap:8px}.chatbot-pill{font-size:12px;padding:7px 10px;border-radius:999px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:#ffffffd9;cursor:pointer;transition:background .15s ease,transform .15s ease;text-align:left}.chatbot-pill:hover{background:#ffffff1a;transform:translateY(-1px)}.chatbot-pill:focus-visible{outline:2px solid rgba(96,165,250,.7);outline-offset:2px}.chat-message{padding:8px 12px;border-radius:1rem;max-width:75%;margin:6px 0;word-wrap:break-word;white-space:pre-wrap}.chat-message.user{align-self:flex-end;background:#3b82f699;color:#fff}.chat-message.bot{align-self:flex-start;background:#262626b3;color:#e5e7eb}.chat-message.loading{font-style:italic;color:#9ca3af}.chat-scroll{overflow-y:auto;scrollbar-width:thin;scrollbar-color:#4b5563 #1f2937;max-height:24rem}.chat-scroll::-webkit-scrollbar{width:6px}.chat-scroll::-webkit-scrollbar-track{background:#1f2937;border-radius:3px}.chat-scroll::-webkit-scrollbar-thumb{background-color:#4b5563;border-radius:3px}.chat-input{background-color:#26262699;border:1px solid #3f3f46;border-radius:.75rem;color:#e5e7eb;padding:.5rem .75rem;width:100%;outline:none;resize:none;overflow-y:hidden;min-height:2.2rem;max-height:8rem;line-height:1.4rem}.chat-input::-moz-placeholder{color:#6b7280}.chat-input::placeholder{color:#6b7280}.chat-input:focus{border-color:#60a5fa}.chat-send{background-color:#2563eb;color:#fff;border:none;border-radius:.75rem;padding:.5rem 1rem;cursor:pointer;transition:background .2s,transform .15s ease}.chat-send:hover{background-color:#3b82f6;transform:translateY(-1px)}.chat-send:disabled{opacity:.6;cursor:not-allowed;transform:none}.chat-float-button{background-color:#171717b3;border:1px solid #3f3f46;border-radius:50%;width:4rem;height:4rem;padding:.5rem;display:flex;justify-content:center;align-items:center;box-shadow:0 4px 10px #00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;transition:background-color .2s,transform .15s ease}.chat-float-button:hover{background-color:#262626cc;transform:translateY(-1px)}.chat-float-button:focus-visible{outline:2px solid rgba(96,165,250,.7);outline-offset:3px}
