@font-face{font-family:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(data:font/woff2;base64,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)format("woff2-variations");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/assets/plus-jakarta-sans-vietnamese-wght-normal-qRpaaN48.woff2)format("woff2-variations");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/assets/plus-jakarta-sans-latin-ext-wght-normal-DmpS2jIq.woff2)format("woff2-variations");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/assets/plus-jakarta-sans-latin-wght-normal-eXO_dkmS.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f8fafc;--surface:#fff;--elevated:#e8f0fe;--overlay:#c7d2fe;--border:#e2e8f0;--border-2:#cbd5e1;--text:#1e293b;--text-2:#475569;--text-3:#94a3b8;--accent:#4f46e5;--accent-hover:#4338ca;--accent-dim:#4f46e514;--accent-glow:#4f46e52e;--accent-border:#4f46e538;--success:#059669;--success-dim:#0596691a;--success-glow:#05966938;--warning:#f59e0b;--warning-dim:#f59e0b1a;--error:#dc2626;--error-dim:#dc262614;--r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:18px;--r-full:999px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--surface);color:var(--text);min-height:100dvh;font-family:Plus Jakarta Sans Variable,Plus Jakarta Sans,system-ui,sans-serif;font-size:15px;line-height:1.6}.navbar{z-index:100;background:var(--surface);border-bottom:2px solid var(--border);position:sticky;top:0;box-shadow:0 1px 3px #0000000a,0 0 0 1px #ffffff80}.navbar-inner{justify-content:space-between;align-items:center;gap:1rem;max-width:90%;margin:0 auto;padding:.875rem 1.25rem;display:flex}.navbar .logo{color:var(--text);align-items:center;gap:9px;font-size:1.0625rem;font-weight:700;text-decoration:none;transition:opacity .15s;display:flex}.navbar .logo:hover{opacity:.85}.navbar .logo svg{color:var(--accent);filter:drop-shadow(0 0 6px var(--accent-glow))}.navbar .nav-toggle{cursor:pointer;background:0 0;border:none;flex-shrink:0;width:42px;height:36px;padding:4px;display:none}.navbar .nav-toggle svg{width:100%;height:100%}.navbar .nav-toggle:before,.navbar .nav-toggle:after{content:"";background:var(--text-2);border-radius:1px;width:22px;height:2px;transition:all .15s;position:absolute}.navbar .nav-toggle:before{top:8px}.navbar .nav-toggle:after{top:20px}.navbar .nav-toggle:hover:before,.navbar .nav-toggle:hover:after{background:var(--text)}.navbar .nav-toggle[aria-expanded=true]:before{top:7px;left:-6px;transform:rotate(45deg)}.navbar .nav-toggle[aria-expanded=true]:after{top:20px;left:-6px;transform:rotate(-45deg)}.navbar .nav-links{gap:1rem;display:flex}.navbar .nav-lang{white-space:nowrap}a{color:var(--accent);text-decoration:none;transition:color .15s}a:hover{color:var(--accent-hover)}h1{letter-spacing:-.035em;color:var(--text);font-size:2rem;font-weight:700;line-height:1.15}h2{letter-spacing:-.02em;color:var(--text);font-size:1.25rem;font-weight:700}h3{letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);font-size:.6875rem;font-weight:600}p{color:var(--text-2)}.page{width:90%;margin-inline:auto}.content{min-height:calc(100dvh - 64px);padding-top:2.5rem}button{border-radius:var(--r-md);cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--accent);color:#fff;border:none;outline:none;justify-content:center;align-items:center;gap:6px;padding:9px 18px;font-family:inherit;font-size:.875rem;font-weight:600;transition:all .15s;display:inline-flex}button:hover{background:var(--accent-hover);box-shadow:0 4px 14px var(--accent-glow)}button:active{box-shadow:none;transform:scale(.97)}button:focus-visible{box-shadow:0 0 0 3px var(--accent-dim);outline:2px solid var(--accent);outline-offset:2px}button.secondary{background:var(--surface);border:1.5px solid var(--border-2);color:var(--text-2)}button.secondary:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);box-shadow:none}button.ghost{color:var(--text-2);background:0 0;padding:5px 10px}button.ghost:hover{background:var(--elevated);color:var(--text);box-shadow:none}button.full-width{width:100%}button.sm{border-radius:var(--r-sm);padding:5px 11px;font-size:.8rem}.back-link{color:var(--text-2);border-radius:var(--r-sm);align-items:center;gap:4px;padding:5px 8px;font-size:.8125rem;font-weight:500;transition:all .15s;display:inline-flex}.back-link:hover{color:var(--text);background:var(--elevated);text-decoration:none}input[type=text],input[type=number]{background:var(--surface);border:1.5px solid var(--border-2);border-radius:var(--r-md);width:100%;color:var(--text);appearance:none;outline:none;padding:9px 13px;font-family:inherit;font-size:.9375rem;transition:border-color .15s,box-shadow .15s;display:block}input[type=text]::placeholder,input[type=number]::placeholder{color:var(--text-3)}input[type=text]:focus,input[type=number]:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}select{background:var(--surface);border:1.5px solid var(--border-2);border-radius:var(--r-md);width:100%;color:var(--text);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394A3B8' d='M6 8.5 1.5 4h9z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;outline:none;padding:9px 36px 9px 13px;font-family:inherit;font-size:.9375rem;transition:border-color .15s,box-shadow .15s;display:block}select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}select option{background:var(--surface)}input[type=checkbox]{appearance:none;border:1.5px solid var(--border-2);background:var(--surface);cursor:pointer;vertical-align:middle;border-radius:4px;flex-shrink:0;width:17px;height:17px;transition:all .15s;position:relative}input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}input[type=checkbox]:checked:after{content:"";border:2px solid #fff;border-top:none;border-left:none;width:6px;height:10px;position:absolute;top:1px;left:4px;transform:rotate(45deg)}input[type=checkbox]:focus-visible{box-shadow:0 0 0 3px var(--accent-dim)}label{color:var(--text-2);margin-bottom:6px;font-size:.8125rem;font-weight:600;display:block}.tool-nav{border-bottom:1.5px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1.25rem;display:flex}.tool-nav .tool-title{color:var(--text);font-size:.9375rem;font-weight:700}.tool-nav .nav-actions{align-items:center;gap:6px;display:flex}.ghost{border-color:var(--border)!important;color:var(--text-3)!important;box-shadow:none!important;background:0 0!important}.ghost:hover{border-color:var(--error)!important;color:var(--error)!important;background:var(--error-dim)!important}.tool-subtitle{color:var(--text-2);margin-bottom:1.75rem;font-size:.875rem;line-height:1.65}.section{margin-bottom:2.25rem}.section>h3{margin-bottom:.875rem}.field-error{color:var(--error);margin-top:5px;font-size:.75rem;font-weight:500;display:block}.field-group{margin-bottom:1rem}.field-group .field-error{color:var(--error);margin-top:5px;font-size:.75rem;font-weight:500;display:block}.accordion{border:1.5px solid var(--border);border-radius:var(--r-md);margin-bottom:12px;overflow:hidden}.accordion--open{border-color:var(--accent-border)}.accordion-trigger{background:var(--surface);cursor:pointer;width:100%;color:var(--text);text-align:left;box-shadow:none;border:none;justify-content:space-between;align-items:center;padding:12px 14px;font-size:.9rem;font-weight:600;display:flex}.accordion-trigger:hover{background:var(--elevated);box-shadow:none}.accordion-trigger:active{transform:none}.accordion-chevron{color:var(--text-3);flex-shrink:0;transition:transform .2s}.accordion--open .accordion-chevron{transform:rotate(180deg)}.accordion-body{border-top:1.5px solid var(--border);background:var(--surface);padding:12px 14px}.accordion--open .accordion-body{border-color:var(--accent-border)}.add-row{gap:8px;display:flex}.add-row input{flex:1}.add-row button{flex-shrink:0}.chips{flex-wrap:wrap;gap:6px;min-height:28px;margin-bottom:10px;display:flex}.chip{background:var(--accent-dim);border:1.5px solid var(--accent-border);color:var(--accent-hover);border-radius:var(--r-full);align-items:center;gap:4px;padding:3px 6px 3px 10px;font-size:.8rem;font-weight:600;display:inline-flex}.chip .chip-remove{color:var(--accent-hover);opacity:.5;cursor:pointer;border-radius:var(--r-full);-webkit-user-select:none;user-select:none;background:0 0;border:none;padding:0 3px;font-size:.95rem;line-height:1;transition:opacity .15s}.chip .chip-remove:hover{opacity:1;box-shadow:none;background:0 0}.chip .chip-remove:active{transform:none}.chip-add{opacity:.5;cursor:pointer;background:0 0;border-style:dashed;padding:3px 10px;font-size:1rem;line-height:1;transition:opacity .15s}.chip-add:hover{opacity:1;box-shadow:none}.chip-add:active{transform:none}.feedback{text-align:center;margin-top:.625rem;font-size:.8125rem;font-weight:600}.feedback.success{color:var(--success)}.feedback.error{color:var(--error)}.hint-text{color:var(--text-3);text-align:center;padding:1.5rem 0;font-size:.8rem}.home-header{text-align:center;background:linear-gradient(180deg, var(--elevated) 0%, transparent 100%);border-radius:var(--r-lg);flex-direction:column;align-items:center;margin-bottom:2rem;padding:1.5rem 0;display:flex}.home-header h1{letter-spacing:-.025em;background:linear-gradient(135deg, var(--text) 0%, var(--accent) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:1.75rem;font-weight:800}.home-header p{color:var(--text-2);max-width:420px;font-size:.9375rem;line-height:1.65}.home-hero{margin-bottom:2rem}.tool-cards{flex-direction:column;gap:12px;max-width:640px;margin-inline:auto;display:flex}.tool-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--r-xl);cursor:pointer;align-items:center;gap:1.125rem;padding:1.375rem 1.5rem;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;position:relative;box-shadow:0 2px 8px #0000000f}.tool-card:hover{border-color:var(--accent);background:linear-gradient(135deg, var(--elevated) 0%, var(--surface) 100%);color:inherit;text-decoration:none;transform:translateY(-2px);box-shadow:0 8px 24px #0d94881f,0 2px 8px #00000014}.tool-card:active{transform:translateY(0)}.tool-card .tool-icon{background:linear-gradient(135deg, var(--elevated) 0%, var(--surface) 100%);border-radius:var(--r-lg);border:2px solid var(--border);flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.5rem;transition:all .2s;display:flex;position:relative}.tool-card .tool-icon:after{content:"";border-radius:inherit;border:2px solid var(--accent);opacity:0;padding:3px;transition:opacity .2s;position:absolute;inset:-3px}.tool-card .tool-icon:hover:after{opacity:1}.tool-card .tool-info{flex:1;min-width:0}.tool-card .tool-name{color:var(--text);letter-spacing:-.01em;font-size:1rem;font-weight:700;line-height:1.35}.tool-card .tool-desc{color:var(--text-2);margin-top:3px;font-size:.875rem;line-height:1.5}.info-btn{background:var(--elevated);border:1.5px solid var(--border);width:32px;min-width:32px;height:32px;color:var(--text-3);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:all .18s;display:flex}.info-btn svg{transition:color .18s}.info-btn:hover{background:var(--accent-dim);border-color:var(--accent-border);color:var(--accent);box-shadow:0 2px 8px var(--accent-glow);transform:scale(1.06)}.info-btn:active{box-shadow:none;transform:scale(.94)}.modal-backdrop{-webkit-backdrop-filter:blur(6px);z-index:200;opacity:0;background:#0f172a52;justify-content:center;align-items:center;padding:1.25rem;transition:opacity .22s;display:flex;position:fixed;inset:0}.modal-backdrop.open{opacity:1}.modal-backdrop.open .modal{opacity:1;transform:translateY(0)}.modal{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);opacity:0;width:100%;max-width:460px;max-height:88dvh;padding:1.75rem;transition:transform .22s,opacity .22s;position:relative;overflow-y:auto;transform:translateY(14px);box-shadow:0 20px 60px #0000001a,0 4px 16px #0000000f}.modal:before{content:"";background:linear-gradient(90deg, transparent, var(--accent), transparent);border-radius:0 0 4px 4px;height:2px;position:absolute;top:0;left:10%;right:10%}.modal-close{background:var(--elevated);border:1.5px solid var(--border);width:28px;min-width:28px;height:28px;color:var(--text-2);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:1rem;transition:all .15s;display:flex;position:absolute;top:1rem;right:1rem}.modal-close:hover{background:var(--overlay);color:var(--text);box-shadow:none}.modal-close:active{box-shadow:none;transform:scale(.93)}.modal-header{align-items:center;gap:.875rem;margin-bottom:1rem;padding-right:2rem;display:flex}.modal-header .modal-icon{background:var(--elevated);border:1.5px solid var(--border);border-radius:var(--r-lg);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.375rem;display:flex}.modal-header h2{letter-spacing:-.02em;font-size:1.125rem;font-weight:700}.modal-desc{color:var(--text-2);margin-bottom:1.5rem;font-size:.9rem;line-height:1.7}.modal-section-title{letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:.75rem;font-size:.6875rem;font-weight:600}.modal-steps{counter-reset:steps;flex-direction:column;gap:10px;margin-bottom:1.25rem;list-style:none;display:flex}.modal-steps li{counter-increment:steps;color:var(--text-2);align-items:flex-start;gap:12px;font-size:.875rem;line-height:1.6;display:flex}.modal-steps li:before{content:counter(steps);background:var(--accent-dim);border:1.5px solid var(--accent-border);min-width:22px;height:22px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;font-size:.7rem;font-weight:700;display:flex}.modal-note{background:var(--elevated);border:1.5px solid var(--border);border-radius:var(--r-md);color:var(--text-2);align-items:flex-start;gap:10px;padding:11px 14px;font-size:.8125rem;line-height:1.6;display:flex}.modal-note:before{content:"✦";color:var(--accent);flex-shrink:0;margin-top:3px;font-size:.65rem}.modal-confirm{max-width:360px}.modal-confirm h2{margin-bottom:8px;font-size:1.1rem}.modal-confirm .modal-desc{margin-bottom:20px}.modal-confirm-actions{justify-content:flex-end;gap:10px;display:flex}.modal-confirm-actions button{margin:0;padding:8px 18px;font-size:.9rem}@media (width>=1024px){.content{padding-top:2.75rem}.home-header{margin-bottom:3rem;padding:2rem 0}.home-header h1{font-size:2.25rem}.home-header p{font-size:1rem}.tool-cards{gap:14px}.tool-card{border-radius:var(--r-xl);padding:1.5rem 1.75rem}.tool-card .tool-icon{width:56px;height:56px;font-size:1.625rem}.tool-card .tool-name{font-size:1.0625rem}.tool-card .tool-desc{font-size:.875rem}.tool-card .tool-arrow{font-size:1rem;right:1.75rem}button{padding:10px 20px;font-size:.9rem}button.sm{padding:6px 13px;font-size:.875rem}.modal-backdrop{padding:1.75rem}.modal{border-radius:var(--r-xl);max-width:540px;max-height:92dvh;padding:2rem}.modal-header{padding-right:2.5rem}.modal-header .modal-icon{width:48px;height:48px;font-size:1.5rem}.modal-header h2{font-size:1.25rem}.modal-desc{font-size:.95rem}.modal-steps{gap:12px}.modal-steps li{font-size:.9rem}.modal-steps li:before{min-width:24px;height:24px;font-size:.75rem}.modal-note{padding:13px 16px;font-size:.875rem}}@media (width>=768px) and (width<=1023px){.content{padding-top:2.5rem}.home-header{margin-bottom:2.5rem;padding:1.5rem 0}.home-header h1{font-size:1.75rem}.home-header p{font-size:.9375rem}.tool-cards{gap:12px}.tool-card{border-radius:var(--r-xl);padding:1.25rem 1.5rem}.tool-card .tool-icon{width:48px;height:48px;font-size:1.375rem}.tool-card .tool-name{font-size:.95rem}.tool-card .tool-desc{font-size:.825rem}.tool-card .tool-arrow{font-size:.875rem;right:1.5rem}button{padding:8px 16px;font-size:.875rem}button.sm{padding:5px 11px;font-size:.825rem}.modal-backdrop{padding:1.5rem}.modal{border-radius:var(--r-xl);max-width:520px;max-height:90dvh;padding:1.75rem}.modal-header{padding-right:2.25rem}.modal-header .modal-icon{width:46px;height:46px;font-size:1.375rem}.modal-header h2{font-size:1.1875rem}.modal-desc{font-size:.925rem}.modal-steps{gap:11px}.modal-steps li{font-size:.875rem}.modal-steps li:before{min-width:23px;height:23px;font-size:.725rem}.modal-note{padding:12px 15px;font-size:.85rem}}@media (width<=480px){.content{padding-top:2rem}.home-header{flex-direction:column;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1.25rem 0}.home-header .logo{justify-content:center;width:100%}.home-header button{width:100%}.home-hero{margin-bottom:1.25rem}.home-hero h1{font-size:1.375rem}.home-hero p{font-size:.875rem}.tool-cards{gap:10px}.tool-card{flex-direction:column;align-items:flex-start;gap:.75rem;padding:1.125rem 1.25rem}.tool-card:hover{transform:none}.tool-card .tool-icon{width:40px;height:40px;font-size:1.25rem}.tool-card .tool-name{font-size:.9rem}.tool-card .tool-desc{font-size:.75rem}.tool-card .tool-arrow{display:none}.info-btn{margin-left:auto;position:static}button{padding:7px 14px;font-size:.85rem}button.sm{padding:4px 9px;font-size:.75rem}.navbar-inner{padding:.75rem 1rem}.nav-toggle{justify-content:center;align-items:center;display:flex}.nav-links,.nav-lang{display:none!important}.nav-menu{background:var(--surface);z-index:99;flex-direction:column;gap:8px;padding:calc(100dvh - 56px) 1.25rem 1.25rem;transition:transform .2s;display:flex;position:fixed;inset:0;transform:translate(100%)}.nav-menu.open{transform:translate(0)}.nav-menu a{border-radius:var(--r-md);color:var(--text);padding:12px 14px;font-size:.9375rem;font-weight:600;text-decoration:none;transition:all .15s;display:block}.nav-menu a:hover{background:var(--accent-dim);color:var(--accent-hover)}.nav-menu button{align-self:center;margin-top:auto}}@media (width>=481px) and (width<=600px){.content{padding-top:2.25rem}.home-header{margin-bottom:2.25rem;padding:1.75rem 0}.home-header h1{font-size:1.625rem}.home-header p{font-size:.9rem}.home-hero{margin-bottom:2rem}.home-hero h1{font-size:1.75rem}.home-hero p{font-size:.9375rem}.tool-cards{gap:11px}.tool-card{border-radius:var(--r-xl);padding:1.25rem 1.375rem}.tool-card .tool-icon{width:46px;height:46px;font-size:1.375rem}.tool-card .tool-name{font-size:.9375rem}.tool-card .tool-desc{font-size:.825rem}.tool-card .tool-arrow{font-size:.875rem;right:1.375rem}button{padding:6px 12px;font-size:.85rem}button.sm{padding:4px 9px;font-size:.75rem}}@media (width<=360px){.content{padding-top:1.875rem}.home-header{margin-bottom:1.25rem;padding:1rem 0}.home-hero{margin-bottom:1.125rem}.home-hero h1{font-size:1.25rem}.home-hero p{font-size:.8125rem}.tool-cards{gap:8px}.tool-card{flex-direction:column;align-items:flex-start;gap:.75rem;padding:1rem}.tool-card:hover{transform:none}.tool-card .tool-icon{width:36px;height:36px;font-size:1.125rem}.tool-card .tool-name{font-size:.875rem}.tool-card .tool-desc{font-size:.7rem}.tool-card .tool-arrow{display:none}.info-btn{margin-left:auto;position:static}button{padding:6px 12px;font-size:.8rem}button.sm{padding:3px 8px;font-size:.7rem}}.scheduler-layout{align-items:flex-start;gap:14px;display:flex}.scheduler-main{flex:1;min-width:0}.schedule-sidebar{flex-direction:column;flex-shrink:0;gap:3px;width:140px;display:flex}@media (width<=560px){.schedule-sidebar{scrollbar-width:none;flex-direction:row;width:100%;padding-bottom:4px;overflow-x:auto}.schedule-sidebar::-webkit-scrollbar{display:none}}.sched-entry{border-radius:var(--r-md);color:var(--text-2);cursor:pointer;text-align:left;background:0 0;border:1.5px solid #0000;justify-content:space-between;align-items:center;gap:4px;width:100%;padding:7px 10px;font-size:.78rem;font-weight:500;transition:background .12s,border-color .12s,color .12s;display:flex}.sched-entry:hover:not(.add-sched){background:var(--elevated);border-color:var(--border)}.sched-entry.active{background:var(--surface);border-color:var(--accent-border);color:var(--accent-hover);font-weight:600}.sched-entry.add-sched{color:var(--text-3);border-style:dashed;border-color:var(--border);justify-content:center;margin-top:4px;font-size:.75rem}.sched-entry.add-sched:hover{color:var(--accent);border-color:var(--accent-border);background:var(--accent-dim)}@media (width<=560px){.sched-entry{white-space:nowrap;flex-shrink:0;width:auto}.sched-entry.add-sched{margin-top:0}}.sched-entry-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.sched-entry-input{min-width:0;color:var(--text);background:0 0;border:none;outline:none;flex:1;width:100%;margin:0;padding:0;font-size:.78rem;font-weight:600}.sched-entry-remove{color:var(--text-3);opacity:0;border-radius:3px;flex-shrink:0;padding:1px 3px;font-size:.8rem;line-height:1;transition:opacity .12s,color .12s,background .12s}.sched-entry:hover .sched-entry-remove{opacity:1}.sched-entry-remove:hover{color:var(--error);background:var(--error-dim)}.sched-tabs{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);flex-wrap:wrap;gap:3px;margin-bottom:1rem;padding:4px;display:flex}.sched-tab{color:var(--text-2);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;align-items:center;gap:5px;padding:5px 11px;font-size:.78rem;font-weight:500;transition:background .12s,color .12s;display:inline-flex}.sched-tab:hover:not(.add-tab):not(.link-tab){background:var(--tab-color-dim,var(--overlay))}.sched-tab.active{background:var(--tab-color,var(--accent));color:#fff}.sched-tab.active .tab-remove{color:#ffffffa6}.sched-tab.active .tab-remove:hover{color:#fff}.sched-tab.active .tab-dot{display:none}.sched-tab.add-tab{color:var(--text-3);padding:4px 10px;font-size:1rem;font-weight:600}.sched-tab.add-tab:hover{color:var(--accent);background:var(--accent-dim)}.sched-tab.link-tab{color:var(--text-3);padding:5px 9px}.sched-tab.link-tab:hover{color:var(--accent);background:var(--accent-dim)}.sched-tab.link-tab.active{background:var(--accent-dim);color:var(--accent)}.tab-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.tab-remove{color:var(--text-3);border-radius:3px;margin-left:1px;padding:1px 2px;font-size:.85rem;line-height:1}.tab-remove:hover{color:var(--error);background:#dc262614}.link-import-form{background:var(--surface);border:1.5px solid var(--accent-border);border-radius:var(--r-lg);box-shadow:0 2px 10px var(--accent-dim);flex-direction:column;gap:8px;margin-bottom:1rem;padding:14px;display:flex}.link-import-form input{margin:0}.link-import-header{justify-content:space-between;align-items:center;margin-bottom:2px;display:flex}.link-import-label{color:var(--text-3);letter-spacing:.06em;text-transform:uppercase;font-size:.72rem;font-weight:700}.link-cancel{width:24px;height:24px;color:var(--text-3);cursor:pointer;border-radius:var(--r-sm);flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;transition:color .12s,background .12s;display:flex}.link-cancel:hover{color:var(--error);background:#dc262614}.participant-name-field{margin-bottom:.75rem}.participants-badge{background:var(--accent-dim);border:1.5px solid var(--accent-border);border-radius:var(--r-full);color:var(--text-2);align-items:center;gap:6px;margin-bottom:1.25rem;padding:5px 13px;font-size:.8rem;display:inline-flex}.participants-badge strong{color:var(--accent-hover);font-weight:600}.grid-scroll{-webkit-overflow-scrolling:touch;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);margin:1.25rem 0;padding:.875rem;overflow-x:auto;box-shadow:0 1px 4px #0000000a}.sched-grid{grid-template-columns:36px repeat(7,minmax(30px,1fr));gap:3px;min-width:268px;display:grid}.sched-grid.read-only .sched-cell.slot:not(.mine):not(.solo):not(.partial){cursor:default}.sched-grid.read-only .sched-cell.slot:not(.mine):not(.solo):not(.partial):hover{opacity:.8}.sched-cell{border-radius:5px;justify-content:center;align-items:center;height:30px;display:flex}.sched-cell.hour-lbl{color:var(--text-3);cursor:default;letter-spacing:.02em;justify-content:flex-end;padding-right:5px;font-size:.575rem;font-weight:500}.sched-cell.day-lbl{color:var(--text-2);cursor:default;letter-spacing:.06em;text-transform:uppercase;font-size:.625rem;font-weight:700}.sched-cell.slot{background:var(--bg);border:1.5px solid var(--border);cursor:crosshair;-webkit-user-select:none;user-select:none;transition:background .1s,border-color .1s,box-shadow .1s}.sched-cell.slot:hover{background:var(--overlay);border-color:var(--border-2)}.sched-cell.slot.mine{background:var(--mine-color,var(--accent));border-color:var(--mine-color,var(--accent));box-shadow:0 0 0 1px var(--mine-dim,#0d94884d), 0 2px 6px var(--mine-dim,#0d948840)}.sched-cell.slot.solo{background:var(--solo-bg,var(--accent-dim));border-color:var(--solo-border,var(--accent-border));cursor:default}.sched-cell.slot.partial{background:var(--partial-bg);border-color:var(--partial-border);opacity:calc(var(--overlap-ratio,0) * .7);cursor:default}.sched-cell.slot.all-match{cursor:default;background:#4f46e5;border-color:#4338ca;box-shadow:0 0 0 1px #4f46e559,0 2px 8px #4f46e540}.sched-cell.slot.all-others{background:#0d948833;border-color:#0d948859}.sched-cell.slot.others{background:var(--warning-dim);border-color:#0d948833}.sched-cell.slot.mine.others{background:var(--accent);border:2px solid var(--success)}.sched-cell.slot.overlap{background:var(--success);border-color:var(--success);box-shadow:0 0 0 1px var(--success-glow), 0 2px 6px var(--success-dim)}.sched-cell.slot.mine.overlap{background:var(--success);border-color:var(--success);box-shadow:0 0 0 1px var(--success-glow), 0 2px 8px var(--success-dim)}.overlap-legend{color:var(--text-2);flex-wrap:wrap;align-items:center;gap:.875rem;margin-bottom:1.5rem;font-size:.75rem;font-weight:500;display:flex}.overlap-legend .legend-item{align-items:center;gap:5px;display:flex}.overlap-legend .dot{border-radius:3px;flex-shrink:0;width:10px;height:10px}.overlap-legend .dot.mine{background:var(--accent)}.overlap-legend .dot.all-others{background:#0d948859}.overlap-legend .dot.others{background:var(--warning);opacity:.55}.overlap-legend .dot.overlap{background:var(--success)}.overlap-legend .dot.partial-legend{background:#0d948859}.overlap-legend .dot.all-label{background:#4f46e5}.results-panel{flex-direction:column;gap:.875rem;margin-bottom:1.25rem;display:flex}.results-section{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);padding:.75rem 1rem}.results-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin-bottom:.5rem;font-size:.7rem;font-weight:700}.results-label.success-label{color:var(--success)}.results-label.all-match-label{color:#4338ca}.results-chips{flex-wrap:wrap;gap:.375rem;display:flex}.result-chip{border-radius:var(--r-full);align-items:center;padding:3px 10px;font-size:.75rem;font-weight:500;display:inline-flex}.result-chip.overlap-chip{color:var(--success);background:#134e4a14;border:1px solid #134e4a38}.result-chip.all-match-chip{color:#4f46e5;background:#4f46e51a;border:1px solid #4f46e547}.result-chip.others-chip{color:var(--text-2);background:#0d948812;border:1px solid #0d94882e}.share-wrap{position:relative}.share-panel{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);z-index:10;position:absolute;bottom:calc(100% + 8px);left:0;right:0;overflow:hidden;box-shadow:0 8px 24px #0000001a,0 2px 8px #0000000f}.share-option{border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;width:100%;color:var(--text);background:0 0;border-radius:0;flex-direction:column;align-items:flex-start;gap:2px;padding:11px 16px;transition:background .12s;display:flex}.share-option:last-child{border-bottom:none}.share-option:hover{background:var(--elevated);box-shadow:none}.share-option:active{box-shadow:none;transform:none}.share-option .share-option-title{color:var(--text);font-size:.875rem;font-weight:600}.share-option .share-option-hint{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:.72rem;overflow:hidden}.results-empty{color:var(--text-3);margin:0;font-size:.8rem}.expense-list{flex-direction:column;gap:10px;margin-bottom:12px;display:flex}.expense-item{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-md);align-items:center;gap:12px;padding:12px 14px;transition:border-color .18s,box-shadow .18s,transform .15s;display:flex;box-shadow:0 1px 3px #0000000a}.expense-item:hover{border-color:var(--border-2);transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.expense-item:active{transform:translateY(0)}.expense-item .expense-info{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.expense-item .exp-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.9375rem;font-weight:600;overflow:hidden}.expense-item .exp-meta{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:.75rem;overflow:hidden}.expense-item .exp-amount{color:var(--text);white-space:nowrap;font-size:1rem;font-weight:700}.expense-item .remove-btn{color:var(--text-3);border-radius:var(--r-sm);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:6px 10px;font-size:1rem;line-height:1;transition:all .15s}.expense-item .remove-btn:hover{color:var(--error);background:var(--error-dim);box-shadow:none}.expense-item .remove-btn:active{transform:scale(.95)}.expense-form{background:var(--elevated);border:1.5px solid var(--border);border-radius:var(--r-lg);flex-direction:column;gap:12px;padding:16px;display:flex;box-shadow:0 2px 8px #0000000f}.expense-form .form-group{flex-direction:column;gap:6px;display:flex}.expense-form .form-group input[type=text]{font-size:1rem}.expense-form .form-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.expense-form .form-field{flex-direction:column;gap:4px;display:flex}.expense-form .form-field .field-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:600}.expense-form .form-field input,.expense-form .form-field select{font-size:.9375rem}.expense-form .participants-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.expense-form .participants-header .participants-actions{gap:4px;display:flex}.expense-form .checkbox-label{color:var(--text-2);margin-bottom:0;font-size:.8rem;font-weight:600}.expense-form .checkbox-list{flex-wrap:wrap;gap:8px 12px;display:flex}.expense-form .checkbox-item{color:var(--text-2);cursor:pointer;border-radius:var(--r-sm);-webkit-user-select:none;user-select:none;align-items:center;gap:6px;padding:4px 8px;font-size:.8rem;font-weight:500;transition:all .15s;display:inline-flex}.expense-form .checkbox-item:hover{background:var(--surface);color:var(--text)}.expense-form .checkbox-item input[type=checkbox]{appearance:none;border:1.5px solid var(--border-2);background:var(--surface);cursor:pointer;vertical-align:middle;border-radius:4px;flex-shrink:0;width:17px;height:17px;transition:all .15s;position:relative}.expense-form .checkbox-item input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.expense-form .checkbox-item input[type=checkbox]:checked:after{content:"";border:2px solid #fff;border-top:none;border-left:none;width:6px;height:10px;position:absolute;top:1px;left:4px;transform:rotate(45deg)}.expense-form .checkbox-item input[type=checkbox]:focus-visible{box-shadow:0 0 0 3px var(--accent-dim)}.expense-form .checkbox-item .checkbox-name{line-height:1.4}.checkboxes{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-md);flex-wrap:wrap;gap:8px 12px;padding:10px 12px;display:flex}.checkboxes label{color:var(--text-2);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:7px;margin-bottom:0;font-size:.8125rem;font-weight:500;transition:color .15s;display:inline-flex}.checkboxes label:hover{color:var(--text)}.bills-tabs{scrollbar-width:none;align-items:center;gap:4px;margin-bottom:1.25rem;padding-bottom:2px;display:flex;overflow-x:auto}.bills-tabs::-webkit-scrollbar{display:none}.bills-tabs .bill-tab{border-radius:var(--r-sm);border:1.5px solid var(--border);background:var(--surface);cursor:pointer;white-space:nowrap;color:var(--text-3);-webkit-user-select:none;user-select:none;flex-shrink:0;align-items:center;gap:4px;padding:5px 10px;font-size:.8rem;font-weight:500;transition:all .15s;display:flex}.bills-tabs .bill-tab:hover{border-color:var(--border-2);color:var(--text-2)}.bills-tabs .bill-tab.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);font-weight:600}.bills-tabs .bill-tab .tab-name{text-overflow:ellipsis;max-width:120px;overflow:hidden}.bills-tabs .bill-tab .tab-close{color:var(--text-3);cursor:pointer;box-shadow:none;background:0 0;border:none;border-radius:2px;flex-shrink:0;padding:0 2px;font-size:.875rem;line-height:1;transition:all .12s}.bills-tabs .bill-tab .tab-close:hover{color:var(--error);background:var(--error-dim);box-shadow:none}.bills-tabs .bill-tab .tab-rename-input{color:var(--accent);background:0 0;border:none;outline:none;width:80px;min-width:0;padding:0;font-size:.8rem;font-weight:600}.bills-tabs .bill-tab-add{border-radius:var(--r-sm);border:1.5px dashed var(--border-2);width:28px;height:28px;color:var(--text-3);cursor:pointer;box-shadow:none;background:0 0;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;transition:all .15s;display:flex}.bills-tabs .bill-tab-add:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);box-shadow:none}.currency-bar{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:1.5rem;display:flex}.currency-bar .currency-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;margin-right:2px;font-size:.75rem;font-weight:600}.currency-bar .currency-btn{border-radius:var(--r-sm);background:var(--surface);border:1.5px solid var(--border-2);color:var(--text-3);cursor:pointer;box-shadow:none;padding:4px 10px;font-size:.8rem;font-weight:600;transition:all .15s}.currency-bar .currency-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);box-shadow:none}.currency-bar .currency-btn:active{transform:scale(.96)}.currency-bar .currency-btn.active{background:var(--accent-dim);border-color:var(--accent-border);color:var(--accent)}.settlement-list{flex-direction:column;gap:8px;margin-bottom:1.25rem;display:flex}.txn-item{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-md);justify-content:space-between;align-items:center;padding:12px 16px;transition:border-color .18s,box-shadow .18s,opacity .18s;display:flex;box-shadow:0 1px 3px #0000000a}.txn-item:hover{border-color:var(--border-2);box-shadow:0 4px 12px #00000014}.txn-item.txn-paid{opacity:.5;border-color:var(--success)}.txn-item.txn-paid .txn-names{text-decoration:line-through}.txn-item.txn-paid .txn-amount{color:var(--text-3)}.txn-item .txn-names{color:var(--text);align-items:center;gap:6px;min-width:0;font-size:.9375rem;display:flex}.txn-item .txn-names strong{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.txn-item .txn-arrow{color:var(--text-3);flex-shrink:0;font-size:.75rem}.txn-item .txn-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.txn-item .txn-amount{color:var(--success);white-space:nowrap;font-size:1rem;font-weight:700}.txn-item .txn-paid-btn{border-radius:var(--r-sm);border:1.5px solid var(--border-2);color:var(--text-3);cursor:pointer;white-space:nowrap;box-shadow:none;background:0 0;flex-shrink:0;padding:3px 9px;font-size:.75rem;transition:all .15s}.txn-item .txn-paid-btn:hover{border-color:var(--success);color:var(--success);background:var(--success-dim);box-shadow:none}.txn-item .txn-paid-btn:active{transform:scale(.95)}.txn-item .txn-paid-btn.is-paid{border-color:var(--success);color:var(--success);background:var(--success-dim)}.all-settled{text-align:center;color:var(--success);padding:1.5rem 0;font-size:1rem;font-weight:600}.settlement-summary{border-top:1px solid var(--border);justify-content:space-between;margin-top:.5rem;padding:.5rem .25rem 0;font-size:.8rem;display:flex}.settlement-summary .summary-paid{color:var(--success)}.settlement-summary .summary-pending{color:var(--text-3)}.total-line{color:var(--text-3);text-align:right;margin-bottom:1rem;font-size:.875rem}.total-line strong{color:var(--text-2)}@media (width<=480px){.expense-item{gap:10px;padding:10px 12px}.expense-item .exp-name{font-size:.9rem}.expense-item .exp-meta{font-size:.7rem}.expense-item .exp-amount{font-size:.9375rem}.expense-form{padding:14px}.expense-form .form-row{grid-template-columns:1fr}.expense-form .form-field .field-label{display:none}.expense-form .checkbox-item{padding:3px 6px;font-size:.75rem}.settlement-list{gap:6px}.txn-item{padding:10px 12px}.txn-names{font-size:.875rem}.txn-amount{font-size:.9375rem}}@media (width>=481px) and (width<=768px){.expense-form{padding:14px}.expense-form .form-row{grid-template-columns:1fr 1fr}}
