@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&display=swap";:root{color-scheme:light;--bg-app: #f4f6fb;--bg-sidebar: #ffffff;--bg-card: #ffffff;--text-main: #1e293b;--text-muted: #64748b;--accent: #4f46e5;--accent-hover: #4338ca;--accent-light: #eeebff;--border-color: #e2e8f0;--shadow-card: 0 10px 30px -5px rgba(0, 0, 0, .04), 0 8px 12px -6px rgba(0, 0, 0, .04);--shadow-sidebar: 4px 0 24px -4px rgba(15, 23, 42, .03);--scrollbar-bg: #f1f5f9;--scrollbar-thumb: #cbd5e1;--border-hover: #cbd5e1;--focus-ring: rgba(79, 70, 229, .15);--bg-footer: rgba(244, 246, 251, .85)}html[data-theme=dark]{color-scheme:dark;--bg-app: #0b0f19;--bg-sidebar: #111827;--bg-card: #1f2937;--text-main: #f9fafb;--text-muted: #9ca3af;--accent: #6366f1;--accent-hover: #4f46e5;--accent-light: rgba(99, 102, 241, .12);--border-color: #374151;--shadow-card: 0 12px 30px -4px rgba(0, 0, 0, .3), 0 8px 16px -6px rgba(0, 0, 0, .3);--shadow-sidebar: 4px 0 24px -4px rgba(0, 0, 0, .4);--scrollbar-bg: #111827;--scrollbar-thumb: #374151;--border-hover: #4b5563;--focus-ring: rgba(99, 102, 241, .25);--bg-footer: rgba(11, 15, 25, .85)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg-app);color:var(--text-main);transition:background-color .3s ease,color .3s ease;min-height:100vh}.app-layout{display:flex;min-height:100vh;overflow-x:hidden}.mobile-header{display:none;background:var(--bg-sidebar);border-bottom:1px solid var(--border-color);padding:12px 20px;align-items:center;gap:16px;position:fixed;top:0;left:0;right:0;z-index:90;height:60px;box-shadow:0 2px 10px #00000005}.mobile-logo-text{font-family:Outfit,sans-serif;font-weight:700;font-size:1.15rem;color:var(--accent)}.icon-btn{background:transparent;border:none;color:var(--text-main);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background-color .2s ease}.icon-btn:hover{background:var(--accent-light);color:var(--accent)}.sidebar{width:280px;flex-shrink:0;background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;height:100vh;position:sticky;top:0;box-shadow:var(--shadow-sidebar);z-index:100;transition:left .3s cubic-bezier(.4,0,.2,1),width .3s cubic-bezier(.4,0,.2,1)}.sidebar-brand{padding:18px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-color);gap:12px}.brand-logo-container{display:flex;align-items:center;gap:10px}.brand-logo{background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 10px #6366f133}.brand-text{font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:800;letter-spacing:-.02em;color:var(--text-main)}.sidebar-collapse-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.sidebar-collapse-btn:hover{background:var(--accent-light);color:var(--accent)}.sidebar-search-container{padding:10px 16px 6px}.search-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:10px;color:var(--text-muted);pointer-events:none}#tool-search{padding:8px 12px 8px 32px;font-size:.85rem;border-radius:8px;background:var(--bg-app)}.sidebar-nav{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:2px}.sidebar-nav::-webkit-scrollbar{width:5px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border:none;background:transparent;border-radius:8px;color:var(--text-muted);cursor:pointer;text-align:left;transition:all .2s ease;font-weight:500;font-size:.85rem;font-family:inherit}.nav-item svg{width:16px;height:16px;flex-shrink:0}.nav-item:hover{background:var(--accent-light);color:var(--accent)}.nav-item.active{background:var(--accent);color:#fff;box-shadow:0 4px 12px #4f46e526}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:12px;transition:padding .3s cubic-bezier(.4,0,.2,1)}.theme-switch-wrapper{display:flex;align-items:center;justify-content:space-between}.theme-label{font-size:.9rem;font-weight:600;color:var(--text-muted)}.theme-toggle-btn{background:var(--bg-app);border:1px solid var(--border-color);color:var(--text-main);cursor:pointer;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.theme-toggle-btn:hover{background:var(--accent-light);color:var(--accent);transform:rotate(15deg)}html:not([data-theme=dark]) .sun-icon{display:none}html[data-theme=dark] .moon-icon{display:none}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:95;opacity:0;transition:opacity .3s ease}.sidebar-overlay.visible{display:block;opacity:1}.main-content{flex:1;min-width:0;padding:48px 48px 0;display:flex;flex-direction:column;gap:36px;overflow-y:auto;height:100vh}.main-content.no-header{padding-top:24px}.main-header{max-width:760px;margin:0 auto;width:100%}.main-header.wide-header{max-width:none}@media (min-width: 769px){.collapsed-sidebar .sidebar{width:78px}.collapsed-sidebar .brand-text,.collapsed-sidebar .sidebar-search-container,.collapsed-sidebar .nav-item span,.collapsed-sidebar .theme-label{display:none!important}.collapsed-sidebar .sidebar-brand{flex-direction:column;justify-content:center;padding:16px 0;gap:10px}.collapsed-sidebar .brand-logo-container{justify-content:center}.collapsed-sidebar .nav-item{justify-content:center;padding:8px 0}.collapsed-sidebar .sidebar-footer{padding:12px 0;align-items:center}.collapsed-sidebar .theme-switch-wrapper{justify-content:center;width:100%}.collapsed-sidebar .sidebar-collapse-btn{background:var(--accent);color:#fff;transform:rotate(180deg)}.collapsed-sidebar .sidebar-collapse-btn:hover{background:var(--accent-hover);color:#fff;transform:scale(1.05) rotate(180deg)}}@media (max-width: 768px){.sidebar-collapse-btn{display:none!important}}.main-header h1{font-family:Outfit,sans-serif;font-size:2.25rem;font-weight:800;letter-spacing:-.03em;margin-bottom:8px;background:linear-gradient(135deg,var(--text-main),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.subtitle{font-size:1.05rem;color:var(--text-muted);line-height:1.5}.tool-stage{width:100%;flex:1;display:flex;flex-direction:column;align-items:center}.tool-card{display:none;background:var(--bg-card);border:1px solid var(--border-color);border-radius:18px;padding:32px;box-shadow:var(--shadow-card);flex-direction:column;gap:20px;width:100%;max-width:680px}.tool-card.active{display:flex;animation:fadeInScale .3s cubic-bezier(.34,1.56,.64,1)}.tool-card--compact{max-width:520px}.tool-card--wide{max-width:none;width:100%}@keyframes fadeInScale{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.tool-card h2{font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:700;letter-spacing:-.02em;border-bottom:1px solid var(--border-color);padding-bottom:12px;margin-bottom:8px}.form-group{display:flex;flex-direction:column;gap:8px;width:100%}.form-group.border-top{border-top:1px solid var(--border-color);padding-top:20px;margin-top:8px}label{font-weight:600;font-size:.9rem;color:var(--text-main)}textarea{resize:none}textarea,input,select{font:inherit;font-size:.95rem;width:100%;padding:12px 16px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-app);color:var(--text-main);outline:none;transition:all .2s ease}textarea:hover,input:hover,select:hover{border-color:var(--border-hover)}textarea:focus,input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--focus-ring);background:var(--bg-card)}textarea[readonly],input[readonly]{background:var(--bg-app);opacity:.75;cursor:text}textarea[readonly]:focus,input[readonly]:focus{box-shadow:none;border-color:var(--border-color);background:var(--bg-app)}.btn-primary{align-self:flex-start;padding:12px 24px;border-radius:10px;border:none;background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;cursor:pointer;font-weight:600;font-size:.95rem;font-family:inherit;transition:all .2s ease;box-shadow:0 4px 12px #4f46e526}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 16px #4f46e540}.btn-primary:active{transform:translateY(0)}.row{display:flex;gap:16px;width:100%}.row>*{flex:1}.flex-1{flex:1}.count-results{margin-top:8px}.result-box{background:var(--accent-light);border:1px solid rgba(79,70,229,.1);border-radius:12px;padding:16px 20px;display:flex;flex-direction:column;gap:6px;transition:all .3s ease}.result-label{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.result-val{font-size:1.75rem;font-weight:800;color:var(--accent);font-family:Outfit,sans-serif}.result-banner{background:var(--accent-light);border-left:4px solid var(--accent);border-radius:4px 12px 12px 4px;padding:16px 20px;font-weight:600;color:var(--text-main);font-size:1.05rem;min-height:52px;display:flex;align-items:center;gap:8px;transition:all .3s ease}.banner-label{color:var(--text-muted);font-weight:500}.small{font-size:.85rem;color:var(--text-muted)}.small.note{margin-top:-8px}.status-msg{min-height:18px;color:#ef4444;font-weight:500}html[data-theme=dark] .status-msg{color:#f87171}.color-preview-bar{height:56px;border-radius:10px;border:1px solid var(--border-color);transition:background-color .25s ease;box-shadow:inset 0 2px 4px #0000000a}.grid-outputs{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;width:100%}.grid-outputs .full-width{grid-column:span 2}@media (max-width: 900px){.main-content{padding:32px 32px 0}.main-content.no-header{padding-top:20px}}@media (max-width: 768px){.mobile-header{display:flex}.sidebar{position:fixed;left:-280px;top:0;bottom:0;height:100vh;box-shadow:none;transition:left .3s cubic-bezier(.4,0,.2,1)}.sidebar.open{left:0;box-shadow:10px 0 30px #00000026}.main-content{padding:80px 20px 0}.main-content.no-header{padding-top:72px}.tool-card{padding:20px}.main-header h1{font-size:1.75rem}.row{flex-direction:column;gap:16px}.grid-outputs{grid-template-columns:1fr}.grid-outputs .full-width{grid-column:span 1}}.label-row-with-copy{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.copy-btn-inline{background:var(--accent-light);color:var(--accent);border:1px solid rgba(79,70,229,.15);padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit;line-height:1}.copy-btn-inline:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.copy-btn-inline.copied{background:#10b981;color:#fff;border-color:#10b981}html[data-theme=dark] .copy-btn-inline{border-color:#6366f14d}html[data-theme=dark] .copy-btn-inline:hover{background:var(--accent);color:#fff}html[data-theme=dark] .copy-btn-inline.copied{background:#059669;border-color:#059669}.btn-secondary{align-self:flex-start;padding:12px 24px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-app);color:var(--text-main);cursor:pointer;font-weight:600;font-size:.95rem;font-family:inherit;transition:all .2s ease}.btn-secondary:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.search-input-group{display:flex;gap:12px;width:100%}@media (max-width: 500px){.search-input-group{flex-direction:column;gap:8px}.search-input-group button{width:100%}}.loader-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:24px}.spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.iplookup-results-layout{display:grid;grid-template-columns:1.2fr 1fr;gap:24px;align-items:stretch;width:100%}@media (max-width: 900px){.iplookup-results-layout{grid-template-columns:1fr;gap:20px}}.map-wrapper{display:flex;flex-direction:column;gap:8px;width:100%;height:100%}.map-container{border-radius:10px;overflow:hidden;border:1px solid var(--border-color);background:var(--bg-app);flex:1;min-height:250px}.imgmeta-container{display:flex;flex-direction:column;gap:24px;width:100%;margin-top:8px}.imgmeta-dropzone{border:2px dashed var(--border-color);border-radius:14px;padding:40px 20px;text-align:center;background:#4f46e505;transition:all .25s ease;cursor:pointer;display:flex;justify-content:center;align-items:center}.imgmeta-dropzone:hover,.imgmeta-dropzone.dragover{border-color:var(--accent);background:var(--accent-light)}.imgmeta-dropzone svg{color:var(--text-muted);margin-bottom:16px;transition:color .25s ease}.imgmeta-dropzone:hover svg,.imgmeta-dropzone.dragover svg{color:var(--accent)}.dropzone-content{display:flex;flex-direction:column;align-items:center}.dropzone-content .btn-secondary{align-self:center}.dropzone-title{font-size:1.1rem;font-weight:600;color:var(--text-main);margin:0}.dropzone-or{font-size:.85rem;color:var(--text-muted);margin:8px 0}.dropzone-note{font-size:.8rem;color:var(--text-muted);margin-top:16px;max-width:320px}.imgmeta-results-grid{display:grid;grid-template-columns:240px 1fr;gap:20px;width:100%;animation:fadeInScale .4s cubic-bezier(.34,1.56,.64,1) forwards}@media (max-width: 900px){.imgmeta-results-grid{grid-template-columns:1fr}}.imgmeta-preview-col{display:flex;flex-direction:column;gap:16px}.imgmeta-preview-card{border-radius:12px;overflow:hidden;border:1px solid var(--border-color);background:var(--bg-card)}.imgmeta-img-container{aspect-ratio:4/3;width:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-app);border-bottom:1px solid var(--border-color);overflow:hidden;position:relative;max-height:180px}.imgmeta-img-container img{max-width:100%;max-height:100%;object-fit:contain}.imgmeta-raw-icon{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--accent)}.imgmeta-raw-icon span{font-size:.8rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.imgmeta-file-meta{padding:16px}.imgmeta-file-meta h3{font-size:1rem;font-weight:600;color:var(--text-main);margin:0 0 12px;word-break:break-all}.imgmeta-file-meta p{font-size:.85rem;margin:6px 0;color:var(--text-main)}.imgmeta-file-meta p .label{color:var(--text-muted);font-weight:500;display:inline-block;width:70px}.imgmeta-actions{display:flex;gap:12px;width:100%}.imgmeta-actions button{padding:12px 16px;font-size:.9rem;border-radius:10px;display:flex;align-items:center;justify-content:center}.imgmeta-data-col{display:flex;flex-direction:column;gap:16px;min-width:0}.imgmeta-header-actions{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.imgmeta-tabs{display:flex;background:var(--bg-app);padding:4px;border-radius:10px;border:1px solid var(--border-color);gap:2px;flex-wrap:wrap}.imgmeta-tabs .tab-btn{border:none;background:transparent;color:var(--text-muted);padding:6px 14px;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.imgmeta-tabs .tab-btn:hover{color:var(--text-main)}.imgmeta-tabs .tab-btn.active{background:var(--bg-card);color:var(--accent);box-shadow:0 2px 6px #0000000d}html[data-theme=dark] .imgmeta-tabs .tab-btn.active{box-shadow:0 2px 6px #0003}.tool-tabs{display:flex;background:var(--bg-app);padding:4px;border-radius:10px;border:1px solid var(--border-color);gap:2px;flex-wrap:wrap;width:fit-content}.tool-tabs .tab-btn{border:none;background:transparent;color:var(--text-muted);padding:8px 16px;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.tool-tabs .tab-btn:hover{color:var(--text-main)}.tool-tabs .tab-btn.active{background:var(--bg-card);color:var(--accent);box-shadow:0 2px 6px #0000000d}html[data-theme=dark] .tool-tabs .tab-btn.active{box-shadow:0 2px 6px #0003}.currency-swap-btn{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;min-width:42px;border-radius:50%;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-muted);cursor:pointer;align-self:flex-end;margin-bottom:2px;transition:all .2s ease}.currency-swap-btn:hover{border-color:var(--accent);color:var(--accent);transform:rotate(180deg)}.currency-result-display{background:var(--bg-app);border:1px solid var(--border-color);border-radius:12px;padding:20px;margin-top:16px;text-align:center}.currency-result-value{font-family:Outfit,sans-serif;font-size:2rem;font-weight:700;color:var(--accent);margin-bottom:8px;word-break:break-all}.currency-result-rate{font-size:.9rem;color:var(--text-muted)}.currency-manual-rate-container{display:flex;align-items:center;gap:12px;margin-top:12px;padding:12px 16px;background:var(--bg-app);border-radius:8px;border:1px dashed var(--border-color)}.currency-manual-rate-container input[type=checkbox]{width:auto;cursor:pointer}.currency-manual-rate-container label{cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.85rem;color:var(--text-main);font-weight:600}.currency-manual-rate-input{max-width:120px;padding:6px 10px;font-size:.85rem;border-radius:6px}.currency-bulk-list{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto;margin-top:12px;padding:12px;background:var(--bg-app);border:1px solid var(--border-color);border-radius:8px;font-family:monospace;font-size:.85rem}.currency-bulk-item{display:flex;justify-content:space-between;border-bottom:1px solid rgba(0,0,0,.05);padding-bottom:4px}html[data-theme=dark] .currency-bulk-item{border-bottom-color:#ffffff0d}.imgmeta-search-wrapper{max-width:240px;flex:1}.imgmeta-search-wrapper input{padding:8px 12px;font-size:.85rem;border-radius:8px;height:36px}.imgmeta-table-container{border:1px solid var(--border-color);border-radius:12px;background:var(--bg-card);overflow:auto;max-height:480px}.imgmeta-table-container.scrollable{overflow:auto}.imgmeta-table{width:100%;border-collapse:collapse;font-size:.85rem;text-align:left}.imgmeta-table th,.imgmeta-table td{padding:8px 12px;border-bottom:1px solid var(--border-color)}.imgmeta-table th{background:var(--bg-app);color:var(--text-muted);font-weight:600;position:sticky;top:0;z-index:1;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1.5px solid var(--border-color);white-space:nowrap}.imgmeta-table tbody tr:last-child td{border-bottom:none}.imgmeta-table tbody tr:hover td{background:#4f46e503}.imgmeta-table td:first-child{font-weight:600;color:var(--text-main);white-space:nowrap}.imgmeta-table td:nth-child(2){color:var(--text-main);white-space:nowrap;max-width:260px;overflow:hidden;text-overflow:ellipsis}.imgmeta-table td:nth-child(3){color:var(--text-muted);white-space:nowrap;max-width:260px;overflow:hidden;text-overflow:ellipsis}.imgmeta-cam-view{display:flex;flex-direction:column;gap:20px;overflow-y:auto;max-height:520px;padding-right:4px;padding-bottom:24px}.imgmeta-cam-view::-webkit-scrollbar{width:6px}.imgmeta-cam-view::-webkit-scrollbar-track{background:transparent}.imgmeta-cam-view::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}.imgmeta-param-group{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px}.imgmeta-param-group-header{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-app);border-bottom:1px solid var(--border-color);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-radius:12px 12px 0 0}.imgmeta-param-group-header span.group-icon{font-size:1rem;line-height:1}.imgmeta-param-grid{display:flex;flex-wrap:wrap;gap:0}.imgmeta-stat-cell{flex:1 1 180px;padding:10px 16px;border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:4px;min-width:0;box-sizing:border-box}.imgmeta-stat-cell:last-child{border-right:none}.imgmeta-stat-cell.no-bottom{border-bottom:none}.imgmeta-stat-label{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.imgmeta-stat-value{font-size:.95rem;font-weight:700;color:var(--text-main);white-space:normal;word-break:break-word;font-family:Outfit,sans-serif}.imgmeta-stat-value.not-available{color:var(--text-muted);font-weight:400;font-style:italic;font-size:.85rem;font-family:inherit}.imgmeta-no-tags-cam{padding:32px;text-align:center;color:var(--text-muted);font-weight:500;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px}.imgmeta-no-tags-msg{padding:32px;text-align:center;color:var(--text-muted);font-weight:500}.wheel-layout{display:grid;grid-template-columns:1.1fr 1fr;gap:32px;width:100%;align-items:start;margin-top:12px}@media (max-width: 1024px){.wheel-layout{grid-template-columns:1fr;gap:24px}}.wheel-canvas-container{display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;width:100%;background:var(--bg-app);border:1px solid var(--border-color);border-radius:16px;padding:32px;min-height:520px}.wheel-title-pill{background:#0f172abf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);color:#fff;padding:10px 36px;border-radius:28px;font-family:Outfit,sans-serif;font-weight:700;font-size:1.25rem;margin-bottom:24px;text-align:center;box-shadow:0 4px 14px #00000026;-webkit-user-select:none;user-select:none;z-index:5;letter-spacing:.03em}.wheel-canvas-wrapper{position:relative;width:420px;height:420px;max-width:100%;aspect-ratio:1 / 1;border-radius:50%;box-shadow:0 16px 40px #00000014;background:var(--bg-card);overflow:visible;cursor:pointer;transition:transform .2s ease}.wheel-canvas-wrapper:hover{transform:scale(1.01)}.wheel-canvas-wrapper canvas{width:100%;height:100%;display:block}.wheel-pointer{position:absolute;right:-14px;top:50%;transform:translateY(-50%);z-index:10;display:flex;align-items:center;filter:drop-shadow(0 2px 6px rgba(0,0,0,.2));pointer-events:none}.wheel-pointer svg{fill:#ef4444;width:36px;height:36px}.wheel-spin-btn-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:76px;height:76px;border-radius:50%;background:linear-gradient(135deg,var(--bg-card),var(--bg-app));border:4px solid var(--accent);box-shadow:0 4px 12px #00000026,inset 0 2px 4px #fff3;display:flex;align-items:center;justify-content:center;z-index:8;font-family:Outfit,sans-serif;font-weight:800;font-size:.95rem;color:var(--accent);letter-spacing:.05em;-webkit-user-select:none;user-select:none;transition:all .2s cubic-bezier(.4,0,.2,1)}.wheel-spin-btn-center:hover{transform:translate(-50%,-50%) scale(1.08);background:var(--accent);color:#fff;border-color:#fff;box-shadow:0 6px 18px #4f46e566}.wheel-spin-btn-center:active{transform:translate(-50%,-50%) scale(.96)}.wheel-result-banner{margin-top:24px;width:100%;max-width:420px;background:var(--accent-light);border:2px solid var(--accent);border-radius:12px;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;animation:bannerPopIn .35s cubic-bezier(.34,1.56,.64,1)}@keyframes bannerPopIn{0%{opacity:0;transform:scale(.9) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.result-banner-title{font-size:.75rem;text-transform:uppercase;font-weight:700;color:var(--text-muted);letter-spacing:.05em}.wheel-result-banner strong{font-size:1.35rem;color:var(--accent);font-family:Outfit,sans-serif;flex-grow:1;text-align:center;word-break:break-all}.result-banner-close{background:transparent;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;transition:color .2s;padding:0 4px;line-height:1}.result-banner-close:hover{color:var(--text-main)}.wheel-controls-panel{display:flex;flex-direction:column;gap:20px;background:var(--bg-sidebar);border:1px solid var(--border-color);border-radius:16px;padding:24px}.wheel-actions-row{display:flex;gap:12px;width:100%}.wheel-actions-row button{flex:1}.btn-danger-custom{background:#ef444414;color:#ef4444;border:1px solid rgba(239,68,68,.2);padding:12px 24px;border-radius:10px;cursor:pointer;font-weight:600;font-size:.95rem;font-family:inherit;transition:all .2s}.btn-danger-custom:hover{background:#ef4444;color:#fff;border-color:#ef4444;box-shadow:0 4px 12px #ef444433;transform:translateY(-1px)}.btn-danger-custom:active{transform:translateY(0)}.checkbox-group{display:flex;align-items:center;margin-top:4px}.toggle-switch{display:inline-flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-switch input{display:none}.toggle-slider{position:relative;width:44px;height:24px;background-color:var(--border-color);border-radius:24px;transition:background-color .25s ease;flex-shrink:0}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;bottom:3px;background-color:#fff;border-radius:50%;transition:transform .25s ease;box-shadow:0 1px 3px #00000026}.toggle-switch input:checked+.toggle-slider{background-color:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.toggle-label{font-size:.9rem;color:var(--text-main);font-weight:500}.wheel-items-list{display:flex;flex-wrap:wrap;gap:8px;padding:12px;background:var(--bg-app);border:1px solid var(--border-color);border-radius:10px;max-height:150px;overflow-y:auto;min-height:52px}.wheel-item-chip{padding:6px 12px;border-radius:8px;font-size:.85rem;font-weight:600;background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-main);transition:all .2s ease;display:flex;align-items:center;gap:6px}.wheel-item-chip.eliminated{background:#94a3b814!important;border-color:var(--border-color)!important;color:var(--text-muted)!important;text-decoration:line-through;opacity:.6}.wheel-item-chip:nth-child(8n+1){border-left:3px solid #6366f1}.wheel-item-chip:nth-child(8n+2){border-left:3px solid #10b981}.wheel-item-chip:nth-child(8n+3){border-left:3px solid #f59e0b}.wheel-item-chip:nth-child(8n+4){border-left:3px solid #ec4899}.wheel-item-chip:nth-child(8n+5){border-left:3px solid #06b6d4}.wheel-item-chip:nth-child(8n+6){border-left:3px solid #8b5cf6}.wheel-item-chip:nth-child(8n+7){border-left:3px solid #f97316}.wheel-item-chip:nth-child(8n+8){border-left:3px solid #3b82f6}.keyboard-shortcuts-card{background:#94a3b808;border:1px dashed var(--border-color);border-radius:12px;padding:16px;margin-top:8px}.keyboard-shortcuts-card h4{font-size:.8rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.keyboard-shortcuts-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.keyboard-shortcuts-card li{font-size:.8rem;color:var(--text-muted);display:flex;align-items:center;gap:8px}.keyboard-shortcuts-card kbd{background:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;box-shadow:0 1px 1px #0000001a;color:var(--text-main);display:inline-block;font-family:inherit;font-weight:700;line-height:1;padding:3px 6px;font-size:.75rem}.custom-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{position:relative;background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:28px;max-width:420px;width:100%;box-shadow:0 20px 50px #0003,0 10px 10px #0000001a;z-index:1001;display:flex;flex-direction:column;gap:16px;animation:modalSlideIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-content h3{font-family:Outfit,sans-serif;font-size:1.25rem;font-weight:700;color:var(--text-main)}.modal-content p{font-size:.9rem;color:var(--text-muted);line-height:1.5}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.btn-danger-confirm{background:#ef4444;color:#fff;border:none;padding:10px 18px;border-radius:8px;font-weight:600;cursor:pointer;font-size:.9rem;font-family:inherit;transition:background-color .2s}.btn-danger-confirm:hover{background:#dc2626}.wheel-list-container{border:1px solid var(--border-color);border-radius:12px;background:var(--bg-app);overflow:hidden;min-height:280px;display:flex;flex-direction:column}.wheel-list-view{padding:16px;height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.wheel-list-item{padding:8px 12px;border-radius:8px;font-size:.95rem;background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-main);font-weight:500;transition:all .2s;word-break:break-all;text-align:left}.wheel-list-item.eliminated{background:#94a3b80d!important;border-color:var(--border-color)!important;color:var(--text-muted)!important;text-decoration:line-through;opacity:.65}.wheel-text-input{padding:16px;height:280px;width:100%;border:none;background:transparent;color:var(--text-main);font-family:inherit;font-size:.95rem;line-height:1.5;resize:none;outline:none}.wheel-options-footer{display:flex;gap:8px;margin-top:8px;justify-content:flex-end}.btn-secondary-sm{padding:6px 12px;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-main);cursor:pointer;font-weight:600;font-size:.8rem;font-family:inherit;transition:all .2s}.btn-secondary-sm:hover{background:var(--bg-app);border-color:var(--border-hover);color:var(--accent)}.btn-secondary-sm:active{background:var(--border-color)}.shiny-footer{position:relative;z-index:90;width:calc(100% + 96px);margin:auto -48px 0;padding:5px 48px;background:var(--bg-sidebar);backdrop-filter:none;-webkit-backdrop-filter:none;border-top:1px solid var(--border-color);border-bottom:none;border-left:none;border-right:none;border-radius:0;box-shadow:0 -4px 20px #0000000a;transition:border-color .3s ease,box-shadow .3s ease}.shiny-footer:before{content:"";position:absolute;top:0;left:0;right:0;height:1.5px;background:linear-gradient(90deg,transparent,var(--accent),#f43f5e,var(--accent),transparent);background-size:200% 100%;animation:shine-sweep 8s linear infinite;opacity:.8}.shiny-footer-content{position:relative;z-index:2;display:flex;flex-direction:row;justify-content:center;align-items:center;gap:6px;font-family:Inter,sans-serif;font-size:.78rem;color:var(--text-muted)}.footer-brand-name{font-family:Outfit,sans-serif;font-weight:700;background:linear-gradient(135deg,var(--accent),#f43f5e);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.footer-copyright{color:var(--text-muted)}.shiny-footer:hover{border-color:#6366f159;box-shadow:0 -6px 24px #6366f10f}@keyframes shine-sweep{0%{background-position:0% 50%}to{background-position:200% 50%}}@media (max-width: 900px){.shiny-footer{width:calc(100% + 64px);margin-left:-32px;margin-right:-32px;padding:8px 32px}}@media (max-width: 768px){.shiny-footer{width:calc(100% + 40px);margin-left:-20px;margin-right:-20px;padding:8px 20px}}.sidebar-tooltip{position:fixed;background:var(--bg-card);color:var(--text-main);padding:6px 12px;border-radius:8px;font-size:.8rem;font-weight:600;white-space:nowrap;border:1px solid var(--border-color);box-shadow:var(--shadow-card);opacity:0;pointer-events:none;transform:translateY(-50%) translate(10px);transition:opacity .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1);z-index:1000}.sidebar-tooltip.visible{opacity:1;transform:translateY(-50%) translate(0)}.sidebar-category-group{display:flex;flex-direction:column;gap:2px;margin-bottom:12px}.sidebar-category-group:last-child{margin-bottom:0}.sidebar-category-header{padding:6px 12px 2px;display:flex;align-items:center;-webkit-user-select:none;user-select:none}.sidebar-category-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);opacity:.55}.collapsed-sidebar .sidebar-category-header{display:none!important}.collapsed-sidebar .sidebar-category-group{margin-bottom:8px;position:relative}.collapsed-sidebar .sidebar-category-group:after{content:"";display:block;width:24px;height:1px;background:var(--border-color);margin:8px auto 0;opacity:.5}.collapsed-sidebar .sidebar-category-group:last-child:after{display:none}.home-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.tab-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:20px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-muted);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);font-family:inherit}.tab-btn svg{width:14px;height:14px;opacity:.7}.tab-btn:hover{border-color:var(--accent);color:var(--accent)}.tab-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 12px #4f46e540}.tab-btn.active svg{opacity:1}.home-category-section{margin-bottom:40px}.home-category-section:last-child{margin-bottom:0}.home-category-heading{font-family:Outfit,sans-serif;font-size:1.2rem;font-weight:700;color:var(--text-main);margin-bottom:16px;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}.home-category-heading svg{color:var(--accent);width:18px;height:18px}.home-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;margin-top:24px}.home-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;padding:24px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;gap:12px}.home-card:hover{border-color:var(--accent);box-shadow:0 10px 25px -5px #6366f114;transform:translateY(-4px)}.home-card-icon{width:42px;height:42px;border-radius:10px;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;transition:background-color .2s ease,color .2s ease}.home-card:hover .home-card-icon{background:var(--accent);color:#fff}.home-card h3{font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:700;color:var(--text-main)}.home-card p{font-size:.85rem;color:var(--text-muted);line-height:1.4}.imgmeta-top-bar{display:flex;flex-direction:column;gap:16px;padding:16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;width:100%;box-sizing:border-box}@media (min-width: 768px){.imgmeta-top-bar{flex-direction:row;align-items:center;justify-content:space-between}}.thumbnails-scroll-container{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;flex:1}.thumbnails-scroll-container::-webkit-scrollbar{height:6px}.thumbnails-scroll-container::-webkit-scrollbar-track{background:transparent}.thumbnails-scroll-container::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}.thumbnail-card{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-app);border:1.5px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s ease;min-width:160px;max-width:220px;flex-shrink:0;position:relative}.thumbnail-card:hover{border-color:var(--accent)}.thumbnail-card.selected{border-color:var(--accent);background:var(--accent-light);box-shadow:0 0 0 2px #4f46e526}.thumb-img-wrapper{width:40px;height:40px;border-radius:6px;overflow:hidden;position:relative;background:#000;display:flex;align-items:center;justify-content:center;flex-shrink:0}.thumb-img-wrapper img{width:100%;height:100%;object-fit:cover}.thumb-raw-icon{color:#fff;font-size:.7rem;font-weight:700;letter-spacing:1px}.thumb-remove-btn{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;background:#ef4444;color:#fff;border:none;font-size:11px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .2s ease;z-index:10;padding:0}.thumbnail-card:hover .thumb-remove-btn{opacity:1}.thumb-info{display:flex;flex-direction:column;min-width:0}.thumb-name{font-size:.8rem;font-weight:600;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.thumb-size{font-size:.7rem;color:var(--text-muted)}.thumbnail-add-card{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;background:transparent;border:1.5px dashed var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s ease;min-width:110px;flex-shrink:0;color:var(--text-muted);font-weight:500;font-size:.8rem}.thumbnail-add-card:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.thumbnail-add-card .add-icon{font-size:1.2rem;font-weight:700}.top-bar-actions{display:flex;gap:8px;flex-shrink:0;align-items:center}.top-bar-actions button{padding:8px 16px;font-size:.85rem;font-weight:600;border-radius:8px}.imgmeta-compare-container{display:flex;flex-direction:column;gap:16px;padding:20px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;width:100%;box-sizing:border-box}.compare-header{display:flex;justify-content:space-between;align-items:center}.compare-header h3{margin:0;font-size:1.15rem;font-weight:700;color:var(--text-main)}.compare-table-wrapper{max-height:600px;overflow:auto}.compare-table{width:100%;border-collapse:separate;border-spacing:0}.compare-table th,.compare-table td{min-width:180px;max-width:300px;word-wrap:break-word;word-break:break-all;vertical-align:middle}.compare-table thead th{position:sticky;top:0;background:var(--bg-card);z-index:3;border-bottom:2px solid var(--border-color)}.compare-table thead th.active-col{background:linear-gradient(0deg,#4f46e508,#4f46e508),var(--bg-card)}.compare-table thead th:first-child{top:0;left:0;z-index:4;background:var(--bg-app)}.compare-table th:first-child,.compare-table td:first-child{min-width:140px;max-width:160px;position:sticky;left:0;background:var(--bg-app);z-index:2;border-right:1.5px solid var(--border-color)}.compare-table td:first-child{background:var(--bg-card);font-weight:600}.compare-th-content{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%}.compare-filename{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.compare-preview-thumb{width:60px;height:45px;border-radius:4px;overflow:hidden;background:#000;display:inline-flex;align-items:center;justify-content:center}.compare-preview-thumb img{width:100%;height:100%;object-fit:contain}.compare-raw-thumb{color:#fff;font-size:.6rem;font-weight:700}.compare-table td.active-col,.compare-table th.active-col{background:#4f46e508;border-left:1px solid rgba(79,70,229,.2);border-right:1px solid rgba(79,70,229,.2)}.compare-field-label{font-weight:600;color:var(--text-muted)}.compare-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;color:var(--text-muted);text-align:center}.compare-empty-state p{margin:0;font-size:1.05rem;font-weight:600;color:var(--text-main)}.thumb-compare-checkbox{width:16px;height:16px;cursor:pointer;accent-color:var(--accent);flex-shrink:0}.imgmeta-stripper-card{padding:16px;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-card);display:flex;flex-direction:column;gap:12px}.imgmeta-stripper-card h4{margin:0;font-size:.95rem;font-weight:700;color:var(--text-main)}.stripper-desc{font-size:.8rem;color:var(--text-muted);margin:0;line-height:1.4}.stripper-buttons{display:flex;gap:8px;margin-top:4px}.stripper-buttons button{flex:1;padding:8px 12px;font-size:.8rem;font-weight:600;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px}.btn-accent{background:var(--accent);color:#fff;border:none}.btn-accent:hover{filter:brightness(1.1)}.btn-accent:disabled,.btn-accent-outline:disabled{opacity:.5;cursor:not-allowed}.btn-accent-outline{background:transparent;color:var(--accent);border:1.5px solid var(--accent)}.btn-accent-outline:hover{background:var(--accent-light)}.stripper-warning{font-size:.75rem;color:#eab308;margin:0;font-weight:500}.stripper-result{display:flex;flex-direction:column;gap:12px}.stripper-status-badge{background:#10b981;color:#fff;font-size:.8rem;font-weight:700;padding:6px 12px;border-radius:6px;text-align:center;text-transform:uppercase;letter-spacing:.05em}.stripper-diff{display:flex;flex-direction:column;gap:10px;background:var(--bg-app);padding:10px;border-radius:8px;border:1px solid var(--border-color)}.diff-section{display:flex;flex-direction:column;gap:6px}.diff-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em}.diff-section.removed .diff-label{color:#ef4444}.diff-section.retained .diff-label{color:#10b981}.diff-tags-list{display:flex;flex-wrap:wrap;gap:6px}.tag-pill{font-size:.7rem;padding:3px 8px;border-radius:4px;font-weight:600}.tag-pill.removed{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.tag-pill.retained{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.tag-pill.more{background:#64748b1a;color:var(--text-muted)}.stripper-actions{display:flex;gap:8px}.stripper-actions button{flex:1;padding:8px 12px;font-size:.8rem;font-weight:600;border-radius:8px}.imgmeta-gps-card{padding:16px;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-card);display:flex;flex-direction:column;gap:12px}.imgmeta-gps-card h4{margin:0;font-size:.95rem;font-weight:700;color:var(--text-main)}.coords-text{font-family:Outfit,monospace;font-size:.85rem;color:var(--text-main);margin:0 0 8px;font-weight:600}.gps-actions{display:flex;gap:8px}.gps-actions button,.gps-actions a{padding:6px 12px;font-size:.75rem;font-weight:600;border-radius:6px;text-align:center}.gps-map-container{overflow:hidden;border-radius:8px;margin-top:4px}.imgmeta-advanced-wrapper{display:flex;flex-direction:column;gap:16px;width:100%}.advanced-toolbar{display:flex;justify-content:space-between;align-items:center}.match-count{font-size:.8rem;color:var(--text-muted);font-weight:500}.advanced-groups-list{display:flex;flex-direction:column;gap:12px}.advanced-group-card{border:1px solid var(--border-color);border-radius:10px;background:var(--bg-card);overflow:hidden}.advanced-group-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-app);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s ease}.advanced-group-header:hover{background:#4f46e505}.header-label{display:flex;align-items:center;gap:8px}.header-label .group-icon{font-size:1rem}.header-label .group-name{font-size:.85rem;font-weight:700;color:var(--text-main)}.header-label .group-count{font-size:.75rem;color:var(--text-muted);font-weight:500}.collapse-arrow{font-size:.75rem;color:var(--text-muted);transition:transform .2s ease}.advanced-group-body{border-top:1px solid var(--border-color);max-height:300px;overflow-y:auto}.top-bar-stripper{display:flex;align-items:center;gap:8px;border-right:1.5px solid var(--border-color);padding-right:16px;margin-right:8px}.stripper-mini-label{font-size:.8rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-right:4px}.stripper-mini-status{font-size:.8rem;font-weight:700;color:#10b981;text-transform:uppercase;letter-spacing:.05em;margin-right:4px}.imgmeta-gps-card.green-region-gps{margin-top:16px;padding:20px;flex-direction:column;gap:16px}.green-region-gps .gps-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;width:100%}.green-region-gps h4{margin:0;font-size:1rem;font-weight:700}.green-region-gps .coords-text{margin:0;font-size:.9rem;font-family:Outfit,monospace;font-weight:600}.green-region-gps .gps-actions{display:flex;gap:8px;align-items:center}.imgmeta-container{position:relative}.imgmeta-drag-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#0f172af2;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:2.5px dashed var(--accent);border-radius:14px;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s ease;pointer-events:none}.imgmeta-drag-overlay .overlay-content{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--accent)}.imgmeta-drag-overlay p{font-size:1.15rem;font-weight:700;margin:0;color:var(--text-main)}.color-tool-layout{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;width:100%;align-items:start}@media (max-width: 1150px){.color-tool-layout{grid-template-columns:repeat(2,1fr);gap:24px}}@media (max-width: 768px){.color-tool-layout{grid-template-columns:1fr;gap:28px}}.color-converter-section,.color-picker-section{display:flex;flex-direction:column;gap:16px;width:100%}.color-converter-section h3,.color-picker-section h3{font-size:.95rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:4px;border-bottom:1px solid var(--border-color);padding-bottom:8px}.input-with-button{display:flex;gap:8px;width:100%}.input-with-button input{flex:1}.eyedropper-btn{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border:1px solid var(--border-color);background:var(--bg-app);color:var(--text-main);border-radius:10px;cursor:pointer;transition:all .2s ease}.eyedropper-btn:hover{background:var(--border-hover);color:var(--accent);border-color:var(--accent);transform:translateY(-1px)}.eyedropper-btn:active{transform:translateY(1px)}.hsl-picker-container{display:flex;gap:24px;width:100%;align-items:stretch}.hsl-picker-board{position:relative;height:220px;flex:1;border-radius:12px;border:1px solid var(--border-color);overflow:hidden;cursor:crosshair;box-shadow:inset 0 2px 4px #0000000d}.hsl-picker-board-rainbow{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to right,red,#ff0 17%,#0f0 33%,#0ff,#00f 67%,#f0f 83%,red)}.hsl-picker-board-saturation{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#80808000,gray)}.hsl-marker{position:absolute;width:18px;height:18px;border-radius:50%;border:2.5px solid #ffffff;box-shadow:0 0 0 1px #00000080,0 2px 6px #0006;transform:translate(-50%,-50%);pointer-events:none}.lightness-slider-wrapper{display:flex;flex-direction:column;align-items:center;gap:6px}.lightness-slider-wrapper .slider-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.lightness-slider{position:relative;width:28px;height:220px;border-radius:14px;border:1px solid var(--border-color);cursor:ns-resize;box-shadow:inset 0 2px 4px #00000014}.lightness-handle{position:absolute;left:-2px;right:-2px;height:8px;background:#fff;border:2px solid #2d3748;border-radius:4px;transform:translateY(-50%);box-shadow:0 1px 4px #0006;pointer-events:none}.swatches-section{display:flex;flex-direction:column;gap:8px;margin-top:4px}.swatches-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.swatches-grid{display:flex;flex-wrap:wrap;gap:8px}.swatch-btn{width:24px;height:24px;border-radius:6px;border:1px solid var(--border-color);cursor:pointer;box-shadow:0 1px 2px #0000000d;transition:all .2s cubic-bezier(.175,.885,.32,1.275)}.swatch-btn:hover{transform:scale(1.15);box-shadow:0 4px 8px #00000026;border-color:var(--accent)}.swatch-btn:active{transform:scale(.95)}.recent-colors{margin-top:8px;border-top:1px dashed var(--border-color);padding-top:12px}.swatches-header{display:flex;justify-content:space-between;align-items:center;width:100%;margin-bottom:2px}.swatches-controls{display:flex;gap:6px;align-items:center}.palette-control-btn{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-muted);border-radius:6px;font-size:.65rem;font-weight:700;text-transform:uppercase;padding:4px 8px;cursor:pointer;transition:all .2s ease;line-height:1.2}.palette-control-btn:hover{background:var(--border-hover);color:var(--text-main);border-color:var(--border-hover)}.palette-control-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.palette-control-btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.palette-control-btn.danger{color:#ef4444;border-color:#ef444433}.palette-control-btn.danger:hover{background:#ef444414;border-color:#ef4444}.swatch-wrapper{position:relative;display:inline-block}.swatch-delete-btn{position:absolute;top:-4px;right:-4px;width:15px;height:15px;border-radius:50%;background:#ef4444;color:#fff;border:none;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 1px 3px #0000004d;transition:all .15s ease;padding:0;line-height:1;z-index:2}.swatch-delete-btn:hover{transform:scale(1.2);background:#dc2626}.swatch-add-btn{width:24px;height:24px;border-radius:6px;border:2px dashed var(--border-color);background:transparent;color:var(--text-muted);font-size:.95rem;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;padding:0;line-height:1}.swatch-add-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light);transform:scale(1.08)}.swatch-add-btn:active{transform:scale(.95)}.swatches-grid.editing{gap:10px}.section-header-row{display:flex;justify-content:space-between;align-items:center;width:100%;border-bottom:1px solid var(--border-color);padding-bottom:8px;margin-bottom:4px}.section-header-row h3{border-bottom:none!important;margin-bottom:0!important;padding-bottom:0!important}.picker-tabs{display:flex;background:var(--bg-app);padding:3px;border-radius:10px;gap:2px;border:1px solid var(--border-color)}.picker-tab-btn{border:none;background:transparent;color:var(--text-muted);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:4px 12px;border-radius:7px;cursor:pointer;transition:all .2s ease;line-height:1.2}.picker-tab-btn:hover{color:var(--text-main)}.picker-tab-btn.active{background:var(--bg-card);color:var(--text-main);box-shadow:0 1px 3px #00000014}.swatches-block-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:3px;width:75%;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-app);padding:4px}.swatch-block{aspect-ratio:1;width:100%;border:none;cursor:pointer;position:relative;padding:0;border-radius:2px;transition:transform .1s cubic-bezier(.165,.84,.44,1);box-shadow:inset 0 0 0 .5px #0000000d}.swatch-block:hover{transform:scale(1.25);z-index:5;box-shadow:0 4px 10px #00000040,inset 0 0 0 .5px #fff6;border-radius:4px}.swatch-block.selected{outline:2.5px solid var(--text-main);outline-offset:-2.5px;box-shadow:0 0 0 1.5px #fff,0 3px 8px #0000004d;z-index:10;border-radius:4px;transform:scale(1.1)}html[data-theme=dark] .swatch-block.selected{box-shadow:0 0 0 1.5px #1f2937,0 3px 8px #0006}.sync-toggle-btn{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-muted);border-radius:6px;font-size:.65rem;font-weight:700;text-transform:uppercase;padding:4px 8px;cursor:pointer;transition:all .2s ease;line-height:1.2;position:relative;display:flex;align-items:center;gap:5px}.sync-toggle-btn:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:#cbd5e1;transition:background-color .2s ease}.sync-toggle-btn.synced{color:var(--text-main);border-color:#10b98166;background:#10b9810d}.sync-toggle-btn.synced:before{background:#10b981;box-shadow:0 0 4px #10b981}.sync-toggle-btn:hover{border-color:var(--border-hover);background:var(--border-hover);color:var(--text-main)}.sync-toggle-btn.synced:hover{border-color:#10b981;background:#10b9811a}.view-mode-toggle-container{display:flex;gap:8px;margin-bottom:20px;background:var(--bg-app);padding:4px;border-radius:10px;align-self:flex-start;border:1px solid var(--border-color);width:fit-content}.view-mode-btn{background:transparent;border:none;padding:6px 16px;border-radius:8px;font-size:.85rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .2s ease;font-family:inherit}.view-mode-btn:hover{color:var(--text-main)}.view-mode-btn.active{background:var(--bg-card);color:var(--accent);box-shadow:0 2px 6px #0000000d}html[data-theme=dark] .view-mode-btn.active{box-shadow:0 2px 6px #0003}.codon-toggle-container{display:flex;background:var(--bg-app);padding:4px;border-radius:10px;border:1px solid var(--border-color);height:46px;width:100%}.codon-toggle-btn{flex:1;background:transparent;border:none;border-radius:8px;font-size:.85rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .2s ease;font-family:inherit;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1}.codon-toggle-btn:hover{color:var(--text-main)}.codon-toggle-btn.active{background:var(--bg-card);color:var(--accent);box-shadow:0 2px 6px #0000000d}html[data-theme=dark] .codon-toggle-btn.active{box-shadow:0 2px 6px #0003}.dna-visual-container{display:flex;flex-direction:column;gap:16px;width:100%}.dna-visual-placeholder{padding:48px;text-align:center;color:var(--text-muted);font-weight:500;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px}.dna-visual-placeholder.error{color:#ef4444;border-color:#ef444433;background:#ef444405}.dna-visual-wrapper{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;display:flex;flex-direction:column;gap:16px;width:100%;box-shadow:var(--shadow-card)}.dna-visual-legend{display:flex;flex-wrap:wrap;gap:24px;font-size:.85rem;color:var(--text-muted);font-weight:500;border-bottom:1px solid var(--border-color);padding-bottom:12px}.legend-item{display:flex;align-items:center;gap:8px}.legend-line{display:inline-block;width:24px;height:6px;border-radius:3px}.legend-line--red{background:#ef4444}.legend-line--blue{background:#3b82f6;opacity:.6}.dna-visual-scroll-container{width:100%;overflow-x:auto;white-space:nowrap;padding-bottom:12px}.dna-visual-scroll-container::-webkit-scrollbar{height:8px}.dna-visual-scroll-container::-webkit-scrollbar-track{background:transparent}.dna-visual-scroll-container::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px}.dna-svg{display:block}.typing-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.typing-header-row h2{margin-bottom:0}.typing-modes-tabs{display:flex;gap:8px}.typing-settings-panel{background:var(--bg-app);border:1px solid var(--border-color);border-radius:12px;padding:16px 20px;margin-bottom:24px}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.setting-control{display:flex;flex-direction:column;gap:6px}.setting-control label{font-size:.85rem;font-weight:600;color:var(--text-muted)}.setting-control select{padding:8px 12px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-sidebar);color:var(--text-main);outline:none;transition:border-color .2s}.setting-control select:focus{border-color:var(--accent)}.custom-template-input-container{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:12px}.file-upload-group{display:flex;align-items:center;gap:12px;font-size:.9rem}.file-upload-group input[type=file]{color:var(--text-muted)}.typing-stage-area{display:flex;flex-direction:column;gap:20px;margin-bottom:30px}.live-indicators{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.live-timer-container{font-family:Outfit,sans-serif;font-weight:700}.live-timer{font-size:2.5rem;color:var(--accent);text-shadow:0 2px 4px rgba(99,102,241,.1)}.live-stat-badges{display:flex;gap:10px}.live-stat-badges .badge{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:8px 14px;font-size:.9rem;font-weight:600;color:var(--text-muted);box-shadow:var(--shadow-card)}.live-stat-badges .badge .val{color:var(--text-main);font-weight:700}.typing-input-catcher{position:absolute;opacity:0;width:0;height:0;overflow:hidden;pointer-events:none}.typing-template-container{position:relative;background:var(--bg-card);border:2px solid var(--border-color);border-radius:12px;padding:30px;min-height:160px;cursor:text;outline:none;transition:border-color .2s,box-shadow .2s;box-shadow:var(--shadow-card);-webkit-user-select:none;user-select:none}.typing-template-container.focused{border-color:var(--accent);box-shadow:0 0 0 3px var(--focus-ring)}.focus-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:10px;display:flex;align-items:center;justify-content:center;z-index:5;color:#fff;font-weight:600;transition:opacity .2s}html[data-theme=light] .focus-overlay{background:#fff9;color:var(--text-main)}.focus-message{display:flex;flex-direction:column;align-items:center;gap:8px;animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.03)}to{transform:scale(1)}}.typing-text-wrapper{font-family:Roboto Mono,Fira Code,Courier New,monospace;font-size:1.55rem;line-height:1.65;word-spacing:.1em;display:flex;flex-wrap:wrap;align-content:flex-start;color:var(--text-muted)}.typing-word{position:relative;display:inline-block;margin-right:.35em;border-bottom:2px solid transparent}.typing-word.error{border-bottom-color:#ef444466}.typing-tooltip{position:absolute;bottom:125%;left:50%;transform:translate(-50%);background:#1e293bf2;border:1px solid rgba(255,255,255,.15);color:#f1f5f9;border-radius:8px;padding:6px 14px;font-size:.85rem;white-space:nowrap;pointer-events:none;box-shadow:0 4px 16px #00000059;display:flex;align-items:center;gap:8px;z-index:10;animation:tooltipFadeIn .15s ease-out;font-family:var(--font-family, sans-serif)}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%,5px)}to{opacity:1;transform:translate(-50%)}}.tooltip-typed{color:#f8fafc;font-weight:700}.tooltip-divider{font-size:1rem}.tooltip-expected{color:#94a3b8;font-weight:500}.char{position:relative;transition:color .12s}.char.untyped{color:#94a3b8}html[data-theme=dark] .char.untyped{color:#4b5563}.char.correct{color:var(--text-main)}.char.incorrect{color:#ef4444;background:#ef44441a;border-radius:2px}.char.space.incorrect{background:#ef444440;border-radius:2px}.caret{position:absolute;left:0;top:10%;height:80%;width:2.5px;background-color:var(--accent);animation:blink-caret 1s step-end infinite;display:inline-block}@keyframes blink-caret{0%,to{background-color:transparent}50%{background-color:var(--accent)}}.ime-composition{position:absolute;left:0;top:100%;background:var(--bg-sidebar);color:var(--accent);border-bottom:2px dashed var(--accent);font-size:.95rem;line-height:1;padding:2px 4px;border-radius:4px;white-space:nowrap;z-index:8;box-shadow:0 2px 8px #00000026}.free-typing-container{width:100%}.free-typing-textarea{width:100%;background:var(--bg-card);color:var(--text-main);border:2px solid var(--border-color);border-radius:12px;padding:20px;font-size:1.25rem;line-height:1.5;outline:none;resize:vertical;transition:border-color .2s,box-shadow .2s;box-shadow:var(--shadow-card)}.free-typing-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--focus-ring)}.free-typing-textarea:disabled{opacity:.4;cursor:not-allowed}.free-typing-container.paused{position:relative}.free-typing-paused-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:12px;pointer-events:none}.free-typing-paused-overlay span:first-child{font-size:1.5rem;font-weight:700;color:#fff;letter-spacing:.05em}.free-typing-paused-overlay .paused-hint{font-size:.8rem;color:#fff9}html[data-theme=light] .free-typing-paused-overlay{background:#ffffffa6}html[data-theme=light] .free-typing-paused-overlay span:first-child{color:var(--text-main)}html[data-theme=light] .free-typing-paused-overlay .paused-hint{color:var(--text-muted)}.test-control-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:10px}.typing-results-dashboard{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:30px;box-shadow:var(--shadow-card);margin-bottom:30px;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.results-card h3{font-size:1.5rem;margin-bottom:24px;text-align:center;color:var(--text-main)}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:20px;margin-bottom:30px}.metric-box{background:var(--bg-app);border:1px solid var(--border-color);border-radius:12px;padding:18px 12px;text-align:center;display:flex;flex-direction:column;gap:8px}.metric-box .label{font-size:.85rem;color:var(--text-muted);font-weight:600}.metric-box .value{font-size:1.85rem;font-weight:800;color:var(--text-main)}.metric-box .value.accent-val{color:var(--accent)}.results-actions{display:flex;justify-content:center;gap:16px}.typing-history-section{margin-top:40px;border-top:1px solid var(--border-color);padding-top:30px}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}.history-actions{display:flex;gap:16px}.text-action-btn{background:transparent;border:none;color:var(--accent);font-weight:600;font-size:.9rem;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background-color .2s,color .2s}.text-action-btn:hover{background:var(--accent-light)}.text-action-btn.danger{color:#ef4444}.text-action-btn.danger:hover{background:#ef444414}.no-history-msg{color:var(--text-muted);font-style:italic;text-align:center;padding:30px}.history-table-wrapper{overflow-x:auto;border-radius:12px;border:1px solid var(--border-color);background:var(--bg-card)}.history-table{width:100%;border-collapse:collapse;text-align:left;font-size:.9rem}.history-table th,.history-table td{padding:12px 16px;border-bottom:1px solid var(--border-color)}.history-table th{background:var(--bg-app);color:var(--text-muted);font-weight:600}.history-table tr:last-child td{border-bottom:none}.history-table tbody tr:hover{background:#f4f6fb80}html[data-theme=dark] .history-table tbody tr:hover{background:#1f293766}.wpm-td{font-weight:700;color:var(--accent)}.typing-config-bar{display:flex;justify-content:center;align-items:center;background:var(--bg-card);border:1px solid var(--border-color);padding:8px 16px;border-radius:10px;font-family:inherit;font-size:.88rem;color:var(--text-muted);margin-bottom:24px;gap:12px;-webkit-user-select:none;user-select:none;flex-wrap:wrap;box-shadow:var(--shadow-card)}.config-group{display:flex;align-items:center;gap:10px}.config-separator{width:1px;height:14px;background:var(--border-color)}.config-item{display:flex;align-items:center;gap:4px;cursor:pointer;transition:all .2s ease;padding:4px 8px;border-radius:6px}.config-item:hover{color:var(--text-main);background:#0000000a}html[data-theme=dark] .config-item:hover{background:#ffffff0a}.config-item.active{color:var(--accent);background:var(--accent-light);font-weight:600}.config-item .icon{font-weight:800;font-size:.95rem}.config-item svg{display:inline-block;vertical-align:middle}.typing-config-container{display:flex;flex-direction:column;align-items:center;gap:20px;margin-bottom:24px;width:100%}.typing-config-container .typing-config-bar{margin-bottom:0}.typing-sub-config-bar{display:flex;justify-content:center;align-items:center;gap:12px;font-size:.8rem;color:var(--text-muted);-webkit-user-select:none;user-select:none;flex-wrap:wrap}.typing-sub-config-bar .config-item{padding:2px 6px;border-radius:4px}.typing-sub-config-bar .config-separator{height:10px}.typing-template-container.code-mode-editor{background:#0f141c;border-color:#6366f140;padding:24px;box-shadow:inset 0 2px 8px #0006}html[data-theme=light] .typing-template-container.code-mode-editor{background:#fafafa;border-color:#e2e8f0;box-shadow:inset 0 2px 4px #0000000d}.typing-code-block{font-family:Fira Code,Roboto Mono,Consolas,Monaco,monospace;font-size:1.15rem;line-height:1.6;width:100%;text-align:left}.code-line{display:flex;align-items:flex-start;width:100%;margin-bottom:2px}.line-number{width:2.2rem;text-align:right;margin-right:1.2rem;color:#4b5563;-webkit-user-select:none;user-select:none;font-size:.95rem;opacity:.6}html[data-theme=light] .line-number{color:#94a3b8}.line-content{flex:1;white-space:pre-wrap;word-break:break-all}.code-mode-editor .char.untyped{color:#4b5563}html[data-theme=light] .code-mode-editor .char.untyped{color:#94a3b8}.code-mode-editor .char.correct{color:#f3f4f6}html[data-theme=light] .code-mode-editor .char.correct{color:#1f2937}.code-mode-editor .char.incorrect{color:#ef4444;background:#ef444426;border-radius:2px}.code-mode-editor .char.space-char.incorrect{background:#ef444440}.newline-char{color:#4b5563;opacity:.4;margin-left:2px;font-weight:700;-webkit-user-select:none;user-select:none;display:inline-block;font-size:1.1rem}html[data-theme=light] .newline-char{color:#94a3b8}.code-mode-editor .newline-char.correct{color:var(--accent);opacity:.7}.code-mode-editor .newline-char.incorrect{color:#ef4444;background:#ef444440;opacity:1}.code-lang-badge{position:absolute;top:12px;right:16px;font-family:var(--font-family, sans-serif);font-size:.72rem;color:#94a3b8;background:#ffffff14;padding:2px 8px;border-radius:4px;text-transform:uppercase;font-weight:700;-webkit-user-select:none;user-select:none;opacity:.7;letter-spacing:.05em;z-index:6}html[data-theme=light] .code-lang-badge{color:#4b5563;background:#0000000d}.template-refresh-row{display:flex;justify-content:center;margin-top:14px;width:100%}.btn-small{padding:5px 12px;font-size:.82rem;border-radius:6px;display:inline-flex;align-items:center;cursor:pointer;transition:all .2s ease}.file-upload-btn{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-family:inherit;font-weight:600;transition:all .2s ease}.uploaded-file-name{font-size:.85rem;color:var(--text-muted);font-weight:500;background:#ffffff0d;padding:4px 10px;border-radius:6px;border:1px solid var(--border-color);margin-left:10px;display:inline-block;vertical-align:middle}html[data-theme=light] .uploaded-file-name{background:#00000005}.code-languages-group{display:flex;flex-wrap:wrap;gap:6px}@keyframes ct-ripple-anim{to{transform:scale(1);opacity:0}}@keyframes ct-panel-slide-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes ct-pulse-glow{0%,to{box-shadow:0 0 #6366f100}50%{box-shadow:0 0 0 6px #6366f126}}.ct-root{display:flex;flex-direction:column;gap:1.5rem;width:100%;max-width:1100px;margin:0 auto;padding:1.5rem 1.25rem 2rem;font-family:Inter,system-ui,sans-serif}.ct-workspace{display:flex;gap:1.5rem;align-items:start;justify-content:center}.ct-table-container{flex:2.2;min-width:0;max-width:760px}.ct-side-panel{flex:1;min-width:300px;position:sticky;top:1.5rem;align-self:start}.ct-header{display:flex;flex-direction:column;gap:.6rem;width:100%}.ct-header-top{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;width:100%}.ct-title{font-size:1.45rem;font-weight:700;color:var(--text-main);display:flex;align-items:center;gap:.55rem;margin-bottom:0}.ct-subtitle{font-size:.85rem;color:var(--text-muted);line-height:1.5}.ct-subtitle-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.5rem;width:100%;margin-top:.2rem}.ct-filter-bar{display:flex;gap:.5rem;flex-wrap:wrap}.ct-filter-btn{padding:.4rem .85rem;border-radius:9999px;font-size:.78rem;font-weight:600;border:1.5px solid var(--border-color);background:var(--bg-card);color:var(--text-muted);cursor:pointer;transition:all .18s ease;letter-spacing:.02em}.ct-filter-btn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.ct-filter-btn.is-active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 8px #6366f159}.ct-filter-btn--start.is-active{background:#16a34a;border-color:#16a34a;box-shadow:0 2px 8px #16a34a59}.ct-filter-btn--stop.is-active{background:#dc2626;border-color:#dc2626;box-shadow:0 2px 8px #dc262659}.ct-legend{display:flex;gap:1rem;flex-wrap:wrap;font-size:.75rem;color:var(--text-muted)}.ct-legend-item{display:flex;align-items:center;gap:.35rem}.ct-legend-item--start{color:#16a34a;font-weight:600}.ct-legend-item--stop{color:#dc2626;font-weight:600}.ct-legend-item--highlight{color:var(--accent);font-weight:600}.ct-outer-grid{display:grid;grid-template-columns:36px 1fr 36px;grid-template-rows:36px auto;gap:0;align-items:stretch;border-radius:12px;overflow:hidden;border:1px solid var(--border-color);box-shadow:var(--shadow-card);background:var(--bg-card)}.ct-axis-label{display:flex;align-items:center;justify-content:center}.ct-axis-label span{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);white-space:nowrap}.ct-axis-label--left{grid-column:1;grid-row:1 / span 2;writing-mode:vertical-rl;background:linear-gradient(180deg,#6366f114,#6366f10a);border-right:1px solid var(--border-color)}.ct-axis-label--top{grid-column:2;grid-row:1;background:linear-gradient(90deg,#6366f114,#6366f10a);border-bottom:1px solid var(--border-color)}.ct-axis-label--right{grid-column:3;grid-row:1 / span 2;writing-mode:vertical-rl;background:linear-gradient(180deg,#6366f114,#6366f10a);border-left:1px solid var(--border-color);transform:rotate(180deg)}.ct-inner-wrapper{grid-column:2;grid-row:2;display:flex;flex-direction:column}.ct-axis-top,.ct-axis-bottom{display:grid;grid-template-columns:36px repeat(4,1fr) 44px;background:var(--bg-app);border-bottom:1px solid var(--border-color)}.ct-axis-bottom{border-bottom:none;border-top:1px solid var(--border-color)}.ct-axis-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.45rem .25rem}.ct-axis-cell--2nd{border-left:1px solid var(--border-color)}.ct-axis-base{font-family:JetBrains Mono,Fira Code,monospace;font-size:1.2rem;font-weight:700}.ct-axis-desc{font-size:.58rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:1px}.ct-base-U{color:#a78bfa}.ct-base-C{color:#38bdf8}.ct-base-A{color:#fbbf24}.ct-base-G{color:#34d399}.ct-cell-b2-U{background:#a78bfa0a}.ct-cell-b2-C{background:#38bdf80a}.ct-cell-b2-A{background:#fbbf240a}.ct-cell-b2-G{background:#34d3990a}.ct-b1-U .ct-row-header{background:#a78bfa1a}.ct-b1-C .ct-row-header{background:#38bdf81a}.ct-b1-A .ct-row-header{background:#fbbf241a}.ct-b1-G .ct-row-header{background:#34d3991a}.ct-table-body{display:flex;flex-direction:column;position:relative}.ct-axis-right-container{display:none}.ct-row-group{display:grid;grid-template-columns:36px 1fr 44px;border-top:1px solid var(--border-color)}.ct-row-group:first-child{border-top:none}.ct-row-header{display:flex;align-items:center;justify-content:center;border-right:1px solid var(--border-color);font-family:JetBrains Mono,monospace;font-size:1.25rem;font-weight:700;padding:.25rem}.ct-row-right-axis{display:grid;grid-template-rows:repeat(4,1fr);border-left:1px solid var(--border-color)}.ct-axis-cell--3rd-inline{display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border-color);font-family:JetBrains Mono,monospace;font-size:.9rem;font-weight:700;padding:0}.ct-axis-cell--3rd-inline:last-child{border-bottom:none}.ct-row-cells{display:grid;grid-template-columns:repeat(4,1fr)}.ct-cell{position:relative;border-left:1px solid var(--border-color);display:grid;grid-template-rows:repeat(4,1fr)}.ct-cell{padding-right:64px}.ct-codon-row{display:flex;align-items:center;padding:2px 4px;border-bottom:1px solid rgba(var(--border-color),.5);min-height:32px;transition:background .15s}.ct-codon-row:last-child{border-bottom:none}.ct-codon-row.ct-hidden{opacity:.2;pointer-events:none}.ct-codon-btn{font-family:JetBrains Mono,Fira Code,monospace;font-size:.88rem;font-weight:600;padding:3px 6px;border-radius:5px;border:1.5px solid transparent;background:transparent;color:var(--text-main);cursor:pointer;transition:all .12s ease;letter-spacing:.04em;white-space:nowrap;position:relative;overflow:hidden;width:100%;text-align:left}.ct-codon-btn:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent);transform:scale(1.05);z-index:2;box-shadow:0 2px 8px #6366f133}.ct-codon-btn:active{transform:scale(.97)}.ct-codon-btn.is-selected{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:700;box-shadow:0 0 0 3px var(--focus-ring),0 2px 10px #6366f159;animation:ct-pulse-glow 2s ease-in-out infinite}.ct-codon-btn.is-highlighted{background:color-mix(in srgb,var(--accent-light) 70%,transparent);border-color:var(--accent)}.ct-codon-btn.codon-start{color:#16a34a;font-weight:700}.ct-codon-btn.codon-start:hover,.ct-codon-btn.codon-start.is-selected{background:#16a34a26;border-color:#16a34a;color:#16a34a;box-shadow:0 0 0 3px #16a34a26}.ct-codon-btn.codon-start.is-selected{background:#16a34a;color:#fff}.ct-codon-btn.codon-stop{color:#dc2626;font-weight:700}.ct-codon-btn.codon-stop:hover,.ct-codon-btn.codon-stop.is-selected{background:#dc26261f;border-color:#dc2626;color:#dc2626;box-shadow:0 0 0 3px #dc262626}.ct-codon-btn.codon-stop.is-selected{background:#dc2626;color:#fff}.ct-codon-btn.codon-stop.is-highlighted,.ct-aa-btn.ct-aa-stop.is-highlighted{border-color:#dc2626;box-shadow:0 0 10px #dc262666;background:#dc262614}.ct-codon-btn.codon-start.is-highlighted,.ct-aa-btn.ct-aa-start.is-highlighted{border-color:#16a34a;box-shadow:0 0 10px #16a34a66;background:#16a34a14}.ct-aa-labels{position:absolute;right:0;top:0;bottom:0;width:62px;display:grid;grid-template-rows:repeat(4,1fr);border-left:1px solid var(--border-color);background:var(--bg-card)}.ct-aa-label-slot{display:flex;align-items:center;justify-content:center;padding:2px}.ct-aa-btn{font-family:Inter,system-ui,sans-serif;font-size:.8rem;font-weight:700;padding:2px 4px;border-radius:4px;border:1.5px solid transparent;background:transparent;cursor:pointer;transition:all .12s ease;text-align:center;white-space:nowrap;position:relative;overflow:hidden;width:100%;color:var(--text-muted)}.ct-aa-btn:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent);transform:scale(1.06);z-index:2}.ct-aa-btn:active{transform:scale(.96)}.ct-aa-btn.is-highlighted{background:var(--accent-light);border-color:var(--accent)}.ct-aa-btn.ct-aa-start{color:#16a34a;font-size:.75rem}.ct-aa-btn.ct-aa-start:hover{background:#16a34a1f;border-color:#16a34a}.ct-aa-btn.ct-aa-stop{color:#dc2626;font-size:.75rem}.ct-aa-btn.ct-aa-stop:hover{background:#dc26261a;border-color:#dc2626}.ct-info-panel{position:relative;border-radius:12px;border:1.5px solid var(--border-color);padding:1.25rem 1.5rem;background:var(--bg-card);display:flex;flex-direction:column;gap:.85rem;animation:ct-panel-slide-in .25s ease;box-shadow:var(--shadow-card)}.ct-panel--start{border-color:#16a34a80;background:linear-gradient(135deg,rgba(22,163,74,.06),var(--bg-card))}.ct-panel--stop{border-color:#dc262680;background:linear-gradient(135deg,rgba(220,38,38,.05),var(--bg-card))}.ct-panel-close{position:absolute;top:.75rem;right:.75rem;width:20px;height:20px;border-radius:50%;border:1px solid var(--border-color);background:var(--bg-app);color:var(--text-muted);cursor:pointer;font-size:.58rem;display:flex;align-items:center;justify-content:center;transition:all .15s}.ct-panel-close:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.ct-panel-header{display:flex;align-items:center;gap:.85rem;flex-wrap:wrap;padding-right:1.8rem}.ct-panel-aa{font-size:1.65rem;font-weight:700;color:var(--text-main);letter-spacing:-.02em}.ct-panel-abbr-badge{padding:.25rem .65rem;border-radius:8px;font-size:.95rem;font-weight:700;background:var(--bg-app);border:1px solid var(--border-color);color:var(--text-main);font-family:JetBrains Mono,monospace;transition:all .15s}html[data-theme=dark] .ct-panel-abbr-badge{background:#ffffff0d}.ct-panel-header-badges{display:flex;gap:.4rem;flex-wrap:nowrap;align-items:center;flex-shrink:0}.ct-badge{padding:.2rem .65rem;border-radius:9999px;font-size:.72rem;font-weight:600;border:1px solid var(--border-color);background:var(--bg-app);color:var(--text-muted)}.ct-badge--codon{font-family:JetBrains Mono,monospace;color:var(--accent);border-color:var(--accent);background:var(--accent-light)}.ct-badge--start{color:#16a34a;border-color:#16a34a;background:#16a34a1a}.ct-badge--stop{color:#dc2626;border-color:#dc2626;background:#dc262614}.ct-badge--1{font-family:JetBrains Mono,monospace}.ct-panel-synonyms{display:flex;flex-direction:column;gap:.45rem}.ct-panel-syn-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.ct-panel-syn-list{display:flex;flex-wrap:wrap;gap:.4rem}.ct-syn-chip{font-family:JetBrains Mono,monospace;font-size:.85rem;padding:.2rem .6rem;border-radius:6px;background:var(--bg-app);border:1px solid var(--border-color);color:var(--text-muted)}.ct-panel-bases{display:flex;gap:.5rem}.ct-base-bubble{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.5rem .75rem;border-radius:8px;background:var(--bg-app);border:1px solid var(--border-color);min-width:54px}.ct-base-pos{font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.ct-base-letter{font-family:JetBrains Mono,monospace;font-size:1.5rem;font-weight:700}.ct-no-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2.5rem 1.5rem;border-radius:12px;border:1.5px dashed var(--border-color);color:var(--text-muted);font-size:.88rem;background:var(--bg-app);text-align:center;min-height:250px;box-sizing:border-box}@media (max-width: 900px){.ct-workspace{flex-direction:column;align-items:stretch}.ct-side-panel{position:static;width:100%}.ct-no-selection{min-height:auto;padding:1.25rem;flex-direction:row}}@media (max-width: 780px){.ct-root{padding:1rem .5rem 1.5rem}.ct-outer-grid{grid-template-columns:24px 1fr 24px;grid-template-rows:28px auto}.ct-row-header{font-size:.85rem}.ct-codon-btn{font-size:.66rem;padding:2px 3px}.ct-aa-labels{width:44px}.ct-cell{padding-right:44px}.ct-aa-btn{font-size:.58rem;padding:1px 2px}.ct-header{flex-direction:column}.ct-panel-codon{font-size:1.4rem}}@media (max-width: 520px){.ct-axis-desc{display:none}.ct-axis-base{font-size:.78rem}.ct-codon-btn{font-size:.58rem;letter-spacing:0}.ct-codon-row{min-height:26px}}html[data-theme=dark] .ct-codon-btn{color:#e2e8f0}html[data-theme=dark] .ct-codon-btn:hover{background:#6366f12e}html[data-theme=dark] .ct-cell-b2-U{background:#a78bfa0f}html[data-theme=dark] .ct-cell-b2-C{background:#38bdf80f}html[data-theme=dark] .ct-cell-b2-A{background:#fbbf240f}html[data-theme=dark] .ct-cell-b2-G{background:#34d3990f}html[data-theme=dark] .ct-b1-U .ct-row-header{background:#a78bfa24}html[data-theme=dark] .ct-b1-C .ct-row-header{background:#38bdf824}html[data-theme=dark] .ct-b1-A .ct-row-header{background:#fbbf2424}html[data-theme=dark] .ct-b1-G .ct-row-header{background:#34d39924}html[data-theme=dark] .ct-info-panel{background:#1a2236;border-color:#2d3a50}html[data-theme=dark] .ct-panel--start{background:linear-gradient(135deg,#16a34a1a,#1a2236)}html[data-theme=dark] .ct-panel--stop{background:linear-gradient(135deg,#dc262614,#1a2236)}.ct-fischer-container{display:flex;flex-direction:column;gap:.6rem;padding:.85rem 1rem;border-radius:10px;background:var(--bg-app);border:1px solid var(--border-color);margin-top:.4rem}.ct-fischer-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.ct-fischer-layout{display:flex;flex-direction:column;align-items:center;gap:.8rem;width:100%}.ct-fischer-svg{flex-shrink:0;background:var(--bg-card);border-radius:8px;border:1px solid var(--border-color);padding:.5rem}.ct-fisc-text{font-family:JetBrains Mono,monospace;font-size:1.08rem;fill:var(--text-muted)}.ct-fisc-main{font-weight:700;fill:var(--text-main);font-size:1.14rem}.ct-fisc-side{font-family:JetBrains Mono,monospace;font-size:1.02rem;font-weight:700;fill:#0284c7}html[data-theme=dark] .ct-fisc-side{fill:#38bdf8}.ct-fisc-side-bond{stroke:#0284c7;stroke-width:2.4px;stroke-linecap:round}html[data-theme=dark] .ct-fisc-side-bond{stroke:#38bdf8}.ct-fisc-main-bond{stroke:var(--text-muted);stroke-width:2.4px;stroke-linecap:round;opacity:.85}.ct-fisc-c{font-family:JetBrains Mono,monospace;font-size:1.14rem;font-weight:700;fill:var(--accent)}.ct-fischer-info{display:flex;flex-direction:column;gap:.35rem;width:100%;border-top:1px dashed var(--border-color);padding-top:.6rem}.ct-fisc-field{display:flex;flex-direction:row;gap:.5rem;align-items:center;justify-content:center;text-align:center}.ct-fisc-lbl{font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:700}.ct-fisc-val{font-size:.82rem;font-weight:600;color:var(--text-main)}.ct-interactive-panel{display:flex;flex-direction:row;gap:1.5rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;margin-bottom:.5rem;box-shadow:0 4px 20px -2px #00000026}@media (max-width: 768px){.ct-interactive-panel{flex-direction:column;gap:1.5rem}}.ct-typer-section,.ct-group-section{display:flex;flex-direction:column;gap:.8rem;flex:1;min-width:0}.ct-section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border-color);padding-bottom:.4rem}.ct-typer-wrapper{display:flex;flex-direction:column;gap:1rem}.ct-typer-cards-row{display:flex;gap:.8rem}.ct-typer-card{display:flex;flex-direction:column;align-items:center;justify-content:center;width:68px;height:84px;border-radius:10px;border:2px solid var(--border-color);background:#ffffff05;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:inset 0 1px 3px #0000001a}.ct-typer-card:hover{border-color:var(--accent);background:#ffffff0d;transform:translateY(-2px)}.ct-typer-card.is-active{border-color:var(--accent);background:#6366f10f;box-shadow:0 0 10px #6366f140;animation:ct-card-pulse 2s infinite ease-in-out}@keyframes ct-card-pulse{0%,to{border-color:var(--accent)}50%{border-color:#6366f180}}.ct-typer-card-pos{font-size:.65rem;font-weight:700;color:var(--text-muted);margin-bottom:.3rem;letter-spacing:.02em}.ct-typer-card-val{font-family:JetBrains Mono,Courier New,monospace;font-size:1.8rem;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;height:2rem}.ct-typer-cursor{display:inline-block;width:2px;height:1.8rem;background-color:var(--accent);margin-left:2px;animation:ct-blink-anim 1s step-end infinite}@keyframes ct-blink-anim{0%,to{opacity:1}50%{opacity:0}}.ct-typer-input-hidden{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.ct-typer-result{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#ffffff05;border:1px solid var(--border-color);border-radius:8px;padding:.6rem 1rem;min-height:52px}.ct-result-placeholder{color:var(--text-muted);font-size:.85rem;font-style:italic}.ct-result-prompt{color:var(--accent);font-size:.85rem;font-weight:600}.ct-result-error{color:#ef4444;font-size:.85rem;font-weight:600}.ct-result-detail{display:flex;flex-direction:column;gap:.2rem}.ct-result-aa-row{display:flex;align-items:center;gap:.4rem}.ct-result-aa-label{font-size:.75rem;text-transform:uppercase;color:var(--text-muted);font-weight:600}.ct-result-aa-name{font-size:.95rem;font-weight:700}.ct-result-type{font-size:.75rem;color:var(--text-muted)}.ct-typer-clear-btn{background:#ffffff0d;border:1px solid var(--border-color);border-radius:6px;padding:.3rem .6rem;font-size:.75rem;color:var(--text-main);cursor:pointer;transition:all .2s;font-weight:600;border-color:var(--border-color)}.ct-typer-clear-btn:hover{background:#ef444426;border-color:#ef444466;color:#ef4444}.ct-group-wrapper{display:flex;flex-direction:column;gap:1rem}.ct-group-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.ct-group-btn{background:#ffffff08;border:1px solid var(--border-color);border-radius:20px;padding:.4rem .8rem;font-size:.8rem;font-weight:600;color:var(--text-main);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.ct-group-btn:hover{border-color:var(--text-muted);background:#ffffff14}.ct-group-btn.is-active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 8px #6366f14d}.ct-group-btn--hydrophobic.is-active{background:#6d28d9;border-color:#6d28d9;box-shadow:0 2px 8px #6d28d959}.ct-group-btn--polar.is-active{background:#3b82f6;border-color:#3b82f6;box-shadow:0 2px 8px #3b82f659}.ct-group-btn--basic.is-active{background:#10b981;border-color:#10b981;box-shadow:0 2px 8px #10b98159}.ct-group-btn--acidic.is-active{background:#ec4899;border-color:#ec4899;box-shadow:0 2px 8px #ec489959}.ct-group-chips-wrapper{display:flex;flex-direction:column;gap:.4rem;animation:ct-fade-in .25s ease-out}@keyframes ct-fade-in{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}.ct-chips-label{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em}.ct-group-chips{display:flex;flex-wrap:wrap;gap:.4rem}.ct-aa-chip{display:inline-flex;align-items:center;gap:.35rem;border:1px solid var(--border-color);border-radius:6px;padding:.3rem .5rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-weight:600}.ct-aa-chip:hover{transform:scale(1.05)}.ct-aa-chip-abbr{font-size:.8rem;font-weight:700}.ct-aa-chip-full{font-size:.68rem;opacity:.8;font-weight:500}.ct-codon-btn,.ct-aa-btn{transition:all .25s cubic-bezier(.4,0,.2,1)}.ct-codon-btn.is-dimmed,.ct-aa-btn.is-dimmed{opacity:.2;filter:grayscale(40%)}.ct-codon-btn.is-highlighted{box-shadow:0 0 10px var(--accent);transform:scale(1.03);z-index:2}.ct-codon-btn.is-highlighted .ct-codon-letters{font-weight:800}.ct-panel-header-merged{display:flex;justify-content:space-between;align-items:center;padding-right:2rem;min-height:2.2rem}.ct-panel-header-title{display:flex;align-items:center;gap:.6rem;flex-wrap:nowrap}.ct-panel-title-empty{font-size:1.25rem;font-weight:700;color:var(--text-main);letter-spacing:-.01em}.ct-panel-prompt{display:flex;justify-content:center;align-items:center;min-height:120px;padding:1.5rem;text-align:center;border:1px dashed var(--border-color);border-radius:8px;background:#ffffff03}.ct-typer-cards-row--sidebar{justify-content:center;margin:1.2rem 0}.ct-panel-details-scroll{display:flex;flex-direction:column;gap:1rem}.ct-panel--empty{border-color:var(--border-color);background:var(--bg-card)}.ct-custom-creator-panel{display:flex;flex-direction:column;gap:1rem;background:#ffffff05;border:1px solid var(--border-color);border-radius:8px;padding:1.25rem;margin:.5rem 0;animation:ct-fade-in .25s ease-out}.ct-creator-title{font-size:.9rem;font-weight:700;color:var(--text-main);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px dashed var(--border-color);padding-bottom:.5rem}.ct-creator-form{display:flex;flex-direction:column;gap:1rem}.ct-creator-field{display:flex;flex-direction:column;gap:.4rem}.ct-creator-label{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase}.ct-creator-input{background:#0003;border:1px solid var(--border-color);border-radius:6px;padding:.5rem .75rem;color:var(--text-main);font-size:.85rem;outline:none;transition:border-color .2s}.ct-creator-input:focus{border-color:var(--accent)}.ct-creator-colors{display:flex;gap:.6rem;flex-wrap:wrap}.ct-color-circle{width:24px;height:24px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .2s}.ct-color-circle:hover{transform:scale(1.15)}.ct-color-circle.is-selected{border-color:#fff;box-shadow:0 0 8px #ffffff80;transform:scale(1.1)}.ct-creator-aa-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(76px,1fr));gap:.4rem}.ct-creator-aa-btn{display:flex;align-items:center;justify-content:center;gap:.2rem;border:1px solid var(--border-color);border-radius:6px;background:#ffffff03;padding:.35rem;cursor:pointer;transition:all .15s;font-size:.75rem}.ct-creator-aa-btn:hover{border-color:var(--aa-color);background:#ffffff0d}.ct-creator-aa-btn.is-chosen{box-shadow:0 1px 4px #00000026}.ct-creator-aa-code{font-weight:700}.ct-creator-aa-letter{font-size:.65rem;opacity:.7}.ct-creator-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem;border-top:1px dashed var(--border-color);padding-top:.75rem}.ct-creator-btn-save{background:var(--accent);border:1px solid var(--accent);color:#fff;border-radius:6px;padding:.4rem 1rem;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.ct-creator-btn-save:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.ct-creator-btn-save:disabled{opacity:.4;cursor:not-allowed}.ct-creator-btn-cancel{background:transparent;border:1px solid var(--border-color);color:var(--text-muted);border-radius:6px;padding:.4rem 1rem;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.ct-creator-btn-cancel:hover{background:#ffffff0d;color:var(--text-main)}.ct-sidebar-container{display:flex;flex-direction:column;gap:1.25rem;width:100%}.ct-sidebar-group-panel{position:relative;border-radius:12px;border:1.5px solid var(--border-color);padding:1.25rem 1.5rem;background:var(--bg-card);display:flex;flex-direction:column;gap:.85rem;box-shadow:var(--shadow-card);animation:ct-panel-slide-in .25s ease}.ct-group-dropdown-row{display:flex;gap:.5rem;align-items:center;width:100%}.ct-group-dropdown{flex:1;background:#0003;border:1px solid var(--border-color);border-radius:6px;padding:.5rem .75rem;color:var(--text-main);font-size:.85rem;cursor:pointer;outline:none;transition:all .2s;min-width:0}.ct-group-dropdown:focus{border-color:var(--accent)}.ct-group-dropdown optgroup{background:var(--bg-card);color:var(--text-muted);font-weight:700;font-size:.75rem}.ct-group-dropdown option{background:var(--bg-card);color:var(--text-main);font-size:.85rem}.ct-group-control-btns{display:flex;gap:.4rem;flex-shrink:0}.ct-dropdown-action-btn{background:#ffffff08;border:1px solid var(--border-color);border-radius:6px;padding:.45rem .6rem;font-size:.75rem;color:var(--text-main);cursor:pointer;transition:all .2s;font-weight:600;white-space:nowrap}.ct-dropdown-action-btn:hover{background:#ffffff14;border-color:var(--text-muted)}.ct-dropdown-action-btn.is-active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 1px 6px #6366f140}.ct-btn-delete:hover{background:#ef444426;border-color:#ef444466;color:#ef4444}.ct-sidebar-group-panel .ct-custom-creator-panel{margin-top:.25rem;padding:1rem}.ct-sidebar-group-panel .ct-creator-aa-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr))}
