@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap";@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}:root{--bg-color: #0d1117;--panel-bg: rgba(22, 27, 34, .6);--panel-border: rgba(255, 255, 255, .08);--text-primary: #f0f6fc;--text-secondary: #8b949e;--accent-color: #58a6ff;--accent-glow: rgba(88, 166, 255, .2);--success: #2ea043;--warning: #d29922;--danger: #f85149;--sidebar-width: 260px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Plus Jakarta Sans,sans-serif;background-color:var(--bg-color);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;position:relative;overflow-x:hidden}body:before{content:"";position:fixed;top:-20%;left:-10%;width:50vw;height:50vw;border-radius:50%;background:radial-gradient(circle,#58a6ff0d,#0d111700 70%);z-index:-1;pointer-events:none}body:after{content:"";position:fixed;bottom:-20%;right:-10%;width:60vw;height:60vw;border-radius:50%;background:radial-gradient(circle,#a371f70d,#0d111700 70%);z-index:-1;pointer-events:none}.app-container{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);padding:2rem;padding-top:calc(2rem + 56px);max-width:calc(100vw - var(--sidebar-width))}.topbar{position:fixed;top:0;right:0;left:var(--sidebar-width);height:56px;display:flex;align-items:center;justify-content:flex-end;padding:0 2rem;background:#0d1117b3;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--panel-border);z-index:90}.topbar-user{position:relative}.topbar-user-btn{display:flex;align-items:center;gap:.65rem;padding:.4rem .75rem;border-radius:10px;border:1px solid transparent;background:transparent;cursor:pointer;font-family:inherit;transition:all .2s ease}.topbar-user-btn:hover{background:#ffffff0d;border-color:var(--panel-border)}.topbar-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}.topbar-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:var(--accent-glow);color:var(--accent-color);font-weight:700;font-size:.85rem}.topbar-user-info{display:flex;flex-direction:column;align-items:flex-start}.topbar-user-name{font-size:.85rem;font-weight:600;color:var(--text-primary);line-height:1.2;white-space:nowrap}.topbar-user-email{font-size:.7rem;color:var(--text-secondary);white-space:nowrap}.topbar-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:220px;background:#161b22fa;border:1px solid var(--panel-border);border-radius:12px;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:0 8px 32px #0006;overflow:hidden;animation:topbarDropdownIn .15s ease}@keyframes topbarDropdownIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.topbar-dropdown-info{padding:.9rem 1rem}.topbar-dropdown-name{font-size:.88rem;font-weight:600;color:var(--text-primary);margin-bottom:.15rem}.topbar-dropdown-email{font-size:.75rem;color:var(--text-secondary)}.topbar-dropdown-divider{height:1px;background:var(--panel-border)}.topbar-logout-btn{display:flex;align-items:center;gap:.6rem;width:100%;padding:.75rem 1rem;border:none;background:transparent;color:var(--danger);font-family:inherit;font-size:.88rem;font-weight:500;cursor:pointer;transition:background .15s;text-align:left}.topbar-logout-btn:hover{background:#f851491a}.sidebar{width:var(--sidebar-width);background:#0d1117cc;border-right:1px solid var(--panel-border);position:fixed;height:100vh;padding:1.5rem 1rem;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:100;display:flex;flex-direction:column}.brand{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:1.75rem;padding:0 1rem;display:flex;align-items:center;gap:.75rem}.brand-icon{background:linear-gradient(135deg,var(--accent-color),#a371f7);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.nav-group{margin-bottom:.5rem}.nav-group-label{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#8b949e80;padding:.6rem 1rem .3rem}.nav-menu{list-style:none;display:flex;flex-direction:column;gap:.25rem}.nav-item{display:flex;align-items:center;gap:.7rem;padding:.7rem 1rem;color:var(--text-secondary);text-decoration:none;border-radius:8px;font-weight:500;font-size:.88rem;transition:all .2s ease;position:relative}.nav-item:hover{background:#ffffff0d;color:var(--text-primary)}.nav-item.active{background:var(--accent-glow);color:var(--accent-color);border-left:3px solid var(--accent-color)}.nav-item-coming-soon{opacity:.5;pointer-events:none}.nav-badge-soon{margin-left:auto;font-size:.6rem;font-weight:700;letter-spacing:.04em;padding:.15rem .45rem;border-radius:4px;background:#d2992226;color:#d29922;border:1px solid rgba(210,153,34,.3)}.sidebar-footer{display:flex;align-items:center;gap:.4rem;padding:.75rem 1rem;border-top:1px solid var(--panel-border);margin-top:auto;font-size:.7rem;color:#8b949e8c;font-variant-numeric:tabular-nums}.page-title{font-size:1.75rem;font-weight:700;margin-bottom:.5rem;color:var(--text-primary)}.page-subtitle{color:var(--text-secondary);margin-bottom:2rem;font-size:.95rem}.dashboard-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.5rem}.glass-panel{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:16px;padding:1.5rem;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 8px 32px #0000001a;transition:transform .2s ease,box-shadow .2s ease}.glass-panel:hover{transform:translateY(-2px);box-shadow:0 12px 40px #0003}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.panel-title{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.stat-value{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.stat-diff{font-size:.875rem;font-weight:600;display:flex;align-items:center;gap:4px}.stat-diff.positive{color:var(--success)}.stat-diff.negative{color:var(--danger)}.col-span-12{grid-column:span 12}.col-span-8{grid-column:span 8}.col-span-4{grid-column:span 4}.col-span-6{grid-column:span 6}.col-span-3{grid-column:span 3}@media(max-width:1024px){.col-span-8,.col-span-4,.col-span-3{grid-column:span 6}}@media(max-width:768px){.app-container{flex-direction:column}.sidebar{width:100%;height:auto;position:relative;border-right:none;border-bottom:1px solid var(--panel-border)}.main-content{margin-left:0;max-width:100vw}.col-span-8,.col-span-4,.col-span-6,.col-span-3{grid-column:span 12}}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;margin-top:2rem}.section-header:first-child{margin-top:0}.section-title{font-size:1.1rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.section-link{color:var(--accent-color);text-decoration:none;font-size:.85rem;font-weight:500;display:flex;align-items:center;gap:4px;transition:opacity .2s}.section-link:hover{opacity:.8}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.summary-card{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:14px;padding:1.25rem;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);cursor:pointer;transition:all .25s ease;position:relative;overflow:hidden}.summary-card:hover{border-color:#ffffff26;transform:translateY(-3px);box-shadow:0 12px 40px #0000004d}.summary-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:14px 14px 0 0}.summary-card[data-accent=blue]:before{background:linear-gradient(90deg,#58a6ff,#79c0ff)}.summary-card[data-accent=purple]:before{background:linear-gradient(90deg,#a371f7,#d2a8ff)}.summary-card[data-accent=green]:before{background:linear-gradient(90deg,#2ea043,#7ee787)}.summary-card[data-accent=orange]:before{background:linear-gradient(90deg,#d29922,#ffa657)}.summary-card[data-accent=pink]:before{background:linear-gradient(90deg,#f778ba,#ff9ec7)}.summary-card .card-label{font-size:.8rem;color:var(--text-secondary);font-weight:500;margin-bottom:.5rem}.summary-card .card-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.summary-card .card-sub{font-size:.8rem;font-weight:500;display:flex;align-items:center;gap:4px}.summary-card .card-sub.up{color:var(--success)}.summary-card .card-sub.down{color:var(--danger)}.summary-card .card-sub.neutral{color:var(--text-secondary)}.sparkline-area{height:50px;margin-top:.75rem}.period-filter{display:flex;gap:.5rem;background:#ffffff08;border-radius:10px;padding:4px}.period-btn{padding:.4rem 1rem;border-radius:8px;border:none;background:transparent;color:var(--text-secondary);font-family:inherit;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.period-btn:hover{color:var(--text-primary)}.period-btn.active{background:var(--accent-glow);color:var(--accent-color);font-weight:600}.tab-bar{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--panel-border);padding-bottom:.5rem;overflow-x:auto}.tab-btn{padding:.5rem 1.25rem;border-radius:8px 8px 0 0;border:none;background:transparent;color:var(--text-secondary);font-family:inherit;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;border-bottom:2px solid transparent}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--accent-color);font-weight:600;border-bottom-color:var(--accent-color)}.product-table{width:100%;border-collapse:separate;border-spacing:0}.product-table th{text-align:left;color:var(--text-secondary);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.75rem 1rem;border-bottom:1px solid var(--panel-border)}.product-table th:last-child{text-align:right}.product-table td{padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.03);font-size:.9rem}.product-table td:last-child{text-align:right;font-weight:600;color:var(--accent-color)}.product-table tr:hover td{background:#ffffff05}.product-table .rank{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;font-size:.75rem;font-weight:700}.product-table .rank.top{background:var(--accent-glow);color:var(--accent-color)}.product-table .rank.normal{background:#ffffff0d;color:var(--text-secondary)}.coming-soon{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:180px;color:var(--text-secondary);gap:.75rem}.coming-soon-icon{width:48px;height:48px;border-radius:12px;background:#ffffff0d;display:flex;align-items:center;justify-content:center}.coming-soon-text{font-size:.9rem;font-weight:500}.back-btn{display:inline-flex;align-items:center;gap:6px;color:var(--text-secondary);background:none;border:none;font-family:inherit;font-size:.85rem;cursor:pointer;padding:.5rem 0;margin-bottom:.5rem;transition:color .2s}.back-btn:hover{color:var(--text-primary)}.drill-panel-overlay{position:fixed;inset:0;background:#00000080;z-index:200;display:flex;justify-content:flex-end;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.drill-panel{width:min(560px,90vw);height:100vh;background:#0d1117fa;border-left:1px solid var(--panel-border);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);display:flex;flex-direction:column;animation:slideIn .25s ease;overflow:hidden}.drill-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--panel-border);flex-shrink:0}.drill-title{font-size:1.15rem;font-weight:700;color:var(--text-primary)}.drill-subtitle{font-size:.8rem;color:#a371f7;font-weight:600;margin-top:2px}.drill-nav-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--panel-border);background:#ffffff0a;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-family:inherit}.drill-nav-btn:hover:not(:disabled){background:#ffffff1a;color:var(--text-primary);border-color:#fff3}.drill-nav-btn:disabled{opacity:.3;cursor:not-allowed}.drill-chart-section{padding:1.25rem 1.5rem;border-bottom:1px solid var(--panel-border);flex-shrink:0}.drill-product-section{padding:1.25rem 1.5rem 0;flex:1;display:flex;flex-direction:column;min-height:0}.drill-product-scroll{flex:1;overflow-y:auto;padding-bottom:1.5rem}.drill-product-scroll::-webkit-scrollbar{width:6px}.drill-product-scroll::-webkit-scrollbar-track{background:transparent}.drill-product-scroll::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.drill-data-notice{display:flex;align-items:flex-start;gap:.5rem;padding:.625rem .75rem;background:#d2992214;border:1px solid rgba(210,153,34,.2);border-radius:8px;font-size:.75rem;color:#d29922;line-height:1.5;margin-bottom:.5rem}.drill-data-notice svg{flex-shrink:0;margin-top:1px}.summary-cards-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.25rem}.summary-card{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:14px;padding:1.1rem 1.25rem;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:all .3s ease}.summary-card:hover{border-color:#ffffff26;transform:translateY(-2px);box-shadow:0 6px 24px #00000040}.summary-card-label{font-size:.78rem;color:var(--text-secondary);margin-bottom:.5rem;font-weight:500}.summary-card-value{font-size:1.3rem;font-weight:700;color:var(--text-primary);margin-bottom:.35rem}.summary-card-change{display:flex;align-items:center}.event-top-table-wrap{padding:.5rem 0}.event-top-table{width:100%;border-collapse:collapse}.event-top-table th{font-size:.7rem;text-transform:uppercase;color:var(--text-secondary);font-weight:600;padding:.5rem .75rem;border-bottom:1px solid var(--panel-border);letter-spacing:.05em;text-align:left}.event-top-table td{padding:.65rem .75rem;color:var(--text-primary);font-size:.88rem;border-bottom:1px solid rgba(255,255,255,.03)}.event-row{cursor:pointer;transition:all .2s ease}.event-row:hover{background:#ffffff0a}.event-row.selected{background:#a371f71a;border-left:3px solid #a371f7}.event-bar-bg{width:100%;height:8px;background:#ffffff0a;border-radius:4px;overflow:hidden}.event-bar-fill{height:100%;border-radius:4px;transition:width .4s ease}.product-name-cell{font-size:.82rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px;display:inline-block;vertical-align:middle}.product-id-link{color:var(--accent-color);cursor:pointer;font-weight:500;font-size:.85rem;transition:all .2s ease;text-decoration:none;border-bottom:1px dashed transparent}.product-id-link:hover{color:#79c0ff;border-bottom-color:#58a6ff66}.product-popover-overlay{position:fixed;inset:0;background:#0009;z-index:300;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}.product-popover{background:#161b22fa;border:1px solid var(--panel-border);border-radius:18px;padding:1.5rem;width:min(400px,90vw);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:0 20px 60px #00000080;position:relative;animation:popIn .2s ease}@keyframes popIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.product-popover-close{position:absolute;top:.75rem;right:.75rem;width:32px;height:32px;border-radius:8px;border:1px solid var(--panel-border);background:#ffffff0a;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;font-family:inherit}.product-popover-close:hover{background:#ffffff1a;color:var(--text-primary)}.product-popover-content{display:flex;gap:1.25rem}.product-popover-img{width:140px;height:140px;border-radius:12px;overflow:hidden;flex-shrink:0;background:#ffffff0a;display:flex;align-items:center;justify-content:center}.product-popover-img img{width:100%;height:100%;object-fit:cover}.product-popover-img-empty{display:flex;flex-direction:column;gap:.5rem}.product-popover-info{flex:1;display:flex;flex-direction:column;gap:.5rem;min-width:0}.product-popover-id{font-size:.78rem;color:var(--text-secondary);font-weight:500}.product-popover-name{font-size:1rem;font-weight:600;color:var(--text-primary);line-height:1.4;word-break:keep-all}.product-popover-cats{display:flex;gap:.4rem;flex-wrap:wrap}.product-cat-badge{display:inline-block;padding:.2rem .6rem;border-radius:6px;font-size:.72rem;font-weight:600;background:#58a6ff1f;color:#58a6ff;border:1px solid rgba(88,166,255,.2)}.product-cat-badge.sub{background:#a371f71a;color:#a371f7;border-color:#a371f733}.product-popover-revenue{font-size:.88rem;color:var(--text-secondary);margin-top:auto}.product-popover-revenue strong{color:var(--text-primary);font-weight:700}.realtime-live-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--success);margin-left:.5rem;vertical-align:middle;animation:pulse-dot 2s ease infinite}@keyframes pulse-dot{0%,to{box-shadow:0 0 #2ea04380}50%{box-shadow:0 0 0 6px #2ea04300}}.realtime-refresh-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--panel-border);background:#ffffff0a;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-family:inherit}.realtime-refresh-btn:hover:not(:disabled){background:#ffffff1a;color:var(--text-primary);border-color:#fff3}.realtime-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.spin-icon{animation:spin 1s linear infinite}.rt-datetime-input{background:#ffffff0f;border:1px solid var(--panel-border);border-radius:8px;padding:.4rem .6rem;color:var(--text-primary);font-size:.85rem;font-family:inherit;outline:none;transition:border-color .2s}.rt-datetime-input:focus{border-color:var(--accent-color)}.rt-datetime-input::-webkit-calendar-picker-indicator{filter:invert(.7);cursor:pointer}.rt-cat-card{transition:transform .15s,box-shadow .15s}.rt-cat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000004d}.rt-cat-active{box-shadow:0 0 0 2px var(--accent-color)!important}.rt-cat-row{padding:.5rem .6rem;border-radius:8px;margin-bottom:.5rem;cursor:pointer;transition:background .15s}.rt-cat-row:hover{background:#ffffff0a}.rt-cat-row.selected{background:#ffffff0f}.rt-event-list{display:flex;flex-direction:column;gap:.25rem}.rt-event-item{display:flex;align-items:center;padding:.5rem .6rem;border-radius:8px;cursor:pointer;transition:background .15s;font-size:.85rem}.rt-event-item:hover{background:#ffffff0f}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-color);position:relative;overflow:hidden}.login-bg-orb{position:fixed;border-radius:50%;pointer-events:none;z-index:0}.login-bg-orb-1{top:-15%;left:-10%;width:50vw;height:50vw;background:radial-gradient(circle,rgba(88,166,255,.08) 0%,transparent 70%)}.login-bg-orb-2{bottom:-20%;right:-10%;width:60vw;height:60vw;background:radial-gradient(circle,rgba(163,113,247,.08) 0%,transparent 70%)}.login-card{position:relative;z-index:1;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:24px;padding:3rem 2.5rem;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:0 16px 64px #0006;text-align:center;max-width:420px;width:90vw;animation:loginFadeIn .5s ease}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-logo{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:20px;background:linear-gradient(135deg,#58a6ff26,#a371f726);margin-bottom:1.5rem}.login-logo svg{background:linear-gradient(135deg,var(--accent-color),#a371f7);background-clip:text;-webkit-background-clip:text;stroke:var(--accent-color)}.login-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem;letter-spacing:-.02em}.login-subtitle{font-size:1rem;color:var(--text-secondary);margin-bottom:0;font-weight:400}.login-divider{height:1px;background:var(--panel-border);margin:1.75rem 0}.login-btn-wrapper{display:flex;flex-direction:column;align-items:center;min-height:50px;margin-bottom:1rem}.login-verifying{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary);font-size:.9rem;padding:.75rem}.login-spinner{width:20px;height:20px;border:2px solid var(--panel-border);border-top-color:var(--accent-color);border-radius:50%;animation:spin .8s linear infinite}.login-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#f851491a;border:1px solid rgba(248,81,73,.25);border-radius:10px;color:var(--danger);font-size:.85rem;text-align:left;margin-bottom:1rem;animation:loginFadeIn .3s ease}.login-error svg{flex-shrink:0}.login-hint{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.8rem;color:var(--text-secondary);opacity:.7}.sidebar-user{display:flex;align-items:center;gap:.6rem;padding:.75rem 1rem;border-top:1px solid var(--panel-border);margin-top:.5rem}.sidebar-user-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;object-fit:cover}.sidebar-user-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:var(--accent-glow);color:var(--accent-color);font-weight:700;font-size:.85rem}.sidebar-user-info{flex:1;min-width:0;display:flex;flex-direction:column}.sidebar-user-name{font-size:.8rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:.65rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-logout-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1px solid var(--panel-border);background:transparent;color:var(--text-secondary);cursor:pointer;flex-shrink:0;transition:all .2s ease}.sidebar-logout-btn:hover{background:#f851491f;border-color:#f851494d;color:var(--danger)}.topbar-hamburger{display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--panel-border);background:#ffffff0a;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;flex-shrink:0}.topbar-hamburger:hover{background:#ffffff1a;color:var(--text-primary)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0000008c;z-index:199;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);animation:fadeIn .2s ease}@media(max-width:1023px)and (min-width:768px){:root{--sidebar-width: 72px}.sidebar{width:72px;padding:1.25rem .5rem;overflow:hidden}.brand{padding:0;justify-content:center;margin-bottom:1.5rem}.brand-text,.nav-group-label{display:none}.nav-item{padding:.75rem;justify-content:center;border-left:none!important}.nav-item.active{border-left:none;border-radius:10px}.nav-item span:not(.nav-badge-soon){display:none}.nav-badge-soon,.sidebar-user-info{display:none}.sidebar-user{justify-content:center}.sidebar-logout-btn,.sidebar-footer{display:none}.topbar{left:72px}.main-content{margin-left:72px;max-width:calc(100vw - 72px);padding:1.5rem;padding-top:calc(1.5rem + 56px)}}@media(max-width:767px){:root{--sidebar-width: 0px}.sidebar{width:260px;transform:translate(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);position:fixed;z-index:200;padding:1.5rem 1rem}.sidebar.sidebar-open{transform:translate(0)}.sidebar-overlay{display:block}.topbar{left:0;padding:0 1rem}.topbar-hamburger{display:flex}.main-content{margin-left:0;max-width:100vw;padding:1rem;padding-top:calc(1rem + 56px)}.page-title{font-size:1.35rem}.page-subtitle{font-size:.85rem;margin-bottom:1.25rem}.section-title{font-size:.95rem}.section-header{margin-top:1.5rem}}@media(max-width:1023px)and (min-width:480px){.summary-cards{grid-template-columns:repeat(2,1fr)}}@media(max-width:479px){.summary-cards{grid-template-columns:1fr;gap:.75rem}.summary-card .card-value{font-size:1.3rem}.sparkline-area{height:40px}}.md-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;gap:.75rem;flex-wrap:wrap}.md-header-controls{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.md-chart-area{height:300px}.md-chart-panel{padding:1.5rem}.product-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.period-filter{flex-wrap:wrap}.tab-bar{-webkit-overflow-scrolling:touch;scrollbar-width:none}.tab-bar::-webkit-scrollbar{display:none}.event-top-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.event-top-table{min-width:700px}@media(max-width:1023px){.dashboard-grid .glass-panel.col-span-6{grid-column:span 12}.summary-cards-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:767px){.md-header .page-title{font-size:1.3rem}.md-header .page-subtitle{font-size:.82rem;margin-bottom:.5rem}.period-filter .period-btn{padding:.3rem .6rem;font-size:.78rem}.summary-cards-row{grid-template-columns:1fr}.product-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.product-table{min-width:380px}.md-chart-area{height:200px}.md-chart-panel{min-height:auto!important}}.is-container{min-height:100%}.is-page{max-width:1080px;margin:0 auto;padding-bottom:3rem}.is-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.75rem;gap:1rem;flex-wrap:wrap}.is-header-actions{display:flex;gap:.5rem;align-items:center}.is-center{display:flex;align-items:center;justify-content:center;min-height:300px}.is-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:.6rem;margin-bottom:.3rem}.is-title-icon{color:#a371f7}.is-subtitle{font-size:.9rem;color:var(--text-secondary)}.is-section-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.is-section-header{display:flex;align-items:center;gap:.75rem;margin:2rem 0 1rem}.is-count{font-size:.8rem;color:var(--text-secondary);background:#ffffff0f;padding:.15rem .5rem;border-radius:20px}.is-btn-primary{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;background:linear-gradient(135deg,#7c3aed,#a371f7);color:#fff;border:none;border-radius:10px;font-family:inherit;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.is-btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px #a371f759}.is-btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.is-btn-ghost{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .9rem;background:#ffffff0d;color:var(--text-secondary);border:1px solid var(--panel-border);border-radius:10px;font-family:inherit;font-size:.88rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;white-space:nowrap}.is-btn-ghost:hover{background:#ffffff17;color:var(--text-primary)}.is-btn-ghost:disabled{opacity:.4;cursor:not-allowed}.is-cat-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--panel-border);padding-bottom:0}.is-cat-tab{padding:.6rem 1.4rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-family:inherit;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;margin-bottom:-1px}.is-cat-tab:hover{color:var(--text-primary)}.is-cat-tab.active{color:#a371f7;border-bottom-color:#a371f7;font-weight:600}.is-cat-badge{display:inline-block;font-size:.72rem;font-weight:600;padding:.2rem .6rem;border-radius:20px;background:#a371f726;color:#a371f7;border:1px solid rgba(163,113,247,.3);margin-bottom:.6rem}.is-cat-badge-sm{display:inline-block;font-size:.7rem;font-weight:500;padding:.15rem .5rem;border-radius:20px;background:#a371f71f;color:#a371f7;border:1px solid rgba(163,113,247,.25)}.is-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1rem}.is-card-skeleton{height:240px;border-radius:16px;background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14,#ffffff0a 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.is-loading-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1rem}.is-template-card{display:flex;flex-direction:column;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:16px;overflow:hidden;cursor:pointer;text-align:left;width:100%;transition:all .25s;font-family:inherit;position:relative}.is-template-card:hover{border-color:#a371f766;transform:translateY(-3px);box-shadow:0 12px 36px #0000004d,0 0 0 1px #a371f726}.is-card-thumb{width:100%;height:160px;background:#ffffff08;overflow:hidden;flex-shrink:0}.is-card-thumb-img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.is-template-card:hover .is-card-thumb-img{transform:scale(1.04)}.is-card-thumb-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:#ffffff26}.is-card-body{padding:1rem;flex:1}.is-card-cat{font-size:.7rem;color:#a371f7;font-weight:600;margin-bottom:.3rem;text-transform:uppercase;letter-spacing:.05em}.is-card-name{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.35rem}.is-card-desc{font-size:.82rem;color:var(--text-secondary);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin-bottom:.5rem}.is-card-date{font-size:.75rem;color:#8b949e99}.is-card-arrow{position:absolute;right:1rem;bottom:1rem;color:#fff3}.is-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 1rem;text-align:center;gap:.75rem}.is-empty-sm{padding:2.5rem 1rem}.is-empty-icon{color:#a371f74d;margin-bottom:.5rem}.is-empty-title{font-size:1rem;font-weight:600;color:var(--text-secondary)}.is-empty-desc{font-size:.85rem;color:#8b949e99}.is-error{background:#f851491a;border:1px solid rgba(248,81,73,.3);border-radius:10px;padding:.75rem 1rem;color:#f85149;font-size:.88rem}.is-form{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:16px;padding:1.75rem;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);display:flex;flex-direction:column;gap:1.25rem;max-width:700px}.is-form-error{background:#f851491a;border:1px solid rgba(248,81,73,.25);border-radius:8px;padding:.65rem 1rem;color:#f85149;font-size:.85rem}.is-form-group{display:flex;flex-direction:column;gap:.4rem}.is-label{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.is-required{color:#f85149}.is-input,.is-select,.is-textarea{background:#ffffff0a;border:1px solid var(--panel-border);border-radius:10px;padding:.65rem .9rem;color:var(--text-primary);font-family:inherit;font-size:.9rem;transition:border-color .2s;width:100%}.is-input:focus,.is-select:focus,.is-textarea:focus{outline:none;border-color:#a371f780;background:#a371f70a}.is-select option{background:#1a1d23}.is-textarea{resize:vertical;line-height:1.6}.is-hint{font-size:.78rem;color:#8b949e99}.is-form-actions{display:flex;gap:.6rem;justify-content:flex-end;padding-top:.5rem;border-top:1px solid var(--panel-border)}.is-asset-grid{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:.6rem}.is-asset-item{position:relative;width:80px;height:80px;border-radius:10px;overflow:hidden;background:#ffffff0d;border:1px solid var(--panel-border);cursor:pointer;transition:border-color .2s;flex-shrink:0;padding:0}.is-asset-item:hover{border-color:#a371f780}.is-asset-img{width:100%;height:100%;object-fit:cover;display:block}.is-asset-del{position:absolute;top:3px;right:3px;width:18px;height:18px;border-radius:50%;background:#000000b3;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:10px;z-index:2}.is-asset-pending{opacity:.8}.is-asset-badge{position:absolute;bottom:0;left:0;right:0;background:#a371f7cc;color:#fff;font-size:.55rem;font-weight:700;text-align:center;padding:2px 0}.is-asset-zoom{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000080;opacity:0;color:#fff;transition:opacity .2s}.is-asset-item:hover .is-asset-zoom{opacity:1}.is-upload-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:1px dashed rgba(163,113,247,.35);border-radius:10px;background:#a371f70d;color:#a371f7;font-family:inherit;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.is-upload-btn:hover{background:#a371f71a;border-color:#a371f799}.is-detail-card{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:16px;padding:1.5rem;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);margin-bottom:2rem}.is-detail-header{margin-bottom:1.25rem}.is-detail-name{font-size:1.4rem;font-weight:700;color:var(--text-primary);margin-bottom:.4rem}.is-detail-desc{font-size:.9rem;color:var(--text-secondary)}.is-detail-section{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--panel-border)}.is-detail-label{font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#8b949e99;margin-bottom:.6rem}.is-detail-text{font-family:inherit;font-size:.88rem;color:var(--text-secondary);white-space:pre-wrap;line-height:1.7}.is-history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem}.is-history-item{position:relative;border-radius:12px;overflow:hidden;cursor:pointer;background:#ffffff08;border:1px solid var(--panel-border);aspect-ratio:1;padding:0;transition:all .2s}.is-history-item:hover{border-color:#a371f780;transform:scale(1.02)}.is-history-img{width:100%;height:100%;object-fit:cover;display:block}.is-history-date{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b3);color:#fffc;font-size:.65rem;padding:.5rem .4rem .35rem;text-align:center}.is-chat-layout{display:flex;flex-direction:column;height:calc(100vh - 56px - 2rem);max-height:900px;min-height:500px}.is-chat-header{display:flex;align-items:center;gap:.75rem;padding:0 0 1rem;border-bottom:1px solid var(--panel-border);flex-shrink:0}.is-chat-header-info{display:flex;align-items:center;gap:.6rem;flex:1}.is-chat-template-name{font-size:1rem;font-weight:600;color:var(--text-primary)}.is-chat-messages{flex:1;overflow-y:auto;padding:1.25rem 0;display:flex;flex-direction:column;gap:1rem;scroll-behavior:smooth}.is-msg{display:flex;align-items:flex-start;gap:.6rem;max-width:85%}.is-msg-ai{align-self:flex-start;margin-right:auto}.is-msg-user{align-self:flex-end;flex-direction:row-reverse;margin-left:auto}.is-msg-avatar{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#7c3aed,#a371f7);display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:#fff;flex-shrink:0}.is-msg-bubble{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:14px;padding:.75rem 1rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);max-width:100%}.is-msg-user .is-msg-bubble{background:#7c3aed26;border-color:#a371f74d}.is-msg-error{border-color:#f851494d;background:#f8514912}.is-msg-text{font-size:.9rem;color:var(--text-primary);line-height:1.6;white-space:pre-wrap;word-break:break-word}.is-msg-img-wrap{display:block;position:relative;margin-top:.6rem;border-radius:10px;overflow:hidden;cursor:pointer;max-width:320px;border:none;padding:0}.is-msg-img{width:100%;height:auto;display:block;border-radius:10px;transition:filter .2s}.is-msg-img-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000073;color:#fff;opacity:0;transition:opacity .2s;border-radius:10px}.is-msg-img-wrap:hover .is-msg-img-overlay{opacity:1}.is-msg-attachment{max-width:120px;border-radius:8px;margin-top:.4rem;display:block}.is-generating{display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--text-secondary);font-style:italic}.is-chat-error{font-size:.82rem;color:#f85149;padding:.4rem 0;flex-shrink:0}.is-chat-input-area{border-top:1px solid var(--panel-border);padding-top:.75rem;flex-shrink:0}.is-attached-files{display:flex;gap:.4rem;margin-bottom:.5rem;flex-wrap:wrap}.is-attached-item{position:relative;width:52px;height:52px;border-radius:8px;overflow:hidden}.is-attached-item img{width:100%;height:100%;object-fit:cover}.is-attached-item button{position:absolute;top:2px;right:2px;width:16px;height:16px;border-radius:50%;background:#000000bf;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:9px}.is-chat-input-row{display:flex;align-items:flex-end;gap:.5rem;background:#ffffff0a;border:1px solid var(--panel-border);border-radius:14px;padding:.5rem .6rem;transition:border-color .2s}.is-chat-input-row:focus-within{border-color:#a371f773}.is-attach-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.3rem;display:flex;align-items:center;transition:color .2s;flex-shrink:0}.is-attach-btn:hover{color:var(--text-primary)}.is-chat-input{flex:1;background:none;border:none;color:var(--text-primary);font-family:inherit;font-size:.9rem;line-height:1.5;resize:none;min-height:24px;max-height:120px;overflow-y:auto}.is-chat-input:focus{outline:none}.is-chat-input::placeholder{color:#8b949e80}.is-send-btn{background:linear-gradient(135deg,#7c3aed,#a371f7);border:none;border-radius:10px;color:#fff;padding:.45rem .7rem;cursor:pointer;display:flex;align-items:center;transition:all .2s;flex-shrink:0}.is-send-btn:hover:not(.is-send-btn-disabled){transform:scale(1.05);box-shadow:0 3px 12px #a371f766}.is-send-btn-disabled{opacity:.4;cursor:not-allowed}.is-imgdetail-layout{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;align-items:start}.is-imgdetail-main{display:flex;flex-direction:column;gap:.75rem}.is-imgdetail-img-wrap{position:relative;border-radius:16px;overflow:hidden;cursor:pointer;background:#ffffff08;border:1px solid var(--panel-border);display:block;width:100%;padding:0}.is-imgdetail-img{width:100%;height:auto;display:block;transition:transform .3s}.is-imgdetail-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:.4rem;background:#00000073;color:#fff;font-size:.9rem;font-weight:600;opacity:0;transition:opacity .2s}.is-imgdetail-img-wrap:hover .is-imgdetail-overlay{opacity:1}.is-dl-btn{align-self:flex-start;text-decoration:none}.is-imgdetail-side{display:flex;flex-direction:column;gap:1rem;position:sticky;top:calc(56px + 2rem)}.is-side-section{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:14px;padding:1rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.is-side-chat{max-height:400px;overflow:hidden;display:flex;flex-direction:column}.is-side-label{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#8b949e80;margin-bottom:.6rem}.is-side-info{display:flex;flex-direction:column;gap:.4rem;font-size:.83rem;color:var(--text-secondary)}.is-session-imgs{display:flex;flex-wrap:wrap;gap:.4rem}.is-session-thumb{width:56px;height:56px;border-radius:8px;overflow:hidden;border:2px solid transparent;cursor:pointer;padding:0;background:none;transition:border-color .2s}.is-session-thumb img{width:100%;height:100%;object-fit:cover;display:block}.is-session-thumb-active{border-color:#a371f7}.is-history-chat{overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:.6rem}.is-hchat-msg{display:flex;gap:.5rem;font-size:.82rem}.is-hchat-user{align-self:flex-end;flex-direction:row-reverse}.is-hchat-ai{align-self:flex-start}.is-hchat-role{font-size:1rem;flex-shrink:0}.is-hchat-text{color:var(--text-secondary);line-height:1.5;word-break:break-word}.is-lightbox{position:fixed;inset:0;background:#000000e0;z-index:9999;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex-direction:column;gap:1rem;padding:2rem}.is-lightbox-close{position:fixed;top:1.25rem;right:1.25rem;background:#ffffff1f;border:none;border-radius:50%;width:40px;height:40px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.is-lightbox-close:hover{background:#fff3}.is-lightbox-img{max-width:90vw;max-height:80vh;object-fit:contain;border-radius:12px;box-shadow:0 20px 60px #0009}.is-lightbox-dl{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:10px;color:#fff;text-decoration:none;font-size:.85rem;transition:background .2s}.is-lightbox-dl:hover{background:#ffffff2e}.is-spin{animation:spin 1s linear infinite}.is-spin-large{color:#a371f7}@media(max-width:900px){.is-imgdetail-layout{grid-template-columns:1fr}.is-imgdetail-side{position:static}}@media(max-width:600px){.is-card-grid{grid-template-columns:1fr}.is-history-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.is-chat-layout{height:calc(100vh - 56px - 1rem)}.is-form{padding:1.25rem}}
