.tool-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.tool-header-title{flex:1;min-width:0;display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.tool-header-icon{width:32px;height:32px;flex-shrink:0}.tool-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.tool-action-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:24px;color:var(--color-text-muted);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition);white-space:nowrap}.tool-action-btn:hover{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow)}.tool-action-btn svg{flex-shrink:0;transition:all var(--transition)}.tool-action-btn--fav:hover svg{color:#ea4335;stroke:#ea4335}.tool-action-btn--fav.active{background:#fce8e6;border-color:#ea4335;color:#ea4335}.tool-action-btn--fav.active svg{fill:#ea4335;stroke:#ea4335}[data-theme=dark] .tool-action-btn--fav.active{background:rgba(234,67,53,.15)}@media (max-width:600px){.tool-header-top{flex-wrap:wrap}.tool-actions{width:100%}.tool-action-btn span{display:none}.tool-action-btn{padding:8px;border-radius:50%}}.breadcrumbs{font-size:.85rem;color:var(--color-text-muted);margin-bottom:1.5rem;display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.breadcrumbs a{color:var(--color-text-muted);text-decoration:none}.breadcrumbs a:hover{color:var(--color-primary)}.breadcrumbs .sep{opacity:.4}.tool-header{margin-bottom:1.5rem}.tool-header h1{font-size:2.2rem;font-weight:700;margin-bottom:.35rem;letter-spacing:-.02em}.tool-tagline{color:var(--color-text-muted);font-size:1.05rem}.tool-workspace{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.75rem;margin-bottom:2rem;box-shadow:var(--shadow)}.tool-input,.tool-output{width:100%;padding:.85rem 1rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.9rem;color:var(--color-text);resize:vertical;outline:0;transition:border-color var(--transition),box-shadow var(--transition)}.tool-input:focus,.tool-output:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(82,128,155,.12)}[data-theme=dark] .tool-input:focus,[data-theme=dark] .tool-output:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(122,163,190,.15)}.tool-actions{display:flex;gap:.5rem;margin:1rem 0;flex-wrap:wrap}.tool-split{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.tool-label{display:block;font-size:.82rem;font-weight:600;margin-bottom:.45rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.75rem;margin-top:1rem}.stat-card{text-align:center;padding:1.1rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);transition:all var(--transition);box-shadow:none}.stat-card:hover{box-shadow:var(--shadow);border-color:var(--color-primary)}.stat-card span{display:block;font-size:1.75rem;font-weight:700;color:var(--color-primary)}.stat-card label{font-size:.78rem;color:var(--color-text-muted);margin-top:.2rem;display:block;text-transform:uppercase;letter-spacing:.03em}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem 1.4rem;border:1px solid var(--color-border);border-radius:24px;font-size:.88rem;font-weight:500;background:var(--color-bg);color:var(--color-text);transition:all var(--transition);text-decoration:none;white-space:nowrap}.btn:hover{border-color:var(--color-primary);color:var(--color-primary);text-decoration:none;box-shadow:var(--shadow)}.btn-primary{background:var(--color-primary);color:#fff;border-color:transparent;box-shadow:0 2px 8px rgba(82,128,155,.3)}.btn-primary:hover{background:var(--color-primary-hover);color:#fff;border-color:transparent;box-shadow:0 4px 12px rgba(82,128,155,.4)}.btn-gradient{background:var(--color-primary);color:#fff;border:none}.btn-gradient:hover{background:var(--color-primary-hover);color:#fff}.btn-sm{padding:.35rem .85rem;font-size:.8rem;border-radius:16px}.btn-success{background:var(--color-success);color:#fff;border-color:var(--color-success)}.btn-danger,.btn-error{background:var(--color-error);color:#fff;border-color:var(--color-error)}.btn-danger:hover,.btn-error:hover{background:#dc2626;border-color:#dc2626;color:#fff}.btn-success:hover{background:#059669;border-color:#059669;color:#fff}.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.97)}.tool-share{display:flex;align-items:center;gap:.5rem;padding:1rem 0;font-size:.9rem;color:var(--color-text-muted);border-top:1px solid var(--color-border);margin-bottom:2rem}.tool-section{margin-bottom:2.5rem}.tool-section h2{font-size:1.35rem;font-weight:600;margin-bottom:1rem;letter-spacing:-.01em}.related-tools-section{margin-top:3rem;margin-bottom:2.5rem;padding-top:2rem;border-top:1px solid var(--color-border)}.related-tools-header{margin-bottom:1.5rem}.related-tools-header h2{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.25rem}.related-tools-subtitle{font-size:.88rem;color:var(--color-text-muted);margin:0}.related-tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:.75rem}.related-tool-card{display:flex;align-items:center;gap:.85rem;padding:.9rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);text-decoration:none;color:var(--color-text);transition:.25s cubic-bezier(.4, 0, .2, 1);box-shadow:0 1px 2px rgba(0,0,0,.04)}.related-tool-card:hover{border-color:var(--color-primary);box-shadow:0 4px 16px rgba(82,128,155,.1),0 1px 4px rgba(0,0,0,.04);transform:translateY(-2px);text-decoration:none}[data-theme=dark] .related-tool-card{box-shadow:0 1px 3px rgba(0,0,0,.2)}[data-theme=dark] .related-tool-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.3),0 0 12px rgba(122,163,190,.05)}.related-tool-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);border-radius:var(--radius-sm);flex-shrink:0;transition:.25s cubic-bezier(.4, 0, .2, 1);overflow:hidden}.related-tool-icon img{width:100%;height:100%;object-fit:contain}[data-theme=dark] .related-tool-icon{background:rgba(122,163,190,.08)}.related-tool-card:hover .related-tool-icon{transform:scale(1.08);background:var(--color-primary);filter:saturate(1.2)}[data-theme=dark] .related-tool-card:hover .related-tool-icon{background:rgba(122,163,190,.15)}.related-tool-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.related-tool-name{font-weight:600;font-size:.88rem;letter-spacing:-.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s}.related-tool-card:hover .related-tool-name{color:var(--color-primary)}.related-tool-tagline{font-size:.78rem;color:var(--color-text-muted);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.related-tool-arrow{flex-shrink:0;color:var(--color-text-muted);opacity:0;transform:translateX(-4px);transition:.25s cubic-bezier(.4, 0, .2, 1);display:flex;align-items:center}.related-tool-card:hover .related-tool-arrow{opacity:.7;transform:translateX(0);color:var(--color-primary)}.how-to-list{list-style:none;padding-left:0;counter-reset:howto}.how-to-list li{padding:.65rem 0 .65rem 2.5rem;position:relative;color:var(--color-text-muted);counter-increment:howto}.how-to-list li::before{content:counter(howto);position:absolute;left:0;top:.55rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);color:var(--color-primary);border-radius:50%;font-size:.8rem;font-weight:700}.faq-list{display:flex;flex-direction:column;gap:.6rem}.faq-item{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;transition:all var(--transition)}.faq-item:hover,[data-theme=dark] .faq-item:hover{box-shadow:var(--shadow)}.faq-item summary{padding:1.1rem 1.35rem;font-weight:500;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;transition:background var(--transition)}.faq-item summary:hover{background:var(--color-primary-light)}.faq-item summary::after{content:"+";font-size:1.3rem;color:var(--color-primary);font-weight:300}.faq-item[open] summary::after{content:"\2212"}.faq-item[open] summary{background:var(--color-primary-light)}.faq-item p{padding:0 1.35rem 1.1rem;color:var(--color-text-muted);line-height:1.7}.color-preview{width:100%;height:80px;border-radius:var(--radius-sm);border:1px solid var(--color-border);cursor:pointer;position:relative;box-shadow:var(--shadow)}.color-preview input[type=color]{opacity:0;position:absolute;inset:0;width:100%;height:100%;cursor:pointer}.match-highlight{background:#fef08a;color:#1e293b;border-radius:3px;padding:1px 3px}[data-theme=dark] .match-highlight{background:#854d0e;color:#fef9c3}.diff-added{background:#e6f4ea;color:#137333}.diff-removed{background:#fce8e6;color:#c5221f}[data-theme=dark] .diff-added{background:rgba(129,201,149,.12);color:#81c995}[data-theme=dark] .diff-removed{background:rgba(242,139,130,.12);color:#f28b82}.diff-output{font-family:var(--font-mono);font-size:.85rem;white-space:pre-wrap}.diff-line{padding:2px 8px;display:block}.strength-bar{height:8px;border-radius:4px;background:var(--color-border);overflow:hidden;margin:.5rem 0}.strength-fill{height:100%;border-radius:4px;transition:width .3s,background .3s}.pwd-output-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem 1.5rem;margin-bottom:1.25rem;box-shadow:var(--shadow)}.pwd-output-row{display:flex;align-items:center;gap:1rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:1rem 1.25rem;min-height:3.5rem;transition:border-color var(--transition)}.pwd-output-row:hover{border-color:var(--color-border-focus)}.pwd-text{flex:1;font-family:var(--font-mono);font-size:1.2rem;font-weight:600;letter-spacing:.05em;word-break:break-all;line-height:1.55;color:var(--color-text);user-select:all}.pwd-output-actions{display:flex;gap:.4rem;flex-shrink:0}.pwd-output-actions .btn-icon{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--color-border);border-radius:var(--radius-xs);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition)}.pwd-output-actions .btn-icon:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:var(--shadow)}.pwd-meter{margin-top:1rem}.pwd-meter-track{height:6px;border-radius:3px;background:var(--color-border);overflow:hidden}.pwd-meter-fill{height:100%;border-radius:3px;transition:width .4s,background .4s}.pwd-meter-info{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem;font-size:.82rem}.pwd-meter-label{font-weight:600}.pwd-meter-time{color:var(--color-text-muted)}.pwd-body{display:flex;flex-direction:column;gap:1.25rem}.pwd-settings-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow)}.pwd-length-group{margin-bottom:1.25rem}.pwd-length-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.pwd-length-badge{display:inline-flex;align-items:center;justify-content:center;min-width:2.75rem;padding:.2rem .65rem;background:var(--color-primary);color:#fff;border-radius:24px;font-size:.85rem;font-weight:700;font-family:var(--font-mono)}.pwd-range-labels{display:flex;justify-content:space-between;font-size:.72rem;color:var(--color-text-light);margin-top:.3rem}.pwd-chartype-group{margin-bottom:1rem}.pwd-chartype-group>.tool-label{margin-bottom:.6rem}.pwd-chartype-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.pwd-chip{display:flex;align-items:center;gap:.6rem;padding:.6rem .85rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;font-size:.85rem;color:var(--color-text-muted);transition:all var(--transition);user-select:none}.pwd-chip input[type=checkbox]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.pwd-chip span{font-family:var(--font-mono);font-weight:700;font-size:.82rem;color:var(--color-text-light);min-width:2rem;transition:color var(--transition)}.pwd-chip:has(:checked){border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}.pwd-chip:has(:checked) span{color:var(--color-primary)}.pwd-chip:hover{border-color:var(--color-primary)}.pwd-toggle-row{display:flex;align-items:center;gap:.6rem;padding:.6rem .75rem;border-radius:var(--radius-sm);cursor:pointer;margin-bottom:1rem;transition:background var(--transition);font-size:.88rem;color:var(--color-text)}.pwd-toggle-row:hover{background:var(--color-bg-alt)}.pwd-toggle-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.pwd-toggle-text{user-select:none}.pwd-toggle-text small{color:var(--color-text-muted)}.pwd-extra-row{display:flex;gap:.75rem;margin-bottom:1rem}.pwd-extra-field{flex:1}.pwd-extra-field--sm{flex:0 0 100px}.pwd-extra-field .tool-label{margin-bottom:.35rem}.pwd-generate-btn{width:100%}.pwd-results-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow)}.pwd-results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.85rem}.pwd-results-header h3{font-size:.95rem;font-weight:600;color:var(--color-text);margin:0}.pwd-results-list{display:flex;flex-direction:column;gap:.4rem;max-height:480px;overflow-y:auto}.pwd-result-row{display:flex;align-items:center;gap:.65rem;padding:.55rem .75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-xs);transition:border-color var(--transition)}.pwd-result-row:hover{border-color:var(--color-border-focus)}.pwd-result-num{font-size:.72rem;font-weight:600;color:var(--color-text-light);min-width:1.75rem;text-align:center}.pwd-result-value{flex:1;font-family:var(--font-mono);font-size:.82rem;word-break:break-all;line-height:1.45;color:var(--color-text)}.pwd-result-copy{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--color-border);border-radius:var(--radius-xs);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition);flex-shrink:0}.pwd-result-copy:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pwd-ch-upper{color:var(--color-secondary)}.pwd-ch-lower{color:var(--color-text)}.pwd-ch-num{color:#e37400}.pwd-ch-sym{color:#c5221f}[data-theme=dark] .pwd-ch-upper{color:#8ab4f8}[data-theme=dark] .pwd-ch-num{color:#fdd663}[data-theme=dark] .pwd-ch-sym{color:#f28b82}.option-group{display:flex;flex-wrap:wrap;gap:.75rem;margin:.75rem 0}.option-group label{display:flex;align-items:center;gap:.4rem;font-size:.9rem;cursor:pointer;color:var(--color-text-muted);padding:.35rem .6rem;border-radius:24px;transition:all var(--transition)}.option-group label:hover{background:var(--color-primary-light);color:var(--color-primary)}.option-group input[type=checkbox],.option-group input[type=radio]{accent-color:var(--color-primary)}.input-group{display:flex;align-items:center;gap:.5rem;margin:.75rem 0}.input-group label{font-size:.9rem;font-weight:500;white-space:nowrap}.input-group input[type=number],.input-group input[type=text],.input-group select{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);outline:0;transition:border-color var(--transition),box-shadow var(--transition)}.input-group input:focus,.input-group select:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 2px rgba(26,115,232,.12)}.input-row{display:flex;gap:1rem;flex-wrap:wrap;margin:.75rem 0}.input-field{flex:1;min-width:150px}.input-field label{display:block;font-size:.8rem;font-weight:600;color:var(--color-text-muted);margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.03em}.input-field input,.input-field select,.input-field textarea{width:100%;padding:.6rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);outline:0;font-size:.9rem;transition:border-color var(--transition),box-shadow var(--transition)}.input-field input:focus,.input-field select:focus,.input-field textarea:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 2px rgba(26,115,232,.12)}.code-output{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:1rem;font-family:var(--font-mono);font-size:.85rem;overflow-x:auto;white-space:pre-wrap;word-break:break-word;position:relative;min-height:3.5rem}.copy-btn{position:absolute;top:.5rem;right:.5rem;padding:.35rem .7rem;font-size:.75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:16px;cursor:pointer;color:var(--color-text-muted);transition:all var(--transition)}.copy-btn:hover{border-color:var(--color-primary);color:var(--color-primary);box-shadow:var(--shadow)}.file-drop{border:2px dashed var(--color-border);border-radius:var(--radius);padding:2.5rem;text-align:center;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition);background:var(--color-bg)}.file-drop.dragover,.file-drop:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.size-info{display:flex;gap:1.5rem;margin:.75rem 0;flex-wrap:wrap;font-size:.85rem;color:var(--color-text-muted)}.size-info strong{color:var(--color-text)}.qr-layout{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}.qr-controls{display:flex;flex-direction:column}.qr-preview-col{display:flex;flex-direction:column;gap:1rem;position:sticky;top:calc(var(--header-h) + 1rem)}.qr-canvas-wrap{display:flex;justify-content:center;padding:1.5rem;background:#fff;border-radius:var(--radius);border:1px solid var(--color-border);box-shadow:var(--shadow)}.qr-canvas-wrap canvas{max-width:100%;height:auto}.qr-theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.5rem}.qr-theme-card{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.5rem .3rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;transition:all var(--transition);text-align:center}.qr-theme-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow)}.qr-theme-card.selected{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:var(--shadow-glow)}.qr-theme-swatch{width:36px;height:36px;border-radius:8px;border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;overflow:hidden}.qr-theme-swatch-inner{width:16px;height:16px;border-radius:3px}.qr-theme-label{font-size:.72rem;font-weight:600;color:var(--color-text)}.qr-options-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.qr-color-pick{display:flex;gap:.4rem;align-items:center}.qr-color-input{width:36px;height:36px;padding:0;border:1px solid var(--color-border);border-radius:var(--radius-xs);cursor:pointer;background:0 0}.qr-color-input::-webkit-color-swatch-wrapper{padding:2px}.qr-color-input::-webkit-color-swatch{border-radius:4px;border:none}@media (max-width:700px){.qr-layout{grid-template-columns:1fr}.qr-preview-col{position:static}.qr-options-grid{grid-template-columns:1fr 1fr}}.preview-pane{padding:1.25rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);overflow:auto;min-height:200px;line-height:1.7;box-shadow:var(--shadow)}.preview-pane h1,.preview-pane h2,.preview-pane h3{margin:1em 0 .5em}.preview-pane p{margin:.5em 0}.preview-pane code{background:var(--color-surface);padding:.15em .4em;border-radius:4px;font-size:.9em}.preview-pane pre{background:var(--color-surface);padding:1em;border-radius:var(--radius-sm);overflow-x:auto}.preview-pane pre code{background:0 0;padding:0}.preview-pane blockquote{border-left:3px solid var(--color-primary);padding-left:1em;color:var(--color-text-muted)}.preview-pane table{border-collapse:collapse;width:100%;margin:1em 0}.preview-pane td,.preview-pane th{border:1px solid var(--color-border);padding:.5em .75em;text-align:left}.preview-pane th{background:var(--color-surface);font-weight:600}.preview-pane ol,.preview-pane ul{padding-left:1.5em;margin:.5em 0}.preview-pane li{list-style:initial}.preview-pane ol li{list-style:decimal}.error-msg{color:var(--color-error);font-size:.85rem;margin-top:.5rem;font-family:var(--font-mono)}.success-msg{color:var(--color-success);font-size:.85rem;margin-top:.5rem}.image-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem;margin:1rem 0}.image-canvas-wrap{display:flex;justify-content:center;align-items:center;padding:1rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);min-height:200px;position:relative;overflow:hidden;box-shadow:var(--shadow)}.image-canvas-wrap canvas{max-width:100%;height:auto}.checkerboard{background-image:linear-gradient(45deg,#ccc 25%,transparent 25%),linear-gradient(-45deg,#ccc 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#ccc 75%),linear-gradient(-45deg,transparent 75%,#ccc 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0}[data-theme=dark] .checkerboard{background-image:linear-gradient(45deg,#333 25%,transparent 25%),linear-gradient(-45deg,#333 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#333 75%),linear-gradient(-45deg,transparent 75%,#333 75%)}.strength-meter{width:100%;height:8px;background:var(--color-border);border-radius:4px;overflow:hidden;margin:.75rem 0}.strength-meter-fill{height:100%;border-radius:4px;transition:width .4s,background .4s}.strength-meter-fill.weak{background:#ea4335}.strength-meter-fill.fair{background:#fbbc04}.strength-meter-fill.good{background:var(--color-secondary)}.strength-meter-fill.strong{background:#34a853}.security-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .75rem;border-radius:24px;font-size:.8rem;font-weight:500}.security-badge.pass{background:#e6f4ea;color:#137333}.security-badge.warn{background:#fef7e0;color:#e37400}.security-badge.fail{background:#fce8e6;color:#c5221f}[data-theme=dark] .security-badge.pass{background:rgba(129,201,149,.12);color:#81c995}[data-theme=dark] .security-badge.warn{background:rgba(253,214,99,.12);color:#fdd663}[data-theme=dark] .security-badge.fail{background:rgba(242,139,130,.12);color:#f28b82}.directive-row{display:flex;align-items:center;gap:.75rem;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-bottom:.5rem;background:var(--color-bg)}.directive-row label{min-width:140px;font-weight:500;font-size:.9rem}.directive-row input[type=text]{flex:1;padding:.4rem .6rem;border:1px solid var(--color-border);border-radius:var(--radius-xs);background:var(--color-bg);color:var(--color-text)}.toggle-switch{position:relative;width:44px;height:24px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-switch .slider{position:absolute;inset:0;background:var(--color-border);border-radius:12px;transition:background var(--transition);cursor:pointer}.toggle-switch .slider::before{content:'';position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform var(--transition);box-shadow:0 1px 3px rgba(0,0,0,.2)}.toggle-switch input:checked+.slider{background:var(--color-primary)}.toggle-switch input:checked+.slider::before{transform:translateX(20px)}.key-output{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:1rem;font-family:var(--font-mono);font-size:.8rem;line-height:1.5;word-break:break-all;white-space:pre-wrap;max-height:300px;overflow-y:auto}input[type=range]{-webkit-appearance:none;width:100%;height:6px;background:var(--color-border);border-radius:3px;outline:0;transition:background var(--transition)}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 3px rgba(0,0,0,.3)}input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 3px rgba(0,0,0,.3)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin:1rem 0}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-size:.8rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.65rem .85rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);outline:0;font-size:.9rem;transition:border-color var(--transition),box-shadow var(--transition)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 2px rgba(26,115,232,.12)}.result-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.75rem;margin:1rem 0;text-align:center;position:relative;box-shadow:var(--shadow)}.result-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-primary);border-radius:var(--radius) var(--radius) 0 0}.result-card .result-value{font-size:2.5rem;font-weight:700;color:var(--color-primary);line-height:1.2;margin-bottom:.25rem}.result-card .result-label{font-size:.85rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.data-table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.88rem}.data-table th{text-align:left;padding:.75rem 1rem;background:var(--color-surface);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border)}.data-table td{padding:.65rem 1rem;border-bottom:1px solid var(--color-border);color:var(--color-text)}.data-table tr:hover td{background:var(--color-surface)}.data-table tbody tr:last-child td{border-bottom:none}.data-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;margin:1rem 0;box-shadow:var(--shadow)}.tab-bar{display:flex;gap:0;border-bottom:2px solid var(--color-border);margin-bottom:1.25rem;overflow-x:auto}.tab-btn{padding:.65rem 1.25rem;background:0 0;border:none;font-size:.88rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition);white-space:nowrap}.tab-btn:hover{color:var(--color-primary)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.tab-content{display:none}.tab-content.active{display:block}.gauge-container{display:flex;align-items:center;gap:1rem;margin:1rem 0}.gauge-bar{flex:1;height:12px;background:var(--color-border);border-radius:6px;overflow:hidden;position:relative}.gauge-fill{height:100%;border-radius:6px;transition:width .5s,background .3s}.gauge-label{font-size:.85rem;font-weight:700;min-width:45px;text-align:right;color:var(--color-text)}.chip{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .75rem;border-radius:24px;font-size:.8rem;font-weight:500;background:var(--color-surface);color:var(--color-text-muted);border:none}.chip--primary{background:var(--color-primary-light);color:var(--color-primary)}.chip--success{background:#e6f4ea;color:#137333}.chip--warning{background:#fef7e0;color:#e37400}.chip--error{background:#fce8e6;color:#c5221f}[data-theme=dark] .chip--success{background:rgba(129,201,149,.12);color:#81c995}[data-theme=dark] .chip--warning{background:rgba(253,214,99,.12);color:#fdd663}[data-theme=dark] .chip--error{background:rgba(242,139,130,.12);color:#f28b82}.calc-display{width:100%;padding:1.25rem 1rem;text-align:right;font-family:var(--font-mono);font-size:2rem;font-weight:700;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);margin-bottom:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.calc-btn{padding:.85rem;border:none;border-radius:var(--radius-sm);font-size:1.05rem;font-weight:500;background:var(--color-surface);color:var(--color-text);cursor:pointer;transition:all var(--transition)}.calc-btn:hover{background:var(--color-surface-2);box-shadow:var(--shadow)}.calc-btn:active{transform:scale(.96)}.calc-btn--op{background:var(--color-primary-light);color:var(--color-primary)}.calc-btn--op:hover{background:var(--color-primary);color:#fff}.calc-btn--eq{background:var(--color-primary);color:#fff;grid-column:span 2}.calc-btn--eq:hover{background:var(--color-primary-hover)}.calc-btn--wide{grid-column:span 2}.calc-btn--fn{font-size:.85rem;background:var(--color-surface);color:var(--color-text-muted)}.calc-btn--fn:hover{color:var(--color-primary)}.timer-display{text-align:center;padding:2rem;font-family:var(--font-mono);font-size:3.5rem;font-weight:700;color:var(--color-text);letter-spacing:.05em;background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border);margin-bottom:1rem;box-shadow:var(--shadow)}.timer-controls{display:flex;justify-content:center;gap:.75rem;margin:1rem 0}.circular-progress{width:220px;height:220px;margin:1rem auto;position:relative}.circular-progress svg{transform:rotate(-90deg)}.circular-progress .progress-text{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:var(--font-mono)}.circular-progress .progress-time{font-size:2.5rem;font-weight:700;line-height:1}.circular-progress .progress-label{font-size:.85rem;color:var(--color-text-muted);margin-top:.25rem}.lap-list{max-height:300px;overflow-y:auto;margin:1rem 0;border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow)}.lap-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem 1rem;border-bottom:1px solid var(--color-border);font-size:.88rem;font-family:var(--font-mono)}.lap-item:last-child{border-bottom:none}.lap-item:hover{background:var(--color-surface)}.lap-number{font-weight:700;color:var(--color-text-muted)}.color-swatch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem;margin:1rem 0}.color-swatch{aspect-ratio:1;border-radius:var(--radius);border:1px solid var(--color-border);cursor:pointer;transition:all var(--transition);position:relative;box-shadow:var(--shadow)}.color-swatch:hover{transform:scale(1.05);box-shadow:var(--shadow-md)}.color-swatch-label{position:absolute;bottom:0;left:0;right:0;padding:.2rem;text-align:center;font-size:.65rem;font-family:var(--font-mono);background:rgba(0,0,0,.6);color:#fff;border-radius:0 0 calc(var(--radius) - 1px) calc(var(--radius) - 1px)}.live-preview{border:1px solid var(--color-border);border-radius:var(--radius);padding:2rem;min-height:150px;display:flex;align-items:center;justify-content:center;background:var(--color-bg);margin:1rem 0;transition:all var(--transition);box-shadow:var(--shadow)}.live-preview-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);margin-bottom:.5rem}.slider-group{display:flex;flex-direction:column;gap:.25rem;margin:.75rem 0}.slider-header{display:flex;justify-content:space-between;align-items:center}.slider-label{font-size:.8rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.slider-value{font-family:var(--font-mono);font-size:.85rem;font-weight:600;color:var(--color-primary);min-width:50px;text-align:right}.emoji-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(42px,1fr));gap:2px;max-height:400px;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius);padding:.5rem}.emoji-cell{display:flex;align-items:center;justify-content:center;font-size:1.5rem;padding:.4rem;border-radius:50%;cursor:pointer;transition:all var(--transition)}.emoji-cell:hover{background:var(--color-primary-light);transform:scale(1.15)}.typing-text{font-size:1.15rem;line-height:1.8;padding:1.25rem;background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border);margin-bottom:1rem;font-family:var(--font-mono)}.typing-text .correct{color:var(--color-success)}.typing-text .incorrect{color:var(--color-error);background:rgba(234,67,53,.1);border-radius:2px}.typing-text .current{border-bottom:2px solid var(--color-primary)}.typing-text .pending{color:var(--color-text-muted)}.invoice-preview{background:#fff;color:#202124;padding:2.5rem;border:1px solid var(--color-border);border-radius:var(--radius);max-width:800px;margin:1rem auto;box-shadow:var(--shadow)}@media print{.back-to-top,.breadcrumbs,.no-print,.site-footer,.site-header,.toast,.tool-actions,.tool-header,.tool-section,.tool-share{display:none!important}.tool-workspace{border:none;box-shadow:none;padding:0;background:0 0}.invoice-preview{border:none;box-shadow:none}}.morse-ref{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.35rem;margin:1rem 0}.morse-ref-item{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;font-size:.8rem;background:var(--color-surface);border-radius:var(--radius-xs);border:none}.morse-ref-char{font-weight:700;min-width:16px;text-align:center}.morse-ref-code{font-family:var(--font-mono);color:var(--color-text-muted);font-size:.75rem}.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin:1rem 0}.case-btn{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.75rem .5rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:.8rem;font-weight:500;transition:all var(--transition)}.case-btn:hover{border-color:var(--color-primary);background:var(--color-bg);box-shadow:var(--shadow)}.case-btn:active{transform:scale(.97)}.case-icon{font-family:var(--font-mono);font-size:.95rem;font-weight:700;color:var(--color-primary);line-height:1}.case-result{overflow:hidden;word-break:break-word;font-size:1rem;min-height:4rem;padding:1.2rem 1rem;line-height:1.6}@media (max-width:480px){.case-grid{grid-template-columns:repeat(2,1fr)}}.heatmap-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin:1rem 0}.heatmap-cell{aspect-ratio:1;border-radius:3px;cursor:pointer;transition:all var(--transition);border:1px solid transparent;min-width:14px}.heatmap-cell:hover{border-color:var(--color-primary);transform:scale(1.2)}.heatmap-cell.level-0{background:var(--color-surface)}.heatmap-cell.level-1{background:#a8dab5}.heatmap-cell.level-2{background:#34a853}.heatmap-cell.level-3{background:#1e8e3e}.heatmap-cell.level-4{background:#137333}[data-theme=dark] .heatmap-cell.level-0{background:var(--color-surface)}[data-theme=dark] .heatmap-cell.level-1{background:#0d652d}[data-theme=dark] .heatmap-cell.level-2{background:#137333}[data-theme=dark] .heatmap-cell.level-3{background:#1e8e3e}[data-theme=dark] .heatmap-cell.level-4{background:#34a853}.wheel-container{display:flex;flex-direction:column;align-items:center;margin:1.5rem 0;position:relative}.wheel-pointer{width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-top:20px solid var(--color-primary);z-index:2;margin-bottom:-4px}.movie-card{display:flex;gap:1rem;padding:1rem;border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:.75rem;transition:all var(--transition);background:var(--color-bg)}.movie-card:hover{box-shadow:var(--shadow-md)}.movie-poster{width:60px;height:85px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:#fff;flex-shrink:0}.movie-info{flex:1;min-width:0}.movie-title{font-weight:600;font-size:1rem;margin-bottom:.15rem}.movie-year{font-size:.82rem;color:var(--color-text-muted)}.movie-desc{font-size:.84rem;color:var(--color-text-muted);margin-top:.35rem;line-height:1.5}.match-badge{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:24px;font-size:.75rem;font-weight:600;background:var(--color-primary-light);color:var(--color-primary)}.activity-card{text-align:center;padding:2rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);margin:1rem 0;transition:.4s;box-shadow:var(--shadow)}.activity-card .activity-icon{font-size:3rem;margin-bottom:1rem}.activity-card .activity-name{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.activity-card .activity-desc{color:var(--color-text-muted);line-height:1.7;max-width:500px;margin:0 auto}.activity-meta{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap;margin-top:1rem}.sleep-timeline{display:flex;height:40px;border-radius:var(--radius);overflow:hidden;margin:1rem 0;border:1px solid var(--color-border)}.sleep-cycle{flex:1;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#fff;transition:all var(--transition)}.sleep-cycle:nth-child(odd){background:var(--color-secondary)}.sleep-cycle:nth-child(2n){background:#4285f4}.mood-calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin:1rem 0}.mood-day{aspect-ratio:1;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;cursor:pointer;border:1px solid var(--color-border);transition:all var(--transition);background:var(--color-bg)}.mood-day:hover{border-color:var(--color-primary);transform:scale(1.05);box-shadow:var(--shadow)}.mood-day.empty{background:0 0;border-color:transparent;cursor:default;box-shadow:none}.mood-day.today{border-color:var(--color-primary);box-shadow:var(--shadow-glow)}.mood-great{background:#e6f4ea!important}.mood-good{background:#e8f0fe!important}.mood-okay{background:#fef7e0!important}.mood-bad,.mood-terrible{background:#fce8e6!important}[data-theme=dark] .mood-great{background:rgba(129,201,149,.15)!important}[data-theme=dark] .mood-good{background:rgba(138,180,248,.15)!important}[data-theme=dark] .mood-okay{background:rgba(253,214,99,.12)!important}[data-theme=dark] .mood-bad,[data-theme=dark] .mood-terrible{background:rgba(242,139,130,.15)!important}.planner-timeline{position:relative;margin:1rem 0;border-left:3px solid var(--color-border);padding-left:1.5rem}.time-block{position:relative;padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:.5rem;cursor:pointer;transition:all var(--transition);background:var(--color-bg)}.time-block:hover{border-color:var(--color-primary);box-shadow:var(--shadow)}.time-block::before{content:'';position:absolute;left:-1.85rem;top:50%;width:10px;height:10px;border-radius:50%;background:var(--color-primary);transform:translateY(-50%)}.time-block-time{font-size:.78rem;font-weight:600;color:var(--color-text-muted)}.time-block-title{font-weight:500}.packing-category{margin-bottom:1.25rem}.packing-category-title{font-weight:600;font-size:.95rem;padding:.5rem 0;border-bottom:1px solid var(--color-border);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.packing-item{display:flex;align-items:center;gap:.5rem;padding:.4rem 0;font-size:.9rem}.packing-item input[type=checkbox]{accent-color:var(--color-primary)}.packing-item.checked{text-decoration:line-through;color:var(--color-text-muted)}.name-card{padding:1rem;border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);background:var(--color-bg)}.name-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary)}.name-card .name-text{font-size:1.15rem;font-weight:600}.name-card .name-meaning{font-size:.82rem;color:var(--color-text-muted);margin-top:.25rem}.name-card .name-origin{font-size:.75rem;margin-top:.35rem}.nav-scroll-indicator{display:flex;gap:.35rem;overflow-x:auto;padding:.5rem 0;scrollbar-width:none;-ms-overflow-style:none}.nav-scroll-indicator::-webkit-scrollbar{display:none}.btn-group{display:inline-flex;border:1px solid var(--color-border);border-radius:24px;overflow:hidden}.btn-group .btn,.btn-group .btn-sm{border-radius:0;border:none;border-right:1px solid var(--color-border)}.btn-group .btn-sm:last-child,.btn-group .btn:last-child{border-right:none}.btn-group .btn-sm.active,.btn-group .btn.active{background:var(--color-primary);color:#fff;font-weight:600}.toggle-group{display:inline-flex;border:1px solid var(--color-border);border-radius:24px;overflow:hidden;background:var(--color-surface)}.toggle-btn{padding:8px 18px;font-size:.85rem;font-weight:500;font-family:inherit;border:none;background:0 0;color:var(--color-text-muted);cursor:pointer;transition:background var(--transition),color var(--transition);position:relative}.toggle-btn:not(:last-child){border-right:1px solid var(--color-border)}.toggle-btn:hover:not(.active){background:var(--color-surface-2);color:var(--color-text)}.toggle-btn.active{background:var(--color-primary);color:#fff;font-weight:600}#tableContainer{scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}#tableContainer::-webkit-scrollbar{width:6px;height:6px}#tableContainer::-webkit-scrollbar-track{background:0 0}#tableContainer::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}#tableContainer::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}#tableContainer::-webkit-scrollbar-corner{background:0 0}.csv-table{width:100%;border-collapse:collapse;font-size:.84rem;table-layout:fixed}.csv-table td,.csv-table th{border:1px solid var(--color-border);padding:0;position:relative}.csv-table thead th{background:var(--color-surface);position:sticky;top:0;z-index:2}.csv-th-inner{display:flex;align-items:center;gap:2px}.csv-col-resize{position:absolute;right:0;top:0;bottom:0;width:5px;cursor:col-resize;z-index:3;user-select:none}.csv-col-resize.active,.csv-col-resize:hover{background:var(--color-primary);opacity:.4}.csv-edit{width:100%;padding:7px 10px;border:none;background:0 0;font:inherit;color:var(--color-text);outline:0;min-width:60px;box-sizing:border-box}.csv-edit:focus{background:var(--color-primary-light);box-shadow:inset 0 0 0 2px var(--color-primary)}.csv-table tbody tr:nth-child(2n) td{background:rgba(0,0,0,.015)}[data-theme=dark] .csv-table tbody tr:nth-child(2n) td{background:rgba(255,255,255,.015)}.csv-edit-header{font-weight:600}.csv-sort{display:flex;align-items:center;justify-content:center;padding:4px;cursor:pointer;color:var(--color-text-muted);flex-shrink:0;user-select:none;opacity:.5;transition:opacity .15s,color .15s,background .15s;border-radius:4px;line-height:1}.csv-sort:hover{opacity:1;color:var(--color-primary);background:var(--color-primary-light)}.csv-sort-active{opacity:1;color:var(--color-primary)}.csv-del-row{background:0 0;border:none;color:var(--color-text-muted);cursor:pointer;font-size:.85rem;padding:2px 4px;border-radius:3px;opacity:0;transition:opacity .1s,color .1s;flex-shrink:0;line-height:1}.csv-row-num:hover .csv-del-row{opacity:.6}.csv-del-row:hover{opacity:1!important;color:var(--color-error)}td.csv-col-selected,th.csv-col-selected{background:rgba(99,102,241,.08)!important}th.csv-col-selected{background:rgba(99,102,241,.15)!important;border-color:var(--color-primary)}td.csv-col-selected{border-left-color:var(--color-primary);border-right-color:var(--color-primary)}tbody tr:last-child td.csv-col-selected{border-bottom-color:var(--color-primary)}[data-theme=dark] td.csv-col-selected,[data-theme=dark] th.csv-col-selected{background:rgba(129,140,248,.12)!important}[data-theme=dark] th.csv-col-selected{background:rgba(129,140,248,.2)!important}#viewSection{position:relative}.csv-col-toolbar{position:absolute;display:flex;align-items:center;gap:2px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;padding:4px;box-shadow:0 4px 16px rgba(0,0,0,.18);z-index:10;transform:translate(-50%,-100%);white-space:nowrap}[data-theme=dark] .csv-col-toolbar{box-shadow:0 4px 16px rgba(0,0,0,.4)}.csv-col-toolbar-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border:none;background:0 0;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:500;color:var(--color-text);transition:background .15s,color .15s}.csv-col-toolbar-btn:hover{background:var(--color-surface)}.csv-col-toolbar-btn.csv-col-delete{color:var(--color-error)}.csv-col-toolbar-btn.csv-col-delete:hover{background:rgba(239,68,68,.1)}.csv-row-num{text-align:center;color:var(--color-text-muted);font-size:.75rem;padding:2px 6px;width:60px;min-width:60px;background:var(--color-surface);white-space:nowrap;user-select:none;overflow:hidden;position:relative}.csv-del-row{position:absolute;right:2px;top:50%;transform:translateY(-50%)}.csv-table tbody tr:hover td{background:var(--color-surface)}.csv-table tbody tr:hover .csv-row-num{background:var(--color-surface-2)}.csv-popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1000;display:flex;align-items:stretch;justify-content:center;padding:1.5vh 1vw;opacity:0;pointer-events:none;transition:opacity .2s}.csv-popup-overlay.open{opacity:1;pointer-events:auto}.csv-popup{width:100%;max-width:1600px;background:var(--color-bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;transform:scale(.97);transition:transform .2s;overflow:hidden}.csv-popup-overlay.open .csv-popup{transform:scale(1)}.csv-popup-header{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1rem;border-bottom:1px solid var(--color-border);background:var(--color-surface);gap:.5rem;flex-shrink:0}.csv-popup-title{display:flex;align-items:center;gap:.75rem;min-width:0}.csv-popup-title h3{margin:0;font-size:.95rem;white-space:nowrap}.csv-popup-stats{font-size:.78rem;color:var(--color-text-muted);white-space:nowrap;background:var(--color-bg);padding:2px 10px;border-radius:24px;border:none}.csv-popup-actions{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.csv-popup-search{padding:.35rem .65rem;border:1px solid var(--color-border);border-radius:24px;background:var(--color-bg);color:var(--color-text);font-size:.82rem;width:200px}.csv-popup-search:focus{outline:0;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(26,115,232,.15)}.csv-popup-search::placeholder{color:var(--color-text-muted)}.csv-popup-sep{width:1px;height:20px;background:var(--color-border);flex-shrink:0}.csv-popup-close{background:0 0;border:none;font-size:1.4rem;cursor:pointer;color:var(--color-text-muted);line-height:1;padding:4px 8px;border-radius:50%;transition:background var(--transition),color var(--transition)}.csv-popup-close:hover{color:var(--color-error);background:rgba(234,67,53,.08)}.csv-popup-body{flex:1;overflow:auto}.csv-popup-body .csv-table{margin:0}.csv-popup-footer{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;border-top:1px solid var(--color-border);background:var(--color-surface);font-size:.78rem;color:var(--color-text-muted);flex-shrink:0;gap:1rem}.csv-popup-footer-hint{opacity:.7}@media (max-width:768px){.csv-popup-overlay{padding:0}.csv-popup{border-radius:0;max-width:100%}.csv-popup-search{width:120px}}.csv-related-tools{display:flex;gap:.75rem;flex-wrap:wrap}.csv-related-link{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border:1px solid var(--color-border);border-radius:24px;background:var(--color-bg);color:var(--color-text);font-size:.85rem;font-weight:500;text-decoration:none;transition:all var(--transition)}.csv-related-link:hover{border-color:var(--color-primary);color:var(--color-primary);text-decoration:none;box-shadow:var(--shadow)}.csv-related-icon{font-size:1.1rem}.inv-tabs{display:flex;gap:0;border-bottom:1px solid var(--color-border);margin-bottom:1.25rem;background:var(--color-bg);border-radius:0;padding:0}.inv-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:.7rem .5rem .55rem;font-size:.78rem;font-weight:500;font-family:inherit;letter-spacing:.02em;background:0 0;border:none;border-radius:0;color:var(--color-text-muted);cursor:pointer;position:relative;white-space:nowrap;transition:color .2s}.inv-tab::after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:0;height:3px;border-radius:3px 3px 0 0;background:var(--color-primary);transition:width .2s}.inv-tab:hover{color:var(--color-text);background:color-mix(in srgb,var(--color-primary) 5%,transparent)}.inv-tab.active{color:var(--color-primary);font-weight:600;background:0 0;box-shadow:none}.inv-tab.active::after{width:60%}.inv-tab-icon{width:20px;height:20px;flex-shrink:0;opacity:.7;transition:opacity .2s}.inv-tab.active .inv-tab-icon{opacity:1}.inv-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:.85rem 1rem}.inv-card-title{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:.5rem}.inv-profile-cards{display:flex;flex-direction:column;gap:6px;margin-bottom:.75rem}.inv-profile-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;background:var(--color-bg);transition:border-color var(--transition),background var(--transition),box-shadow var(--transition);min-width:0}.inv-profile-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow)}.inv-profile-card--active{border-color:var(--color-primary);background:var(--color-primary-light)}.inv-profile-card--add{border-style:dashed;opacity:.7;justify-content:center}.inv-profile-card--add:hover{opacity:1}.inv-profile-card-logo{width:36px;height:36px;border-radius:10px;object-fit:contain;flex-shrink:0}.inv-profile-card-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0}.inv-profile-card--add .inv-profile-card-avatar{background:var(--color-border);color:var(--color-text-muted);font-size:1.2rem}.inv-profile-card-info{flex:1;min-width:0}.inv-profile-card-name{font-weight:500;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inv-profile-card-detail{font-size:.73rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.inv-profile-card-actions{display:flex;gap:4px;flex-shrink:0;opacity:0;transition:opacity var(--transition)}.inv-profile-card:hover .inv-profile-card-actions{opacity:1}.inv-profile-card-btn{background:0 0;border:1px solid var(--color-border);border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-muted);font-size:.82rem;padding:0;transition:all var(--transition)}.inv-profile-card-btn:hover{background:var(--color-bg);color:var(--color-text);border-color:var(--color-text-muted)}.inv-profile-card-btn--del:hover{color:var(--color-error);border-color:var(--color-error);background:rgba(234,67,53,.06)}.inv-from-cancel-btn{margin-top:.75rem;float:right}.inv-section-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.inv-details-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem}.inv-logo-dropzone{position:relative;width:100%;border:2px dashed var(--color-border);border-radius:var(--radius);background:var(--color-bg);transition:border-color var(--transition),background var(--transition);cursor:pointer}.inv-logo-dropzone.inv-logo-dragover,.inv-logo-dropzone:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.inv-logo-file-input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:1}.inv-logo-drop-content{display:flex;flex-direction:column;align-items:center;gap:4px;padding:1.25rem 1rem;color:var(--color-text-muted);font-size:.82rem;pointer-events:none}.inv-logo-drop-content svg{opacity:.5}.inv-logo-hint{font-size:.7rem;opacity:.6}.inv-logo-preview-wrap{position:relative;display:flex;align-items:center;justify-content:center;padding:.75rem}.inv-logo-preview-wrap img{max-height:64px;max-width:100%;object-fit:contain;border-radius:8px}.inv-logo-remove{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;z-index:2;transition:all var(--transition)}.inv-logo-remove:hover{color:var(--color-error);border-color:var(--color-error)}.inv-customer-select-wrap{position:relative;margin-bottom:.75rem}.inv-customer-select{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);cursor:pointer;font-size:.85rem;transition:border-color var(--transition);min-height:40px}.inv-customer-select:hover{border-color:var(--color-primary)}.inv-customer-select-name{font-weight:500}.inv-customer-select-hint{color:var(--color-text-muted)}.inv-customer-select-chevron{font-size:.65rem;color:var(--color-text-muted);transition:transform var(--transition);flex-shrink:0;margin-left:8px}.inv-customer-select-wrap.open .inv-customer-select-chevron{transform:rotate(180deg)}.inv-customer-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-lg);margin-top:4px;max-height:260px;overflow-y:auto;display:none}.inv-customer-select-wrap.open .inv-customer-dropdown{display:block}.inv-customer-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background var(--transition);border-bottom:1px solid var(--color-border)}.inv-customer-item:last-child{border-bottom:none}.inv-customer-item:hover{background:var(--color-surface)}.inv-customer-item--active{background:var(--color-primary-light)}.inv-customer-item-avatar{width:32px;height:32px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;flex-shrink:0}.inv-customer-item-info{flex:1;min-width:0}.inv-customer-item-name{font-weight:500;font-size:.84rem}.inv-customer-item-detail{font-size:.72rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inv-customer-item-edit{background:0 0;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;border-radius:50%;opacity:0;transition:opacity var(--transition);flex-shrink:0}.inv-customer-item:hover .inv-customer-item-edit{opacity:1}.inv-customer-item-edit:hover{color:var(--color-primary)}.inv-customer-item--add{justify-content:center;color:var(--color-text-muted);font-size:.84rem;font-weight:500;gap:6px}.inv-customer-item--add:hover{color:var(--color-primary)}.inv-customers-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.inv-customer-list{display:flex;flex-direction:column;gap:10px}.inv-customer-list-card{display:flex;align-items:center;gap:12px;padding:1rem 1.25rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition)}.inv-customer-list-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.inv-customer-list-avatar{width:40px;height:40px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}.inv-customer-list-info{flex:1;min-width:0}.inv-customer-list-name{font-weight:500;font-size:.95rem}.inv-customer-list-detail{font-size:.78rem;color:var(--color-text-muted);margin-top:2px}.inv-customer-list-meta{text-align:right;flex-shrink:0}.inv-customer-list-count{font-weight:700;font-size:.95rem}.inv-customer-list-label{font-size:.72rem;color:var(--color-text-muted)}.inv-customer-list-actions{display:flex;gap:4px;flex-shrink:0}.inv-customer-list-delete{background:0 0;border:none;color:var(--color-text-muted);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:all var(--transition);flex-shrink:0;margin-left:4px}.inv-customer-list-card:hover .inv-customer-list-delete{opacity:1}.inv-customer-list-delete:hover{color:var(--color-error);background:rgba(234,67,53,.08)}.inv-customer-view-back{display:inline-flex;align-items:center;gap:4px;font-size:.84rem;color:var(--color-text-muted);cursor:pointer;margin-bottom:1rem;background:0 0;border:none;padding:4px 0}.inv-customer-view-back:hover{color:var(--color-primary)}.inv-customer-view-header{display:flex;align-items:center;gap:12px;margin-bottom:1.25rem}.inv-customer-view-avatar{width:48px;height:48px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;flex-shrink:0}.inv-customer-view-name{font-weight:600;font-size:1.1rem}.inv-customer-view-detail{font-size:.82rem;color:var(--color-text-muted);margin-top:2px}.inv-customer-view-actions{margin-left:auto;display:flex;gap:6px}.inv-field{margin-bottom:.35rem}.inv-field label{display:block;font-size:.72rem;font-weight:600;margin-bottom:2px;color:var(--color-text-muted)}.inv-details-grid .tool-input,.inv-field .tool-input{padding:.45rem .65rem;font-size:.82rem}.inv-field textarea.tool-input{padding:.4rem .65rem;min-height:unset}.inv-items-wrap{overflow-x:auto}.inv-items-table{width:100%;border-collapse:collapse}.inv-items-table th{text-align:left;padding:8px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border)}.inv-items-table td{padding:4px;border-bottom:1px solid var(--color-border)}.inv-items-table .tool-input{padding:6px 8px;font-size:.84rem}.inv-del-row{background:0 0;border:none;color:var(--color-text-muted);font-size:1.1rem;cursor:pointer;padding:4px 8px;border-radius:50%;transition:all var(--transition);line-height:1}.inv-del-row:hover{color:var(--color-error);background:rgba(234,67,53,.08)}.inv-totals{margin-top:1rem;display:flex;flex-direction:column;align-items:flex-end;gap:4px}.inv-totals-row{display:flex;justify-content:space-between;width:220px;font-size:.88rem}.inv-totals-row span{color:var(--color-text-muted)}.inv-totals-total{margin-top:4px;padding-top:8px;border-top:2px solid var(--color-border);font-size:1.1rem}.inv-totals-total span{color:var(--color-text)}.inv-totals-total strong{color:var(--color-primary)}.inv-action-bar{display:flex;align-items:center;gap:6px;margin-bottom:.75rem;flex-shrink:0}.inv-act-spacer{flex:1}.inv-act-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border:1px solid var(--color-border);border-radius:24px;font-size:.78rem;font-weight:500;background:var(--color-bg);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition);white-space:nowrap;line-height:1}.inv-act-btn svg{flex-shrink:0;opacity:.7}.inv-act-btn:hover{border-color:var(--color-primary);color:var(--color-primary);box-shadow:var(--shadow)}.inv-act-btn:hover svg{opacity:1}.inv-act-btn:active{transform:scale(.97)}.inv-act-btn--primary{background:var(--color-primary);color:#fff;border-color:transparent;box-shadow:0 1px 2px rgba(26,115,232,.3)}.inv-act-btn--primary svg{opacity:1}.inv-act-btn--primary:hover{background:var(--color-primary-hover);color:#fff;border-color:transparent;box-shadow:0 2px 6px rgba(26,115,232,.4)}.inv-modal--wide{max-width:680px}.inv-tpl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.inv-tpl-card{position:relative;border:1px solid var(--color-border);border-radius:var(--radius);padding:0;cursor:pointer;background:#fff;overflow:hidden;transition:all var(--transition)}.inv-tpl-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.inv-tpl-card.active{border-color:var(--color-primary);box-shadow:var(--shadow-glow)}.inv-tpl-card.active::after{content:'\2713';position:absolute;top:6px;right:6px;width:20px;height:20px;background:var(--color-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.inv-tpl-thumb{width:100%;aspect-ratio:3/4;padding:10px;display:flex;flex-direction:column;font-size:5px;line-height:1.4;color:#5f6368;overflow:hidden;pointer-events:none}.inv-tpl-name{text-align:center;font-size:.75rem;font-weight:500;padding:6px 4px 8px;color:var(--color-text);border-top:1px solid var(--color-border);background:var(--color-bg-alt)}@media (max-width:560px){.inv-tpl-grid{grid-template-columns:repeat(2,1fr)}.inv-modal--wide{max-width:400px}}@media (max-width:380px){.inv-act-btn span{display:none}.inv-act-btn{padding:7px 9px}}.inv-fullpage{display:flex;flex-direction:column;height:100%}.inv-fullpage .inv-tabs{flex-shrink:0;padding:.25rem 0 0;border-bottom:1px solid var(--color-border);border-radius:0;background:0 0;margin-bottom:0}.inv-fullpage .inv-panel{flex:1;overflow-y:auto;padding:1rem;display:none}.inv-fullpage .inv-panel:has(.inv-view-page){overflow-y:visible;overflow:visible}.inv-fullpage .inv-panel.active{display:flex;flex-direction:column}.inv-fullpage .inv-editor-split.active{flex-direction:row;display:flex}.inv-editor-split{gap:0;flex:1;overflow:hidden}.inv-editor-split.active{display:flex!important}.inv-editor-form{flex:1;min-width:0;overflow-y:auto;padding:1rem 1.25rem;border-right:1px solid var(--color-border);scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.inv-editor-form::-webkit-scrollbar{width:6px}.inv-editor-form::-webkit-scrollbar-track{background:0 0}.inv-editor-form::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.inv-editor-form::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.inv-editor-preview{width:50%;min-width:380px;overflow-y:auto;background:var(--color-surface);padding:1rem;display:flex;flex-direction:column}.inv-preview{background:#fff;color:#333;padding:2rem;border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);flex:1;min-height:0}.inv-fullpage #panelCustomers,.inv-fullpage #panelSaved,.inv-fullpage #panelStats{padding:1.5rem 2rem;max-width:1400px;margin-left:auto;margin-right:auto;width:100%;box-sizing:border-box}.inv-fullpage #panelSaved{display:none;flex-direction:column}.inv-fullpage #panelSaved.active{display:flex}#savedInvoicesList{flex:1;display:flex;flex-direction:column}@media (max-width:900px){.inv-editor-split{flex-direction:column}.inv-editor-form{border-right:none;border-bottom:1px solid var(--color-border);overflow-y:auto}.inv-editor-preview{width:100%;min-width:0}}@media (max-width:480px){.inv-editor-form,.inv-editor-preview{padding:.75rem}.inv-preview{padding:1.25rem}}.inv-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.45);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}.inv-modal{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;width:100%;max-width:500px;box-shadow:var(--shadow-lg)}.inv-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.inv-modal-title{font-weight:600;font-size:1rem}.inv-modal-close{background:0 0;border:none;font-size:1.4rem;cursor:pointer;color:var(--color-text-muted);padding:4px 8px;border-radius:50%;line-height:1}.inv-modal-close:hover{color:var(--color-text);background:var(--color-surface)}.inv-modal textarea{width:100%;resize:vertical;min-height:120px}.inv-modal-footer{display:flex;justify-content:flex-end;margin-top:1rem}.inv-saved-toolbar{display:flex;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap;align-items:center}.inv-saved-toolbar .tool-input{height:40px}.inv-saved-toolbar .tool-input[type=text]{flex:1;min-width:200px;max-width:400px}.inv-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;min-height:0;text-align:center;gap:.5rem}#customersListView{display:flex;flex-direction:column;flex:1;min-height:0}#savedInvoicesList:empty{display:none}.inv-empty-title{font-size:1.05rem;font-weight:600;color:var(--color-text);margin-top:.5rem}.inv-empty-desc{font-size:.85rem;color:var(--color-text-muted);max-width:300px;line-height:1.5}.inv-view-page{display:flex;flex-direction:column}.inv-view-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem;flex-shrink:0}.inv-view-toolbar-right{display:flex;align-items:center;gap:.5rem}.inv-view-preview{border-radius:var(--radius);display:flex;flex-direction:column}.inv-view-preview .inv-preview{border-radius:var(--radius);flex:1}.inv-preview-a4{width:210mm;min-height:297mm;max-width:100%;margin:0 auto;padding:2.5rem;box-sizing:border-box}.inv-saved-list{display:flex;flex-direction:column;gap:10px}.inv-saved-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.1rem 1.25rem;transition:all var(--transition)}.inv-saved-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.inv-saved-top{display:flex;justify-content:space-between;align-items:flex-start}.inv-saved-number{font-weight:600;font-size:.95rem}.inv-saved-client{font-size:.82rem;color:var(--color-text-muted);margin-top:2px}.inv-saved-amount{font-weight:700;font-size:1.05rem}.inv-status{display:inline-block;padding:2px 12px;border-radius:24px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-top:4px}.inv-status-paid{background:rgba(52,168,83,.12);color:var(--color-success)}.inv-status-unpaid{background:rgba(251,188,4,.15);color:#e37400}.inv-saved-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border)}.inv-saved-date{font-size:.78rem;color:var(--color-text-muted)}.inv-saved-actions{display:flex;gap:6px}.inv-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.inv-stat-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem 1.5rem;text-align:center;box-shadow:var(--shadow)}.inv-stat-card--primary{border-color:var(--color-primary);background:var(--color-primary-light)}.inv-stat-card--success{border-color:var(--color-success)}.inv-stat-card--warning{border-color:var(--color-warning)}.inv-stat-value{font-size:1.5rem;font-weight:700}.inv-stat-card--primary .inv-stat-value{color:var(--color-primary)}.inv-stat-card--success .inv-stat-value{color:var(--color-success)}.inv-stat-card--warning .inv-stat-value{color:#e37400}.inv-stat-label{font-size:.75rem;color:var(--color-text-muted);margin-top:4px;font-weight:500}.inv-chart-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;min-width:0}.inv-chart-bar{width:100%;max-width:40px;border-radius:4px 4px 0 0;transition:height .3s}.inv-chart-bar--paid{background:var(--color-success)}.inv-chart-bar--unpaid{background:var(--color-warning)}.inv-chart-label{font-size:.65rem;color:var(--color-text-muted);margin-top:6px;white-space:nowrap}.inv-payment-row{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px solid var(--color-border);font-size:.84rem}.inv-payment-row:last-child{border-bottom:none}@media (max-width:768px){.inv-section-grid{grid-template-columns:1fr}.inv-details-grid,.inv-stats-grid{grid-template-columns:1fr 1fr}}@media (max-width:480px){.inv-details-grid,.inv-stats-grid{grid-template-columns:1fr}}.share-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:none;font-size:.85rem;font-weight:700;cursor:pointer;transition:all var(--transition);color:#fff;font-family:var(--font)}.share-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.share-btn--twitter{background:#1da1f2}.share-btn--facebook{background:#1877f2}.share-btn--linkedin{background:#0a66c2}.share-btn--reddit{background:#ff4500}.share-btn--whatsapp{background:#25d366}.share-btn--copy{background:var(--color-text-muted);font-size:1rem}.ct-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:1rem 0}.ct-display-wrap{position:relative;width:260px;height:260px}.ct-ring{position:absolute;inset:0}.ct-time-display{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.ct-time{font-size:3rem;font-weight:700;font-family:var(--font-mono);color:var(--color-text);letter-spacing:.02em;line-height:1}.ct-label{font-size:.85rem;color:var(--color-text-muted);margin-top:.25rem;font-weight:500}.ct-presets{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:center}.ct-preset{padding:.4rem .9rem;border-radius:24px;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text-muted);font-size:.82rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.ct-preset:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.ct-inputs{display:flex;align-items:center;gap:.5rem}.ct-input-group{display:flex;flex-direction:column;align-items:center;gap:.2rem}.ct-input{width:70px;text-align:center;padding:.5rem;font-size:1.4rem;font-weight:700;font-family:var(--font-mono);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);outline:0;transition:border-color var(--transition),box-shadow var(--transition)}.ct-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(26,115,232,.12)}.ct-input-label{font-size:.7rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase}.ct-colon{font-size:1.5rem;font-weight:700;color:var(--color-text-muted)}.ct-controls{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.ct-btn-main{min-width:120px;font-size:1rem;padding:.7rem 1.5rem}.ct-btn{min-width:100px}.ct-complete .ct-time{color:var(--color-error);animation:.5s ease-in-out 3 ct-pulse}@keyframes ct-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.ms-journey-bar{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:2rem;padding:0 .5rem}.ms-journey-step{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.ms-journey-num{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;border:2px solid var(--color-border);color:var(--color-text-muted);background:var(--color-bg);transition:.35s}.ms-journey-label{font-size:.78rem;font-weight:500;color:var(--color-text-muted);transition:color .3s;white-space:nowrap}.ms-journey-step.active .ms-journey-num{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 0 0 4px rgba(26,115,232,.15)}.ms-journey-step.active .ms-journey-label{color:var(--color-primary);font-weight:600}.ms-journey-step.done .ms-journey-num{background:#34a853;color:#fff;border-color:#34a853}.ms-journey-step.done .ms-journey-label{color:#34a853}.ms-journey-line{width:40px;height:2px;background:var(--color-border);margin:0 .35rem;transition:background .4s;flex-shrink:1}.ms-journey-line.done{background:#34a853}.ms-step{display:none}.ms-step.active{display:block;animation:.4s both msFadeIn}.ms-step.exit{animation:.3s both msFadeOut}.ms-step-header{text-align:center;margin-bottom:1.5rem}.ms-step-title{font-size:1.35rem;font-weight:700;margin-bottom:.25rem}.ms-step-sub{font-size:.9rem;color:var(--color-text-muted)}.ms-pick-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.65rem;margin-bottom:1.5rem}.ms-pick-card{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem .5rem;border-radius:var(--radius);border:1.5px solid var(--color-border);background:var(--color-bg);cursor:pointer;transition:.2s;user-select:none;text-align:center;font-family:inherit}.ms-pick-card:hover{border-color:var(--color-primary);transform:translateY(-3px);box-shadow:var(--shadow-md)}.ms-pick-card.selected{border-color:var(--color-primary);background:var(--color-primary-light);transform:scale(1.04);box-shadow:var(--shadow-glow)}.ms-pick-card.selected::after{content:'\2713';position:absolute;top:6px;right:8px;color:var(--color-primary);font-weight:700;font-size:.75rem}.ms-pick-emoji{font-size:1.8rem;line-height:1;margin-bottom:.3rem}.ms-pick-label{font-size:.8rem;font-weight:500;color:var(--color-text)}.ms-step-nav{display:flex;justify-content:space-between;align-items:center;margin-top:1.75rem;gap:.75rem}.ms-arrow{font-size:.9em}.ms-refine-group{margin-bottom:1.25rem}.ms-refine-label{font-size:.88rem;font-weight:600;margin-bottom:.5rem;color:var(--color-text)}.ms-pill-row{display:flex;flex-wrap:wrap;gap:.4rem}.ms-pill{padding:.4rem .9rem;border-radius:99px;border:1.5px solid var(--color-border);background:var(--color-bg);font-size:.82rem;font-weight:500;cursor:pointer;transition:.2s;color:var(--color-text);font-family:inherit}.ms-pill:hover{border-color:var(--color-primary);color:var(--color-primary)}.ms-pill.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.ms-refine-extras{margin-top:1rem}.ms-checkbox-label{font-size:.85rem;color:var(--color-text-muted);display:flex;align-items:center;gap:.4rem;cursor:pointer}.ms-checkbox-label input{accent-color:var(--color-primary)}.ms-surprise-btn{white-space:nowrap}.ms-results-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;gap:.75rem;flex-wrap:wrap}.ms-results-left{display:flex;align-items:center;gap:.75rem}.ms-results-right{display:flex;align-items:center;gap:.5rem}.ms-results-title{font-size:1.15rem;font-weight:700;margin:0}.ms-results-count{font-size:.82rem;color:var(--color-text-muted)}.ms-wl-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:99px;padding:0 5px;background:var(--color-primary);color:#fff;font-size:.7rem;font-weight:700;margin-left:.25rem}.ms-empty{text-align:center;padding:2rem 1rem;color:var(--color-text-muted);font-size:.9rem}.ms-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.ms-card{display:flex;flex-direction:column;background:var(--color-bg);border:1.5px solid var(--color-border);border-radius:var(--radius);overflow:hidden;transition:.25s;animation:.4s both msFadeIn;animation-delay:calc(var(--i, 0) * .06s)}.ms-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.ms-poster{width:100%;height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden}.ms-poster::after{content:'';position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(to top,rgba(0,0,0,.4),transparent);pointer-events:none;z-index:1}.ms-poster-img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;z-index:0;transition:opacity .3s,transform .4s}.ms-card:hover .ms-poster-img{transform:scale(1.04)}.ms-poster-img.loaded~.ms-poster-letter{display:none}.ms-poster-letter{font-size:4rem;font-weight:900;color:rgba(255,255,255,.85);text-shadow:0 2px 16px rgba(0,0,0,.3);z-index:1}.ms-poster-rating{position:absolute;bottom:10px;right:10px;z-index:2;background:rgba(0,0,0,.7);color:#fbbc04;font-size:.8rem;font-weight:700;padding:3px 10px;border-radius:24px;backdrop-filter:blur(4px)}.ms-poster-year{position:absolute;top:10px;left:10px;z-index:2;background:rgba(0,0,0,.5);color:#fff;font-size:.75rem;font-weight:500;padding:2px 10px;border-radius:24px;backdrop-filter:blur(4px)}.ms-info{padding:1rem 1.25rem 1.25rem;flex:1;display:flex;flex-direction:column}.ms-title{font-size:1.05rem;font-weight:700;margin-bottom:.1rem;line-height:1.3}.ms-director{font-size:.8rem;color:var(--color-text-muted);margin-bottom:.4rem}.ms-stars{color:#fbbc04;font-size:.85rem;margin-bottom:.4rem;letter-spacing:1px}.ms-match{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.78rem;font-weight:500;color:var(--color-text-muted)}.ms-match-track{flex:1;height:6px;background:var(--color-surface-2);border-radius:3px;overflow:hidden}.ms-match-bar{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--color-primary),#8b5cf6);transition:width .6s}.ms-tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.5rem}.ms-tags .chip{font-size:.68rem;padding:2px 8px;cursor:default}.ms-desc{font-size:.85rem;color:var(--color-text-muted);line-height:1.5;margin:0 0 .75rem;flex:1}.ms-actions{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:auto;align-items:center}.ms-trailer-link{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;font-weight:600;color:#ea4335;text-decoration:none;padding:.3rem .7rem;border:1.5px solid #ea4335;border-radius:99px;transition:.2s}.ms-trailer-link:hover{background:#ea4335;color:#fff}.ms-imdb-link{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;font-weight:600;color:#f5c518;text-decoration:none;padding:.3rem .7rem;border:1.5px solid #f5c518;border-radius:99px;transition:.2s}.ms-imdb-link:hover{background:#f5c518;color:#000}.ms-action-btn{font-size:.78rem;font-weight:500;padding:.3rem .6rem;border-radius:99px;border:1.5px solid var(--color-border);background:var(--color-bg);color:var(--color-text-muted);cursor:pointer;transition:.2s;font-family:inherit}.ms-action-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.ms-action-btn.saved{border-color:#f59e0b;color:#f59e0b;background:rgba(245,158,11,.08)}.ms-action-btn.watched{border-color:#34a853;color:#34a853;background:rgba(52,168,83,.08)}@keyframes msFadeIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes msFadeOut{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}@media (max-width:768px){.ms-journey-label{display:none}.ms-journey-line{width:24px}.ms-journey-num{width:28px;height:28px;font-size:.75rem}.ms-pick-grid{grid-template-columns:repeat(auto-fill,minmax(95px,1fr));gap:.5rem}.ms-pick-card{padding:.7rem .3rem}.ms-pick-emoji{font-size:1.4rem}.ms-pick-label{font-size:.72rem}.ms-results-grid{grid-template-columns:1fr}.ms-poster{height:180px}.ms-results-bar{flex-direction:column;align-items:flex-start}.ms-step-title{font-size:1.15rem}}@media (max-width:480px){.ms-pick-grid{grid-template-columns:repeat(3,1fr)}.ms-pill{padding:.35rem .65rem;font-size:.78rem}.ms-poster{height:160px}}.xc-tabs{display:flex;gap:0;margin-bottom:1.25rem;border-bottom:2px solid var(--color-border)}.xc-tab{padding:.6rem 1.25rem;font-weight:500;font-size:.9rem;border:none;background:0 0;color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition)}.xc-tab:hover{color:var(--color-text)}.xc-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.xc-panel{display:none}.xc-panel.active{display:block}.xc-upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;border:2px dashed var(--color-border);border-radius:var(--radius);background:var(--color-bg);cursor:pointer;transition:all var(--transition);text-align:center}.xc-upload-zone.dragover,.xc-upload-zone:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.xc-upload-icon{font-size:2.5rem;margin-bottom:.5rem}.xc-upload-text{font-size:.9rem;color:var(--color-text-muted)}.xc-preview-wrap{max-height:400px;overflow:auto;border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow)}.xc-table{width:100%;border-collapse:collapse;font-size:.82rem}.xc-table th{position:sticky;top:0;background:var(--color-surface);padding:.5rem .65rem;text-align:left;font-weight:600;border-bottom:1px solid var(--color-border);white-space:nowrap}.xc-table td{padding:.4rem .65rem;border-bottom:1px solid var(--color-border);white-space:nowrap;max-width:250px;overflow:hidden;text-overflow:ellipsis}.xc-table tr:hover td{background:var(--color-surface)}.site-main:has(.tool-fullpage){padding:0}.tool-fullpage-breadcrumbs{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;font-size:.78rem;color:var(--color-text-muted);padding:.45rem 1rem;border-bottom:1px solid var(--color-border);background:var(--color-bg-alt)}.tool-fullpage-breadcrumbs a{color:var(--color-text-muted);text-decoration:none}.tool-fullpage-breadcrumbs a:hover{color:var(--color-primary)}.tool-fullpage-breadcrumbs .sep{opacity:.4}.tool-header--fullwidth{background:var(--color-bg);border-bottom:1px solid var(--color-border);padding:.5rem 1.25rem .4rem;margin-bottom:0}.tool-header--fullwidth .tool-tagline{margin:0;font-size:.85rem}.tool-header--fullwidth h1{font-size:1.35rem;margin-bottom:0}.tool-header--fullwidth .tool-header-top{align-items:center}.tool-fullpage{width:100%;max-width:100%;height:calc(100vh - var(--header-h) - 30px);padding:0;overflow:hidden}.tool-header--below{margin-top:2rem;margin-bottom:1rem}@media (max-width:768px){.tool-fullpage{height:calc(100vh - var(--header-h) - 28px)}.tool-header--below{margin-top:1.5rem}.tool-fullpage-breadcrumbs{padding:.4rem .75rem;font-size:.72rem}}.tool-guide-link{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.25rem;margin:1.5rem 0;background:var(--color-primary-light);border:1px solid var(--color-border);border-left:4px solid var(--color-primary);border-radius:var(--radius-sm);font-size:.9rem}.tool-guide-link svg{flex-shrink:0;color:var(--color-primary)}.tool-guide-link a{font-weight:500}.article-page{padding-bottom:3rem}.article-header{text-align:center;padding:2.5rem 0 2rem;max-width:800px;margin:0 auto}.article-category-badge{display:inline-block;padding:4px 14px;border-radius:24px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;background:var(--color-primary-light);color:var(--color-primary);margin-bottom:1rem}.article-header h1{font-size:2.25rem;font-weight:700;line-height:1.2;margin-bottom:1rem}.article-subtitle{font-size:1.1rem;color:var(--color-text-muted);line-height:1.6;margin-bottom:1.5rem}.article-cta-top{display:flex;flex-direction:column;align-items:center;gap:.5rem}.article-cta-top .btn-lg{display:inline-flex;align-items:center;gap:8px;padding:.875rem 2rem;font-size:1rem}.article-cta-note{font-size:.8rem;color:var(--color-text-light)}.article-toc{max-width:800px;margin:0 auto 2.5rem;padding:1.25rem 1.5rem;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius)}.article-toc h2{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:.75rem}.article-toc ul{display:flex;flex-wrap:wrap;gap:.25rem 1.5rem}.article-toc li{list-style:none}.article-toc a{font-size:.875rem;font-weight:500;color:var(--color-primary);padding:2px 0;display:inline-block}.article-toc a:hover{text-decoration:underline}.article-section{max-width:800px;margin:0 auto 2.5rem}.article-section h2{font-size:1.5rem;font-weight:700;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-border)}.article-section p{font-size:1rem;line-height:1.75;color:var(--color-text);margin-bottom:1rem}.article-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-top:1rem}.article-feature{padding:1.25rem;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius)}.article-feature-icon{font-size:1.5rem;display:block;margin-bottom:.5rem}.article-feature h3{font-size:.95rem;font-weight:600;margin-bottom:.375rem}.article-feature p{font-size:.85rem;color:var(--color-text-muted);margin:0;line-height:1.5}.article-steps{list-style:none;counter-reset:steps;margin-top:1rem}.article-steps li{margin-bottom:1rem}.article-step{display:flex;align-items:flex-start;gap:1rem}.article-step-num{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-primary);color:#fff;font-size:.875rem;font-weight:700;border-radius:50%}.article-step p{margin:0;padding-top:6px}.article-cta-inline{text-align:center;margin:1.5rem 0}.article-checklist{list-style:none;margin-top:1rem}.article-checklist li{position:relative;padding:.625rem 0 .625rem 2rem;border-bottom:1px solid var(--color-border);font-size:.95rem;line-height:1.5}.article-checklist li::before{content:'✓';position:absolute;left:0;color:var(--color-accent);font-weight:700;font-size:1.1rem}.article-use-cases{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:1rem}.article-use-case{padding:1.25rem;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius)}.article-use-case h3{font-size:.95rem;font-weight:600;margin-bottom:.375rem;color:var(--color-primary)}.article-use-case p{font-size:.85rem;color:var(--color-text-muted);margin:0;line-height:1.5}.article-bottom-cta{margin-top:3rem}.article-cta-box{text-align:center;padding:2.5rem 2rem;background:var(--color-primary-light);border:1px solid var(--color-border);border-radius:var(--radius)}.article-cta-box h2{border:none;padding:0;margin-bottom:.5rem}.article-cta-box p{color:var(--color-text-muted);margin-bottom:1.5rem}@media (max-width:600px){.article-header h1{font-size:1.5rem}.article-subtitle{font-size:.95rem}.article-section h2{font-size:1.25rem}.article-features-grid,.article-use-cases{grid-template-columns:1fr}.article-toc ul{flex-direction:column;gap:.25rem}}.dm-wrap{max-width:720px;margin:0 auto}.dm-tabs{display:inline-flex;gap:4px;padding:4px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;margin-bottom:2rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;width:100%}.dm-tabs::-webkit-scrollbar{display:none}.dm-tab{display:flex;align-items:center;gap:.4rem;flex:1;padding:.6rem 1rem;font-weight:500;font-size:.85rem;border:none;background:0 0;color:var(--color-text-muted);cursor:pointer;border-radius:10px;transition:.2s;white-space:nowrap;justify-content:center;text-decoration:none;position:relative}.dm-tab:hover{color:var(--color-text);background:var(--color-bg-alt)}.dm-tab.active{color:var(--color-primary);background:var(--color-bg);font-weight:600;box-shadow:0 1px 4px rgba(0,0,0,.08)}.dm-tab-icon{font-size:1rem;line-height:1}.dm-panel{animation:.35s cubic-bezier(.22,1,.36,1) both dmFadeIn}@keyframes dmFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dm-textarea{width:100%;resize:vertical;min-height:130px;font-size:.92rem;line-height:1.7;border-radius:var(--radius);padding:1rem 1.1rem;border:1.5px solid var(--color-border);background:var(--color-surface);transition:border-color .2s,box-shadow .2s}.dm-textarea:focus{border-color:var(--color-primary);outline:0;box-shadow:0 0 0 3px rgba(26,115,232,.1)}.dm-action-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;margin-top:1.1rem;padding:.9rem 1.5rem;font-size:1rem;font-weight:600;border-radius:var(--radius);transition:.2s cubic-bezier(.22,1,.36,1);position:relative;overflow:hidden}.dm-action-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(26,115,232,.25)}.dm-action-btn:active{transform:translateY(0);box-shadow:0 2px 8px rgba(26,115,232,.2)}.dm-btn-icon{font-size:1.15rem;line-height:1}.dm-result-box{margin-top:1.75rem;padding:2rem 1.5rem;text-align:center;background:var(--color-surface);border:1.5px solid var(--color-primary);border-radius:16px;animation:.4s cubic-bezier(.22,1,.36,1) both dmResultPop;position:relative;overflow:hidden}.dm-result-box::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0,rgba(26,115,232,.06) 0,transparent 70%);pointer-events:none}@keyframes dmResultPop{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.dm-result-label{font-size:.8rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.6rem}.dm-result-value{font-size:1.85rem;font-weight:800;color:var(--color-primary);line-height:1.3;word-break:break-word}.dm-wheel-area{display:flex;flex-direction:column;align-items:center;margin-top:1.75rem;position:relative}.dm-wheel-pointer{font-size:1.8rem;color:var(--color-primary);line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.25));z-index:2;margin-bottom:-8px;transition:transform .15s}#wheelCanvas{border-radius:50%;box-shadow:0 8px 32px rgba(0,0,0,.12),0 2px 8px rgba(0,0,0,.08),inset 0 0 0 3px rgba(255,255,255,.1)}.dm-pc-options-grid{display:flex;flex-direction:column;gap:.65rem}.dm-pc-option-row{display:flex;align-items:center;gap:.5rem}.dm-pc-option-row .tool-input{flex:1}.dm-pc-option-row .dm-pc-remove-opt{width:30px;height:30px;border-radius:50%;border:none;background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;font-size:1.1rem;line-height:1;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.2s}.dm-pc-option-row .dm-pc-remove-opt:hover{color:#ef4444;background:rgba(239,68,68,.08)}.dm-pc-add-link{display:inline-flex;align-items:center;gap:.3rem;border:none;background:0 0;color:var(--color-primary);font-size:.85rem;font-weight:600;cursor:pointer;padding:.5rem 0;transition:.2s}.dm-pc-add-link:hover{color:var(--color-primary-hover);gap:.45rem}.dm-pc-card{border:1.5px solid var(--color-border);border-radius:16px;padding:1.35rem;background:var(--color-surface);margin-bottom:1.1rem;transition:border-color .2s,box-shadow .2s}.dm-pc-card:hover{border-color:var(--color-border-focus);box-shadow:0 4px 16px rgba(0,0,0,.05)}.dm-pc-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.1rem;padding-bottom:.7rem;border-bottom:1px solid var(--color-border)}.dm-pc-card-title{font-size:1.05rem;font-weight:700}.dm-pc-card-score{font-size:.82rem;font-weight:700;padding:3px 12px;border-radius:99px}.dm-pc-card-score--pos{background:rgba(34,197,94,.1);color:#16a34a}.dm-pc-card-score--neg{background:rgba(239,68,68,.1);color:#dc2626}.dm-pc-card-score--zero{background:var(--color-bg-alt);color:var(--color-text-muted)}.dm-pc-row{display:grid;grid-template-columns:1fr 1fr;gap:1.35rem}.dm-pc-section{min-width:0}.dm-pc-section-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.55rem;display:flex;align-items:center;gap:.4rem}.dm-pc-section-label--pro{color:#22c55e}.dm-pc-section-label--con{color:#ef4444}.dm-pc-list{min-height:0}.dm-pc-item{display:flex;align-items:center;gap:.45rem;padding:.45rem .6rem;font-size:.85rem;border-radius:8px;margin-bottom:.3rem;transition:.15s}.dm-pc-item:hover{background:var(--color-bg-alt)}.dm-pc-item--pro .dm-pc-item-icon{color:#22c55e}.dm-pc-item--con .dm-pc-item-icon{color:#ef4444}.dm-pc-item-icon{flex-shrink:0;font-size:.8rem;width:18px;text-align:center;font-weight:700}.dm-pc-item-text{flex:1;min-width:0}.dm-pc-item-weight{font-size:.7rem;font-weight:600;color:var(--color-text-muted);flex-shrink:0;background:var(--color-bg-alt);padding:1px 6px;border-radius:4px}.dm-pc-item-del{width:22px;height:22px;border-radius:6px;border:none;background:0 0;color:var(--color-text-muted);cursor:pointer;font-size:.85rem;line-height:1;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0;transition:.15s}.dm-pc-item:hover .dm-pc-item-del{opacity:1}.dm-pc-item-del:hover{color:#ef4444;background:rgba(239,68,68,.08)}.dm-pc-empty{font-size:.82rem;color:var(--color-text-muted);padding:.85rem 0;font-style:italic}.dm-pc-add-row{display:flex;gap:.45rem;margin-top:.6rem;align-items:center}.dm-pc-add-row input{flex:1;font-size:.85rem;padding:.45rem .7rem;min-width:0}.dm-pc-add-row button{flex-shrink:0}.dm-pc-weight-wrap{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.dm-pc-weight-wrap input[type=range]{width:60px;height:4px;accent-color:var(--color-primary);cursor:pointer;border-radius:2px}.dm-pc-weight-val{font-size:.72rem;font-weight:700;color:var(--color-text-muted);width:16px;text-align:center;background:var(--color-bg-alt);padding:1px 0;border-radius:4px}.dm-pc-hint{font-size:.82rem;color:var(--color-text-muted);margin-bottom:1.35rem;line-height:1.55;padding:.75rem 1rem;background:var(--color-surface);border-radius:var(--radius-sm);border-left:3px solid var(--color-primary)}.dm-pc-result{margin-top:1.75rem;animation:.4s cubic-bezier(.22,1,.36,1) both dmResultPop}.dm-pc-result-title{font-size:1.1rem;font-weight:700;margin-bottom:.85rem}.dm-pc-result-card{padding:1.1rem 1.35rem;margin-bottom:.7rem;border:1.5px solid var(--color-border);border-radius:14px;background:var(--color-surface);transition:.2s}.dm-pc-result-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.05)}.dm-pc-result-card--winner{border-color:var(--color-primary);border-width:2px;background:var(--color-surface);position:relative;overflow:hidden}.dm-pc-result-card--winner::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0,rgba(26,115,232,.06) 0,transparent 70%);pointer-events:none}.dm-pc-result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.45rem}.dm-pc-result-name{font-size:1rem;font-weight:700}.dm-pc-result-score{font-size:1.15rem;font-weight:800}.dm-pc-result-score--pos{color:#22c55e}.dm-pc-result-score--neg{color:#ef4444}.dm-pc-result-meta{display:flex;gap:1rem;font-size:.82rem;color:var(--color-text-muted);margin-bottom:.5rem}.dm-pc-result-bar{height:8px;border-radius:99px;overflow:hidden;background:var(--color-bg-alt)}.dm-pc-result-bar-fill{height:100%;border-radius:99px;transition:width .6s cubic-bezier(.22,1,.36,1)}.dm-coin-stage{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem 0}.dm-coin-perspective{perspective:800px;width:160px;height:160px}.dm-coin{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform 1s cubic-bezier(.22,1,.36,1);cursor:pointer}.dm-coin:hover{filter:brightness(1.08)}.dm-coin-face{position:absolute;inset:0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.8rem;font-weight:900;backface-visibility:hidden;box-shadow:0 6px 24px rgba(0,0,0,.18),0 2px 6px rgba(0,0,0,.1),inset 0 2px 4px rgba(255,255,255,.3),inset 0 -3px 6px rgba(0,0,0,.15)}.dm-coin-heads{background:linear-gradient(145deg,#fde68a 0,#fbbf24 30%,#f59e0b 60%,#d97706 100%);color:#78350f;text-shadow:0 1px 2px rgba(120,53,15,.2)}.dm-coin-tails{background:linear-gradient(145deg,#e2e8f0 0,#b0bec5 30%,#94a3b8 60%,#64748b 100%);color:#1e293b;transform:rotateY(180deg);text-shadow:0 1px 2px rgba(30,41,59,.2)}.dm-coin-result{font-size:1.6rem;font-weight:800;animation:.35s cubic-bezier(.22,1,.36,1) both dmResultPop;letter-spacing:-.01em}.dm-coin-history{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;max-width:380px}.dm-coin-chip{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;font-size:.72rem;font-weight:800;transition:.2s;border:1.5px solid transparent}.dm-coin-chip:last-child{animation:.3s cubic-bezier(.22,1,.36,1) both dmResultPop}.dm-coin-chip--h{background:#fef3c7;color:#92400e;border-color:#fde68a}.dm-coin-chip--t{background:#e2e8f0;color:#475569;border-color:#cbd5e1}.dm-coin-stats{font-size:.85rem;color:var(--color-text-muted);font-weight:600;text-align:center;padding:.5rem 1.25rem;background:var(--color-surface);border-radius:99px;border:1px solid var(--color-border)}.dm-history-section{margin-top:2.5rem;padding-top:1.5rem;border-top:1.5px solid var(--color-border)}.dm-history-item{display:flex;justify-content:space-between;align-items:center;padding:.7rem .75rem;border-radius:8px;margin-bottom:2px;font-size:.88rem;transition:background .15s}.dm-history-item:hover{background:var(--color-surface)}.dm-history-result{font-weight:600}.dm-history-type{font-size:.72rem;font-weight:600;color:var(--color-text-muted);margin-left:.5rem;background:var(--color-bg-alt);padding:2px 8px;border-radius:4px}.dm-history-time{font-size:.78rem;color:var(--color-text-muted);flex-shrink:0}.dm-clear-history{margin-top:.75rem}@media (max-width:640px){.dm-tabs{gap:2px;padding:3px;border-radius:12px}.dm-tab{padding:.5rem .6rem;font-size:.78rem;gap:.3rem;border-radius:9px}.dm-tab-icon{font-size:.9rem}.dm-result-value{font-size:1.4rem}.dm-coin-perspective{width:130px;height:130px}.dm-coin-face{font-size:2.2rem}#wheelCanvas{width:280px;height:280px}.dm-pc-row{grid-template-columns:1fr;gap:1rem}.dm-pc-item-del{opacity:1}.dm-pc-weight-wrap input[type=range]{width:48px}.dm-coin-stats{font-size:.78rem;padding:.4rem 1rem}}.pomo-main{text-align:center}.pomo-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-sm);background:var(--color-bg-alt);border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition)}.pomo-icon-btn:hover{color:var(--color-text);background:var(--color-surface)}.pomo-options-spacer{flex:1}.pomo-history-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}.pomo-history-title{font-size:1rem;font-weight:600;color:var(--color-text)}.pomo-year-nav{display:flex;align-items:center;gap:.5rem}.pomo-year-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-xs);background:var(--color-bg-alt);border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition)}.pomo-year-btn:hover:not(:disabled){color:var(--color-text);background:var(--color-surface)}.pomo-year-btn:disabled{cursor:default}.pomo-year-label{font-size:.9rem;font-weight:700;color:var(--color-text);min-width:40px;text-align:center;font-family:var(--font-mono, monospace)}.pomo-options-bar{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;margin-bottom:1rem}.pomo-switch-label{display:flex;align-items:center;gap:.45rem;cursor:pointer;user-select:none}.pomo-switch-text{font-size:.78rem;font-weight:500;color:var(--color-text-muted)}.pomo-switch{position:relative;display:inline-block;width:36px;height:20px}.pomo-switch input{opacity:0;width:0;height:0;position:absolute}.pomo-switch-track{position:absolute;inset:0;background:var(--color-border);border-radius:99px;transition:background .25s;cursor:pointer}.pomo-switch-track::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .25s;box-shadow:0 1px 3px rgba(0,0,0,.15)}.pomo-switch input:checked+.pomo-switch-track{background:#3b82f6}.pomo-switch input:checked+.pomo-switch-track::after{transform:translateX(16px)}.pomo-phase-tabs{display:inline-flex;gap:4px;padding:4px;background:var(--color-bg-alt);border-radius:99px;margin-bottom:1.5rem;border:1px solid var(--color-border)}.pomo-phase-tab{padding:.4rem 1rem;border-radius:99px;border:none;font-size:.78rem;font-weight:600;letter-spacing:.03em;background:0 0;color:var(--color-text-muted);cursor:pointer;transition:.25s;font-family:inherit}.pomo-phase-tab:hover{color:var(--color-text)}.pomo-phase-tab.active{color:#fff;box-shadow:0 2px 8px rgba(0,0,0,.1)}.pomo-phase-tab.active[data-phase=work]{background:var(--color-primary)}.pomo-phase-tab.active[data-phase=short]{background:#f59e0b}.pomo-phase-tab.active[data-phase=long]{background:#10b981}.pomo-ring-row{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-bottom:1.25rem}.pomo-ring-wrap{position:relative;width:240px;height:240px;cursor:pointer}.pomo-ring-svg{width:100%;height:100%;transform:rotate(-90deg)}.pomo-ring-bg{fill:none;stroke:var(--color-border);stroke-width:6;opacity:.4}.pomo-ring-progress{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset .4s linear,stroke .4s}.pomo-ring-wrap[data-phase=work] .pomo-ring-progress{stroke:var(--color-primary)}.pomo-ring-wrap[data-phase=short] .pomo-ring-progress{stroke:#f59e0b}.pomo-ring-wrap[data-phase=long] .pomo-ring-progress{stroke:#10b981}.pomo-ring-inner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.pomo-timer-display{font-size:3rem;font-weight:800;line-height:1;font-family:var(--font-mono, monospace);letter-spacing:-.02em;transition:color .4s}.pomo-ring-wrap[data-phase=work] .pomo-timer-display{color:var(--color-primary)}.pomo-ring-wrap[data-phase=short] .pomo-timer-display{color:#f59e0b}.pomo-ring-wrap[data-phase=long] .pomo-timer-display{color:#10b981}.pomo-phase-label{font-size:.78rem;color:var(--color-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-top:.3rem}.pomo-ring-action{margin-top:.35rem;opacity:.5;transition:opacity .2s}.pomo-ring-wrap:hover .pomo-ring-action{opacity:1}.pomo-ring-action svg{color:var(--color-text-muted)}.pomo-ring-wrap:hover{filter:brightness(1.02)}.pomo-ring-wrap:active{transform:scale(.98);transition:transform .1s}.pomo-ring-pulse{position:absolute;inset:-8px;border-radius:50%;pointer-events:none;border:3px solid transparent;opacity:0}.pomo-ring-pulse.animate{animation:.8s ease-out pomoPulse}.pomo-ring-wrap[data-phase=work] .pomo-ring-pulse.animate{border-color:var(--color-primary)}.pomo-ring-wrap[data-phase=short] .pomo-ring-pulse.animate{border-color:#f59e0b}.pomo-ring-wrap[data-phase=long] .pomo-ring-pulse.animate{border-color:#10b981}@keyframes pomoPulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.2);opacity:0}}.pomo-session-dots{display:flex;gap:.5rem;justify-content:center;margin-bottom:1.5rem}.pomo-dot{width:12px;height:12px;border-radius:50%;border:2.5px solid var(--color-border);transition:.3s}.pomo-dot.filled{background:#3b82f6;border-color:#3b82f6}.pomo-dot.current{border-color:#3b82f6;box-shadow:0 0 0 4px rgba(59,130,246,.18)}.pomo-btn{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:none;cursor:pointer;transition:.2s;font-family:inherit}.pomo-btn-secondary{width:44px;height:44px;background:var(--color-bg-alt);color:var(--color-text-muted);border:1.5px solid var(--color-border)}.pomo-btn-secondary:hover{color:var(--color-text);background:var(--color-surface);transform:scale(1.08)}.pomo-option-btn{background:0 0;border:none;cursor:pointer;font-size:1.1rem;padding:.2rem;color:var(--color-text-muted);transition:color var(--transition)}.pomo-option-btn:hover{color:var(--color-text)}.pomo-stats{display:inline-flex;align-items:center;gap:1.25rem;padding:.85rem 1.5rem;background:var(--color-bg-alt);border-radius:var(--radius);border:1px solid var(--color-border)}.pomo-stat{text-align:center}.pomo-stat-value{font-size:1.3rem;font-weight:700;font-family:var(--font-mono, monospace);color:var(--color-primary)}.pomo-stat-label{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:.1rem}.pomo-stat-sep{width:1px;height:28px;background:var(--color-border)}.pomo-history-summary{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.pomo-history-card{flex:1;min-width:100px;padding:.85rem 1rem;text-align:center;background:var(--color-bg-alt);border-radius:var(--radius);border:1px solid var(--color-border)}.pomo-history-card-value{font-size:1.4rem;font-weight:700;font-family:var(--font-mono, monospace);color:var(--color-primary)}.pomo-history-card-label{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:.2rem}.pomo-graph-wrap{background:var(--color-bg-alt);border-radius:var(--radius);border:1px solid var(--color-border);padding:1.25rem;overflow:hidden}.pomo-graph-scroll{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}.pomo-graph-months{display:flex;padding-left:32px;margin-bottom:6px}.pomo-graph-month{font-size:.68rem;color:var(--color-text-muted);text-align:left}.pomo-graph-body{display:flex;gap:0}.pomo-graph-days{display:flex;flex-direction:column;gap:3px;padding-right:6px;flex-shrink:0;width:32px}.pomo-graph-days span{height:14px;line-height:14px;font-size:.65rem;color:var(--color-text-muted);text-align:right}.pomo-graph-grid{display:flex;gap:3px}.pomo-graph-col{display:flex;flex-direction:column;gap:3px}.pomo-graph-cell{width:14px;height:14px;border-radius:2px;outline:rgba(27,31,35,.04) solid 1px;cursor:default}.pomo-graph-cell.future,.pomo-graph-cell.outside{opacity:.35}.pomo-graph-cell[data-level="0"]{background:var(--color-surface-2)}.pomo-graph-cell[data-level="1"]{background:#9be9a8}.pomo-graph-cell[data-level="2"]{background:#40c463}.pomo-graph-cell[data-level="3"]{background:#30a14e}.pomo-graph-cell[data-level="4"]{background:#216e39}[data-theme=dark] .pomo-graph-cell[data-level="0"]{background:var(--color-surface-2)}[data-theme=dark] .pomo-graph-cell[data-level="1"]{background:#0e4429}[data-theme=dark] .pomo-graph-cell[data-level="2"]{background:#006d32}[data-theme=dark] .pomo-graph-cell[data-level="3"]{background:#26a641}[data-theme=dark] .pomo-graph-cell[data-level="4"]{background:#39d353}[data-theme=dark] .pomo-graph-cell{outline-color:rgba(255,255,255,.04)}.pomo-graph-footer{display:flex;justify-content:flex-end;margin-top:.75rem}.pomo-graph-legend{display:flex;align-items:center;gap:3px}.pomo-graph-legend .pomo-graph-cell{cursor:default}.pomo-graph-legend-label{font-size:.65rem;color:var(--color-text-muted);padding:0 4px}.pomo-graph-tooltip{position:fixed;z-index:9999;padding:.45rem .7rem;background:var(--color-text);color:var(--color-bg);border-radius:var(--radius-xs);font-size:.75rem;pointer-events:none;opacity:0;transition:opacity .15s;white-space:nowrap;font-weight:500;box-shadow:var(--shadow-md)}.pomo-graph-tooltip.visible{opacity:1}.pomo-graph-tooltip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--color-text)}.pomo-widget{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .75rem .3rem .55rem;border-radius:99px;text-decoration:none;font-family:var(--font-mono, monospace);font-size:.82rem;font-weight:600;line-height:1;transition:.2s;white-space:nowrap;animation:.3s pomoWidgetIn}.pomo-widget:hover{transform:scale(1.05);text-decoration:none}.pomo-widget-phase{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:.65rem;font-weight:800;color:#fff;line-height:1}.pomo-widget-time{letter-spacing:.02em}.pomo-widget.pw-work{background:rgba(59,130,246,.1);color:#3b82f6;border:1.5px solid rgba(59,130,246,.25)}.pomo-widget.pw-work .pomo-widget-phase{background:#3b82f6}[data-theme=dark] .pomo-widget.pw-work{background:rgba(59,130,246,.12);color:#93bbfd;border-color:rgba(59,130,246,.3)}.pomo-widget.pw-short{background:rgba(245,158,11,.1);color:#d97706;border:1.5px solid rgba(245,158,11,.25)}.pomo-widget.pw-short .pomo-widget-phase{background:#f59e0b}[data-theme=dark] .pomo-widget.pw-short{background:rgba(245,158,11,.12);color:#fbbf24;border-color:rgba(245,158,11,.3)}.pomo-widget.pw-long{background:rgba(16,185,129,.1);color:#059669;border:1.5px solid rgba(16,185,129,.25)}.pomo-widget.pw-long .pomo-widget-phase{background:#10b981}[data-theme=dark] .pomo-widget.pw-long{background:rgba(16,185,129,.12);color:#6ee7b7;border-color:rgba(16,185,129,.3)}@keyframes pomoWidgetIn{0%{opacity:0;transform:scale(.85)}100%{opacity:1;transform:scale(1)}}@media (max-width:768px){.pomo-ring-wrap{width:200px;height:200px}.pomo-timer-display{font-size:2.4rem}.pomo-stats{gap:.85rem;padding:.7rem 1rem}.pomo-stat-value{font-size:1.1rem}.pomo-btn-secondary{width:40px;height:40px}.pomo-phase-tabs{gap:2px;padding:3px}.pomo-phase-tab{padding:.35rem .75rem;font-size:.72rem}.pomo-ring-row{gap:1rem}.pomo-widget{padding:.25rem .55rem .25rem .4rem;font-size:.75rem}.pomo-widget-phase{width:18px;height:18px;font-size:.6rem}}@media (max-width:480px){.pomo-ring-wrap{width:180px;height:180px}.pomo-timer-display{font-size:2rem}.pomo-ring-row{gap:.75rem}.pomo-stats{flex-direction:column;gap:.5rem}.pomo-stat-sep{width:40px;height:1px}.pomo-history-summary{gap:.5rem}.pomo-history-card{min-width:0;padding:.6rem .5rem}.pomo-history-card-value{font-size:1.1rem}.pomo-history-card-label{font-size:.62rem}}.pdf-conv-layout{display:flex;flex-direction:column;gap:1.25rem}.pdf-mode-tabs{display:flex;border-bottom:1px solid var(--color-border);gap:0;padding:0;background:var(--color-bg)}.pdf-mode-tab{flex:1;display:flex;align-items:center;justify-content:center;padding:.85rem .5rem;background:0 0;border:none;font-size:.88rem;font-weight:500;letter-spacing:.02em;color:var(--color-text-muted);cursor:pointer;position:relative;transition:color .2s;white-space:nowrap;text-decoration:none;font-family:var(--font)}.pdf-mode-tab::after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:0;height:3px;border-radius:3px 3px 0 0;background:var(--color-primary);transition:width .2s}.pdf-mode-tab:hover{color:var(--color-text);background:color-mix(in srgb,var(--color-primary) 5%,transparent)}.pdf-mode-tab.active{color:var(--color-primary);font-weight:600}.pdf-mode-tab.active::after{width:60%}.pdf-panel{display:none;flex-direction:column;gap:1rem}.pdf-panel.active{display:flex}.pdf-dropzone{border:2px dashed var(--color-border);border-radius:var(--radius);padding:2.5rem 1.5rem;text-align:center;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition);background:var(--color-bg);display:flex;flex-direction:column;align-items:center;gap:.5rem}.pdf-dropzone svg{color:var(--color-text-light);transition:color var(--transition)}.pdf-dropzone p{margin:0;font-size:.92rem}.pdf-dropzone strong{color:var(--color-primary)}.pdf-dropzone.dragover,.pdf-dropzone:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.pdf-dropzone.dragover svg,.pdf-dropzone:hover svg{color:var(--color-primary)}.pdf-dropzone.has-file{border-style:solid;border-color:var(--color-success);background:var(--color-bg)}.pdf-hint{font-size:.8rem;color:var(--color-text-light)}.pdf-file-list{display:flex;flex-direction:column;gap:.35rem}.pdf-file-row{display:flex;align-items:center;gap:.75rem;padding:.55rem .75rem;border-radius:var(--radius-sm);background:var(--color-surface);border:1px solid var(--color-border);font-size:.85rem;transition:background var(--transition)}.pdf-file-row:hover{background:var(--color-surface-2)}.pdf-file-name{flex:1;font-weight:500;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pdf-file-size{color:var(--color-text-muted);font-size:.8rem;white-space:nowrap}.pdf-file-remove{background:0 0;border:none;cursor:pointer;color:var(--color-text-light);font-size:1.2rem;line-height:1;padding:.15rem .35rem;border-radius:var(--radius-xs);transition:all var(--transition)}.pdf-file-remove:hover{color:var(--color-error);background:var(--color-surface-2)}.pdf-options-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem}.pdf-progress{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:var(--radius-sm);background:var(--color-surface);border:1px solid var(--color-border)}.pdf-progress-bar{flex:1;height:8px;background:var(--color-border);border-radius:4px;overflow:hidden}.pdf-progress-fill{height:100%;background:var(--color-primary);border-radius:4px;transition:width .3s;width:0}#progressText{font-size:.82rem;color:var(--color-text-muted);white-space:nowrap;min-width:100px}.pdf-img-actions{display:flex;align-items:center;gap:1rem;padding:.75rem;border-radius:var(--radius-sm);background:var(--color-surface);border:1px solid var(--color-border)}.pdf-img-count{font-size:.85rem;color:var(--color-text-muted);font-weight:500}.pdf-img-results{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.pdf-img-card{border-radius:var(--radius);overflow:hidden;border:1px solid var(--color-border);background:var(--color-surface);transition:box-shadow var(--transition)}.pdf-img-card:hover{box-shadow:var(--shadow-md)}.pdf-img-card img{width:100%;height:auto;display:block;background:#fff}.pdf-img-card-footer{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;font-size:.82rem;color:var(--color-text-muted);border-top:1px solid var(--color-border)}.pdf-img-card-footer .btn{font-size:.78rem;padding:.3rem .65rem}@media (max-width:768px){.pdf-mode-tab{padding:.65rem .3rem;font-size:.82rem}.pdf-dropzone{padding:1.75rem 1rem}.pdf-options-row{grid-template-columns:1fr}.pdf-img-results{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media (max-width:480px){.pdf-mode-tab{padding:.5rem .2rem;font-size:.75rem}.pdf-img-results{grid-template-columns:1fr}}.ftg-input-wrap{margin-bottom:1rem}.ftg-input-wrap .tool-input{font-size:1.15rem;resize:vertical}.ftg-search-wrap{margin-bottom:1.25rem}.ftg-search-wrap .tool-input{padding:.6rem 1rem;font-size:.95rem}.ftg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.ftg-card{position:relative;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.85rem 1rem;cursor:pointer;transition:border-color var(--transition),box-shadow var(--transition),transform .15s ease;overflow:hidden;user-select:none}.ftg-card:focus-visible,.ftg-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow);transform:translateY(-1px)}.ftg-card-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:.4rem}.ftg-card-text{font-size:1.1rem;line-height:1.5;word-break:break-all;color:var(--color-text);min-height:1.6em}.ftg-card-copied{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--color-primary);color:#fff;font-weight:700;font-size:.95rem;opacity:0;pointer-events:none;transition:opacity .2s;border-radius:var(--radius-sm)}.ftg-card.ftg-copied .ftg-card-copied{opacity:1}@media (max-width:480px){.ftg-grid{grid-template-columns:1fr}}.met{max-width:560px;margin:0 auto;text-align:center}.met-hero{margin-bottom:1.75rem;display:flex;justify-content:center;padding:1rem 0}.met-ring{position:relative;width:260px;height:260px;display:flex;align-items:center;justify-content:center;background:var(--color-surface);border-radius:50%;box-shadow:0 8px 32px rgba(82,128,155,.1),0 2px 8px rgba(0,0,0,.04),inset 0 0 0 1px var(--color-border)}[data-theme=dark] .met-ring{box-shadow:0 8px 32px rgba(0,0,0,.35),0 2px 8px rgba(0,0,0,.2),inset 0 0 0 1px var(--color-border)}.met-ring-svg{position:absolute;inset:0;width:100%;height:100%;transform:rotate(-90deg)}.met-ring-track{fill:none;stroke:var(--color-border);stroke-width:5}.met-ring-progress{fill:none;stroke:var(--color-primary);stroke-width:5;stroke-linecap:round;transition:stroke-dashoffset 80ms;filter:drop-shadow(0 0 8px rgba(82,128,155,.35))}[data-theme=dark] .met-ring-progress{filter:drop-shadow(0 0 10px rgba(122,163,190,.35))}.met-ring-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1}.met-bpm-val{width:130px;text-align:center;font-size:4.2rem;font-weight:800;border:none;background:0 0;color:var(--color-text);font-family:var(--font);outline:0;line-height:1;-moz-appearance:textfield;letter-spacing:-.04em}.met-bpm-val::-webkit-inner-spin-button,.met-bpm-val::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.met-bpm-unit{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--color-primary);margin-top:4px}.met-tempo-name{font-size:.78rem;color:var(--color-text-light);font-style:italic;margin-top:6px;opacity:.8}.met-ring.met-pulse{animation:.15s ease-out metRingPulse}.met-ring.met-pulse .met-ring-inner{animation:.12s ease-out metPop}@keyframes metRingPulse{0%,100%{box-shadow:0 8px 32px rgba(82,128,155,.1),0 2px 8px rgba(0,0,0,.04),inset 0 0 0 1px var(--color-border)}50%{box-shadow:0 8px 32px rgba(82,128,155,.1),0 2px 8px rgba(0,0,0,.04),inset 0 0 0 1px var(--color-border),0 0 30px rgba(82,128,155,.18)}}[data-theme=dark] .met-ring.met-pulse{animation:.15s ease-out metRingPulseDark}@keyframes metRingPulseDark{0%,100%{box-shadow:0 8px 32px rgba(0,0,0,.35),0 2px 8px rgba(0,0,0,.2),inset 0 0 0 1px var(--color-border)}50%{box-shadow:0 8px 32px rgba(0,0,0,.35),0 2px 8px rgba(0,0,0,.2),inset 0 0 0 1px var(--color-border),0 0 35px rgba(122,163,190,.15)}}@keyframes metPop{0%,100%{transform:scale(1)}50%{transform:scale(1.03)}}.met-dots{display:flex;justify-content:center;gap:.75rem;margin-bottom:1.5rem}.met-dot{width:44px;height:44px;border-radius:50%;background:var(--color-bg);border:2.5px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--color-text-muted);transition:80ms}.met-dot-acc{border-color:var(--color-primary);color:var(--color-primary)}.met-dot.on{background:var(--gradient-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 0 22px rgba(82,128,155,.45);transform:scale(1.18)}[data-theme=dark] .met-dot.on{box-shadow:0 0 22px rgba(122,163,190,.4)}.met-dot-acc.on{box-shadow:0 0 32px rgba(82,128,155,.55);transform:scale(1.28)}[data-theme=dark] .met-dot-acc.on{box-shadow:0 0 32px rgba(122,163,190,.5)}.met-actions{display:flex;justify-content:center;align-items:center;gap:1.25rem;margin-bottom:1.75rem}.met-play{width:72px;height:72px;border-radius:50%;background:var(--gradient-primary);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(82,128,155,.35);transition:all var(--transition);flex-shrink:0}.met-play:hover{transform:scale(1.08);box-shadow:0 8px 28px rgba(82,128,155,.5)}.met-play.met-active{background:var(--color-error);box-shadow:0 6px 20px rgba(239,68,68,.35)}.met-play.met-active:hover{box-shadow:0 8px 28px rgba(239,68,68,.5)}.met-tap{padding:.65rem 1.2rem;border-radius:var(--radius);border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);font-weight:600;font-size:.82rem;cursor:pointer;display:flex;align-items:center;gap:.45rem;transition:all var(--transition)}.met-tap:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.met-tap.met-tap-flash{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.met-tap kbd{font-size:.58rem;padding:.08rem .3rem;border-radius:4px;background:var(--color-bg);border:1px solid var(--color-border);font-family:var(--font-mono)}.met-tap svg{opacity:.6;flex-shrink:0}.met-tap:hover svg{opacity:1}.met-slider-wrap{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.75rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.met-nudge{width:34px;height:34px;border-radius:50%;border:none;background:var(--color-bg);color:var(--color-text-muted);font-weight:700;font-size:.78rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);flex-shrink:0;padding:0}.met-nudge:hover{background:var(--color-primary);color:#fff}.met-slider{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:var(--color-border);border-radius:3px;outline:0;cursor:pointer}.met-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:3px solid var(--color-surface);box-shadow:0 1px 6px rgba(82,128,155,.3)}.met-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:3px solid var(--color-surface);box-shadow:0 1px 6px rgba(82,128,155,.3)}.met-info{font-size:.82rem;color:var(--color-primary);margin-bottom:1.5rem;background:var(--color-primary-light);display:inline-flex;align-items:center;gap:.35rem;padding:.4rem 1.15rem;border-radius:99px;font-weight:500}.met-presets{display:grid;grid-template-columns:repeat(6,1fr);gap:.4rem;margin-bottom:1.5rem}.met-pre{display:flex;flex-direction:column;align-items:center;padding:.55rem .4rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:.92rem;font-weight:700;line-height:1.15;transition:all var(--transition)}.met-pre small{font-size:.56rem;font-weight:500;color:var(--color-text-muted);margin-top:2px;text-transform:uppercase;letter-spacing:.03em}.met-pre:hover{border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px);box-shadow:var(--shadow)}.met-pre.active{background:var(--gradient-primary);color:#fff;border-color:transparent;box-shadow:0 3px 12px rgba(82,128,155,.3)}.met-pre.active small{color:rgba(255,255,255,.8)}.met-opts{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem 1.35rem;display:flex;flex-direction:column;gap:1.1rem;margin-bottom:1rem;text-align:left}.met-opt-row{display:flex;gap:1.25rem}.met-opt{flex:1;min-width:0}.met-opt-full{flex:1 1 100%}.met-opt-label{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted);margin-bottom:.45rem}.met-pills{display:flex;gap:.3rem;flex-wrap:wrap}.met-pill{padding:.4rem .72rem;border-radius:var(--radius-xs);border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);cursor:pointer;font-size:.78rem;font-weight:500;transition:all var(--transition)}.met-pill:hover{border-color:var(--color-primary);color:var(--color-primary)}.met-pill.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.met-vol{display:flex;align-items:center;gap:.5rem}.met-vol-num{font-size:.78rem;font-weight:600;color:var(--color-text-muted);min-width:34px;text-align:right}.met-trainer{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:1rem;text-align:left}.met-trainer-sum{padding:.9rem 1.35rem;font-weight:600;font-size:.9rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;list-style:none;color:var(--color-text);transition:color var(--transition)}.met-trainer-sum:hover{color:var(--color-primary)}.met-trainer-sum::-webkit-details-marker{display:none}.met-trainer-sum::after{content:'';margin-left:auto;width:8px;height:8px;border-right:2px solid var(--color-text-muted);border-bottom:2px solid var(--color-text-muted);transform:rotate(45deg);transition:transform .2s}.met-trainer[open] .met-trainer-sum::after{transform:rotate(-135deg)}.met-trainer-body{padding:0 1.35rem 1.25rem}.met-trainer-grid{display:flex;gap:.85rem;flex-wrap:wrap;margin-bottom:.85rem}.met-tl{display:flex;align-items:center;gap:.35rem;font-size:.82rem;color:var(--color-text-muted);font-weight:500}.met-ti{width:56px;text-align:center;padding:.4rem .3rem;border:1px solid var(--color-border);border-radius:var(--radius-xs);background:var(--color-bg);color:var(--color-text);font-size:.85rem;font-weight:700;font-family:var(--font)}.met-ti:focus{border-color:var(--color-primary);outline:0;box-shadow:var(--shadow-glow)}.met-trainer-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.85rem;font-weight:500}.met-trainer-toggle input{display:none}.met-sw{position:relative;width:40px;height:22px;background:var(--color-border);border-radius:11px;transition:background .2s;flex-shrink:0}.met-sw::after{content:'';position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.15)}.met-trainer-toggle input:checked+.met-sw{background:var(--color-primary)}.met-trainer-toggle input:checked+.met-sw::after{transform:translateX(18px)}.met-keys{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;font-size:.72rem;color:var(--color-text-light);padding:.65rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.met-keys kbd{font-size:.62rem;padding:.12rem .4rem;border-radius:4px;background:var(--color-bg);border:1px solid var(--color-border);font-family:var(--font-mono);margin:0 2px}@media (max-width:768px){.met-opt-row{flex-direction:column;gap:.85rem}.met-presets{grid-template-columns:repeat(3,1fr)}}@media (max-width:480px){.met-ring{width:220px;height:220px}.met-bpm-val{font-size:3.2rem;width:110px}.met-dot{width:36px;height:36px;font-size:.68rem}.met-play{width:64px;height:64px}.met-tap{padding:.55rem .9rem;font-size:.78rem}.met-actions{gap:.85rem}.met-pre{padding:.45rem .35rem;font-size:.85rem}.met-presets{grid-template-columns:repeat(3,1fr);gap:.35rem}.met-trainer-grid{flex-direction:column}.met-slider-wrap{padding:.6rem .75rem}}.grc-tabs{display:flex;gap:0;margin-bottom:1.25rem;border-bottom:2px solid var(--color-border)}.grc-tab{padding:.65rem 1.25rem;border:none;background:0 0;color:var(--color-text-muted);font-size:.95rem;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition)}.grc-tab:hover{color:var(--color-text)}.grc-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.grc-panel{display:none}.grc-panel.active{display:block}.grc-table-wrap{overflow-x:auto;margin-bottom:.75rem}.grc-table{width:100%;border-collapse:collapse}.grc-table th{text-align:left;padding:.5rem .4rem;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border)}.grc-table td{padding:.35rem .25rem}.grc-input{width:100%;padding:.5rem .6rem;border:1px solid var(--color-border);border-radius:var(--radius-xs);background:var(--color-bg);color:var(--color-text);font-size:.9rem;font-family:var(--font);transition:border-color var(--transition)}.grc-input:focus{border-color:var(--color-primary);outline:0}.grc-name{min-width:120px}.grc-score,.grc-weight{width:80px;text-align:center}.grc-del{background:0 0;border:none;color:var(--color-text-light);font-size:1.2rem;cursor:pointer;padding:.3rem .5rem;border-radius:var(--radius-xs);transition:all var(--transition)}.grc-del:hover{color:var(--color-error);background:var(--color-surface)}.grc-actions{display:flex;gap:.5rem;margin-bottom:1.25rem}.grc-results{margin-top:.5rem}.grc-weight-bar-wrap{height:6px;background:var(--color-border);border-radius:3px;margin-top:.75rem;overflow:hidden}.grc-weight-bar{height:100%;background:var(--color-primary);border-radius:3px;transition:width .3s;width:0%}.grc-weight-bar.grc-weight-over{background:var(--color-error)}.grc-grade-a{color:#16a34a!important}.grc-grade-b{color:#2563eb!important}.grc-grade-c{color:#d97706!important}.grc-grade-d{color:#ea580c!important}.grc-grade-f{color:var(--color-error)!important}.grc-final-form{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.25rem}.grc-final-form .input-group label{margin-bottom:.3rem;display:block}.grc-final-form .tool-input{text-align:center;font-size:1.1rem}.grc-final-result-card .stat-value{font-size:2rem}.grc-final-msg{margin-top:.75rem;font-size:.95rem;text-align:center}.grc-msg-easy{color:#16a34a;font-weight:600}.grc-msg-medium{color:#d97706;font-weight:600}.grc-msg-hard{color:var(--color-error);font-weight:600}.grc-ref{margin-top:1.5rem}.grc-ref h3{margin-bottom:.75rem}.grc-ref-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}.grc-ref-item{display:flex;flex-direction:column;align-items:center;padding:.5rem;border-radius:var(--radius-xs);background:var(--color-surface);border:1px solid var(--color-border)}.grc-ref-letter{font-weight:700;font-size:1.1rem}.grc-ref-range{font-size:.75rem;color:var(--color-text-muted)}@media (max-width:768px){.grc-final-form{grid-template-columns:1fr}}@media (max-width:480px){.grc-ref-grid{grid-template-columns:repeat(auto-fill,minmax(75px,1fr))}.grc-score,.grc-weight{width:65px}}