@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700&family=DM+Sans:wght@400;500;600&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--navy:#08203a;--blue:#1560a8;--sky:#3896d8;--pool:#d6eef9;--foam:#edf6fb;--gold:#c07010;--white:#fff;--ink:#1a2e42;--muted:#607080;--light:#f4f8fb;--line:#dce8f0;--red:#c93b3b;--green:#258a4c;--fh:"Playfair Display",Georgia,serif;--fb:"DM Sans",system-ui,sans-serif;--r:10px;--sh:0 2px 16px rgba(8,32,58,.09)}body.dark{--navy:#0a1628;--blue:#4a9eda;--sky:#5aaeea;--pool:#1a2d42;--foam:#141e2e;--gold:#d4913a;--white:#1e2d3d;--ink:#c8daea;--muted:#7a9ab5;--light:#111a27;--line:#2a3d52;--red:#e05555;--green:#3aaa6a;--sh:0 2px 16px rgba(0,0,0,.35)}body.dark .hdr,body.dark .gate{background:#060e1a}body.dark .gate-card,body.dark .modal-box{background:var(--white)}body.dark .modal-overlay{background:#000000b3}body.dark input,body.dark select,body.dark textarea{background:var(--foam);color:var(--ink);border-color:var(--line)}body.dark input:focus,body.dark select:focus{border-color:var(--sky)}body.dark .mrow:hover,body.dark .mrow.sel{background:var(--pool)}body{font-family:var(--fb);background:var(--light);color:var(--ink);min-height:100vh;transition:background-color .3s ease,color .3s ease}.dark-toggle{background:transparent;border:1.5px solid rgba(255,255,255,.2);border-radius:7px;padding:.38rem .65rem;cursor:pointer;color:#9ec8e8;display:flex;align-items:center;transition:all .2s;flex-shrink:0}.dark-toggle:hover{background:#ffffff1a;color:#fff}.dark-toggle svg{width:15px;height:15px}.gate{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--navy);z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem}.gate-card{background:var(--white);border-radius:14px;box-shadow:0 12px 48px #0006;padding:2.4rem;width:100%;max-width:380px;text-align:center}.gate-icon{font-size:2.6rem;margin-bottom:.7rem}.gate-title{font-family:var(--fh);font-size:1.6rem;color:var(--ink);margin-bottom:.4rem}.gate-sub{font-size:.88rem;color:var(--muted);line-height:1.55;margin-bottom:1.6rem}.gate-field{display:flex;flex-direction:column;gap:.3rem;margin-bottom:1rem;text-align:left}.gate-field label{font-size:.74rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.gate-field input{font-family:var(--fb);font-size:1rem;padding:.68rem .9rem;border:1.5px solid var(--line);border-radius:8px;color:var(--ink);width:100%;transition:border-color .2s,box-shadow .2s;background:var(--white)}.gate-field input:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 3px #3896d821}.gate-btn{width:100%;font-family:var(--fb);font-size:1rem;font-weight:600;background:var(--blue);color:#fff;border:none;border-radius:9px;padding:.8rem;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 14px #1560a847}.gate-btn:hover{background:var(--navy)}.gate-btn:disabled{opacity:.55;cursor:not-allowed}.gate-err{background:#fde8e8;border:1px solid #f0cccc;color:var(--red);border-radius:8px;padding:.65rem .9rem;font-size:.86rem;margin-top:.8rem}.hdr{background:var(--navy);height:60px;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:300;box-shadow:0 2px 14px #0000004d}.hdr-logo{display:flex;align-items:center;gap:.65rem;text-decoration:none;cursor:pointer}.hdr-icon{width:36px;height:36px;border-radius:50%;background:var(--sky);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}.hdr-name{font-family:var(--fh);color:#fff;font-size:1.05rem;line-height:1.2}.hdr-sub{color:#9ec8e8;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase}.hdr-right{display:flex;align-items:center;gap:.7rem}.hdr-user{display:flex;align-items:center;gap:.45rem;color:#9ec8e8;font-size:.78rem}.hdr-user-dot{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0}.hdr-role{font-size:.65rem;font-weight:600;padding:.18rem .6rem;border-radius:20px;text-transform:uppercase;letter-spacing:.05em;background:#3896d84d;color:#7fd4ff}.hdr-new{font-family:var(--fb);font-size:.85rem;font-weight:600;background:var(--sky);color:#fff;border:none;border-radius:7px;padding:.45rem 1rem;cursor:pointer;display:flex;align-items:center;gap:.35rem;transition:background .2s;white-space:nowrap}.hdr-new:hover{background:var(--blue)}.hdr-new svg{width:15px;height:15px}.hdr-btn{font-family:var(--fb);font-size:.82rem;font-weight:600;background:transparent;color:#9ec8e8;border:1.5px solid rgba(255,255,255,.2);border-radius:7px;padding:.42rem .9rem;cursor:pointer;display:flex;align-items:center;gap:.35rem;transition:all .2s;white-space:nowrap}.hdr-btn:hover{background:#ffffff1a;color:#fff}.hdr-btn svg{width:14px;height:14px}.accent{height:4px;background:linear-gradient(90deg,var(--sky),var(--blue),var(--navy))}.summary-bar{background:var(--navy);border-bottom:1px solid rgba(255,255,255,.08);padding:.6rem 1.5rem;display:flex;align-items:center;flex-wrap:wrap;overflow-x:auto;position:sticky;top:60px;z-index:200}.sb-group{display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.12);padding-right:1.4rem;margin-right:1.4rem}.sb-group:last-child{border-right:none;padding-right:0;margin-right:0}.sb-group-title{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#ffffff59;margin-bottom:.45rem;white-space:nowrap}.sb-items{display:flex;align-items:flex-end;gap:1rem}.sb-item{display:flex;flex-direction:column;align-items:center;min-width:54px}.sb-n{font-size:1.3rem;font-weight:700;line-height:1;color:#fff}.sb-l{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:#9ec8e8;margin-top:.22rem;text-align:center;white-space:nowrap}.tab-bar{display:flex;gap:0;border-bottom:2px solid var(--line);background:var(--white);padding:0 1.5rem;overflow-x:auto;flex-shrink:0}.tab-btn{font-family:var(--fb);font-size:.88rem;font-weight:600;padding:.7rem 1.2rem;border:none;background:transparent;color:var(--muted);cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-2px;transition:all .18s;white-space:nowrap;display:flex;align-items:center;gap:.4rem}.tab-btn:hover{color:var(--blue)}.tab-btn.active{color:var(--blue);border-bottom-color:var(--blue)}.tab-btn svg{width:14px;height:14px}.layout{display:grid;grid-template-columns:340px 1fr;min-height:calc(100vh - 112px);max-width:1400px;margin:0 auto}@media (max-width:820px){.layout{grid-template-columns:1fr}}.list-panel{border-right:1px solid var(--line);background:var(--white);display:flex;flex-direction:column;position:sticky;top:112px;height:calc(100vh - 112px);overflow:hidden}@media (max-width:820px){.list-panel{position:static;height:auto;border-right:none;border-bottom:2px solid var(--line)}}.search-wrap{padding:.9rem 1rem;border-bottom:1px solid var(--line);flex-shrink:0}.sbox{position:relative}.sbox svg{position:absolute;left:.7rem;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--muted);pointer-events:none}.sbox input{width:100%;padding:.58rem .8rem .58rem 2.1rem;border:1.5px solid var(--line);border-radius:8px;font-family:var(--fb);font-size:.88rem;color:var(--ink);background:var(--white);transition:border-color .2s,box-shadow .2s}.sbox input:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 3px #3896d821}.smeta{font-size:.74rem;color:var(--muted);margin-top:.45rem;display:flex;justify-content:space-between}.filter-chips{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.6rem}.chip{font-family:var(--fb);font-size:.72rem;font-weight:600;padding:.28rem .7rem;border-radius:20px;border:1.5px solid var(--line);background:transparent;color:var(--muted);cursor:pointer;transition:all .15s;white-space:nowrap}.chip:hover{border-color:var(--sky);color:var(--blue)}.chip.on{border-color:var(--blue);background:var(--pool);color:var(--blue)}.chip.on.c-inactive{border-color:#c93b3b;background:#fde8e8;color:#c93b3b}.chip.on.c-pending{border-color:#b07010;background:#fef6e4;color:#7a5700}.chip.on.c-active{border-color:var(--green);background:#e6f7ec;color:var(--green)}.chip.on.c-waitlist{border-color:#1560a8;background:var(--pool);color:#0c447c}.mlist{flex:1;overflow-y:auto;overscroll-behavior:contain}.mlist::-webkit-scrollbar{width:4px}.mlist::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}.mrow{display:flex;align-items:center;gap:.7rem;padding:.8rem 1rem;border-bottom:1px solid var(--line);cursor:pointer;transition:background .12s}.mrow:hover{background:var(--foam)}.mrow.sel{background:var(--pool);border-left:3px solid var(--blue)}.mrow.sel .mname{color:var(--blue)}.mavatar{width:36px;height:36px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.88rem;color:#fff;text-transform:uppercase}.minfo{flex:1;min-width:0}.mname{font-size:.9rem;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mmeta{font-size:.73rem;color:var(--muted);margin-top:.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portal-meta{color:var(--muted)}body.dark .mmeta,body.dark .portal-meta,body.dark .dh-sub{color:#9ec8e8}body.dark code{color:#9ec8e8;background:#1a2d42;border-color:#2a3d52}.spill{font-size:.67rem;font-weight:600;padding:.16rem .5rem;border-radius:20px;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.s-active{background:#d4edda;color:#155724}.s-inactive{background:#f8d7da;color:#721c24}.s-pending{background:#fff3cd;color:#856404}.s-waitlist{background:var(--pool);color:#0c447c;border:1px solid #b8d9ef}.dpanel{padding:1.8rem 2rem 4rem;overflow-y:auto}@media (max-width:820px){.dpanel{padding:1.2rem 1rem 4rem}}.d-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:55vh;color:var(--muted);text-align:center;gap:.7rem}.d-empty svg{width:52px;height:52px;opacity:.18}.d-empty h3{font-family:var(--fh);font-size:1.35rem;color:var(--ink);opacity:.35}.d-empty p{font-size:.86rem;max-width:260px;line-height:1.5}.dh{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}.dh-l{display:flex;align-items:center;gap:.85rem}.dh-av{width:50px;height:50px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;color:#fff;text-transform:uppercase}.dh-title{font-family:var(--fh);font-size:1.45rem;color:var(--ink)}.dh-sub{font-size:.8rem;color:var(--muted);margin-top:.1rem;display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.mbadge{font-size:.7rem;font-weight:600;padding:.18rem .65rem;border-radius:20px;text-transform:uppercase;letter-spacing:.04em;background:var(--pool);color:var(--blue)}.mbadge.ed{background:#fff3cd;color:#7a5700}.dh-r{display:flex;gap:.6rem;flex-wrap:wrap}.sec{background:var(--white);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:1.3rem;margin-bottom:1.1rem}.sec-t{font-size:.8rem;font-weight:600;color:var(--blue);text-transform:uppercase;letter-spacing:.08em;padding-bottom:.55rem;margin-bottom:1rem;border-bottom:2px solid var(--pool);display:flex;align-items:center;gap:.4rem}.sec-t svg{width:14px;height:14px;flex-shrink:0}.g2{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.85rem}.s2{grid-column:span 2}.s3{grid-column:span 3}@media (max-width:580px){.g2,.g3{grid-template-columns:1fr}.s2,.s3{grid-column:1}}.fld{display:flex;flex-direction:column;gap:.26rem}.fld label{font-size:.72rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.fld label .req{color:var(--red);margin-left:2px}.fld input,.fld select,.fld textarea{font-family:var(--fb);font-size:.9rem;padding:.56rem .78rem;border:1.5px solid var(--line);border-radius:8px;background:var(--white);color:var(--ink);transition:border-color .2s,box-shadow .2s;width:100%}.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 3px #3896d821}.fld textarea{resize:vertical;min-height:70px}.input-group{display:flex;flex-direction:column;gap:.26rem;margin-bottom:.85rem}.label{font-size:.72rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.hint{font-size:.76rem;color:var(--muted);margin-top:.2rem}.stats{display:flex;gap:.7rem;flex-wrap:wrap;margin-bottom:1.1rem}.stat{flex:1;min-width:72px;background:var(--pool);border:1px solid #b8d9ef;border-radius:10px;padding:.6rem .7rem;text-align:center}.stat-n{font-size:1.6rem;font-weight:700;color:var(--blue);line-height:1}.stat-l{font-size:.66rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-top:.18rem}.btn{font-family:var(--fb);font-size:.88rem;font-weight:600;padding:.58rem 1.2rem;border-radius:8px;border:1.5px solid transparent;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;transition:all .18s;white-space:nowrap}.btn svg{width:14px;height:14px;flex-shrink:0}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-save,.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 4px 14px #1560a840}.btn-save:hover,.btn-primary:hover{background:var(--navy);border-color:var(--navy)}.btn-save:active{transform:scale(.98)}.btn-edit{background:var(--pool);color:var(--blue);border-color:var(--sky)}.btn-edit:hover{background:var(--blue);color:#fff}.btn-ghost{background:transparent;color:var(--muted);border-color:var(--line)}.btn-ghost:hover{border-color:var(--blue);color:var(--blue)}.btn-delete,.btn-danger{background:transparent;color:var(--red);border-color:#f0cccc}.btn-delete:hover,.btn-danger:hover{background:var(--red);color:#fff;border-color:var(--red)}.btn-green{background:var(--green);color:#fff;border-color:var(--green)}.btn-green:hover{background:#1a6b38}.btn-sm{font-size:.8rem;padding:.42rem .85rem}.btn-lg{font-size:1rem;padding:.75rem 1.6rem}.btn-block{width:100%;justify-content:center}.form-footer{display:flex;justify-content:space-between;align-items:center;gap:.65rem;flex-wrap:wrap;margin-top:1.3rem;padding-top:.9rem;border-top:1px solid var(--line)}.label-pill{display:inline-flex;align-items:center;gap:.3rem;font-size:.7rem;font-weight:600;padding:.2rem .6rem;border-radius:20px;background:#ede9fe;color:#5b21b6;border:1px solid #c4b5fd;white-space:nowrap}.label-pill .lx{cursor:pointer;opacity:.6;font-size:.8rem;line-height:1;margin-left:.1rem}.label-pill .lx:hover{opacity:1}.labels-row{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center;padding:.1rem 0}.pill{display:inline-block;padding:.16rem .58rem;border-radius:20px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.r-adult{background:var(--pool);color:var(--blue);border:1px solid #b8d9ef}.r-child{background:#e6f7ec;color:#1d6b38;border:1px solid #a9d8ba}.r-addon{background:#fef6e4;color:#7a5700;border:1px solid #f0d88a}.p-act{background:#d4edda;color:#155724}.p-ina{background:#f8d7da;color:#721c24}.person-row{display:grid;grid-template-columns:1fr 1fr 92px 1fr 1fr 84px 34px;gap:.42rem;align-items:end;padding:.7rem;background:var(--foam);border:1px solid var(--line);border-radius:8px;margin-bottom:.5rem;animation:pop .2s ease}@keyframes pop{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}@media (max-width:680px){.person-row{grid-template-columns:1fr 1fr}}.person-row .fld label{font-size:.68rem}.person-row input,.person-row select{font-size:.83rem;padding:.44rem .58rem}.rmbtn{background:none;border:1.5px solid var(--red);color:var(--red);border-radius:7px;cursor:pointer;padding:.36rem;display:flex;align-items:center;justify-content:center;transition:all .2s;height:32px;width:32px}.rmbtn:hover{background:var(--red);color:#fff}.rmbtn svg{width:13px;height:13px}.add-btns{display:flex;gap:.45rem;flex-wrap:wrap;margin-bottom:.8rem}.addbtn{font-family:var(--fb);font-size:.8rem;font-weight:600;padding:.42rem .85rem;border-radius:7px;border:1.5px solid;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:.3rem;background:transparent}.ab-adult{color:var(--blue);border-color:var(--blue)}.ab-child{color:var(--green);border-color:var(--green)}.ab-addon{color:var(--gold);border-color:var(--gold)}.addbtn:hover{opacity:.8;background:var(--pool)}.pay-summary{display:flex;gap:.7rem;flex-wrap:wrap;margin-bottom:1rem}.pay-stat{flex:1;min-width:90px;border-radius:9px;padding:.65rem .8rem;text-align:center;border:1px solid}.pay-stat-n{font-size:1.4rem;font-weight:700;line-height:1}.pay-stat-l{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-top:.2rem}.pay-owed{background:#fff8e6;border-color:#f0d088;color:#7a5700}.pay-paid{background:#e6f7ec;border-color:#a9d8ba;color:#1a6b38}.pay-bal-ok{background:var(--pool);border-color:#b8d9ef;color:var(--blue)}.pay-bal-due{background:#fde8e8;border-color:#f0cccc;color:var(--red)}.pay-tbl{width:100%;border-collapse:collapse;font-size:.84rem;margin-bottom:.9rem}.pay-tbl thead tr{background:var(--pool)}.pay-tbl th{padding:.45rem .75rem;text-align:left;font-size:.69rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--blue)}.pay-tbl tbody tr{border-bottom:1px solid var(--line)}.pay-tbl tbody tr:hover{background:var(--foam)}.pay-tbl td{padding:.52rem .75rem;vertical-align:middle}.pay-del{background:none;border:none;color:var(--muted);cursor:pointer;padding:.25rem;border-radius:5px;transition:all .15s}.pay-del:hover{color:var(--red);background:#fde8e8}.pay-form{background:var(--foam);border:1px solid var(--line);border-radius:9px;padding:1rem;margin-top:.5rem}.pay-form-title{font-size:.78rem;font-weight:600;color:var(--blue);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.75rem}.pay-grid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin-bottom:.75rem}@media (max-width:520px){.pay-grid{grid-template-columns:1fr}}.billing-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.2rem}@media (max-width:680px){.billing-stats{grid-template-columns:repeat(2,1fr)}}.bstat{background:var(--foam);border-radius:var(--r);padding:.75rem 1rem;border:1px solid var(--line)}.bstat-n{font-size:1.5rem;font-weight:700;line-height:1;color:var(--ink)}.bstat-n.green{color:var(--green)}.bstat-n.amber{color:#b07010}.bstat-n.red{color:var(--red)}.bstat-l{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-top:.25rem}.bill-filter-row{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.9rem;align-items:center}.bill-search{font-family:var(--fb);font-size:.86rem;padding:.5rem .85rem .5rem 2rem;border:1.5px solid var(--line);border-radius:8px;color:var(--ink);background:var(--white);width:220px;transition:border-color .2s}.bill-search:focus{outline:none;border-color:var(--sky)}.bchip{font-family:var(--fb);font-size:.72rem;font-weight:600;padding:.3rem .75rem;border-radius:20px;border:1.5px solid var(--line);background:transparent;color:var(--muted);cursor:pointer;transition:all .15s}.bchip:hover{border-color:var(--sky);color:var(--blue)}.bchip.on{border-color:var(--blue);background:var(--pool);color:var(--blue)}.bchip.on.bc-paid{border-color:var(--green);background:#e6f7ec;color:var(--green)}.bchip.on.bc-partial{border-color:#b07010;background:#fff8e6;color:#7a5700}.bchip.on.bc-unpaid{border-color:var(--red);background:#fde8e8;color:var(--red)}.btbl-wrap{background:var(--white);border:1px solid var(--line);border-radius:var(--r);overflow-x:auto}.btbl{width:100%;border-collapse:collapse;font-size:.84rem;table-layout:fixed}.btbl thead tr{background:var(--pool)}.btbl th{padding:.5rem .85rem;text-align:left;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--blue);white-space:nowrap}.btbl tbody tr{border-bottom:1px solid var(--line)}.btbl tbody tr:hover td{background:var(--foam)}.btbl td{padding:0 .85rem;vertical-align:middle;height:46px}.btbl tr:last-child td{border-bottom:none}.bpay-btn{font-family:var(--fb);font-size:.75rem;font-weight:600;padding:.32rem .7rem;border:1.5px solid var(--sky);border-radius:7px;background:var(--pool);color:var(--blue);cursor:pointer;transition:all .18s}.bpay-btn:hover{background:var(--blue);color:#fff}.num{font-variant-numeric:tabular-nums}.bal-due{color:var(--red);font-weight:600}.bal-ok{color:var(--green)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#08203a80;z-index:9500;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--white);border-radius:14px;box-shadow:0 12px 48px #0000004d;padding:1.8rem;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;animation:slideUp .18s ease}.modal-box.modal-lg{max-width:820px}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.modal-icon{font-size:2rem;margin-bottom:.5rem}.modal-title{font-family:var(--fh);font-size:1.2rem;color:var(--ink);margin-bottom:.4rem}.modal-body{font-size:.87rem;color:var(--muted);line-height:1.6;margin-bottom:1.2rem}.modal-body strong{color:var(--ink)}.modal-actions{display:flex;gap:.6rem;justify-content:flex-end;flex-wrap:wrap;margin-top:1.2rem;padding-top:.9rem;border-top:1px solid var(--line)}.alert{padding:.75rem 1rem;border-radius:8px;font-size:.86rem;margin-bottom:1rem;line-height:1.5}.alert-error{background:#fde8e8;border:1px solid #f0cccc;color:var(--red)}.alert-success{background:#e6f7ec;border:1px solid #a9d8ba;color:var(--green)}.alert-warning{background:#fff8e6;border:1px solid #f0d088;color:#7a5700}.alert-info{background:var(--pool);border:1px solid #b8d9ef;color:#0c447c}.toast{position:fixed;bottom:1.3rem;right:1.3rem;max-width:320px;padding:.85rem 1.2rem;border-radius:10px;font-size:.86rem;font-weight:500;box-shadow:0 8px 24px #0000002e;z-index:9999;transform:translateY(60px);opacity:0;transition:all .3s cubic-bezier(.34,1.56,.64,1);pointer-events:none}.toast.show{transform:translateY(0);opacity:1;pointer-events:auto}.toast.ok{background:var(--green);color:#fff}.toast.err{background:var(--red);color:#fff}.spin,.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:rot .65s linear infinite}.spin-dark{border-color:#0000001f;border-top-color:var(--blue)}@keyframes rot{to{transform:rotate(360deg)}}.loading-full{display:flex;align-items:center;justify-content:center;height:60vh;flex-direction:column;gap:.75rem;color:var(--muted)}.loading-full .spin{border-color:#0000001f;border-top-color:var(--blue);width:28px;height:28px;border-width:3px}.skeleton{background:linear-gradient(90deg,var(--line) 25%,var(--foam) 50%,var(--line) 75%);background-size:200%;animation:shim 1.2s infinite}@keyframes shim{0%{background-position:200%}to{background-position:-200%}}code{font-family:monospace;font-size:.82rem;background:var(--foam);padding:.1rem .35rem;border-radius:4px;color:var(--navy);border:1px solid var(--line)}.main-wrap{padding:1.8rem 2rem 4rem;max-width:1400px;margin:0 auto}@media (max-width:820px){.main-wrap{padding:1.2rem 1rem 4rem}}.setup-wrap{min-height:100vh;background:var(--navy);display:flex;align-items:center;justify-content:center;padding:1.5rem}.setup-card{background:var(--white);border-radius:16px;width:100%;max-width:580px;box-shadow:0 16px 60px #0006;overflow:hidden}.setup-prog{display:flex;gap:4px;padding:12px 24px;background:#0003}.setup-prog-step{flex:1;height:4px;border-radius:2px;background:#fff3;transition:background .3s}.setup-prog-step.done{background:var(--sky)}.setup-hdr{background:var(--navy);padding:1.4rem 1.8rem;display:flex;align-items:center;gap:.85rem}.setup-hdr-icon{width:42px;height:42px;border-radius:50%;background:var(--sky);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.setup-hdr h2{font-family:var(--fh);color:#fff;font-size:1.15rem;margin-bottom:2px}.setup-hdr p{color:#9ec8e8;font-size:.76rem}.setup-body{padding:1.8rem}.setup-footer{padding:0 1.8rem 1.8rem;display:flex;justify-content:space-between}.pin-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:1.3rem;margin-bottom:1.1rem}.pin-status{display:flex;align-items:center;gap:.6rem;margin-bottom:.8rem}.pin-indicator{width:10px;height:10px;border-radius:50%;flex-shrink:0}.pin-indicator.set{background:var(--green)}.pin-indicator.expired{background:var(--red)}.pin-indicator.none{background:var(--muted)}.pin-value{font-family:monospace;font-size:1.5rem;font-weight:700;letter-spacing:.2em;color:var(--ink);background:var(--foam);border:1.5px solid var(--line);border-radius:8px;padding:.5rem 1.2rem;display:inline-block;margin-bottom:.4rem}.pin-exp{font-size:.78rem;color:var(--muted);margin-bottom:.2rem}.pin-exp.expired{color:var(--red);font-weight:600}.pin-actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.9rem}.pin-link-box{margin-top:.85rem;padding:.85rem 1rem;background:var(--foam);border:1.5px solid var(--line);border-radius:9px}.pin-link-url{font-family:monospace;font-size:.78rem;color:var(--ink);background:var(--white);border:1px solid var(--line);border-radius:6px;padding:.38rem .65rem;word-break:break-all;flex:1;min-width:0}.btn-pin-gen{background:var(--pool);color:var(--blue);border-color:var(--sky);font-size:.82rem;padding:.46rem .9rem}.btn-pin-gen:hover{background:var(--blue);color:#fff}.btn-pin-clear{background:transparent;color:var(--red);border-color:#f0cccc;font-size:.82rem;padding:.46rem .9rem}.btn-pin-clear:hover{background:var(--red);color:#fff;border-color:var(--red)}.btn-pin-email{background:var(--green);color:#fff;border-color:var(--green);font-size:.82rem;padding:.46rem .9rem}.btn-pin-email:hover{background:#1a6b38;border-color:#1a6b38}.btn-pin-email:disabled{opacity:.55;cursor:not-allowed}.btn-copy{font-family:var(--fb);font-size:.78rem;font-weight:600;background:var(--pool);color:var(--blue);border:1.5px solid var(--sky);border-radius:6px;padding:.38rem .75rem;cursor:pointer;display:inline-flex;align-items:center;gap:.3rem;transition:all .2s;white-space:nowrap;flex-shrink:0}.btn-copy:hover{background:var(--blue);color:#fff;border-color:var(--blue)}.wi-input,.wi-textarea{width:100%;max-width:100%;box-sizing:border-box;padding:.32rem .5rem;border:1.5px solid var(--line);border-radius:6px;background:var(--white);color:var(--ink);font-family:var(--fb);font-size:.8rem}.wi-textarea{min-height:64px;resize:vertical}.wi-actions{display:flex;flex-direction:column;gap:.3rem;min-width:92px}.wi-btn{font-family:var(--fb);font-size:.68rem;font-weight:600;padding:.22rem .4rem;border-radius:6px;border:1.5px solid var(--sky);background:var(--pool);color:var(--blue);cursor:pointer;line-height:1.15;white-space:nowrap;transition:all .15s}.wi-btn:hover{background:var(--blue);color:#fff}.wi-btn.complete{background:var(--green);border-color:var(--green);color:#fff}.wi-btn.delete{background:transparent;border-color:#f0cccc;color:var(--red)}.wi-btn.delete:hover{background:var(--red);border-color:var(--red);color:#fff}.wi-complete-pill{display:inline-block;margin-top:.35rem;padding:.14rem .5rem;border-radius:20px;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:#d4edda;color:#155724}.billing-wrap{padding:1.5rem 2rem 4rem;max-width:1400px;margin:0 auto}@media (max-width:820px){.billing-wrap{padding:1rem 1rem 4rem}}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:var(--foam, #f4f7fa);border:1px solid var(--line, #dfe4ec);border-radius:6px;color:var(--ink, #1a2530);cursor:pointer;transition:background .15s,border-color .15s,color .15s}.icon-btn:hover{background:#e8eef5;border-color:var(--blue, #1560a8);color:var(--blue, #1560a8)}.icon-btn svg{display:block}.icon-btn-danger:hover{background:#fdecec;border-color:#c0392b;color:#c0392b}.mobile-back-btn{display:none;align-items:center;gap:6px;padding:6px 10px;margin:0 0 10px;background:var(--foam, #f4f7fa);border:1px solid var(--line, #dfe4ec);border-radius:6px;font-size:.85rem;color:var(--ink, #1a2530);cursor:pointer}.mobile-back-btn:hover{border-color:var(--blue, #1560a8);color:var(--blue, #1560a8)}@media (max-width: 820px){.layout.mobile-detail-active .list-panel{display:none}.layout.mobile-detail-active .dpanel{width:100%;max-width:100%;flex:1 1 100%}.layout.mobile-detail-active .mobile-back-btn{display:inline-flex}}.labels-editor{display:flex;flex-direction:column;gap:8px}.labels-applied{display:flex;flex-wrap:wrap;gap:6px;min-height:4px}.label-pill-removable{display:inline-flex;align-items:center;gap:4px;padding-right:4px}.label-pill-x{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;padding:0;margin-left:2px;background:transparent;border:none;border-radius:50%;color:inherit;opacity:.65;font-size:14px;line-height:1;cursor:pointer}.label-pill-x:hover{opacity:1;background:#00000014}.labels-input-row{display:flex;gap:6px;align-items:center}.labels-input-row input{flex:1 1 auto}.labels-input-row .btn{flex:0 0 auto;padding:6px 12px}.labels-suggest-row{display:flex;flex-wrap:wrap;gap:5px}.label-suggest-chip{display:inline-flex;align-items:center;padding:3px 9px;background:#ede9fe;border:1px dashed #c4b5fd;border-radius:14px;font-size:.75rem;font-weight:600;color:#5b21b6;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.label-suggest-chip:hover{background:#ddd6fe;border-style:solid;border-color:#a78bfa;color:#4c1d95}.labels-chip-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
