@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.header{z-index:100;background:var(--header-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);height:64px;position:sticky;top:0}.header-container{justify-content:space-between;align-items:center;max-width:1200px;height:100%;margin:0 auto;padding:0 1.5rem;display:flex}.logo{color:var(--text-primary);align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;display:flex}.logo:hover,.logo-icon{color:var(--accent-primary)}.nav{align-items:center;gap:.5rem;display:flex}.nav-link{color:var(--text-secondary);border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-weight:500;transition:all .2s;display:flex}.nav-link:hover{color:var(--text-primary);background:var(--border-color)}.nav-link.active{color:var(--accent-primary);background:#4f46e51a}.header-actions{align-items:center;gap:.75rem;display:flex}.social-link{width:40px;height:40px;color:var(--text-secondary);border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.social-link:hover{color:var(--text-primary);background:var(--border-color)}.theme-toggle{background:var(--bg-secondary);width:40px;height:40px;color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.theme-toggle:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.mobile-menu-btn{width:40px;height:40px;color:var(--text-primary);background:0 0;border-radius:8px;justify-content:center;align-items:center;display:none}@media (width<=768px){.mobile-menu-btn{display:flex}.nav{background:var(--bg-primary);z-index:99;flex-direction:column;gap:.5rem;padding:1rem;transition:transform .3s;position:fixed;inset:64px 0 0;transform:translate(-100%)}.nav-open{transform:translate(0)}.nav-link{justify-content:flex-start;width:100%;padding:1rem}.header-actions{display:none}.header-actions-open{background:var(--bg-secondary);border-top:1px solid var(--border-color);z-index:99;justify-content:center;gap:1rem;padding:1rem;display:flex;position:fixed;bottom:0;left:0;right:0}}@media (width<=640px){.nav-link span{display:none}.nav-link{padding:.5rem}.header-actions{gap:.5rem}}.footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);margin-top:auto;padding:1.5rem}.footer-container{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;display:flex}.copyright{color:var(--text-secondary);font-size:.875rem}.footer-social{align-items:center;gap:1rem;display:flex}.footer-social a{color:var(--text-secondary);transition:color .2s}.footer-social a:hover{color:var(--accent-primary)}@media (width<=640px){.footer-container{text-align:center;flex-direction:column;gap:1rem}}.tool-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;padding:1.5rem;text-decoration:none;transition:all .3s;display:flex}@media (width<=640px){.tool-card{padding:1.25rem}.tool-card-icon{width:48px;height:48px}.tool-card-title{font-size:1.125rem}}.tool-card:hover{box-shadow:var(--shadow-lg);border-color:var(--accent-primary);transform:translateY(-4px)}.tool-card-icon{width:56px;height:56px;color:var(--accent-primary);background:#4f46e51a;border-radius:12px;justify-content:center;align-items:center;margin-bottom:1rem;display:flex}.tool-card-title{color:var(--text-primary);margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.tool-card-description{color:var(--text-secondary);flex:1;margin-bottom:.75rem;font-size:.875rem;line-height:1.5}.tool-card-tags{flex-wrap:wrap;gap:.375rem;margin-bottom:1rem;display:flex}.tool-card-tag{color:var(--accent-primary);background:#4f46e51a;border-radius:9999px;padding:.125rem .5rem;font-size:.6875rem;font-weight:500;display:inline-block}.tool-card-footer{justify-content:space-between;align-items:center;display:flex}.tool-card-badge{background:var(--accent-primary);color:#fff;border-radius:9999px;padding:.25rem .75rem;font-size:.75rem;font-weight:500;display:inline-block}.tool-card-arrow{color:var(--accent-primary);transition:transform .2s}.tool-card:hover .tool-card-arrow{transform:translate(4px)}.tool-card-favorite{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.25rem;transition:all .2s;display:flex;position:absolute;top:1rem;right:1rem}.tool-card-favorite:hover{color:var(--accent-primary);background:#4f46e51a}.tool-card-favorite.active{color:#ef4444}.tool-card-favorite.active:hover{background:#ef44441a}.tool-card{touch-action:none;-webkit-user-select:none;user-select:none;position:relative}.tool-card-drag-handle{color:var(--text-secondary);cursor:grab;opacity:0;border-radius:4px;justify-content:center;align-items:center;padding:.25rem;transition:opacity .2s,transform .2s;display:flex;position:absolute;top:1rem;left:.5rem}.tool-card:hover .tool-card-drag-handle,.tool-card.drag-handle-active .tool-card-drag-handle{opacity:.7}.tool-card.drag-handle-active .tool-card-drag-handle{transform:scale(1.1)}.tool-card-drag-handle:hover{color:var(--accent-primary);background:#4f46e526;opacity:1!important}.tool-card-drag-handle:active{cursor:grabbing}.tool-card.dragging{opacity:.4;border:2px dashed var(--accent-primary);z-index:1000;transform:scale(.95)rotate(1deg);box-shadow:0 20px 40px #4f46e540}.tool-card.drag-over{border-color:var(--accent-primary);background:#4f46e50d;transform:scale(1.02)}.tool-card.drag-over:before{content:"";background:var(--accent-primary);border-radius:2px;width:60px;height:4px;animation:.6s ease-in-out infinite drop-indicator;position:absolute;top:-2px;left:50%;transform:translate(-50%)}@keyframes drop-indicator{0%,to{opacity:.6;transform:translate(-50%)scaleX(.8)}50%{opacity:1;transform:translate(-50%)scaleX(1)}}.tool-card.reorder-animate{animation:.3s ease-out reorder-pop}@keyframes reorder-pop{0%{opacity:.7;transform:scale(.95)}50%{transform:scale(1.02)}to{opacity:1;transform:scale(1)}}.tools-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;padding:1rem 0;display:grid}.tools-grid:before{content:"";grid-column:1/-1;height:0;display:block}@media (width<=640px){.tools-grid{grid-template-columns:1fr;gap:1rem}}.landing{min-height:calc(100vh - 64px)}.hero{text-align:center;justify-content:center;align-items:center;min-height:70vh;padding:4rem 1.5rem;display:flex;position:relative;overflow:hidden}.hero-bg{position:absolute;inset:0;overflow:hidden}.hero-shape{opacity:.1;border-radius:50%;animation:20s ease-in-out infinite float;position:absolute}.shape-1{background:var(--accent-primary);width:400px;height:400px;animation-delay:0s;top:-100px;left:-100px}.shape-2{background:var(--success);width:300px;height:300px;animation-delay:-5s;bottom:-50px;right:-50px}.shape-3{background:var(--warning);width:200px;height:200px;animation-delay:-10s;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes float{0%,to{transform:translate(0)rotate(0)}25%{transform:translate(20px,-20px)rotate(5deg)}50%{transform:translate(-10px,20px)rotate(-5deg)}75%{transform:translate(-20px,-10px)rotate(3deg)}}.hero-content{z-index:1;max-width:700px;position:relative}.hero-title{margin-bottom:1.5rem;font-size:3.5rem;font-weight:700;line-height:1.1}.hero-gradient{background:linear-gradient(135deg, var(--accent-primary), var(--success));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:var(--text-secondary);margin-bottom:2rem;font-size:1.25rem;line-height:1.6}.hero-cta{padding:1rem 2rem;font-size:1.125rem}.hero-cta svg{transition:transform .2s}.hero-cta:hover svg{transform:translate(4px)}.featured{background:var(--bg-secondary);padding:4rem 0}.section-title{text-align:center;margin-bottom:3rem;font-size:2rem}.section-header .section-title{margin-bottom:0}.favorites-toggle{background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;transition:all .2s;display:flex}.favorites-toggle:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.favorites-toggle.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.featured-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;padding:1rem 0;display:grid}@media (width<=1024px){.featured-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.featured-grid{grid-template-columns:1fr;gap:1rem}}.features{padding:4rem 0}.features-grid{grid-template-columns:repeat(3,1fr);gap:2rem;display:grid}.feature-card{text-align:center;padding:2rem}.feature-icon{width:64px;height:64px;color:var(--accent-primary);background:#4f46e51a;border-radius:16px;justify-content:center;align-items:center;margin:0 auto 1rem;display:flex}.feature-title{margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.feature-description{color:var(--text-secondary);font-size:.875rem}@media (width<=1024px){.featured-grid,.features-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.hero{min-height:60vh;padding:2rem 1rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.hero-cta{padding:.875rem 1.5rem;font-size:1rem}.featured,.features{padding:2rem 0}.section-title{margin-bottom:2rem;font-size:1.5rem}.featured-grid,.features-grid{grid-template-columns:1fr;gap:1rem}.feature-card{padding:1.5rem}}.landing-footer{opacity:.4;justify-content:center;padding:1.5rem;display:flex}.commit-tag{color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;padding:.25rem .5rem;font-family:monospace;font-size:.75rem}.gallery-page{min-height:calc(100vh - 64px);padding:2rem 0}.tools-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;display:grid}.page-filters{margin-bottom:1.5rem}.filter-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;transition:all .2s;display:inline-flex}.filter-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.filter-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.tag-filters{flex-wrap:wrap;gap:.5rem;display:flex}.tag-pill{padding:.375rem .75rem;font-size:.8125rem}.tag-pill.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.clear-tags{color:var(--text-secondary);background:0 0}.clear-tags:hover{color:#ef4444;border-color:#ef4444}.no-favorites{text-align:center;color:var(--text-secondary);padding:3rem 1rem}.about-page{min-height:calc(100vh - 64px);padding:2rem 0}.about-page .container{max-width:800px}.about-card{background:var(--bg-secondary);border:1px solid var(--border-color);text-align:center;border-radius:16px;margin-bottom:2rem;padding:3rem}.about-avatar{width:100px;height:100px;color:var(--accent-primary);background:#4f46e51a;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1.5rem;display:flex}.about-title{margin-bottom:1rem;font-size:2rem}.about-bio{color:var(--text-secondary);max-width:600px;margin:0 auto 2rem;font-size:1.1rem;line-height:1.8}.about-section-title{color:var(--text-secondary);margin-bottom:1rem;font-size:1rem;font-weight:600}.social-links{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.social-link-btn{background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:500;transition:all .2s;display:inline-flex}.social-link-btn:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.skills-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:2rem}.skills-title{text-align:center;margin-bottom:1.5rem;font-size:1.25rem}.skills-grid{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.skill-tag{color:var(--accent-primary);background:#4f46e51a;border-radius:8px;padding:.5rem 1rem;font-size:.875rem;font-weight:500}@media (width<=640px){.about-card{padding:2rem 1.5rem}.about-bio{font-size:1rem}.social-links{flex-direction:column}.social-link-btn{justify-content:center;width:100%}}.settings-page{min-height:calc(100vh - 64px);padding:2rem 0}.settings-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.settings-section-title{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.125rem;font-weight:600;display:flex}.settings-description{color:var(--text-secondary);margin-bottom:1rem;font-size:.95rem}.storage-table-container{margin-bottom:1.5rem;overflow-x:auto}.storage-table{border-collapse:collapse;width:100%;font-size:.95rem}.storage-table th,.storage-table td{text-align:left;border-bottom:1px solid var(--border-color);padding:.75rem 1rem}.storage-table th{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.storage-table td{color:var(--text-primary)}.storage-table td:first-child,.storage-table th:first-child{padding-left:0}.storage-table .checkbox-col{width:40px}.storage-table input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent-primary);cursor:pointer}.storage-table .total-row td{color:var(--text-primary);border-top:2px solid var(--border-color);border-bottom:none;font-weight:600}.storage-actions{flex-wrap:wrap;gap:1rem;display:flex}.theme-selector{gap:.75rem;display:flex}.theme-option{border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:500;transition:all .2s;display:flex}.theme-option:hover{border-color:var(--accent-primary)}.theme-option.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.preference-item{justify-content:space-between;align-items:center;gap:1rem;display:flex}.preference-info{flex-direction:column;gap:.25rem;display:flex}.preference-label{color:var(--text-primary);font-weight:500}.preference-description{color:var(--text-secondary);font-size:.875rem}.toggle{width:48px;height:26px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background:var(--border-color);border-radius:26px;transition:all .3s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:all .3s;position:absolute;bottom:3px;left:3px}.toggle input:checked+.toggle-slider{background:var(--accent-primary)}.toggle input:checked+.toggle-slider:before{transform:translate(22px)}@media (width<=640px){.storage-table-container{margin:0 -1.5rem 1.5rem}.storage-table{font-size:.875rem}.storage-table th,.storage-table td{padding:.5rem .75rem}.storage-actions{flex-direction:column}.storage-actions .btn{width:100%}.theme-selector{flex-direction:column}.theme-option{justify-content:center;width:100%}}.import-status{border-radius:8px;margin-top:1rem;padding:.75rem 1rem;font-size:.875rem}.import-status.success{color:#22c55e;background:#22c55e1a;border:1px solid #22c55e33}.import-status.error{color:#ef4444;background:#ef44441a;border:1px solid #ef444433}.oss-page{min-height:calc(100vh - 64px);padding:2rem 1rem}.oss-page .page-header{margin-bottom:2rem}.oss-page .page-title{align-items:center;gap:.75rem;display:flex}.oss-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.search-wrapper{flex:1;max-width:400px;position:relative}.search-icon{color:var(--text-secondary);position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.search-input{border:1px solid var(--border-color);background:var(--bg-secondary);width:100%;color:var(--text-primary);border-radius:8px;padding:.75rem 1rem .75rem 2.75rem;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.search-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-alpha);outline:none}.library-count{color:var(--text-secondary);font-size:.9rem}.table-wrapper{border:1px solid var(--border-color);background:var(--bg-secondary);border-radius:12px;overflow-x:auto}.libraries-table{border-collapse:collapse;width:100%;font-size:.95rem}.libraries-table th{background:var(--bg-tertiary);text-align:left;color:var(--text-primary);border-bottom:2px solid var(--border-color);white-space:nowrap;padding:1rem;font-weight:600}.libraries-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s}.libraries-table th.sortable:hover{background:var(--bg-hover)}.sort-icon{vertical-align:middle;color:var(--primary-color);margin-left:.5rem;display:inline-block}.sort-icon.inactive{color:var(--text-secondary);opacity:.5}.libraries-table td{border-bottom:1px solid var(--border-color);vertical-align:top;padding:1rem}.libraries-table tbody tr{transition:background .15s}.libraries-table tbody tr:hover{background:var(--bg-hover)}.libraries-table tbody tr:last-child td{border-bottom:none}.lib-name code{background:var(--primary-color-alpha);color:var(--primary-color);border-radius:4px;padding:.25rem .5rem;font-weight:500}.version-badge{background:var(--bg-tertiary);color:var(--text-secondary);border-radius:12px;padding:.25rem .6rem;font-family:monospace;font-size:.85rem;display:inline-block}.lib-description{max-width:280px;color:var(--text-secondary);line-height:1.5}.lib-usage{max-width:300px;color:var(--text-secondary);line-height:1.5}.no-results{text-align:center;color:var(--text-secondary);padding:3rem}@media (width<=900px){.libraries-table th:nth-child(3),.libraries-table td:nth-child(3),.libraries-table th:nth-child(4),.libraries-table td:nth-child(4){display:none}}@media (width<=600px){.oss-controls{flex-direction:column;align-items:stretch}.search-wrapper{max-width:100%}.library-count{text-align:center}}.calculator-page{min-height:calc(100vh - 64px);padding:2rem 0}.calculator-header{margin-bottom:2rem}.calculator{background:var(--bg-secondary);border:1px solid var(--border-color);max-width:360px;box-shadow:var(--shadow-lg);border-radius:16px;margin:0 auto;overflow:hidden}.calculator-display{background:var(--bg-primary);text-align:right;border-bottom:1px solid var(--border-color);padding:1.5rem}.calculator-history{color:var(--text-secondary);min-height:1.25rem;margin-bottom:.25rem;font-size:.875rem}.calculator-result{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:2.5rem;font-weight:600;overflow:hidden}.calculator-buttons{background:var(--border-color);grid-template-columns:repeat(4,1fr);gap:1px;display:grid}.calc-btn{background:var(--bg-secondary);color:var(--text-primary);border:none;padding:1.25rem;font-size:1.25rem;font-weight:500;transition:all .15s}.calc-btn:hover{background:var(--border-color)}.calc-btn:active{transform:scale(.95)}.calc-btn.number{background:var(--bg-secondary)}.calc-btn.operator{color:var(--accent-primary);background:#4f46e51a}.calc-btn.operator:hover{background:#4f46e533}.calc-btn.function{background:var(--bg-primary);color:var(--text-secondary);font-size:1rem}.calc-btn.equals{background:var(--accent-primary);color:#fff}.calc-btn.equals:hover{background:var(--accent-hover)}.calculator-help{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;max-width:360px;margin:2rem auto 0;padding:1.25rem}.calculator-help h3{color:var(--text-primary);margin-bottom:1rem;font-size:1rem}.help-grid{grid-template-columns:auto 1fr;gap:.5rem 1rem;font-size:.875rem;display:grid}.help-grid span:first-child{color:var(--text-secondary)}.help-grid span:last-child{color:var(--accent-primary);font-family:monospace}.notepad-page{min-height:calc(100vh - 64px);padding:2rem 0}.notepad-header{margin-bottom:2rem}.notepad-layout{grid-template-columns:300px 1fr;gap:1.5rem;height:calc(100vh - 220px);min-height:500px;display:grid}.notes-sidebar{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:.75rem;padding:1rem;display:flex}.search-box{background:var(--bg-primary);border:1px solid var(--border-color);min-width:150px;color:var(--text-secondary);border-radius:8px;flex:1;align-items:center;gap:.5rem;padding:.5rem .75rem;display:flex}.search-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-size:.875rem}.search-input::placeholder{color:var(--text-secondary)}.new-note-btn{flex-shrink:0;padding:.5rem 1rem;font-size:.875rem}.notes-list{flex:1;overflow-y:auto}.note-item{border-bottom:1px solid var(--border-color);cursor:pointer;padding:1rem;transition:background .2s}.note-item:hover{background:var(--bg-primary)}.note-item.active{border-left:3px solid var(--accent-primary);background:#4f46e51a}.note-item-title{white-space:nowrap;text-overflow:ellipsis;margin-bottom:.25rem;font-size:.875rem;font-weight:600;overflow:hidden}.note-item-preview{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:.25rem;font-size:.75rem;overflow:hidden}.note-item-date{color:var(--text-secondary);font-size:.7rem}.empty-notes{text-align:center;color:var(--text-secondary);padding:2rem 1rem;font-size:.875rem}.note-editor{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;display:flex;overflow:hidden}.editor-toolbar{border-bottom:1px solid var(--border-color);align-items:center;gap:1rem;padding:1rem;display:flex}.title-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;padding:.5rem 0;font-size:1.25rem;font-weight:600}.title-input::placeholder{color:var(--text-secondary)}.editor-actions{gap:.5rem;display:flex}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.content-textarea{color:var(--text-primary);resize:none;background:0 0;border:none;outline:none;flex:1;padding:1rem;font-size:1rem;line-height:1.8}.content-textarea::placeholder{color:var(--text-secondary)}.editor-footer{border-top:1px solid var(--border-color);color:var(--text-secondary);gap:1.5rem;padding:.75rem 1rem;font-size:.75rem;display:flex}.no-note-selected{color:var(--text-secondary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1rem;display:flex}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border-radius:12px;width:100%;max-width:400px;padding:1.5rem}.modal h3{margin-bottom:.75rem;font-size:1.25rem}.modal p{color:var(--text-secondary);margin-bottom:1.5rem}.modal-actions{justify-content:flex-end;gap:.75rem;display:flex}@media (width<=768px){.notepad-layout{grid-template-columns:1fr;height:auto}.notes-sidebar{max-height:300px}.note-editor{min-height:400px}}.converter-page{min-height:calc(100vh - 64px);padding:2rem 0}.converter-header{margin-bottom:2rem}.converter-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;max-width:800px;margin:0 auto;padding:2rem}.category-selector{margin-bottom:2rem}.category-tabs{flex-wrap:wrap;gap:.5rem;margin-top:.75rem;display:flex}.category-tab{background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:8px;align-items:center;gap:.375rem;padding:.5rem .75rem;font-size:.8125rem;font-weight:500;transition:all .2s;display:flex}.category-tab:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.category-tab.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.conversion-area{grid-template-columns:1fr auto 1fr;align-items:end;gap:1rem;margin-bottom:2rem;display:grid}.conversion-input-group{flex-direction:column;gap:.5rem;display:flex}.conversion-input{text-align:right;font-size:1.25rem}.result-input{color:var(--accent-primary);background:#4f46e50d;font-weight:600}.unit-select{padding:.75rem}.swap-btn{background:var(--accent-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:.5rem;transition:all .2s;display:flex}.swap-btn:hover{background:var(--accent-hover);transform:rotate(180deg)}.visualization-section{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;margin-bottom:2rem;padding:1.5rem}.viz-header{color:var(--accent-primary);align-items:center;gap:.5rem;margin-bottom:1.25rem;font-size:.9375rem;font-weight:600;display:flex}.viz-container{justify-content:center;align-items:center;height:220px;margin-bottom:1.25rem;display:flex}.viz-slider-container{padding:0 .5rem}.viz-slider{background:linear-gradient(to right, var(--accent-primary), #8b5cf6, #ec4899);-webkit-appearance:none;cursor:pointer;border-radius:4px;outline:none;width:100%;height:8px}.viz-slider::-webkit-slider-thumb{-webkit-appearance:none;border:3px solid var(--accent-primary);cursor:pointer;background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .2s;box-shadow:0 2px 8px #0003}.viz-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}.viz-labels{color:var(--text-secondary);justify-content:space-between;margin-top:.75rem;font-size:.75rem;display:flex}.viz-current{color:var(--accent-primary);align-items:center;gap:.25rem;font-weight:600;display:flex}.guidance-panel{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:1.5rem;padding:1.25rem}.guidance-header{color:var(--accent-primary);align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.875rem;font-weight:600;display:flex}.guidance-text{color:var(--text-secondary);font-size:.875rem;line-height:1.6}.quick-conversions h3{color:var(--text-primary);margin-bottom:1rem;font-size:1rem}.quick-grid{grid-template-columns:repeat(2,1fr);gap:.5rem 2rem;display:grid}.quick-grid span{color:var(--text-secondary);font-size:.875rem}@media (width<=640px){.conversion-area{grid-template-columns:1fr;gap:1rem}.swap-btn{margin:0 auto;transform:rotate(90deg)}.swap-btn:hover{transform:rotate(270deg)}.quick-grid{grid-template-columns:1fr}.category-tabs{gap:.375rem}.category-tab{padding:.375rem .625rem;font-size:.75rem}}.length-viz{width:100%;padding:1rem}.ruler-container{position:relative}.ruler{align-items:flex-end;height:60px;display:flex;position:relative}.ruler-line{will-change:width;background:linear-gradient(90deg,#f97316,#eab308);border-radius:0 4px 4px 0;min-width:20px;height:20px;transition:width .15s ease-out;position:relative}.ruler-marks{height:30px;position:absolute;top:-30px;left:0;right:0}.ruler-mark{flex-direction:column;align-items:center;display:flex;position:absolute}.ruler-mark:before{content:"";background:var(--text-secondary);width:2px;height:12px}.ruler-number{color:var(--text-secondary);margin-top:2px;font-size:.625rem}.ruler-end{position:absolute;bottom:25px;transform:translate(-50%)}.ruler-value{color:var(--accent-primary);white-space:nowrap;font-size:.875rem;font-weight:600}.length-label{text-align:center;color:var(--text-secondary);margin-top:1rem;font-size:.875rem}.weight-viz{width:100%;padding:1rem}.scale{width:200px;height:120px;margin:0 auto;position:relative}.scale-beam{transform-origin:0;background:linear-gradient(90deg,#6b7280,#9ca3af);border-radius:2px;width:180px;height:4px;transition:transform .5s;position:absolute;top:30px;left:10px}.scale-pivot{z-index:2;background:#374151;border-radius:50%;width:16px;height:16px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.scale-plates{justify-content:space-between;display:flex;position:absolute;top:-40px;left:0;right:0}.weight-plate{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.5rem;font-weight:600;animation:.6s ease-out backwards plateBounce;display:flex}@keyframes plateBounce{0%{transform:scale(0)}60%{transform:scale(1.1)}to{transform:scale(1)}}.scale-base{background:linear-gradient(90deg,#4b5563,#6b7280);border-radius:2px;width:8px;height:50px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.scale-base:before{content:"";background:#374151;border-radius:4px 4px 0 0;width:60px;height:8px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.weight-label{text-align:center;color:var(--text-secondary);margin-top:1rem;font-size:.875rem}.temp-viz{width:100%;padding:1rem}.thermometer{width:80px;height:180px;margin:0 auto;position:relative}.thermo-tube{background:#fff3;border:2px solid #d1d5db;border-radius:20px 20px 0 0;width:20px;height:130px;position:absolute;bottom:30px;left:50%;overflow:hidden;transform:translate(-50%)}.thermo-liquid{border-radius:0 0 16px 16px;transition:height .3s,background .3s;position:absolute;bottom:0;left:0;right:0}.thermo-bubbles{height:100%;position:absolute;top:0;left:0;right:0}.bubble{background:#fff9;border-radius:50%;width:4px;height:4px;animation:2s infinite bubbleRise;position:absolute;bottom:0}@keyframes bubbleRise{0%{opacity:0;transform:translateY(0)}50%{opacity:1}to{opacity:0;transform:translateY(-100px)}}.thermo-bulb{border-radius:50%;width:30px;height:30px;transition:background-color .3s;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.thermo-scale{height:130px;position:absolute;bottom:30px;right:-35px}.thermo-mark{align-items:center;width:25px;display:flex;position:absolute;right:0}.thermo-mark:before{content:"";background:var(--text-secondary);width:8px;height:1px}.thermo-mark span{color:var(--text-secondary);margin-left:4px;font-size:.5625rem}.thermo-indicator{transition:bottom .3s;position:absolute;left:50%;transform:translate(-50%)}.thermo-indicator span{color:#fff;white-space:nowrap;border-radius:4px;padding:.125rem .375rem;font-size:.6875rem;font-weight:600}.temp-label{text-align:center;color:var(--text-secondary);margin-top:.75rem;font-size:.875rem;font-weight:600}.volume-viz{width:100%;padding:1rem}.cube-container{perspective:500px;justify-content:center;align-items:center;height:160px;display:flex}.cube{width:var(--size);height:var(--size);transform-style:preserve-3d;animation:8s linear infinite cubeRotate;position:relative}@keyframes cubeRotate{0%{transform:rotateX(-20deg)rotateY(0)}to{transform:rotateX(-20deg)rotateY(360deg)}}.cube-face{background:linear-gradient(135deg,#8b5cf64d,#8b5cf61a);border:2px solid #8b5cf6;justify-content:center;align-items:flex-end;display:flex;position:absolute;overflow:hidden}.cube-front{width:var(--size);height:var(--size);transform:translateZ(calc(var(--size) / 2))}.cube-back{width:var(--size);height:var(--size);transform:translateZ(calc(var(--size) / -2)) rotateY(180deg)}.cube-right{width:var(--size);height:var(--size);transform:translateX(calc(var(--size) / 2)) rotateY(90deg)}.cube-left{width:var(--size);height:var(--size);transform:translateX(calc(var(--size) / -2)) rotateY(-90deg)}.cube-top{width:var(--size);height:var(--size);transform:translateY(calc(var(--size) / -2)) rotateX(90deg)}.cube-bottom{width:var(--size);height:var(--size);transform:translateY(calc(var(--size) / 2)) rotateX(-90deg)}.liquid{opacity:.7;background:linear-gradient(#06b6d4,#3b82f6);width:100%;transition:height .5s}.volume-label{text-align:center;color:var(--text-secondary);margin-top:.5rem;font-size:.875rem}.area-viz{width:100%;padding:1rem}.paper-container{justify-content:center;align-items:center;height:160px;display:flex}.paper{will-change:width, height;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #d97706;border-radius:4px;justify-content:center;align-items:center;transition:all .3s,width .2s ease-out,height .2s ease-out;animation:3s ease-in-out infinite paperShadows;display:flex;position:relative;box-shadow:4px 4px 12px #00000026}@keyframes paperShadows{0%,to{box-shadow:4px 4px 12px #00000026}50%{box-shadow:6px 6px 16px #0003}}.paper-grid{opacity:.3;position:absolute;inset:0}.grid-line-h,.grid-line-v{background:#92400e;position:absolute}.grid-line-h{height:1px;left:0;right:0}.grid-line-v{width:1px;top:0;bottom:0}.paper-label{color:#92400e;text-align:center;z-index:1;padding:.25rem;font-size:.75rem;font-weight:600}.area-info{text-align:center;color:var(--text-secondary);margin-top:.75rem;font-size:.75rem}.time-viz{width:100%;padding:1rem}.clock{background:radial-gradient(circle,#fef3c7,#fde68a);border:4px solid #d97706;border-radius:50%;width:140px;height:140px;margin:0 auto;position:relative;box-shadow:inset 0 0 20px #0000001a,0 4px 12px #00000026}.clock-face{width:100%;height:100%;position:relative}.clock-center{z-index:10;background:#92400e;border-radius:50%;width:12px;height:12px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.clock-hand{transform-origin:bottom;background:#374151;border-radius:4px;position:absolute;bottom:50%;left:50%}.hour-hand{width:4px;height:35px;margin-left:-2px}.minute-hand{width:3px;height:45px;margin-left:-1.5px}.second-hand{background:#ef4444;width:1px;height:50px;margin-left:-.5px}.second-glow{background:#ef4444;border-radius:50%;width:3px;height:3px;position:absolute;top:0;left:50%;transform:translate(-50%);box-shadow:0 0 8px #ef4444}.clock-number{color:#374151;font-size:.625rem;font-weight:600;position:absolute;top:50%;left:50%}.time-digital{text-align:center;color:var(--accent-primary);background:var(--bg-secondary);border-radius:4px;margin-top:.75rem;padding:.25rem .75rem;font-family:monospace;font-size:1.25rem;font-weight:600;display:inline-block}.time-label{text-align:center;color:var(--text-secondary);margin-top:.5rem;font-size:.75rem}.speed-viz{width:100%;padding:1rem}.road{background:linear-gradient(#374151 0%,#4b5563 50%,#6b7280 100%);border-radius:8px;width:100%;height:80px;position:relative;overflow:hidden}.road-lines{will-change:animation-duration;height:4px;animation-duration:.5s;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.road-line{background:#fbbf24;width:40px;height:4px;animation:.5s linear infinite roadMove;position:absolute;left:-50px}@keyframes roadMove{0%{left:-50px}to{left:100%}}.runner{transition:left .3s;position:absolute;top:50%;transform:translate(-50%,-50%)}.runner-body{animation:.3s ease-in-out infinite alternate runBounce;position:relative}@keyframes runBounce{0%{transform:translateY(0)}to{transform:translateY(-3px)}}.runner-head{background:#f97316;border-radius:50%;width:12px;height:12px;margin:0 auto}.runner-torso{background:#ea580c;border-radius:4px;width:8px;height:20px;margin:2px auto 0}.runner-legs{width:20px;height:15px;position:absolute;bottom:-12px;left:50%;transform:translate(-50%)}.leg{background:#c2410c;border-radius:2px;width:4px;height:15px;animation:.3s ease-in-out infinite alternate legSwing;position:absolute}.leg-left{animation-delay:0s;left:0}.leg-right{animation-delay:.15s;right:0}@keyframes legSwing{0%{transform:rotate(-20deg)}to{transform:rotate(20deg)}}.speed-badge{color:#fff;white-space:nowrap;background:#f97316;border-radius:4px;margin-top:.5rem;padding:.125rem .375rem;font-size:.5625rem;font-weight:600;display:block}.speed-label{text-align:center;color:var(--text-secondary);margin-top:1rem;font-size:.875rem;font-weight:600}.data-viz{width:100%;padding:1rem}.data-blocks{grid-template-columns:repeat(var(--cols,8), 1fr);gap:4px;max-width:180px;margin:0 auto;display:grid}.data-block{aspect-ratio:1;border-radius:4px;justify-content:center;align-items:center;animation:.3s ease-out backwards blockAppear;display:flex;box-shadow:inset 0 1px #ffffff4d,0 2px 4px #0003}@keyframes blockAppear{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.block-bit{color:#fff;text-shadow:0 1px 2px #0000004d;font-size:.5rem;font-weight:700}.data-label{text-align:center;color:var(--text-secondary);margin-top:1rem;font-family:monospace;font-size:.75rem}.comparison-section{background:var(--bg-secondary);border-radius:12px;margin-top:1.5rem;padding:1.5rem}.comparison-section .viz-header{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:1rem;font-weight:500;display:flex}.comparison-chart{background:var(--bg-primary);border-radius:8px;padding:1rem}.comparison-info{text-align:center;color:var(--text-secondary);margin-top:1rem;font-size:.8rem}.comparison-info strong{color:var(--accent-primary)}.resume-page{min-height:calc(100vh - 64px);padding:2rem 0}.resume-header{margin-bottom:2rem}.resume-layout{grid-template-columns:200px 1fr 300px;align-items:start;gap:1.5rem;display:grid}.resume-sidebar{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1rem;position:sticky;top:80px}.section-nav{flex-direction:column;gap:.25rem;margin-bottom:1.5rem;display:flex}.nav-item{color:var(--text-secondary);text-align:left;background:0 0;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1rem;font-weight:500;transition:all .2s;display:flex}.nav-item:hover{background:var(--bg-primary);color:var(--text-primary)}.nav-item.active{color:var(--accent-primary);background:#4f46e51a}.sidebar-actions{flex-direction:column;gap:.5rem;display:flex}.sidebar-actions .btn{width:100%;font-size:.875rem}.resume-form{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem}.form-section h2{margin-bottom:1.5rem;font-size:1.25rem}.section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.section-header h2{margin-bottom:0}.form-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.form-group.full-width{grid-column:span 2}.repeatable-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:1rem;padding:1rem}.item-header{justify-content:space-between;align-items:center;margin-bottom:1rem;font-weight:600;display:flex}.delete-btn{width:32px;height:32px;color:var(--text-secondary);background:0 0;border-radius:6px;justify-content:center;align-items:center;transition:all .2s;display:flex}.delete-btn:hover{background:var(--error);color:#fff}.empty-message{color:var(--text-secondary);text-align:center;padding:2rem}.help-text{color:var(--text-secondary);margin-top:.5rem;font-size:.75rem}.resume-preview{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;max-height:calc(100vh - 120px);padding:1rem;position:sticky;top:80px;overflow-y:auto}.resume-preview h3{margin-bottom:1rem;font-size:1rem}.preview-content{color:#1a1a2e;background:#fff;border-radius:8px;padding:1rem;font-size:.75rem}.preview-name{margin-bottom:.25rem;font-size:1rem;font-weight:700}.preview-contact{color:#666;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;font-size:.65rem;display:flex}.preview-contact span:not(:last-child):after{content:"|";margin-left:.5rem}.preview-section{margin-bottom:.75rem}.preview-section h4{text-transform:uppercase;color:#4f46e5;border-bottom:1px solid #e2e8f0;margin-bottom:.25rem;padding-bottom:.125rem;font-size:.7rem;font-weight:700}.preview-section p{line-height:1.4}.preview-item{margin-bottom:.5rem}.preview-item strong{font-weight:600}.preview-item small{color:#666}.preview-skills{line-height:1.4}@media (width<=1024px){.resume-layout{grid-template-columns:1fr}.resume-sidebar{flex-direction:column;display:flex;position:static}.section-nav{flex-flow:wrap}.nav-item{flex:1;justify-content:center;min-width:120px}.nav-item span{display:inline}.sidebar-actions{flex-direction:row}.resume-preview{display:none}}@media (width<=640px){.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:span 1}.section-nav{flex-direction:column}.nav-item{justify-content:flex-start}}.linkedin-btn{justify-content:center;align-items:center;gap:.5rem;display:flex}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;width:90%;max-width:600px;max-height:90vh;animation:.2s slideUp;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header h2{align-items:center;gap:.75rem;margin:0;font-size:1.25rem;display:flex}.modal-close{width:36px;height:36px;color:var(--text-secondary);background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.modal-close:hover{background:var(--bg-primary);color:var(--text-primary)}.modal-body{padding:1.5rem}.modal-description{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.5}.import-mode-toggle{gap:.5rem;margin-bottom:1.5rem;display:flex}.mode-btn{border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);border-radius:8px;flex:1;padding:.75rem 1rem;font-weight:500;transition:all .2s}.mode-btn:hover{border-color:var(--accent-primary);color:var(--text-primary)}.mode-btn.active{border-color:var(--accent-primary);color:var(--accent-primary);background:#4f46e51a}.linkedin-textarea{font-family:monospace;font-size:.75rem}.file-upload-area{border:2px dashed var(--border-color);text-align:center;border-radius:12px;padding:3rem 2rem;transition:all .2s}.file-upload-area:hover{border-color:var(--accent-primary);background:#4f46e50d}.upload-btn{color:var(--text-secondary);background:0 0;border-radius:8px;flex-direction:column;align-items:center;gap:1rem;padding:1rem 2rem;transition:all .2s;display:flex}.upload-btn:hover{color:var(--accent-primary)}.file-selected{color:#22c55e;margin-top:1rem;font-size:.875rem}.import-error{color:var(--error);background:#ef44441a;border-radius:8px;margin-top:1rem;padding:.75rem;font-size:.875rem}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.linkedin-modal .btn:disabled{opacity:.5;cursor:not-allowed}.keygen-page{min-height:calc(100vh - 64px);padding:2rem 0}.keygen-header{margin-bottom:1.5rem}.back-link{color:var(--text-secondary);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.875rem;transition:color .2s;display:inline-flex}.keygen-layout{grid-template-columns:1fr 320px;align-items:start;gap:1.5rem;display:grid}.keygen-main{min-width:0}.keygen-config-output{grid-template-columns:280px 1fr;align-items:start;gap:1.25rem;display:grid}.keygen-options{width:100%}.keygen-output{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;flex-direction:column;min-height:380px;display:flex;overflow:hidden}.output-header{border-bottom:1px solid var(--border-color);background:#00000026;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.output-title{align-items:center;gap:.625rem;display:flex}.output-icon{color:var(--accent-primary)}.output-title h3{font-size:1rem;font-weight:600}.key-type-badge{background:var(--accent-primary);color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:20px;padding:.25rem .5rem;font-size:.6875rem;font-weight:600}.output-actions{gap:.5rem;display:flex}.key-display{flex-direction:column;flex:1;gap:1rem;padding:1rem;display:flex;overflow-y:auto}.key-section{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;transition:border-color .2s;overflow:hidden}.key-section:hover{border-color:#4f46e566}.key-label{border-bottom:1px solid var(--border-color);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;background:#00000040;justify-content:space-between;align-items:center;padding:.625rem 1rem;font-size:.75rem;font-weight:600;display:flex}.btn-icon{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:.25rem;transition:all .2s;display:flex}.btn-icon:hover{color:var(--accent-primary);background:#4f46e51a}.key-content{color:var(--text-primary);white-space:pre-wrap;word-break:break-all;max-height:140px;margin:0;padding:1rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.75rem;line-height:1.6;overflow-y:auto}.key-content.private-key{border-left:3px solid #f59e0b}.security-notice{border-top:1px solid var(--border-color);color:var(--text-secondary);background:#4f46e50a;align-items:center;gap:.5rem;padding:.875rem 1.25rem;font-size:.75rem;display:flex}.security-notice svg{color:var(--accent-primary);flex-shrink:0}.empty-state{color:var(--text-secondary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1rem;padding:3rem;display:flex}.empty-state svg{opacity:.4;color:var(--accent-primary)}.empty-state p{text-align:center;max-width:280px;font-size:.9375rem}.options-card.compact{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:1.25rem}.options-header{color:var(--text-secondary);align-items:center;gap:.625rem;margin-bottom:1.25rem;display:flex}.options-header h3{color:var(--text-primary);font-size:.9375rem;font-weight:600}.options-body{flex-direction:column;gap:1.25rem;display:flex}.option-group{flex-direction:column;gap:.625rem;display:flex}.option-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:600}.key-type-grid{grid-template-columns:repeat(5,1fr);gap:.5rem;display:grid}.key-type-btn{background:var(--bg-primary);border:1px solid var(--border-color);cursor:pointer;color:var(--text-primary);will-change:transform, border-color, background-color;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:.375rem;padding:.75rem .5rem;transition:all .2s;display:flex}.key-type-btn:active:not(.active){transform:scale(.95)}.key-type-btn span{font-size:.6875rem;font-weight:600}.key-type-btn:hover{border-color:var(--accent-primary);background:#4f46e50d}.key-type-btn.active{border-color:var(--accent-primary);color:var(--accent-primary);background:#4f46e51f}.size-options{gap:.5rem;display:flex}.size-btn{background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;border-radius:8px;flex:1;padding:.625rem 1rem;font-size:.8125rem;font-weight:500;transition:all .2s}.size-btn:hover{border-color:var(--accent-primary)}.size-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.generate-btn{will-change:transform;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;margin-top:.25rem;padding:.875rem 1.5rem;font-size:.9375rem;font-weight:600;transition:transform .15s,background-color .2s,box-shadow .2s;display:flex}.generate-btn:active:not(:disabled){transform:scale(.97)}.generate-btn:disabled{opacity:.7;cursor:not-allowed}.generate-btn .spinning{will-change:transform;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.keygen-sidebar{position:sticky;top:2rem}.sidebar-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;flex-direction:column;max-height:520px;padding:1.25rem;display:flex}.sidebar-header{color:var(--text-secondary);align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.sidebar-header h3{color:var(--text-primary);flex:1;font-size:.9375rem;font-weight:600}.key-count{background:var(--bg-primary);color:var(--text-secondary);border-radius:20px;padding:.25rem .5rem;font-size:.6875rem;font-weight:600}.saved-keys-list{flex-direction:column;flex:1;gap:.5rem;min-height:0;display:flex;overflow-y:auto}.saved-key-item{background:var(--bg-primary);border:1px solid var(--border-color);cursor:pointer;border-radius:10px;justify-content:space-between;align-items:center;padding:.75rem;transition:all .2s;display:flex}.saved-key-item:hover{border-color:var(--accent-primary);background:#4f46e50a}.saved-key-info{flex-direction:column;flex:1;gap:.25rem;min-width:0;display:flex}.saved-key-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;font-weight:600;overflow:hidden}.saved-key-date{color:var(--text-secondary);font-size:.6875rem}.key-name-input{color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--accent-primary);border-radius:4px;outline:none;width:100%;min-width:120px;padding:.25rem .5rem;font-size:.8125rem;font-weight:600}.saved-key-actions{gap:.125rem;display:flex}.saved-key-actions .btn-icon{padding:.375rem}.saved-key-actions .btn-delete:hover{color:#ef4444;background:#ef44441a}.no-saved-keys{text-align:center;color:var(--text-secondary);padding:2rem 1rem;font-size:.8125rem}.save-message{color:#22c55e;text-align:center;background:#22c55e1a;border:1px solid #22c55e;border-radius:8px;margin:.75rem 1rem 0;padding:.625rem 1rem;font-size:.8125rem}@media (width<=1024px){.keygen-layout{grid-template-columns:1fr 280px}}@media (width<=900px){.keygen-layout,.keygen-config-output{grid-template-columns:1fr}.keygen-sidebar{order:2;position:static}.keygen-main{order:1}.sidebar-card{max-height:350px}.key-type-grid{grid-template-columns:repeat(5,1fr)}}@media (width<=600px){.keygen-page{padding:1rem 0}.keygen-layout{gap:1rem}.key-type-grid{grid-template-columns:repeat(3,1fr)}.key-type-btn{padding:.625rem .375rem}.key-type-btn span{font-size:.625rem}.options-card.compact{padding:1rem}.output-header{flex-direction:column;align-items:flex-start;gap:.75rem}.output-actions{width:100%}.output-actions .btn{flex:1;justify-content:center}.key-content{max-height:120px;font-size:.6875rem}.sidebar-card{padding:1rem}}.terminal-page{min-height:calc(100vh - 64px);padding:2rem 0}.terminal-header{margin-bottom:2rem}.back-link{color:var(--text-secondary);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.875rem;display:inline-flex}.back-link:hover{color:var(--accent-primary)}.page-title{align-items:center;gap:.75rem;display:flex}.terminal-window{background:#1a1a1a;border-radius:8px 8px 0 0;max-width:900px;margin:0 auto;overflow:hidden;box-shadow:0 8px 32px #0000004d}.terminal-titlebar{background:linear-gradient(#3d3846 0%,#2d2d2d 100%);align-items:center;gap:12px;padding:10px 12px;display:flex}.terminal-buttons{gap:8px;display:flex}.terminal-buttons span{border-radius:50%;width:12px;height:12px;display:inline-block}.btn-close{background:#e95420}.btn-minimize{background:#f99b11}.btn-maximize{background:#5dc419}.terminal-title{color:#999;font-family:Ubuntu Mono,Monaco,monospace;font-size:.8rem}.terminal-body{min-height:500px;max-height:60vh;padding:1rem;font-family:Ubuntu Mono,Monaco,Menlo,monospace;font-size:14px;line-height:1.5;overflow-y:auto}.terminal-welcome{color:#fff;margin-bottom:1rem}.terminal-welcome pre{color:#4dff4d;margin:0;font-family:Ubuntu Mono,Monaco,monospace;font-size:12px}.terminal-line{color:#fff;white-space:pre-wrap;word-break:break-all;margin-bottom:2px}.terminal-line.error{color:#f55}.terminal-line.output{color:#ddd;margin-left:0}.terminal-input-line{color:#fff;display:flex}.prompt{color:#4dff4d;white-space:nowrap;margin-right:8px}.username{color:#5dff5d}.path{color:#5bc8af}.terminal-input{color:#fff;font-family:inherit;font-size:inherit;caret-color:#fff;background:0 0;border:none;outline:none;flex:1}.editor-modal{background:#1e1e1e;flex-direction:column;height:60vh;display:flex}.editor-header{color:#ccc;background:#2d2d2d;justify-content:space-between;align-items:center;padding:10px 12px;font-family:Ubuntu Mono,monospace;font-size:13px;display:flex}.editor-close{color:#999;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:20px;line-height:1}.editor-close:hover{color:#fff}.editor-content{color:#ddd;resize:none;background:#1e1e1e;border:none;outline:none;flex:1;padding:12px;font-family:Ubuntu Mono,Monaco,monospace;font-size:14px;line-height:1.5}.editor-footer{background:#2d2d2d;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.editor-help{color:#888;font-family:Ubuntu Mono,monospace;font-size:12px}.cheatsheet{background:#1e1e1e;flex-direction:column;height:60vh;display:flex}.cheatsheet-header{color:#ddd;background:#2d2d2d;align-items:center;gap:10px;padding:12px 16px;font-family:Ubuntu Mono,monospace;font-size:14px;display:flex}.cheatsheet-header svg{color:var(--accent-primary)}.cheatsheet-close{color:#999;cursor:pointer;background:0 0;border:none;margin-left:auto;padding:0 4px;font-size:20px;line-height:1}.cheatsheet-close:hover{color:#fff}.cheatsheet-content{flex:1;padding:8px 0;overflow-y:auto}.cheatsheet-item{border-bottom:1px solid #333;grid-template-columns:100px 1fr 2fr;gap:12px;padding:8px 16px;font-family:Ubuntu Mono,monospace;font-size:12px;display:grid}.cheatsheet-item:hover{background:#252525}.cheatsheet-cmd{color:#5dff5d;font-weight:600}.cheatsheet-usage{color:#888}.cheatsheet-desc{color:#bbb}@media (width<=768px){.terminal-body{min-height:400px;font-size:13px}.terminal-welcome pre{font-size:10px}.cheatsheet-item{grid-template-columns:80px 1fr;gap:8px}.cheatsheet-usage{display:none}}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;top:0;left:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:0 0}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{-webkit-transform-origin:0 0;width:1600px;height:1600px}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{width:auto;padding:0;max-width:none!important;max-height:none!important}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:#33b5e566}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{box-sizing:border-box;z-index:800;width:0;height:0}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{z-index:800;pointer-events:visiblePainted;pointer-events:auto;position:relative}.leaflet-top,.leaflet-bottom{z-index:1000;pointer-events:none;position:absolute}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{outline-offset:1px;background:#ddd}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{background:#ffffff80;border:2px dotted #38f}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:.75rem;line-height:1.5}.leaflet-bar{border-radius:4px;box-shadow:0 1px 5px #000000a6}.leaflet-bar a{text-align:center;color:#000;background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;text-decoration:none;display:block}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom:none;border-bottom-right-radius:4px;border-bottom-left-radius:4px}.leaflet-bar a.leaflet-disabled{cursor:default;color:#bbb;background-color:#f4f4f4}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-right-radius:2px;border-bottom-left-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{text-indent:1px;font:700 18px Lucida Console,Monaco,monospace}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{background:#fff;border-radius:5px;box-shadow:0 1px 5px #0006}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{color:#333;background:#fff;padding:6px 10px 6px 6px}.leaflet-control-layers-scrollbar{padding-right:5px;overflow:hidden scroll}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{font-size:1.08333em;display:block}.leaflet-control-layers-separator{border-top:1px solid #ddd;height:0;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{color:#333;padding:0 5px;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{width:1em;height:.6669em;vertical-align:baseline!important;display:inline!important}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{white-space:nowrap;box-sizing:border-box;text-shadow:1px 1px #fff;background:#fffc;border:2px solid #777;border-top:none;padding:2px 5px 1px;line-height:1.1}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{background-clip:padding-box;border:2px solid #0003}.leaflet-popup{text-align:center;margin-bottom:20px;position:absolute}.leaflet-popup-content-wrapper{text-align:left;border-radius:12px;padding:1px}.leaflet-popup-content{min-height:1px;margin:13px 24px 13px 20px;font-size:1.08333em;line-height:1.3}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{pointer-events:none;width:40px;height:20px;margin-top:-1px;margin-left:-20px;position:absolute;left:50%;overflow:hidden}.leaflet-popup-tip{pointer-events:auto;width:17px;height:17px;margin:-10px auto 0;padding:1px;transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{color:#333;background:#fff;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{text-align:center;color:#757575;background:0 0;border:none;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;text-decoration:none;position:absolute;top:0;right:0}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";width:24px;filter:progid:DXImageTransform.Microsoft.Matrix(M11=.707107, M12=.707107, M21=-.707107, M22=.707107);margin:0 auto}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{color:#222;white-space:nowrap;-webkit-user-select:none;user-select:none;pointer-events:none;background-color:#fff;border:1px solid #fff;border-radius:3px;padding:6px;position:absolute;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{pointer-events:none;content:"";background:0 0;border:6px solid #0000;position:absolute}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{margin-left:-6px;left:50%}.leaflet-tooltip-top:before{border-top-color:#fff;margin-bottom:-12px;bottom:0}.leaflet-tooltip-bottom:before{border-bottom-color:#fff;margin-top:-12px;margin-left:-6px;top:0}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{margin-top:-6px;top:50%}.leaflet-tooltip-left:before{border-left-color:#fff;margin-right:-12px;right:0}.leaflet-tooltip-right:before{border-right-color:#fff;margin-left:-12px;left:0}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.map-viewer-page{padding:2rem 0}.map-viewer-header{margin-bottom:2rem}.map-viewer-content{flex-direction:column;gap:1.5rem;display:flex}.map-controls{background:var(--card-bg,#fff);border-radius:12px;flex-wrap:wrap;align-items:flex-end;gap:1rem;padding:1.5rem;display:flex;box-shadow:0 2px 8px #00000014}.input-group{flex-direction:column;flex:1;gap:.5rem;min-width:150px;display:flex}.input-group label{color:var(--text-secondary,#666);font-size:.875rem;font-weight:500}.input-group input{border:1px solid var(--border-color,#ddd);background:var(--input-bg,#fff);color:var(--text-primary,#333);border-radius:8px;padding:.75rem 1rem;font-size:1rem}.input-group input:focus{border-color:var(--primary-color,#3b82f6);outline:none}.preset-locations{background:var(--card-bg,#fff);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014}.preset-locations h3{color:var(--text-secondary,#666);margin:0 0 1rem;font-size:1rem}.preset-grid{flex-wrap:wrap;gap:.5rem;display:flex}.preset-btn{border:1px solid var(--border-color,#ddd);background:var(--bg-secondary,#f5f5f5);color:var(--text-primary,#333);cursor:pointer;border-radius:20px;padding:.5rem 1rem;font-size:.875rem;transition:all .2s}.preset-btn:hover{background:var(--primary-color,#3b82f6);color:#fff;border-color:var(--primary-color,#3b82f6)}.map-container{border-radius:12px;height:500px;position:relative;overflow:hidden;box-shadow:0 2px 8px #00000014}.map-container .leaflet-container{width:100%;height:100%}.coordinates-display{background:var(--card-bg,#fff);z-index:1000;border-radius:8px;padding:.5rem 1rem;font-family:monospace;font-size:.875rem;position:absolute;bottom:1rem;right:1rem;box-shadow:0 2px 8px #00000026}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary:hover{background:var(--primary-hover,#2563eb)}.save-location-section{flex:1;gap:.5rem;display:flex}.save-location-section input{border:1px solid var(--border-color,#ddd);background:var(--input-bg,#fff);color:var(--text-primary,#333);border-radius:8px;flex:1;padding:.75rem 1rem;font-size:1rem}.saved-locations{background:var(--card-bg,#fff);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014}.saved-locations h3{color:var(--text-secondary,#666);margin:0 0 1rem;font-size:1rem}.saved-list{flex-direction:column;gap:.5rem;display:flex}.saved-location-item{background:var(--bg-secondary,#f5f5f5);border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.saved-location-name{cursor:pointer;color:var(--primary-color,#3b82f6);font-weight:500}.saved-location-name:hover{text-decoration:underline}.delete-btn{color:var(--text-secondary,#666);cursor:pointer;background:0 0;border:none;align-items:center;padding:.25rem;display:flex}.delete-btn:hover{color:var(--danger-color,#ef4444)}@media (width<=640px){.map-controls{flex-direction:column}.input-group{width:100%}.map-container{height:400px}}.ttt-page{justify-content:center;min-height:calc(100vh - 64px);padding:2rem 0;display:flex}.ttt-container{width:100%;max-width:500px;padding:0 1rem}.ttt-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.ttt-header h1{font-size:1.75rem}.ttt-header .btn{align-items:center;gap:.5rem;display:flex}.players{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.player-card{background:var(--bg-secondary);border:2px solid var(--border-color);text-align:center;border-radius:12px;flex:1;padding:1rem;transition:all .3s}.player-card.active{border-color:var(--accent-primary);box-shadow:0 0 0 3px #4f46e533}.player-card.winner{border-color:var(--success);background:#10b9811a}.player-name{cursor:pointer;flex-direction:column;align-items:center;gap:.25rem;display:flex;position:relative}.player-mark{font-size:1.25rem;font-weight:600}.player-mark.X{color:#ef4444}.player-mark.O{color:#3b82f6}.player-label{font-size:2rem;font-weight:700;line-height:1}.player-mark.X+.player-label{color:#ef4444}.player-mark.O+.player-label{color:#3b82f6}.edit-icon{opacity:0;color:var(--text-secondary);transition:opacity .2s;position:absolute;top:50%;right:-20px;transform:translateY(-50%)}.player-name:hover .edit-icon{opacity:1}.name-edit{justify-content:center;align-items:center;gap:.5rem;display:flex}.name-edit input{border:1px solid var(--border-color);background:var(--bg-primary);width:100px;color:var(--text-primary);text-align:center;border-radius:6px;padding:.5rem;font-size:.875rem}.name-edit button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;padding:.25rem;display:flex}.name-edit button:first-of-type{color:var(--success)}.name-edit button:last-of-type{color:var(--error)}.vs{color:var(--text-secondary);font-size:1.25rem;font-weight:700}.ttt-status{text-align:center;color:var(--text-primary);margin-bottom:1.5rem;font-size:1.25rem;font-weight:600}.ttt-status.game-over{color:var(--accent-primary)}.ttt-board{background:var(--border-color);aspect-ratio:1;border-radius:16px;grid-template-columns:repeat(3,1fr);gap:8px;max-width:350px;margin:0 auto;padding:8px;display:grid}.ttt-cell{background:var(--bg-secondary);cursor:pointer;aspect-ratio:1;border:none;border-radius:12px;justify-content:center;align-items:center;font-size:3rem;font-weight:700;transition:all .2s;display:flex}.ttt-cell:hover:not(:disabled){background:var(--bg-primary);transform:scale(.98)}.ttt-cell.X{color:#ef4444}.ttt-cell.O{color:#3b82f6}.ttt-cell.winning{background:#10b98133;animation:.5s ease-in-out pulse}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.ttt-hint{text-align:center;color:var(--text-secondary);margin-top:1.5rem;font-size:.875rem}@media (width<=480px){.ttt-header{flex-direction:column;gap:1rem}.ttt-header h1{font-size:1.5rem}.players{flex-direction:column;gap:.75rem}.vs{font-size:1rem}.player-card{width:100%}.ttt-cell{font-size:2.5rem}.ttt-board{max-width:300px}}.ludo-page{background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);justify-content:center;min-height:calc(100vh - 64px);padding:1.5rem 0;display:flex}.ludo-container{width:100%;max-width:420px;padding:0 1rem}.ludo-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.ludo-header h1{background:linear-gradient(135deg,#ef4444,#22c55e,#eab308,#3b82f6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.75rem}.ludo-header .btn{align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;display:flex}.ludo-turn-indicator{text-align:center;margin-bottom:1rem}.turn-player{color:#fff;border-radius:20px;padding:.5rem 1.5rem;font-size:.9rem;font-weight:600;display:inline-block;box-shadow:0 4px 12px #00000026}.ludo-players{grid-template-columns:repeat(4,1fr);gap:.5rem;margin-bottom:1rem;display:grid}.ludo-player{background:var(--bg-secondary);border:2px solid var(--border-color);text-align:center;border-radius:12px;padding:.6rem;transition:all .3s}.ludo-player.active{border-color:var(--accent-primary);transform:scale(1.02);box-shadow:0 0 0 3px #4f46e533}.ludo-player .player-name{cursor:pointer;justify-content:center;align-items:center;gap:.4rem;margin-bottom:.4rem;font-size:.8rem;font-weight:600;display:flex}.ludo-player .dot{border-radius:50%;width:10px;height:10px}.ludo-player .dot.red{background:#ef4444}.ludo-player .dot.green{background:#22c55e}.ludo-player .dot.yellow{background:#eab308}.ludo-player .dot.blue{background:#3b82f6}.ludo-player .name-edit{justify-content:center;align-items:center;gap:.25rem;display:flex}.ludo-player .name-edit input{border:1px solid var(--border-color);background:var(--bg-primary);width:60px;color:var(--text-primary);text-align:center;border-radius:4px;padding:.25rem;font-size:.7rem}.ludo-player .name-edit button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:.125rem;display:flex}.token-indicators{justify-content:center;gap:3px;display:flex}.token-dot{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:.6rem;font-weight:600;display:flex}.token-dot.base{background:#94a3b8}.token-dot.active{background:var(--accent-primary)}.token-dot.home{color:#333;background:gold}.ludo-winner{text-align:center;background:linear-gradient(135deg,gold,#ffed4a);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1rem;padding:1rem;font-size:1.5rem;font-weight:700;animation:1s ease-in-out infinite winnerPulse}@keyframes winnerPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.ludo-board{aspect-ratio:1;border:3px solid var(--border-color);background:#fff;border-radius:16px;max-width:340px;margin:0 auto;position:relative;overflow:hidden;box-shadow:0 8px 32px #00000026}.ludo-grid{grid-template-rows:repeat(11,1fr);grid-template-columns:repeat(11,1fr);width:100%;height:100%;display:grid}.ludo-cell{border:.5px solid #00000014;justify-content:center;align-items:center;display:flex}.ludo-cell.base{opacity:1}.ludo-cell.base-red{background:linear-gradient(135deg,#fca5a5,#ef4444)}.ludo-cell.base-green{background:linear-gradient(135deg,#86efac,#22c55e)}.ludo-cell.base-yellow{background:linear-gradient(135deg,#fde047,#eab308)}.ludo-cell.base-blue{background:linear-gradient(135deg,#93c5fd,#3b82f6)}.ludo-cell.safe{background:linear-gradient(135deg,#e0e7ff,#c7d2fe)}.ludo-cell.path{background:#f8fafc}.ludo-cell.home-path{background:linear-gradient(135deg,#fef3c7,#fde68a)}.ludo-cell .center-home{color:#64748b;font-size:.65rem;font-weight:700}.tokens-container{pointer-events:none;position:absolute;inset:0}.token{color:#fff;pointer-events:auto;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:7%;min-width:24px;height:7%;min-height:24px;font-size:.65rem;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;transform:translate(-50%,-50%);box-shadow:0 3px 8px #0000004d,inset 0 2px 4px #ffffff4d}.token.red{background:linear-gradient(135deg,#f87171,#dc2626)}.token.green{background:linear-gradient(135deg,#4ade80,#16a34a)}.token.yellow{color:#333;background:linear-gradient(135deg,#facc15,#ca8a04)}.token.blue{background:linear-gradient(135deg,#60a5fa,#2563eb)}.token.clickable{cursor:pointer;z-index:10;animation:.6s ease-in-out infinite tokenBounce;transform:translate(-50%,-50%)scale(1.15)}.token.at-home{border-color:gold;box-shadow:0 0 15px #ffd70099;color:#333!important;background:linear-gradient(135deg,gold,#ffb700)!important}@keyframes tokenBounce{0%,to{transform:translate(-50%,-50%)scale(1)}50%{transform:translate(-50%,-50%)scale(1.15)}}.ludo-controls{text-align:center;margin-top:1.25rem}.dice-btn{background:linear-gradient(135deg, var(--accent-primary), #6366f1);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100px;height:50px;font-size:1.1rem;font-weight:700;transition:all .2s;box-shadow:0 4px 15px #4f46e566}.dice-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #4f46e580}.dice-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.dice-btn.rolled{animation:.5s ease-out diceRoll}@keyframes diceRoll{0%{transform:rotate(0)scale(1)}25%{transform:rotate(90deg)scale(1.1)}50%{transform:rotate(180deg)scale(1)}75%{transform:rotate(270deg)scale(1.1)}to{transform:rotate(360deg)scale(1)}}.ludo-hint{color:var(--text-secondary);min-height:2.4rem;margin-top:.75rem;font-size:.8rem}@media (width<=440px){.ludo-header{flex-direction:column;gap:.75rem}.ludo-header h1{font-size:1.5rem}.ludo-board{max-width:280px}.ludo-player{padding:.4rem;font-size:.7rem}.token-dot{width:14px;height:14px;font-size:.55rem}.turn-player{padding:.4rem 1rem;font-size:.8rem}}.chess-page{justify-content:center;min-height:calc(100vh - 64px);padding:1rem 0;display:flex}.chess-container{width:100%;max-width:500px;padding:0 .5rem}.chess-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.chess-header h1{font-size:1.5rem}.chess-header .btn{align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;display:flex}.chess-players{justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:1rem;display:flex}.chess-player{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;flex:1;min-width:100px;padding:.5rem;font-size:.8rem}.chess-player.active{border-color:var(--accent-primary)}.chess-player .player-name{cursor:pointer;align-items:center;gap:.375rem;margin-bottom:.25rem;display:flex}.chess-player .piece{font-size:1rem}.chess-player .name-edit{align-items:center;gap:.25rem;display:flex}.chess-player .name-edit input{border:1px solid var(--border-color);background:var(--bg-primary);width:70px;color:var(--text-primary);border-radius:4px;padding:.25rem;font-size:.75rem}.chess-player .name-edit button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:.125rem;display:flex}.chess-status{text-align:center;color:var(--accent-primary);max-width:120px;padding:.5rem .25rem;font-size:.8rem;font-weight:600}.chess-captured{flex-wrap:wrap;gap:1px;min-height:1rem;font-size:.7rem;display:flex}.chess-player .captured span{margin-right:1px}.chess-board{aspect-ratio:1;border-radius:8px;grid-template-columns:repeat(8,1fr);max-width:350px;margin:0 auto;display:grid;overflow:hidden;box-shadow:0 4px 12px #00000026}.chess-square{aspect-ratio:1;cursor:pointer;justify-content:center;align-items:center;transition:all .15s;display:flex;position:relative}.chess-square.light{background:#f0d9b5}.chess-square.dark{background:#b58863}.chess-square.selected{background:#4f46e580!important}.chess-square.valid{background:#4f46e54d!important}.chess-square.in-check{animation:.5s ease-in-out infinite pulse-check;background:#ef444499!important}@keyframes pulse-check{0%,to{background:#ef444466}50%{background:#ef4444b3}}.chess-square .piece{-webkit-user-select:none;user-select:none;font-size:clamp(1.5rem,5vw,2.5rem);line-height:1}.chess-square .dot{background:#4f46e566;border-radius:50%;width:30%;height:30%}.chess-hint{text-align:center;color:var(--text-secondary);margin-top:1rem;padding:0 .5rem;font-size:.75rem}@media (width<=400px){.chess-header h1{font-size:1.25rem}.chess-player{padding:.375rem;font-size:.7rem}.chess-status{padding:.25rem;font-size:.7rem}.chess-board{max-width:300px}}.pictionary-page{background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);justify-content:center;min-height:calc(100vh - 64px);padding:1.5rem 0;display:flex}.pictionary-container{width:100%;max-width:900px;padding:0 1rem}.pictionary-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.pictionary-header h1{background:linear-gradient(135deg,#8b5cf6,#ec4899);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.75rem}.pictionary-header .header-actions{gap:.5rem;display:flex}.pictionary-header .btn{align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;display:flex}.pictionary-toolbar{background:var(--bg-secondary);border-radius:12px;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem;padding:.75rem;display:flex;box-shadow:0 2px 8px #0000001a}.tool-group{align-items:center;gap:.5rem;display:flex}.tool-group.colors{flex:1;justify-content:center}.tool-btn{border:2px solid var(--border-color);background:var(--bg-primary);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.tool-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.tool-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.color-btn{cursor:pointer;border:2px solid #0000;border-radius:50%;width:28px;height:28px;transition:all .2s}.color-btn:hover{transform:scale(1.15)}.color-btn.active{border-color:var(--text-primary);box-shadow:0 0 0 2px white, 0 0 0 4px var(--accent-primary)}.brush-sizes .size-btn{border:2px solid var(--border-color);background:var(--bg-primary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.brush-sizes .size-btn.active{border-color:var(--accent-primary)}.canvas-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #00000026}.canvas-container canvas{cursor:crosshair;touch-action:none;width:100%;height:auto;display:block}.pictionary-hint{text-align:center;color:var(--text-secondary);margin-top:1rem;font-size:.875rem}@media (width<=768px){.pictionary-toolbar{justify-content:center}.pictionary-header{flex-direction:column;align-items:stretch}.pictionary-header h1{text-align:center}.pictionary-header .header-actions{justify-content:center}}@media (width<=480px){.tool-group.colors{flex-wrap:wrap}.color-btn{width:24px;height:24px}}.scrabble-page{background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);justify-content:center;min-height:calc(100vh - 64px);padding:1.5rem 0;display:flex;overflow-x:auto}.scrabble-container{width:100%;max-width:700px;padding:0 1rem}.scrabble-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.scrabble-header h1{background:linear-gradient(135deg,#22c55e,#16a34a);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.75rem}.scrabble-header .header-info{align-items:center;gap:1rem;display:flex}.scrabble-header .score{color:var(--accent-primary);font-size:1.25rem;font-weight:700}.scrabble-header .btn{align-items:center;gap:.5rem;padding:.5rem 1rem;display:flex}.scrabble-message{text-align:center;background:var(--bg-secondary);color:var(--text-secondary);border-radius:8px;margin-bottom:1rem;padding:.75rem;font-weight:500}.scrabble-board{background:wheat;border-radius:8px;margin-bottom:1rem;padding:4px;box-shadow:0 4px 20px #00000026}.board-row{display:flex}.board-cell{cursor:pointer;border:1px solid #0000001a;justify-content:center;align-items:center;width:32px;height:32px;font-size:.6rem;display:flex;position:relative}.board-cell.dw{background:#ffb6c1}.board-cell.tw{color:#fff;background:#ff6b6b}.board-cell.tl{background:#87ceeb}.board-cell.filled{background:#fff8dc}.tile{background:linear-gradient(145deg,#fff8dc,#deb887);border-radius:4px;flex-direction:column;justify-content:center;align-items:center;width:28px;height:28px;display:flex;box-shadow:1px 1px 3px #0000004d}.tile-letter{font-size:.85rem;font-weight:700;line-height:1}.tile-score{color:#666;font-size:.55rem}.scrabble-controls{background:var(--bg-secondary);border-radius:12px;margin-bottom:1rem;padding:1rem}.rack{flex-wrap:wrap;justify-content:center;gap:.5rem;margin-bottom:1rem;display:flex}.rack-tile{cursor:pointer;background:linear-gradient(145deg,#fff8dc,#deb887);border:none;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;width:40px;height:46px;transition:all .2s;display:flex;box-shadow:2px 2px 6px #0003}.rack-tile:hover{transform:translateY(-3px)}.rack-tile.selected{background:linear-gradient(145deg,gold,#daa520);transform:translateY(-5px);box-shadow:0 4px 12px #0000004d}.rack-tile .tile-letter{font-size:1.1rem}.rack-tile .tile-score{font-size:.65rem}.control-buttons{justify-content:center;gap:1rem;display:flex}.control-buttons .btn{align-items:center;gap:.5rem;padding:.6rem 1.25rem;display:flex}.scrabble-legend{flex-wrap:wrap;justify-content:center;gap:1.5rem;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.8rem;display:flex}.legend-item .dot{border-radius:4px;width:16px;height:16px}.legend-item .dot.tw{background:#ff6b6b}.legend-item .dot.dw{background:#ffb6c1}.legend-item .dot.tl{background:#87ceeb}@media (width<=600px){.board-cell{width:20px;height:20px}.tile{width:18px;height:18px}.tile-letter{font-size:.6rem}.tile-score{display:none}.rack-tile{width:32px;height:38px}.rack-tile .tile-letter{font-size:.9rem}}.carrom-page{background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);justify-content:center;min-height:calc(100vh - 64px);padding:1.5rem 0;display:flex}.carrom-container{width:100%;max-width:500px;padding:0 1rem}.carrom-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.carrom-header h1{background:linear-gradient(135deg,#f59e0b,#d97706);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.75rem}.carrom-header .btn{align-items:center;gap:.5rem;padding:.5rem 1rem;display:flex}.carrom-message{text-align:center;background:var(--bg-secondary);border-radius:8px;margin-bottom:1rem;padding:.75rem;font-size:.9rem;font-weight:500}.carrom-scores{grid-template-columns:repeat(4,1fr);gap:.5rem;margin-bottom:1rem;display:grid}.score-card{background:var(--bg-secondary);border:2px solid var(--border-color);text-align:center;border-radius:8px;padding:.5rem;transition:all .3s}.score-card.active{border-color:var(--player-color);box-shadow:0 0 0 3px color-mix(in srgb, var(--player-color) 30%, transparent)}.player-info{justify-content:center;align-items:center;gap:.25rem;margin-bottom:.25rem;font-size:.75rem;display:flex}.player-info .dot{border-radius:50%;width:10px;height:10px}.score-card .score{color:var(--player-color);font-size:1.25rem;font-weight:700}.carrom-board-container{justify-content:center;margin-bottom:1rem;display:flex}.carrom-canvas{border-radius:12px;max-width:100%;height:auto;box-shadow:0 8px 32px #0003}.carrom-controls{background:var(--bg-secondary);border-radius:12px;flex-direction:column;gap:.75rem;padding:1rem;display:flex}.angle-control,.power-control{align-items:center;gap:.75rem;display:flex}.angle-control span,.power-control span{min-width:50px;font-size:.875rem}.angle-control button{background:var(--accent-primary);color:#fff;cursor:pointer;border:none;border-radius:8px;width:36px;height:36px;font-size:1rem;transition:all .2s}.angle-control button:hover{background:var(--accent-hover)}.strike-btn{padding:.75rem;font-size:1.1rem;font-weight:700}.strike-btn:disabled{opacity:.6;cursor:not-allowed}@media (width<=480px){.carrom-scores{grid-template-columns:repeat(2,1fr)}.angle-control,.power-control{flex-wrap:wrap;justify-content:center}}.pool-page{background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);justify-content:center;min-height:calc(100vh - 64px);padding:1.5rem 0;display:flex}.pool-container{width:100%;max-width:650px;padding:0 1rem}.pool-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.pool-header h1{background:linear-gradient(135deg,#0ea5e9,#0284c7);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.75rem}.pool-header .btn{align-items:center;gap:.5rem;padding:.5rem 1rem;display:flex}.pool-message{text-align:center;background:var(--bg-secondary);border-radius:8px;margin-bottom:1rem;padding:.75rem;font-weight:500}.pool-scores{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.pool-player{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;flex:1;justify-content:space-between;align-items:center;padding:.75rem 1rem;transition:all .3s;display:flex}.pool-player.active{border-color:var(--accent-primary);box-shadow:0 0 0 3px #4f46e533}.player-name{font-weight:600}.player-score{color:var(--accent-primary);font-size:1.5rem;font-weight:700}.pool-scores .vs{color:var(--text-secondary);font-weight:700}.pool-table-container{justify-content:center;margin-bottom:1rem;display:flex}.pool-canvas{cursor:crosshair;border-radius:16px;max-width:100%;height:auto;box-shadow:0 8px 32px #0000004d}.pool-controls{background:var(--bg-secondary);border-radius:12px;flex-direction:column;gap:.75rem;padding:1rem;display:flex}.power-control{align-items:center;gap:.75rem;display:flex}.power-control span{min-width:50px;font-size:.875rem}.power-control input[type=range]{background:var(--border-color);-webkit-appearance:none;border-radius:4px;outline:none;flex:1;height:8px}.power-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent-primary);cursor:pointer;border-radius:50%;width:20px;height:20px}.shoot-btn{padding:.75rem;font-size:1.1rem;font-weight:700}.pool-hint{text-align:center;color:var(--text-secondary);font-size:.875rem}@media (width<=640px){.pool-scores{flex-direction:column}.pool-player{width:100%}.vs{font-size:.875rem}}.editor-page{background:var(--bg-primary);flex-direction:column;height:calc(100vh - 56px);display:flex;overflow:hidden}@media (width<=768px){.editor-page{height:calc(100dvh - 56px)}}.editor-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0;align-items:center;gap:8px;padding:8px 16px;display:flex}.editor-header .back-link{color:var(--text-secondary);border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:13px;text-decoration:none;transition:all .2s;display:flex}.editor-header .back-link:hover{background:var(--accent-primary);color:#fff}.page-title{color:var(--text-primary);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.title-icon{color:var(--accent-primary)}.editor-container{flex:1;display:flex;overflow:hidden}.editor-main{background:#1a1a2e;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.editor-canvas-area{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.canvas-wrapper{backface-visibility:hidden;perspective:1000px;justify-content:center;align-items:center;max-width:100%;max-height:100%;display:flex;position:relative;overflow:auto;transform:translateZ(0)}.editor-canvas{cursor:crosshair;border-radius:4px;max-width:100%;max-height:100%;box-shadow:0 8px 40px #00000080}@media (width<=768px){.editor-canvas{max-width:calc(100vw - 16px);max-height:calc(100dvh - 200px)}}@media (width>=1200px){.editor-canvas{max-width:calc(100vw - 340px);max-height:calc(100vh - 100px)}}@media (width>=1600px){.editor-canvas{max-width:calc(100vw - 360px);max-height:calc(100vh - 100px)}}.upload-prompt{cursor:pointer;color:#fff9;text-align:center;border:2px dashed #fff3;border-radius:16px;flex-direction:column;align-items:center;gap:16px;max-width:400px;padding:60px 40px;transition:all .3s;display:flex}.upload-prompt:hover{border-color:var(--accent-primary);color:#fff;background:#8b5cf61a}.upload-prompt h3{color:#fff;margin:0;font-size:18px;font-weight:600}.upload-prompt p{margin:0;font-size:14px}.upload-prompt .hint{opacity:.5;font-size:12px}.file-input-hidden{display:none}.top-toolbar{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:10;will-change:transform, opacity;background:#000000bf;border:1px solid #ffffff1a;border-radius:10px;align-items:center;gap:2px;padding:4px 6px;transition:opacity .25s,transform .25s;display:flex;position:absolute;top:12px;left:50%;transform:translate(-50%)}.top-toolbar.hidden{opacity:0;pointer-events:none;transform:translate(-50%)translateY(-10px)}.toolbar-divider{background:#ffffff26;width:1px;height:24px;margin:0 4px}.toolbar-btn{color:#fffc;cursor:pointer;will-change:transform, background-color;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .15s;display:flex;position:relative}.toolbar-btn:hover:not(:disabled){color:#fff;background:#ffffff26}.toolbar-btn:active:not(:disabled){transform:scale(.92)}.toolbar-btn.active,.toolbar-btn.primary{background:var(--accent-primary);color:#fff}.toolbar-btn.primary:hover:not(:disabled){background:var(--accent-secondary)}.toolbar-btn:disabled{opacity:.3;cursor:not-allowed}.toolbar-btn[data-tooltip]:hover:after{content:attr(data-tooltip);color:#fff;white-space:nowrap;pointer-events:none;z-index:100;background:#000000e6;border-radius:4px;padding:3px 8px;font-size:11px;position:absolute;bottom:-28px;left:50%;transform:translate(-50%)}.left-panel{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:10;will-change:transform, opacity;background:#000000bf;border:1px solid #ffffff1a;border-radius:10px;flex-direction:column;gap:2px;padding:6px;transition:opacity .25s,transform .25s;display:flex;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.left-panel.hidden{opacity:0;pointer-events:none;transform:translateY(-50%)translate(-10px)}.left-panel-btn{color:#fffc;cursor:pointer;will-change:transform, background-color;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .15s;display:flex;position:relative}.left-panel-btn:hover:not(:disabled){color:#fff;background:#ffffff26}.left-panel-btn.active{background:var(--accent-primary);color:#fff}.left-panel-btn:disabled{opacity:.3;cursor:not-allowed}.left-panel-btn[data-tooltip]:hover:after{content:attr(data-tooltip);color:#fff;white-space:nowrap;pointer-events:none;z-index:100;background:#000000e6;border-radius:4px;padding:3px 8px;font-size:11px;position:absolute;top:50%;left:calc(100% + 8px);transform:translateY(-50%)}.zoom-controls{border-top:1px solid #ffffff1a;flex-direction:column;align-items:center;gap:2px;margin-top:4px;padding:4px 0;display:flex}.zoom-level{color:#fff9;text-align:center;min-width:36px;padding:2px 0;font-size:10px}.adjustments-panel{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:10;will-change:transform, opacity;background:#000000d9;border:1px solid #ffffff1a;border-radius:12px;flex-direction:column;width:260px;transition:opacity .25s,transform .25s;display:flex;position:absolute;top:56px;bottom:12px;right:12px;overflow:hidden}.adjustments-panel.hidden{opacity:0;pointer-events:none;transform:translate(10px)}@media (width>=1200px){.adjustments-panel{width:280px}}.adjustments-header{border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.adjustments-title{color:#fff;align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.close-panel-btn{color:#ffffffb3;cursor:pointer;background:#ffffff1a;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;transition:all .15s;display:flex}.close-panel-btn:hover{color:#fff;background:#fff3}.category-tabs{border-bottom:1px solid #ffffff0d;gap:4px;padding:10px 14px;display:flex;overflow-x:auto}.category-btn{color:#fff9;cursor:pointer;text-transform:capitalize;background:#ffffff14;border:none;border-radius:6px;flex-shrink:0;padding:6px 12px;font-size:12px;font-weight:500;transition:all .15s}.category-btn:hover{color:#fff;background:#ffffff26}.category-btn.active{background:var(--accent-primary);color:#fff}.sliders-container{flex-direction:column;flex:1;gap:16px;padding:12px 14px;display:flex;overflow-y:auto}.slider-row{flex-direction:column;gap:6px;display:flex}.slider-header{color:#ffffffb3;align-items:center;gap:8px;font-size:12px;display:flex}.slider-label{flex:1}.slider-value{text-align:right;font-variant-numeric:tabular-nums;color:#ffffff80;background:#ffffff0d;border-radius:4px;min-width:32px;padding:2px 6px;font-size:11px}.slider-value.modified{color:var(--accent-primary);background:#8b5cf633}.reset-btn{color:#ffffff80;cursor:pointer;background:#ffffff1a;border:none;border-radius:4px;justify-content:center;align-items:center;width:18px;height:18px;transition:all .15s;display:flex}.reset-btn:hover{color:#fff;background:#ff50504d}.slider-input-wrapper{padding:4px 0;position:relative}.slider-input{appearance:none;cursor:pointer;background:#ffffff26;border-radius:2px;outline:none;width:100%;height:4px}.slider-input::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .15s;box-shadow:0 2px 8px #0000004d}.slider-input::-webkit-slider-thumb:hover{transform:scale(1.2)}.slider-input::-moz-range-thumb{cursor:pointer;background:#fff;border:none;border-radius:50%;width:16px;height:16px;box-shadow:0 2px 8px #0000004d}.filters-strip{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:10;will-change:transform, opacity;background:#000000d9;border:1px solid #ffffff1a;border-radius:12px;padding:12px 14px;transition:opacity .25s,transform .25s;position:absolute;bottom:12px;left:12px;right:12px}.filters-strip.hidden{opacity:0;pointer-events:none;transform:translateY(10px)}.filters-label{color:#ffffff80;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:11px;font-weight:600;display:block}.filters-scroll{gap:10px;padding-bottom:4px;display:flex;overflow-x:auto}.filters-scroll::-webkit-scrollbar{height:4px}.filters-scroll::-webkit-scrollbar-track{background:#ffffff0d;border-radius:2px}.filters-scroll::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.preset-btn{cursor:pointer;background:0 0;border:2px solid #0000;border-radius:8px;flex-direction:column;flex-shrink:0;align-items:center;gap:6px;padding:6px;transition:all .15s;display:flex}.preset-btn:hover{background:#ffffff1a}.preset-btn.active{border-color:var(--accent-primary)}.preset-preview{color:#ffffff80;background:#ffffff14;border-radius:6px;justify-content:center;align-items:center;width:64px;height:48px;font-size:10px;display:flex;overflow:hidden}.preset-preview[data-preset=vivid]{background:linear-gradient(135deg,#ff6b6b,#4ecdc4)}.preset-preview[data-preset=warm]{background:linear-gradient(135deg,#f093fb,#f5576c)}.preset-preview[data-preset=cool]{background:linear-gradient(135deg,#4facfe,#00f2fe)}.preset-preview[data-preset=bw]{background:linear-gradient(135deg,#667eea,#764ba2)}.preset-preview[data-preset=sepia]{background:linear-gradient(135deg,#d4a574,#c49b63)}.preset-preview[data-preset=fade]{opacity:.7;background:linear-gradient(135deg,#e0c3fc,#8ec5fc)}.preset-preview[data-preset=vintage]{background:linear-gradient(135deg,#f5af19,#f12711)}.preset-preview[data-preset=dramatic]{background:linear-gradient(135deg,#0c3483,#a2b6df)}.preset-preview[data-preset=muted]{background:linear-gradient(135deg,#c9d6ff,#e2e2e2)}.preset-name{color:#fff;font-size:9px;font-weight:600}.preset-label{color:#fff9;font-size:10px}.hide-all-btn{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);color:#fffc;cursor:pointer;z-index:20;background:#000000bf;border:1px solid #ffffff1a;border-radius:8px;align-items:center;gap:6px;padding:8px 12px;font-size:12px;font-weight:500;transition:all .15s;display:flex;position:absolute;top:12px;right:12px}.hide-all-btn:hover{color:#fff;background:#000000e6}.histogram-panel{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:10;will-change:opacity;background:#000000d9;border:1px solid #ffffff1a;border-radius:10px;width:200px;padding:10px;transition:opacity .25s;position:absolute;bottom:80px;left:12px}.histogram-panel.hidden{opacity:0;pointer-events:none}.histogram-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.histogram-header span{color:#ffffffb3;text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.histogram-header button{color:#ffffff80;cursor:pointer;background:#ffffff1a;border:none;border-radius:4px;justify-content:center;align-items:center;width:20px;height:20px;transition:all .15s;display:flex}.histogram-header button:hover{color:#fff;background:#fff3}.histogram-display{aspect-ratio:2.5;width:100%}.histogram-svg{width:100%;height:100%}.processing-overlay{color:#fff;z-index:50;background:#0009;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:13px;display:flex;position:absolute;inset:0}.spinner{will-change:transform;border:3px solid #fff3;border-top-color:#fff;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@media (width<=768px){.top-toolbar{scrollbar-width:none;border-radius:12px;gap:2px;max-width:calc(100% - 16px);padding:4px 6px;top:auto;bottom:56px;left:50%;overflow:auto hidden;transform:translate(-50%)}.top-toolbar::-webkit-scrollbar{display:none}.top-toolbar.hidden{transform:translate(-50%)translateY(10px)}.toolbar-btn{flex-shrink:0;width:34px;height:34px}.toolbar-divider{height:20px;margin:0 2px}.top-toolbar .toolbar-btn[data-tooltip=Save\ As],.top-toolbar .toolbar-btn[data-tooltip=Histogram],.top-toolbar .toolbar-btn[data-tooltip=Import\ Filter],.top-toolbar .toolbar-btn[data-tooltip=Crop\ Grid]{display:none}.left-panel{padding:6px 10px;padding-bottom:max(6px, env(safe-area-inset-bottom));z-index:12;border-bottom:none;border-left:none;border-right:none;border-radius:0;flex-direction:row;justify-content:center;gap:2px;position:fixed;inset:auto 0 0;transform:none}.left-panel.hidden{transform:translateY(100%)}.left-panel-btn{width:38px;height:38px}.left-panel-btn[data-tooltip]:hover:after{top:auto;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}.zoom-controls{border-top:none;border-left:1px solid #ffffff1a;flex-direction:row;margin-top:0;margin-left:6px;padding:0 6px}.ie-mobile-toggle{background:var(--accent-primary);color:#fff;cursor:pointer;z-index:13;border:none;border-radius:20px 20px 0 0;padding:6px 16px;font-size:12px;display:flex;position:fixed;bottom:60px;left:50%;transform:translate(-50%);box-shadow:0 -2px 10px #0000004d}.left-panel.mobile-hidden{transform:translateY(100%)}.zoom-level{writing-mode:horizontal-tb;min-width:40px;font-size:11px}.adjustments-panel{z-index:20;border:none;border-radius:16px 16px 0 0;width:100%;max-height:55vh;transition:transform .3s cubic-bezier(.4,0,.2,1);position:fixed;inset:auto 0 0;transform:translateY(0)}.adjustments-panel.hidden{pointer-events:none;transform:translateY(100%)}.sliders-container{max-height:calc(55vh - 110px)}.slider-input::-webkit-slider-thumb{width:22px;height:22px}.slider-input::-moz-range-thumb{width:22px;height:22px}.slider-input{height:6px}.filters-strip{z-index:20;padding-bottom:max(12px, env(safe-area-inset-bottom));border:none;border-radius:16px 16px 0 0;transition:transform .3s cubic-bezier(.4,0,.2,1);position:fixed;bottom:0;left:0;right:0;transform:translateY(0)}.filters-strip.hidden{pointer-events:none;transform:translateY(100%)}.session-panel{z-index:25;border:none;border-radius:16px 16px 0 0;width:100%;max-height:70vh;position:fixed;inset:auto 0 0}.gallery-panel{z-index:100;border-radius:0;inset:0}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.editor-canvas{max-width:calc(100vw - 16px);max-height:calc(100dvh - 200px)}.histogram-panel{width:140px;bottom:100px;left:8px}.hide-all-btn{z-index:14;padding:8px;top:auto;bottom:100px;right:8px}.hide-all-btn span{display:none}.crop-aspect-bar{flex-wrap:wrap;justify-content:center;gap:2px;max-width:calc(100% - 16px);padding:4px 8px;top:10px}.aspect-btn{padding:4px 8px;font-size:10px}.crop-controls{flex-direction:column;gap:6px;padding:8px 12px;bottom:60px;left:12px;right:12px;transform:none}.crop-btn{padding:10px 16px;font-size:14px}.upload-prompt{max-width:300px;padding:40px 24px}.upload-prompt h3{font-size:16px}.upload-prompt p{font-size:13px}.saving-status{display:none}}@media (width<=480px){.toolbar-btn{width:32px;height:32px}.left-panel-btn{width:36px;height:36px}.left-panel{padding:4px 8px;padding-bottom:max(4px, env(safe-area-inset-bottom));gap:1px}.adjustments-panel{max-height:60vh}.sliders-container{max-height:calc(60vh - 110px)}.editor-canvas{max-height:calc(100dvh - 210px)}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}.preset-preview{width:56px;height:42px}}.crop-overlay-container{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.crop-overlay{pointer-events:none;background:0 0;width:100%;height:100%;position:absolute;top:0;left:0}.crop-selection{box-sizing:border-box;pointer-events:none;background:0 0;border:2px dashed #fff;position:absolute;box-shadow:inset 0 0 0 9999px #00000080}.crop-controls{z-index:10;background:#00000040;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:6px 12px;display:flex;position:absolute;bottom:14px;left:50%;transform:translate(-50%)}.crop-grid{pointer-events:none;opacity:.6;mix-blend-mode:overlay;background-image:linear-gradient(90deg,#ffffff40 1px,#0000 1px),linear-gradient(#ffffff40 1px,#0000 1px);background-size:32px 32px;position:absolute;inset:0}.crop-btn{cursor:pointer;color:#fff;background:#ffffff14;border:none;border-radius:6px;justify-content:center;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;transition:background .2s;display:inline-flex}.crop-btn.apply{color:#fff;background:#22c55e}.crop-btn.apply:hover{background:#16a34a}.crop-btn.cancel{color:#fff;background:#6b7280}.crop-btn.cancel:hover{background:#4b5563}.crop-aspect-bar{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);pointer-events:auto;z-index:20;background:#000000d9;border:1px solid #ffffff26;border-radius:8px;gap:4px;padding:6px 10px;display:flex;position:absolute;top:20px;left:50%;transform:translate(-50%)}.saving-status{color:#e2e8f0;opacity:.85;align-items:center;padding:0 8px;font-size:12px;display:inline-flex}.crop-aspect-selector{flex-wrap:wrap;justify-content:center;gap:4px;margin-bottom:8px;display:flex}.aspect-btn{color:#fffc;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff26;border-radius:4px;padding:4px 10px;font-size:11px;font-weight:500;transition:all .15s}.aspect-btn:hover{color:#fff;background:#fff3}.aspect-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.crop-actions{justify-content:center;gap:8px;display:flex}.session-panel{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:15;background:#000000e6;border:1px solid #ffffff1a;border-radius:12px;flex-direction:column;width:300px;display:flex;position:absolute;top:56px;bottom:12px;right:12px;overflow:hidden}.session-panel-header{border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.session-panel-header h3{color:#fff;margin:0;font-size:14px;font-weight:600}.session-actions{border-bottom:1px solid #ffffff0d;gap:8px;padding:12px 14px;display:flex}.session-actions .btn-primary,.session-actions .btn-secondary{cursor:pointer;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:6px;padding:8px 12px;font-size:12px;font-weight:500;transition:all .15s;display:flex}.session-actions .btn-primary{background:var(--accent-primary);color:#fff}.session-actions .btn-primary:hover{background:var(--accent-secondary)}.session-actions .btn-secondary{color:#fffc;background:#ffffff1a}.session-actions .btn-secondary:hover:not(:disabled){color:#fff;background:#fff3}.session-actions .btn-secondary:disabled{opacity:.4;cursor:not-allowed}.session-list{flex-direction:column;flex:1;gap:4px;padding:8px;display:flex;overflow-y:auto}.session-empty{text-align:center;color:#fff6;padding:20px;font-size:13px}.session-item{cursor:pointer;background:#ffffff0d;border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;padding:10px 12px;transition:all .15s;display:flex}.session-item:hover{background:#ffffff1a}.session-item.active{border-color:var(--accent-primary);background:#8b5cf626}.session-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.session-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;overflow:hidden}.session-date{color:#ffffff80;font-size:10px}.session-steps{color:#ffffff80;white-space:nowrap;font-size:10px}.session-item-actions{align-items:center;gap:4px;display:flex}.session-delete-btn,.session-edit-btn{color:#fff6;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;transition:all .15s;display:flex}.session-delete-btn:hover{color:#ff5050;background:#ff505033}.session-edit-btn:hover{color:#64c8ff;background:#64c8ff33}.history-timeline{border-top:1px solid #ffffff1a;flex-direction:column;flex:1;padding:12px 14px;display:flex;overflow:hidden}.history-timeline h4{color:#fff9;text-transform:uppercase;letter-spacing:.5px;margin:0 0 10px;font-size:11px;font-weight:600}.timeline-list{flex-direction:column;flex:1;gap:4px;display:flex;overflow-y:auto}.timeline-empty{color:#fff6;font-size:11px;font-style:italic}.timeline-item{text-align:left;background:#ffffff0d;border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;padding:8px 10px;transition:all .15s;display:flex}.timeline-item:hover{background:#ffffff1a}.timeline-item.current{border-color:var(--accent-primary);background:#8b5cf633}.timeline-item.past{opacity:.7}.timeline-item-main{color:inherit;cursor:pointer;text-align:left;background:0 0;border:none;flex:1;align-items:center;gap:10px;padding:0;display:flex}.timeline-apply-btn{color:#fffc;cursor:pointer;opacity:0;background:#8b5cf64d;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;transition:all .15s;display:flex}.timeline-item:hover .timeline-apply-btn{opacity:1}.timeline-apply-btn:hover{background:var(--accent-primary);color:#fff}.timeline-step-num{color:#ffffffb3;background:#ffffff1a;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:600;display:flex}.timeline-item.current .timeline-step-num{background:var(--accent-primary);color:#fff}.timeline-step-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.timeline-step-title{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:500;overflow:hidden}.timeline-step-desc{color:#ffffff80;white-space:nowrap;text-overflow:ellipsis;font-size:9px;overflow:hidden}.session-settings{border-top:1px solid #ffffff1a;flex-direction:column;gap:12px;padding:12px 14px;display:flex}.session-settings .settings-header{color:#fff9;text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;font-size:11px;font-weight:600;display:flex}.session-settings .settings-group{flex-direction:column;gap:8px;display:flex}.session-settings .toggle-row{cursor:pointer;justify-content:space-between;align-items:center;padding:6px 0;display:flex}.session-settings .toggle-label{color:#fffc;font-size:12px}.session-settings .toggle{cursor:pointer;display:inline-flex;position:relative}.session-settings .toggle input{opacity:0;width:0;height:0}.session-settings .toggle-slider{background:#fff3;border-radius:11px;width:40px;height:22px;transition:background .2s}.session-settings .toggle-slider:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:3px;left:3px}.session-settings .toggle input:checked+.toggle-slider{background:var(--accent-primary)}.session-settings .toggle input:checked+.toggle-slider:after{transform:translate(18px)}.session-settings .setting-row{justify-content:space-between;align-items:center;padding:6px 0;display:flex}.session-settings .setting-row .toggle-label{color:#fffc;font-size:12px}.session-settings .setting-row input[type=number]{color:#fff;text-align:center;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;width:56px;padding:6px 8px;font-size:12px}.session-settings .setting-row input[type=number]:focus{border-color:var(--accent-primary);outline:none}.session-settings .storage-info{color:#fff6;border-top:1px solid #ffffff0d;padding-top:8px;font-size:10px}.modal-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.import-modal{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#000000e6;border:1px solid #ffffff1a;border-radius:12px;width:400px;max-width:90vw}.modal-header{border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.modal-header h3{color:#fff;margin:0;font-size:14px;font-weight:600}.modal-content{padding:16px}.modal-content p{color:#ffffffb3;margin:0 0 16px;font-size:13px}.modal-content .file-input{color:#ffffffb3;cursor:pointer;background:#ffffff0d;border:2px dashed #fff3;border-radius:8px;width:100%;padding:12px;font-size:13px;transition:all .2s}.modal-content .file-input:hover{border-color:var(--accent-primary);background:#8b5cf61a}.modal-content .file-input::file-selector-button{background:var(--accent-primary);color:#fff;cursor:pointer;border:none;border-radius:4px;margin-right:12px;padding:6px 12px}.filters-strip .preset-btn.add-new{background:#ffffff0d;border:2px dashed #fff3}.filters-strip .preset-btn.add-new:hover{background:#ffffff1a;border-color:#fff6}.gallery-panel{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:100;background:#141419f2;border:1px solid #ffffff1a;border-radius:16px;flex-direction:column;display:flex;position:absolute;inset:60px 20px 20px 60px;overflow:hidden}.gallery-header{border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.gallery-header h3{color:#ffffffe6;margin:0;font-size:16px;font-weight:600}.gallery-grid{flex:1;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));align-content:start;gap:16px;padding:20px;display:grid;overflow-y:auto}.gallery-empty{color:#fff6;flex-direction:column;grid-column:1/-1;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.gallery-empty .hint{opacity:.6;font-size:13px}.gallery-item{aspect-ratio:1;cursor:pointer;background:#ffffff0d;border:2px solid #0000;border-radius:12px;transition:all .2s;position:relative;overflow:hidden}.gallery-item:hover{border-color:var(--accent-primary);transform:scale(1.02)}.gallery-item img{object-fit:cover;width:100%;height:100%}.gallery-item-overlay{opacity:0;background:linear-gradient(#0000,#000c);justify-content:space-between;align-items:center;padding:8px;transition:opacity .2s;display:flex;position:absolute;bottom:0;left:0;right:0}.gallery-item:hover .gallery-item-overlay{opacity:1}.gallery-item-name{color:#ffffffe6;white-space:nowrap;text-overflow:ellipsis;max-width:120px;font-size:12px;overflow:hidden}.gallery-delete-btn{cursor:pointer;color:#fff;background:#ff3232cc;border:none;border-radius:6px;justify-content:center;align-items:center;padding:6px;transition:background .2s;display:flex}.gallery-delete-btn:hover{background:#ff3232}.filter-preview{border-radius:8px;overflow:hidden}.filter-thumbnail{object-fit:cover;width:100%;height:100%;transition:filter .2s}.no-saved-filters{color:#fff6;text-align:center;padding:20px;font-size:13px}.video-editor{color:#eee;background:#1a1a2e;flex-direction:column;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex}.ve-header{background:#16213e;border-bottom:1px solid #2a2a4a;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.ve-header-left{align-items:center;gap:12px;display:flex}.ve-logo{font-size:24px}.ve-project-name{color:#fff;background:0 0;border:1px solid #0000;border-radius:4px;padding:6px 10px;font-size:16px}.ve-project-name:hover,.ve-project-name:focus{background:#1a1a2e;border-color:#4a90d9}.ve-header-center{gap:8px;display:flex}.ve-header-right{gap:10px;display:flex}.ve-btn-icon{color:#fff;cursor:pointer;background:#2a2a4a;border:none;border-radius:6px;width:36px;height:36px;font-size:16px}.ve-btn-icon:hover{background:#3a3a5a}.ve-btn-icon:disabled{opacity:.4;cursor:not-allowed}.ve-btn-action{color:#fff;cursor:pointer;background:#4a90d9;border:none;border-radius:6px;width:100%;margin-bottom:10px;padding:10px 16px;font-size:14px}.ve-btn-action:hover{background:#5a9fe9}.ve-btn-secondary{color:#fff;cursor:pointer;background:#2a2a4a;border:none;border-radius:6px;padding:8px 16px;font-size:14px}.ve-btn-secondary:hover{background:#3a3a5a}.ve-btn-primary{color:#fff;cursor:pointer;background:#4a90d9;border:none;border-radius:6px;padding:8px 20px;font-size:14px;font-weight:500}.ve-btn-primary:hover{background:#5a9fe9}.ve-btn-danger{color:#fff;cursor:pointer;background:#d94a4a;border:none;border-radius:6px;width:100%;margin-top:12px;padding:8px 16px;font-size:14px}.ve-btn-danger:hover{background:#e95a5a}.ve-main{flex:1;grid-template-columns:250px 1fr 280px;display:grid;overflow:hidden auto}.ve-sidebar{background:#16213e;border-right:1px solid #2a2a4a;flex-direction:column;display:flex}.ve-tabs{border-bottom:1px solid #2a2a4a;flex-wrap:wrap;display:flex}.ve-tab{color:#888;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;min-width:50px;padding:12px 8px;font-size:12px}.ve-tab:hover{color:#ccc}.ve-tab.active{color:#4a90d9;border-bottom-color:#4a90d9}.ve-tab-content{flex:1;padding:12px;overflow-y:auto}.ve-media-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.ve-media-item{aspect-ratio:16/9;cursor:pointer;color:#888;background:#2a2a4a;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;font-size:12px;transition:all .2s;display:flex}.ve-media-item:hover{color:#fff;background:#3a3a5a}.ve-media-item.selected{border:2px solid #4a90d9}.ve-audio-item{cursor:pointer;background:#2a2a4a;border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:8px;padding:10px 12px;font-size:12px;display:flex}.ve-audio-item:hover{background:#3a3a5a}.ve-audio-item.selected{border:2px solid #4a90d9}.ve-audio-duration{color:#888;font-size:11px}.ve-thumbnail{border-radius:4px;width:100%;height:60%;margin-bottom:4px}.ve-media-item span{text-align:center;font-size:10px}.ve-text-templates{flex-direction:column;gap:8px;display:flex}.ve-text-template{color:#fff;cursor:pointer;text-align:left;background:#2a2a4a;border:none;border-radius:6px;padding:12px}.ve-text-template:hover{background:#3a3a5a}.ve-empty-message{color:#666;text-align:center;padding:20px;font-size:13px}.ve-transitions-grid,.ve-filters-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.ve-transition-item,.ve-filter-item{color:#fff;cursor:pointer;background:#2a2a4a;border:none;border-radius:6px;padding:10px;font-size:12px}.ve-transition-item:hover,.ve-filter-item:hover{background:#3a3a5a}.ve-filter-item.active{background:#4a90d9}.ve-canvas-area{background:#0f0f1e;flex-direction:column;display:flex}.ve-canvas-container{flex:1;justify-content:center;align-items:center;padding:20px;display:flex}.ve-canvas-container.drag-over,.ve-canvas.drag-over{outline-offset:-10px;background:#4a90d933;outline:2px dashed #4a90d9}.ve-canvas{background:#000;border-radius:8px;justify-content:center;align-items:center;max-width:100%;max-height:100%;display:flex;position:relative;overflow:hidden}.ve-video-element{object-fit:contain;width:100%;height:100%}.ve-canvas-placeholder{color:#666;flex-direction:column;justify-content:center;align-items:center;font-size:14px;display:flex}.ve-clip-preview{color:#fff;justify-content:center;align-items:center;width:100%;height:100%;font-size:18px;font-weight:500;display:flex}.ve-text-overlay{text-shadow:2px 2px 4px #000c;cursor:pointer;position:absolute}.ve-text-overlay.selected{outline:2px dashed #4a90d9}.ve-text-input{color:#fff;font-size:inherit;font-weight:inherit;text-align:center;background:#000000b3;border:2px solid #4a90d9;border-radius:4px;min-width:100px;padding:4px 8px}.ve-playback-controls{background:#16213e;border-top:1px solid #2a2a4a;align-items:center;gap:16px;padding:12px 20px;display:flex}.ve-play-btn{color:#fff;cursor:pointer;background:#4a90d9;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;display:flex}.ve-play-btn:hover{background:#5a9fe9}.ve-time-display{color:#888;min-width:100px;font-family:monospace;font-size:14px}.ve-progress-bar{-webkit-appearance:none;cursor:pointer;background:#2a2a4a;border-radius:3px;flex:1;height:6px}.ve-progress-bar::-webkit-slider-thumb{-webkit-appearance:none;cursor:pointer;background:#4a90d9;border-radius:50%;width:14px;height:14px}.ve-volume-control{align-items:center;gap:8px;display:flex}.ve-volume-control input{-webkit-appearance:none;background:#2a2a4a;border-radius:2px;width:80px;height:4px}.ve-volume-control input::-webkit-slider-thumb{-webkit-appearance:none;background:#4a90d9;border-radius:50%;width:12px;height:12px}.ve-properties{background:#16213e;border-left:1px solid #2a2a4a;flex-direction:column;display:flex}.ve-panel-tabs{border-bottom:1px solid #2a2a4a;display:flex}.ve-panel-tab{color:#888;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:12px;font-size:12px}.ve-panel-tab:hover{color:#ccc}.ve-panel-tab.active{color:#4a90d9;border-bottom-color:#4a90d9}.ve-panel-content{flex:1;padding:16px;overflow-y:auto}.ve-panel-section h4{color:#ccc;margin:0 0 16px;font-size:14px;font-weight:500}.ve-control-group{margin-bottom:16px}.ve-control-group label{color:#888;margin-bottom:6px;font-size:12px;display:block}.ve-control-group select,.ve-control-group input[type=range]{width:100%}.ve-control-group select{color:#fff;background:#2a2a4a;border:none;border-radius:4px;padding:8px;font-size:13px}.ve-control-group input[type=range]{-webkit-appearance:none;background:#2a2a4a;border-radius:2px;height:4px}.ve-control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:#4a90d9;border-radius:50%;width:14px;height:14px}.ve-timeline{background:#16213e;border-top:1px solid #2a2a4a;flex-direction:column;flex:1;height:auto;min-height:180px;display:flex}.ve-timeline-controls{border-bottom:1px solid #2a2a4a;align-items:center;gap:16px;padding:8px 16px;display:flex}.ve-timeline-btn{color:#fff;cursor:pointer;background:#2a2a4a;border:none;border-radius:4px;padding:6px 12px;font-size:12px}.ve-timeline-btn:hover{background:#3a3a5a}.ve-timeline-btn.active{background:#22c55e}.ve-zoom-control{color:#888;align-items:center;gap:8px;margin-left:auto;font-size:12px;display:flex}.ve-zoom-control input{width:80px}.ve-timeline-content{cursor:pointer;flex:1;position:relative;overflow:auto}.ve-time-ruler{background:#1a1a2e;border-bottom:1px solid #2a2a4a;height:24px;position:relative}.ve-time-marker{color:#666;font-size:10px;position:absolute;top:4px}.ve-tracks{padding:8px 0}.ve-track-actions{flex-wrap:wrap;gap:8px;margin-bottom:8px;padding:8px 12px;display:flex}.ve-add-track-btn{color:#aaa;cursor:pointer;background:#2a2a4a;border:1px solid #4a4a6a;border-radius:4px;padding:4px 10px;font-size:11px;transition:all .2s}.ve-add-track-btn:hover{color:#fff;background:#3a3a5a}.ve-track{align-items:center;height:40px;min-height:40px;margin-bottom:4px;display:flex}.ve-track-label{color:#666;background:#1a1a2e;border-radius:4px;justify-content:center;align-items:center;gap:4px;width:50px;margin-right:4px;font-size:11px;display:flex}.ve-track-delete{color:#fff;cursor:pointer;background:#d94a4a;border:none;border-radius:50%;width:16px;height:16px;padding:0;font-size:12px;line-height:1;display:none}.ve-track:hover .ve-track-delete{justify-content:center;align-items:center;display:flex}.ve-track-clips{flex:1;position:relative}.ve-clip{cursor:pointer;border:2px solid #0000;border-radius:4px;align-items:center;height:calc(100% - 4px);padding:0 8px;transition:border-color .2s;display:flex;position:absolute}.ve-clip:hover{border-color:#ffffff4d}.ve-clip.selected{border-color:#4a90d9}.ve-clip-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.ve-clip-delete{color:#fff;cursor:pointer;background:#ff0000b3;border:none;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:14px;line-height:1;display:none;position:absolute;top:2px;right:2px}.ve-clip:hover .ve-clip-delete{display:flex}.ve-text-clip{background:#8b5cf6!important}.ve-audio-clip{background:linear-gradient(#22c55e 0%,#16a34a 100%)!important}.ve-trim-handle{cursor:ew-resize;opacity:0;background:#ffffff4d;width:8px;transition:opacity .2s;position:absolute;top:0;bottom:0}.ve-clip:hover .ve-trim-handle{opacity:1}.ve-trim-handle:hover{background:#ffffff80}.ve-trim-start{border-radius:4px 0 0 4px;left:0}.ve-trim-end{border-radius:0 4px 4px 0;right:0}.ve-clip-delete{color:#fff;cursor:pointer;opacity:0;background:#00000080;border:none;border-radius:50%;width:20px;height:20px;font-size:14px;line-height:1;transition:opacity .2s;position:absolute;top:50%;right:4px;transform:translateY(-50%)}.ve-clip:hover .ve-clip-delete{opacity:1}.ve-playhead{z-index:10;pointer-events:none;background:#ff4757;width:2px;position:absolute;top:0;bottom:0}.ve-playhead:before{content:"";border:6px solid #0000;border-top-color:#ff4757;position:absolute;top:0;left:-5px}.ve-export-modal{z-index:100;background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.ve-export-content{background:#16213e;border-radius:12px;width:400px;max-width:90%;padding:24px}.ve-export-content h3{margin:0 0 20px;font-size:18px}.ve-export-platforms{margin:20px 0}.ve-export-platforms h4{color:#888;margin:0 0 12px;font-size:14px}.ve-platform-btns{gap:8px;display:flex}.ve-platform-btn{color:#fff;cursor:pointer;background:#2a2a4a;border:none;border-radius:6px;flex:1;padding:10px;font-size:12px}.ve-platform-btn:hover{background:#3a3a5a}.ve-export-actions{justify-content:flex-end;gap:12px;margin-top:20px;display:flex}@media (width<=1024px){.ve-main{grid-template-columns:200px 1fr}.ve-properties{z-index:50;width:280px;transition:right .3s;position:fixed;top:0;bottom:0;right:-280px;box-shadow:-4px 0 20px #00000080}.ve-properties.open{right:0}.ve-properties-toggle{display:flex!important}}@media (width<=768px){.ve-header{flex-wrap:wrap;gap:8px;padding:10px 12px}.ve-header-left{flex:1;order:1}.ve-header-center{order:3;justify-content:center;gap:8px;width:100%}.ve-header-right{flex:1;order:2;justify-content:flex-end}.ve-project-name{max-width:100px;font-size:14px}.ve-btn-secondary,.ve-btn-primary{padding:6px 10px;font-size:12px}.ve-logo{display:none}.ve-main{grid-template-columns:1fr;height:calc(100vh - 120px)}.ve-sidebar{z-index:100;width:280px;transition:left .3s;position:fixed;top:0;bottom:0;left:-280px;box-shadow:4px 0 20px #00000080}.ve-sidebar.open{left:0}.ve-sidebar .ve-tabs{flex-wrap:nowrap;overflow-x:auto}.ve-sidebar .ve-tab{flex-shrink:0;min-width:56px;padding:10px 6px;font-size:11px}.ve-canvas-area{order:1}.ve-canvas-container{flex:1;min-height:200px;padding:8px}.ve-canvas{max-height:100%}.ve-playback-controls{flex-wrap:wrap;justify-content:center;gap:8px;padding:8px 12px}.ve-play-btn{width:40px;height:40px}.ve-time-display{min-width:80px;font-size:12px}.ve-progress-bar{flex:1;min-width:100px}.ve-volume-control{display:none}.ve-properties{width:100%;max-width:320px}.ve-timeline{order:2;height:120px}.ve-timeline-controls{gap:8px;padding:6px 10px}.ve-timeline-btn{padding:4px 8px;font-size:11px}.ve-zoom-control{display:none}.ve-mobile-toggle{color:#fff;cursor:pointer;background:#2a2a4a;border:none;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex!important}.ve-mobile-toggle:hover{background:#3a3a5a}.ve-panel-tabs{flex-wrap:wrap}.ve-panel-tab{min-width:50%;padding:10px;font-size:12px}.ve-panel-content{padding:12px}.ve-control-group{margin-bottom:12px}.ve-export-content{width:95%;padding:16px}.ve-export-platforms{display:none}}.ve-mobile-toggle{display:none}.ve-properties-toggle{margin-right:8px}.ve-context-menu{z-index:1000;background:#252542;border:1px solid #3a3a5a;border-radius:8px;min-width:140px;padding:6px 0;position:fixed;box-shadow:0 4px 20px #0006}.ve-context-menu button{color:#eee;text-align:left;cursor:pointer;background:0 0;border:none;width:100%;padding:10px 16px;font-size:14px;display:block}.ve-context-menu button:hover{background:#3a3a5a}.app{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;padding-top:80px}.page-container{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.page-header{margin-bottom:2rem}.page-title{margin-bottom:.5rem;font-size:2rem;font-weight:700}.page-subtitle{color:var(--text-secondary);font-size:1.1rem}.btn{border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--border-color)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{opacity:.9}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--bg-secondary);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;transition:all .3s}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.input{border:1px solid var(--border-color);background:var(--bg-secondary);width:100%;color:var(--text-primary);border-radius:8px;padding:.75rem 1rem;transition:all .2s}.input:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 3px #4f46e51a}.input::placeholder{color:var(--text-secondary)}.textarea{border:1px solid var(--border-color);background:var(--bg-secondary);width:100%;color:var(--text-primary);resize:vertical;border-radius:8px;min-height:100px;padding:.75rem 1rem;font-family:inherit}.textarea:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 3px #4f46e51a}.select{border:1px solid var(--border-color);background:var(--bg-secondary);width:100%;color:var(--text-primary);cursor:pointer;border-radius:8px;padding:.75rem 1rem}.select:focus{border-color:var(--accent-primary);outline:none}.label{color:var(--text-primary);margin-bottom:.5rem;font-weight:500;display:block}.form-group{margin-bottom:1.25rem}.badge{background:var(--accent-primary);color:#fff;border-radius:9999px;padding:.25rem .75rem;font-size:.75rem;font-weight:500;display:inline-block}.grid{gap:1.5rem;display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (width<=1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}.empty-state{text-align:center;color:var(--text-secondary);padding:3rem 1rem}.empty-state svg{opacity:.5;width:64px;height:64px;margin-bottom:1rem}:root{--bg-primary:#fafafa;--bg-secondary:#fff;--text-primary:#1a1a2e;--text-secondary:#64748b;--accent-primary:#4f46e5;--accent-hover:#4338ca;--border-color:#e2e8f0;--success:#10b981;--warning:#f59e0b;--error:#ef4444;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--header-bg:#fffc;--animations-enabled:1}:root [data-animations=false]{--animations-enabled:0}[data-theme=dark]{--bg-primary:#0f172a;--bg-secondary:#1e293b;--text-primary:#f8fafc;--text-secondary:#94a3b8;--accent-primary:#818cf8;--accent-hover:#6366f1;--border-color:#334155;--success:#34d399;--warning:#fbbf24;--error:#fb7185;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px -1px #0006;--shadow-lg:0 10px 15px -3px #00000080;--header-bg:#0f172acc}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;transition:background-color .3s,color .3s}a{color:var(--accent-primary);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-hover)}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:1rem}h1{font-size:3rem;font-weight:700;line-height:1.2}h2{font-size:2.25rem;font-weight:600;line-height:1.3}h3{font-size:1.5rem;font-weight:600;line-height:1.4}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}@media (width<=640px){h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.25rem}.container{padding:0 1rem}}[data-animations=false] *,[data-animations=false] :before,[data-animations=false] :after{transition:none!important;animation:none!important}
