:root{color-scheme:dark;font-size:16px;font-family:Inter,"Segoe UI",-apple-system,BlinkMacSystemFont,sans-serif;--font-sans:"Inter","Segoe UI",-apple-system,BlinkMacSystemFont,sans-serif;--font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,monospace;--radius-sm:10px;--radius-md:16px;--radius-lg:24px;--shadow-sm:0 6px 16px rgba(15, 23, 42, 0.22);--shadow-md:0 16px 38px rgba(15, 23, 42, 0.32);--shadow-lg:0 30px 60px rgba(15, 23, 42, 0.40);--transition:180ms ease;--bg-page:#09090b;--bg-header:#09090b;--surface-card:#111113;--surface-muted:rgba(148, 163, 184, 0.12);--surface-soft:rgba(30, 30, 38, 0.80);--surface-elevated:rgba(30, 30, 38, 0.95);--border-soft:rgba(148, 163, 184, 0.24);--border-strong:rgba(148, 163, 184, 0.36);--text-strong:#f8fafc;--text-primary:rgba(226, 232, 240, 0.92);--text-muted:rgba(148, 163, 184, 0.78);--text-inverse:#0f172a;--accent:#2dd4bf;--accent-strong:#14b8a6;--accent-soft:rgba(45, 212, 191, 0.15);--accent-border:rgba(45, 212, 191, 0.5);--accent-focus:rgba(45, 212, 191, 0.35);--brand-gradient:linear-gradient(120deg, #6366f1 0%, #2dd4bf 50%, #22d3ee 100%);--meter-gradient:linear-gradient(90deg, #ef4444 0%, #f59e0b 40%, #22c55e 100%);--color-char-upper:#2dd4bf;--color-char-number:#60a5fa;--color-char-symbol:#f87171;--meter-0:#ef4444;--meter-1:#f97316;--meter-2:#eab308;--meter-3:#60a5fa;--meter-4:#2dd4bf}body[data-theme=light]{color-scheme:light;--bg-page:#f1f5f9;--bg-header:#ffffff;--surface-card:#ffffff;--surface-soft:rgba(255, 255, 255, 0.66);--surface-muted:rgba(226, 232, 240, 0.5);--surface-elevated:rgba(255, 255, 255, 0.96);--border-soft:rgba(100, 116, 139, 0.24);--border-strong:rgba(30, 41, 59, 0.18);--text-strong:#0f172a;--text-primary:rgba(15, 23, 42, 0.88);--text-muted:rgba(71, 85, 105, 0.8);--text-inverse:#ffffff;--accent:#0d9488;--accent-strong:#0f766e;--accent-soft:rgba(13, 148, 136, 0.12);--accent-border:rgba(13, 148, 136, 0.4);--accent-focus:rgba(13, 148, 136, 0.28);--shadow-sm:0 8px 18px rgba(148, 163, 184, 0.2);--shadow-md:0 16px 35px rgba(148, 163, 184, 0.25);--shadow-lg:0 28px 50px rgba(148, 163, 184, 0.35);--color-char-upper:#0d9488;--color-char-number:#2563eb;--color-char-symbol:#dc2626;--meter-0:#dc2626;--meter-1:#ea580c;--meter-2:#ca8a04;--meter-3:#2563eb;--meter-4:#0d9488}*,::after,::before{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font-sans);background:var(--bg-page);color:var(--text-primary);display:flex;flex-direction:column}body[data-theme=light]{background:var(--bg-page)}a{color:inherit;text-decoration:none}a:focus,a:hover{text-decoration:underline}img{max-width:100%;display:block}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.site-header{position:sticky;top:0;z-index:50;background:rgba(9,9,11,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between;padding:.85rem clamp(1rem,4vw,2rem)}.site-header:has(.site-header__inner){display:block;padding:0}body[data-theme=light] .site-header{background:rgba(255,255,255,.92)}.site-header__inner{max-width:1080px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:.85rem clamp(1rem,4vw,2rem)}.brand{display:inline-flex;align-items:center;gap:.6rem;color:var(--text-strong);text-decoration:none}.brand:hover{text-decoration:none}.brand__logo{display:inline-flex;align-items:center;gap:.6rem}.brand__icon{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:.5rem;background:var(--accent);flex-shrink:0}.brand__icon svg{width:1rem;height:1rem;stroke:var(--text-inverse);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.brand__shield svg{width:clamp(32px,3.2vw,38px);height:clamp(38px,3.6vw,46px);stroke:var(--accent);stroke-width:1.6;fill:none;stroke-linejoin:round}.brand__name{font-size:1rem;font-weight:600;letter-spacing:-.01em;color:var(--text-strong)}.brand__text{display:inline-flex;align-items:baseline;gap:.15rem;font-weight:800;letter-spacing:-.02em}.brand__segment{font-size:clamp(1.3rem, 2.2vw, 1.6rem);background:var(--brand-gradient);-webkit-background-clip:text;background-clip:text;color:transparent}.brand__dot{font-size:clamp(1.1rem, 1.8vw, 1.3rem);font-weight:700;background:var(--brand-gradient);-webkit-background-clip:text;background-clip:text;color:transparent}.site-header__nav{display:none;align-items:center;gap:1.5rem}.site-header__nav a{font-size:.8rem;color:var(--text-muted);font-weight:500;transition:color var(--transition);text-decoration:none}.site-header__nav a:hover{color:var(--text-strong);text-decoration:none}@media (min-width:640px){.site-header__nav{display:flex}}.header-actions{display:flex;align-items:center;gap:.75rem}.mobile-menu-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:0 0;color:var(--text-muted);cursor:pointer;border-radius:8px;transition:color var(--transition),background var(--transition)}.mobile-menu-btn:hover{color:var(--text-strong);background:var(--surface-muted)}.mobile-menu-btn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}@media (min-width:640px){.mobile-menu-btn{display:none}}.mobile-menu{display:none;flex-direction:column;gap:.25rem;padding:.75rem 1rem;border-top:1px solid var(--border-soft);background:var(--bg-header)}body[data-theme=light] .mobile-menu{background:rgba(255,255,255,.96)}.mobile-menu.is-open{display:flex}.mobile-menu a{font-size:.9rem;color:var(--text-muted);padding:.5rem .5rem;border-radius:8px;transition:color var(--transition),background var(--transition);text-decoration:none}.mobile-menu a:hover{color:var(--text-strong);background:var(--surface-muted);text-decoration:none}.header-lang-wrap{position:relative}.header-lang-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .65rem;border-radius:.5rem;border:1px solid var(--border-soft);background:var(--surface-muted);color:var(--text-strong);font-size:.75rem;font-weight:500;cursor:pointer;transition:background var(--transition),border-color var(--transition)}.header-lang-btn:hover{background:var(--surface-soft);border-color:var(--border-strong)}.header-lang-btn svg{width:14px;height:14px;stroke:var(--text-muted);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.header-lang-btn .chevron{width:12px;height:12px;stroke:var(--text-muted);fill:none;stroke-width:2;transition:transform var(--transition)}.header-lang-btn.is-open .chevron{transform:rotate(180deg)}.header-lang-dropdown{display:none;position:absolute;top:100%;right:0;margin-top:.5rem;width:11rem;border-radius:.5rem;border:1px solid var(--border-soft);background:var(--surface-card);box-shadow:var(--shadow-lg);z-index:60;padding:.375rem}.header-lang-dropdown.is-open{display:grid;grid-template-columns:1fr 1fr;gap:.125rem}.header-lang-dropdown a{display:block;padding:.375rem .625rem;border-radius:.375rem;font-size:.75rem;color:var(--text-muted);transition:background var(--transition),color var(--transition);text-decoration:none}.header-lang-dropdown a:hover{background:var(--surface-muted);color:var(--text-strong);text-decoration:none}.header-lang-dropdown a.is-current{color:var(--accent);font-weight:500;background:var(--accent-soft)}.language-switcher{display:inline-flex;align-items:center;gap:.5rem;background:var(--surface-muted);border:1px solid var(--border-soft);border-radius:var(--radius-sm);padding:.35rem .75rem;color:var(--text-primary)}.language-switcher select{background:0 0;border:none;color:inherit;font-weight:600;font-size:.95rem;cursor:pointer}.language-switcher select:focus-visible{outline:2px solid var(--accent-focus);outline-offset:2px}.theme-toggle{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:.35rem;border-radius:999px;border:1px solid var(--border-soft);background:rgba(30,30,38,.6);color:var(--text-strong);cursor:pointer;transition:border-color var(--transition),box-shadow var(--transition),background var(--transition)}body[data-theme=light] .theme-toggle{background:rgba(226,232,240,.7);color:#1f2937}.theme-toggle:focus-visible,.theme-toggle:hover{border-color:var(--accent-border);box-shadow:0 8px 20px rgba(15,23,42,.2)}.theme-toggle__track{position:relative;display:inline-flex;align-items:center;justify-content:space-between;width:54px;height:26px;border-radius:999px;background:linear-gradient(135deg,rgba(99,102,241,.35),rgba(14,165,233,.25));padding:3px 6px;overflow:hidden}body[data-theme=light] .theme-toggle__track{background:linear-gradient(135deg,rgba(59,130,246,.38),rgba(250,204,21,.32))}.theme-toggle__track::after,.theme-toggle__track::before{font-size:.88rem;line-height:1;transition:opacity var(--transition)}.theme-toggle__track::before{content:"🌙";opacity:.9}.theme-toggle__track::after{content:"☀️";opacity:.45}body[data-theme=light] .theme-toggle__track::before{opacity:.4}body[data-theme=light] .theme-toggle__track::after{opacity:.95}.theme-toggle__thumb{position:absolute;top:50%;left:6px;width:22px;height:22px;border-radius:50%;background:var(--text-strong);transform:translate(0,-50%);transition:transform var(--transition),background var(--transition);box-shadow:0 6px 12px rgba(15,23,42,.25)}body[data-theme=light] .theme-toggle__thumb{transform:translate(24px,-50%);background:#1f2937}.page-wrapper{flex:1 1 auto;display:flex;justify-content:center}.layout{width:100%;display:flex;flex-direction:column;gap:clamp(2.5rem,4vw,3.5rem);padding:clamp(2rem,4vw,3rem) 0 clamp(3rem,6vw,4.5rem)}.layout>.card{width:min(100%,1080px);margin:0 auto}.container{width:min(100%,768px);margin:0 auto;padding:0 clamp(1rem,4vw,2rem)}.card{background:var(--surface-card);border-radius:var(--radius-lg);border:1px solid var(--border-soft);box-shadow:var(--shadow-md);padding:clamp(1.75rem,3vw,2.25rem)}.card--light{background:var(--surface-soft)}.display{margin:0;font-size:clamp(2.2rem, 5vw, 3rem);font-weight:800;letter-spacing:-.02em;color:var(--text-strong)}.display__accent{color:var(--accent)}.lead{margin:0;font-size:clamp(1rem, 2.5vw, 1.2rem);color:var(--text-muted)}.generator{width:100%}.generator__container{display:flex;flex-direction:column;gap:clamp(1rem,2vw,1.6rem);text-align:center}.generator__intro{display:flex;flex-direction:column;gap:.6rem;align-items:center;max-width:640px;margin:0 auto}.generator-card{display:flex;flex-direction:column;gap:1.5rem;border:1px solid var(--border-soft);border-radius:var(--radius-lg);background:var(--surface-card);box-shadow:var(--shadow-md);padding:clamp(1.25rem,3vw,2rem);width:min(100%,768px);margin:0 auto}.generator-card__divider{height:1px;background:var(--border-soft)}.password-display{display:flex;align-items:center;gap:.75rem;border-radius:var(--radius-md);border:1px solid var(--border-soft);background:var(--surface-soft);padding:1rem 1.25rem;position:relative;transition:border-color var(--transition)}.password-display:hover{border-color:var(--accent-border)}.password-display__text{flex:1;font-family:var(--font-mono);font-size:clamp(1.1rem, 3vw, 1.5rem);letter-spacing:.06em;overflow-x:auto;white-space:nowrap;-webkit-user-select:all;user-select:all;scrollbar-width:none}.password-display__text::-webkit-scrollbar{display:none}.password-display__actions{display:flex;align-items:center;gap:.25rem;flex-shrink:0}.char{display:inline-block;animation:charSlideIn .3s both;color:var(--text-strong)}.char--upper{color:var(--color-char-upper)}.char--number{color:var(--color-char-number)}.char--symbol{color:var(--color-char-symbol)}@keyframes charSlideIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.copy-tooltip{position:absolute;bottom:-2rem;left:50%;transform:translateX(-50%);font-size:.75rem;color:var(--accent);white-space:nowrap;pointer-events:none;animation:tooltipFade 2s ease forwards}@keyframes tooltipFade{0%{opacity:0;transform:translateX(-50%) translateY(4px)}15%{opacity:1;transform:translateX(-50%) translateY(0)}80%{opacity:1}100%{opacity:0}}.meter-segments{display:flex;align-items:center;gap:.75rem}.meter-segments__label{font-size:.75rem;color:var(--text-muted);flex-shrink:0;width:5.5rem}.meter-segments__bars{flex:1;display:flex;align-items:center;gap:.375rem}.meter-segments__bar{flex:1;height:6px;border-radius:999px;background:var(--surface-muted);transition:background .5s ease}.meter-segments__value{font-size:.75rem;font-weight:600;flex-shrink:0;color:var(--text-muted);transition:color .5s ease}.password-card{display:flex;flex-direction:column;gap:1rem;background:var(--surface-elevated);padding:clamp(1.35rem,2.5vw,1.9rem);width:min(100%,780px);margin:0 auto}.password-card__row{display:flex;align-items:center;gap:.85rem}.password-output{flex:1;font-size:clamp(1.5rem, 4vw, 2.35rem);font-weight:700;letter-spacing:.08em;border:none;background:0 0;color:var(--text-strong)}.password-output::placeholder{color:var(--text-muted)}.password-card__actions{display:inline-flex;align-items:center;gap:.65rem}.icon-button{width:36px;height:36px;border-radius:8px;border:none;background:0 0;color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform var(--transition),color var(--transition),background var(--transition)}.icon-button svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;transform-origin:center}.icon-button:focus-visible,.icon-button:hover{color:var(--text-strong);background:var(--surface-muted)}.icon-button svg path{vector-effect:non-scaling-stroke}.icon-button.is-copied{color:var(--accent)}.password-card__meter .meter{display:flex;flex-direction:column;gap:.6rem;align-items:flex-start}.meter-bar{position:relative;width:100%;height:8px;border-radius:999px;background:var(--surface-muted);overflow:hidden}.meter-bar span{position:absolute;inset:0;transform-origin:left center;transform:scaleX(.2);background:var(--meter-gradient);transition:transform 220ms ease}.meter-label{font-size:.9rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.options-card{display:flex;flex-direction:column;gap:clamp(1.35rem,2.6vw,1.8rem);text-align:left;background:var(--surface-elevated);padding:clamp(1.4rem,2.6vw,2rem);width:min(100%,780px);margin:0 auto}.settings-title{margin:0;font-size:clamp(1.4rem, 3vw, 1.7rem);color:var(--text-strong)}.settings-options{display:grid;gap:1rem}@media (min-width:900px){.settings-options{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.3rem}}.length-control{display:flex;flex-direction:column;gap:1rem}.length-control__header{display:flex;align-items:center;justify-content:space-between}.length-control__label{font-weight:600;font-size:.875rem;color:var(--text-primary)}.length-control__value{display:flex;align-items:center;gap:.5rem}.length-control__number{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}.length-control__unit{font-size:.75rem;color:var(--text-muted)}.length-inputs{display:flex;flex-wrap:wrap;align-items:center;gap:.85rem}.length-inputs__number{width:90px;height:48px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:rgba(15,23,42,.3);color:var(--text-strong);text-align:center;font-weight:600;font-size:1rem;position:relative}body[data-theme=light] .length-inputs__number{background:rgba(255,255,255,.85);color:var(--text-strong)}.length-inputs__number:focus-visible{outline:2px solid var(--accent-focus);outline-offset:2px}.length-inputs__number::-webkit-inner-spin-button,.length-inputs__number::-webkit-outer-spin-button{width:18px;height:48px;background:linear-gradient(180deg,rgba(148,163,184,.24),rgba(148,163,184,.06));border-left:1px solid rgba(148,163,184,.2);border-radius:0 var(--radius-sm) var(--radius-sm) 0;cursor:pointer}.length-inputs__number::-webkit-inner-spin-button:active{background:rgba(99,102,241,.24)}.length-inputs__number::-moz-focus-inner{border:0}.length-inputs__number::-moz-number-spin-box{background:linear-gradient(180deg,rgba(148,163,184,.24),rgba(148,163,184,.06));border-left:1px solid rgba(148,163,184,.2)}.length-inputs__number::-moz-number-spin-down,.length-inputs__number::-moz-number-spin-up{background:0 0;border:none;height:24px}.length-inputs__number::-moz-number-spin-down:hover,.length-inputs__number::-moz-number-spin-up:hover{background:rgba(99,102,241,.18)}.length-inputs__range{width:100%;appearance:none;-webkit-appearance:none;height:6px;border-radius:999px;background:0 0;cursor:pointer}.length-inputs__range::-webkit-slider-runnable-track{height:6px;border-radius:999px;background:linear-gradient(to right,var(--accent) var(--range-progress,20%),var(--surface-muted) var(--range-progress,20%))}.length-inputs__range::-webkit-slider-thumb{appearance:none;width:16px;height:16px;border-radius:50%;border:2px solid var(--accent);background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.2);margin-top:-5px;transition:transform var(--transition),box-shadow var(--transition)}.length-inputs__range::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 0 0 4px var(--accent-focus)}.length-inputs__range::-moz-range-track{height:6px;border-radius:999px;background:var(--surface-muted)}.length-inputs__range::-moz-range-progress{height:6px;border-radius:999px;background:var(--accent)}.length-inputs__range::-moz-range-thumb{border:2px solid var(--accent);border-radius:50%;background:#fff;width:14px;height:14px;box-shadow:0 1px 4px rgba(0,0,0,.2);transition:transform var(--transition),box-shadow var(--transition)}.length-inputs__range::-moz-range-thumb:hover{transform:scale(1.15);box-shadow:0 0 0 4px var(--accent-focus)}.length-markers{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted)}.length-hint{margin:0;font-size:.8rem;color:var(--text-muted);line-height:1.5}.switch-toggle{position:relative;display:inline-flex;align-items:center;width:2rem;height:1.15rem;flex-shrink:0}.switch-toggle input{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:pointer;z-index:1}.switch-toggle__track{width:100%;height:100%;border-radius:999px;background:var(--surface-muted);border:1px solid var(--border-soft);transition:background var(--transition),border-color var(--transition)}.switch-toggle__thumb{position:absolute;top:50%;left:1px;width:1rem;height:1rem;border-radius:50%;background:var(--text-muted);transform:translateY(-50%);transition:transform var(--transition),background var(--transition);pointer-events:none}.switch-toggle input:checked~.switch-toggle__track{background:var(--accent);border-color:var(--accent)}.switch-toggle input:checked~.switch-toggle__thumb{transform:translateY(-50%) translateX(calc(2rem - 1rem - 2px));background:var(--text-inverse)}body[data-theme=light] .switch-toggle input:checked~.switch-toggle__thumb{background:#fff}.switch-toggle input:focus-visible~.switch-toggle__track{box-shadow:0 0 0 3px var(--accent-focus)}.toggle-option{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.875rem;border-radius:var(--radius-md);border:1px solid var(--border-soft);background:var(--surface-soft);cursor:pointer;transition:border-color var(--transition),background var(--transition)}.toggle-option:has(input:checked){border-color:var(--accent-border);background:var(--accent-soft)}.toggle-option:hover{border-color:var(--border-strong)}.toggle-option__info{display:flex;flex-direction:column;gap:.15rem}.toggle-option__label{font-size:.875rem;font-weight:500;color:var(--text-strong)}.toggle-option__desc{font-size:.75rem;color:var(--text-muted)}.fieldset{margin:0;padding:0;border:none;display:flex;flex-direction:column;gap:.85rem}.fieldset legend{font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.85rem;color:var(--text-muted);margin-bottom:.35rem}.checkbox-grid{display:grid;gap:.75rem;grid-template-columns:1fr}.checkbox-grid--types{grid-template-columns:repeat(2,minmax(0,1fr))}.checkbox-grid--options{grid-template-columns:minmax(0,1fr)}.checkbox-option{position:relative;display:flex;align-items:center;gap:.75rem;padding:.6rem 0;border-radius:var(--radius-md);background:0 0;border:none;transition:color var(--transition),background var(--transition);cursor:pointer}.checkbox-option:focus-within,.checkbox-option:hover{background:var(--accent-soft);color:var(--text-strong)}.checkbox-option input{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:pointer}.checkbox-option__visual{width:26px;height:26px;border-radius:50%;border:2px solid var(--border-soft);background:var(--surface-card);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color var(--transition),background var(--transition),box-shadow var(--transition)}.checkbox-option__visual::after{content:"";width:12px;height:12px;border-radius:50%;background:0 0;transition:transform var(--transition),background var(--transition)}.checkbox-option__label{display:inline-flex;align-items:center;gap:.4rem;font-weight:400;color:var(--text-primary)}.checkbox-option input:checked+.checkbox-option__visual{border-color:var(--accent);background:var(--accent-soft)}.checkbox-option input:checked+.checkbox-option__visual::after{background:var(--accent);transform:scale(.8)}.checkbox-option input:focus-visible+.checkbox-option__visual{box-shadow:0 0 0 4px var(--accent-focus)}.checkbox-option input:checked~.checkbox-option__label{color:var(--text-strong)}.settings-footer{display:flex;flex-direction:column;gap:.75rem}@media (min-width:640px){.settings-footer{flex-direction:row;align-items:center}}.button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:48px;padding:.95rem 1.4rem;border-radius:var(--radius-md);border:1px solid transparent;font-weight:700;font-size:1rem;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),background var(--transition),color var(--transition)}.button--primary{background:var(--accent);color:var(--text-inverse);box-shadow:var(--shadow-sm);font-size:.9rem}.button--primary:focus-visible,.button--primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);background:var(--accent-strong)}.button--primary.is-copied{background:var(--accent-strong)}.button--primary svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}.button--ghost{background:0 0;color:var(--text-muted);border-color:var(--border-soft);padding:.95rem 1.4rem;font-size:1.06rem}.button--ghost img{width:18px;height:18px}.button--refresh{gap:.6rem}.button--ghost:focus-visible,.button--ghost:hover{color:var(--text-strong);border-color:var(--accent-border)}.button--full{width:100%}.status-line{margin:0;font-size:.92rem;color:var(--text-muted);min-height:1.2em}.quick-features{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width:640px){.quick-features{grid-template-columns:repeat(3,1fr)}}.quick-feature{display:flex;flex-direction:column;align-items:center;gap:.5rem;border-radius:var(--radius-md);border:1px solid var(--border-soft);background:var(--surface-card);padding:1.25rem;text-align:center}.quick-feature__icon{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:.5rem;background:var(--accent-soft)}.quick-feature__icon svg{width:1.25rem;height:1.25rem;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.quick-feature__title{margin:0;font-size:.875rem;font-weight:500;color:var(--text-strong)}.quick-feature__text{margin:0;font-size:.75rem;color:var(--text-muted);line-height:1.5}.steps-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width:640px){.steps-grid{grid-template-columns:repeat(3,1fr)}}.step-card{display:flex;flex-direction:column;gap:.75rem;border-radius:var(--radius-md);border:1px solid var(--border-soft);background:var(--surface-card);padding:1.25rem}.step-card__header{display:flex;align-items:center;gap:.75rem}.step-card__icon{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:.5rem;background:var(--accent-soft)}.step-card__icon svg{width:1.25rem;height:1.25rem;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.step-card__num{font-size:.75rem;font-weight:700;color:var(--accent);font-family:var(--font-mono)}.step-card__title{font-size:.875rem;font-weight:600;color:var(--text-strong)}.step-card__text{margin:0;font-size:.875rem;color:var(--text-muted);line-height:1.6}.resources-grid,.share-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.resource-card,.share-link{display:inline-flex;align-items:center;justify-content:center;padding:1rem 1.1rem;border-radius:var(--radius-md);background:var(--surface-muted);border:1px solid transparent;font-weight:600;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)}.resource-card:focus-visible,.resource-card:hover,.share-link:focus-visible,.share-link:hover{transform:translateY(-2px);border-color:var(--accent-border);box-shadow:var(--shadow-sm)}.link-card{display:flex;flex-direction:column;gap:.75rem;padding:1.25rem;border-radius:var(--radius-md);border:1px solid var(--border-soft);background:var(--surface-card);transition:border-color var(--transition),background var(--transition);text-decoration:none}.link-card:hover{border-color:var(--accent-border);background:var(--accent-soft);text-decoration:none}.link-card__header{display:flex;align-items:center;gap:.75rem}.link-card__icon{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:.5rem;background:var(--accent-soft);flex-shrink:0}.link-card__icon svg{width:1.25rem;height:1.25rem;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.link-card__title{margin:0;font-size:1rem;font-weight:600;color:var(--text-strong)}.link-card__text{margin:0;font-size:.875rem;line-height:1.55;color:var(--text-muted)}.link-card__cta{display:inline-flex;align-items:center;gap:.35rem;font-weight:600;font-size:.875rem;color:var(--accent);margin-top:auto}.link-card__cta svg{width:1rem;height:1rem;stroke:currentColor;fill:none;stroke-width:2;transition:transform var(--transition)}.link-card:hover .link-card__cta svg{transform:translateX(4px)}.feature-section{display:flex;flex-direction:column;gap:clamp(1.4rem,2.6vw,2rem)}.feature-grid{display:grid;gap:clamp(1rem,2vw,1.5rem);grid-template-columns:repeat(1,minmax(0,1fr))}.feature-card{display:flex;flex-direction:column;gap:.7rem;padding:clamp(1.1rem,2vw,1.5rem);border-radius:var(--radius-md);border:1px solid var(--border-soft);background:var(--surface-card);box-shadow:var(--shadow-sm);text-align:left}.feature-card__title{margin:0;font-size:1.05rem;color:var(--text-strong)}.feature-card__text{margin:0;font-size:.98rem;line-height:1.55;color:var(--text-primary)}.feature-card__link{display:inline-flex;align-items:center;gap:.35rem;font-weight:600;color:var(--accent)}.feature-card__link:focus-visible,.feature-card__link:hover{text-decoration:underline}@media (min-width:768px){.feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.help-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:.65rem;font-weight:700;border:1px solid var(--accent-border);background:var(--surface-muted);color:var(--accent);cursor:help;position:relative;transition:background var(--transition),color var(--transition),border-color var(--transition);outline:0;flex-shrink:0;line-height:1}.help-icon::before{content:"";position:absolute;inset:-12px}body[data-theme=light] .help-icon{background:rgba(148,163,184,.16)}.help-icon::after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%,6px);background:var(--surface-elevated);color:var(--text-primary);padding:.55rem .7rem;border-radius:var(--radius-sm);border:1px solid var(--border-soft);box-shadow:var(--shadow-sm);white-space:normal;min-width:180px;max-width:240px;opacity:0;pointer-events:none;transition:opacity var(--transition),transform var(--transition);z-index:5}.help-icon:focus-visible::after,.help-icon:hover::after{opacity:1;transform:translate(-50%,0)}.section-divider{height:1px;background:var(--border-soft);width:min(100%,768px);margin:0 auto}.section-title{margin:0;font-size:clamp(1.2rem, 3vw, 1.5rem);font-weight:700;color:var(--text-strong)}.footer{border-top:1px solid var(--border-soft);margin-top:3rem;color:var(--text-muted)}.footer__inner{max-width:1080px;margin:0 auto;padding:3rem clamp(1rem,4vw,2.5rem)}.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem 1.5rem}@media (min-width:640px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem}}.footer-grid__brand{grid-column:1/-1;display:flex;flex-direction:column;gap:1rem}@media (min-width:640px){.footer-grid__brand{grid-column:1/2}}.footer-grid__brand .brand{font-size:.9rem}.footer-grid__brand p{margin:0;font-size:.875rem;line-height:1.6;color:var(--text-muted);max-width:320px}.footer-lang-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:.5rem;border:1px solid var(--border-soft);background:var(--surface-muted);color:var(--text-strong);font-size:.75rem;font-weight:500;cursor:pointer;transition:background var(--transition),border-color var(--transition);margin-top:.25rem}.footer-lang-btn:hover{background:var(--surface-soft);border-color:var(--border-strong)}.footer-lang-btn svg{width:14px;height:14px;stroke:var(--text-muted);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.footer-lang-btn .chevron{width:12px;height:12px;stroke:var(--text-muted);fill:none;stroke-width:2;transition:transform var(--transition)}.footer-lang-btn.is-open .chevron{transform:rotate(180deg)}.footer-lang-dropdown{display:none;position:absolute;bottom:100%;left:0;margin-bottom:.5rem;width:11rem;border-radius:.5rem;border:1px solid var(--border-soft);background:var(--surface-card);box-shadow:var(--shadow-lg);z-index:50;padding:.375rem}.footer-lang-dropdown.is-open{display:grid;grid-template-columns:1fr 1fr;gap:.125rem}.footer-lang-dropdown a{display:block;padding:.375rem .625rem;border-radius:.375rem;font-size:.75rem;color:var(--text-muted);transition:background var(--transition),color var(--transition);text-decoration:none}.footer-lang-dropdown a:hover{background:var(--surface-muted);color:var(--text-strong);text-decoration:none}.footer-lang-dropdown a.is-current{color:var(--accent);font-weight:500;background:var(--accent-soft)}.footer-lang-wrap{position:relative}.footer-col h3{margin:0 0 .75rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-strong)}.footer-col nav{display:flex;flex-direction:column;gap:.625rem}.footer-col a{font-size:.875rem;color:var(--text-muted);transition:color var(--transition);text-decoration:none}.footer-col a:hover{color:var(--text-strong);text-decoration:none}.footer__bottom{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border-soft);font-size:.75rem;color:var(--text-muted);line-height:1.6}.footer-card{text-align:center;font-size:.95rem;line-height:1.6;background:0 0}.footer-card a{color:inherit;font-weight:600}@media (max-width:640px){.site-header__inner{gap:.5rem}.password-card__row{flex-direction:column;align-items:stretch;text-align:left}.password-card__actions{justify-content:flex-end}.settings-footer{align-items:stretch}}.share-card{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}.share-card__list{display:grid;grid-template-columns:repeat(auto-fit,minmax(42px,1fr));gap:.75rem;width:100%;max-width:320px}.share-card__button{display:inline-flex;align-items:center;justify-content:center;width:100%;min-width:42px;aspect-ratio:1/1;border-radius:12px;border:1px solid rgba(148,163,184,.2);background:rgba(15,23,42,.4);color:var(--text-strong);font-size:1.1rem;transition:transform var(--transition),background var(--transition),border-color var(--transition)}.share-card__icon{display:inline-flex;width:18px;height:18px}.share-card__icon img{max-width:100%;max-height:100%}body[data-theme=light] .share-card__button{background:rgba(226,232,240,.7);color:#1f2937}.share-card__button:focus-visible,.share-card__button:hover{transform:translateY(-2px);border-color:var(--accent-border);background:rgba(99,102,241,.22)}body[data-theme=light] .share-card__button:focus-visible,body[data-theme=light] .share-card__button:hover{background:rgba(59,130,246,.24);border-color:rgba(59,130,246,.38)}.share-card__button span[aria-hidden=true]{font-weight:700;font-size:1rem}.info-card{border-radius:var(--radius-md);border:1px solid var(--border-soft);background:var(--surface-card);padding:1.25rem}.info-card p{margin:0;font-size:.875rem;color:var(--text-muted);line-height:1.6}.info-card a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.info-card a:hover{opacity:.8}.quick-links{display:grid;grid-template-columns:1fr;gap:.75rem}@media (min-width:640px){.quick-links{grid-template-columns:repeat(2,1fr)}}.quick-link{display:flex;align-items:flex-start;gap:1rem;border-radius:var(--radius-md);border:1px solid var(--border-soft);background:var(--surface-card);padding:1rem 1.25rem;text-decoration:none;transition:border-color var(--transition),background var(--transition)}.quick-link:hover{border-color:var(--accent-border);background:var(--accent-soft);text-decoration:none}.quick-link__icon{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:.5rem;background:var(--accent-soft);flex-shrink:0}.quick-link__icon svg{width:1.25rem;height:1.25rem;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.quick-link__content{display:flex;flex-direction:column;gap:.25rem;min-width:0}.quick-link__title{font-size:.875rem;font-weight:500;color:var(--text-strong);transition:color var(--transition)}.quick-link:hover .quick-link__title{color:var(--accent)}.quick-link__desc{font-size:.75rem;color:var(--text-muted);line-height:1.5}.hero--article{text-align:left}.hero--article .container{display:flex;flex-direction:column;gap:1rem}.eyebrow{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin:0}.cta-group{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.5rem}.article-content{text-align:left}.article-content h2{display:flex;align-items:center;gap:.75rem;font-size:clamp(1.15rem, 2.5vw, 1.4rem);font-weight:700;color:var(--text-strong);margin:2.5rem 0 1rem;line-height:1.3}.article-content h2:first-child{margin-top:0}.step-num{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;height:2rem;border-radius:50%;background:var(--accent);color:var(--text-inverse);font-size:.8rem;font-weight:700;flex-shrink:0}body[data-theme=light] .step-num{color:#fff}.article-content p{font-size:.95rem;line-height:1.7;color:var(--text-muted);margin:0 0 1rem}.article-content code{font-family:var(--font-mono);font-size:.85em;padding:.15em .4em;border-radius:4px;background:var(--surface-muted);color:var(--accent)}.article-content strong{color:var(--text-strong);font-weight:600}.article-content em{color:var(--accent);font-style:normal;font-weight:600}.article-content a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.article-content a:hover{opacity:.85}.article-content hr{border:none;height:1px;background:var(--border-soft);margin:2rem 0}.article-content ul{padding-left:1.25rem;margin:0 0 1rem}.article-content li{font-size:.95rem;line-height:1.7;color:var(--text-muted);margin-bottom:.35rem}.checklist-card{border-radius:var(--radius-md);border:1px solid var(--border-soft);background:var(--surface-soft);padding:1.5rem 2rem;margin:2rem 0}.checklist-card h2{margin-top:0!important;font-size:1.15rem!important;display:block!important}.checklist-card ul{list-style:none;padding:0;margin:1rem 0 0}.checklist-card li{padding:.4rem 0 .4rem 1.5rem;position:relative;font-size:.9rem;line-height:1.6;color:var(--text-muted)}.checklist-card li::before{content:"";position:absolute;left:0;top:.7em;width:7px;height:7px;border-radius:50%;background:var(--accent)}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:1.5rem 0}.comparison-table-v2{width:100%;border-collapse:separate;border-spacing:0;border-radius:var(--radius-md);border:1px solid var(--border-soft);overflow:hidden;font-size:.85rem}.comparison-table-v2 td,.comparison-table-v2 th{padding:.75rem .65rem;text-align:left;border-bottom:1px solid var(--border-soft)}.comparison-table-v2 thead th{background:var(--surface-soft);font-size:.7rem;font-weight:600;color:var(--text-muted)}.comparison-table-v2 tbody td{vertical-align:middle;color:var(--text-muted)}.comparison-table-v2 tbody td:first-child{font-weight:600;color:var(--text-strong)}.comparison-table-v2 tbody td:nth-child(2){font-family:var(--font-mono);font-size:.75rem}.comparison-table-v2 .check{color:var(--accent);font-size:1.1rem}.comparison-table-v2 .cross{color:var(--text-muted);opacity:.4;font-size:1.1rem}.comparison-table-v2 tbody tr:last-child td{border-bottom:none}@media (max-width:640px){.comparison-table-v2{font-size:.75rem}.comparison-table-v2 td,.comparison-table-v2 th{padding:.5rem .35rem}}.manager-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin:1.5rem 0}@media (min-width:640px){.manager-grid{grid-template-columns:repeat(2,1fr)}}.manager-card{border-radius:var(--radius-md);border:1px solid var(--border-soft);background:var(--surface-card);padding:1.25rem;display:flex;flex-direction:column;gap:.5rem}.manager-card__header{display:flex;align-items:center;justify-content:space-between}.manager-card__name{font-weight:700;color:var(--text-strong)}.manager-card__plan{font-size:.75rem;color:var(--text-muted)}.manager-card__tagline{font-size:.85rem;color:var(--accent);font-weight:500}.manager-card__details{display:flex;gap:2rem;margin-top:.25rem}.manager-card__detail-label{font-size:.7rem;color:var(--text-muted);display:block;margin-bottom:.15rem}.manager-card__detail-value{font-family:var(--font-mono);font-size:.8rem;color:var(--text-strong);font-weight:600}.manager-card__platforms{font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.recommendation-card{border-radius:var(--radius-md);border:1px solid var(--border-soft);background:var(--surface-soft);padding:1.5rem 2rem;margin:2rem 0}.recommendation-card h2{margin:0 0 1rem;font-size:1.15rem;color:var(--text-strong)}.recommendation-card p{font-size:.9rem;line-height:1.7;color:var(--text-muted);margin:0 0 1rem}.recommendation-card p:last-child{margin-bottom:0}.recommendation-card a{color:var(--accent);font-weight:600;text-decoration:none}.recommendation-card a:hover{text-decoration:underline}.criteria-section{margin:2rem 0}.criteria-section h2{font-size:clamp(1.2rem, 2.5vw, 1.5rem);font-weight:700;color:var(--text-strong);margin:0 0 1.5rem}.criteria-item{margin-bottom:1.25rem}.criteria-item h3{font-size:1rem;font-weight:600;color:var(--text-strong);margin:0 0 .4rem}.criteria-item p{font-size:.9rem;line-height:1.7;color:var(--text-muted);margin:0}