:root{--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;font-family:var(--font-sans);line-height:1.5;color:#1a2420;background:#f0f4f2}html{font-family:var(--font-sans)}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font-sans)}button,input,textarea,select{font-family:inherit}.app{max-width:720px;margin:0 auto;padding:2rem 1.5rem}header h1{margin:0 0 .75rem;font-size:1.75rem}nav{display:flex;gap:1rem}nav a{color:#2563eb;text-decoration:none;font-weight:500}nav a:hover{text-decoration:underline}main section h2{margin-top:0}:root{--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--auth-bg: #0d2818;--auth-surface: #ffffff;--auth-border: #e2ebe6;--auth-text: #1a2420;--auth-muted: #6b7c75;--auth-primary: #1b4332;--auth-primary-hover: #0d2818;--auth-error-bg: #fef2f2;--auth-error-text: #b91c1c;--auth-radius: 12px;--auth-shadow: 0 25px 50px -12px rgb(15 23 42 / .18)}.auth-page{min-height:100vh;position:relative;display:flex;align-items:stretch;font-family:var(--font-sans)}.auth-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 10% 20%,rgb(64 145 108 / .35),transparent),radial-gradient(ellipse 60% 50% at 90% 80%,rgb(45 106 79 / .25),transparent),var(--auth-bg);z-index:0}.auth-shell{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;width:100%;min-height:100vh}.auth-brand{display:flex;align-items:center;padding:3rem;color:#f8fafc}.auth-brand-inner{max-width:420px}.auth-logo,.auth-card-logo,.dashboard-logo{display:inline-flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;border-radius:12px;background:linear-gradient(135deg,#52b788,#1b4332);color:#fff;font-weight:700;font-size:.85rem;letter-spacing:.04em;text-decoration:none}.auth-brand h1{margin:1.5rem 0 .75rem;font-size:1.75rem;font-weight:600;line-height:1.25}.auth-brand p{margin:0;color:#94a3b8;line-height:1.6}.auth-features{margin:2rem 0 0;padding:0;list-style:none}.auth-features li{position:relative;padding-left:1.25rem;margin-bottom:.65rem;color:#cbd5e1;font-size:.95rem}.auth-features li:before{content:"";position:absolute;left:0;top:.55em;width:6px;height:6px;border-radius:50%;background:#52b788}.auth-panel{display:flex;align-items:center;justify-content:center;padding:2rem;background:#f8fafcf7}.auth-card{width:100%;max-width:420px;background:var(--auth-surface);border:1px solid var(--auth-border);border-radius:var(--auth-radius);box-shadow:var(--auth-shadow);padding:2rem 2rem 1.5rem}.auth-card-header h2{margin:1rem 0 .35rem;font-size:1.5rem;font-weight:600;color:var(--auth-text)}.auth-card-header p{margin:0;color:var(--auth-muted);font-size:.9rem;line-height:1.5}.auth-form{margin-top:1.5rem;display:flex;flex-direction:column;gap:1rem}.auth-field{display:flex;flex-direction:column;gap:.35rem}.auth-field span{font-size:.8rem;font-weight:600;color:var(--auth-text);letter-spacing:.02em;text-transform:uppercase}.auth-field input{height:2.75rem;padding:0 .85rem;border:1px solid var(--auth-border);border-radius:8px;font-size:.95rem;color:var(--auth-text);background:#fff;transition:border-color .15s,box-shadow .15s}.auth-field input:focus{outline:none;border-color:var(--auth-primary);box-shadow:0 0 0 3px #1b43321f}.auth-field input::placeholder{color:#94a3b8}.auth-hint{margin:0;font-size:.8rem;color:var(--auth-muted);line-height:1.45}.auth-alert{padding:.75rem .85rem;border-radius:8px;font-size:.875rem}.auth-alert-error{background:var(--auth-error-bg);color:var(--auth-error-text);border:1px solid #fecaca}.auth-btn{display:inline-flex;align-items:center;justify-content:center;height:2.75rem;padding:0 1.25rem;border-radius:999px;font-size:.95rem;font-weight:600;cursor:pointer;border:none;transition:background .15s,opacity .15s}.auth-btn:disabled{opacity:.65;cursor:not-allowed}.auth-btn-primary{width:100%;background:var(--auth-primary);color:#fff;margin-top:.25rem}.auth-btn-primary:hover:not(:disabled){background:var(--auth-primary-hover)}.auth-btn-ghost{background:transparent;color:var(--auth-text);border:1px solid var(--auth-border)}.auth-btn-ghost:hover{background:#f1f5f9}.auth-card-footer{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--auth-border);text-align:center;font-size:.9rem;color:var(--auth-muted)}.auth-card-footer a{color:var(--auth-primary);font-weight:600;text-decoration:none}.auth-card-footer a:hover{text-decoration:underline}.auth-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f8fafc}.auth-spinner{width:2rem;height:2rem;border:2px solid #e2e8f0;border-top-color:var(--auth-primary);border-radius:50%;animation:auth-spin .7s linear infinite}@keyframes auth-spin{to{transform:rotate(360deg)}}.dashboard{min-height:100vh;background:#f8fafc}.dashboard-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 2rem;background:#fff;border-bottom:1px solid var(--auth-border)}.dashboard-header h1{margin:.5rem 0 0;font-size:1.25rem;font-weight:600}.dashboard-main{max-width:720px;margin:0 auto;padding:2rem 1.5rem}.dashboard-card{background:#fff;border:1px solid var(--auth-border);border-radius:var(--auth-radius);padding:1.5rem 1.75rem;box-shadow:0 1px 3px #0f172a0f}.dashboard-card h2{margin:0 0 1rem;font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--auth-muted)}.dashboard-meta{margin:0;display:grid;gap:1rem}.dashboard-meta dt{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--auth-muted);margin-bottom:.2rem}.dashboard-meta dd{margin:0;font-size:1rem;color:var(--auth-text)}.dashboard-note{margin:1.25rem 0 0;padding-top:1rem;border-top:1px solid var(--auth-border);font-size:.875rem;color:var(--auth-muted)}.role-badge{display:inline-block;padding:.2rem .65rem;border-radius:999px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.role-badge-admin{background:#d8f3dc;color:#1b4332}.role-badge-user{background:#f1f5f9;color:#475569}@media(max-width:900px){.auth-shell{grid-template-columns:1fr}.auth-brand{display:none}.auth-panel{min-height:100vh}}:root{--dash-green-950: #0d2818;--dash-green-900: #1b4332;--dash-green-800: #2d6a4f;--dash-green-600: #40916c;--dash-green-500: #52b788;--dash-green-400: #74c69d;--dash-green-200: #b7e4c7;--dash-green-100: #d8f3dc;--dash-green-50: #f1f8f4}.dash-layout{--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--dash-bg: #f0f4f2;--dash-surface: #ffffff;--dash-surface-muted: #f8faf9;--dash-border: #e2ebe6;--dash-border-soft: #ecf2ee;--dash-text: #1a2420;--dash-text-muted: #6b7c75;--dash-accent: var(--dash-green-900);--dash-accent-soft: var(--dash-green-100);--dash-accent-hover: var(--dash-green-950);--dash-teal: var(--dash-green-600);--dash-teal-soft: var(--dash-green-50);--dash-success: var(--dash-green-800);--dash-success-soft: var(--dash-green-100);--dash-warn: #b8860b;--dash-warn-soft: #faf6e8;--dash-neutral-soft: #eef2f0;--dash-text-xs: .6875rem;--dash-text-sm: .8125rem;--dash-text-base: .875rem;--dash-text-md: .9375rem;--dash-text-lg: 1.0625rem;--dash-text-xl: 1.1875rem;--dash-text-2xl: 1.375rem;--dash-pad-x: clamp(1rem, 2.5vw, 2rem);--dash-max-width: 1280px;--dash-radius: 18px;--dash-shadow: 0 1px 2px rgb(27 67 50 / .05), 0 8px 24px rgb(27 67 50 / .06);--dash-shadow-section: 0 1px 3px rgb(27 67 50 / .06), 0 12px 32px rgb(27 67 50 / .05);min-height:100vh;width:100%;background:var(--dash-bg);font-family:var(--font-sans);font-size:var(--dash-text-base);color:var(--dash-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.dash-layout .auth-logo{background:linear-gradient(135deg,var(--dash-green-600),var(--dash-green-900));box-shadow:0 2px 10px #1b433247}.dash-container{width:100%;max-width:var(--dash-max-width);margin:0 auto;padding-inline:var(--dash-pad-x)}.dash-header{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1rem;background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--dash-border-soft);border-radius:var(--dash-radius);box-shadow:var(--dash-shadow)}.dash-header-left{display:flex;align-items:center;gap:.75rem}.dash-header-title{margin:0;font-size:var(--dash-text-lg);font-weight:600;color:var(--dash-text);letter-spacing:-.02em}.dash-header-sub{margin:.1rem 0 0;font-size:var(--dash-text-sm);color:var(--dash-text-muted)}.dash-header-right{display:flex;align-items:center;gap:.65rem}.dash-layout .role-badge-admin{background:var(--dash-accent-soft);color:var(--dash-accent-hover)}.dash-nav{position:sticky;top:4.75rem;z-index:30;display:flex;gap:.35rem;margin-top:.65rem;padding:.45rem .55rem;background:#ffffffe0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--dash-border-soft);border-radius:var(--dash-radius);box-shadow:var(--dash-shadow);overflow-x:auto}.dash-nav-link{flex-shrink:0;padding:.4rem .85rem;border-radius:999px;font-size:var(--dash-text-sm);font-weight:500;color:var(--dash-text-muted);text-decoration:none;transition:background .2s,color .2s}.dash-nav-link:hover,.dash-nav-link--active,.dash-nav-link[aria-current=true]{background:var(--dash-accent-soft);color:var(--dash-accent-hover)}.dash-content{width:100%;padding:1.35rem 0 2rem;display:flex;flex-direction:column;gap:1.25rem}.dash-section{scroll-margin-top:6.5rem;background:var(--dash-surface);border:1px solid var(--dash-border-soft);border-radius:var(--dash-radius);padding:1.25rem 1.35rem 1.35rem;box-shadow:var(--dash-shadow-section)}.dash-section-head{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.dash-section-head h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--dash-text);letter-spacing:-.02em}.dash-section-head p{margin:.3rem 0 0;font-size:var(--dash-text-sm);color:var(--dash-text-muted);line-height:1.45}.dash-section-meta{display:inline-flex;align-items:center;flex-wrap:wrap;gap:.35rem;margin-top:.45rem;padding:.25rem .65rem;border-radius:999px;font-size:var(--dash-text-xs);font-weight:500;color:var(--dash-text-muted);background:var(--dash-neutral-soft);line-height:1.4}.dash-section-meta:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--dash-teal);flex-shrink:0}.dash-section-count{font-size:var(--dash-text-xs);color:var(--dash-text-muted);font-weight:500}.dash-section-head-actions{display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}.dash-view-all{font-size:var(--dash-text-sm);font-weight:600;color:var(--dash-accent);text-decoration:none;white-space:nowrap}.dash-view-all:hover{color:var(--dash-accent-hover)}.dash-back-link{font-size:var(--dash-text-sm);font-weight:500;color:var(--dash-text-muted);text-decoration:none;white-space:nowrap}.dash-back-link:hover{color:var(--dash-accent)}.dash-content-list-page{padding-top:1rem}.dash-state{margin:0 0 1rem;font-size:var(--dash-text-sm);color:var(--dash-text-muted)}.dash-state-loading{margin-bottom:1.25rem}.dash-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.dash-skeleton{--skeleton-base: #e0e9e2;--skeleton-highlight: #e9f0ec;display:flex;flex-direction:column;gap:.8rem}.dash-skeleton-row,.dash-skeleton-card,.dash-skeleton-chart,.dash-skeleton-table-head,.dash-skeleton-table-row{background:linear-gradient(90deg,var(--skeleton-base) 25%,var(--skeleton-highlight) 37%,var(--skeleton-base) 63%);background-size:400% 100%;animation:dash-skeleton-shimmer 1.25s ease-in-out infinite;border-radius:10px}.dash-skeleton-row--title{width:min(380px,65%);height:1.3rem}.dash-skeleton-row--meta{width:min(260px,45%);height:.95rem}.dash-skeleton-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.8rem}.dash-skeleton-card{height:86px}.dash-skeleton-chart{height:220px}.dash-skeleton-table{border:1px solid var(--dash-border-soft);border-radius:10px;padding:.65rem;display:flex;flex-direction:column;gap:.55rem}.dash-skeleton-table-head{height:1.7rem}.dash-skeleton-table-row{height:1.45rem}@keyframes dash-skeleton-shimmer{0%{background-position:100% 50%}to{background-position:0 50%}}.dash-page-body{position:relative;display:flex;flex-direction:column;gap:var(--space-4)}.dash-page-body--dimmed{opacity:.55;pointer-events:none;transition:opacity .15s ease}.dash-fetch-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;display:flex;align-items:flex-start;justify-content:center;padding-top:3rem;pointer-events:none}.dash-fetch-overlay-pill{display:inline-flex;align-items:center;padding:.4rem .9rem;border-radius:999px;font-size:var(--type-caption, .75rem);font-weight:600;color:var(--dash-green-900, #1b4332);background:var(--dash-surface, #fff);border:1px solid var(--dash-border-soft, #ecf2ee);box-shadow:0 4px 16px #1b43321a}.dash-state-error{padding:.85rem 1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#b91c1c;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.dash-state-error p,.dash-table-section-full{margin:0}.dash-pagination-controls{display:flex;align-items:center;gap:.65rem;margin-left:auto}.dash-page-range{font-size:var(--dash-text-sm);color:var(--dash-text-muted);font-weight:500}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.85rem}.stat-grid-wide{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-grid-2{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.stat-card{padding:1rem 1.1rem 1rem 1rem;background:linear-gradient(145deg,var(--dash-surface-muted) 0%,var(--dash-surface) 100%);border:1px solid var(--dash-border-soft);border-left:3px solid var(--dash-accent);border-radius:12px;transition:border-color .2s,box-shadow .2s}.stat-grid .stat-card:nth-child(3n+2){border-left-color:var(--dash-teal)}.stat-grid .stat-card:nth-child(3n),.stat-grid-2 .stat-card:nth-child(2n){border-left-color:var(--dash-success)}.stat-grid-2 .stat-card:nth-child(1){border-left-color:var(--dash-accent)}.stat-card:hover{border-color:var(--dash-border);box-shadow:0 4px 12px #2c28250d}.stat-card-label{margin:0;font-size:var(--dash-text-xs);font-weight:600;text-transform:none;letter-spacing:.02em;color:var(--dash-text-muted)}.stat-card-value{margin:.35rem 0 0;font-size:1.5rem;font-weight:700;color:var(--dash-text);line-height:1.2;letter-spacing:-.03em}.stat-card-trend{margin:.3rem 0 0;font-size:var(--dash-text-xs);font-weight:500}.stat-card-trend-up{color:var(--dash-success)}.stat-card-trend-down{color:#c45c5c}.dash-chart-card{margin-top:1rem;padding:1rem 1.1rem;border:1px solid var(--dash-border-soft);border-radius:12px;background-color:var(--dash-surface-muted);background-image:repeating-linear-gradient(to top,transparent,transparent 27px,rgb(232 228 223 / .45) 27px,rgb(232 228 223 / .45) 28px);background-size:100% 28px;background-position:0 2.5rem}.dash-overview-analytics .dash-section-head{margin:-.15rem -.15rem 1.15rem;padding:1.1rem 1.2rem;background:linear-gradient(135deg,var(--dash-green-50) 0%,var(--dash-green-100) 55%,var(--dash-surface-muted) 100%);border:1px solid var(--dash-border-soft);border-radius:calc(var(--dash-radius) - 2px)}.dash-overview-analytics .dash-section-head h2{font-size:1.3125rem}.dash-overview-analytics .dash-section-meta{background:#ffffffb8}.dash-overview-analytics .stat-grid{row-gap:1.15rem;column-gap:.85rem}.dash-overview-analytics .stat-grid+.stat-grid{margin-top:1.25rem}.dash-overview-analytics .dash-chart-card{margin-top:1.35rem}.dash-overview-analytics .dash-subsection{scroll-margin-top:7rem}.dash-overview-analytics .dash-subsection+.dash-subsection{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--dash-border-soft)}.dash-subsection-title{margin:0 0 .85rem;font-size:var(--dash-text-md);font-weight:600;color:var(--dash-text);letter-spacing:-.01em}.dash-chart-card h3,.dash-chart-title{margin:0 0 .85rem;font-size:var(--dash-text-sm);font-weight:600;text-transform:none;letter-spacing:0;color:var(--dash-text-muted)}.dash-bar-chart{display:flex;align-items:flex-end;gap:.65rem;height:168px;max-height:200px;padding-top:.35rem}.dash-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;min-width:0}.dash-bar{width:100%;max-width:44px;min-height:4px;background:linear-gradient(180deg,var(--dash-green-500) 0%,var(--dash-green-900) 100%);border-radius:12px 12px 4px 4px;margin-top:auto;transition:height .2s,opacity .2s}.dash-bar-col:hover .dash-bar{opacity:.88}.dash-bar-label{margin-top:.45rem;font-size:var(--dash-text-xs);font-weight:600;color:var(--dash-text-muted)}.dash-bar-value{font-size:var(--dash-text-xs);color:#a39e97}.dash-table-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem 1rem;margin-bottom:.85rem}.dash-search{width:100%;max-width:420px;height:2.375rem;padding:0 .85rem;border:1px solid var(--dash-border);border-radius:10px;font-size:var(--dash-text-sm);color:var(--dash-text);background:var(--dash-surface-muted);transition:border-color .2s,box-shadow .2s,background .2s}.dash-search::placeholder{color:#a39e97}.dash-search:focus{outline:none;border-color:var(--dash-accent);background:var(--dash-surface);box-shadow:0 0 0 3px #1b43321f}.dash-table-wrap{overflow-x:auto;border:1px solid var(--dash-border-soft);border-radius:10px;background:var(--dash-surface)}.dash-table{width:100%;border-collapse:collapse;font-size:var(--dash-text-sm)}.dash-table th{text-align:left;padding:.65rem 1rem;background:var(--dash-surface-muted);font-size:var(--dash-text-xs);font-weight:600;text-transform:none;letter-spacing:.02em;color:var(--dash-text-muted);border-bottom:1px solid var(--dash-border-soft);white-space:nowrap}.dash-table td{padding:.7rem 1rem;border-bottom:1px solid var(--dash-border-soft);color:var(--dash-text)}.dash-table tbody tr:last-child td{border-bottom:none}.dash-table tbody tr.dash-snapshot-group-end td{border-bottom:5px solid whitesmoke}.dash-table tbody tr:hover td{background:var(--dash-green-50)}.dash-table-empty{text-align:center;color:var(--dash-text-muted);padding:2.25rem 1rem!important;font-size:var(--dash-text-sm)}.dash-table-row-clickable{cursor:pointer}.dash-row-link{color:var(--dash-accent, #b45309);font-weight:600;text-decoration:none}.dash-row-link:hover{text-decoration:underline}.dash-variant-subrow-cell{display:inline-flex;align-items:center;padding-left:1.1rem;font-size:.9em;color:var(--dash-text-muted)}.dash-breadcrumb{margin:0 0 1.25rem;font-size:.9rem;color:var(--dash-text-muted)}.dash-breadcrumb a{color:var(--dash-accent, #b45309);text-decoration:none}.dash-breadcrumb a:hover{text-decoration:underline}.dash-store-meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem 1.5rem;margin-bottom:1.75rem;padding:1rem 1.25rem;background:var(--dash-surface, #fff);border:1px solid var(--dash-border-soft);border-radius:8px}.dash-store-meta-row{display:flex;flex-direction:column;gap:.2rem}.dash-store-meta-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--dash-text-muted)}.dash-store-url{color:var(--dash-accent, #b45309);word-break:break-all}.dash-subsection-title{margin:0 0 1rem;font-size:1.1rem;font-weight:600}.dash-pagination{display:flex;align-items:center;flex-wrap:wrap;justify-content:space-between;gap:.65rem;margin-top:.85rem;padding-top:.85rem;border-top:1px solid var(--dash-border-soft)}.dash-page-btn{height:2.125rem;padding:0 .85rem;border:1px solid var(--dash-border);border-radius:8px;background:var(--dash-surface);font-size:var(--dash-text-sm);font-weight:500;color:var(--dash-text);cursor:pointer;transition:background .15s,border-color .15s}.dash-page-btn:hover:not(:disabled){background:var(--dash-accent-soft);border-color:var(--dash-green-200);color:var(--dash-accent-hover)}.dash-page-btn:disabled{opacity:.4;cursor:not-allowed}.dash-page-info{font-size:var(--dash-text-xs);color:var(--dash-text-muted)}.status-chip{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-size:var(--dash-text-xs);font-weight:600;text-transform:capitalize}.status-chip-active,.status-chip-completed{background:var(--dash-success-soft);color:var(--dash-success)}.status-chip-inactive,.status-chip-cancelled{background:var(--dash-neutral-soft);color:var(--dash-text-muted)}.status-chip-pending{background:var(--dash-warn-soft);color:var(--dash-warn)}.dash-layout .auth-btn-ghost{border-color:var(--dash-border);color:var(--dash-text-muted);font-size:var(--dash-text-sm)}.dash-layout .auth-btn-ghost:hover{background:var(--dash-surface-muted);border-color:var(--dash-border);color:var(--dash-text)}.dash-list-actions{display:flex;justify-content:flex-end;margin-bottom:1rem}.dash-btn-sm{width:auto;min-height:2.25rem;padding:0 1rem;font-size:var(--dash-text-sm)}.dash-form-section .dash-section-head{align-items:flex-start}.dash-form{display:flex;flex-direction:column;gap:1.1rem;max-width:520px}.dash-field{display:flex;flex-direction:column;gap:.35rem}.dash-field>span:first-child{font-size:var(--dash-text-sm);font-weight:600;color:var(--dash-text)}.dash-field input[type=text],.dash-field input[type=url]{height:2.5rem;padding:0 .85rem;border:1px solid var(--dash-border);border-radius:10px;font-size:var(--dash-text-sm);color:var(--dash-text);background:var(--dash-surface-muted);transition:border-color .2s,box-shadow .2s,background .2s}.dash-field input:focus{outline:none;border-color:var(--dash-accent);background:var(--dash-surface);box-shadow:0 0 0 3px #1b43321f}.dash-field-hint{font-size:var(--dash-text-xs);color:var(--dash-text-muted);line-height:1.4}.dash-field-checkbox{flex-direction:row;align-items:center;gap:.55rem}.dash-field-checkbox input{width:1rem;height:1rem;accent-color:var(--dash-accent)}.dash-field-checkbox span{font-size:var(--dash-text-sm);font-weight:500;color:var(--dash-text)}.dash-form-actions{display:flex;align-items:center;flex-wrap:wrap;gap:.85rem 1.25rem;margin-top:.35rem}.dash-form-actions .auth-btn-primary{width:auto;min-width:8.5rem}.dash-alert{margin-bottom:1rem;padding:.75rem 1rem;border-radius:10px;font-size:var(--dash-text-sm);font-weight:500}.dash-alert-success{background:var(--dash-success-soft);border:1px solid rgb(61 154 110 / .25);color:var(--dash-success)}.admin-denied{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--dash-bg);padding:1.5rem}.admin-denied-card{text-align:center;max-width:380px;padding:2rem 1.75rem;background:var(--dash-surface);border:1px solid var(--dash-border-soft);border-radius:var(--dash-radius);box-shadow:var(--dash-shadow)}.admin-denied-card h1{margin:1rem 0 .45rem;font-size:var(--dash-text-xl);font-weight:600;color:var(--dash-text)}.admin-denied-card p{margin:0 0 1.25rem;color:var(--dash-text-muted);font-size:var(--dash-text-sm);line-height:1.5}.admin-denied-card .auth-btn{width:100%}@media(max-width:1024px){.stat-grid-2{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media(max-width:640px){.dash-container{padding-inline:1rem}.dash-content{padding:1rem 0 1.75rem}.stat-grid,.stat-grid-wide,.stat-grid-2{grid-template-columns:1fr}.dash-header{padding:.7rem .85rem}.dash-nav{padding:.4rem .45rem;margin-top:.5rem;top:4rem}.dash-overview-analytics .dash-section-head{margin:0 0 1rem;padding:.95rem 1rem}}.dash-app{--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--dash-bg: #f0f4f2;--dash-surface: #ffffff;--dash-surface-muted: #f8faf9;--dash-border: #e2ebe6;--dash-border-soft: #ecf2ee;--dash-text: #1a2420;--dash-text-muted: #6b7c75;--dash-accent: var(--dash-green-900);--dash-accent-soft: var(--dash-green-100);--dash-accent-hover: var(--dash-green-950);--dash-teal: var(--dash-green-600);--dash-teal-soft: var(--dash-green-50);--dash-success: var(--dash-green-800);--dash-success-soft: var(--dash-green-100);--dash-warn: #b8860b;--dash-warn-soft: #faf6e8;--dash-neutral-soft: #eef2f0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.75rem;--type-page-title: 1.625rem;--type-section: 1.125rem;--type-body: .875rem;--type-caption: .75rem;--type-metric: 2rem;--dash-pad-x: clamp(1rem, 2.5vw, 1.5rem);--dash-max-width: 1200px;--dash-radius: 20px;--dash-shadow: 0 1px 2px rgb(27 67 50 / .05), 0 6px 20px rgb(27 67 50 / .06);display:flex;min-height:100vh;font-family:var(--font-sans);font-size:var(--type-body);color:var(--dash-text);background:var(--dash-bg);-webkit-font-smoothing:antialiased}.dash-sidebar{width:260px;flex-shrink:0;display:flex;flex-direction:column;padding:var(--space-5) var(--space-4);background:var(--dash-surface);border-right:1px solid var(--dash-border-soft)}.dash-brand-logo{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:12px;background:linear-gradient(145deg,var(--dash-green-600),var(--dash-green-900));color:#fff;font-weight:700;font-size:.8rem;letter-spacing:.04em;box-shadow:0 4px 12px #1b433238}.dash-sidebar-section{margin:0 0 var(--space-2);padding:0 .75rem;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--dash-text-muted)}.dash-sidebar-footer{margin-top:auto;padding-top:var(--space-5)}.dash-sidebar-promo{padding:var(--space-4);border-radius:var(--dash-radius);background:linear-gradient(145deg,var(--dash-green-900) 0%,var(--dash-green-800) 100%);color:#fff;box-shadow:0 8px 24px #1b433233}.dash-sidebar-promo-title{margin:0;font-size:var(--type-body);font-weight:600;letter-spacing:-.02em}.dash-sidebar-promo-text{margin:var(--space-2) 0 0;font-size:var(--type-caption);line-height:1.45;color:#ffffffc7}.dash-sidebar-brand{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-6)}.dash-sidebar-title{margin:0;font-size:var(--type-section);font-weight:600;letter-spacing:-.02em}.dash-sidebar-sub{margin:.1rem 0 0;font-size:var(--type-caption);color:var(--dash-text-muted)}.dash-sidebar-nav{display:flex;flex-direction:column;gap:var(--space-1)}.dash-sidebar-link{padding:.6rem .85rem;border-radius:12px;font-size:var(--type-body);font-weight:500;color:var(--dash-text-muted);text-decoration:none;transition:background .15s,color .15s}.dash-sidebar-link:hover{background:var(--dash-green-50);color:var(--dash-text)}.dash-sidebar-link--active{background:var(--dash-green-100);color:var(--dash-green-900);font-weight:600;box-shadow:inset 0 0 0 1px #1b433214}.dash-main{flex:1;min-width:0;display:flex;flex-direction:column}.dash-topbar{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--dash-surface);border-bottom:1px solid var(--dash-border-soft);box-shadow:0 1px 2px #1b43320a}.dash-topbar-user{display:flex;align-items:center;gap:var(--space-2)}.dash-topbar-name{font-size:var(--type-body);font-weight:500;color:var(--dash-text-muted)}.dash-main-inner{flex:1;padding:var(--space-5);overflow-x:auto}.dash-page{max-width:var(--dash-max-width);margin:0 auto;display:flex;flex-direction:column;gap:var(--space-5)}.dash-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.dash-page-title{margin:0;font-size:var(--type-page-title);font-weight:600;letter-spacing:-.03em;line-height:1.2}.dash-page-desc{margin:var(--space-2) 0 0;font-size:var(--type-body);color:var(--dash-text-muted);line-height:1.5}.dash-page-header-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.dash-pill{display:inline-flex;align-items:center;margin-top:var(--space-2);padding:.2rem .65rem;border-radius:999px;font-size:var(--type-caption);font-weight:500;color:var(--dash-green-800);background:var(--dash-green-100)}.dash-pill-warn{background:var(--dash-warn-soft);color:var(--dash-warn)}.dash-panel{background:var(--dash-surface);border:1px solid var(--dash-border-soft);border-radius:var(--dash-radius);padding:var(--space-5);box-shadow:var(--dash-shadow)}.dash-panel-title{margin:0 0 var(--space-4);font-size:var(--type-section);font-weight:600;letter-spacing:-.02em}.dash-empty-panel{text-align:center;padding:var(--space-6)}.dash-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.dash-kpi-grid--2{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.kpi-card{padding:var(--space-5);background:var(--dash-surface);border:1px solid var(--dash-border-soft);border-radius:var(--dash-radius);box-shadow:var(--dash-shadow);transition:box-shadow .2s,transform .2s}.kpi-card:hover{box-shadow:0 4px 20px #1b433214}.kpi-card--featured{background:linear-gradient(145deg,var(--dash-green-900) 0%,var(--dash-green-800) 100%);border:none;color:#fff;box-shadow:0 10px 28px #1b433238}.kpi-card--featured:hover{box-shadow:0 12px 32px #1b433247}.kpi-card--teal .kpi-card-label,.kpi-card--success .kpi-card-label,.kpi-card--accent .kpi-card-label{color:var(--dash-text-muted)}.kpi-card-label{margin:0;font-size:var(--type-caption);font-weight:600;color:var(--dash-text-muted);letter-spacing:.01em}.kpi-card--featured .kpi-card-label{color:#ffffffbf}.kpi-card-value{margin:var(--space-2) 0 0;font-size:var(--type-metric);font-weight:700;letter-spacing:-.03em;font-feature-settings:"tnum";line-height:1.15;color:var(--dash-text)}.kpi-card--featured .kpi-card-value{color:#fff}.kpi-card-hint{margin:var(--space-2) 0 0;font-size:var(--type-caption);color:var(--dash-text-muted)}.kpi-card--featured .kpi-card-hint{color:#ffffffb8}.kpi-card-trend{margin:var(--space-3) 0 0;padding-top:var(--space-2);border-top:1px solid var(--dash-border-soft);font-size:var(--type-caption);font-weight:500}.kpi-card--featured .kpi-card-trend{border-top-color:#ffffff26;color:#ffffffd9}.kpi-card-trend--up{color:var(--dash-success)}.kpi-card--featured .kpi-card-trend--up,.kpi-card--featured .kpi-card-trend--down{color:#ffffffe6}.kpi-card-trend--down{color:#c45c5c}.dash-chart-block-title{margin:0 0 var(--space-4);font-size:var(--type-body);font-weight:600;color:var(--dash-text-muted)}.dash-trend-chart{display:flex;align-items:flex-end;gap:4px;height:200px;padding-top:var(--space-2);overflow-x:auto}.dash-trend-col{flex:1;min-width:28px;max-width:48px;display:flex;flex-direction:column;align-items:center;height:100%}.dash-trend-value{font-size:.625rem;font-weight:600;color:var(--dash-text-muted);font-feature-settings:"tnum";margin-bottom:2px}.dash-trend-bar{width:100%;max-width:36px;min-height:4px;margin-top:auto;border-radius:14px 14px 4px 4px;transition:height .2s}.dash-trend-col:nth-child(3n+1) .dash-trend-bar{background:linear-gradient(180deg,var(--dash-green-500) 0%,var(--dash-green-900) 100%)}.dash-trend-col:nth-child(3n+2) .dash-trend-bar{background:linear-gradient(180deg,var(--dash-green-400) 0%,var(--dash-green-600) 100%)}.dash-trend-col:nth-child(3n) .dash-trend-bar{background:repeating-linear-gradient(-45deg,var(--dash-green-600),var(--dash-green-600) 3px,var(--dash-green-400) 3px,var(--dash-green-400) 6px)}.dash-trend-label{margin-top:var(--space-2);font-size:.625rem;font-weight:500;color:var(--dash-text-muted);text-align:center;white-space:nowrap}.dash-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-3) var(--space-4)}.dash-search-wide{max-width:360px;flex:1;min-width:200px}.dash-toolbar-count{font-size:var(--type-caption);font-weight:500;color:var(--dash-text-muted)}.store-list{background:var(--dash-surface);border:1px solid var(--dash-border-soft);border-radius:var(--dash-radius);box-shadow:var(--dash-shadow);overflow:hidden}.store-list-header,.store-row{display:grid;grid-template-columns:minmax(140px,1.4fr) minmax(160px,2fr) 88px 100px 120px 28px;align-items:center;gap:var(--space-3) var(--space-4);padding:.75rem var(--space-5)}.store-list-header{background:var(--dash-surface-muted);border-bottom:1px solid var(--dash-border-soft);font-size:var(--type-caption);font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--dash-text-muted)}.store-list-body{display:flex;flex-direction:column}.store-row{text-decoration:none;color:inherit;border-bottom:1px solid var(--dash-border-soft);transition:background .15s}.store-row:last-child{border-bottom:none}.store-row:hover{background:var(--dash-green-50)}.store-row-cell{min-width:0}.store-row-cell--name{display:flex;flex-direction:column;gap:.15rem}.store-row-title{font-size:var(--type-body);font-weight:600;letter-spacing:-.02em;color:var(--dash-text)}.store-row-key{font-size:var(--type-caption);color:var(--dash-text-muted)}.store-row-url{display:block;font-size:var(--type-caption);color:var(--dash-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.store-row-cell--metric{display:flex;flex-direction:column;gap:.1rem;text-align:right}.store-row-metric-label{font-size:.625rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em;color:var(--dash-text-muted)}.store-row-metric-value{font-size:var(--type-body);font-weight:700;font-feature-settings:"tnum";color:var(--dash-text)}.store-row-arrow{font-size:var(--type-body);font-weight:600;color:var(--dash-green-800);text-align:center}.dash-detail-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);margin-top:var(--space-2)}.dash-detail-toolbar{display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--space-4)}.dash-date-picker,.dash-date-range{display:flex;flex-direction:row;gap:var(--space-4)}.dash-variant-filter{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:var(--space-4);min-width:220px}.dash-date-range-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-2)}.dash-date-range-presets{display:flex;gap:.35rem}.dash-date-range-preset{padding:.25rem .55rem;border:1px solid var(--dash-border-soft);border-radius:999px;background:var(--dash-surface);font-size:.75rem;font-weight:600;color:var(--dash-text-muted);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.dash-date-range-preset:hover{background:var(--dash-green-50, #f1f8f4);border-color:var(--dash-green-200, #b7e4c7);color:var(--dash-green-900, #1b4332)}.dash-drp-anchor{position:relative;width:fit-content;max-width:100%;overflow:visible;min-width:200px}.dash-drp-trigger{display:inline-flex;min-width:200px;align-items:center;gap:.55rem;min-height:2.5rem;padding:0 .9rem;border:1px solid var(--dash-border-soft, #dce5e0);border-radius:12px;background:var(--dash-surface, #fff);font-size:.875rem;font-weight:500;color:var(--dash-text, #1a2420);cursor:pointer;transition:border-color .15s,box-shadow .15s}.dash-drp-trigger:hover,.dash-drp-trigger[aria-expanded=true]{border-color:var(--dash-accent, #1b4332);box-shadow:0 0 0 3px #1b43321a}.dash-drp-trigger--static{cursor:default;pointer-events:none}.dash-drp-trigger-icon{display:flex;color:var(--dash-accent, #1b4332);flex-shrink:0}.dash-drp-trigger-label{white-space:nowrap}.dash-drp-popover{position:absolute;top:calc(100% + .45rem);left:0;z-index:50;width:max-content;max-width:min(96vw,620px);min-width:580px;padding:.85rem;border:1px solid var(--dash-border-soft, #dce5e0);border-radius:14px;background:var(--dash-surface, #fff);box-shadow:0 12px 40px #0d28181f,0 2px 8px #0d28180f}@media(max-width:640px){.dash-drp-popover{min-width:0;width:min(96vw,320px)}}.dash-drp-popover-presets{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--dash-border-soft, #ecf2ee)}.dash-drp-popover-footer{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--dash-border-soft, #ecf2ee)}.dash-drp-popover-status{margin:0 0 .65rem;font-size:.75rem;color:var(--dash-text-muted, #6b7c75);line-height:1.4}.dash-drp-popover-actions{display:flex;justify-content:flex-end;gap:.5rem}.dash-drp-btn{padding:.4rem .85rem;border-radius:8px;font-size:.8125rem;font-weight:600;cursor:pointer;border:1px solid transparent;transition:background .15s,border-color .15s}.dash-drp-btn--ghost{background:transparent;border-color:var(--dash-border-soft, #dce5e0);color:var(--dash-text-muted, #6b7c75)}.dash-drp-btn--ghost:hover{background:var(--dash-green-50, #f1f8f4)}.dash-drp-btn--primary{background:var(--dash-accent, #1b4332);color:#fff}.dash-drp-btn--primary:hover:not(:disabled){background:var(--dash-green-800, #2d6a4f)}.dash-drp-btn--primary:disabled{opacity:.45;cursor:not-allowed}.dash-date-picker-label{font-size:16px;font-weight:600;color:var(--dash-text)}.dash-date-picker-input{height:2.5rem;min-width:200px;padding:0 var(--space-3);border:1px solid var(--dash-border);border-radius:8px;font-size:var(--type-body);font-family:inherit;color:var(--dash-text);background:var(--dash-surface)}.dash-date-picker-input:focus{outline:none;border-color:var(--dash-accent);box-shadow:0 0 0 3px #1b43321f}.dash-date-picker-hint{font-size:var(--type-caption);color:var(--dash-text-muted);max-width:320px;line-height:1.4}.dash-app .role-badge-admin{background:var(--dash-green-100);color:var(--dash-green-900)}.dash-app .auth-btn-primary{background:var(--dash-green-900);border-radius:999px;color:#fff}.dash-app .auth-btn-primary:hover:not(:disabled){background:var(--dash-green-950)}.dash-app .auth-btn-ghost{border-radius:999px;border-color:var(--dash-border);color:var(--dash-text-muted)}.dash-app .auth-btn-ghost:hover{background:var(--dash-green-50);border-color:var(--dash-green-200);color:var(--dash-green-900)}.dash-app .dash-row-link,.dash-app .dash-view-all,.dash-app .dash-breadcrumb a{color:var(--dash-green-800)}.dash-app .dash-search{border-radius:999px;background:var(--dash-surface)}.dash-app .dash-search:focus{border-color:var(--dash-green-600);box-shadow:0 0 0 3px #40916c26}.dash-app .dash-date-picker-input{border-radius:12px}.dash-app .dash-date-picker-input:focus{border-color:var(--dash-green-600);box-shadow:0 0 0 3px #40916c1f}@media(max-width:900px){.dash-app{flex-direction:column}.dash-sidebar{width:100%;flex-direction:row;flex-wrap:wrap;align-items:center;padding:var(--space-3) var(--space-4);border-right:none;border-bottom:1px solid var(--dash-border-soft)}.dash-sidebar-brand{margin-bottom:0;margin-right:auto}.dash-sidebar-nav{flex-direction:row;flex-wrap:wrap;width:100%;margin-top:var(--space-3)}.dash-sidebar-footer{display:none}.dash-main-inner{padding:var(--space-4)}.dash-kpi-grid{grid-template-columns:1fr 1fr}}.product-detail-head{margin-top:var(--space-2)}.product-detail-thumb{width:48px;height:48px;border-radius:12px;object-fit:cover;border:1px solid var(--dash-border-soft)}.product-detail-chart-note{margin:var(--space-3) 0 0;font-size:var(--type-caption);color:var(--dash-text-muted);line-height:1.45}.dash-table-compact th,.dash-table-compact td{padding:.5rem .75rem;font-size:var(--type-caption)}@media(max-width:640px){.dash-kpi-grid,.dash-kpi-grid--2{grid-template-columns:1fr}.store-list-header{display:none}.store-row{grid-template-columns:1fr auto;grid-template-areas:"name arrow" "url url" "stats stats";padding:var(--space-4);gap:var(--space-2)}.store-row-cell--name{grid-area:name}.store-row-cell--url{grid-area:url}.store-row-cell--status{display:none}.store-row-cell--metric{grid-area:stats;flex-direction:row;justify-content:space-between;text-align:left}.store-row-cell--metric:last-of-type{margin-left:var(--space-4)}.store-row-arrow{grid-area:arrow}.dash-page-header{flex-direction:column}}
