*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--brand: #f90400;--brand-dark: #d90400;--brand-glow: rgba(249,4,0,.16);--brand-subtle: rgba(249,4,0,.08);--bg: #f5f5f7;--bg1: #ffffff;--bg2: #fafafc;--bg3: #f3f4f6;--bg4: #e8eaee;--b1: rgba(16,24,40,.06);--b2: rgba(16,24,40,.11);--b3: rgba(16,24,40,.18);--t1: #0f172a;--t2: #334155;--t3: #64748b;--green: #0f9d58;--green-bg: rgba(15,157,88,.1);--green-b: rgba(15,157,88,.25);--red: #ef4444;--red-bg: rgba(239,68,68,.1);--red-b: rgba(239,68,68,.24);--amber: #d97706;--amber-bg: rgba(217,119,6,.11);--amber-b: rgba(217,119,6,.26);--blue: #2563eb;--blue-bg: rgba(37,99,235,.1);--blue-b: rgba(37,99,235,.24);--purple: #7c3aed;--purple-bg: rgba(124,58,237,.1);--purple-b:rgba(124,58,237,.25);--cyan: #0891b2;--cyan-bg: rgba(8,145,178,.1);--cyan-b: rgba(8,145,178,.24);--r: 6px;--r-md:10px;--r-lg:14px;--r-xl:20px;--font-head: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Inter", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: "SF Mono", ui-monospace, "DM Mono", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--shadow: 0 10px 30px rgba(15,23,42,.08), 0 2px 8px rgba(15,23,42,.05);--shadow-sm: 0 4px 12px rgba(15,23,42,.07);--page-max: 1340px;--ease-spring: cubic-bezier(.32, .72, 0, 1)}html,body,#root{height:100%}body{font-family:var(--font-head);background:var(--bg);color:var(--t1);font-size:13.5px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow:hidden}.app-shell{display:flex;height:100vh;overflow:hidden}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.page-body{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;padding:clamp(18px,3vw,32px) max(26px,env(safe-area-inset-right)) clamp(22px,4vw,40px) max(26px,env(safe-area-inset-left));padding-bottom:max(28px,env(safe-area-inset-bottom));max-width:var(--page-max);margin:0 auto;width:100%;box-sizing:border-box}.sidebar{position:relative;width:224px;min-width:224px;background:var(--bg1);border-right:1px solid var(--b1);box-shadow:inset -1px 0 0 var(--b1);display:flex;flex-direction:column;overflow:hidden}.sidebar-inner{flex:1;overflow-y:auto;padding-bottom:12px}.logo-bar{padding:18px 18px 14px;border-bottom:1px solid var(--b1);display:flex;align-items:center;gap:10px}.logo-mark{width:30px;height:30px;background:var(--brand);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.logo-mark svg{width:16px;height:16px}.logo-name{font-family:var(--font-head);font-size:16px;font-weight:800;letter-spacing:-.02em;color:var(--t1)}.logo-domain{font-size:9px;color:var(--t3);letter-spacing:.04em;margin-top:1px}.nav-section-label{font-size:9px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--t3);padding:14px 18px 5px}.nav-link{display:flex;align-items:center;gap:9px;padding:8px 18px;color:var(--t2);cursor:pointer;border-left:2px solid transparent;font-size:13px;font-family:var(--font-head);font-weight:400;transition:all .12s;-webkit-user-select:none;user-select:none}.nav-link:hover{color:var(--t1);background:var(--bg2)}.nav-link.active{color:var(--brand);border-left-color:var(--brand);background:var(--brand-subtle)}.nav-link .icon{width:15px;height:15px;flex-shrink:0}.nav-link.active .icon{opacity:1}.nav-link .icon{opacity:.55}.sidebar-footer{padding:12px 18px;border-top:1px solid var(--b1);font-size:10px;color:var(--t3);display:flex;align-items:center;justify-content:space-between}.dot-online{width:6px;height:6px;border-radius:50%;background:var(--brand);display:inline-block;margin-right:4px}.topbar{min-height:56px;background:#ffffffb8;border-bottom:1px solid var(--b1);backdrop-filter:saturate(1.35) blur(14px);-webkit-backdrop-filter:saturate(1.35) blur(14px);display:flex;align-items:flex-start;justify-content:space-between;padding:12px max(28px,env(safe-area-inset-right)) 12px max(26px,env(safe-area-inset-left));padding-top:max(12px,env(safe-area-inset-top));gap:14px}.topbar-left{min-width:0;flex:1}.topbar-title{font-family:var(--font-head);font-size:clamp(17px,2.2vw,19px);font-weight:600;letter-spacing:-.026em;line-height:1.22}.topbar-sub{font-family:var(--font-head);font-size:12px;font-weight:400;color:var(--t3);margin-top:3px;line-height:1.42}.topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end;padding-top:2px}.card{background:var(--bg1);border:1px solid var(--b1);border-radius:var(--r-lg);padding:20px 22px;box-shadow:var(--shadow-sm)}.card+.card,.card+.card-group{margin-top:14px}.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.card-title{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--t3)}.section-title{font-family:var(--font-head);font-size:14px;font-weight:600;color:var(--t1);margin-bottom:14px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(172px,1fr));gap:clamp(12px,2vw,18px);margin-bottom:clamp(22px,3vw,30px)}.kpi{background:linear-gradient(180deg,var(--bg1),var(--bg2));border:1px solid var(--b1);border-radius:var(--r-lg);padding:16px 18px;position:relative;overflow:hidden;transition:transform .18s ease,box-shadow .18s ease}@media (hover: hover){.kpi:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}}.kpi:after{content:"";position:absolute;top:0;left:0;right:0;height:2px;border-radius:var(--r-lg) var(--r-lg) 0 0}.kpi.green:after{background:var(--green)}.kpi.red:after{background:var(--red)}.kpi.amber:after{background:var(--amber)}.kpi.blue:after{background:var(--blue)}.kpi.purple:after{background:var(--purple)}.kpi.cyan:after{background:var(--cyan)}.kpi-label{font-size:10px;letter-spacing:.09em;text-transform:uppercase;color:var(--t3);margin-bottom:7px}.kpi-val{font-family:var(--font-head);font-size:clamp(20px,2.8vw,24px);font-weight:600;letter-spacing:-.03em;line-height:1.1}.kpi-val.green{color:var(--green)}.kpi-val.red{color:var(--red)}.kpi-val.amber{color:var(--amber)}.kpi-val.blue{color:var(--blue)}.kpi-val.purple{color:var(--purple)}.kpi-val.cyan{color:var(--cyan)}.kpi-sub{font-size:10px;color:var(--t3);margin-top:4px}.tbl-wrap{overflow-x:auto;border-radius:var(--r-md);border:1px solid var(--b1);background:var(--bg1);box-shadow:0 1px 2px #0f172a08}.tbl-wrap table{margin:0}table{width:100%;border-collapse:collapse;font-size:12px}thead th{font-size:9px;font-weight:500;letter-spacing:.13em;text-transform:uppercase;color:var(--t3);padding:8px 10px;border-bottom:1px solid var(--b1);text-align:left;white-space:nowrap}tbody td{padding:9px 10px;border-bottom:1px solid var(--b1);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#0f172a08}tfoot td{padding:10px;font-weight:500;border-top:1px solid var(--b2)}table.tbl-compact tbody td{padding:7px 10px;font-size:12px}table.tbl-compact thead th{padding:7px 10px;font-size:9px}.badge{display:inline-block;font-size:10px;font-weight:500;padding:2px 7px;border-radius:20px;letter-spacing:.04em;text-transform:uppercase;font-family:var(--font-mono);white-space:nowrap}.badge-green{background:var(--green-bg);color:var(--green);border:1px solid var(--green-b)}.badge-red{background:var(--red-bg);color:var(--red);border:1px solid var(--red-b)}.badge-amber{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-b)}.badge-blue{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-b)}.badge-purple{background:var(--purple-bg);color:var(--purple);border:1px solid var(--purple-b)}.badge-cyan{background:var(--cyan-bg);color:var(--cyan);border:1px solid var(--cyan-b)}.badge-gray{background:var(--bg3);color:var(--t2);border:1px solid var(--b2)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:999px;border:1px solid var(--b2);background:var(--bg2);color:var(--t1);font-family:var(--font-head);font-size:12.5px;font-weight:500;cursor:pointer;transition:all .12s;white-space:nowrap;line-height:1}.btn:hover{border-color:var(--b3);background:#f8fafc}.btn:active{transform:scale(.98)}.btn-brand{background:var(--brand);border-color:var(--brand);color:#fff;font-weight:600}.btn-brand:hover{background:var(--brand-dark);border-color:var(--brand-dark);color:#fff}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--bg2);border-color:var(--b1)}.btn-danger{border-color:var(--red-b);color:var(--red)}.btn-sm{padding:4px 9px;font-size:11px;border-radius:var(--r)}.btn-icon{padding:6px;border-radius:var(--r)}.btn svg{width:14px;height:14px;flex-shrink:0}.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}.form-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--t2);font-family:var(--font-head)}.form-hint{font-size:11px;color:var(--t3);margin-top:3px}input,select,textarea{background:var(--bg1);border:1px solid var(--b2);border-radius:var(--r-md);color:var(--t1);font-family:var(--font-head);font-size:13px;padding:8px 10px;width:100%;transition:border-color .12s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand)}input::placeholder,textarea::placeholder{color:var(--t3)}select option{background:var(--bg2);color:var(--t1)}textarea{resize:vertical;min-height:72px}.input-group{position:relative}.input-group .prefix{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--t3);font-size:12px;pointer-events:none}.input-group input{padding-left:24px}.g2{display:grid;grid-template-columns:1fr 1fr;gap:18px}.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-center{display:flex;align-items:center}.gap-6{gap:6px}.gap-8{gap:8px}.gap-10{gap:10px}.gap-12{gap:12px}.gap-14{gap:14px}.gap-16{gap:16px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-10{margin-bottom:10px}.mb-12{margin-bottom:12px}.mb-14{margin-bottom:14px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.text-right{text-align:right}.text-center{text-align:center}.text-muted{color:var(--t2)}.text-faint{color:var(--t3)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-amber{color:var(--amber)}.text-blue{color:var(--blue)}.text-brand{color:var(--brand)}.font-head{font-family:var(--font-head)}.font-mono{font-family:var(--font-mono)}.fw-500{font-weight:500}.fw-600{font-weight:600}.fw-700{font-weight:700}.fs-11{font-size:11px}.fs-12{font-size:12px}.fs-14{font-size:14px}.filter-bar{display:flex;align-items:center;gap:clamp(10px,2vw,14px);flex-wrap:wrap;background:var(--bg1);border:1px solid var(--b1);border-radius:var(--r-lg);padding:12px 16px;margin-bottom:clamp(14px,2.5vw,20px);box-shadow:0 1px 3px #0f172a08}.filter-bar label{font-size:10px;color:var(--t3);letter-spacing:.06em;text-transform:uppercase;font-weight:500;font-family:var(--font-head)}.filter-bar input{width:130px;min-width:0;flex-shrink:0}.chip-group{display:flex;gap:5px}.chip{padding:6px 12px;border-radius:999px;font-size:12px;border:1px solid var(--b2);color:var(--t2);cursor:pointer;font-family:var(--font-head);font-weight:500;background:var(--bg2);transition:all .12s ease}.chip:hover{color:var(--t1);border-color:var(--b3);background:var(--bg1)}.chip.active{background:var(--brand-subtle);color:var(--brand);border-color:#f9040052;font-weight:600}.tabs{display:flex;border-bottom:1px solid var(--b1);margin-bottom:16px;gap:2px}.tab{padding:9px 14px;font-size:12.5px;cursor:pointer;color:var(--t2);border-bottom:2px solid transparent;margin-bottom:-1px;font-family:var(--font-head);font-weight:500;transition:all .12s}.pl-section-head{font-size:9px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--t3);padding:12px 0 5px;border-bottom:1px solid var(--b1);margin-bottom:3px}.pl-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(15,23,42,.045);font-size:12.5px;font-family:var(--font-head)}.pl-row:last-child{border-bottom:none}.pl-row.indent{padding-left:14px;color:var(--t2)}.pl-row.subtotal{font-weight:500;border-top:1px solid var(--b1);margin-top:3px}.pl-row.grand{font-family:var(--font-head);font-size:16px;font-weight:700;padding:10px 0;border-top:2px solid var(--b2);margin-top:5px}.inv-paper{background:#fff;color:#111;border-radius:var(--r-lg);padding:36px;font-family:var(--font-mono);box-shadow:var(--shadow);line-height:1.5}.inv-paper.layout-modern{font-family:Helvetica Neue,sans-serif}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}.divider{height:1px;background:var(--b1);margin:14px 0}.empty{text-align:center;padding:56px 24px;color:var(--t3)}.empty .empty-icon{font-size:32px;margin-bottom:10px;opacity:.4}.empty .empty-title{font-family:var(--font-head);font-size:16px;color:var(--t2);margin-bottom:6px}.empty .empty-sub{font-size:12px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal{background:var(--bg1);border:1px solid var(--b2);border-radius:var(--r-xl);padding:24px;width:100%;max-width:580px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow)}.modal-title{font-family:var(--font-head);font-size:16px;font-weight:700;margin-bottom:16px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.swatch-row{display:flex;gap:8px;flex-wrap:wrap}.swatch{width:26px;height:26px;border-radius:6px;cursor:pointer;border:2px solid transparent;transition:all .12s}.swatch.selected{border-color:var(--t1);transform:scale(1.15)}.template-card{background:var(--bg2);border:1px solid var(--b1);border-radius:var(--r-lg);padding:16px;cursor:pointer;transition:all .15s;position:relative}.template-card:hover{border-color:var(--b2);background:var(--bg3)}.template-card.selected{border-color:var(--brand);background:var(--brand-subtle)}.template-card .tpl-badge{position:absolute;top:10px;right:10px}.template-thumb{height:90px;border-radius:var(--r);margin-bottom:10px;display:flex;align-items:center;justify-content:center;font-size:28px;opacity:.6}.template-name{font-family:var(--font-head);font-size:13px;font-weight:600;margin-bottom:3px}.template-desc{font-size:11px;color:var(--t2)}.schedule-card{background:var(--bg2);border:1px solid var(--b1);border-radius:var(--r-lg);padding:14px 16px}.schedule-card .sch-freq{font-family:var(--font-head);font-size:13px;font-weight:600}.design-panel{background:var(--bg2);border:1px solid var(--b1);border-radius:var(--r-lg);padding:16px}.dropzone{border:2px dashed var(--b2);border-radius:var(--r-lg);padding:40px 24px;text-align:center;cursor:pointer;transition:all .15s;color:var(--t3)}.dropzone:hover,.dropzone.drag-over{border-color:var(--brand);color:var(--brand);background:var(--brand-subtle)}.progress-bar{height:4px;background:var(--bg4);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--brand);border-radius:2px;transition:width .3s}.toast{position:fixed;bottom:20px;right:20px;z-index:9999;background:var(--bg2);border:1px solid var(--b2);border-radius:var(--r-lg);padding:12px 16px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow);font-size:13px;max-width:340px;animation:slide-in .2s ease}.toast.success{border-color:var(--green-b)}.toast.error{border-color:var(--red-b)}@keyframes slide-in{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}[data-tip]{position:relative}[data-tip]:hover:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--bg4);border:1px solid var(--b2);color:var(--t1);font-size:11px;padding:4px 8px;border-radius:var(--r);white-space:nowrap;pointer-events:none;z-index:100}.mobile-nav-fab,.sidebar-backdrop{display:none}@media (max-width: 960px){.g2,.g3,.g4{grid-template-columns:1fr;gap:16px}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:180;background:#0f172a59;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}.sidebar{display:flex;position:fixed;inset:0 auto 0 0;width:min(294px,88vw);z-index:190;transform:translate(calc(-100% - 12px));transition:transform .3s var(--ease-spring);box-shadow:var(--shadow);border-right:1px solid var(--b1)}.sidebar.sidebar--open{transform:translate(0)}.mobile-nav-fab{display:inline-flex;align-items:center;justify-content:center;position:fixed;z-index:120;bottom:max(22px,calc(12px + env(safe-area-inset-bottom)));left:max(18px,env(safe-area-inset-left));width:50px;height:50px;padding:0;margin:0;border:1px solid var(--b2);border-radius:999px;background:#ffffffdb;box-shadow:var(--shadow-sm);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);color:var(--t1);cursor:pointer;transition:transform .16s ease,box-shadow .16s ease}.mobile-nav-fab:active{transform:scale(.94)}.mobile-nav-fab svg{flex-shrink:0;opacity:.92}.mobile-nav-fab.mobile-nav-fab--muted{visibility:hidden;opacity:0;pointer-events:none;transform:scale(.9)}.page-body{padding-bottom:max(92px,env(safe-area-inset-bottom))}}@media (min-width: 961px){.sidebar{transform:none!important;position:relative;width:224px;min-width:224px}.sidebar-backdrop{display:none!important;pointer-events:none;visibility:hidden}.mobile-nav-fab{display:none!important}}.nav-section{font-size:9px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--t3);padding:14px 16px 4px}.nav-item{display:flex;align-items:center;gap:9px;padding:8px 16px;font-family:var(--font-head);font-size:13px;font-weight:400;color:var(--t2);cursor:pointer;border-left:2px solid transparent;transition:all .12s;width:100%;border-top:none;border-right:none;border-bottom:none;background:transparent;text-align:left}.nav-item:hover{color:var(--t1);background:var(--bg2)}.nav-item.active{color:var(--brand);border-left-color:var(--brand);background:var(--brand-subtle)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:14px 16px;border-top:1px solid var(--b1);cursor:pointer;transition:background .12s}.sidebar-user:hover{background:var(--bg2)}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--brand);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.user-menu{position:absolute;bottom:56px;left:0;right:0;background:var(--bg2);border:1px solid var(--b2);border-radius:var(--r-md);margin:0 12px 4px;overflow:hidden;z-index:100;box-shadow:var(--shadow)}.user-menu-item{display:block;width:100%;padding:10px 14px;text-align:left;font-family:var(--font-head);font-size:12px;font-weight:500;color:var(--t2);background:transparent;border:none;cursor:pointer;transition:background .12s}.user-menu-item:hover{background:var(--bg3);color:var(--t1)}.kpi-tile{background:var(--bg2);border:1px solid var(--b1);border-radius:var(--r-lg);padding:14px 16px;position:relative;overflow:hidden}.kpi-tile:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--kpi-color, var(--brand))}.kpi-value{font-family:var(--font-head);font-size:21px;font-weight:700;letter-spacing:-.02em}.tab-bar{display:flex;border-bottom:1px solid var(--b1)}.tab{padding:9px 16px;font-size:12.5px;cursor:pointer;color:var(--t2);border-bottom:2px solid transparent;margin-bottom:-1px;font-family:var(--font-head);font-weight:500;transition:all .12s;background:none;border-top:none;border-left:none;border-right:none}.tab:hover{color:var(--t1)}.tab.active{color:var(--brand);border-bottom-color:var(--brand)}.btn-danger{border-color:var(--red);color:var(--red)}.btn-danger:hover{background:var(--red-bg)}
