
:root{
  --bg:#f5f3ef;--card:#ffffff;--text:#2e241d;--muted:#7b6d63;--line:#eadfd5;
  --orange:#f4a261;--orange-2:#ffbf86;--coffee:#8b5e3c;--coffee-2:#b7855a;
  --soft:#f8ede3;--success:#27ae60;--warning:#f1c40f;--danger:#e74c3c;--info:#3498db;
  --shadow:0 12px 32px rgba(86,58,34,0.08);--radius:22px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,Arial,sans-serif;background:linear-gradient(180deg,#fbfaf8,#f4efe8 40%,#f7f2ed);color:var(--text)}
a{text-decoration:none;color:inherit} body{min-height:100vh}
.app{max-width:980px;margin:0 auto;padding:18px 16px 96px}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;position:sticky;top:0;padding:10px 0 6px;z-index:9;backdrop-filter:blur(8px);background:linear-gradient(180deg,rgba(247,242,237,.92),rgba(247,242,237,.76),rgba(247,242,237,0))}
.brand{display:flex;gap:12px;align-items:center}
.logo{width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,var(--orange),var(--coffee));display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--shadow)}
.title h1{font-size:18px;line-height:1.1;margin:0;font-weight:800}
.title p{font-size:12px;color:var(--muted);margin:2px 0 0}
.role-chip,.pill,.mini-pill{background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 12px;font-size:12px;color:var(--muted);box-shadow:var(--shadow)}
.grid{display:grid;gap:14px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{background:var(--card);border:1px solid rgba(139,94,60,0.08);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;animation:fadeIn .45s ease, slideUp .45s ease}
.card h3,.section-title{margin:0 0 12px;font-size:15px}
.muted{color:var(--muted)}
.kpi{padding:16px;border-radius:20px;color:#fff;position:relative;overflow:hidden;min-height:112px}
.kpi:before{content:"";position:absolute;right:-18px;top:-18px;width:88px;height:88px;border-radius:50%;background:rgba(255,255,255,.12)}
.kpi .label{font-size:12px;opacity:.9}.kpi .value{font-size:28px;font-weight:800;margin-top:10px}.kpi .sub{font-size:12px;opacity:.9;margin-top:8px}
.orange{background:linear-gradient(135deg,#f4a261,#ffb677)}.coffee{background:linear-gradient(135deg,#8b5e3c,#b7855a)}.soft-info{background:linear-gradient(135deg,#7db6ff,#5d8ee6)}.soft-green{background:linear-gradient(135deg,#4cc98b,#2f9d64)}
.notice{background:linear-gradient(135deg,#fff8ef,#fef3e2);border:1px solid #f2d3b4;color:#7a4d24;padding:12px 14px;border-radius:16px;font-size:13px}
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.input,.select,textarea{width:100%;border:1px solid var(--line);background:#fff;border-radius:16px;padding:13px 14px;font-size:14px;outline:none;color:var(--text)}
textarea{min-height:100px;resize:vertical}
button,.btn{border:none;border-radius:16px;padding:13px 16px;font-size:14px;font-weight:700;cursor:pointer;background:linear-gradient(135deg,var(--orange),var(--coffee));color:#fff;box-shadow:var(--shadow);transition:transform .12s ease, filter .2s ease, box-shadow .2s ease}
button:hover,.btn:hover{filter:brightness(1.03)} button:active,.btn:active{transform:scale(.985)}
.btn.secondary{background:#fff;color:var(--coffee);border:1px solid var(--line)} .btn.warn{background:linear-gradient(135deg,#f1c40f,#e67e22)} .btn.danger{background:linear-gradient(135deg,#ff6b6b,#d64545)}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.list{display:grid;gap:10px}
.item{border:1px solid var(--line);border-radius:18px;padding:14px;background:linear-gradient(180deg,#fff,#fdfaf7)}
.item-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.item h4{margin:0 0 6px;font-size:14px}
.meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.mini-pill{padding:6px 10px;box-shadow:none}
.badge{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;font-size:12px;font-weight:700}
.badge.green{background:#eaf8ef;color:#1f7f4c}.badge.yellow{background:#fff8dd;color:#907300}.badge.blue{background:#eaf4ff;color:#2667a9}.badge.red{background:#ffeceb;color:#b43e36}.badge.gray{background:#f0efed;color:#6f655e}
.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px 10px;border-bottom:1px solid var(--line);text-align:left;font-size:13px;vertical-align:top}.table th{color:var(--muted);font-weight:700}
.bottom-nav{position:fixed;left:50%;transform:translateX(-50%);bottom:14px;width:min(960px,calc(100% - 18px));background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border:1px solid rgba(139,94,60,.12);box-shadow:0 18px 42px rgba(73,49,28,.12);border-radius:24px;padding:10px 6px;display:grid;grid-template-columns:repeat(7,1fr);gap:4px;z-index:20}
.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:9px 4px;border-radius:18px;color:var(--muted);font-size:11px;font-weight:700}
.nav-item.active{background:linear-gradient(135deg,#fff4e9,#f7e3cf);color:var(--coffee)}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:18px}
.login-card{width:min(460px,100%);padding:22px}
.hero{background:linear-gradient(135deg,#fff2e5,#f6e4d7 55%,#efe2d6);border:1px solid #efd8c6;border-radius:24px;padding:18px;position:relative;overflow:hidden}
.hero:after{content:"";position:absolute;right:-20px;bottom:-20px;width:120px;height:120px;border-radius:50%;background:rgba(139,94,60,.10)}
.shimmer{position:relative;overflow:hidden;background:linear-gradient(90deg,#f1ece7 25%,#f9f6f3 45%,#f1ece7 65%);background-size:300% 100%;animation:shimmer 1.4s infinite;border-radius:18px;height:90px}
.empty{padding:18px;text-align:center;color:var(--muted);border:1px dashed var(--line);border-radius:18px;background:#fff}
.chart-card canvas{width:100%!important;height:280px!important}.footer-note{font-size:12px;color:var(--muted);text-align:center;margin-top:14px}
@keyframes fadeIn{from{opacity:0}to{opacity:1}} @keyframes slideUp{from{transform:translateY(8px)}to{transform:translateY(0)}} @keyframes shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}
@media (max-width:820px){.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:640px){.app{padding:14px 12px 98px}.grid-2,.grid-3,.grid-4,.form-grid{grid-template-columns:1fr}.topbar{padding-top:2px}.bottom-nav{gap:0;padding:8px 4px}.nav-item{font-size:10px}.kpi .value{font-size:24px}.table{display:block;overflow:auto;white-space:nowrap}}
