:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;height:100%;width:100%}#root{height:100%;width:100%}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.faq-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem;position:relative}.camera-logo svg{width:160px;height:160px}.camera-logo:hover{transform:scale(1.1)}.camera-logo:focus{outline:2px solid rgba(255,255,255,.8);outline-offset:2px;border-radius:8px}.faq-container{background:#fffffff2;border-radius:16px;padding:3rem 2rem;max-width:800px;width:100%;margin:0 auto;box-shadow:0 10px 40px #0003}.faq-container h1{text-align:center;color:#333;font-size:2.5rem;margin-bottom:2rem;font-weight:700}.faq-list{display:flex;flex-direction:column;gap:1rem}.faq-item{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;transition:box-shadow .2s ease}.faq-item:hover{box-shadow:0 2px 8px #0000001a}.faq-question{width:100%;padding:1.25rem 1.5rem;background:#fff;border:none;text-align:left;font-size:1.1rem;font-weight:600;color:#333;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background-color .2s ease}.faq-question:hover{background-color:#f8f9fa}.faq-question:focus{outline:2px solid #667eea;outline-offset:-2px}.faq-icon{flex-shrink:0;color:#667eea;transition:transform .3s ease}.faq-icon.open{transform:rotate(180deg)}.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;background:#f8f9fa}.faq-answer.open{max-height:500px;padding:1.5rem}.faq-answer p{color:#555;line-height:1.6;margin:0}@media(max-width:768px){.faq-page{padding:8rem 1rem 1rem}.camera-logo{top:.75rem;left:.75rem}.camera-logo svg{width:128px;height:128px}.faq-container{padding:2rem 1.25rem;margin-top:0}.faq-container h1{font-size:1.8rem;margin-bottom:1.5rem}.faq-question{padding:1rem 1.25rem;font-size:1rem}.faq-answer.open{padding:1.25rem}.faq-answer p{font-size:.95rem}}@media(max-width:480px){.faq-page{padding:7rem .75rem .75rem}.camera-logo{top:.5rem;left:.5rem}.camera-logo svg{width:112px;height:112px}.faq-container{padding:1.5rem 1rem;margin-top:0}.faq-container h1{font-size:1.5rem;margin-bottom:1rem}.faq-question{padding:.875rem 1rem;font-size:.95rem}.faq-answer.open{padding:1rem}.faq-answer p{font-size:.9rem}}.dark-mode .faq-page{background:linear-gradient(135deg,#1a1a1a,#2d2d2d)}.dark-mode .faq-container{background:#282828f2;box-shadow:0 10px 40px #0006}.dark-mode .faq-container h1{color:#e0e0e0}.dark-mode .faq-item{border-color:#8080804d}.dark-mode .faq-item:hover{box-shadow:0 2px 8px #0000004d}.dark-mode .faq-question{background:#323232cc;color:#e0e0e0}.dark-mode .faq-question:hover{background-color:#3c3c3ccc}.dark-mode .faq-question:focus{outline-color:#888}.dark-mode .faq-icon{color:#888}.dark-mode .faq-answer{background:#2d2d2dcc}.dark-mode .faq-answer p{color:#b0b0b0}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;width:100%;overflow-x:hidden}.app{position:relative;height:100vh;width:100%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;overflow:hidden}.camera-logo{position:absolute;top:1rem;left:1rem;cursor:pointer;transition:transform .2s ease;z-index:10}.camera-logo svg{width:56px;height:56px}.theme-toggle-btn{position:absolute;top:1rem;right:1rem;background:#fff3;border:none;border-radius:50%;width:56px;height:56px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 8px #0000001a;z-index:10}.theme-toggle-btn:hover{background:#ffffff4d;transform:scale(1.05);box-shadow:0 4px 12px #0003}.theme-toggle-btn:focus{outline:2px solid rgba(255,255,255,.8);outline-offset:2px}.theme-toggle-btn svg{width:40px;height:40px;color:#fff}.faq-link{position:absolute;bottom:1rem;right:1rem;z-index:10;min-width:fit-content;max-width:fit-content;white-space:nowrap;padding:6px 12px;font-size:.875rem}@media(max-width:768px){.faq-link{padding:4px 8px;font-size:.75rem;bottom:.75rem;right:.75rem;max-width:60px}}.camera-logo:hover{transform:scale(1.05)}.camera-logo:focus{outline:2px solid rgba(255,255,255,.8);outline-offset:2px}.header{text-align:center;padding:2rem 1rem;color:#fff}.header h1{font-size:3rem;font-weight:700;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.header p{font-size:1.2rem;opacity:.9}.main{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:.5rem;overflow:auto;position:relative}.upload-area{background:#fffffff2;border-radius:16px;padding:4rem 3rem;max-width:600px;width:100%;cursor:pointer;transition:all .3s ease;box-shadow:0 10px 40px #0003}.upload-area:hover{transform:translateY(-5px);box-shadow:0 15px 50px #0000004d}.upload-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.upload-icon{width:80px;height:80px;color:#667eea}.upload-area p{font-size:1.2rem;color:#333;font-weight:500;text-align:center}.upload-hint{font-size:.9rem;color:#666}.file-input{display:none}.workspace{background:#fffffff2;border-radius:16px;padding:0;max-width:100%;width:100%;height:100%;box-shadow:none;display:flex;flex-direction:column;position:relative}.panel-toggle-btn{position:absolute;top:1rem;right:1rem;z-index:100;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;padding:.5rem;cursor:pointer;display:none;align-items:center;justify-content:center;box-shadow:0 4px 12px #0003;transition:all .3s ease}.panel-toggle-btn:hover{transform:scale(1.05);box-shadow:0 6px 16px #0000004d}.panel-toggle-btn svg{width:24px;height:24px;color:#fff}.panel-overlay{position:absolute;inset:0;background:#00000080;z-index:50;display:none}.panel-overlay.overlay-visible{display:block}@media(max-width:768px){.panel-overlay.overlay-visible{position:fixed;z-index:55}}.workspace-content{display:flex;gap:2rem;flex:1;min-height:0}.left-panel{width:320px;min-width:320px;display:flex;flex-direction:column;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #0000001a}.panel-header{margin-bottom:1.5rem;padding-bottom:1rem;padding-top:.5rem;border-bottom:2px solid rgba(102,126,234,.2);display:flex;flex-direction:column;gap:.75rem;position:relative;min-height:45px}.panel-header h2{font-size:1.5rem;color:#667eea;font-weight:700;margin:0}.panel-header-actions{position:absolute;top:.5rem;left:0;z-index:10}.btn-download{padding:8px 16px;font-size:.9rem;display:inline-block}.processing-timer{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.75rem 1rem;border-radius:8px;font-size:.95rem;font-weight:600;text-align:center;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.85}}.drop-image-btn{align-self:flex-start;background:linear-gradient(135deg,#ff6b6b,#ee5a6f);font-size:.85rem;padding:8px 16px;border-radius:6px;transition:all .3s ease}.drop-image-btn:hover{background:linear-gradient(135deg,#ee5a6f,#ff6b6b);transform:translateY(-1px);box-shadow:0 4px 12px #ee5a6f4d}.panel-functions{flex:1;display:flex;flex-direction:column;gap:1rem;overflow-y:scroll;padding-right:12px;scrollbar-width:auto;scrollbar-color:rgba(102,126,234,.5) rgba(0,0,0,.08)}.panel-functions::-webkit-scrollbar{width:14px}.panel-functions::-webkit-scrollbar-track{background:#00000014;border-radius:7px}.panel-functions::-webkit-scrollbar-thumb{background:#667eea80;border-radius:7px;min-height:40px}.panel-functions::-webkit-scrollbar-thumb:hover{background:#667eeab3}.function-card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 2px 8px #00000014;transition:all .3s ease}.function-card:hover{box-shadow:0 4px 16px #667eea33}.function-card.active{border:2px solid #667eea}.function-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.function-icon{width:32px;height:32px;color:#667eea;flex-shrink:0}.function-header h3{font-size:1.1rem;color:#333;font-weight:600;margin:0}.function-description{font-size:.9rem;color:#666;margin-bottom:1rem;line-height:1.4}.angle-selector{margin-bottom:1rem}.angle-label{display:block;font-size:.85rem;color:#555;font-weight:500;margin-bottom:.5rem}.angle-controls{display:flex;flex-direction:column;gap:.5rem}.angle-select{width:100%;padding:.625rem;border:1px solid #ddd;border-radius:8px;font-size:.9rem;background-color:#fff;color:#333;cursor:pointer;transition:border-color .2s ease}.angle-select:hover{border-color:#667eea}.angle-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.angle-select:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.6}.angle-custom-input{width:100%;padding:.625rem;border:1px solid #ddd;border-radius:8px;font-size:.9rem;background-color:#fff;color:#333;transition:border-color .2s ease}.angle-custom-input:hover{border-color:#667eea}.angle-custom-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.angle-custom-input:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.6}.angle-custom-input::placeholder{color:#999}.function-actions{display:flex;flex-direction:column;gap:.75rem}.panel-footer{margin-top:auto;padding-top:1rem;border-top:2px solid rgba(102,126,234,.2)}.right-panel{flex:1;display:flex;flex-direction:column;min-width:0}.mode-switcher{display:flex;gap:.75rem;margin-bottom:1rem;justify-content:center;flex-wrap:wrap}.mode-btn{padding:10px 24px;border:2px solid #667eea;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;background:#fff;color:#667eea;text-transform:uppercase;letter-spacing:.5px}.mode-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.mode-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea}.btn-full{width:100%;text-align:center}.buttons{display:flex;gap:1rem}.example-showcase{background:#fffffff2;border-radius:16px;padding:2rem;max-width:1400px;width:100%;margin:0 auto 2rem;box-shadow:0 10px 40px #0003}.example-header{text-align:center;margin-bottom:2rem}.example-header h2{font-size:2rem;color:#667eea;font-weight:700;margin-bottom:.5rem}.example-header p{font-size:1.1rem;color:#666}.examples-row{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.examples-row+.examples-row{margin-top:2rem}.examples-row-bottom{justify-content:center}.example-card{flex:1 1 calc(33.333% - 1rem);min-width:320px;max-width:420px;background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 4px 12px #0000001a;display:flex;flex-direction:column;gap:1rem}.example-card-header{text-align:center}.example-card-header h3{font-size:1.25rem;color:#667eea;font-weight:700;margin-bottom:.25rem}.example-card-header p{font-size:.9rem;color:#666;margin:0}.example-container{display:flex;flex-direction:column;gap:1.5rem}.example-comparison-wrapper{width:100%}.example-comparison-wrapper .comparison-container{border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #00000026}.example-description{text-align:center;padding:.75rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:8px;border-left:4px solid #667eea}.example-description p{font-size:.9rem;color:#333;line-height:1.5;margin:0}.example-description strong{color:#667eea;font-weight:700}@media(max-width:768px){.example-showcase{padding:1.5rem}.example-header h2{font-size:1.5rem}.examples-row{flex-direction:column;align-items:center}.example-card{max-width:100%;min-width:unset}}.btn{padding:12px 32px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;text-align:center;display:inline-block}.btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #0003}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-success{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff}.btn-secondary{background:linear-gradient(135deg,#434343,#000);color:#fff}.processing-hint{font-size:.85rem;font-weight:400;opacity:.9;margin-left:.5rem;font-style:italic;text-transform:none;letter-spacing:normal}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1rem;text-align:center;font-weight:500}.image-container{display:flex;justify-content:center;align-items:center;min-height:400px;width:100%}.single-image{width:100%;max-width:800px}.single-image img{width:100%;height:auto;border-radius:8px;display:block;max-height:70vh;object-fit:contain}.comparison-container{width:100%;max-width:1000px;border-radius:8px;overflow:hidden;aspect-ratio:auto}.comparison-container>div{height:auto!important;min-height:50vh;max-height:75vh}.comparison-item{width:100%;height:100%;position:relative}.comparison-item img{width:100%;height:100%;object-fit:contain;display:block}.comparison-label{position:absolute;bottom:16px;left:50%;transform:translate(-50%);background:#000000b3;color:#fff;padding:8px 16px;border-radius:20px;font-size:.9rem;font-weight:500;white-space:nowrap}.dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.dialog{background:#fff;border-radius:16px;padding:2rem;max-width:400px;width:90%;box-shadow:0 20px 60px #0000004d;text-align:center}.dialog p{font-size:1.1rem;color:#333;margin-bottom:1.5rem;line-height:1.5}.dialog-buttons{display:flex;gap:1rem;justify-content:center}.dialog-buttons .btn{min-width:100px}@media(max-width:768px){.camera-logo{top:.75rem;left:.75rem;width:48px;height:48px}.camera-logo svg{width:34px;height:34px}.theme-toggle-btn{top:.75rem;right:.75rem;width:48px;height:48px}.theme-toggle-btn svg{width:34px;height:34px}.header{padding:6rem .5rem 1rem}.header h1{font-size:1.8rem}.header p{font-size:.9rem}.main{padding:1rem;padding-bottom:0}.upload-area{padding:2rem 1.5rem}.upload-icon{width:60px;height:60px}.upload-area p{font-size:1rem}.workspace{padding:0;max-height:calc(100vh - 120px);display:flex;flex-direction:column;overflow:hidden}.panel-toggle-btn{display:flex}.workspace-content{flex-direction:column;gap:1rem}.left-panel{width:100%;min-width:0;transition:all .3s ease}.left-panel.panel-hidden{display:none}.left-panel.panel-visible{display:flex;position:fixed;bottom:0;left:0;right:0;max-height:70vh;overflow-y:auto;z-index:60;border-radius:16px 16px 0 0;animation:slideUp .3s ease-out;box-shadow:0 -4px 20px #0000004d}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.panel-header h2{font-size:1.2rem}.function-card{padding:1rem}.function-header h3{font-size:1rem}.function-description{font-size:.85rem}.panel-functions{flex:0 1 auto;overflow-y:visible}.buttons{flex-direction:column;gap:.75rem;margin-bottom:1rem}.btn{width:100%;padding:10px 24px;font-size:.9rem}.image-container{flex:1;min-height:auto;display:flex;align-items:center;justify-content:center}.single-image{max-width:100%;width:100%}.single-image img{max-height:60vh;width:100%;object-fit:contain}.comparison-container{max-width:100%;width:100%}.comparison-container>div{min-height:55vh;max-height:70vh}.comparison-item img{width:100%;height:100%;object-fit:contain}.comparison-label{bottom:8px;padding:6px 12px;font-size:.8rem}}@media(max-width:480px){.camera-logo{top:.5rem;left:.5rem}.camera-logo svg{width:70px;height:70px}.theme-toggle-btn{top:.5rem;right:.5rem;width:56px;height:56px}.theme-toggle-btn svg{width:40px;height:40px}.header{padding-top:5rem}.header h1{font-size:1.5rem}.header p{font-size:.8rem}.workspace{padding:0;max-height:calc(100vh - 100px)}.buttons{margin-bottom:.75rem}.btn{padding:8px 20px;font-size:.85rem}.single-image img{max-height:50vh}.comparison-container>div{min-height:50vh;max-height:60vh}}.auth-page{position:relative;min-height:100vh;width:100%;background:linear-gradient(135deg,#667eea,#764ba2);display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto 1fr;grid-template-areas:"logo ." "auth showcase" "auth showcase";gap:1rem;padding:5rem 1rem 1rem}.auth-page>.header{grid-area:header;align-self:start;display:none}.auth-page>.example-showcase{grid-area:showcase;margin-top:1rem}.auth-container{background:#fffffff2;border-radius:16px;padding:2rem;max-width:450px;width:100%;box-shadow:0 10px 40px #0003;margin-top:1rem}.auth-container-compact{grid-area:auth;align-self:start;justify-self:start;background:#fffffff2;border-radius:12px;padding:1.25rem;width:300px;max-width:calc(100vw - 2rem);box-shadow:0 8px 24px #00000026;z-index:5;margin-top:1rem}.auth-form-compact{display:flex;flex-direction:column;gap:.75rem}.form-group-compact{display:flex;flex-direction:column;gap:.35rem}.form-group-compact label{font-weight:500;color:#333;font-size:.85rem}.form-group-compact input{padding:.6rem .75rem;border:2px solid #eee;border-radius:6px;font-size:.9rem;transition:border-color .3s ease}.form-group-compact input:focus{outline:none;border-color:#667eea}.form-group-compact input:disabled{background:#f5f5f5;color:#666}.auth-submit-compact{padding:.6rem 1rem;font-size:.9rem;margin-top:.5rem}.auth-tabs{display:flex;margin-bottom:1.5rem;border-bottom:2px solid #eee}.auth-tab{flex:1;padding:12px;border:none;background:none;font-size:1rem;font-weight:600;color:#666;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent;margin-bottom:-2px}.auth-tab.active{color:#667eea;border-bottom-color:#667eea}.auth-tab:hover:not(.active){color:#333}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:#333;font-size:.9rem}.form-group input{padding:12px;border:2px solid #eee;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background:#f5f5f5;color:#666}.auth-message{padding:12px;border-radius:8px;font-size:.9rem;text-align:center}.auth-message.error{background:#fee;color:#c33}.auth-message.success{background:#efe;color:#3a3}.auth-submit{margin-top:.5rem}.user-bar{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;background:#ffffff1a;border-radius:8px;margin-bottom:1rem}.user-email{color:#fff;font-size:.9rem}.btn-small{padding:6px 12px;font-size:.85rem}.faq-button{margin-left:auto}.btn-danger{background:linear-gradient(135deg,#ff416c,#ff4b2b);color:#fff}.account-info{margin-bottom:1.5rem}.status-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:500}.status-badge.confirmed{background:#efe;color:#3a3}.status-badge.unconfirmed{background:#ffe;color:#a83}.account-actions{display:flex;flex-direction:column;gap:.75rem}.delete-confirm{border-top:2px solid #eee;padding-top:1.5rem}.delete-confirm h3{color:#c33;margin-bottom:.5rem}.warning-text{color:#666;font-size:.9rem;margin-bottom:1rem}.delete-actions{display:flex;gap:1rem;margin-top:1rem}.loading-screen{position:fixed;inset:0;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;justify-content:center;align-items:center;color:#fff;gap:1rem}.loading-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.auth-page{display:flex;flex-direction:column;padding:5rem 1rem 1rem}.auth-container{padding:1.5rem}.auth-container-compact{position:relative;top:0;right:0;width:100%;max-width:100%;margin:1rem auto;justify-self:stretch;order:2}.auth-page>.header{display:none}.auth-page>.example-showcase{order:3;margin-top:1rem}.camera-logo{top:.5rem;left:.5rem}.theme-toggle-btn{top:.5rem;right:.5rem}.user-bar{flex-wrap:wrap;justify-content:center}.delete-actions{flex-direction:column}}.dark-mode .app{background:linear-gradient(135deg,#2a2a2a,#3d3d3d)}.dark-mode .theme-toggle-btn{background:#5a5a5a99;box-shadow:0 2px 8px #0000004d}.dark-mode .theme-toggle-btn:hover{background:#6e6e6eb3;box-shadow:0 4px 12px #0006}.dark-mode .header h1{text-shadow:2px 2px 4px rgba(0,0,0,.5)}.dark-mode .upload-area{background:#373737f2;box-shadow:0 10px 40px #0006}.dark-mode .upload-area:hover{box-shadow:0 15px 50px #00000080}.dark-mode .upload-area p{color:#f0f0f0}.dark-mode .upload-hint{color:#b0b0b0}.dark-mode .workspace{background:#373737f2}.dark-mode .left-panel{background:linear-gradient(135deg,#3a3a3a,#4a4a4a);box-shadow:0 4px 12px #0000004d}.dark-mode .panel-header{border-bottom-color:#a0a0a033}.dark-mode .panel-header h2{color:#e8e8e8}.dark-mode .function-card{background:#414141cc;box-shadow:0 2px 8px #0003}.dark-mode .function-card:hover{box-shadow:0 4px 16px #a0a0a04d}.dark-mode .function-card.active{border-color:#aaa}.dark-mode .function-header h3{color:#f0f0f0}.dark-mode .function-description{color:#c8c8c8}.dark-mode .angle-label{color:#e8e8e8}.dark-mode .angle-select,.dark-mode .angle-custom-input{background-color:#414141cc;color:#f0f0f0;border-color:#a0a0a04d}.dark-mode .angle-select:hover,.dark-mode .angle-custom-input:hover{border-color:#aaa}.dark-mode .angle-select:focus,.dark-mode .angle-custom-input:focus{border-color:#aaa;box-shadow:0 0 0 3px #a0a0a01a}.dark-mode .angle-select:disabled,.dark-mode .angle-custom-input:disabled{background-color:#32323280}.dark-mode .angle-custom-input::placeholder{color:#909090}.dark-mode .panel-footer{border-top-color:#a0a0a033}.dark-mode .mode-btn{background:#414141cc;color:#e8e8e8;border-color:#aaa}.dark-mode .mode-btn:hover{box-shadow:0 4px 12px #a0a0a066}.dark-mode .mode-btn.active{background:linear-gradient(135deg,#5a5a5a,#6a6a6a);color:#fff;border-color:#aaa}.dark-mode .btn-primary{background:linear-gradient(135deg,#6a6a6a,#7a7a7a)}.dark-mode .btn-secondary{background:linear-gradient(135deg,#4a4a4a,#3a3a3a)}.dark-mode .btn-success{background:linear-gradient(135deg,#3d7a3d,#4d9a4d)}.dark-mode .btn-danger,.dark-mode .drop-image-btn{background:linear-gradient(135deg,#9b4a4a,#b34a4a)}.dark-mode .drop-image-btn:hover{background:linear-gradient(135deg,#b34a4a,#9b4a4a);box-shadow:0 4px 12px #9b4a4a66}.dark-mode .error-message{background:#641e1ee6;color:#ff6b6b}.dark-mode .dialog{background:#323242f2;box-shadow:0 20px 60px #00000080}.dark-mode .dialog p{color:#f0f0f0}.dark-mode .dialog-buttons{gap:1rem}.dark-mode .comparison-label{background:#000c}.dark-mode .auth-page{background:linear-gradient(135deg,#2a2a2a,#3d3d3d)}.dark-mode .auth-container{background:#373737f2;box-shadow:0 10px 40px #0006}.dark-mode .auth-tabs{border-bottom-color:#a0a0a033}.dark-mode .auth-tab{color:#999}.dark-mode .auth-tab.active{color:#bbb;border-bottom-color:#aaa}.dark-mode .auth-tab:hover:not(.active){color:#ccc}.dark-mode .form-group label{color:#f0f0f0}.dark-mode .form-group input{background:#414141cc;border-color:#a0a0a04d;color:#f0f0f0}.dark-mode .form-group input:focus{border-color:#aaa}.dark-mode .form-group input:disabled{background:#32323280;color:#909090}.dark-mode .auth-message.error{background:#641e1ee6;color:#ff6b6b}.dark-mode .auth-message.success{background:#1e641ee6;color:#4ade80}.dark-mode .user-bar{background:#0003}.dark-mode .user-email{color:#f0f0f0}.dark-mode .status-badge.confirmed{background:#1e641ee6;color:#4ade80}.dark-mode .status-badge.unconfirmed{background:#64501ee6;color:#fbbf24}.dark-mode .delete-confirm{border-top-color:#a0a0a033}.dark-mode .delete-confirm h3{color:#ff6b6b}.dark-mode .warning-text{color:#c8c8c8}.dark-mode .loading-screen{background:linear-gradient(135deg,#2a2a2a,#3d3d3d)}.dark-mode .loading-spinner{border-color:#aaaaaa4d;border-top-color:#aaa}.dark-mode-toggle{display:flex;align-items:center;justify-content:center;padding:6px 12px;min-width:36px}.dark-mode-toggle svg{display:block}.dark-mode .processing-timer{background:linear-gradient(135deg,#5a5a5a,#6a6a6a)}.dark-mode .faq-link{background:linear-gradient(135deg,#2a2a2a,#1a1a1a);border-color:#444}.dark-mode .faq-link:hover{background:linear-gradient(135deg,#3a3a3a,#2a2a2a);box-shadow:0 4px 12px #0006}
