/*! tailwindcss v4.1.14 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-duration:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-gray-800:oklch(27.8% .033 256.848);--color-black:#000;--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:1rem;--text-base--line-height: 1.5 ;--font-weight-medium:500;--radius-lg:.5rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg,#1e1e1e);color:var(--color-fg,#d4d4d4);margin:0;font-family:Monaco,Menlo,Ubuntu Mono,monospace}*{box-sizing:border-box}}@layer components;@layer utilities{.absolute{position:absolute}.relative{position:relative}.top-full{top:100%}.right-0{right:calc(var(--spacing)*0)}.z-\[1000\]{z-index:1000}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.mt-1{margin-top:calc(var(--spacing)*1)}.box-border{box-sizing:border-box}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.inline-block{display:inline-block}.h-8{height:calc(var(--spacing)*8)}.w-5{width:calc(var(--spacing)*5)}.w-full{width:100%}.max-w-\[120px\]{max-width:120px}.min-w-\[160px\]{min-width:160px}.min-w-\[200px\]{min-width:200px}.cursor-pointer{cursor:pointer}.grid-cols-\[1fr_auto_1fr\]{grid-template-columns:1fr auto 1fr}.items-center{align-items:center}.gap-2{gap:calc(var(--spacing)*2)}.justify-self-end{justify-self:flex-end}.justify-self-start{justify-self:flex-start}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.rounded-lg{border-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-none{--tw-border-style:none;border-style:none}.border-black\/10{border-color:#0000001a}@supports (color:color-mix(in lab,red,red)){.border-black\/10{border-color:color-mix(in oklab,var(--color-black)10%,transparent)}}.bg-white\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.bg-white\/10{background-color:color-mix(in oklab,var(--color-white)10%,transparent)}}.bg-white\/95{background-color:#fffffff2}@supports (color:color-mix(in lab,red,red)){.bg-white\/95{background-color:color-mix(in oklab,var(--color-white)95%,transparent)}}.bg-none{background-image:none}.p-2\.5{padding:calc(var(--spacing)*2.5)}.px-3{padding-inline:calc(var(--spacing)*3)}.py-1\.5{padding-block:calc(var(--spacing)*1.5)}.text-center{text-align:center}.text-left{text-align:left}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.text-ellipsis{text-overflow:ellipsis}.whitespace-nowrap{white-space:nowrap}.text-gray-800{color:var(--color-gray-800)}.text-white{color:var(--color-white)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a),0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}@media(hover:hover){.hover\:bg-black\/5:hover{background-color:#0000000d}@supports (color:color-mix(in lab,red,red)){.hover\:bg-black\/5:hover{background-color:color-mix(in oklab,var(--color-black)5%,transparent)}}}}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-duration{syntax:"*";inherits:false}.App{height:100vh;display:flex;flex-direction:column}.header-bar{display:flex;justify-content:space-between;align-items:center;background-color:var(--color-status, #007acc);color:#fff;padding:8px 16px;font-size:14px}.header-title{font-weight:700}.header-controls{display:flex;align-items:center;gap:12px}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.vim-editor{flex:1;display:flex;flex-direction:column;background-color:var(--color-bg, #1e1e1e);color:var(--color-fg, #d4d4d4);font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:16px;outline:none;padding:10px}.editor-content{flex:1;overflow-y:auto;padding:10px}.editor-line{display:flex;min-height:20px;line-height:20px;white-space:pre}.line-number{display:inline-block;width:40px;text-align:right;color:var(--color-comment, #858585);margin-right:20px;-webkit-user-select:none;user-select:none}.line-content{flex:1;white-space:pre}.cursor{background-color:var(--color-cursor, #ffffff);color:var(--color-bg, #1e1e1e);animation:blink 1s step-end infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.status-bar{display:flex;justify-content:space-between;align-items:center;background-color:var(--color-status, #007acc);color:#fff;padding:5px 10px;font-size:14px;border-top:1px solid var(--color-line, #2d2d30)}.status-message{flex:1}.command-buffer{margin:0 10px;font-weight:700}.cursor-position{font-size:12px}.file-info{display:flex;align-items:center;gap:8px;margin:0 10px}.file-name{font-size:12px;color:var(--color-comment, #858585);font-family:Monaco,Menlo,Ubuntu Mono,monospace;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.unsaved-indicator{color:var(--color-warning, #ffcc02);font-weight:700;font-size:12px}.file-handle-indicator,.cloud-indicator{font-size:12px;margin-left:4px;opacity:.8}.save-success-indicator{font-size:12px;margin-left:4px;color:#4caf50;animation:pulse .5s ease-in-out}.save-error-indicator{font-size:12px;margin-left:4px;color:#f44336;animation:pulse .5s ease-in-out}.save-saving-indicator{font-size:12px;margin-left:4px;color:#ff9800;animation:spin 1s linear infinite}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.filename-prompt-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.filename-prompt-dialog{background-color:var(--color-bg, #1e1e1e);border:1px solid var(--color-line, #2d2d30);border-radius:8px;padding:20px;min-width:300px;box-shadow:0 4px 20px #00000080}.filename-prompt-dialog h3{margin:0 0 15px;color:var(--color-fg, #d4d4d4);font-size:16px;font-weight:400}.filename-prompt-dialog input{width:100%;padding:8px 12px;background-color:var(--color-bg-secondary, #2d2d30);border:1px solid var(--color-line, #2d2d30);border-radius:4px;color:var(--color-fg, #d4d4d4);font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:14px;margin-bottom:15px;box-sizing:border-box;outline:none;user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text}.filename-prompt-dialog input:focus{outline:none;border-color:var(--color-status, #007acc);box-shadow:0 0 0 2px #007acc33}.filename-prompt-buttons{display:flex;gap:10px;justify-content:flex-end}.filename-prompt-buttons button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.save-button{background-color:var(--color-status, #007acc);color:#fff}.save-button:hover{background-color:#005a9e}.cancel-button{background-color:var(--color-bg-secondary, #2d2d30);color:var(--color-fg, #d4d4d4);border:1px solid var(--color-line, #2d2d30)}.cancel-button:hover{background-color:var(--color-line, #2d2d30)}.file-list-dialog{background-color:var(--color-bg, #1e1e1e);border:1px solid var(--color-line, #2d2d30);border-radius:8px;padding:20px;min-width:400px;max-width:600px;max-height:70vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000080}.file-list-dialog h3{margin:0 0 15px;color:var(--color-fg, #d4d4d4);font-size:16px;font-weight:400}.file-list{flex:1;overflow-y:auto;margin-bottom:15px;border:1px solid var(--color-line, #2d2d30);border-radius:4px;max-height:400px}.file-list-item{padding:12px 16px;border-bottom:1px solid var(--color-line, #2d2d30);cursor:pointer;transition:background-color .2s}.file-list-item:last-child{border-bottom:none}.file-list-item:hover{background-color:var(--color-bg-secondary, #2d2d30)}.file-list-item .file-name{color:var(--color-fg, #d4d4d4);font-size:14px;font-weight:500;margin-bottom:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.file-list-item .file-meta{display:flex;gap:12px;font-size:12px;color:var(--color-comment, #858585)}.loading-message,.no-files-message{padding:40px 20px;text-align:center;color:var(--color-comment, #858585);font-size:14px}.syntax-comment{color:var(--color-comment, #6a9955)}.syntax-keyword{color:var(--color-keyword, #569cd6);font-weight:700}.syntax-string{color:var(--color-string, #ce9178)}.syntax-number{color:var(--color-number, #b5cea8)}.syntax-function{color:var(--color-function, #dcdcaa)}.syntax-variable{color:var(--color-variable, #9cdcfe)}.syntax-type{color:var(--color-type, #4ec9b0)}.syntax-constant{color:var(--color-constant, #4fc1ff)}.syntax-error{color:var(--color-error, #f44747);background-color:#f447471a}.syntax-warning{color:var(--color-warning, #ffcc02)}.syntax-info{color:var(--color-info, #75beff)}.file-upload-container{display:flex;align-items:center;gap:12px;padding:8px 12px;background-color:var(--color-line, #2d2d30);border-bottom:1px solid var(--color-line, #2d2d30)}.file-actions{display:flex;gap:8px}.file-button{display:flex;align-items:center;gap:6px;padding:6px 12px;background-color:var(--color-bg, #1e1e1e);color:var(--color-fg, #d4d4d4);border:1px solid var(--color-line, #2d2d30);border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s;white-space:nowrap}.file-button:hover:not(:disabled){background-color:var(--color-line, #2d2d30);border-color:var(--color-status, #007acc)}.file-button:disabled{opacity:.5;cursor:not-allowed}.file-button-upload:hover:not(:disabled){color:#4ade80;border-color:#4ade80}.file-button-download:hover:not(:disabled){color:#60a5fa;border-color:#60a5fa}.file-button-cloud:hover:not(:disabled){color:#a78bfa;border-color:#a78bfa}.file-icon{width:14px;height:14px;flex-shrink:0}.file-info{display:flex;align-items:center;margin-left:auto}.file-name{font-size:12px;color:var(--color-comment, #858585);font-family:Monaco,Menlo,Ubuntu Mono,monospace;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-api-status{margin-top:.5rem;font-size:.75rem;padding:.25rem .5rem;border-radius:.25rem;background-color:var(--color-bg, #1e1e1e);border:1px solid var(--color-line, #2d2d30);font-family:Monaco,Menlo,Ubuntu Mono,monospace}.api-available{color:#10b981;font-weight:500}.api-unavailable{color:#f59e0b;font-weight:500}@media(max-width:640px){.file-upload-container{flex-wrap:wrap;gap:8px}.file-actions{flex:1;min-width:0}.file-button span{display:none}.file-button{padding:6px;min-width:32px;justify-content:center}.file-info{margin-left:0;width:100%}}.theme-switcher-button{display:flex;align-items:center;gap:8px;padding:6px 12px;background-color:#374151;color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .2s;height:32px;box-sizing:border-box}.theme-switcher-button:hover{background-color:#4b5563}.theme-icon{width:16px;height:16px}.theme-label{display:none}@media(min-width:640px){.theme-label{display:inline}}.theme-arrow{width:12px;height:12px}.theme-dropdown{position:absolute;right:0;top:100%;margin-top:4px;width:192px;background-color:#1f2937;border:1px solid #4b5563;border-radius:6px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;z-index:50}.theme-dropdown-content{padding:4px 0}.theme-option{width:100%;text-align:left;padding:8px 16px;font-size:14px;background:none;border:none;color:#d1d5db;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background-color .2s}.theme-option:hover{background-color:#374151}.theme-option-active{background-color:#374151;color:#60a5fa}.theme-check{width:16px;height:16px}.theme-overlay{position:fixed;inset:0;z-index:40}.login-button-container{position:relative;display:inline-block}.login-button{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;background:#ffffff1a;border:none;border-radius:4px;padding:6px 12px;color:#fff;cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500;white-space:nowrap;height:32px;box-sizing:border-box;min-width:200px}.login-button:hover{background:#fff3;transform:translateY(-1px)}.user-icon,.login-icon{font-size:16px;justify-self:start}.user-email{text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px}.dropdown-arrow{font-size:10px;transition:transform .2s ease;justify-self:end}.login-button:hover .dropdown-arrow{transform:translateY(1px)}.dropdown-menu{position:absolute;top:100%;right:0;background:#fffffff2;border:1px solid rgba(0,0,0,.1);border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:160px;z-index:1000;margin-top:4px;overflow:hidden}.dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 16px;background:none;border:none;color:#333;cursor:pointer;transition:background-color .2s ease;font-size:14px;text-align:left}.dropdown-item:hover{background:#0000000d}.dropdown-item:first-child{border-bottom:1px solid rgba(0,0,0,.1)}.dropdown-icon{font-size:16px;width:20px;text-align:center}@media(prefers-color-scheme:dark){.login-button{background:#ffffff1a}.login-button:hover{background:#fff3}.dropdown-menu{background:#1e1e1ef2;border-color:#ffffff1a;box-shadow:0 4px 12px #0000004d}.dropdown-item{color:#fff}.dropdown-item:hover{background:#ffffff1a}.dropdown-item:first-child{border-bottom-color:#ffffff1a}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;padding:40px;width:100%;max-width:400px;animation:slideUp .3s ease-out}.login-card h2{text-align:center;margin-bottom:30px;color:#333;font-size:28px;font-weight:600}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:500;color:#555;font-size:14px}.form-group input{padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;transition:border-color .2s ease;background:#fafbfc}.form-group input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.error-message{background:#fee;color:#c53030;padding:12px 16px;border-radius:8px;font-size:14px;border:1px solid #feb2b2}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:14px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:10px}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}.submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.toggle-auth{margin-top:24px;text-align:center;padding-top:20px;border-top:1px solid #e1e5e9}.toggle-auth p{color:#666;font-size:14px;margin:0}.toggle-button{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;text-decoration:underline;margin-left:8px;font-size:14px}.toggle-button:hover{color:#5a67d8}.divider{display:flex;align-items:center;margin:20px 0;text-align:center}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#e1e5e9}.divider span{padding:0 16px;color:#666;font-size:14px;background:#fff}.google-button{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;background:#fff;color:#333;border:2px solid #e1e5e9;padding:12px 16px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-top:8px}.google-button:hover:not(:disabled){border-color:#4285f4;box-shadow:0 2px 8px #4285f41a}.google-button:disabled{opacity:.6;cursor:not-allowed}.google-icon{width:20px;height:20px}@media(prefers-color-scheme:dark){.login-card{background:#1a202c;color:#e2e8f0}.login-card h2{color:#e2e8f0}.form-group label{color:#a0aec0}.form-group input{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.form-group input:focus{background:#2d3748;border-color:#667eea}.toggle-auth{border-top-color:#4a5568}.toggle-auth p{color:#a0aec0}.divider:before,.divider:after{background:#4a5568}.divider span{background:#1a202c;color:#a0aec0}.google-button{background:#2d3748;color:#e2e8f0;border-color:#4a5568}.google-button:hover:not(:disabled){border-color:#4285f4}}.user-profile{position:relative;display:inline-block}.profile-button{display:flex;align-items:center;gap:8px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:8px 12px;color:#fff;cursor:pointer;transition:all .2s ease;font-size:14px}.profile-button:hover{background:#fff3;border-color:#ffffff4d}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;color:#fff}.user-email{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-arrow{font-size:10px;transition:transform .2s ease}.profile-button:hover .dropdown-arrow{transform:rotate(180deg)}.profile-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border-radius:12px;box-shadow:0 10px 30px #00000026;border:1px solid #e1e5e9;min-width:280px;z-index:1000;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.profile-info{padding:20px;border-bottom:1px solid #e1e5e9}.profile-header{display:flex;align-items:center;gap:12px}.profile-avatar-large{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px;color:#fff}.profile-details{flex:1}.profile-email{font-weight:600;color:#333;font-size:16px;margin-bottom:4px}.profile-uid{color:#666;font-size:12px;font-family:monospace}.profile-actions{padding:16px 20px}.signout-button{width:100%;background:#e53e3e;color:#fff;border:none;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.signout-button:hover:not(:disabled){background:#c53030;transform:translateY(-1px)}.signout-button:disabled{opacity:.6;cursor:not-allowed;transform:none}@media(prefers-color-scheme:dark){.profile-dropdown{background:#1a202c;border-color:#4a5568}.profile-info{border-bottom-color:#4a5568}.profile-email{color:#e2e8f0}.profile-uid{color:#a0aec0}}.login-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column}.login-page-header{display:flex;align-items:center;justify-content:space-between;padding:20px;color:#fff}.login-page-header h1{margin:0;font-size:24px;font-weight:600}.back-button{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:8px 16px;color:#fff;cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500}.back-button:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-1px)}.login-page-content{flex:1;display:flex;align-items:center;justify-content:center;padding:20px}.user-dashboard{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;padding:40px;max-width:500px;width:100%;animation:slideUp .3s ease-out}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #e1e5e9}.dashboard-header h1{margin:0;color:#333;font-size:28px;font-weight:600}.user-info{text-align:center}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;color:#fff}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media(prefers-color-scheme:dark){.user-dashboard{background:#1a202c;color:#e2e8f0}.dashboard-header{border-bottom-color:#4a5568}.dashboard-header h1{color:#e2e8f0}}.profile-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.profile-container{max-width:800px;margin:0 auto;background:#fffffff2;border-radius:12px;box-shadow:0 8px 32px #0000001a;overflow:hidden}.profile-header{display:flex;align-items:center;gap:20px;padding:20px 30px;background:#ffffff1a;border-bottom:1px solid rgba(0,0,0,.1)}.back-button{background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:8px 16px;color:#333;cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500}.back-button:hover{background:#ffffff4d;transform:translateY(-1px)}.profile-header h1{margin:0;color:#333;font-size:24px;font-weight:600}.profile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.profile-content{padding:30px}.profile-info{display:flex;gap:30px;margin-bottom:40px}.profile-avatar{flex-shrink:0;width:120px;height:120px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0000001a}.avatar-icon{font-size:48px;color:#fff}.profile-details{flex:1;min-width:0}.profile-display h2{margin:0 0 8px;color:#333;font-size:28px;font-weight:600}.user-email{color:#666;font-size:16px;margin-bottom:20px}.profile-bio,.profile-website,.profile-location{margin-bottom:20px}.profile-bio h3,.profile-website h3,.profile-location h3{margin:0 0 8px;color:#333;font-size:16px;font-weight:600}.profile-bio p,.profile-location p{margin:0;color:#666;line-height:1.5}.profile-website a{color:#667eea;text-decoration:none;font-weight:500}.profile-website a:hover{text-decoration:underline}.edit-button{background:#667eea;color:#fff;border:none;border-radius:6px;padding:10px 20px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;margin-top:20px}.edit-button:hover{background:#5a6fd8;transform:translateY(-1px)}.profile-form{width:100%}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;color:#333;font-weight:500;font-size:14px}.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s ease;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;gap:12px;margin-top:30px}.save-button{background:#667eea;color:#fff;border:none;border-radius:6px;padding:10px 20px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.save-button:hover:not(:disabled){background:#5a6fd8;transform:translateY(-1px)}.save-button:disabled{background:#ccc;cursor:not-allowed;transform:none}.cancel-button{background:transparent;color:#666;border:1px solid #ddd;border-radius:6px;padding:10px 20px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.cancel-button:hover{background:#f5f5f5;border-color:#ccc}.profile-stats{background:#f8f9fa;border-radius:8px;padding:20px}.profile-stats h3{margin:0 0 20px;color:#333;font-size:18px;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.stat-item{display:flex;flex-direction:column;gap:4px}.stat-label{color:#666;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-value{color:#333;font-size:14px;font-weight:500}.error-message{background:#fee;color:#c33;padding:12px 16px;border-radius:6px;margin:20px 30px;border:1px solid #fcc;font-size:14px}@media(prefers-color-scheme:dark){.profile-page{background:linear-gradient(135deg,#2d3748,#4a5568)}.profile-container{background:#2d3748f2;color:#e2e8f0}.profile-header{background:#ffffff0d;border-bottom-color:#ffffff1a}.back-button{background:#ffffff1a;border-color:#fff3;color:#e2e8f0}.back-button:hover{background:#fff3}.profile-header h1,.profile-display h2{color:#e2e8f0}.user-email{color:#a0aec0}.profile-bio h3,.profile-website h3,.profile-location h3{color:#e2e8f0}.profile-bio p,.profile-location p{color:#a0aec0}.profile-website a{color:#90cdf4}.form-group label{color:#e2e8f0}.form-group input,.form-group textarea{background:#ffffff1a;border-color:#fff3;color:#e2e8f0}.form-group input:focus,.form-group textarea:focus{border-color:#90cdf4;box-shadow:0 0 0 3px #90cdf41a}.profile-stats{background:#ffffff0d}.profile-stats h3{color:#e2e8f0}.stat-label{color:#a0aec0}.stat-value{color:#e2e8f0}.error-message{background:#dc26261a;color:#fca5a5;border-color:#dc262633}}.adsense-container{margin:20px 0;text-align:center;background:var(--bg-secondary, #f5f5f5);border-radius:8px;padding:10px;border:1px solid var(--border-color, #e0e0e0)}.adsense-top{margin-bottom:20px}.adsense-bottom{margin-top:20px}.adsense-sidebar{position:fixed;right:20px;top:50%;transform:translateY(-50%);width:300px;z-index:1000}.adsense-ad{min-height:90px;display:flex;align-items:center;justify-content:center}@media(max-width:768px){.adsense-sidebar{position:static;transform:none;width:100%;margin:20px 0}.adsense-container{margin:10px 0;padding:5px}}[data-theme=dark] .adsense-container{background:var(--bg-secondary, #2a2a2a);border-color:var(--border-color, #404040)}@media print{.adsense-container{display:none!important}}
