/* assets/css/main.css */
@import url('https://fonts.googleapis.com/css2?family=Sarabun:wght@300;400;500;600;700;800&family=Prompt:wght@600;700;800;900&display=swap');

:root {
  --green-deep:  #1a3c2a;
  --green-mid:   #2d6a4f;
  --green-bright:#52b788;
  --green-light: #95d5b2;
  --green-pale:  #d8f3dc;
  --amber:       #e9c46a;
  --amber-dark:  #c9932e;
  --blue:        #4a9edd;
  --red:         #e63946;
  --text-dark:   #1a2e1f;
  --text-mid:    #3d5a46;
  --text-soft:   #7a9e85;
  --bg:          #f4f9f5;
  --white:       #fff;
  --shadow:      0 4px 20px rgba(26,60,42,.10);
  --radius:      12px;
  --sidebar-w:   240px;
}

* { margin:0; padding:0; box-sizing:border-box; }

body { font-family:'Sarabun',sans-serif; background:var(--bg); color:var(--text-dark); min-height:100vh; }

/* ─── SIDEBAR ─────────────── */
.sidebar {
  width:var(--sidebar-w); background:var(--green-deep);
  position:fixed; top:0; left:0; bottom:0; z-index:100;
  display:flex; flex-direction:column; overflow:hidden;
}
.role-admin .sidebar { background:linear-gradient(180deg,#0f1f2e,#1a2d42); }

.sidebar-logo { padding:24px 20px 18px; border-bottom:1px solid rgba(255,255,255,.07); }
.logo-icon { width:42px; height:42px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:20px; margin-bottom:8px; background:linear-gradient(135deg,var(--green-bright),var(--green-light)); }
.logo-title { font-family:'Prompt',sans-serif; font-size:13px; font-weight:700; color:#fff; line-height:1.3; }
.logo-sub { font-size:10px; color:var(--green-light); margin-top:2px; }

.sidebar-nav { padding:12px 10px; flex:1; overflow-y:auto; }
.nav-section { font-size:9px; font-weight:700; letter-spacing:1.5px; color:rgba(255,255,255,.3); text-transform:uppercase; padding:0 10px; margin:14px 0 4px; }
.nav-item {
  display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:12px; cursor:pointer;
  color:rgba(255,255,255,.68); font-size:13.5px; font-weight:500; text-decoration:none; margin-bottom:4px;
  transition:all .18s ease; position:relative; border:1px solid transparent;
}
.nav-item:hover {
  background:rgba(255,255,255,.08); color:#fff; border-color:rgba(255,255,255,.06);
  transform:translateX(2px);
}
.nav-item.active {
  background:linear-gradient(135deg,rgba(82,183,136,.24),rgba(82,183,136,.10)); color:#f4fff8; font-weight:600;
  border-color:rgba(149,213,178,.18); box-shadow:0 8px 20px rgba(0,0,0,.12);
}
.nav-item.active::before { content:''; position:absolute; left:0; top:25%; bottom:25%; width:3px; background:var(--green-bright); border-radius:0 2px 2px 0; }
.nav-icon {
  font-size:15px; width:30px; height:30px; text-align:center; flex-shrink:0;
  display:inline-flex; align-items:center; justify-content:center; border-radius:10px;
  background:rgba(255,255,255,.08); color:#fff; box-shadow:inset 0 0 0 1px rgba(255,255,255,.05);
}
.nav-item:hover .nav-icon { background:rgba(255,255,255,.14); }
.nav-item.active .nav-icon {
  background:linear-gradient(135deg,rgba(149,213,178,.28),rgba(82,183,136,.18));
  color:#fff;
}
.nav-badge { margin-left:auto; background:var(--amber); color:#5c3d1e; font-size:10px; font-weight:700; padding:1px 6px; border-radius:10px; }

.sidebar-user { padding:12px 14px; border-top:1px solid rgba(255,255,255,.07); display:flex; align-items:center; gap:9px; }
.user-avatar { width:32px; height:32px; border-radius:9px; background:linear-gradient(135deg,var(--green-bright),var(--amber)); display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:700; color:#fff; flex-shrink:0; }
.user-name { font-size:12px; font-weight:600; color:#fff; }
.user-role { font-size:10px; color:var(--green-light); }

/* ─── TOPBAR ───────────────── */
.topbar { height:58px; background:var(--white); border-bottom:1px solid #e8f0ea; display:flex; align-items:center; padding:0 24px; gap:12px; position:sticky; top:0; z-index:50; box-shadow:0 2px 10px rgba(26,60,42,.06); margin-left:var(--sidebar-w); }
.page-title { font-family:'Prompt',sans-serif; font-size:15px; font-weight:700; color:var(--text-dark); }
.topbar-actions { margin-left:auto; display:flex; align-items:center; gap:10px; }
.live-pill { display:flex; align-items:center; gap:6px; background:var(--green-pale); border:1px solid var(--green-light); border-radius:20px; padding:4px 12px; font-size:12px; font-weight:600; color:var(--green-mid); }
.live-dot { width:6px; height:6px; background:var(--green-bright); border-radius:50%; animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.4)} }

/* ─── MAIN CONTENT ─────────── */
.main-content { margin-left:var(--sidebar-w); padding:24px; min-height:calc(100vh - 58px); }

/* ─── LOGIN ────────────────── */
.login-wrap { min-height:100vh; display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,#0d2b1a,#1a4c2e,#2d6a4f); }
.login-box { background:#fff; border-radius:22px; padding:36px; width:360px; box-shadow:0 40px 80px rgba(0,0,0,.35); }
.login-logo { text-align:center; margin-bottom:24px; }
.login-icon { font-size:44px; margin-bottom:6px; }
.login-title { font-family:'Prompt',sans-serif; font-size:19px; font-weight:800; color:var(--green-deep); }
.login-sub { font-size:12px; color:var(--text-soft); }
.login-footer { text-align:center; margin-top:14px; font-size:12px; color:var(--text-soft); }
.login-footer a { color:var(--green-mid); font-weight:600; }
.btn-full { width:100%; justify-content:center; padding:11px; }

/* ─── CARDS ────────────────── */
.card { background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow); border:1px solid rgba(82,183,136,.08); overflow:hidden; }
.card-header { padding:16px 20px; border-bottom:1px solid #f0f7f2; display:flex; align-items:center; justify-content:space-between; }
.card-title { font-family:'Prompt',sans-serif; font-size:14px; font-weight:700; color:var(--text-dark); display:flex; align-items:center; gap:6px; }
.card-form { padding:24px; }

/* ─── STATS GRID ───────────── */
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.stat-card { background:var(--white); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow); border:1px solid rgba(82,183,136,.08); border-left:4px solid var(--green-bright); }
.stat-icon { width:40px; height:40px; border-radius:11px; display:flex; align-items:center; justify-content:center; font-size:18px; margin-bottom:10px; }
.icon-green { background:#d8f3dc; }
.icon-amber { background:#fef3cd; }
.icon-blue  { background:#e8f4fd; }
.icon-red   { background:#fde8ea; }
.stat-value { font-family:'Prompt',sans-serif; font-size:22px; font-weight:700; color:var(--text-dark); line-height:1; margin-bottom:3px; }
.stat-label { font-size:11.5px; color:var(--text-soft); font-weight:500; }
.stat-change { font-size:11px; font-weight:600; margin-top:6px; }

/* ─── PRICE BOARD ──────────── */
.price-board { background:linear-gradient(135deg,var(--green-deep),#2a4d38); border-radius:18px; padding:22px 26px; box-shadow:0 12px 40px rgba(26,60,42,.2); position:relative; overflow:hidden; }
.price-board::after { content:'🌿'; position:absolute; right:-10px; bottom:-20px; font-size:130px; opacity:.05; pointer-events:none; }
.price-board-header { font-size:12px; font-weight:600; color:var(--green-light); margin-bottom:14px; display:flex; align-items:center; gap:8px; }
.live-tag { background:rgba(82,183,136,.2); border:1px solid rgba(82,183,136,.4); color:var(--green-bright); font-size:9px; font-weight:700; padding:1px 7px; border-radius:4px; letter-spacing:1px; }
.prices-row { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.price-item { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.1); border-radius:12px; padding:14px 16px; }
.price-type { font-size:11px; color:rgba(255,255,255,.6); margin-bottom:4px; }
.price-num { font-family:'Prompt',sans-serif; font-size:26px; font-weight:700; color:#fff; line-height:1; }
.price-unit { font-size:10px; color:var(--green-light); margin-top:2px; }

/* ─── FORMS ────────────────── */
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-group { display:flex; flex-direction:column; gap:5px; }
.col-full { grid-column:1/-1; }
.form-label { font-size:12px; font-weight:600; color:var(--text-mid); }
.form-input, .form-select, .form-textarea {
  padding:9px 13px; border:1.5px solid #ddeee3; border-radius:9px;
  font-family:'Sarabun',sans-serif; font-size:13.5px; color:var(--text-dark);
  background:var(--white); transition:border .2s,box-shadow .2s; outline:none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color:var(--green-bright); box-shadow:0 0 0 3px rgba(82,183,136,.15);
}
.form-textarea { min-height:80px; resize:vertical; }
.form-actions { display:flex; gap:10px; flex-wrap:wrap; margin-top:4px; }

/* ─── BUTTONS ──────────────── */
.btn { padding:8px 16px; border-radius:8px; border:none; cursor:pointer; font-family:'Sarabun',sans-serif; font-size:13px; font-weight:600; transition:all .2s; display:inline-flex; align-items:center; justify-content:center; gap:5px; text-decoration:none; }
.btn-primary { background:linear-gradient(135deg,var(--green-mid),var(--green-bright)); color:#fff; box-shadow:0 3px 10px rgba(45,106,79,.3); }
.btn-primary:hover { transform:translateY(-1px); box-shadow:0 5px 16px rgba(45,106,79,.35); }
.btn-amber { background:linear-gradient(135deg,var(--amber-dark),var(--amber)); color:#fff; box-shadow:0 3px 10px rgba(201,147,46,.3); }
.btn-outline { background:transparent; border:1.5px solid var(--green-bright); color:var(--green-mid); }
.btn-outline:hover { background:var(--green-pale); }
.btn-danger { background:#fde8ea; color:var(--red); border:1px solid #f5c6cb; }
.btn-sm { padding:4px 10px; font-size:11.5px; border-radius:6px; }
.btn-notice {
  background:linear-gradient(135deg,#fff4bf,#f7d154);
  color:#5c4300;
  border:1px solid #f0cb47;
  box-shadow:0 4px 14px rgba(201,147,46,.25);
}
.btn-notice:hover {
  transform:translateY(-1px);
  box-shadow:0 6px 16px rgba(201,147,46,.35);
}
.notice-chip {
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:#fff8dc;
  color:#7a5a00;
  border:1px solid #f2d675;
  border-radius:999px;
  padding:4px 10px;
  font-size:11px;
  font-weight:700;
}

/* ─── TABLE ────────────────── */
.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; font-size:13px; }
th { padding:9px 14px; text-align:left; font-size:10.5px; font-weight:700; color:var(--text-soft); letter-spacing:.5px; text-transform:uppercase; background:#f8fbf9; border-bottom:1px solid #eef5f0; white-space:nowrap; }
td { padding:11px 14px; border-bottom:1px solid #f5f9f6; vertical-align:middle; }
tr:last-child td { border-bottom:none; }
tr:hover td { background:#fafdf9; }

/* ─── BADGES ───────────────── */
.badge { padding:2px 9px; border-radius:20px; font-size:11px; font-weight:700; display:inline-block; white-space:nowrap; }
.badge-pending   { background:#fff3cd; color:#856404; }
.badge-received  { background:#cff4fc; color:#0c5460; }
.badge-inspected { background:#d1ecf1; color:#0c5460; }
.badge-completed { background:#d1fae5; color:#065f46; }
.badge-paid      { background:var(--green-pale); color:var(--green-mid); }
.badge-cancelled { background:#f0f0f0; color:#666; }

/* ─── ALERTS ───────────────── */
.alert { padding:11px 14px; border-radius:9px; font-size:13px; margin-bottom:14px; }
.alert-error   { background:#fde8ea; color:#c62828; border:1px solid #f5c6cb; }
.alert-success { background:var(--green-pale); color:var(--green-mid); border:1px solid var(--green-light); }
.alert-warning { background:#fff8e1; color:#7c5e00; border:1px solid #ffe082; }

/* ─── MISC ─────────────────── */
.main-grid { display:grid; grid-template-columns:1fr 340px; gap:18px; }
.banner-green { background:linear-gradient(135deg,var(--green-deep),var(--green-mid)); border-radius:18px; padding:22px 26px; display:flex; align-items:center; justify-content:space-between; box-shadow:0 8px 32px rgba(26,60,42,.15); }
.banner-title { font-family:'Prompt',sans-serif; font-size:18px; font-weight:800; color:#fff; }
.banner-sub { font-size:12px; color:var(--green-light); margin-top:3px; }
.calc-box { background:linear-gradient(135deg,var(--green-pale),#eafaf0); border:1.5px solid var(--green-light); border-radius:12px; padding:16px 18px; display:flex; align-items:center; justify-content:space-between; }
.calc-label { font-size:12px; font-weight:600; color:var(--text-mid); }
.calc-formula { font-size:11.5px; color:var(--text-soft); margin-top:2px; }
.calc-result { font-family:'Prompt',sans-serif; font-size:22px; font-weight:800; color:var(--green-mid); }
.order-info-box { background:#f8fbf9; border:1px solid #ddeee3; border-radius:10px; padding:14px 16px; display:flex; flex-direction:column; gap:6px; font-size:13px; }
.receipt-preview { padding:16px 18px; }
.receipt-header { text-align:center; margin-bottom:12px; padding-bottom:10px; border-bottom:1px dashed var(--green-light); }
.receipt-shop { font-family:'Prompt',sans-serif; font-size:15px; font-weight:700; color:var(--green-deep); }
.receipt-date { font-size:10px; color:var(--text-soft); margin-top:2px; }
.receipt-row { display:flex; justify-content:space-between; margin-bottom:5px; font-size:12.5px; }
.receipt-total { display:flex; justify-content:space-between; margin-top:10px; padding-top:10px; border-top:2px solid var(--green-bright); font-family:'Prompt',sans-serif; font-size:15px; font-weight:700; color:var(--green-mid); }
.farmer-cell { display:flex; align-items:center; gap:8px; }
.avatar-sm { width:28px; height:28px; border-radius:7px; background:linear-gradient(135deg,var(--green-bright),var(--green-mid)); display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; color:#fff; flex-shrink:0; }

/* ─── FOOTER ───────────────── */
.site-footer {
  margin-left:var(--sidebar-w);
  width:calc(100% - var(--sidebar-w));
  background:linear-gradient(180deg,#0d1f15,#11281b);
  color:#d8f3dc;
  padding:20px 24px 18px;
  border-top:1px solid rgba(255,255,255,.06);
}
.site-footer-inner {
  width:min(1180px, 100%);
  margin:0 auto;
  display:flex; align-items:flex-start; justify-content:space-between; gap:20px; flex-wrap:wrap;
}
.site-footer-title {
  font-family:'Prompt',sans-serif; font-size:14px; font-weight:700; color:#fff;
}
.site-footer-text {
  font-size:12px; color:rgba(216,243,220,.75); margin-top:4px; line-height:1.7;
}
.site-footer-links {
  display:flex; gap:12px; flex-wrap:wrap; align-items:center;
}
.site-footer-links a {
  color:#d8f3dc; text-decoration:none; font-size:12px; opacity:.88;
}
.site-footer-links a:hover { opacity:1; text-decoration:underline; }
.site-footer-copy {
  width:min(1180px, 100%);
  margin-left:auto;
  margin-right:auto;
  margin-top:12px; padding-top:12px; border-top:1px solid rgba(255,255,255,.08);
  font-size:11px; color:rgba(216,243,220,.65);
}
.role-admin .site-footer {
  background:linear-gradient(180deg,#0a1520,#0f1d2a);
}
.role- .site-footer,
body:not([class*="role-"]) .site-footer,
.login-wrap + .site-footer,
.pub-shell + .site-footer {
  margin-left:0;
  width:100%;
}

/* ─── UTILITIES ────────────── */
.mb-4 { margin-bottom:20px; }
.text-center { text-align:center; }
.text-muted { color:var(--text-soft); }
.text-small { font-size:11.5px; }
.text-green { color:var(--green-mid); }
.text-red { color:var(--red); }
.fw-600 { font-weight:600; }
.fw-700 { font-weight:700; }
.mono { font-family:monospace; }
.up   { color:#2d9e5f; }
.down { color:var(--red); }

::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-thumb { background:#c3e6cb; border-radius:10px; }

/* ─── MOBILE RESPONSIVE ────── */
@media (max-width:860px) {
  body { font-size:14px; }
  .stats-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
  .main-grid  { grid-template-columns:1fr; gap:12px; }
  .main-content { padding:12px; }
  .topbar { padding:8px 12px; }
  .site-footer { margin-left:0; padding:16px 12px 14px; }
  .price-board { padding:16px; }
  .prices-row { gap:10px; }
  .price-num  { font-size:1.6rem !important; }
  .card { border-radius:10px; }
  .table-wrap table { min-width:540px; }
  .form-grid  { grid-template-columns:1fr; }
  .col-full   { grid-column:auto; }
  .btn-full   { font-size:14px; padding:10px; }
}

@media (max-width:480px) {
  .stats-grid { grid-template-columns:1fr 1fr; gap:8px; }
  .stat-card  { padding:12px; }
  .stat-value { font-size:1.3rem; }
  .banner-green { flex-direction:column; align-items:flex-start; gap:12px; }
  h1,h2 { font-size:1.1rem; }
}

/* ─── PRINT ───────────────── */
@media print {
  .sidebar, .topbar, .no-print, .btn,
  nav, .stats-grid, form { display:none !important; }
  .main-content { margin:0 !important; padding:0 !important; }
  body  { background:white !important; font-size:12px; }
  .card { box-shadow:none !important; border:1px solid #ddd !important; }
  a     { text-decoration:none !important; color:black !important; }
}
