/* ===========================================================
   MicheByte Farm Manager — flat forest-green theme (NO gradients)
   =========================================================== */
:root{
  --green:#1B5E20; --green-2:#2E7D32; --green-3:#388E3C;
  --amber:#F9A825; --amber-2:#FFB300;
  --bg:#F4F6F4; --surface:#FFFFFF; --text:#1C1C1C; --muted:#6B6B6B;
  --divider:#E6E6E6; --success:#2E7D32; --warning:#F9A825;
  --danger:#C62828; --info:#1565C0;
  --radius:16px; --radius-sm:12px;
  --shadow:0 2px 8px rgba(0,0,0,.08);
  --shadow-lg:0 -6px 24px rgba(0,0,0,.16);
  --tap:44px;
  --font-head:'Poppins',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
}
[data-theme="dark"]{
  --bg:#10140F; --surface:#1A2018; --text:#ECEFEA; --muted:#9AA59A;
  --divider:#2A322A; --green:#2E7D32; --green-2:#388E3C;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body); background:var(--bg); color:var(--text);
  -webkit-font-smoothing:antialiased; font-size:15px; line-height:1.5;
  overscroll-behavior-y:contain;
}
h1,h2,h3,h4{font-family:var(--font-head); margin:0 0 .4em; line-height:1.2}
a{color:var(--green-2); text-decoration:none}
.muted{color:var(--muted)} .small{font-size:12.5px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  min-height:var(--tap); padding:0 18px; border:none; border-radius:var(--radius-sm);
  font-family:var(--font-head); font-weight:600; font-size:14px; cursor:pointer;
  background:var(--green); color:#fff; transition:filter .15s, transform .05s;
}
.btn:active{transform:scale(.97)}
.btn:hover{filter:brightness(1.05)}
.btn-primary{background:var(--green)}
.btn-amber{background:var(--amber); color:#1C1C1C}
.btn-outline{background:transparent; color:var(--green-2); border:1.5px solid var(--green-2)}
.btn-danger{background:var(--danger)}
.btn-block{width:100%}
.btn-sm{min-height:36px; padding:0 14px; font-size:13px}
.link{background:none;border:none;color:var(--green-2);cursor:pointer;font-size:13px}

/* ---------- forms ---------- */
.form label{display:block; margin-bottom:14px; font-size:13px; font-weight:500; color:var(--muted)}
.form input,.form select,.form textarea,.search{
  width:100%; margin-top:5px; padding:11px 12px; min-height:var(--tap);
  border:1.5px solid var(--divider); border-radius:var(--radius-sm);
  background:var(--surface); color:var(--text); font-size:15px; font-family:var(--font-body);
}
.form textarea{min-height:80px; resize:vertical}
.form input:focus,.form select:focus,.form textarea:focus{
  outline:none; border-color:var(--green-2); box-shadow:0 0 0 3px rgba(46,125,50,.15);
}
.row2{display:grid; grid-template-columns:1fr 1fr; gap:12px}
input[type=checkbox]{width:auto; min-height:auto; transform:scale(1.3); margin-right:8px}

/* ---------- alerts ---------- */
.alert{padding:11px 14px; border-radius:var(--radius-sm); margin-bottom:14px; font-size:14px}
.alert-danger{background:#FBE9E7; color:var(--danger)}
.alert-success{background:#E8F5E9; color:var(--success)}
[data-theme="dark"] .alert-danger{background:#3a1a1a}
[data-theme="dark"] .alert-success{background:#16301a}

/* ---------- auth ---------- */
.auth-body{background:var(--green); min-height:100vh; display:flex; align-items:flex-start; justify-content:center; padding:24px 16px}
.auth-wrap{width:100%; max-width:460px}
.auth-brand{text-align:center; color:#fff; padding:24px 0 18px}
.auth-logo{font-size:44px}
.auth-brand h1{font-size:26px; margin:.2em 0}
.auth-tag{opacity:.9; margin:0}
.auth-card{background:var(--surface); border-radius:var(--radius); padding:24px; box-shadow:var(--shadow)}
.auth-card-wide{max-width:560px}
.auth-alt{text-align:center; margin-top:16px; font-size:14px; color:var(--muted)}
.demo-box{margin-top:16px; padding:12px; background:var(--bg); border-radius:var(--radius-sm); text-align:center; font-size:13px}
.benefits{list-style:none; padding:0; margin:0 0 18px; display:grid; grid-template-columns:1fr 1fr; gap:6px; font-size:13px}
.benefits li{color:var(--text)}

/* pricing — mobile-first: 1 column on phones, 2 columns from 700px up */
.plans{display:grid; gap:14px; grid-template-columns:1fr}
@media(min-width:700px){ .plans{grid-template-columns:1fr 1fr} }
.plan{border:1.5px solid var(--divider); border-radius:var(--radius); padding:18px; position:relative; text-align:center}
.plan-featured{border-color:var(--amber); border-width:2px}
.plan-badge{position:absolute; top:-11px; left:50%; transform:translateX(-50%); background:var(--amber); color:#1C1C1C; font-size:11px; font-weight:700; padding:3px 10px; border-radius:999px}
.plan-name{font-family:var(--font-head); font-weight:600}
.plan-price{font-size:26px; font-weight:700; font-family:var(--font-head); color:var(--green-2)}
.plan-cycle{color:var(--muted); font-size:13px; margin-bottom:10px}
.plan-feats{list-style:none; padding:0; margin:0 0 14px; font-size:13px; text-align:left}
.plan-feats li{padding:3px 0}

/* ===========================================================
   App shell
   =========================================================== */
.app{min-height:100vh; padding-bottom:calc(72px + env(safe-area-inset-bottom))}
.appbar{
  position:sticky; top:0; z-index:30; display:flex; align-items:center; gap:8px;
  background:var(--green); color:#fff; padding:10px 12px; padding-top:calc(10px + env(safe-area-inset-top));
  box-shadow:var(--shadow);
}
.appbar-title{flex:1; display:flex; flex-direction:column; line-height:1.1}
.appbar-app{font-family:var(--font-head); font-weight:600; font-size:16px}
.appbar-farm{font-size:11.5px; opacity:.85}
.iconbtn{
  background:rgba(255,255,255,.12); border:none; color:#fff; width:var(--tap); height:var(--tap);
  border-radius:12px; font-size:18px; cursor:pointer; display:flex; align-items:center; justify-content:center; position:relative;
}
.iconbtn:active{transform:scale(.94)}
.bell .badge{position:absolute; top:4px; right:4px; background:var(--amber); color:#1c1c1c; font-size:10px; font-weight:700; min-width:16px; height:16px; border-radius:8px; display:flex; align-items:center; justify-content:center; padding:0 3px}

/* drawer */
.scrim,.sheet-scrim{position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:40}
.drawer{
  position:fixed; top:0; left:0; bottom:0; width:280px; max-width:84%; background:var(--surface);
  z-index:50; transform:translateX(-105%); transition:transform .25s ease; display:flex; flex-direction:column;
  box-shadow:2px 0 16px rgba(0,0,0,.2);
}
.drawer.open{transform:translateX(0)}
.drawer-head{background:var(--green); color:#fff; padding:24px 18px; padding-top:calc(24px + env(safe-area-inset-top)); display:flex; gap:12px; align-items:center}
.avatar{width:44px; height:44px; border-radius:50%; background:var(--amber); color:#1c1c1c; display:flex; align-items:center; justify-content:center; font-weight:700; font-family:var(--font-head); font-size:18px}
.drawer-name{font-weight:600} .drawer-email{font-size:12px; opacity:.85}
.drawer-list{list-style:none; margin:0; padding:8px; overflow:auto; flex:1}
.drawer-list a{display:flex; align-items:center; gap:12px; padding:12px 14px; border-radius:12px; color:var(--text); font-weight:500; min-height:var(--tap)}
.drawer-list a.active{background:#E8F5E9; color:var(--green)}
[data-theme="dark"] .drawer-list a.active{background:#16301a; color:#fff}
.nico{font-size:18px; width:24px; text-align:center}
.drawer-foot{padding:14px; color:var(--muted); font-size:12px; text-align:center; border-top:1px solid var(--divider)}

/* content */
.content{padding:16px; max-width:1100px; margin:0 auto}

/* notif panel */
.notif-panel{position:fixed; top:60px; right:10px; width:320px; max-width:92%; background:var(--surface); border-radius:var(--radius); box-shadow:var(--shadow); z-index:35; max-height:70vh; overflow:auto}
.notif-head{display:flex; justify-content:space-between; align-items:center; padding:12px 14px; border-bottom:1px solid var(--divider); font-weight:600}
.notif-list{padding:6px}
.notif-item{padding:10px 12px; border-radius:12px; margin-bottom:4px}
.notif-item.unread{background:#E8F5E9}
[data-theme="dark"] .notif-item.unread{background:#16301a}
.notif-item .nt{font-weight:600; font-size:14px}
.notif-item .nb{font-size:13px; color:var(--muted)}

/* ---------- dashboard ---------- */
.page-greeting{font-size:20px}
.section-title{font-size:15px; margin:18px 0 10px; color:var(--muted); text-transform:uppercase; letter-spacing:.04em; font-size:12px}
.stat-row{display:grid; grid-template-columns:repeat(auto-fit,minmax(110px,1fr)); gap:10px}
.stat{background:var(--surface); border-radius:var(--radius); padding:14px; box-shadow:var(--shadow)}
.stat .sv{font-size:22px; font-weight:700; font-family:var(--font-head); color:var(--green-2)}
.stat .sl{font-size:12px; color:var(--muted)}
.insights{display:grid; gap:10px}
.insight{background:var(--surface); border-radius:var(--radius); padding:14px; box-shadow:var(--shadow); border-left:5px solid var(--info); display:flex; flex-direction:column; gap:2px}
.insight.warning{border-left-color:var(--warning)}
.insight.danger{border-left-color:var(--danger)}
.insight.success{border-left-color:var(--success)}
.insight.info{border-left-color:var(--info)}
.insight .it{font-weight:600; font-size:14px}
.insight .ib{font-size:13px; color:var(--muted)}

.card-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:12px}
.tile{
  background:var(--surface); border-radius:var(--radius); padding:22px 14px; text-align:center;
  box-shadow:var(--shadow); display:flex; flex-direction:column; align-items:center; gap:8px;
  color:var(--text); transition:transform .08s;
}
.tile:active{transform:scale(.97)}
.tile-ico{font-size:30px}
.tile-label{font-family:var(--font-head); font-weight:600; font-size:14px}

.card{background:var(--surface); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow); margin-bottom:16px}

/* ---------- module list ---------- */
.module-head{display:flex; justify-content:space-between; align-items:center; margin-bottom:12px}
.toolbar{display:flex; gap:10px; align-items:center; margin-bottom:14px; flex-wrap:wrap}
.seg{display:inline-flex; background:var(--surface); border-radius:999px; padding:3px; box-shadow:var(--shadow)}
.seg button{border:none; background:none; padding:7px 14px; border-radius:999px; font-size:13px; font-weight:600; color:var(--muted); cursor:pointer; min-height:36px}
.seg button.active{background:var(--green); color:#fff}
.search{max-width:240px}
.list-area{display:flex; flex-direction:column; gap:8px}
.rec{
  background:var(--surface); border-radius:var(--radius); padding:12px 14px; box-shadow:var(--shadow);
  display:flex; align-items:center; gap:12px;
}
.rec-main{flex:1; min-width:0}
.rec-title{font-weight:600; font-size:15px}
.rec-sub{font-size:13px; color:var(--muted); display:flex; gap:10px; flex-wrap:wrap}
.rec-actions{display:flex; gap:6px}
.chip{display:inline-block; padding:2px 9px; border-radius:999px; font-size:11px; font-weight:600; background:#E8F5E9; color:var(--green)}
.chip.gray{background:var(--divider); color:var(--muted)}
.chip.amber{background:#FFF3E0; color:#E65100}
.chip.red{background:#FBE9E7; color:var(--danger)}
.empty{text-align:center; padding:40px 16px; color:var(--muted)}
.empty .ei{font-size:40px}

/* ---------- bottom sheet ---------- */
.sheet{
  position:fixed; left:0; right:0; bottom:0; z-index:60; background:var(--surface);
  border-radius:24px 24px 0 0; box-shadow:var(--shadow-lg); max-height:90vh; overflow:auto;
  transform:translateY(100%); transition:transform .28s cubic-bezier(.2,.8,.2,1);
  padding-bottom:env(safe-area-inset-bottom);
}
.sheet.open{transform:translateY(0)}
.sheet-grip{width:40px; height:4px; background:var(--divider); border-radius:2px; margin:10px auto 0}
.sheet-head{display:flex; justify-content:space-between; align-items:center; padding:8px 18px 4px}
.sheet-head .iconbtn{background:var(--bg); color:var(--text)}
.sheet-body{padding:6px 18px 20px}

/* ---------- toasts ---------- */
.toasts{position:fixed; left:50%; bottom:84px; transform:translateX(-50%); z-index:80; display:flex; flex-direction:column; gap:8px; width:max-content; max-width:90%}
.toast{background:#222; color:#fff; padding:11px 16px; border-radius:12px; font-size:14px; box-shadow:var(--shadow); animation:slideup .25s}
.toast.success{background:var(--success)} .toast.error{background:var(--danger)} .toast.info{background:var(--info)}
@keyframes slideup{from{opacity:0; transform:translateY(12px)}to{opacity:1}}

/* ---------- FAB + bottom nav ---------- */
.fab-sync{
  position:fixed; right:16px; bottom:calc(78px + env(safe-area-inset-bottom)); z-index:25;
  background:var(--amber); color:#1c1c1c; border:none; border-radius:999px; padding:0 18px; height:50px;
  display:flex; align-items:center; gap:8px; font-family:var(--font-head); font-weight:600; box-shadow:var(--shadow); cursor:pointer;
}
.fab-sync:active{transform:scale(.96)}
.fab-ico{font-size:18px; display:inline-block}
.fab-sync.spinning .fab-ico{animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.sync-dot{width:9px; height:9px; border-radius:50%; background:var(--success); margin-left:2px}
.sync-dot.pending{background:var(--warning)} .sync-dot.failed{background:var(--danger)}

.bottomnav{
  position:fixed; left:0; right:0; bottom:0; z-index:20; background:var(--surface);
  display:flex; justify-content:space-around; border-top:1px solid var(--divider);
  padding-bottom:env(safe-area-inset-bottom); box-shadow:0 -2px 8px rgba(0,0,0,.06);
}
.bottomnav a{flex:1; text-align:center; padding:8px 0; color:var(--muted); font-size:11px; font-weight:600; display:flex; flex-direction:column; align-items:center; gap:2px; min-height:56px; justify-content:center}
.bottomnav a span{font-size:20px}
.bottomnav a.active{color:var(--green)}

/* ---------- reports ---------- */
.report-filters{display:flex; gap:10px; flex-wrap:wrap; align-items:end; margin-bottom:14px}
.report-filters label{font-size:12px; color:var(--muted)}
.report-filters input,.report-filters select{padding:8px; border:1.5px solid var(--divider); border-radius:10px; background:var(--surface); color:var(--text)}
.report-tiles{display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:16px}
.rtile{background:var(--surface); border:none; border-radius:var(--radius); padding:14px 6px; box-shadow:var(--shadow); display:flex; flex-direction:column; align-items:center; gap:6px; font-size:24px; cursor:pointer; color:var(--text)}
.rtile span{font-size:12px; font-weight:600; font-family:var(--font-head)}
.rtile.active{background:var(--green); color:#fff}
.report-view{background:var(--surface); border-radius:var(--radius); padding:16px; box-shadow:var(--shadow); min-height:160px}
.kpis{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:14px}
.kpi{flex:1; min-width:120px} .kpi .kv{font-size:22px; font-weight:700; font-family:var(--font-head); color:var(--green-2)} .kpi .kl{font-size:12px; color:var(--muted)}
table.rt{width:100%; border-collapse:collapse; font-size:13px}
table.rt th,table.rt td{text-align:left; padding:8px 6px; border-bottom:1px solid var(--divider)}
table.rt th{color:var(--muted); font-weight:600}
canvas.chart{width:100%; max-width:100%; height:auto; display:block; margin-bottom:12px}

/* ---------- adviser ---------- */
.adviser{display:flex; flex-direction:column}
.chat{background:var(--surface); border-radius:var(--radius); padding:14px; box-shadow:var(--shadow); min-height:280px; display:flex; flex-direction:column; gap:10px; margin-bottom:12px}
.bubble{max-width:85%; padding:10px 14px; border-radius:16px; font-size:14px; white-space:pre-wrap; line-height:1.45}
.bubble.bot{background:var(--bg); align-self:flex-start; border-bottom-left-radius:4px}
.bubble.me{background:var(--green); color:#fff; align-self:flex-end; border-bottom-right-radius:4px}
.bubble.typing{opacity:.7}
.chat-suggest{display:flex; gap:8px; overflow-x:auto; padding-bottom:10px}
.chat-suggest button{white-space:nowrap; background:var(--surface); border:1.5px solid var(--divider); border-radius:999px; padding:8px 14px; font-size:13px; cursor:pointer; color:var(--text)}
.chat-input{display:flex; gap:8px}
.chat-input input{flex:1; padding:12px; border:1.5px solid var(--divider); border-radius:999px; background:var(--surface); color:var(--text)}

/* ---------- family tree ---------- */
.ftree-pick select{padding:10px; border:1.5px solid var(--divider); border-radius:12px; background:var(--surface); color:var(--text); margin-top:6px; width:100%; max-width:320px}
.ftree-view{margin-top:16px}
.ft-node{background:var(--surface); border-radius:12px; padding:10px 12px; box-shadow:var(--shadow); display:inline-block; min-width:120px}
.ft-node .ftn{font-weight:600} .ft-node .fts{font-size:12px; color:var(--muted)}
.ft-level{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:14px}
.ft-branch{border-left:3px solid var(--divider); padding-left:14px; margin-left:8px}
.ft-label{font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.05em; margin-bottom:4px}

/* ---------- skeletons ---------- */
.skeleton,.skeleton-row{background:var(--divider); border-radius:var(--radius); position:relative; overflow:hidden}
.skeleton{height:64px} .skeleton-row{height:60px}
.stat.skeleton{height:64px}
.skeleton::after,.skeleton-row::after{content:""; position:absolute; inset:0; background:rgba(255,255,255,.35); transform:translateX(-100%); animation:shimmer 1.3s infinite}
@keyframes shimmer{100%{transform:translateX(100%)}}

/* responsive: tablet/desktop */
@media(min-width:720px){
  .card-grid{grid-template-columns:repeat(3,1fr)}
  .stat-row{grid-template-columns:repeat(5,1fr)}
  .content{padding:24px}
  .fab-sync{bottom:24px}
  .bottomnav{display:none}
  .app{padding-bottom:24px}
  .plans{grid-template-columns:repeat(2,1fr)}
}
@media(min-width:1000px){
  .card-grid{grid-template-columns:repeat(4,1fr)}
}

/* ===========================================================
   Public landing / marketing site
   =========================================================== */
.site{background:var(--bg);color:var(--text)}
.btn-outline-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.7)}
.site-nav{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:12px 20px;background:var(--green);color:#fff}
.site-logo{display:flex;align-items:center;gap:8px;color:#fff;font-family:var(--font-head);font-weight:700;font-size:18px;white-space:nowrap;flex-shrink:0}
.site-logo-ico{font-size:22px}
.site-links{display:flex;align-items:center;gap:18px;flex-wrap:nowrap}
.site-links a{color:#fff;font-weight:600;font-size:14px}
.site-links a.btn{color:inherit}
.btn-amber.btn-sm,.site-links .btn-amber{color:#1c1c1c}

.hero{background:var(--green);color:#fff;padding:48px 20px 60px;display:grid;gap:36px;
  grid-template-columns:1fr;max-width:1100px;margin:0 auto;align-items:center}
.hero-inner{max-width:620px}
.hero-pill{display:inline-block;background:rgba(255,255,255,.14);padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600;margin-bottom:18px}
.hero h1{font-family:var(--font-head);font-weight:800;font-size:38px;line-height:1.12;margin:0 0 14px}
.hero-sub{font-size:17px;opacity:.92;line-height:1.55;margin:0 0 24px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-cta .btn{height:50px;padding:0 22px;font-size:15px}
.hero-note{margin-top:14px;font-size:13px;opacity:.8}
.hero-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.hc{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);border-radius:16px;padding:16px}
.hc-ico{font-size:24px}.hc-v{font-family:var(--font-head);font-weight:700;font-size:22px;margin-top:6px}
.hc-l{font-size:12.5px;opacity:.85}

.section{padding:54px 20px}
.section-alt{background:var(--surface)}
.section-wrap{max-width:1100px;margin:0 auto}
.sec-h{font-family:var(--font-head);font-weight:700;font-size:28px;text-align:center;margin:0 0 8px}
.sec-sub{text-align:center;color:var(--muted);max-width:620px;margin:0 auto 32px}
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.feat{background:var(--surface);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.section-alt .feat{background:var(--bg)}
.feat-ico{font-size:28px}
.feat h3{font-size:16px;margin:10px 0 6px}
.feat p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.5}
.how{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.how-step{text-align:center;padding:10px}
.how-n{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:var(--amber);color:#1c1c1c;font-family:var(--font-head);font-weight:700;font-size:20px;margin-bottom:12px}
.how-step h3{font-size:17px;margin:0 0 6px}
.how-step p{color:var(--muted);font-size:14px;margin:0}

.cta-band{background:var(--green-2);color:#fff;text-align:center;padding:50px 20px}
.cta-band h2{font-family:var(--font-head);font-size:26px;margin:0 0 8px}
.cta-band p{opacity:.9;margin:0 0 20px}

.site-footer{background:#10140F;color:#cdd;padding:40px 20px 20px}
.site-foot-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}
.site-footer h4{color:#fff;font-size:14px;margin:0 0 10px}
.site-footer a{display:block;color:#cdd;font-size:14px;padding:3px 0}
.site-foot-base{max-width:1100px;margin:22px auto 0;border-top:1px solid #2a322a;padding-top:16px;font-size:13px;text-align:center;color:#9ab}

@media(min-width:860px){
  .hero{grid-template-columns:1.2fr 1fr;padding-top:64px}
  .hero h1{font-size:46px}
}
@media(max-width:760px){
  .feat-grid{grid-template-columns:1fr 1fr}
  .how{grid-template-columns:1fr}
  .site-foot-grid{grid-template-columns:1fr}
  /* Mobile header: keep logo + language + one CTA; hide secondary text links */
  .site-nav{padding:10px 14px}
  .site-logo{font-size:16px} .site-logo-ico{font-size:20px}
  .site-links{gap:10px}
  .site-links .site-navlink{display:none}
  .site-links .btn-sm{padding:0 12px;font-size:12.5px;min-height:38px}
  .lang-select{padding:8px}
}
@media(max-width:460px){ .feat-grid{grid-template-columns:1fr} }
@media(max-width:360px){ .site-logo .lg-word{display:none} }

/* language switcher */
.lang-select{background:rgba(255,255,255,.14);color:#fff;border:none;border-radius:10px;padding:8px 10px;font-size:13px;font-weight:600;cursor:pointer}
.lang-select option{color:#1c1c1c}
[dir="rtl"] body, body[dir="rtl"]{direction:rtl}
[dir="rtl"] .drawer{left:auto;right:0;transform:translateX(105%)}
[dir="rtl"] .drawer.open{transform:translateX(0)}
[dir="rtl"] .insight{border-left:none;border-right:5px solid var(--info)}

/* MoMo subscribe page */
.pay-card{max-width:460px}
.pay-amount{font-family:var(--font-head);font-weight:700;font-size:30px;color:var(--green-2);text-align:center}
.pay-plan{text-align:center;color:var(--muted);margin-bottom:16px}
.pay-status{margin-top:14px;padding:12px;border-radius:12px;font-size:14px;text-align:center}
.pay-status.pending{background:#FFF3E0;color:#E65100}
.pay-status.ok{background:#E8F5E9;color:var(--success)}
.pay-status.fail{background:#FBE9E7;color:var(--danger)}
.momo-badge{display:flex;align-items:center;gap:10px;background:#FFCC00;color:#1c1c1c;border-radius:12px;padding:10px 14px;font-weight:700;margin-bottom:16px;justify-content:center}

/* language dropdown */
.lang-dd{position:relative}
.lang-dd > summary{list-style:none;display:inline-flex;align-items:center;gap:4px}
.lang-dd > summary::-webkit-details-marker{display:none}
.lang-menu{position:absolute;right:0;top:calc(100% + 6px);background:var(--surface);border-radius:12px;box-shadow:var(--shadow);min-width:160px;z-index:60;overflow:hidden;padding:4px}
[dir="rtl"] .lang-menu{right:auto;left:0}
.lang-menu a{display:block;padding:10px 14px;color:var(--text);font-size:14px;border-radius:8px}
.lang-menu a.active{background:#E8F5E9;color:var(--green);font-weight:600}
[data-theme="dark"] .lang-menu a.active{background:#16301a;color:#fff}
.site-nav .lang-menu a, .auth-lang .lang-menu a{color:var(--text)}
.auth-lang{position:absolute;top:16px;right:16px}
[dir="rtl"] .auth-lang{right:auto;left:16px}

/* ===========================================================
   Hero image slider (landing)
   =========================================================== */
.hero-slider{position:relative;height:560px;overflow:hidden;background:var(--green)}
.hslide{position:absolute;inset:0;opacity:0;transition:opacity .9s ease;background-size:cover;background-position:center;background-repeat:no-repeat}
.hslide.active{opacity:1}
.hslide-1{background-image:url(../img/hero-cattle.jpg)}
.hslide-2{background-image:url(../img/hero-goats.jpg)}
.hslide-3{background-image:url(../img/hero-poultry.jpg)}
.hslide-4{background-image:url(../img/hero-eggs.jpg)}
.hslide-5{background-image:url(../img/hero-pigs.jpg)}
.hslide-overlay{position:absolute;inset:0;background:rgba(16,20,15,.55);display:flex;align-items:center}
.hslide-content{max-width:1100px;margin:0 auto;width:100%;padding:0 24px;color:#fff}
.hslide-content .hero-pill{background:rgba(255,255,255,.18)}
.hslide-content h1{color:#fff;font-family:var(--font-head);font-weight:800;font-size:42px;line-height:1.12;margin:12px 0 14px;max-width:680px}
.hslide-content .hero-sub{color:#fff;opacity:.95;max-width:600px}
.hslide-content .hero-note{color:#fff;opacity:.8}
.slider-dots{position:absolute;bottom:20px;left:0;right:0;display:flex;gap:10px;justify-content:center;z-index:3}
.slider-dots .dot{width:11px;height:11px;border-radius:50%;border:none;background:rgba(255,255,255,.5);cursor:pointer;padding:0;transition:width .25s,background .25s}
.slider-dots .dot.active{background:var(--amber);width:28px;border-radius:6px}
@media(max-width:760px){
  .hero-slider{height:540px}
  .hslide-content h1{font-size:30px}
  .hslide-overlay{background:rgba(16,20,15,.6)}
}

/* Keep the English brand name in natural order even under RTL */
.site-logo, .appbar-app, .auth-brand h1, .momo-badge { direction:ltr; unicode-bidi:isolate; }

/* ===========================================================
   Brand logo lockups (white "app-icon" badge)
   =========================================================== */
.brand-badge{background:#fff;border-radius:8px;padding:3px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 1px 3px rgba(0,0,0,.18)}
.brand-badge img{display:block;height:28px;width:28px;border-radius:5px}
.site-nav .brand-badge img{height:30px;width:30px}
.appbar-badge{padding:2px;border-radius:7px}
.appbar-badge img{height:26px;width:26px}
/* keep appbar from crowding when the badge + lang + icons are present */
.appbar-title{min-width:0}
.appbar-app,.appbar-farm{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.auth-logo-card{width:104px;height:104px;margin:0 auto 6px;background:#fff;border-radius:24px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(0,0,0,.22)}
.auth-logo-card img{width:88px;height:88px;border-radius:16px;display:block}
@media(max-width:380px){ .appbar-badge{display:none} }   /* save space on very small phones */

/* ===========================================================
   Responsive fixes — pricing plans + overflow guard
   =========================================================== */
.site, .auth-body { overflow-x:hidden; }
.section-wrap, .plans { max-width:100%; }
@media(max-width:600px){
  .plans{grid-template-columns:1fr;}      /* stack plans on phones (was 2-col, caused overflow) */
  .plan-price{font-size:24px;}
}

/* ===========================================================
   Module action group + print
   =========================================================== */
.module-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.print-only{display:none}
.print-head .ph-farm{font-weight:700;font-size:15px;color:var(--green)}
.print-head h2{margin:2px 0}
.print-head .ph-range,.print-head .ph-date{color:#555;font-size:13px}
.print-head .ph-date{margin-bottom:12px}

@media print{
  /* hide all app/site chrome — print only the content */
  .appbar,.drawer,.scrim,.bottomnav,.fab-sync,.notif-panel,.notif-panel *,
  .sheet,.sheet-scrim,.toasts,.site-nav,.site-footer,
  .report-tiles,.report-filters,.toolbar,.seg,.search,
  .module-actions,.rec-actions,.chat-suggest,.chat-input,.lang-dd,.hero-slider{ display:none !important; }
  html,body,.app,.content,.report-view,.card,.module{ background:#fff !important; color:#000 !important; }
  .app{ padding:0 !important; }
  .content{ padding:0 !important; max-width:100% !important; margin:0 !important; }
  .report-view,.card,.rec,.stat,.feat{ box-shadow:none !important; border:1px solid #ddd; break-inside:avoid; }
  .print-only{ display:block !important; }
  table.rt{ width:100%; border-collapse:collapse; }
  table.rt th,table.rt td{ border:1px solid #999; padding:6px 8px; }
  canvas.chart{ max-width:100% !important; }
  a[href]:after{ content:""; }
  @page{ margin:14mm; }
}

/* trial / expiry banner */
.trial-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;
  padding:10px 14px;border-radius:var(--radius-sm);margin-bottom:14px;font-size:14px;font-weight:600}
.trial-banner.is-trial{background:#E8F5E9;color:var(--green)}
.trial-banner.is-warn{background:#FFF3E0;color:#E65100}
[data-theme="dark"] .trial-banner.is-trial{background:#16301a;color:#fff}
@media print{ .trial-banner{display:none !important} }

/* prevent button labels from wrapping in tight headers */
.btn{white-space:nowrap}
