:root{--terra-50: #fdf5f0;--terra-100: #faeae0;--terra-200: #f3d4bd;--terra-300: #ebb591;--terra-400: #df9163;--terra-500: #c66f3e;--terra-600: #a8552a;--terra-700: #864221;--terra-800: #5e2f17;--bark-50: #f6f2ee;--bark-100: #ebe3da;--bark-200: #d4c4b3;--bark-300: #b39c84;--bark-400: #8a7560;--bark-500: #5e4d3c;--bark-600: #443628;--bark-700: #2d2218;--bark-800: #1a130c;--cream-50: #fdfbf7;--cream-100: #f7f1e8;--cream-200: #efe5d3;--cream-300: #e3d4b9;--pine-100: #e1ebe0;--pine-200: #b9d0b6;--pine-500: #4a7a4d;--pine-700: #2c5230;--plum-100: #ede0e7;--plum-200: #d4b8c8;--plum-500: #8a4d6e;--plum-700: #5e2f48;--sun-100: #fbeec6;--sun-200: #f5d97c;--sun-500: #d49b1e;--sun-700: #8c6310;--rose-100: #f7d7d0;--rose-200: #f0a99c;--rose-500: #c14a3b;--rose-700: #862718;--av-1: #c66f3e;--av-2: #4a7a4d;--av-3: #8a4d6e;--av-4: #d49b1e;--av-5: #5e4d3c;--av-6: #6b8a9a;--bg: var(--cream-100);--bg-page: #f4ecdf;--surface: #fffcf6;--surface-2: #fbf5e9;--surface-3: #f4ecdf;--line: rgba(94, 77, 60, .14);--line-strong: rgba(94, 77, 60, .28);--ink: var(--bark-800);--ink-2: var(--bark-600);--ink-3: var(--bark-400);--ink-soft: var(--bark-300);--primary: var(--terra-500);--primary-d: var(--terra-600);--primary-l: var(--terra-100);--ok: var(--pine-500);--ok-bg: var(--pine-100);--warn: var(--sun-700);--warn-bg: var(--sun-100);--bad: var(--rose-500);--bad-bg: var(--rose-100);--info: #3a5d72;--info-bg: #d6e4ec;--radius-xs: 6px;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-xl: 22px;--shadow-sm: 0 1px 2px rgba(45, 34, 24, .06);--shadow: 0 1px 3px rgba(45, 34, 24, .06), 0 4px 14px rgba(45, 34, 24, .06);--shadow-lg: 0 6px 20px rgba(45, 34, 24, .1), 0 24px 60px rgba(45, 34, 24, .1);--font-sans: "Inter Tight", "Inter", system-ui, -apple-system, sans-serif;--font-display: "Fraunces", "Cormorant Garamond", Georgia, serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--t-xs: 11px;--t-sm: 12.5px;--t-base:14px;--t-md: 15px;--t-lg: 17px;--t-xl: 20px;--t-2xl: 26px;--t-3xl: 34px;--t-4xl: 44px;--sidebar-w: 232px;--sidebar-w-collapsed: 64px;--topbar-h: 60px}*{box-sizing:border-box}html,body,#app{height:100%}body{margin:0;font-family:var(--font-sans);font-size:var(--t-base);color:var(--ink);background:var(--bg-page);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;letter-spacing:-.005em}button,input,select,textarea{font:inherit;color:inherit}a{color:inherit;text-decoration:none}hr{border:0;border-top:1px solid var(--line);margin:0}.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;height:100%;background:var(--bg-page)}.shell.collapsed{grid-template-columns:var(--sidebar-w-collapsed) 1fr}.sidebar{background:var(--bark-700);color:var(--cream-100);padding:14px 12px;display:flex;flex-direction:column;gap:4px;border-right:1px solid rgba(0,0,0,.2);position:relative}.sb-brand{display:flex;align-items:center;gap:10px;padding:8px 10px 14px;margin-bottom:6px;border-bottom:1px solid rgba(255,255,255,.08)}.sb-brand .logo{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,var(--terra-400),var(--terra-600));display:grid;place-items:center;flex-shrink:0;box-shadow:0 2px 6px #0000004d,inset 0 1px #fff3}.sb-brand .logo svg{width:18px;height:18px}.sb-brand .name{font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:-.01em}.sb-brand .sub{font-size:10px;color:#ffffff8c;letter-spacing:.04em;text-transform:uppercase;margin-top:-2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.sb-section{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:#fff6;padding:14px 12px 6px}.sb-item{display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:8px;color:#ffffffc7;font-size:13.5px;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative;transition:background .12s,color .12s}.sb-item:hover{background:#ffffff0f;color:#fff}.sb-item.active{background:var(--terra-600);color:#fff;box-shadow:inset 0 1px #ffffff1f}.sb-item .ico{width:18px;height:18px;flex-shrink:0;opacity:.9}.sb-item .badge{margin-left:auto;background:var(--terra-500);color:#fff;font-size:10.5px;font-weight:600;padding:1px 7px;border-radius:999px;min-width:18px;text-align:center}.sb-item.active .badge{background:#fff3}.sb-spacer{flex:1}.sb-user{margin-top:8px;padding:10px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px;cursor:pointer;border-radius:0}.sb-user .info{flex:1;min-width:0}.sb-user .nm{font-size:13px;font-weight:500}.sb-user .em{font-size:11px;color:#ffffff80}.main{display:flex;flex-direction:column;min-width:0;height:100%;overflow:hidden}.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 24px;gap:16px;flex-shrink:0}.topbar .crumbs{display:flex;align-items:center;gap:6px;color:var(--ink-3);font-size:13px}.topbar .crumbs .sep{opacity:.4}.topbar .crumbs .current{color:var(--ink);font-weight:500}.search{flex:1;max-width:380px;position:relative}.search input{width:100%;padding:8px 12px 8px 34px;background:var(--surface-2);border:1px solid var(--line);border-radius:9px;font-size:13px;outline:none;transition:border-color .12s,background .12s}.search input:focus{border-color:var(--terra-400);background:var(--surface)}.search .ico{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--ink-3)}.search .kbd{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:10.5px;color:var(--ink-3);border:1px solid var(--line);padding:1px 5px;border-radius:4px;background:var(--surface)}.tb-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.tb-iconbtn{width:34px;height:34px;display:grid;place-items:center;border-radius:8px;border:1px solid var(--line);background:var(--surface);cursor:pointer;color:var(--ink-2);position:relative}.tb-iconbtn:hover{background:var(--surface-2)}.tb-iconbtn .dot{position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--terra-500);border:2px solid var(--surface)}.page{flex:1;min-height:0;overflow-y:auto;background:var(--bg-page)}.page-inner{padding:24px 32px;max-width:1440px;margin:0 auto}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;gap:24px}.page-header h1{margin:0;font-family:var(--font-display);font-size:32px;font-weight:500;letter-spacing:-.02em;color:var(--ink)}.page-header .sub{margin-top:4px;color:var(--ink-3);font-size:13.5px}.page-header .actions{display:flex;gap:10px;align-items:center}.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:9px;font-size:13px;font-weight:500;border:1px solid transparent;cursor:pointer;transition:all .12s;white-space:nowrap;background:var(--surface);border-color:var(--line);color:var(--ink)}.btn:hover{background:var(--surface-2)}.btn .ico{width:14px;height:14px}.btn.primary{background:var(--terra-500);color:#fff;border-color:var(--terra-600);box-shadow:var(--shadow-sm)}.btn.primary:hover{background:var(--terra-600)}.btn.dark{background:var(--bark-700);color:#fff;border-color:var(--bark-800)}.btn.dark:hover{background:var(--bark-800)}.btn.ghost{background:transparent;border-color:transparent}.btn.ghost:hover{background:var(--surface-2)}.btn.danger{background:var(--rose-500);color:#fff;border-color:var(--rose-700)}.btn.sm{padding:5px 10px;font-size:12px;border-radius:7px}.btn.lg{padding:11px 18px;font-size:14px}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.card-head{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:10px}.card-head>div:first-child{min-width:0;flex:1}.card-head h3{margin:0;font-size:14px;font-weight:600;color:var(--ink);letter-spacing:-.005em}.card-head .sub{font-size:12px;color:var(--ink-3);margin-top:2px}.card-body{padding:18px}.card-body.flush{padding:0}.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;position:relative;overflow:hidden}.kpi .label{font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);font-weight:500}.kpi .value{font-family:var(--font-display);font-size:30px;font-weight:500;letter-spacing:-.02em;margin-top:6px;color:var(--ink)}.kpi .row{display:flex;align-items:center;justify-content:space-between;gap:12px}.kpi .delta{font-size:11.5px;font-weight:500;padding:2px 8px;border-radius:5px;display:inline-flex;align-items:center;gap:3px}.kpi .delta.up{background:var(--pine-100);color:var(--pine-700)}.kpi .delta.down{background:var(--rose-100);color:var(--rose-700)}.kpi .spark{height:36px;margin-top:10px}.kpi .meta{font-size:11.5px;color:var(--ink-3);margin-top:6px}.avatar{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:600;color:#fff;flex-shrink:0;text-transform:uppercase;letter-spacing:.02em}.avatar.av-1{background:var(--av-1)}.avatar.av-2{background:var(--av-2)}.avatar.av-3{background:var(--av-3)}.avatar.av-4{background:var(--av-4)}.avatar.av-5{background:var(--av-5)}.avatar.av-6{background:var(--av-6)}.avatar.lg{width:40px;height:40px;font-size:13px}.avatar.xl{width:60px;height:60px;font-size:17px}.avatar.xxl{width:84px;height:84px;font-size:24px}.avatar.sm{width:22px;height:22px;font-size:10px}.pet-emoji{width:32px;height:32px;border-radius:50%;background:var(--cream-200);display:grid;place-items:center;font-size:17px;flex-shrink:0;border:1px solid var(--line)}.pet-emoji.lg{width:44px;height:44px;font-size:22px}.pet-emoji.xl{width:64px;height:64px;font-size:32px}.chip{display:inline-flex;align-items:center;gap:6px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:500;background:var(--surface-3);color:var(--ink-2);border:1px solid var(--line)}.chip.terra{background:var(--terra-100);color:var(--terra-700);border-color:var(--terra-200)}.chip.pine{background:var(--pine-100);color:var(--pine-700);border-color:var(--pine-200)}.chip.plum{background:var(--plum-100);color:var(--plum-700);border-color:var(--plum-200)}.chip.sun{background:var(--sun-100);color:var(--sun-700);border-color:#d49b1e4d}.chip.rose{background:var(--rose-100);color:var(--rose-700)}.chip.info{background:var(--info-bg);color:var(--info)}.chip.bark{background:var(--bark-100);color:var(--bark-700)}.chip.active{background:var(--bark-700);color:#fff;border-color:var(--bark-700)}.chip.dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}.tag{font-size:10.5px;font-weight:500;padding:1.5px 6px;border-radius:4px;background:var(--bark-100);color:var(--bark-600);text-transform:uppercase;letter-spacing:.04em}.tag.clickable{cursor:pointer;padding:3px 10px;border-radius:6px;-webkit-user-select:none;user-select:none}.tag.clickable:hover{opacity:.8}.tag.selected{outline:2px solid currentColor;outline-offset:1px}.tag.vip{background:var(--sun-100);color:var(--sun-700)}.tag.new{background:var(--pine-100);color:var(--pine-700)}.tag.recurring{background:var(--terra-100);color:var(--terra-700)}.tbl{width:100%;border-collapse:collapse}.tbl th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);padding:10px 16px;border-bottom:1px solid var(--line);background:var(--surface-2);position:sticky;top:0;z-index:1}.tbl td{padding:12px 16px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:middle}.tbl tr:hover td{background:var(--cream-50)}.tbl tr:last-child td{border-bottom:none}.tbl .num{text-align:right;font-variant-numeric:tabular-nums}.tbl .compact td{padding:8px 16px}.tbl .clickable tr{cursor:pointer}.iconbtn{background:none;border:none;cursor:pointer;padding:4px;border-radius:6px;color:var(--ink-3);display:flex;align-items:center;justify-content:center}.iconbtn:hover{background:var(--surface-2);color:var(--ink-1)}.row-menu{position:absolute;right:0;top:100%;z-index:20;background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:0 4px 16px #0000001a;min-width:150px;padding:4px}.row-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:none;cursor:pointer;font-size:13px;color:var(--ink-1);border-radius:6px;text-align:left}.row-menu-item:hover{background:var(--surface-2)}.row-menu-item.danger{color:var(--rose-500)}.row-menu-item.danger:hover{background:var(--rose-50)}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:12px;font-weight:500;color:var(--ink-2)}.field .hint{font-size:11.5px;color:var(--ink-3)}.input,.select,.textarea{width:100%;padding:8px 12px;border:1px solid var(--line);border-radius:8px;background:var(--surface);font-size:13.5px;outline:none;transition:border-color .12s,background .12s,box-shadow .12s}.input:focus,.select:focus,.textarea:focus{border-color:var(--terra-400);box-shadow:0 0 0 3px #c66f3e1f}.textarea{resize:vertical;min-height:80px;font-family:inherit}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%235e4d3c' stroke-width='1.5'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:14px;padding-right:32px}.toggle{width:34px;height:20px;background:var(--bark-200);border-radius:999px;position:relative;cursor:pointer;transition:background .12s;flex-shrink:0}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .14s;box-shadow:0 1px 2px #0003}.toggle.on{background:var(--terra-500)}.toggle.on:after{transform:translate(14px)}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--line);margin-bottom:18px;overflow-x:auto}.tab{padding:9px 14px;font-size:13px;font-weight:500;color:var(--ink-3);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;display:flex;align-items:center;gap:6px}.tab:hover{color:var(--ink-2)}.tab.active{color:var(--terra-600);border-bottom-color:var(--terra-500)}.tab .count{font-size:11px;color:var(--ink-3);background:var(--surface-3);padding:1px 6px;border-radius:4px}.tab.active .count{background:var(--terra-100);color:var(--terra-700)}.muted{color:var(--ink-3)}.softer{color:var(--ink-soft)}.mono{font-family:var(--font-mono);font-size:12px}.divider{height:1px;background:var(--line);margin:16px 0}.flex{display:flex}.row{display:flex;align-items:center;gap:10px}.col{display:flex;flex-direction:column}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-10{gap:10px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}.between{justify-content:space-between}.grow{flex:1;min-width:0}.center{align-items:center}.ellip{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nowrap{white-space:nowrap}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.empty{text-align:center;padding:60px 20px;color:var(--ink-3);font-size:13px}.empty .ttl{color:var(--ink);font-weight:500;font-size:14px;margin-bottom:4px}.s-scheduled{color:var(--info)}.s-completed{color:var(--ink-3)}.s-in_progress{color:var(--terra-600)}.s-cancelled{color:var(--ink-soft)}.s-paid{color:var(--pine-700)}.s-unpaid{color:var(--sun-700)}.s-past_due{color:var(--rose-700)}.s-issued{color:var(--info)}.s-draft{color:var(--ink-3)}.dot-status{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.dot-status.scheduled{background:var(--info)}.dot-status.completed{background:var(--bark-300)}.dot-status.in_progress{background:var(--terra-500);animation:pulse 1.6s ease-in-out infinite}.dot-status.cancelled{background:var(--ink-soft)}.dot-status.paid{background:var(--pine-500)}.dot-status.unpaid{background:var(--sun-500)}.dot-status.past_due{background:var(--rose-500)}.dot-status.issued{background:var(--info)}.dot-status.draft{background:var(--bark-300)}@keyframes pulse{0%,to{box-shadow:0 0 #c66f3e80}50%{box-shadow:0 0 0 5px #c66f3e00}}.page::-webkit-scrollbar,.scroll::-webkit-scrollbar{width:10px;height:10px}.page::-webkit-scrollbar-thumb,.scroll::-webkit-scrollbar-thumb{background:var(--bark-200);border-radius:999px;border:2px solid var(--bg-page)}.page::-webkit-scrollbar-track,.scroll::-webkit-scrollbar-track{background:transparent}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#2d221852;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;display:grid;place-items:center;padding:40px 20px;animation:fade .14s ease-out}@keyframes fade{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:100%;max-height:100%;overflow:hidden;display:flex;flex-direction:column;animation:rise .16s ease-out}@keyframes rise{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-head{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-shrink:0}.modal-head h2{margin:0;font-size:17px;font-weight:600}.modal-body{padding:22px;overflow-y:auto;flex:1;min-height:0}.modal-foot{padding:14px 22px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end;flex-shrink:0;background:var(--surface-2)}.iconbtn-x{width:28px;height:28px;border-radius:6px;display:grid;place-items:center;cursor:pointer;color:var(--ink-3);border:0;background:transparent}.iconbtn-x:hover{background:var(--surface-3);color:var(--ink)}.drawer-back{position:fixed;top:0;right:0;bottom:0;left:0;background:#2d22184d;z-index:100;animation:fade .14s}.drawer{position:fixed;top:0;right:0;bottom:0;width:520px;max-width:100%;background:var(--surface);box-shadow:-8px 0 30px #2d221826;z-index:101;display:flex;flex-direction:column;animation:slidein .2s ease-out}@keyframes slidein{0%{transform:translate(20px);opacity:.5}to{transform:translate(0);opacity:1}}@keyframes toastIn{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.drawer-head{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-shrink:0}.drawer-head h2{margin:0;font-size:17px;font-weight:600}.drawer-body{flex:1;overflow-y:auto;padding:22px}.drawer-foot{padding:14px 22px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end;background:var(--surface-2)}.brandmark{width:32px;height:32px;background:linear-gradient(135deg,var(--terra-400),var(--terra-600));border-radius:9px;display:grid;place-items:center;color:#fff}.hr-soft{height:1px;background:var(--line);border:0;margin:0}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.gallery-grid.dense{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.photo{position:relative;aspect-ratio:4 / 3;border-radius:12px;overflow:hidden;cursor:pointer;background:var(--surface-2);border:1px solid var(--line);transition:transform .15s ease,box-shadow .15s ease;isolation:isolate}.photo:hover{transform:translateY(-2px);box-shadow:0 8px 22px #3c1e0a1f}.photo.selected{outline:3px solid var(--terra-500);outline-offset:2px}.photo .ph-fill{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--patt-bg, linear-gradient(135deg, #d8b88a, #8b6f47))}.photo .ph-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:var(--patt-deco, none);background-size:var(--patt-size, 22px 22px);opacity:var(--patt-opacity, .32);mix-blend-mode:var(--patt-blend, soft-light)}.photo .ph-fill:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.18),transparent 55%),radial-gradient(circle at 80% 90%,rgba(0,0,0,.22),transparent 60%)}.photo .ph-tag{position:absolute;top:8px;left:8px;z-index:3;padding:3px 8px;border-radius:999px;font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.photo .ph-tag.before{background:#ffffffeb;color:var(--bark-700)}.photo .ph-tag.after{background:var(--pine-600);color:#fff}.photo .ph-meta{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:18px 10px 8px;background:linear-gradient(to top,rgba(0,0,0,.55),transparent);color:#fff;font-size:11.5px;display:flex;justify-content:space-between;gap:6px;opacity:0;transition:opacity .15s ease}.photo:hover .ph-meta{opacity:1}.photo .ph-meta .cap{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.photo .ph-check{position:absolute;top:8px;right:8px;z-index:4;width:22px;height:22px;border-radius:50%;background:#ffffffd9;display:grid;place-items:center;border:2px solid white;opacity:0;transition:opacity .15s ease;color:var(--bark-700)}.photo:hover .ph-check,.gallery-grid.selecting .photo .ph-check{opacity:1}.photo.selected .ph-check{opacity:1;background:var(--terra-500);color:#fff;border-color:var(--terra-500)}.photo-pair{display:grid;grid-template-columns:1fr 1fr;gap:0;aspect-ratio:8 / 3;border-radius:12px;overflow:hidden;border:1px solid var(--line);position:relative;cursor:pointer}.photo-pair .photo{border-radius:0;border:0;aspect-ratio:auto}.photo-pair .pair-divider{position:absolute;left:50%;top:0;bottom:0;width:2px;background:#fff;transform:translate(-50%);z-index:5}.photo-pair .pair-label{position:absolute;bottom:8px;z-index:6;padding:3px 8px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;background:#0000008c;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.photo-pair .pair-label.before{left:8px}.photo-pair .pair-label.after{right:8px}.gallery-group{margin-bottom:22px}.gallery-group-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}.gallery-group-head .date{font-family:var(--font-display);font-size:16px;font-weight:500}.gallery-group-head .meta{font-size:12px;color:var(--muted)}.gallery-group-head:after{content:"";flex:1;height:1px;background:var(--line)}.gallery-filters{display:flex;gap:8px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--line);flex-wrap:wrap}.filt-chip{padding:6px 12px;border-radius:999px;border:1px solid var(--line);background:var(--surface);font-size:12.5px;cursor:pointer;transition:all .12s;display:inline-flex;align-items:center;gap:6px}.filt-chip:hover{background:var(--surface-2)}.filt-chip.active{background:var(--bark-700);color:#fff;border-color:var(--bark-700)}.filt-chip .ct{font-size:11px;opacity:.65}.filt-chip.active .ct{opacity:.85}.photo-upload{aspect-ratio:4 / 3;border-radius:12px;border:2px dashed var(--terra-300);background:var(--terra-50);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--terra-700);cursor:pointer;transition:background .12s,border-color .12s;font-size:13px}.photo-upload:hover{background:var(--terra-100);border-color:var(--terra-500)}.photo-upload .ico-wrap{width:38px;height:38px;border-radius:50%;background:#fff;display:grid;place-items:center;color:var(--terra-600)}.lightbox-back{position:fixed;top:0;right:0;bottom:0;left:0;background:#140c06e0;z-index:200;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.lightbox{width:min(900px,92vw);max-height:92vh;background:var(--surface);border-radius:16px;overflow:hidden;display:grid;grid-template-rows:1fr auto;box-shadow:0 30px 80px #0009}.lightbox-frame{position:relative;background:#1a1108;aspect-ratio:4 / 3;overflow:hidden}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:#fffffff2;border:0;display:grid;place-items:center;cursor:pointer;z-index:5;color:var(--bark-700);box-shadow:0 4px 14px #0000004d}.lightbox-nav:hover{background:#fff}.lightbox-nav.prev{left:14px}.lightbox-nav.next{right:14px}.lightbox-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:#00000080;color:#fff;border:0;display:grid;place-items:center;cursor:pointer;z-index:5}.lightbox-counter{position:absolute;top:12px;left:16px;padding:4px 10px;border-radius:999px;background:#0000008c;color:#fff;font-size:12px;z-index:5}.lightbox-foot{padding:14px 18px;display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;background:var(--surface)}.lightbox-foot .cap{font-size:14px}.lightbox-foot .meta{font-size:12px;color:var(--muted);margin-top:3px}.lightbox-foot .actions{display:flex;gap:8px}.selection-bar{position:sticky;top:0;z-index:10;padding:10px 14px;background:var(--bark-700);color:#fff;border-radius:10px;margin-bottom:14px;display:flex;align-items:center;gap:12px;box-shadow:0 6px 18px #3c1e0a2e}.selection-bar .ct{font-weight:600;font-size:13px}.selection-bar .btn{background:#ffffff24;color:#fff;border-color:transparent}.selection-bar .btn:hover{background:#ffffff3d}.report-card{background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:16px;display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:start}.report-card .icon-wrap{width:40px;height:40px;border-radius:10px;background:var(--pine-100);color:var(--pine-700);display:grid;place-items:center}.report-card .meta{font-size:12px;color:var(--muted);margin-top:2px}.report-card .summary{font-size:13.5px;line-height:1.5;margin-top:8px;color:var(--bark-800)}.report-empty{background:var(--terra-50);border:1px dashed var(--terra-300);border-radius:12px;padding:18px;display:flex;align-items:center;gap:14px}.report-empty .icon-wrap{width:44px;height:44px;border-radius:10px;background:#fff;color:var(--terra-600);display:grid;place-items:center}.report-empty .body{flex:1;font-size:13px}.report-empty .body strong{color:var(--bark-800);display:block;margin-bottom:2px}.complete-prompt{position:absolute;top:0;right:0;bottom:0;left:0;background:#fffdfaf5;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:5;display:flex;align-items:center;justify-content:center;border-radius:inherit}.complete-prompt .inner{max-width:380px;text-align:center;padding:24px}.complete-prompt .check-circle{width:64px;height:64px;border-radius:50%;background:var(--pine-500);color:#fff;display:grid;place-items:center;margin:0 auto 14px;box-shadow:0 0 0 8px var(--pine-100);animation:pop-in .35s cubic-bezier(.34,1.56,.64,1)}@keyframes pop-in{0%{transform:scale(.5);opacity:0}}.complete-prompt h3{font-family:var(--font-display);font-size:22px;font-weight:500;margin:0 0 6px}.complete-prompt p{font-size:13.5px;color:var(--muted);margin:0 0 18px}.complete-prompt .actions{display:flex;gap:10px;justify-content:center}.vitals-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.vital-chip{background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px}.vital-chip .lbl{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:4px}.vital-chip input{border:0;padding:0;font-size:14px;font-weight:500;width:100%;background:transparent}.vital-chip input:focus{outline:none}.photo-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px;max-height:280px;overflow-y:auto;padding:4px}.photo-picker .photo{aspect-ratio:1 / 1;border-radius:8px}.photo-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:6px}.photo-strip .photo{aspect-ratio:1 / 1;border-radius:8px}.patt-spaniel-before{--patt-bg: linear-gradient(135deg, #c89568 0%, #8b6f47 60%, #4a3728 100%);--patt-deco: radial-gradient(circle at 20% 20%, rgba(255,255,255,.5) 1.5px, transparent 2px);--patt-size: 14px 14px;--patt-opacity: .45}.patt-spaniel-after{--patt-bg: linear-gradient(135deg, #f9d49b 0%, #d4a373 50%, #7a5230 100%);--patt-deco: repeating-linear-gradient(115deg, transparent 0 8px, rgba(255,255,255,.18) 8px 9px);--patt-opacity: .7}.patt-spaniel-coat{--patt-bg: linear-gradient(150deg, #d4a373 0%, #a07a5a 100%);--patt-deco: repeating-linear-gradient(60deg, transparent 0 6px, rgba(0,0,0,.1) 6px 7px);--patt-opacity: .5}.patt-spaniel-pose{--patt-bg: radial-gradient(ellipse at 35% 40%, #e8c896 0%, #b08560 60%, #6a4a30 100%);--patt-deco: radial-gradient(circle, rgba(255,255,255,.3) 1px, transparent 1.5px);--patt-size: 18px 18px}.patt-spaniel-portrait{--patt-bg: radial-gradient(ellipse at 40% 30%, #e0b890 0%, #a07a55 50%, #4a3220 100%);--patt-deco: radial-gradient(circle, rgba(255,255,255,.15) .5px, transparent 1px);--patt-size: 8px 8px}.patt-ear-detail{--patt-bg: radial-gradient(circle at 50% 50%, #d4a373 0%, #6a4830 70%, #2a1a10 100%);--patt-deco: radial-gradient(circle, rgba(255,255,255,.2) 1px, transparent 2px);--patt-size: 12px 12px}.patt-berner-before{--patt-bg: linear-gradient(135deg, #5b3a1f 0%, #2c2c2c 50%, #f5e6d0 100%);--patt-deco: radial-gradient(circle, rgba(255,255,255,.2) 1px, transparent 2px);--patt-size: 10px 10px;--patt-opacity: .5}.patt-berner-after{--patt-bg: linear-gradient(135deg, #7a5a3a 0%, #1a1a1a 45%, #fae8c8 100%);--patt-deco: repeating-linear-gradient(120deg, transparent 0 7px, rgba(255,255,255,.15) 7px 8px);--patt-opacity: .55}.patt-berner-paw{--patt-bg: radial-gradient(circle at 50% 60%, #4a3020 0%, #1a1008 100%);--patt-deco: radial-gradient(circle, rgba(255,255,255,.18) 1px, transparent 2px);--patt-size: 14px 14px}.patt-poodle-before{--patt-bg: linear-gradient(135deg, #e8c896 0%, #c89548 50%, #6b4a30 100%);--patt-deco: radial-gradient(circle, rgba(255,255,255,.45) 1.5px, transparent 2px);--patt-size: 8px 8px;--patt-opacity: .5}.patt-poodle-after{--patt-bg: linear-gradient(135deg, #fae0b0 0%, #e0b870 60%, #946530 100%);--patt-deco: radial-gradient(circle, rgba(255,255,255,.5) 2px, transparent 2.5px);--patt-size: 10px 10px;--patt-opacity: .6}.patt-poodle-tail{--patt-bg: radial-gradient(circle at 30% 40%, #fde0a0 0%, #d4a868 80%);--patt-deco: radial-gradient(circle, rgba(255,255,255,.55) 2.5px, transparent 3px);--patt-size: 12px 12px}.patt-frenchie-portrait{--patt-bg: radial-gradient(ellipse at 45% 30%, #f0d4a8 0%, #c89568 60%, #6a4830 100%);--patt-deco: radial-gradient(circle, rgba(0,0,0,.1) 1px, transparent 2px);--patt-size: 14px 14px;--patt-opacity: .5}.patt-whippet-paw-before{--patt-bg: linear-gradient(150deg, #d8b88a 0%, #886648 100%);--patt-deco: repeating-linear-gradient(90deg, transparent 0 12px, rgba(0,0,0,.12) 12px 14px);--patt-opacity: .5}.patt-whippet-paw-after{--patt-bg: linear-gradient(150deg, #e8c896 0%, #a08260 100%);--patt-deco: repeating-linear-gradient(90deg, transparent 0 14px, rgba(255,255,255,.2) 14px 16px);--patt-opacity: .45}.patt-schnauzer-walk{--patt-bg: linear-gradient(160deg, #4a6a5a 0%, #6a8b76 50%, #c8b896 100%);--patt-deco: repeating-linear-gradient(75deg, transparent 0 10px, rgba(255,255,255,.15) 10px 11px);--patt-opacity: .5}.patt-schnauzer-park{--patt-bg: linear-gradient(160deg, #98b8a0 0%, #5a8068 60%, #2a4030 100%);--patt-deco: radial-gradient(circle, rgba(255,255,255,.25) 1px, transparent 2px);--patt-size: 16px 16px}.patt-schnauzer-rest{--patt-bg: linear-gradient(135deg, #a8a8a8 0%, #6a6a6a 60%, #2a2a2a 100%);--patt-deco: radial-gradient(circle, rgba(255,255,255,.18) 1px, transparent 2px);--patt-size: 10px 10px}.patt-husky-before{--patt-bg: linear-gradient(135deg, #c2c5c8 0%, #7a8089 50%, #2a3038 100%);--patt-deco: repeating-linear-gradient(100deg, transparent 0 6px, rgba(255,255,255,.18) 6px 7px);--patt-opacity: .55}.patt-husky-after{--patt-bg: linear-gradient(135deg, #e8eaed 0%, #a5abb3 50%, #555a62 100%);--patt-deco: repeating-linear-gradient(100deg, transparent 0 8px, rgba(255,255,255,.25) 8px 9px);--patt-opacity: .65}.patt-shiba-portrait{--patt-bg: radial-gradient(ellipse at 50% 35%, #f5c875 0%, #c88548 60%, #6a3818 100%);--patt-deco: radial-gradient(circle, rgba(255,255,255,.18) 1px, transparent 2px);--patt-size: 12px 12px;--patt-opacity: .5}.patt-lab-senior{--patt-bg: radial-gradient(ellipse at 40% 35%, #e8d088 0%, #b89860 60%, #6a5028 100%);--patt-deco: radial-gradient(circle, rgba(255,255,255,.2) 1px, transparent 2px);--patt-size: 10px 10px;--patt-opacity: .5}.patt-border-bath-before{--patt-bg: linear-gradient(135deg, #6b5530 0%, #3a2818 60%, #1a0e08 100%);--patt-deco: radial-gradient(circle, rgba(255,255,255,.15) 1px, transparent 2px);--patt-size: 10px 10px;--patt-opacity: .5}.patt-border-bath-after{--patt-bg: linear-gradient(135deg, #f0e8d8 0%, #6e6058 50%, #2a2520 100%);--patt-deco: repeating-linear-gradient(90deg, transparent 0 8px, rgba(255,255,255,.18) 8px 9px);--patt-opacity: .55}.hamburger,.sidebar-overlay,.back-btn{display:none}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.dash-main{display:grid;grid-template-columns:1.4fr 1fr;gap:20px}.dash-bottom{display:grid;grid-template-columns:1fr 1fr;gap:20px}.profile-header{display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center}.overview-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px}.msg-layout{display:grid;grid-template-columns:320px 1fr;height:100%}.msg-layout.context-open{grid-template-columns:320px 1fr 300px}.msg-list,.msg-thread{display:flex;flex-direction:column}.msg-context{display:flex;flex-direction:column;border-left:1px solid var(--line);background:var(--surface-2);overflow-y:auto}.msg-bubble{max-width:460px;padding:10px 14px;border-radius:14px;font-size:13.5px;line-height:1.5;word-break:break-word}.msg-bubble.inbound{background:#fff;color:var(--ink);border:1px solid var(--line);border-bottom-left-radius:4px}.msg-bubble.outbound{background:var(--terra-500);color:#fff;border-bottom-right-radius:4px}.msg-date-sep{display:flex;align-items:center;gap:12px;margin:18px 0;font-size:11px;font-weight:500;color:var(--ink-3);text-transform:uppercase;letter-spacing:.03em}.msg-date-sep:before,.msg-date-sep:after{content:"";flex:1;height:1px;background:var(--line)}.char-counter{font-size:11px;color:var(--ink-3);text-align:right;margin-top:4px}.char-counter.warn{color:var(--amber-600, #d97706);font-weight:500}.msg-status{font-size:10px;margin-top:2px;display:inline-flex;align-items:center;gap:3px;color:var(--ink-3)}.msg-status.failed{color:var(--rose-500, #f43f5e)}.attach-option{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;border:none;background:none;font-size:13px;color:var(--ink);cursor:pointer;text-align:left}.attach-option:hover{background:var(--surface-2, #f5f5f5)}.msg-status.delivered{color:var(--pine-500, #22c55e)}.settings-layout{display:grid;grid-template-columns:220px 1fr;gap:24px}.auth-layout{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;background:var(--bg-page)}.pet-list-layout{display:grid;grid-template-columns:140px 1fr}.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.phone-picker{display:flex;flex-direction:column;gap:16px}.phone-picker-search{position:relative}.phone-picker-search input{width:100%;padding:10px 12px 10px 36px;border:1px solid var(--line);border-radius:9px;background:var(--surface);font-size:13.5px;outline:none;transition:border-color .12s}.phone-picker-search input:focus{border-color:var(--terra-400);box-shadow:0 0 0 3px #c66f3e1f}.phone-picker-search .ico{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--ink-3)}.phone-picker-list{display:flex;flex-direction:column;gap:8px}.number-card{display:flex;flex-direction:column;gap:4px;padding:12px 16px;border:1.5px solid var(--line);border-radius:10px;background:var(--surface);cursor:pointer;transition:border-color .12s,background .12s,box-shadow .12s}.number-card:hover{border-color:var(--terra-300);background:var(--terra-50)}.number-card.selected{border-color:var(--terra-500);background:var(--terra-50);box-shadow:0 0 0 3px #c66f3e1f}.number-card-main{display:flex;align-items:center;gap:10px}.number-card-number{font-family:var(--font-mono, monospace);font-size:14px;font-weight:500;color:var(--ink);flex:1}.number-card-check{color:var(--terra-500)}.number-card-meta{font-size:12px;color:var(--ink-3);padding-left:28px}.phone-picker-error{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--rose-50, #fff1f2);color:var(--rose-700, #be123c);border-radius:8px;font-size:13px}.phone-picker-error button{margin-left:auto;background:none;border:none;cursor:pointer;color:var(--rose-700, #be123c);font-weight:500;text-decoration:underline}.phone-assigned{display:flex;align-items:center;gap:12px;padding:16px;border:1.5px solid var(--line);border-radius:10px;background:var(--surface)}.phone-assigned-number{font-family:var(--font-mono, monospace);font-size:16px;font-weight:600;color:var(--ink)}.phone-assigned-badge{font-size:11px;font-weight:600;text-transform:uppercase;padding:2px 8px;border-radius:4px;background:var(--pine-100, #dcfce7);color:var(--pine-700, #15803d)}.onboarding{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg, #faf9f6);padding:24px}.onboarding-card{width:100%;max-width:520px;display:flex;flex-direction:column;gap:24px;background:var(--surface, #fff);border:1px solid var(--line);border-radius:16px;padding:40px}.onboarding-logo{display:flex;align-items:center;gap:8px;font-size:20px;font-weight:700;color:var(--pine-600, #16a34a)}.onboarding-steps{display:flex;align-items:center;gap:0;justify-content:center}.onboarding-step-dot{width:10px;height:10px;border-radius:50%;background:var(--line);transition:background .2s}.onboarding-step-dot.active{background:var(--pine-600, #16a34a)}.onboarding-step-line{width:40px;height:2px;background:var(--line)}.onboarding-header h2{font-size:20px;font-weight:600;margin:0 0 6px}.onboarding-form{display:flex;flex-direction:column;gap:16px}.onboarding-form .form-field{display:flex;flex-direction:column;gap:4px}.onboarding-form .form-label{font-size:13px;font-weight:500;color:var(--muted)}.onboarding-form input{padding:10px 12px;border:1px solid var(--line);border-radius:8px;font-size:14px;background:var(--bg, #faf9f6)}.onboarding-form input:focus{outline:none;border-color:var(--pine-500, #22c55e)}.onboarding-phone-step{display:flex;flex-direction:column;gap:12px}.onboarding-footer{text-align:center;font-size:13px}@media(max-width:768px){.shell{grid-template-columns:1fr}.sidebar{position:fixed;top:0;bottom:0;left:0;right:auto;z-index:90;width:280px;transform:translate(-100%);transition:transform .25s ease}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#2d221866;z-index:89;opacity:0;pointer-events:none;transition:opacity .25s ease}.sidebar-overlay.visible{opacity:1;pointer-events:auto}.hamburger{display:flex}.topbar{padding:0 12px;gap:8px}.topbar .crumbs,.topbar .search,.tb-actions .btn.primary.sm span{display:none}.tb-actions .btn.primary.sm{padding:8px 10px;gap:0}.page-inner{padding:16px 14px}.page-header{flex-direction:column;align-items:flex-start;gap:12px}.page-header h1{font-size:24px}.page-header .actions{flex-wrap:wrap}.grid-2,.grid-3{grid-template-columns:1fr}.grid-4{grid-template-columns:repeat(2,1fr)}.form-grid{grid-template-columns:1fr}.modal-backdrop{padding:8px}.modal{width:100%!important;border-radius:var(--radius)}.modal-head{padding:14px 16px}.modal-body{padding:16px}.modal-foot{padding:12px 16px}.drawer{width:100%}.tbl-wrap .tbl{min-width:500px}.hide-mobile{display:none}.dash-main,.dash-bottom{grid-template-columns:1fr}.client-toolbar{flex-direction:column;align-items:stretch;gap:12px}.client-toolbar .search{max-width:100%}.profile-header{grid-template-columns:1fr;text-align:center;gap:12px}.profile-header .avatar{margin:0 auto}.profile-header .row{flex-wrap:wrap;justify-content:center}.overview-grid,.msg-layout,.msg-layout.context-open{grid-template-columns:1fr}.msg-layout .msg-thread,.msg-layout.thread-active .msg-list{display:none}.msg-layout.thread-active .msg-thread{display:flex}.msg-context{display:none}.back-btn{display:inline-flex}.settings-layout{grid-template-columns:1fr;gap:12px}.settings-layout>.col:first-child{flex-direction:row;overflow-x:auto;gap:4px;padding-bottom:8px;-webkit-overflow-scrolling:touch}.auth-layout{grid-template-columns:1fr}.auth-layout>div:last-child{display:none}.pet-list-layout{grid-template-columns:1fr}.pet-list-layout>div:first-child{display:none}}@keyframes spin{to{transform:rotate(360deg)}}.period-toggle{display:flex;gap:4px}.period-toggle .btn.sm.active{background:var(--bark-700);color:#fff}.shimmer{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 50%,var(--surface-2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}html[data-density=compact]{--topbar-h: 52px}html[data-density=comfy]{--topbar-h: 68px}html[data-density=compact] .page-inner{padding:18px 22px 40px}html[data-density=comfy] .page-inner{padding:32px 36px 64px}html[data-density=compact] .card-body{padding:14px}html[data-density=comfy] .card-body{padding:22px}html[data-density=compact] .kpi{padding:14px}html[data-density=comfy] .kpi{padding:22px}html[data-radius=sharp]{--radius: 4px;--radius-lg: 8px}html[data-radius=rounded]{--radius: 14px;--radius-lg: 20px}html[data-radius=pill]{--radius: 18px;--radius-lg: 26px}html[data-theme=crisp]{--bg-page: #f4f5f7;--surface: #ffffff;--surface-2: #f7f8fa;--surface-3: #eef0f3;--line: rgba(20, 25, 40, .08);--line-strong: rgba(20, 25, 40, .18);--ink: #15181f;--ink-2: #3d4250;--ink-3: #6b7283;--ink-soft: #9aa0ad;--primary: var(--terra-500);--primary-d: var(--terra-600);--primary-l: var(--terra-100)}html[data-theme=crisp] .sidebar{background:#1a1d26;color:#e6e8ee}html[data-theme=crisp] .sb-item:hover{background:#ffffff0f}html[data-theme=crisp] .sb-item.active{background:var(--primary)}html[data-theme=crisp] .tbl tr:hover td,html[data-theme=crisp] .modal-foot,html[data-theme=crisp] .drawer-foot{background:#f7f8fa}html[data-theme=indigo]{--bg-page: #f1f3f9;--surface: #ffffff;--surface-2: #f6f7fc;--surface-3: #ebeef7;--line: rgba(40, 48, 90, .1);--line-strong: rgba(40, 48, 90, .22);--ink: #161a2e;--ink-2: #3a4060;--ink-3: #6b7396;--ink-soft: #9aa1bf;--primary: #4f5dd9;--primary-d: #3a47b8;--primary-l: #e2e6fb}html[data-theme=indigo] .sidebar{background:#1f2444;color:#e8ebf8}html[data-theme=indigo] .sb-item:hover{background:#ffffff14}html[data-theme=indigo] .sb-item.active{background:var(--primary)}html[data-theme=indigo] .sb-brand .logo{background:linear-gradient(135deg,#6b78e8,#3a47b8)}html[data-theme=indigo] .btn.primary{background:var(--primary);border-color:var(--primary-d)}html[data-theme=indigo] .btn.primary:hover{background:var(--primary-d)}html[data-theme=indigo] .btn.dark{background:#1f2444;border-color:#161a2e}html[data-theme=indigo] .input:focus,html[data-theme=indigo] .select:focus,html[data-theme=indigo] .textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f5dd926}html[data-theme=indigo] .search input:focus{border-color:var(--primary)}html[data-theme=indigo] .toggle.on{background:var(--primary)}html[data-theme=indigo] .tab.active{color:var(--primary);border-bottom-color:var(--primary)}html[data-theme=indigo] .tab.active .count{background:var(--primary-l);color:var(--primary-d)}html[data-theme=indigo] .sb-item .badge{background:var(--primary)}html[data-theme=indigo] .tbl tr:hover td,html[data-theme=indigo] .modal-foot,html[data-theme=indigo] .drawer-foot{background:#f6f7fc}html[data-theme=indigo] .s-in_progress{color:var(--primary-d)}html[data-theme=indigo] .dot-status.in_progress{background:var(--primary)}html[data-theme=forest]{--bg-page: #eff3ee;--surface: #ffffff;--surface-2: #f5f8f3;--surface-3: #e6ece3;--line: rgba(28, 50, 30, .1);--line-strong: rgba(28, 50, 30, .22);--ink: #15211a;--ink-2: #38463c;--ink-3: #6a7b6f;--ink-soft: #97a39a;--primary: #2f8a55;--primary-d: #1e6a3f;--primary-l: #d8ecdf}html[data-theme=forest] .sidebar{background:#1a2e22;color:#e6efe9}html[data-theme=forest] .sb-item:hover{background:#ffffff14}html[data-theme=forest] .sb-item.active{background:var(--primary)}html[data-theme=forest] .sb-brand .logo{background:linear-gradient(135deg,#4cae71,#1e6a3f)}html[data-theme=forest] .btn.primary{background:var(--primary);border-color:var(--primary-d)}html[data-theme=forest] .btn.primary:hover{background:var(--primary-d)}html[data-theme=forest] .btn.dark{background:#1a2e22;border-color:#15211a}html[data-theme=forest] .input:focus,html[data-theme=forest] .select:focus,html[data-theme=forest] .textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2f8a5526}html[data-theme=forest] .search input:focus{border-color:var(--primary)}html[data-theme=forest] .toggle.on{background:var(--primary)}html[data-theme=forest] .tab.active{color:var(--primary);border-bottom-color:var(--primary)}html[data-theme=forest] .tab.active .count{background:var(--primary-l);color:var(--primary-d)}html[data-theme=forest] .sb-item .badge{background:var(--primary)}html[data-theme=forest] .tbl tr:hover td,html[data-theme=forest] .modal-foot,html[data-theme=forest] .drawer-foot{background:#f5f8f3}html[data-theme=forest] .s-in_progress{color:var(--primary-d)}html[data-theme=forest] .dot-status.in_progress{background:var(--primary)}html[data-theme=slate]{--bg-page: #f3f4f6;--surface: #ffffff;--surface-2: #f7f8fa;--surface-3: #ebedf1;--line: rgba(20, 25, 35, .1);--line-strong: rgba(20, 25, 35, .22);--ink: #0d1117;--ink-2: #353a44;--ink-3: #6a7180;--ink-soft: #9ba1ad;--primary: #1f2937;--primary-d: #0d1117;--primary-l: #e3e6ec}html[data-theme=slate] .sidebar{background:#0d1117;color:#e7e9ee}html[data-theme=slate] .sb-item:hover{background:#ffffff0f}html[data-theme=slate] .sb-item.active{background:#2c3340;color:#fff;box-shadow:inset 2px 0 #fff}html[data-theme=slate] .sb-brand .logo{background:linear-gradient(135deg,#4b5563,#1f2937)}html[data-theme=slate] .btn.primary{background:var(--primary);border-color:var(--primary-d)}html[data-theme=slate] .btn.primary:hover{background:var(--primary-d)}html[data-theme=slate] .btn.dark{background:#0d1117;border-color:#000}html[data-theme=slate] .input:focus,html[data-theme=slate] .select:focus,html[data-theme=slate] .textarea:focus{border-color:#6a7180;box-shadow:0 0 0 3px #1419231a}html[data-theme=slate] .search input:focus{border-color:#6a7180}html[data-theme=slate] .toggle.on{background:var(--primary)}html[data-theme=slate] .tab.active{color:var(--primary);border-bottom-color:var(--primary)}html[data-theme=slate] .tab.active .count{background:var(--primary-l);color:var(--primary-d)}html[data-theme=slate] .sb-item .badge{background:var(--primary)}html[data-theme=slate] .tbl tr:hover td,html[data-theme=slate] .modal-foot,html[data-theme=slate] .drawer-foot{background:#f7f8fa}html[data-theme=slate] .s-in_progress{color:var(--primary)}html[data-theme=slate] .dot-status.in_progress{background:var(--primary)}html[data-theme=plum]{--bg-page: #f5f1f5;--surface: #ffffff;--surface-2: #faf6fa;--surface-3: #ede5ed;--line: rgba(60, 30, 60, .1);--line-strong: rgba(60, 30, 60, .22);--ink: #1f1421;--ink-2: #463848;--ink-3: #7a6c7e;--ink-soft: #a89aac;--primary: #7e3f8c;--primary-d: #5d2a6a;--primary-l: #ecdef0}html[data-theme=plum] .sidebar{background:#2a1a2e;color:#ede0ee}html[data-theme=plum] .sb-item:hover{background:#ffffff14}html[data-theme=plum] .sb-item.active{background:var(--primary)}html[data-theme=plum] .sb-brand .logo{background:linear-gradient(135deg,#a55fb3,#5d2a6a)}html[data-theme=plum] .btn.primary{background:var(--primary);border-color:var(--primary-d)}html[data-theme=plum] .btn.primary:hover{background:var(--primary-d)}html[data-theme=plum] .btn.dark{background:#2a1a2e;border-color:#1f1421}html[data-theme=plum] .input:focus,html[data-theme=plum] .select:focus,html[data-theme=plum] .textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #7e3f8c26}html[data-theme=plum] .search input:focus{border-color:var(--primary)}html[data-theme=plum] .toggle.on{background:var(--primary)}html[data-theme=plum] .tab.active{color:var(--primary);border-bottom-color:var(--primary)}html[data-theme=plum] .tab.active .count{background:var(--primary-l);color:var(--primary-d)}html[data-theme=plum] .sb-item .badge{background:var(--primary)}html[data-theme=plum] .tbl tr:hover td,html[data-theme=plum] .modal-foot,html[data-theme=plum] .drawer-foot{background:#faf6fa}html[data-theme=plum] .s-in_progress{color:var(--primary-d)}html[data-theme=plum] .dot-status.in_progress{background:var(--primary)}html[data-theme=ocean]{--bg-page: #eef4f6;--surface: #ffffff;--surface-2: #f4f8fa;--surface-3: #e2ecef;--line: rgba(15, 50, 60, .1);--line-strong: rgba(15, 50, 60, .22);--ink: #0e1f24;--ink-2: #2f4751;--ink-3: #62798a;--ink-soft: #93a6b1;--primary: #0d8a93;--primary-d: #066970;--primary-l: #d3ebee}html[data-theme=ocean] .sidebar{background:#0e2a30;color:#e3f0f2}html[data-theme=ocean] .sb-item:hover{background:#ffffff14}html[data-theme=ocean] .sb-item.active{background:var(--primary)}html[data-theme=ocean] .sb-brand .logo{background:linear-gradient(135deg,#2bb1bb,#066970)}html[data-theme=ocean] .btn.primary{background:var(--primary);border-color:var(--primary-d)}html[data-theme=ocean] .btn.primary:hover{background:var(--primary-d)}html[data-theme=ocean] .btn.dark{background:#0e2a30;border-color:#0e1f24}html[data-theme=ocean] .input:focus,html[data-theme=ocean] .select:focus,html[data-theme=ocean] .textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0d8a9326}html[data-theme=ocean] .search input:focus{border-color:var(--primary)}html[data-theme=ocean] .toggle.on{background:var(--primary)}html[data-theme=ocean] .tab.active{color:var(--primary);border-bottom-color:var(--primary)}html[data-theme=ocean] .tab.active .count{background:var(--primary-l);color:var(--primary-d)}html[data-theme=ocean] .sb-item .badge{background:var(--primary)}html[data-theme=ocean] .tbl tr:hover td,html[data-theme=ocean] .modal-foot,html[data-theme=ocean] .drawer-foot{background:#f4f8fa}html[data-theme=ocean] .s-in_progress{color:var(--primary-d)}html[data-theme=ocean] .dot-status.in_progress{background:var(--primary)}html[data-theme=mono]{--bg-page: #fafafa;--surface: #ffffff;--surface-2: #f5f5f5;--surface-3: #ededed;--line: rgba(0, 0, 0, .08);--line-strong: rgba(0, 0, 0, .2);--ink: #000000;--ink-2: #2e2e2e;--ink-3: #6e6e6e;--ink-soft: #a0a0a0;--primary: #000000;--primary-d: #000000;--primary-l: #ededed}html[data-theme=mono] .sidebar{background:#fff;color:#2e2e2e;border-right:1px solid var(--line)}html[data-theme=mono] .sb-section{color:#9a9a9a}html[data-theme=mono] .sb-item{color:#4a4a4a}html[data-theme=mono] .sb-item:hover{background:#f5f5f5;color:#000}html[data-theme=mono] .sb-item.active{background:#000;color:#fff}html[data-theme=mono] .sb-item.active .ico{opacity:1}html[data-theme=mono] .sb-brand{border-bottom-color:var(--line)}html[data-theme=mono] .sb-brand .name{color:#000}html[data-theme=mono] .sb-brand .sub{color:#6e6e6e}html[data-theme=mono] .sb-brand .logo{background:#000}html[data-theme=mono] .btn.primary{background:#000;color:#fff;border-color:#000}html[data-theme=mono] .btn.primary:hover{background:#2e2e2e}html[data-theme=mono] .btn.dark{background:#000;border-color:#000}html[data-theme=mono] .input:focus,html[data-theme=mono] .select:focus,html[data-theme=mono] .textarea:focus{border-color:#000;box-shadow:0 0 0 3px #00000014}html[data-theme=mono] .search input:focus{border-color:#000}html[data-theme=mono] .toggle.on{background:#000}html[data-theme=mono] .tab.active{color:#000;border-bottom-color:#000}html[data-theme=mono] .tab.active .count{background:#ededed;color:#000}html[data-theme=mono] .sb-item .badge{background:#000}html[data-theme=mono] .tbl tr:hover td,html[data-theme=mono] .modal-foot,html[data-theme=mono] .drawer-foot{background:#f5f5f5}html[data-theme=mono] .s-in_progress{color:#000}html[data-theme=mono] .dot-status.in_progress{background:#000}html[data-theme=midnight]{--bg-page: #0e1118;--surface: #161a24;--surface-2: #1d2230;--surface-3: #252b3b;--line: rgba(255, 255, 255, .08);--line-strong: rgba(255, 255, 255, .18);--ink: #f0f2f7;--ink-2: #c5cad6;--ink-3: #8a91a3;--ink-soft: #5e6679;--primary: #ff8a5b;--primary-d: #e66a3a;--primary-l: #3a2418;--pine-100: #1f3326;--pine-700: #6dd095;--rose-100: #3a1f1c;--rose-700: #ff8a78;--sun-100: #382b15;--sun-700: #e8c25a;--info: #6aa9d8;--info-bg: #1a2a38}html[data-theme=midnight] body{background:#0e1118}html[data-theme=midnight] .sidebar{background:#0a0d14;color:#d8dce8}html[data-theme=midnight] .sb-item:hover{background:#ffffff0d}html[data-theme=midnight] .sb-item.active{background:var(--primary);color:#1a0e08}html[data-theme=midnight] .sb-brand .logo{background:linear-gradient(135deg,var(--primary),var(--primary-d))}html[data-theme=midnight] .btn{background:var(--surface-2);color:var(--ink);border-color:var(--line-strong)}html[data-theme=midnight] .btn:hover{background:var(--surface-3)}html[data-theme=midnight] .btn.primary{background:var(--primary);color:#1a0e08;border-color:var(--primary-d)}html[data-theme=midnight] .btn.primary:hover{background:var(--primary-d);color:#fff}html[data-theme=midnight] .btn.dark{background:#000;border-color:#000;color:#fff}html[data-theme=midnight] .btn.ghost{background:transparent;color:var(--ink-2)}html[data-theme=midnight] .btn.ghost:hover{background:var(--surface-2);color:var(--ink)}html[data-theme=midnight] .input,html[data-theme=midnight] .select,html[data-theme=midnight] .textarea{background:var(--surface-2);color:var(--ink);border-color:var(--line-strong)}html[data-theme=midnight] .input:focus,html[data-theme=midnight] .select:focus,html[data-theme=midnight] .textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ff8a5b2e}html[data-theme=midnight] .search input{background:var(--surface-2);color:var(--ink);border-color:var(--line-strong)}html[data-theme=midnight] .search input:focus{border-color:var(--primary);background:var(--surface)}html[data-theme=midnight] .search .kbd{background:var(--surface-3);color:var(--ink-3);border-color:var(--line-strong)}html[data-theme=midnight] .toggle{background:var(--surface-3)}html[data-theme=midnight] .toggle.on{background:var(--primary)}html[data-theme=midnight] .tab.active{color:var(--primary);border-bottom-color:var(--primary)}html[data-theme=midnight] .tab .count{background:var(--surface-2);color:var(--ink-3)}html[data-theme=midnight] .tab.active .count{background:var(--primary-l);color:var(--primary)}html[data-theme=midnight] .sb-item .badge{background:var(--primary);color:#1a0e08}html[data-theme=midnight] .tbl tr:hover td{background:var(--surface-2)}html[data-theme=midnight] .modal,html[data-theme=midnight] .drawer{background:var(--surface);color:var(--ink)}html[data-theme=midnight] .modal-foot,html[data-theme=midnight] .drawer-foot{background:var(--surface-2)}html[data-theme=midnight] .topbar{background:var(--surface)}html[data-theme=midnight] .tb-iconbtn{background:var(--surface-2);border-color:var(--line-strong);color:var(--ink-2)}html[data-theme=midnight] .tb-iconbtn:hover{background:var(--surface-3)}html[data-theme=midnight] .tb-iconbtn .dot{border-color:var(--surface-2)}html[data-theme=midnight] .avatar{background:var(--surface-3);color:var(--ink-2)}html[data-theme=midnight] .chip{border-color:var(--line-strong)}html[data-theme=midnight] .chip.terra{background:#ff8a5b26;color:var(--primary);border-color:#ff8a5b4d}html[data-theme=midnight] .chip.pine{background:#6dd0951f;color:var(--pine-700);border-color:#6dd09540}html[data-theme=midnight] .chip.rose{background:#ff8a781f;color:var(--rose-700);border-color:#ff8a7840}html[data-theme=midnight] .chip.sun{background:#e8c25a1f;color:var(--sun-700);border-color:#e8c25a40}html[data-theme=midnight] .chip.info{background:var(--info-bg);color:var(--info)}html[data-theme=midnight] .chip.bark,html[data-theme=midnight] .tag{background:var(--surface-2);color:var(--ink-2)}html[data-theme=midnight] .tag.vip{background:#e8c25a26;color:var(--sun-700)}html[data-theme=midnight] .tag.new{background:#6dd09526;color:var(--pine-700)}html[data-theme=midnight] .tag.recurring{background:#ff8a5b26;color:var(--primary)}html[data-theme=midnight] .kpi .delta.up{background:#6dd09526;color:var(--pine-700)}html[data-theme=midnight] .kpi .delta.down{background:#ff8a7826;color:var(--rose-700)}html[data-theme=midnight] .iconbtn-x:hover{background:var(--surface-3)}html[data-theme=midnight] .empty{color:var(--ink-3)}html[data-theme=midnight] .s-in_progress{color:var(--primary)}html[data-theme=midnight] .dot-status.in_progress{background:var(--primary)}html[data-theme=midnight] .dot-status.completed{background:var(--ink-3)}html[data-theme=midnight] .page::-webkit-scrollbar-thumb,html[data-theme=midnight] .scroll::-webkit-scrollbar-thumb{background:var(--surface-3);border-color:var(--bg-page)}html[data-theme=midnight] .modal-back,html[data-theme=midnight] .drawer-back{background:#0000008c}
