/* Premium Bento Styling (profile + calendar chips) */
:root{
  --bg:#F5F5F7;--surface:#FFFFFF;--text:#111827;--muted:#6B7280;
  --line:#E5E7EB;--shadow:0 18px 60px rgba(0,0,0,.08);
  --primary:#0B8A2A;--primary-ink:#fff;
  --chip-green:#DCFCE7;--chip-blue:#E0F2FE;--chip-brown:#EDE7DB;
  --ink-green:#166534;--ink-blue:#075985;--ink-brown:#92400E
}
*{box-sizing:border-box} html,body{height:100%}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text)}
.kg-container{max-width:1180px;margin:0 auto;padding:0 22px}
.green{color:#0B8A2A} .small{font-size:.85rem}
/* Navbar */
.kg-navbar{position:sticky;top:0;background:var(--surface);border-bottom:1px solid var(--line);z-index:20;backdrop-filter:saturate(180%) blur(10px)}
.kg-navbar .kg-container{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{font-weight:700;letter-spacing:.2px}
.nav-links a{margin-left:16px;text-decoration:none;color:#111;padding:10px 12px;border-radius:12px;transition:background .2s}
.nav-links a:hover{background:#F3F4F6}
/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 16px;border-radius:14px;border:1px solid transparent;cursor:pointer;font-weight:600}
.btn-primary{background:var(--primary);color:var(--primary-ink);box-shadow:0 6px 18px rgba(11,138,42,.25)}
.btn-secondary{background:#F3F4F6;color:#111;border-color:#E5E7EB}
/* Layout / Bento */
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.bento .bento-box{background:var(--surface);border:1px solid #EEF2F7;border-radius:24px;box-shadow:var(--shadow);padding:22px}
.bento .span-2{grid-column:span 2}
@media (max-width:980px){.bento{grid-template-columns:1fr}.bento .span-2{grid-column:span 1}}
/* Forms */
.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.form-control,.form-select{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:14px;background:#FBFBFC;outline:none;transition:border-color .2s, box-shadow .2s}
.form-control:focus,.form-select:focus{border-color:#9EE6B3;box-shadow:0 0 0 4px rgba(11,138,42,.12);background:#fff}
label{font-weight:600;color:#374151}
.alert{padding:12px 14px;border-radius:12px;border:1px solid #E5E7EB;background:#F9FAFB}
.alert-danger{border-color:#fecaca;background:#fff1f2;color:#7f1d1d}
.alert-success{border-color:#bbf7d0;background:#f0fdf4;color:#14532d}
/* Weather */
.weather-card .today{font-size:1rem;margin:8px 0}
.forecast-row{display:flex;gap:12px;overflow-x:auto;padding:4px 0}
.forecast-item{min-width:100px;background:#FAFAFB;border:1px solid #EEE;border-radius:14px;padding:10px;text-align:center}
/* Tasks */
.task-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.task-list.compact .task-row{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid #EEF2F7;border-radius:14px;background:#FAFAFB}
.task-title{display:flex;flex-direction:column}
.task-title .task-date{font-style:normal;color:var(--muted);font-size:.85rem}
.badge{background:#E3F9E5;color:#0B8A2A;border:1px solid #C7F3CC;border-radius:10px;padding:3px 8px;font-size:.75rem;margin-left:auto}
/* Calendar */
.calendar{width:100%;border-collapse:separate;border-spacing:0}
.calendar th,.calendar td{text-align:center;padding:10px;border-bottom:1px solid var(--line)}
.calendar td{height:82px;vertical-align:top;background:#fff}
.cal-slot{margin-top:6px;display:flex;flex-direction:column;gap:4px}
.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:10px;font-size:12px;line-height:1;font-weight:600;width:fit-content}
.chip.water{background:#E0F2FE;color:#075985}
.chip.mow{background:#DCFCE7;color:#166534}
.chip.fert{background:#EDE7DB;color:#92400E}
/* Skeleton */
.skeleton{background:linear-gradient(90deg,#eee,#f5f5f7,#eee);background-size:200% 100%;animation:s 1.2s infinite}
.skeleton-text{height:16px;border-radius:6px}
.skeleton-row{height:52px;border-radius:16px;margin-top:8px}
@keyframes s{0%{background-position:200% 0}100%{background-position:-200% 0}}