*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fff;--bg-white:#fff;--bg-warm:#f2f2f7;--bg-hover:#e8e8f0;--border:#e5e5ea;--border-light:#f2f2f7;--text:#1d1d1f;--text-sub:#6e6e73;--text-muted:#aeaeb2;--accent:#3b5bdb;--accent-light:#eef2ff;--accent-dark:#1b2d75;--accent-warm:#d4a843;--accent-warm-light:#fdf6e3;--green:#34c759;--green-light:#edfaf2;--red:#ff3b30;--red-light:#fff0ef;--amber:#ff9f0a;--amber-light:#fff8ec;--purple:#6c5ce7;--purple-light:#f0eeff;--cyan:#2d8fd5;--cyan-light:#e8f4fd;--radius:16px;--radius-sm:12px;--shadow:0 0 0 1px #0000000a,0 2px 8px #0000000a;--shadow-md:0 0 0 1px #0000000a,0 8px 24px #0000000f;--shadow-card:0 0 0 1px #0000000d,0 2px 8px #0000000a,0 8px 24px #00000008;--sidebar-bg:#0f1e4d;--sidebar-text:#ffffff85;--sidebar-text-active:#fff;--sidebar-active-bg:#1b2d75;--sidebar-section-label:#ffffff47;--card-border:#0000000d}body{background:var(--bg-warm);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px}.app-layout{background:var(--bg-warm);width:100%;height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--sidebar-bg);z-index:10;flex-direction:column;flex-shrink:0;width:220px;display:flex;overflow:hidden}.sidebar-logo{padding:26px 22px 20px}.sidebar-logo-main{color:var(--sidebar-text-active);letter-spacing:-.3px;align-items:center;gap:10px;font-size:20px;font-weight:800;display:flex}.sidebar-logo-main span{color:#fff;background:#ffffff26;border-radius:9px;justify-content:center;align-items:center;width:30px;height:30px;font-size:15px;font-weight:800;display:inline-flex}.sidebar-logo-sub{color:var(--sidebar-section-label);letter-spacing:.02em;margin-top:4px;padding-left:40px;font-size:12px;font-weight:500}.sidebar-nav{flex-direction:column;flex:1;gap:1px;padding:4px 14px;display:flex;overflow-y:auto}.sidebar-section-label{letter-spacing:.08em;text-transform:uppercase;color:var(--sidebar-section-label);opacity:1;padding:22px 10px 6px;font-size:11px;font-weight:700}.sidebar-section-label:first-child{padding-top:10px}.tab-btn{border-radius:var(--radius-sm);cursor:pointer;color:#ffffff85;text-align:left;background:0 0;border:none;align-items:center;gap:9px;width:100%;padding:8px 10px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s,color .15s;display:flex}.tab-btn.active{background:var(--sidebar-active-bg);color:var(--sidebar-text-active);font-weight:600}.tab-btn.active svg{stroke:#fff;opacity:1}.tab-btn:hover:not(.active){color:var(--sidebar-text-active);background:#ffffff0f}.tab-btn svg{opacity:.6;flex-shrink:0;transition:opacity .15s}.tab-btn:hover:not(.active) svg{opacity:.85}.tab-btn.disabled{opacity:.3;cursor:default;pointer-events:none}.sidebar-badge{color:#fff;background:#ffffff26;border-radius:6px;margin-left:auto;padding:2px 8px;font-size:9px;font-weight:600}.sidebar-link{border-radius:var(--radius-sm);cursor:pointer;width:100%;color:var(--sidebar-text);text-align:left;background:0 0;border:none;align-items:center;gap:11px;padding:10px 14px;font-family:inherit;font-size:12.5px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.sidebar-link:hover{color:var(--sidebar-text-active);background:#ffffff14}.sidebar-bottom{border-top:1px solid #ffffff1a;padding:16px 18px}.sidebar-user{justify-content:space-between;align-items:center;display:flex}.user-badge{color:#fff;background:#ffffff1f;border-radius:99px;padding:5px 12px;font-size:11px;font-weight:600}.logout-btn{color:var(--sidebar-text);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:5px 10px;font-family:inherit;font-size:11px;transition:all .15s}.logout-btn:hover{color:var(--sidebar-text-active);background:#ffffff14}.main-content{background:var(--bg-warm);flex-direction:column;flex:1;display:flex;overflow:hidden}.main-topbar{border-bottom:1px solid var(--border);background:#fff;flex-shrink:0;align-items:center;gap:16px;height:56px;padding:0 24px;display:flex}.main-topbar-title{color:var(--text);letter-spacing:-.3px;flex-shrink:0;margin-right:auto;font-size:16px;font-weight:700}.topbar-filter{align-items:center;display:flex}.segment-wrap{background:var(--border-light);border-radius:100px;gap:1px;padding:3px;display:flex}.topbar-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.topbar-role-badge{background:var(--accent-light);color:var(--accent);border-radius:99px;padding:4px 12px;font-size:11px;font-weight:600}.topbar-email{color:var(--text-sub);font-size:12px;font-weight:500}.topbar-user-pill{border:1px solid var(--border);cursor:pointer;border-radius:100px;align-items:center;gap:8px;padding:4px 4px 4px 12px;display:flex}.topbar-user-avatar{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:10px;font-weight:700;display:flex}.filter-bar{background:0 0;flex-wrap:wrap;align-items:center;gap:8px;padding:0;display:flex}.date-preset{cursor:pointer;color:var(--text-sub);background:0 0;border:none;border-radius:100px;padding:5px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:background .12s,color .12s}.date-preset:hover{color:var(--text);background:#0000000a}.date-preset.active{color:var(--text);box-shadow:var(--shadow);background:#fff;font-weight:600}.filter-sep-line{background:var(--border);flex-shrink:0;width:1px;height:20px;margin:0 4px}.filter-bar input[type=date]{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-white);color:var(--text);outline:none;height:34px;padding:6px 12px;font-family:inherit;font-size:12.5px;transition:all .15s}.filter-bar input[type=date]:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1b2d7514}.filter-date-sep{color:var(--text-muted);padding:0 2px;font-size:13px}.filter-sep{flex:1}.apply-btn{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-white);cursor:pointer;color:var(--text-sub);padding:6px 18px;font-family:inherit;font-size:12.5px;font-weight:600;transition:all .15s}.apply-btn:hover{border-color:var(--accent);color:var(--accent)}.apply-btn.dirty{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 10px #1b2d7533}.dash-wrap{background:var(--bg-warm);flex-direction:column;flex:1;gap:20px;padding:24px;display:flex;overflow-y:auto}.kpi-row{grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:16px;display:grid}.kpi-card{background:var(--bg-white);border-radius:var(--radius-sm);box-shadow:var(--shadow-card);border:none;padding:20px 20px 18px;transition:transform .15s,box-shadow .15s;position:relative;overflow:hidden}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-card:before{content:"";border-radius:var(--radius-sm)var(--radius-sm)0 0;height:3px;position:absolute;top:0;left:0;right:0}.kpi-card.blue:before{background:linear-gradient(90deg,#3b5bdb,#6c8eff)}.kpi-card.green:before{background:linear-gradient(90deg,#34c759,#5ce67a)}.kpi-card.yellow:before{background:linear-gradient(90deg,#ff9f0a,#ffb740)}.kpi-card.red:before{background:linear-gradient(90deg,#ff3b30,#ff6b63)}.kpi-card.purple:before{background:linear-gradient(90deg,#6c5ce7,#a29af0)}.kpi-card.cyan:before{background:linear-gradient(90deg,#2d8fd5,#5bb8f0)}.kpi-label{color:var(--text-sub);letter-spacing:.01em;margin-bottom:10px;font-size:12px;font-weight:600}.kpi-val,.kpi-value{color:var(--text);letter-spacing:-.03em;font-variant-numeric:tabular-nums;font-size:24px;font-weight:800;line-height:1}.kpi-sub{color:var(--text-muted);font-variant-numeric:tabular-nums;align-items:center;gap:4px;margin-top:8px;font-size:11px;display:flex}.section-header{justify-content:space-between;align-items:center;min-height:36px;margin-bottom:14px;display:flex}.section-header-left{align-items:center;gap:10px;display:flex}.section-header-title{color:var(--text);letter-spacing:-.3px;font-size:16px;font-weight:700}.section-header-badge{color:var(--accent);background:var(--accent-light);border-radius:99px;padding:3px 10px;font-size:11px;font-weight:600}.section-header-action{align-items:center;gap:8px;display:flex}.kpi-row-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}@media (max-width:768px){.kpi-row-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.kpi-row-4{grid-template-columns:1fr 1fr}}.hero-card{border-radius:var(--radius-sm);box-shadow:var(--shadow-card);background:linear-gradient(135deg,#0f1e4d 0%,#1b2d75 60%,#2840a0 100%);border:none;justify-content:space-between;align-items:center;gap:24px;margin-bottom:16px;padding:20px 24px;display:flex;position:relative;overflow:hidden}.hero-card:before{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff0f 0%,#0000 70%);width:220px;height:220px;position:absolute;top:-60px;right:-60px}.hero-card:after{content:"";pointer-events:none;background:radial-gradient(circle,#4f75ff26 0%,#0000 70%);width:160px;height:160px;position:absolute;bottom:-40px;left:30%}.hero-card-left{z-index:1;flex-direction:column;flex:1;gap:4px;display:flex;position:relative}.hero-card-title{color:#fff;letter-spacing:-.5px;font-variant-numeric:tabular-nums;font-size:24px;font-weight:800}.hero-card-subtitle{color:#ffffff73;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;font-size:11px;font-weight:600}.hero-card-primary-label{color:#ffffffb3;margin-bottom:4px;font-size:13px;font-weight:600}.hero-card-primary-value{color:#fff;letter-spacing:-.03em;font-variant-numeric:tabular-nums;font-size:30px;font-weight:800;line-height:1.1}.hero-card-channels{z-index:1;align-items:center;gap:0;display:flex;position:relative}.hero-channel-card{text-align:right;border-left:1px solid #ffffff1f;padding:0 28px}.hero-channel-card:first-child{border-left:none}.hero-channel-label{color:#fff6;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-size:10px;font-weight:600}.hero-channel-value{color:#fff;font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-size:18px;font-weight:800}.hero-channel-sub{color:#ffffff73;font-variant-numeric:tabular-nums;margin-top:2px;font-size:11px;font-weight:500}@media (max-width:768px){.hero-card{flex-direction:column}.hero-card-channels{gap:12px;width:100%}}@media (max-width:480px){.hero-card-channels{grid-template-columns:1fr 1fr;gap:12px;display:grid}}.chart-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.chart-card{border-radius:var(--radius-sm);box-shadow:var(--shadow-card);background:#fff;border:none;padding:20px 20px 18px}.chart-title,.chart-card-title{color:var(--text);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:14px;font-size:14px;font-weight:700;display:flex}.chart-title span,.chart-card-title span{color:var(--text-sub);background:var(--bg-warm);border-radius:100px;padding:3px 10px;font-size:11px;font-weight:600}.chart-full{grid-column:1/-1}.data-table-wrap{border-radius:var(--radius-sm);box-shadow:var(--shadow-card);background:#fff;border:none;overflow:hidden}.data-table-head{color:var(--text);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:18px 24px;font-size:14px;font-weight:700;display:flex}.data-table-head span{color:var(--text-muted);font-size:11px;font-weight:500}.table-card{border-radius:var(--radius-sm);box-shadow:var(--shadow-card);background:#fff;border:none;overflow:hidden}.table-card-title{color:var(--text);border-bottom:1px solid var(--border-light);padding:16px 20px;font-size:14px;font-weight:700}.table-scroll{width:100%;overflow-x:auto}table,.data-table{border-collapse:collapse;width:100%;font-size:13px}thead th{text-align:left;color:var(--text-muted);border-bottom:1px solid var(--border-light);white-space:nowrap;letter-spacing:.08em;text-transform:uppercase;background:#fafafa;padding:10px 16px;font-size:10px;font-weight:700}thead th.right{text-align:right}tbody td{border-bottom:1px solid var(--border-light);color:var(--text);vertical-align:middle;padding:12px 16px}tbody td.right{text-align:right;font-variant-numeric:tabular-nums}tbody td.muted{color:var(--text-sub)}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--accent-light)}.data-table tbody td:first-child{width:48px;min-width:48px;max-width:48px;padding:6px 8px}.td-date{color:var(--accent);font-variant-numeric:tabular-nums;font-size:12px;font-weight:600}.st{border-radius:99px;align-items:center;gap:5px;padding:4px 12px;font-size:10px;font-weight:600;display:inline-flex}.st:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px}.st-blue{background:var(--accent-light);color:var(--accent)}.st-green{background:var(--green-light);color:var(--green)}.st-yellow{background:var(--amber-light);color:var(--amber)}.st-red{background:var(--red-light);color:var(--red)}.st-purple{background:var(--purple-light);color:var(--purple)}.sub-tabs{background:var(--border-light);box-shadow:none;border-radius:100px;gap:1px;margin-bottom:20px;padding:3px;display:flex}.sub-tab{color:var(--text-sub);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:100px;padding:6px 16px;font-family:inherit;font-size:12px;font-weight:500;transition:background .12s,color .12s}.sub-tab.active{color:var(--text);box-shadow:var(--shadow);background:#fff;font-weight:600}.sub-tab:hover:not(.active){color:var(--text);background:#ffffff80}.gallery-controls{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.gallery-controls select{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-white);color:var(--text);outline:none;padding:8px 14px;font-family:inherit;font-size:12.5px;transition:all .15s}.gallery-controls select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1b2d7514}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;display:grid}.gallery-card{background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow-card);cursor:pointer;border:none;transition:all .2s;overflow:hidden}.gallery-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.gallery-thumb{aspect-ratio:3/4;background:var(--bg);width:100%;color:var(--text-muted);justify-content:center;align-items:center;font-size:11px;display:flex;position:relative;overflow:hidden}.gallery-thumb img{object-fit:cover;width:100%;height:100%}.gallery-info{padding:16px}.gallery-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:6px;font-size:12.5px;font-weight:600;overflow:hidden}.gallery-campaign{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-bottom:12px;font-size:10px;overflow:hidden}.gallery-metrics{grid-template-columns:1fr 1fr;gap:8px;display:grid}.gallery-metric{color:var(--text-muted);flex-direction:column;gap:2px;font-size:10px;display:flex}.gallery-metric strong{color:var(--text);font-size:14px;font-weight:700}.gallery-type-badge{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;border-radius:8px;align-items:center;gap:3px;padding:4px 10px;font-size:9px;font-weight:700;display:flex;position:absolute;top:12px;left:12px}.gallery-video-overlay{background:#0000001a;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.gallery-video-overlay svg{fill:#fffffff2;filter:drop-shadow(0 2px 8px #00000040);width:48px;height:48px}.gallery-ad-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:12px;font-weight:600;overflow:hidden}.gallery-spend{color:var(--accent);margin-bottom:6px;font-size:15px;font-weight:700}.gallery-video-placeholder{background:var(--bg);width:100%;height:100%;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.gallery-no-thumb{background:var(--bg);width:100%;height:100%;color:var(--text-muted);justify-content:center;align-items:center;font-size:11px;display:flex}.gallery-platform-text{flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;height:100%;font-size:12px;font-weight:600;display:flex}.gallery-platform-text.google{color:#5f6368;background:#f8f9fa}.gallery-view-toggle{background:var(--bg-warm);border-radius:var(--radius-sm);gap:4px;padding:5px;display:flex;box-shadow:inset 0 1px 3px #0000000a}.view-toggle-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:10px;padding:9px 20px;font-family:inherit;font-size:12.5px;font-weight:500;transition:all .15s}.view-toggle-btn.active{color:#fff;background:var(--accent);font-weight:600;box-shadow:0 2px 12px #1b2d7533}.view-toggle-btn:hover:not(.active){color:var(--accent);background:var(--bg-hover)}.gallery-metric-selector{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.metric-chips{flex-wrap:wrap;gap:6px;display:flex}.metric-chip{border:1.5px solid var(--border);cursor:pointer;color:var(--text-sub);background:0 0;border-radius:20px;padding:4px 10px;font-family:inherit;font-size:11px;font-weight:600;transition:all .15s}.metric-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}.metric-chip:hover:not(.active){border-color:var(--accent);color:var(--accent)}.platform-badge{text-transform:capitalize;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.platform-meta{color:#4267b2;background:#4267b226}.platform-google{color:#ea4335;background:#ea43351f}.platform-naver{color:#03c75a;background:#03c75a1f}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:900;background:#1a1a2e66;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-overlay.show{display:flex}.modal-content{background:var(--bg-white);border-radius:20px;width:90vw;max-width:920px;max-height:85vh;overflow-y:auto;box-shadow:0 24px 64px #1b2d751f,0 8px 24px #00000014}.modal-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:22px 28px;display:flex}.modal-header h3{font-size:16px;font-weight:700}.modal-close{border-radius:var(--radius-sm);background:var(--bg);cursor:pointer;width:34px;height:34px;color:var(--text-sub);border:none;justify-content:center;align-items:center;font-size:17px;transition:all .15s;display:flex}.modal-close:hover{background:var(--accent-light);color:var(--accent)}.modal-body{grid-template-columns:1fr 1fr;gap:0;display:grid}.modal-media{background:var(--bg-warm);border-radius:0 0 0 20px;justify-content:center;align-items:center;min-height:300px;padding:28px;display:flex}.modal-media img,.modal-media video{border-radius:var(--radius-sm);object-fit:contain;max-width:100%;max-height:400px}.modal-details{flex-direction:column;gap:16px;padding:28px;display:flex}.modal-meta-row{border-bottom:1px solid var(--border-light);justify-content:space-between;padding:8px 0;font-size:12.5px;display:flex}.modal-meta-row .label{color:var(--text-muted)}.modal-meta-row .value{color:var(--text);font-weight:600}.modal-kpi-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.modal-kpi{background:var(--bg-warm);border-radius:var(--radius-sm);text-align:center;padding:16px}.modal-kpi .label{color:var(--text-muted);letter-spacing:.03em;margin-bottom:6px;font-size:10px}.modal-kpi .value{color:var(--text);font-size:22px;font-weight:800}.scm-inventory-table th,.scm-inventory-table td{padding:10px 14px;font-size:11.5px}.stock-days-bar{border-radius:3px;min-width:4px;height:6px}.stock-critical{background:var(--red)}.stock-warning{background:var(--amber)}.stock-ok{background:var(--green)}.admin-layout{max-width:960px;margin:0 auto;padding:36px}.admin-card{background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow-card);margin-bottom:20px;padding:28px}.admin-card h2{color:var(--text);margin-bottom:18px;font-size:16px;font-weight:700}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th{text-align:left;color:var(--text-muted);background:var(--bg-warm);border-bottom:1px solid var(--border-light);text-transform:uppercase;letter-spacing:.04em;padding:11px 16px;font-size:11px;font-weight:700}.admin-table td{border-bottom:1px solid var(--border-light);color:var(--text);padding:12px 16px}.admin-table tr:hover{background:var(--bg-hover)}.admin-btn{border-radius:var(--radius-sm);cursor:pointer;border:none;padding:8px 18px;font-family:inherit;font-size:12.5px;font-weight:600;transition:all .15s}.admin-btn-primary{background:var(--accent);color:#fff}.admin-btn-primary:hover{background:var(--accent-dark)}.admin-btn-danger{background:var(--red-light);color:var(--red)}.admin-btn-danger:hover{background:var(--red);color:#fff}.admin-select{border:1.5px solid var(--border);background:var(--bg-white);color:var(--text);border-radius:8px;outline:none;padding:7px 12px;font-family:inherit;font-size:12px}.admin-select:focus{border-color:var(--accent)}.permission-grid{gap:0;display:grid}.permission-cell{text-align:center;border-bottom:1px solid var(--border-light);padding:12px}.permission-cell input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.stats-bottom-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.daily-table-wrap{background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow-card);flex-direction:column;max-height:420px;display:flex;overflow:hidden}.daily-table-head{color:var(--text);border-bottom:1px solid var(--border-light);flex-shrink:0;padding:16px 20px;font-size:14px;font-weight:700}.daily-table-scroll{flex:1;overflow-y:auto}.daily-total-row td{color:var(--accent);z-index:1;font-weight:700;position:sticky;bottom:0;background:var(--accent-light)!important}.table-total-row td{border-top:2px solid var(--border);font-weight:700;background:var(--bg-warm)!important}.delta-up{color:var(--green);white-space:nowrap;font-size:11px;font-weight:600}.delta-dn{color:var(--red);white-space:nowrap;font-size:11px;font-weight:600}.delta-flat{color:var(--text-muted);font-size:11px}.mini-bar-wrap{flex-direction:column;gap:3px;display:flex}.mini-bar{background:var(--accent);opacity:.3;border-radius:2px;min-width:2px;height:3px;transition:width .3s}.weekend-row{background:var(--bg-hover)!important}@media (max-width:768px){.stats-bottom-grid{grid-template-columns:1fr}}.top3-card{margin-top:16px}.top3-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:20px;display:flex}.top3-period-tabs{background:var(--bg-warm);border-radius:var(--radius-sm);gap:4px;padding:4px;display:flex;box-shadow:inset 0 1px 3px #0000000a}.top3-period-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s}.top3-period-btn.active{background:var(--accent);color:#fff;font-weight:600;box-shadow:0 2px 8px #1b2d7533}.top3-period-btn:hover:not(.active){color:var(--accent);background:var(--bg-hover)}.top3-loading{justify-content:center;padding:40px 0;display:flex}.top3-empty{text-align:center;color:var(--text-muted);padding:40px;font-size:13px}.top3-grid{grid-template-columns:repeat(5,1fr);gap:12px;display:grid}.top3-card-item{background:var(--bg-white);border-radius:var(--radius);border:1.5px solid var(--border-light);transition:all .2s;overflow:hidden}.top3-card-item:hover{box-shadow:var(--shadow-md);border-color:var(--accent);transform:translateY(-2px)}.top3-thumb{aspect-ratio:3/4;background:var(--bg-warm);justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.top3-thumb img{object-fit:cover;width:100%;height:100%}.top3-rank-badge{color:#fff;letter-spacing:.03em;z-index:2;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:800;position:absolute;top:10px;left:10px;box-shadow:0 2px 8px #0003}.top3-platform-badge{text-transform:capitalize;z-index:2;border-radius:10px;padding:3px 8px;font-size:10px;font-weight:700;position:absolute;top:10px;right:10px}.top3-google-placeholder{color:#5f6368;background:#f8f9fa;flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;height:100%;font-size:12px;font-weight:600;display:flex}.top3-video-placeholder{background:var(--bg);width:100%;height:100%;color:var(--text-muted);justify-content:center;align-items:center;font-size:32px;display:flex}.top3-no-thumb{background:var(--bg);width:100%;height:100%;color:var(--text-muted);justify-content:center;align-items:center;font-size:11px;display:flex}.top3-info{padding:14px 16px}.top3-ad-name{color:var(--text);-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:32px;margin-bottom:10px;font-size:12px;font-weight:600;line-height:1.4;display:-webkit-box;overflow:hidden}.top3-metrics{grid-template-columns:1fr 1fr;gap:6px;display:grid}.top3-metric{background:var(--bg-warm);border-radius:8px;flex-direction:column;gap:2px;padding:8px 10px;display:flex}.top3-metric.primary{grid-column:1/-1}.top3-metric-label{color:var(--text-muted);letter-spacing:.02em;font-size:10px;font-weight:500}.top3-metric-value{color:var(--text);font-size:14px;font-weight:700}.top3-metric.primary .top3-metric-value{font-size:18px}@media (max-width:1100px){.top3-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:700px){.top3-grid{grid-template-columns:repeat(2,1fr)}}.placeholder-msg{text-align:center;color:var(--text-muted);padding:80px 40px}.placeholder-msg h3{color:var(--text-sub);margin-bottom:12px;font-size:18px;font-weight:700}.placeholder-msg p{font-size:13px;line-height:1.6}.loading-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-bg{background:linear-gradient(135deg,#f4f1ec 0%,#e8e3da 50%,#f4f1ec 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--bg-white);width:400px;box-shadow:var(--shadow-md);border:none;border-radius:20px;padding:48px}.login-card h1{color:var(--accent);letter-spacing:-.5px;margin-bottom:4px;font-size:26px;font-weight:800}.login-card p{color:var(--text-sub);margin-bottom:32px;font-size:12.5px}.login-google-btn{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:10px;width:100%;padding:14px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s;display:flex}.login-google-btn:hover{background:var(--accent-dark);transform:translateY(-1px);box-shadow:0 6px 20px #1b2d7540}.login-google-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.login-error{color:var(--red);text-align:center;background:var(--red-light);border-radius:var(--radius-sm);margin-top:14px;padding:10px 14px;font-size:11px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-block{background:linear-gradient(90deg,var(--bg-hover)25%,var(--border-light)50%,var(--bg-hover)75%);background-size:200% 100%;border-radius:6px;animation:1.4s ease-in-out infinite skeleton-shimmer}.skeleton-kpi-row{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px;display:grid}.skeleton-kpi-card{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:16px 18px}.skeleton-chart-row{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px;display:grid}.skeleton-chart{background:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:16px 18px}@media (max-width:768px){.skeleton-kpi-row{grid-template-columns:repeat(2,1fr)}.skeleton-chart-row{grid-template-columns:1fr}}@media (max-width:1024px){.sidebar{width:200px}.kpi-row,.top3-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){html,body{width:100%;overflow-x:hidden}.app-layout{flex-direction:column;width:100%;height:100dvh}.sidebar{border-top:1px solid #ffffff14;border-radius:0;flex-direction:row;flex-shrink:0;order:2;width:100%;height:56px;overflow:hidden;box-shadow:0 -1px #ffffff0f}.sidebar-logo,.sidebar-bottom,.sidebar-section-label{display:none}.sidebar-nav{scrollbar-width:none;flex-direction:row;flex:1;align-items:stretch;gap:0;padding:0;overflow-x:auto}.sidebar-nav::-webkit-scrollbar{display:none}.tab-btn{white-space:nowrap;border-radius:0;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:3px;min-width:64px;height:56px;padding:6px 12px;font-size:10px}.tab-btn svg{opacity:.55;width:18px;height:18px;display:block}.tab-btn.active svg{opacity:1}.sidebar-badge,.sidebar-link{display:none}.main-content{flex:1;order:1;min-height:0;overflow:hidden}.main-topbar{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:0;height:auto;min-height:48px;padding:0 16px}.main-topbar-title{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;padding:12px 0;font-size:15px;overflow:hidden}.topbar-filter{border-top:1px solid var(--border-light);order:3;width:100%;padding:6px 0 8px}.topbar-right{padding:8px 0}.filter-sep-line,.filter-bar input[type=date],.filter-date-sep,.apply-btn{display:none}.filter-bar{gap:4px}.topbar-user-pill{padding:3px 3px 3px 8px}.topbar-email{display:none}.dash-wrap{gap:14px;padding:12px 16px 80px}.hero-card{flex-direction:column;gap:16px;padding:16px}.hero-card-title{font-size:20px}.hero-card-primary-value{font-size:24px}.hero-card-channels{grid-template-columns:repeat(3,1fr);gap:0;width:100%;display:grid}.hero-channel-card{text-align:center;border-left:1px solid #ffffff1f;padding:8px 12px}.hero-channel-card:first-child{border-left:none}.hero-channel-value{font-size:15px}.kpi-row,.kpi-row-4{grid-template-columns:repeat(2,1fr);gap:10px}.kpi-card{padding:16px}.kpi-val,.kpi-value{font-size:20px}.chart-row{grid-template-columns:1fr;gap:10px}.chart-full{grid-column:auto}.data-table-wrap,.table-card,.table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}table,.data-table{min-width:560px}thead th{padding:8px 12px;font-size:10px}tbody td{padding:9px 12px;font-size:12px}.section-header{min-height:auto;margin-bottom:10px}.section-header-title{font-size:14px}.sub-tabs{scrollbar-width:none;border-radius:100px;flex-wrap:nowrap;overflow-x:auto}.sub-tabs::-webkit-scrollbar{display:none}.sub-tab{white-space:nowrap;padding:6px 14px}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:10px}.modal-body{grid-template-columns:1fr}.modal-content{width:95vw;max-height:90vh}.stats-bottom-grid{grid-template-columns:1fr}.admin-layout{padding:16px}.top3-grid{grid-template-columns:repeat(2,1fr);gap:10px}.app-layout.chat-open .chat-panel{z-index:999;border-left:none;border-radius:0;width:100%;height:100dvh;position:fixed;inset:0}.app-layout.chat-open .chat-fab{opacity:0;pointer-events:none}.ai-insights-header{flex-wrap:wrap;gap:8px}}@media (max-width:480px){.kpi-row{grid-template-columns:1fr 1fr}.kpi-val,.kpi-value{font-size:18px}.hero-card-channels{grid-template-columns:1fr 1fr}.hero-channel-card:nth-child(3){text-align:left;border-top:1px solid #ffffff1a;border-left:none;grid-column:1/-1;margin-top:4px;padding-top:10px}.gallery-grid{grid-template-columns:1fr}.top3-grid{grid-template-columns:1fr 1fr}.tab-btn{min-width:52px;padding:4px 8px;font-size:9px}.dash-wrap{padding:10px 12px 72px}}.chat-fab{z-index:1000;color:#fff;cursor:pointer;background:#1a1a1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;font-size:18px;transition:transform .15s,background .15s,opacity .15s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 20px #00000047}.chat-fab:hover{background:#2a2a2a;transform:scale(1.08)}.chat-fab-open{background:#2a2a2a}.chat-panel{z-index:999;background:#fff;border:1px solid #0000001a;border-radius:18px;flex-direction:column;width:360px;height:520px;display:flex;position:fixed;bottom:82px;right:24px;overflow:hidden;box-shadow:0 12px 48px #0000002e,0 2px 8px #00000014}.app-layout.chat-open .chat-panel{border:none;border-left:1px solid var(--border);width:440px;height:100vh;box-shadow:none;z-index:auto;border-radius:0;flex-shrink:0;position:relative;bottom:auto;right:auto}.app-layout.chat-open .chat-fab{opacity:0;pointer-events:none}.chat-header{background:#fff;border-bottom:1px solid #00000012;justify-content:space-between;align-items:center;padding:14px 16px 13px;display:flex}.chat-header-title{color:#1a1a1a;letter-spacing:-.01em;align-items:center;gap:8px;font-size:13.5px;font-weight:600;display:flex}.chat-header-icon{color:#fff;background:#1a1a1a;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;display:inline-flex}.chat-close-btn{cursor:pointer;color:#999;background:0 0;border:none;border-radius:8px;padding:4px 7px;font-size:13px;line-height:1;transition:background .15s,color .15s}.chat-close-btn:hover{color:#333;background:#f0f0f0}.chat-messages{background:#fff;flex-direction:column;flex:1;gap:14px;padding:16px 14px;display:flex;overflow-y:auto}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-thumb{background:#0000001a;border-radius:4px}.chat-msg{align-items:flex-start;gap:8px;display:flex}.chat-msg-user{flex-direction:row-reverse}.chat-msg-avatar{color:#fff;background:#1a1a1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-top:2px;font-size:10px;display:flex}.chat-msg-bubble{word-break:break-word;letter-spacing:-.01em;border-radius:16px;max-width:270px;padding:10px 13px;font-size:13px;line-height:1.6}.chat-msg-assistant .chat-msg-bubble{color:#1a1a1a;background:#f4f4f4;border-top-left-radius:4px}.chat-msg-user .chat-msg-bubble{color:#fff;background:#1a1a1a;border-top-right-radius:4px}.chat-typing{align-items:center;gap:5px;min-width:52px;padding:12px 14px;display:flex}.chat-typing span{background:#bbb;border-radius:50%;width:6px;height:6px;animation:1.2s infinite chatBounce;display:inline-block}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes chatBounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-6px)}}.chat-input-row{background:#fff;border-top:1px solid #00000012;align-items:flex-end;gap:8px;padding:10px 12px 12px;display:flex}.chat-input{resize:none;color:#1a1a1a;background:#fafafa;border:1px solid #0000001f;border-radius:12px;outline:none;flex:1;min-height:38px;max-height:100px;padding:9px 12px;font-family:inherit;font-size:13px;line-height:1.5;transition:border .15s,background .15s;overflow-y:auto}.chat-input:focus{background:#fff;border-color:#1a1a1a}.chat-input::placeholder{color:#aaa}.chat-send-btn{color:#fff;cursor:pointer;background:#1a1a1a;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:15px;transition:opacity .15s,background .15s;display:flex}.chat-send-btn:hover:not(:disabled){background:#333}.chat-send-btn:disabled{opacity:.3;cursor:default}.chat-feedback{align-items:center;gap:4px;margin-top:7px;display:flex}.chat-feedback-btn{cursor:pointer;opacity:.5;background:0 0;border:1px solid #0000001a;border-radius:7px;padding:2px 7px;font-size:12px;transition:opacity .15s,border-color .15s}.chat-feedback-btn:hover{opacity:1;border-color:#00000040}.chat-feedback-done{color:#999;font-size:11px}.ai-insights-card{margin-top:16px;margin-bottom:20px;position:relative;overflow:hidden;background:linear-gradient(135deg,#0a1628 0%,#0d2144 40%,#0f2e5c 70%,#1a3a6e 100%)!important;border:1px solid #63b3ff26!important;box-shadow:0 0 0 1px #63b3ff14,0 4px 24px #0a1e4666!important}.ai-insights-card:before{content:"";pointer-events:none;background:radial-gradient(circle,#63b3ff1f 0%,#0000 65%);width:260px;height:260px;position:absolute;top:-80px;right:-80px}.ai-insights-card:after{content:"";pointer-events:none;background:radial-gradient(circle,#4f75ff1a 0%,#0000 65%);width:180px;height:180px;position:absolute;bottom:-60px;left:10%}.ai-insights-header{z-index:1;justify-content:space-between;align-items:center;margin-bottom:12px;display:flex;position:relative}.ai-insights-icon{color:#63b3ff;margin-right:6px;font-size:14px}.ai-insights-card .chart-title{color:#e8f4ff!important}.ai-insights-card .chart-title span{color:#e8f4ff73!important;background:#ffffff0f!important}.ai-insights-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb,#3b82f6);border:none;border-radius:8px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:opacity .15s;box-shadow:0 2px 8px #2563eb66}.ai-insights-btn:hover{opacity:.85}.ai-insights-btn-secondary{color:#63b3ff;background:0 0;border:1px solid #63b3ff66}.ai-insights-placeholder{color:#e8f4ff73;z-index:1;padding:12px 0;font-size:13px;position:relative}.ai-insights-loading{color:#e8f4ff99;z-index:1;align-items:center;gap:10px;padding:16px 0;font-size:13px;display:flex;position:relative}.ai-insights-list{z-index:1;flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex;position:relative}.ai-insights-item{color:#e8f4ffd9;align-items:flex-start;gap:10px;font-size:13px;line-height:1.6;display:flex}.ai-insights-num{color:#fff;background:linear-gradient(135deg,#2563eb,#60a5fa);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;margin-top:1px;font-size:11px;font-weight:600;display:flex;box-shadow:0 2px 6px #2563eb80}.ai-insights-qa{background:#ffffff0d;border:1px solid #63b3ff1a;border-radius:10px;flex-direction:column;gap:6px;padding:10px 12px;display:flex}.ai-insights-qa-q{color:#e8f4ff99;align-items:flex-start;gap:8px;font-size:12.5px;display:flex}.ai-insights-qa-a{color:#e8f4ffe6;align-items:flex-start;gap:8px;font-size:13px;line-height:1.6;display:flex}.ai-insights-qa-icon{color:#e8f4ffb3;background:#ffffff26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;margin-top:1px;font-size:10px;font-weight:700;display:flex}.ai-insights-input-row{z-index:1;border-top:1px solid #63b3ff1f;align-items:flex-end;gap:8px;margin-top:14px;padding-top:12px;display:flex;position:relative}.ai-insights-input{resize:none;color:#e8f4ffe6;background:#ffffff12;border:1px solid #63b3ff33;border-radius:10px;outline:none;flex:1;min-height:36px;max-height:90px;padding:9px 12px;font-family:inherit;font-size:12.5px;line-height:1.5;transition:border .15s,background .15s;overflow-y:auto}.ai-insights-input:focus{background:#ffffff1a;border-color:#63b3ff80}.ai-insights-input::placeholder{color:#e8f4ff4d}.ai-insights-send-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb,#3b82f6);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:opacity .15s;display:flex;box-shadow:0 2px 8px #2563eb66}.ai-insights-send-btn:disabled{opacity:.3;cursor:default}
