:root{--primary: #10b981;--primary-dark: #059669;--primary-light: #d1fae5;--on-primary: #ffffff;--background: #ffffff;--surface: #f3f4f6;--text-main: #1f2937;--text-secondary: #6b7280;--border: #e5e7eb;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1)}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background-color:var(--background);color:var(--text-main);line-height:1.5;-webkit-font-smoothing:antialiased;overscroll-behavior-y:none}button{cursor:pointer;border:none;background:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:16px}.container{max-width:480px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;background-color:var(--background);position:relative}.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}html,body{margin:0;padding:0;width:100%;height:100%}.app-shell{width:100%;height:100%;display:block}.app-content-full{width:100%;height:100%;padding-bottom:80px;box-sizing:border-box;overflow-y:auto}.app-nav{position:fixed;bottom:0;left:0;width:100%;height:64px;background-color:#fff;border-top:1px solid #f1f5f9;display:flex;justify-content:space-around;align-items:center;z-index:1000;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -4px 6px -1px #0000000d}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;color:#94a3b8;font-size:11px;font-weight:500;width:100%;height:100%;gap:4px;transition:color .2s ease}.nav-item:active{background-color:#f8fafc}.nav-item.active{color:#10b981}.nav-item svg{stroke-width:2px}.onboarding-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .3s ease-out}.onboarding-card{background:#fff;width:100%;max-width:340px;border-radius:32px;padding:32px 24px;position:relative;box-shadow:0 20px 40px #0003;animation:slideUp .4s cubic-bezier(.175,.885,.32,1.275)}.onboarding-close{position:absolute;top:16px;right:16px;background:none;border:none;color:#9ca3af;cursor:pointer;padding:8px;border-radius:50%;transition:background .2s}.onboarding-close:active{background:#f3f4f6}.onboarding-content{display:flex;flex-direction:column;align-items:center;text-align:center}.onboarding-icon-circle{width:96px;height:96px;border-radius:50%;background:#f9fafb;display:flex;align-items:center;justify-content:center;margin-bottom:24px;border:2px solid transparent;transition:all .3s ease}.onboarding-content h2{font-size:24px;font-weight:800;color:#1f2937;margin:0 0 12px}.onboarding-content p{font-size:15px;color:#6b7280;line-height:1.5;margin:0 0 32px;padding:0 16px}.onboarding-indicators{display:flex;gap:8px;margin-bottom:32px}.indicator-dot{width:8px;height:8px;border-radius:50%;background:#e5e7eb;transition:all .3s ease}.indicator-dot.active{width:24px;background:#10b981;border-radius:4px}.onboarding-btn{width:100%;background:#1f2937;color:#fff;border:none;padding:16px;border-radius:16px;font-size:16px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:transform .1s}.onboarding-btn:active{transform:scale(.98)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}:root{--bg-color: #ffffff;--text-main: #1f2937;--text-sub: #6b7280;--primary-accent: #10b981;--purple-accent: #8b5cf6;--pink-accent: #ec4899;--teal-accent: #14b8a6;--border-light: #f3f4f6;--font-ui: "Inter", system-ui, sans-serif}html,body,#root{height:100vh;height:100dvh;margin:0;padding:0;overflow:hidden;font-family:var(--font-ui);background-color:var(--bg-color)}.mobile-shell{height:100vh;height:100dvh;display:flex;flex-direction:column;position:relative;background-image:url(/assets/tft_logo-CgOYosst.png);background-repeat:no-repeat;background-position:center bottom;background-size:120%}.mobile-shell:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:#fffffff5;z-index:0}.mobile-content{flex:1;overflow-y:auto;padding:20px 24px;z-index:10;position:relative;-ms-overflow-style:none;scrollbar-width:none}.mobile-content::-webkit-scrollbar{display:none}.centered-layout{display:flex;flex-direction:column}.center-hero{display:flex;flex-direction:column;align-items:center;margin-top:20px;margin-bottom:30px;text-align:center}.big-logo-container{width:100px;height:100px;margin-bottom:16px}.big-logo{width:100%;height:100%;object-fit:contain}.center-hero h1{font-size:24px;font-weight:800;color:var(--text-main);margin:0 0 4px;letter-spacing:-.5px}.hero-date{font-size:12px;color:var(--text-sub);font-weight:600;text-transform:uppercase;letter-spacing:1px;margin:0}.mobile-greeting{text-align:center;margin-bottom:24px}.mobile-greeting h2{font-size:20px;font-weight:600;color:var(--text-main);margin:0 0 4px}.mobile-greeting p{font-size:14px;color:var(--text-sub);margin:0}.mobile-actions{display:flex;flex-direction:column;gap:16px;width:100%}.mobile-card{background:#fff;padding:18px;border-radius:20px;display:flex;align-items:center;gap:16px;box-shadow:0 8px 24px #0000000a;border:1px solid rgba(0,0,0,.02);transition:transform .1s active;cursor:pointer}.mobile-card:active{transform:scale(.98)}.card-icon-box{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.purple-bg{background-color:var(--purple-accent);box-shadow:0 4px 12px #8b5cf640}.pink-bg{background-color:var(--pink-accent);box-shadow:0 4px 12px #ec489940}.teal-bg{background-color:var(--teal-accent);box-shadow:0 4px 12px #14b8a640}.black-bg{background-color:#111827;box-shadow:0 4px 12px #00000040}.highlight-card{border:1px solid var(--text-main)}.card-details{flex:1}.card-details h3{font-size:16px;font-weight:700;color:var(--text-main);margin:0 0 2px}.card-details p{font-size:12px;color:var(--text-sub);margin:0}.card-arrow{color:#e5e7eb}.mobile-footer{flex:0 0 auto;z-index:10;position:relative;text-align:center;padding:16px 20px 24px;padding-bottom:calc(24px + env(safe-area-inset-bottom));background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--border-light)}.thesis-degree{font-size:10px;font-weight:700;color:var(--text-main);text-transform:uppercase;letter-spacing:.5px;margin:0 0 4px}.thesis-school{font-size:10px;font-weight:600;color:var(--text-sub);margin:0}.toast-container{position:fixed;bottom:80px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:1000;width:90%;max-width:400px;pointer-events:none}.toast-message{background-color:var(--text-main);color:#fff;padding:12px 20px;border-radius:var(--radius-full);font-size:14px;font-weight:500;box-shadow:var(--shadow-lg);animation:slideUp .3s ease-out;opacity:.95;pointer-events:auto;display:flex;align-items:center;justify-content:space-between;gap:12px}.toast-message.success{background-color:var(--text-main)}.toast-message.error{background-color:#ef4444}.toast-action-btn{background:#fff;color:var(--text-main);border:none;padding:4px 10px;border-radius:var(--radius-sm);font-size:12px;font-weight:700;text-transform:uppercase;cursor:pointer;transition:transform .1s}.toast-action-btn:active{transform:scale(.95)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:.95}}.palette-header{flex:0 0 auto;background:#fff;padding:16px 0 0;border-bottom:1px solid var(--border-light);z-index:20;display:flex;flex-direction:column;gap:16px}.top-row{display:flex;align-items:center;justify-content:space-between;padding:0 20px;gap:16px}.back-btn,.refresh-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border-light);background:#fff;display:flex;align-items:center;justify-content:center;color:var(--text-main);cursor:pointer;transition:background .2s}.refresh-btn:active{background:#f3f4f6}.spin{animation:spin 1s linear infinite}.top-row h1{font-size:18px;font-weight:700;margin:0;color:var(--text-main);flex:1}.category-scroll{display:flex;gap:12px;padding:0 20px 16px;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}.category-scroll::-webkit-scrollbar{display:none}.cat-pill{padding:6px 16px;border-radius:20px;background:#f3f4f6;color:var(--text-sub);font-size:13px;font-weight:600;border:none;white-space:nowrap;cursor:pointer;transition:all .2s}.cat-pill.active{background:var(--text-main);color:#fff}.bg-gray{background-color:#f9fafb;padding-top:24px}.palette-grid{display:grid;grid-template-columns:1fr;gap:20px;padding-bottom:40px}.palette-card{background:#fff;border-radius:20px;padding:12px;box-shadow:0 2px 12px #00000008;border:1px solid rgba(0,0,0,.03);display:flex;flex-direction:column;gap:12px}.palette-strips{height:120px;border-radius:14px;display:flex;overflow:hidden;cursor:pointer}.palette-strip{flex:1;transition:flex .2s}.palette-strip:active{flex:1.5}.card-info{padding:0 4px 4px}.info-left h3{font-size:16px;font-weight:700;margin:0 0 4px;color:var(--text-main)}.cat-tag{font-size:10px;font-weight:700;color:var(--text-sub);text-transform:uppercase;background:#f3f4f6;padding:2px 8px;border-radius:4px}.loading-strips{height:120px;border-radius:14px;display:flex;overflow:hidden;gap:0}.skeleton{flex:1;background:#e5e7eb;animation:pulse 1.5s infinite}.s1{animation-delay:.1s}.s2{animation-delay:.2s}.s3{animation-delay:.3s}.s4{animation-delay:.4s}.s5{animation-delay:.5s}.skeleton-text{width:60%;height:16px;background:#e5e7eb;border-radius:4px;animation:pulse 1.5s infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}.slide-in{animation:slideUp .3s ease-out forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.history-container{display:flex;flex-direction:column;gap:var(--spacing-md);padding-bottom:80px}.history-header{background-color:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border);position:relative;margin-bottom:8px}.header-img{width:100%;height:100px;object-fit:cover;object-position:center;display:block}.header-text{padding:16px;background:#fff;border-top:1px solid var(--border)}.header-text h2{font-size:20px;font-weight:700;color:var(--text-main);margin:0}.header-text p{font-size:13px;color:var(--text-secondary);margin:4px 0 0}.empty-history{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-secondary);text-align:center;margin-top:40px;gap:12px}.empty-history-img{width:180px;height:auto;opacity:.9;margin-bottom:8px}.empty-history p{font-weight:600;font-size:16px;color:var(--text-main);margin:0}.sub-text{font-size:14px!important;font-weight:400!important;color:var(--text-secondary)!important;margin:0!important}.color-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.history-card{border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);background-color:#fff;transition:box-shadow .2s;display:flex;flex-direction:column}.history-card.expanded{box-shadow:var(--shadow-md)}.color-row{height:80px;padding:0 var(--spacing-lg);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:background-color .2s}.color-info{display:flex;flex-direction:column}.color-hex{font-weight:700;font-size:18px;font-family:monospace}.color-date{font-size:11px;opacity:.8}.row-actions{display:flex;gap:var(--spacing-md);align-items:center}.row-actions button{opacity:.7;transition:opacity .2s;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.row-actions button:active{opacity:1;transform:scale(.95)}.expanded-content{padding:var(--spacing-md);background-color:var(--background);border-top:1px solid rgba(0,0,0,.05);animation:slideDown .2s ease-out;display:flex;flex-direction:column;gap:var(--spacing-md)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.section-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase}.variations-grid-mini{display:flex;height:40px;border-radius:var(--radius-md);overflow:hidden}.variation-mini{flex:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.variation-mini.active{flex:1.5;box-shadow:inset 0 0 0 2px #0003}.hsl-section{display:flex;flex-direction:column;gap:12px;padding:8px 0}.slider-row{display:flex;align-items:center;gap:12px;font-family:monospace;font-size:14px;color:var(--text-secondary)}.hsl-slider{flex:1;-webkit-appearance:none;height:6px;border-radius:3px;outline:none}.hue-slider{background:linear-gradient(to right,red,#ff0,#0f0,#0ff,#00f,#f0f,red)}.sat-slider{background:linear-gradient(to right,gray,red)}.light-slider{background:linear-gradient(to right,#000,#fff)}.hsl-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;border:2px solid var(--border);box-shadow:0 1px 3px #0003;cursor:pointer}.save-changes-btn{width:100%;padding:12px;background-color:var(--text-main);color:#fff;font-weight:600;border-radius:var(--radius-md);margin-top:4px}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-out}.modal-content{background-color:#fff;width:85%;max-width:320px;padding:24px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:16px;text-align:center;animation:scaleIn .2s ease-out}.modal-content h3{font-size:18px;font-weight:700;color:var(--text-main)}.modal-content p{color:var(--text-secondary);font-size:14px}.modal-actions{display:flex;gap:12px;margin-top:8px}.modal-btn{flex:1;height:44px;border-radius:var(--radius-md);font-weight:600;font-size:14px;cursor:pointer;transition:opacity .2s}.modal-btn:active{opacity:.8}.modal-btn.cancel{background-color:var(--surface);color:var(--text-main);border:1px solid var(--border)}.modal-btn.confirm{background-color:var(--primary);color:#fff;border:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.scan-container{height:100%;display:flex;flex-direction:column}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;gap:32px;text-align:center}.empty-state-img{width:100%;max-width:280px;height:auto;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(0,0,0,.05))}.empty-state-content h3{font-size:24px;font-weight:800;color:var(--text-main);margin-bottom:8px}.empty-state-content p{color:var(--text-secondary);font-size:16px;max-width:280px;margin:0 auto}.upload-options{display:flex;flex-direction:column;gap:16px;width:100%;max-width:320px}.upload-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:16px;border-radius:var(--radius-full);font-weight:600;font-size:16px;transition:transform .2s,box-shadow .2s;cursor:pointer;border:none}.upload-btn:active{transform:scale(.98)}.upload-btn.primary{background-color:var(--primary);color:#fff;box-shadow:0 4px 12px #10b9814d}.upload-btn.secondary{background-color:transparent;color:var(--primary);border:2px solid var(--primary)}.editor-view{display:flex;flex-direction:column;height:100%}.canvas-wrapper{position:relative;overflow:hidden;background-color:#111;touch-action:none;flex:1;min-height:200px;display:flex;align-items:center;justify-content:center}.image-canvas{max-width:100%;box-shadow:var(--shadow-lg)}.picker-indicator{position:absolute;width:24px;height:24px;border-radius:50%;border:2px solid white;transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 0 4px #00000080;background-color:transparent;z-index:10}.controls-scrollable{flex-shrink:0;max-height:60%;overflow-y:auto;background-color:var(--background);border-top:1px solid var(--border);box-shadow:0 -4px 12px #0000000d;z-index:20}.controls-panel{padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-md)}.dominant-strip{display:flex;align-items:center;gap:var(--spacing-md)}.strip-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase}.strip-colors{display:flex;gap:var(--spacing-sm);flex:1}.strip-swatch{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .2s,border-color .2s}.strip-swatch.active{transform:scale(1.1);border-color:var(--text-main)}.color-preview-card{background-color:var(--surface);border-radius:var(--radius-md);padding:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-md)}.color-swatch-large{width:48px;height:48px;border-radius:var(--radius-sm);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.color-values{flex:1;display:flex;flex-direction:column;gap:4px}.value-row{display:flex;align-items:center;justify-content:space-between}.value-row .label{font-size:11px;font-weight:600;color:var(--text-secondary)}.value-row .value{font-size:14px;font-weight:500;color:var(--text-main)}.font-mono{font-family:SF Mono,Roboto Mono,monospace}.variations-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.variations-grid{display:flex;width:100%;height:40px;border-radius:var(--radius-md);overflow:hidden}.variation-swatch{flex:1;cursor:pointer;transition:transform .1s}.variation-swatch:active{transform:scale(.9);border-radius:4px;z-index:10}.action-buttons{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xs)}.control-btn{height:50px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;background-color:var(--surface);color:var(--text-main);transition:transform .1s}.control-btn:active{transform:scale(.96)}.control-btn.primary{flex:1;background-color:var(--primary);color:#fff;gap:var(--spacing-sm);font-weight:600;font-size:16px;box-shadow:var(--shadow-md)}
