*{box-sizing:border-box}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:#eef2f7;color:#111827}a{text-decoration:none;color:inherit}.app{display:flex;min-height:100vh}.sidebar{width:260px;background:#111827;color:#fff;padding:18px;position:fixed;top:0;bottom:0;left:0}.brand{font-size:21px;font-weight:900;padding:14px;background:#1f2937;border-radius:14px;text-align:center;margin-bottom:14px}.userbox{background:#1f2937;border-radius:14px;padding:12px;margin-bottom:14px}.userbox span{display:block;color:#cbd5e1;font-size:13px;margin-top:4px}.sidebar a{display:block;padding:12px 14px;border-radius:12px;color:#d1d5db;margin:5px 0;font-weight:700}.sidebar a.active,.sidebar a:hover{background:#2563eb;color:#fff}.main{margin-left:260px;padding:22px;width:calc(100% - 260px)}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.topbar h1{margin:0;font-size:25px}.topbar p{margin:4px 0 0;color:#64748b}.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px}.card,.panel{background:#fff;border-radius:18px;padding:18px;box-shadow:0 8px 24px rgba(15,23,42,.08);margin-bottom:16px}.card span{display:block;color:#64748b;font-size:13px;margin-bottom:8px}.card b{font-size:26px}.panel h2{margin:0 0 14px}.btn{display:inline-block;border:0;border-radius:12px;padding:11px 14px;background:#2563eb;color:#fff;font-weight:800;cursor:pointer;font-size:14px;text-align:center}.btn.green{background:#16a34a}.btn.orange{background:#f97316}.btn.red{background:#dc2626}.btn.small{padding:8px 10px}.btn.full{width:100%;padding:14px;margin-top:12px}input,select,textarea{width:100%;border:1px solid #dbe3ef;border-radius:12px;padding:10px;font-size:14px;background:#fff}label{display:block;font-size:12px;color:#64748b;font-weight:800;margin:8px 0 5px}.filter{display:grid;grid-template-columns:repeat(4,minmax(140px,1fr));gap:10px;align-items:end}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse;font-size:14px}th,td{padding:11px 9px;border-bottom:1px solid #e5e7eb;text-align:left;vertical-align:middle}th{background:#f8fafc;color:#334155;white-space:nowrap}.alert{padding:12px;border-radius:14px;margin-bottom:14px;font-weight:700}.alert.ok{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.alert.warn{background:#fff7ed;color:#9a3412;border:1px solid #fed7aa}.alert.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:14px}.product-card,.mobile-card{border:1px solid #e5e7eb;border-radius:16px;padding:13px;margin-bottom:12px;background:#fbfdff}.pc-head,.card-head{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:10px}.pc-head span,.badge{background:#dbeafe;color:#1d4ed8;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:800}.calc{background:#f1f5f9;border-radius:12px;padding:9px;margin:8px 0;font-size:13px;color:#475569}.inline{display:flex;gap:8px;margin-top:10px}hr{border:0;border-top:1px solid #e5e7eb;margin:18px 0}.mobile-nav{display:none}.login-body{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1d4ed8,#0f172a);padding:16px}.login-box{width:100%;max-width:390px;background:#fff;border-radius:22px;padding:24px;box-shadow:0 20px 60px rgba(0,0,0,.22)}.login-box h1{margin:0 0 8px}.login-box p{color:#64748b;margin:0 0 16px}.hint{margin-top:12px;color:#64748b;font-size:13px;text-align:center}@media(max-width:900px){body{background:#f8fafc;padding-bottom:74px}.app{display:block}.sidebar{display:none}.main{margin:0;width:100%;padding:0 12px 18px}.topbar{position:sticky;top:0;z-index:10;background:linear-gradient(135deg,#1d4ed8,#0f172a);color:#fff;margin:0 -12px 14px;padding:18px 14px;border-bottom-left-radius:22px;border-bottom-right-radius:22px}.topbar p{color:#dbeafe}.cards{grid-template-columns:repeat(2,1fr);gap:10px}.card,.panel{border-radius:16px;padding:14px}.filter{grid-template-columns:1fr 1fr}.product-grid{grid-template-columns:1fr}.table-wrap{overflow:visible}table,thead,tbody,tr,th,td{display:block;width:100%}thead{display:none}tr{border:1px solid #e5e7eb;border-radius:14px;margin-bottom:10px;padding:8px;background:#fff}td{border:0;padding:7px 4px}td:before{content:attr(data-label);display:block;font-size:11px;color:#64748b;font-weight:800;margin-bottom:3px}.mobile-card table{display:table}.mobile-card thead{display:table-header-group}.mobile-card tbody{display:table-row-group}.mobile-card tr{display:table-row;border:0}.mobile-card th,.mobile-card td{display:table-cell;border:1px solid #e5e7eb}.mobile-card td:before{display:none}.mobile-nav{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid #e5e7eb;display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:8px;z-index:50}.mobile-nav a{text-align:center;padding:10px 4px;border-radius:12px;color:#64748b;font-size:12px;font-weight:900}.mobile-nav a.active{background:#dbeafe;color:#1d4ed8}}@media(max-width:520px){.filter{grid-template-columns:1fr}.cards{grid-template-columns:1fr 1fr}.card b{font-size:22px}}
