:root{--bg:#f5f7fb;--surface:#fff;--surface-soft:#f3f6fb;--surface-tint:#eef2ff;--text:#0f172a;--muted:#64748b;--primary:#6366f1;--primary-dark:#4f46e5;--success:#16a34a;--warning:#f97316;--danger:#dc2626;--border:#dce4ef;--shadow:0 14px 34px #0f172a12;--shadow-soft:0 8px 22px #0f172a0d}*{box-sizing:border-box}html{font-size:15px}body{background:radial-gradient(circle at top left, #6366f114, transparent 34rem), linear-gradient(180deg, #f8fafc 0%, var(--bg) 18rem);color:var(--text);margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}a{color:var(--primary-dark);text-decoration:none}input,select,textarea,button{font:inherit}label{color:var(--muted);gap:.45rem;font-size:.88rem;font-weight:700;display:grid}.field-label{color:var(--muted);font-size:.88rem;font-weight:700}input,select,textarea{border:1px solid var(--border);width:100%;color:var(--text);background:#ffffffdb;border-radius:12px;padding:.68rem .8rem;transition:border-color .14s,box-shadow .14s,background-color .14s}.currency-select{display:grid;position:relative}.currency-select>span{z-index:1;color:#fff;background:var(--primary);pointer-events:none;border-radius:999px;place-items:center;width:1.6rem;height:1.6rem;font-weight:900;display:grid;position:absolute;top:50%;left:.85rem;transform:translateY(-50%)}.currency-select select{padding-left:3rem}.pretty-select{appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--muted) 50%), linear-gradient(135deg, var(--muted) 50%, transparent 50%);background-position:calc(100% - 18px) calc(50% - 3px),calc(100% - 12px) calc(50% - 3px);background-repeat:no-repeat;background-size:6px 6px,6px 6px;padding-right:2.5rem}input:focus,select:focus,textarea:focus{border-color:var(--primary);background:var(--surface);outline:0;box-shadow:0 0 0 3px #6366f124}textarea{resize:vertical}.btn{cursor:pointer;min-height:36px;box-shadow:none;border:0;border-radius:12px;justify-content:center;align-items:center;padding:.55rem .9rem;font-weight:800;transition:transform .14s,background-color .14s,border-color .14s,color .14s;display:inline-flex}.btn:disabled{cursor:not-allowed;opacity:.65}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn.primary{color:#fff;background:linear-gradient(135deg, var(--primary), var(--primary-dark))}.btn.primary:hover{background:var(--primary-dark)}.btn.secondary{color:var(--text);border:1px solid var(--border);background:#ffffffc2}.btn.ghost{color:var(--muted);background:0 0}.btn.danger{color:#fff;background:var(--danger)}.screen-center{place-items:center;min-height:100vh;display:grid}.form-message{border-radius:14px;margin:0 0 .85rem;padding:.75rem .85rem;font-weight:700}.form-message.error{color:#991b1b;background:#fee2e2}.form-message.success{color:#166534;background:#dcfce7}.form-message.warning{color:#854d0e;background:#fef3c7}.empty{border:1px dashed var(--border);text-align:center;background:#ffffffb8;border-radius:18px;padding:1.6rem}.empty h3{margin:0 0 .4rem}.empty p{color:var(--muted);margin:0}.pill{background:var(--surface-soft);color:var(--muted);white-space:nowrap;border-radius:999px;align-items:center;padding:.3rem .65rem;font-size:.78rem;font-weight:800;display:inline-flex}.pill.active,.pill.approved{color:#166534;background:#dcfce7}.pill.paused,.pill.pending{color:#9a3412;background:#ffedd5}.pill.cancelled,.pill.rejected,.pill.suspended{color:#991b1b;background:#fee2e2}.modal-backdrop{z-index:20;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172a6b;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.modal{background:var(--surface);width:min(780px,100%);max-height:92vh;box-shadow:var(--shadow);border-radius:18px;padding:1.15rem;overflow:auto}.modal-head{justify-content:space-between;align-items:center;gap:1rem;display:flex}.modal-head h2{letter-spacing:0;margin:0;font-size:1.25rem}.modal-head .btn{min-width:36px;padding-inline:.75rem}.auth-page{background:linear-gradient(#f8fafcdb,#f8fafcf0),url(https://images.unsplash.com/photo-1554224155-6726b3ff858f?auto=format&fit=crop&w=1600&q=80) 50%/cover;place-items:center;min-height:100vh;padding:1.25rem;display:grid}.auth-panel{border:1px solid var(--border);width:min(480px,100%);box-shadow:var(--shadow);background:#fffffff0;border-radius:8px;gap:1rem;padding:clamp(1.2rem,4vw,2rem);display:grid}.hero-panel{width:min(720px,100%)}.auth-panel h1{letter-spacing:0;margin:0;font-size:clamp(2rem,6vw,4rem);line-height:1}.auth-panel p{color:var(--muted);margin:0}.eyebrow{text-transform:uppercase;color:var(--primary-dark);font-size:.78rem;font-weight:900}.auth-actions{flex-wrap:wrap;gap:.75rem;display:flex}.app-shell{grid-template-columns:228px 1fr;min-height:100vh;display:grid}.mobile-header{display:none}.sidebar{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffd6;border-right:1px solid #dce4efd1;grid-template-rows:auto 1fr auto;gap:1.5rem;height:100vh;padding:1.15rem;display:grid;position:sticky;top:0}.brand{letter-spacing:0;font-size:1.12rem;font-weight:950}.sidebar nav{align-content:start;gap:.35rem;display:grid}.sidebar nav a{color:var(--muted);border-radius:14px;padding:.68rem .75rem;font-weight:800;transition:background-color .14s,color .14s,transform .14s}.sidebar nav a.active,.sidebar nav a:hover{color:var(--primary-dark);background:linear-gradient(135deg,#6366f121,#14b8a614)}.sidebar nav a:hover{transform:translate(2px)}.sidebar-user{color:var(--muted);gap:.35rem;display:grid}.sidebar-user strong{color:var(--text)}.main{min-width:0;padding:clamp(.9rem,2vw,1.4rem)}.topbar{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.topbar p{color:var(--muted);margin:0;font-weight:800}.topbar h1{letter-spacing:0;margin:.1rem 0 0;font-size:clamp(1.45rem,2.4vw,2.05rem)}.topbar-actions{gap:.75rem;display:flex}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(158px,1fr));gap:.75rem;margin-bottom:1rem;display:grid}.stat-card,.content-section,.subscription-card{border:1px solid var(--border);box-shadow:var(--shadow-soft);background:#ffffffd1;border-radius:18px}.stat-card{gap:.22rem;min-height:104px;padding:.8rem .9rem;display:grid;position:relative;overflow:hidden}.stat-card:before{content:"";background:linear-gradient(180deg, var(--primary), #14b8a6);opacity:.7;width:3px;position:absolute;inset:0 auto 0 0}.stat-card span,.stat-card small{color:var(--muted);font-weight:700}.stat-value{font-size:clamp(1.15rem,2vw,1.55rem);font-weight:900}.stat-breakdown{gap:.25rem;display:grid}.stat-breakdown strong,.stat-empty{font-size:clamp(1rem,1.5vw,1.3rem);line-height:1.15;display:block}.stat-empty{color:var(--muted)}.content-section{margin-bottom:1rem;padding:1rem}.section-head{justify-content:space-between;align-items:center;margin-bottom:.9rem;display:flex}.section-head h2{margin:0}.subscription-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem;display:grid}.subscription-card{gap:.8rem;padding:.85rem;display:grid}.compact-sub-card{text-align:left;width:100%;font:inherit;color:var(--text);cursor:pointer;grid-template-columns:minmax(0,1fr) auto;align-items:center;transition:transform .15s,border-color .15s,box-shadow .15s,background-color .15s}.compact-sub-main{align-items:center;gap:1rem;min-width:0;display:flex}.compact-sub-card h3{overflow-wrap:anywhere;margin:0}.compact-sub-card p{color:var(--muted);margin:.35rem 0 0;font-weight:750}.compact-sub-card:hover{border-color:color-mix(in srgb, var(--primary) 34%, var(--border));box-shadow:var(--shadow);transform:translateY(-2px)}.card-row,.card-actions,.card-meta{justify-content:space-between;align-items:start;gap:.75rem;display:flex}.card-row h3{margin:0}.card-row p,.card-meta{color:var(--muted);margin:0}.card-meta{flex-wrap:wrap;justify-content:flex-start}.card-price{font-size:1.35rem;font-weight:900}.card-price span{color:var(--muted);font-size:.9rem}.card-actions{justify-content:flex-start}.renewal-list{gap:.6rem;display:grid}.renewal-row{border:1px solid var(--border);border-radius:8px;grid-template-columns:1fr auto auto;align-items:center;gap:1rem;padding:.8rem;display:grid}.renewal-row span{color:var(--muted)}.dashboard-section{margin-bottom:1.1rem}.dashboard-section-head{justify-content:space-between;align-items:center;gap:1rem;margin:0 0 .85rem;display:flex}.dashboard-section-head h2{margin:0;font-size:clamp(1.1rem,2vw,1.45rem)}.dashboard-section-head span{border:1px solid color-mix(in srgb, var(--primary) 28%, var(--border));color:var(--primary-dark);background:#ffffffd1;border-radius:999px;padding:.35rem .75rem;font-weight:900}.dashboard-sub-list,.upcoming-list{gap:.72rem;display:grid}.dashboard-sub-card,.upcoming-card{border:1px solid var(--border);width:100%;color:var(--text);box-shadow:var(--shadow-soft);cursor:pointer;text-align:left;background:#ffffffd1;border-radius:18px;transition:transform .15s,border-color .15s,box-shadow .15s,background-color .15s}.dashboard-sub-card{grid-template-columns:auto 1fr auto;align-items:center;gap:.85rem;padding:.75rem .9rem;display:grid}.dashboard-sub-card:hover,.upcoming-card:hover{border-color:color-mix(in srgb, var(--primary) 34%, var(--border));background:var(--surface);box-shadow:var(--shadow);transform:translateY(-2px)}.dash-avatar,.upcoming-logo{color:var(--avatar-text,var(--primary-dark));background:var(--avatar-color,color-mix(in srgb, var(--primary) 16%, white));letter-spacing:0;flex:none;place-items:center;font-weight:950;display:grid}.dash-avatar{border-radius:15px;width:42px;height:42px;font-size:1.35rem;box-shadow:inset 0 0 0 1px #ffffff42}.dash-sub-main,.dash-sub-side{gap:.3rem;display:grid}.dash-sub-main strong,.dash-sub-side strong,.upcoming-card strong{font-size:clamp(.98rem,1.7vw,1.18rem)}.dash-sub-main small,.dash-sub-side small,.upcoming-card small{color:var(--muted);font-weight:750}.dash-sub-side{justify-items:end}.dash-sub-side small{color:var(--primary-dark);background:color-mix(in srgb, var(--primary) 10%, white);text-transform:uppercase;border-radius:999px;padding:.25rem .55rem}.upcoming-card{grid-template-columns:auto 1fr auto;align-items:center;gap:.85rem;padding:.75rem .9rem;display:grid}.upcoming-card>span:nth-child(2){gap:.35rem;min-width:0;display:grid}.upcoming-card>span:nth-child(2) strong{overflow-wrap:anywhere}.upcoming-card small{display:block}.upcoming-logo{border-radius:999px;width:40px;height:40px}.dash-avatar svg,.upcoming-logo svg,.service-symbol svg{fill:none;stroke:currentColor;stroke-width:2.4px;stroke-linecap:round;stroke-linejoin:round;width:62%;height:62%}.upcoming-card.urgent{background:#fff7f7;border-color:#fecaca}.upcoming-card.urgent small,.upcoming-card.urgent>strong{color:var(--danger)}.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;margin-top:1rem;display:grid}.detail-grid div{border:1px solid var(--border);background:#f8fafcdb;border-radius:14px;min-width:0;padding:.75rem .8rem}.detail-grid span,.detail-grid strong{overflow-wrap:anywhere;display:block}.detail-grid span{color:var(--muted);font-size:.82rem;font-weight:800}.detail-grid strong{margin-top:.25rem}.detail-notes{border:1px solid var(--border);color:var(--muted);background:#f8fafcbf;border-radius:14px;padding:.8rem;line-height:1.6}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:1rem;display:flex}.import-panel{gap:1rem;display:grid}.import-panel p{color:var(--muted);margin:0;font-weight:650;line-height:1.55}.toolbar{grid-template-columns:1fr 210px;gap:.75rem;margin-bottom:1rem;display:grid}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem;display:grid}.form-grid .wide{grid-column:1/-1}.form-actions{justify-content:flex-end;gap:.75rem;display:flex}.service-combobox{position:relative}.service-menu{z-index:40;border:1px solid var(--border);max-height:300px;box-shadow:var(--shadow);background:#fffffff5;border-radius:16px;padding:.35rem;display:none;position:absolute;top:calc(100% + .35rem);left:0;right:0;overflow:auto}.service-combobox.open .service-menu{gap:.25rem;display:grid}.service-menu button{color:var(--text);text-align:left;cursor:pointer;background:0 0;border:0;border-radius:12px;grid-template-columns:auto 1fr;align-items:center;gap:.7rem;padding:.58rem;display:grid}.service-menu button:hover{background:color-mix(in srgb, var(--service-color,var(--primary)) 12%, white)}.service-symbol{width:34px;height:34px;color:var(--avatar-text,white);background:var(--avatar-color,var(--service-color,var(--primary)));border-radius:12px;place-items:center;font-size:.75rem;font-weight:900;display:grid}.service-menu strong,.service-menu small{display:block}.service-menu small{color:var(--muted);margin-top:.15rem;font-weight:650}.category-picker{gap:.45rem;display:grid}.category-dropdown{position:relative}.category-trigger{border:1px solid var(--border);background:linear-gradient(90deg, color-mix(in srgb, var(--category-color) 12%, white), #fff 58%);width:100%;min-height:41px;color:var(--text);text-align:left;cursor:pointer;border-radius:12px;justify-content:flex-start;align-items:center;gap:.6rem;padding:.66rem .8rem;font-weight:800;display:flex}.category-trigger:hover,.category-dropdown.open .category-trigger{border-color:var(--category-color,var(--primary));box-shadow:0 0 0 3px color-mix(in srgb, var(--category-color,var(--primary)) 16%, transparent);outline:0}.select-caret{border-left:5px solid #0000;border-right:5px solid #0000;border-top:6px solid var(--muted);width:0;height:0;margin-left:auto}.category-menu{z-index:30;border:1px solid var(--border);max-height:240px;box-shadow:var(--shadow);background:#fffffff5;border-radius:16px;padding:.35rem;display:none;position:absolute;top:calc(100% + .35rem);left:0;right:0;overflow:auto}.category-dropdown.open .category-menu{gap:.25rem;display:grid}.category-menu button{min-height:38px;color:var(--text);text-align:left;cursor:pointer;background:0 0;border:0;border-radius:12px;align-items:center;gap:.6rem;padding:.55rem .6rem;font-weight:750;display:flex}.category-menu button:hover,.category-menu button.selected{background:color-mix(in srgb, var(--category-color,var(--primary)) 12%, white)}.category-create-inline{border-bottom:1px solid var(--border);gap:.55rem;margin-bottom:.35rem;padding:.35rem .35rem .7rem;display:grid}.category-create-inline .btn{background:var(--surface-soft);border:1px solid var(--border);color:var(--text);justify-content:center;padding:.55rem .75rem}.category-create-inline input{min-height:38px}.color-palette{flex-wrap:wrap;gap:.45rem;display:flex}.color-palette button{background:var(--swatch);width:28px;height:28px;min-height:28px;box-shadow:0 0 0 1px var(--border);border:2px solid #fff;border-radius:999px;padding:0}.color-palette button.selected{box-shadow:0 0 0 3px color-mix(in srgb, var(--swatch) 28%, transparent)}.category-dot{background:var(--category-color,var(--primary));width:14px;height:14px;box-shadow:0 0 0 4px color-mix(in srgb, var(--category-color,var(--primary)) 18%, transparent);border-radius:999px;flex:none}.muted-dot{background:var(--muted);box-shadow:0 0 0 4px #64748b29}.category-create{grid-template-columns:1fr 56px auto;gap:.75rem;margin:1rem 0;display:grid}.category-create input[type=color]{height:44px;padding:.25rem}.category-list{gap:.65rem;display:grid}.category-row{border:1px solid var(--border);background:#ffffffb8;border-radius:16px;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;padding:.75rem;display:grid}.category-row>div{flex-wrap:wrap;gap:.5rem;display:flex}.category-row strong{font-size:.98rem;font-weight:800}.category-action{min-height:34px;color:var(--muted);padding:.4rem .55rem;font-size:.86rem}.category-action:hover{background:var(--surface-soft);color:var(--text)}.danger-link{color:#b91c1c}.danger-link:hover{color:#991b1b;background:#fee2e2}.category-swatch{border:2px solid var(--surface);width:18px;height:18px;box-shadow:0 0 0 1px var(--border);border-radius:999px}@media (width<=920px){.app-shell{min-height:100svh;display:block}.sidebar{display:none}.mobile-header{z-index:10;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffe6;padding:.82rem 1rem;display:block;position:sticky;top:0}.mobile-brand{color:var(--text);margin-bottom:.65rem;font-size:1.12rem;font-weight:900}.mobile-header nav{scrollbar-width:none;gap:.4rem;padding-bottom:.1rem;display:flex;overflow-x:auto}.mobile-header nav::-webkit-scrollbar{display:none}.mobile-header nav a{color:var(--muted);border-radius:999px;flex:none;padding:.56rem .74rem;font-weight:800}.mobile-header nav a.active,.mobile-header nav a:hover{color:var(--primary-dark);background:linear-gradient(135deg,#6366f121,#14b8a614)}.main{padding:1rem .9rem calc(1rem + env(safe-area-inset-bottom))}.stats-grid,.subscription-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=640px){.mobile-header{padding:.75rem .9rem}.mobile-brand{margin-bottom:.5rem;font-size:1.05rem}.mobile-header nav a{padding:.52rem .68rem}.topbar,.card-row,.card-meta{flex-direction:column;align-items:stretch}.topbar-actions{flex-wrap:wrap;gap:.5rem}.topbar-actions .btn{flex:auto}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.stats-grid .stat-card:first-child{grid-column:1/-1}.stat-card{min-height:96px}.stat-value{font-size:1.15rem}.stat-breakdown strong,.stat-empty{font-size:.98rem}.subscription-grid,.toolbar,.form-grid,.compact-sub-card,.renewal-row{grid-template-columns:1fr}.dashboard-sub-card,.upcoming-card{grid-template-columns:auto 1fr;padding:.72rem}.dash-sub-side,.upcoming-card>strong{grid-column:2;justify-self:start}.dash-sub-side{justify-items:start}.detail-grid,.category-create,.category-row{grid-template-columns:1fr}}.admin-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.admin-panel{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);border-radius:8px;align-content:start;gap:.75rem;padding:1rem;display:grid}.admin-panel h2{margin:0 0 .4rem}.admin-row,.log-row{border:1px solid var(--border);border-radius:8px;grid-template-columns:1fr auto;align-items:center;gap:.75rem;padding:.85rem;display:grid}.admin-row div:first-child,.log-row{min-width:0}.admin-row strong,.admin-row span,.admin-row small,.log-row strong,.log-row span,.log-row small{overflow-wrap:anywhere;display:block}.admin-row span,.admin-row small,.log-row span,.log-row small{color:var(--muted)}.row-actions{flex-wrap:wrap;grid-column:1/-1;gap:.5rem;display:flex}.row-actions select{width:auto;min-width:150px}@media (width<=980px){.admin-grid{grid-template-columns:1fr}}@media (width<=560px){.admin-row,.log-row{grid-template-columns:1fr}}
