:root {
    --green-900:#1a3a2a;--green-800:#1e4d35;--green-700:#256642;--green-600:#2d7d52;
    --green-500:#3a9e68;--green-400:#56b87f;--green-300:#86d4a4;--green-200:#c0eacd;
    --green-100:#e6f7ec;--green-50:#f4fbf6;
    --earth-800:#4a3728;--earth-600:#7a5c42;--earth-400:#b08060;--earth-200:#e0c9b4;--earth-100:#f5ede4;
    --amber-600:#c97c1a;--amber-100:#fef4e0;
    --red-600:#c0392b;--red-100:#fdecea;
    --blue-600:#1e6fac;--blue-100:#e3f0fa;
    --gray-900:#1c2520;--gray-700:#3d4a42;--gray-600:#5c6c62;--gray-500:#6b7a6f;--gray-300:#b8c4bb;--gray-100:#f0f3f1;
    --sidebar-w:260px;--header-h:64px;
    --touch-min: 44px;
  }

  .sync-indicator {
    display:flex;align-items:center;gap:5px;font-size:11px;padding:4px 10px;border-radius:12px;
    background:var(--gray-100);color:var(--gray-600);border:1px solid transparent;transition:var(--transition-smooth);
  }
  body.dark-mode .sync-indicator {
    background:rgba(45,74,56,0.5);color:var(--green-300);border-color:rgba(45,74,56,0.8);
  }
  *{box-sizing:border-box;margin:0;padding:0}
  body{font-family:'DM Sans',sans-serif;background:var(--soil);color:var(--white-90);min-height:100vh;display:flex;font-size:14px}
  .sidebar{width:var(--sidebar-w);height:100vh;min-height:100vh;background:var(--green-900);position:fixed;top:0;left:0;z-index:100;display:flex;flex-direction:column;overflow:hidden}
  .sidebar-logo{padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,0.08);display:flex;align-items:center;gap:12px;flex-shrink:0}
  .sidebar-logo h1{font-family:'DM Serif Display',serif;font-size:22px;color:var(--green-200);font-weight:400}
  .sidebar-logo p{font-size:11px;color:var(--green-400);margin-top:2px;letter-spacing:.05em}
  .sb-season{margin:12px 20px;padding:10px;border-radius:10px;background:rgba(255,255,255,0.05);display:flex;align-items:center;gap:10px;flex-shrink:0}
  .nav{padding:12px 0;flex:1;overflow-y:auto;min-height:0}
  .nav-section{font-size:10px;font-weight:600;letter-spacing:.08em;color:var(--green-600);padding:12px 20px 4px;text-transform:uppercase}
  .nav-item{display:flex;align-items:center;gap:10px;padding:9px 20px;cursor:pointer;color:var(--green-300);font-size:13.5px;font-weight:400;transition:all .15s;border-left:3px solid transparent;margin:1px 0}
  .nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
  .nav-item.active{background:rgba(56,158,104,.2);color:#fff;border-left-color:var(--green-400)}
  .nav-item .icon{width:16px;text-align:center;font-size:15px}
  .sidebar-footer{padding:20px;border-top:1px solid rgba(255,255,255,.08);flex-shrink:0;background:rgba(0,0,0,0.3);display:flex;flex-direction:column;gap:14px;z-index:10}
  .farm-badge{background:rgba(56,158,104,0.15);border-radius:12px;padding:12px;border:1px solid rgba(255,255,255,0.05);position:relative}
  .farm-badge .name{font-size:14px;color:#fff;font-weight:700;letter-spacing:0.01em}
  .farm-badge .sub{font-size:11px;color:var(--green-300);margin-top:2px;opacity:0.8}
  .sb-weather{background:rgba(255,255,255,0.04);border-radius:10px;padding:10px;border:1px solid rgba(255,255,255,0.03)}
  .sb-wx-temp{font-size:18px;font-weight:700;color:var(--harvest)}
  .sb-wx-desc{font-size:11px;color:var(--green-300);text-transform:uppercase;letter-spacing:0.02em}
  .footer-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .footer-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:all 0.2s;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.05);color:#fff;text-decoration:none}
  .footer-btn:hover{background:rgba(255,255,255,0.1);transform:translateY(-1px)}
  .footer-btn.logout{border-color:rgba(192, 57, 43, 0.3);background:rgba(192, 57, 43, 0.1);color:#ff9999}
  .footer-btn.logout:hover{background:rgba(192, 57, 43, 0.2);border-color:rgba(192, 57, 43, 0.5)}
  .main{margin-left:260px;flex:1;display:flex;flex-direction:column;min-height:100vh;padding-bottom:140px}
  .topbar{height:var(--header-h);background:var(--card);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:50}
  .topbar-title{font-family:'DM Serif Display',serif;font-size:20px;color:var(--text-bright);font-weight:400}
  .topbar-right{display:flex;align-items:center;gap:10px}
  .btn{padding:7px 16px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .15s;font-family:'DM Sans',sans-serif}
  .btn-primary{background:var(--green-700);color:#fff}
  .btn-primary:hover{background:var(--green-800)}
  .btn-secondary{background:var(--card);color:var(--white-90);border:1px solid var(--border)}
  .btn-secondary:hover{background:var(--green-soft)}
  .btn-ghost{background:transparent;color:var(--white-90);border:1px solid var(--border)}
  .btn-ghost:hover{background:var(--green-soft)}
  .btn-ai{background:linear-gradient(135deg,#1e4d35,#3a9e68);color:#fff}
  .btn-ai:hover{opacity:.9}
  .btn-sm{padding:5px 12px;font-size:12px}
  .page{padding:24px 28px;flex:1;display:none}
  .page.active{display:block}
  .card{background:var(--card);border-radius:12px;border:1px solid var(--border);padding:20px;backdrop-filter:blur(20px)}
  .mobile-dock{
    position:fixed;bottom:20px;left:50%;transform:translateX(-50%);
    max-width:94vw;padding:10px;
    background:var(--card);border:1px solid var(--border-hi);
    backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border-radius:999px;z-index:1000;
    box-shadow:0 14px 40px rgba(0,0,0,0.2), inset 0 1px 0 rgba(255,255,255,0.1);
  }
  .dock-scroll{
    display:flex;align-items:center;gap:2px;overflow-x:auto;
    scrollbar-width:none;-ms-overflow-style:none;
    -webkit-overflow-scrolling:touch;padding:0 4px;
  }
  .dock-scroll::-webkit-scrollbar{display:none}
  .mobile-dock .dock-btn{
    display:flex;flex-direction:column;align-items:center;gap:4px;
    min-width:68px;padding:8px 8px;border:none;border-radius:999px;cursor:pointer;
    background:transparent;color:var(--white-60);font-size:9.5px;font-weight:600;
    transition:all .2s ease;font-family:'DM Sans',sans-serif;flex-shrink:0;
  }
  .mobile-dock .dock-btn:hover{
    background:var(--green-soft);color:var(--white-90);transform:translateY(-1px);
  }
  .mobile-dock .dock-btn.active{
    background:var(--green-soft);
    color:var(--harvest);box-shadow:inset 0 0 0 1px var(--border-hi);
  }
  .mobile-dock .dock-icon{font-size:16px;line-height:1}
  .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
  .card-title{font-size:15px;font-weight:600;color:var(--text-bright)}
  .card-sub{font-size:12px;color:var(--white-60);margin-top:2px}
  .stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
  .stat-card{background:var(--card);border-radius:12px;border:1px solid var(--border);padding:18px 20px;backdrop-filter:blur(16px)}
  .stat-label{font-size:12px;color:var(--white-60);font-weight:500;letter-spacing:.02em}
  .stat-value{font-size:28px;font-weight:600;margin-top:4px;font-family:'DM Serif Display',serif}
  .stat-meta{font-size:12px;color:var(--white-60);margin-top:4px}
  .stat-green .stat-value{color:var(--leaf)}
  .stat-amber .stat-value{color:var(--harvest)}
  .stat-earth .stat-value{color:var(--wheat)}
  .stat-blue .stat-value{color:var(--sky)}
  .table-wrap{overflow-x:auto}
  .pagination-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 0;flex-wrap:wrap;gap:8px}
  .pagination-bar .btn{padding:6px 14px;font-size:12px}
  .pagination-bar .btn:disabled{opacity:.35;pointer-events:none}
  table{width:100%;border-collapse:collapse;font-size:13.5px}
  th{text-align:left;padding:10px 14px;font-size:11.5px;font-weight:600;color:var(--white-60);letter-spacing:.04em;text-transform:uppercase;border-bottom:1px solid var(--border);background:var(--green-soft)}
  td{padding:11px 14px;border-bottom:1px solid var(--border);color:var(--white-90);vertical-align:middle}
  tr:last-child td{border-bottom:none}
  tr:hover td{background:var(--green-soft)}
  .badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11.5px;font-weight:500}
  .badge-green{background:var(--green-soft);color:var(--leaf);border:1px solid var(--green-border)}
  .badge-amber{background:rgba(242, 208, 92, 0.1);color:var(--harvest);border:1px solid rgba(242, 208, 92, 0.2)}
  .badge-red{background:rgba(216, 112, 52, 0.1);color:var(--rust);border:1px solid rgba(216, 112, 52, 0.2)}
  .badge-blue{background:rgba(179, 229, 252, 0.1);color:var(--sky);border:1px solid rgba(179, 229, 252, 0.2)}
  .badge-earth{background:rgba(212, 188, 141, 0.1);color:var(--wheat);border:1px solid rgba(212, 188, 141, 0.2)}
  .badge-gray{background:var(--gray-100);color:var(--gray-500)}
  .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
  .grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
  .mb-20{margin-bottom:20px}
  .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .form-group{margin-bottom:14px}
  .form-label{display:block;font-size:12.5px;font-weight:500;color:var(--gray-700);margin-bottom:5px}
  .form-control{width:100%;padding:8px 12px;border:1px solid var(--gray-300);border-radius:8px;font-size:13.5px;font-family:'DM Sans',sans-serif;color:var(--gray-900);background:#fff;transition:border .15s}
  .form-control:focus{outline:none;border-color:var(--green-500)}
  .form-control[aria-invalid="true"]{border-color:var(--red-500, #dc2626);box-shadow:0 0 0 3px rgba(220,38,38,0.12)}
  .field-error{font-size:11.5px;color:var(--red-600, #b91c1c);margin-top:3px}
  select.form-control{cursor:pointer}
  .modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:200;align-items:center;justify-content:center}
  .modal-overlay.open{display:flex}
  .modal{background:#fff;border-radius:14px;width:520px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.15)}
  .modal-lg{width:680px}
  .modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;align-items:center}
  .modal-title{font-family:'DM Serif Display',serif;font-size:18px;color:var(--green-800);font-weight:400}
  .modal-body{padding:20px 24px}
  .modal-footer{padding:16px 24px;border-top:1px solid var(--gray-100);display:flex;justify-content:flex-end;gap:10px}
  .close-btn{background:none;border:none;font-size:20px;cursor:pointer;color:var(--gray-500);line-height:1}
  .progress-bar{background:var(--gray-100);border-radius:20px;height:6px;overflow:hidden}
  .progress-fill{height:100%;border-radius:20px;background:var(--green-500);transition:width .3s}
  .avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}
  .avatar-green{background:var(--green-100);color:var(--green-700)}
  .plot-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
  .plot-card{background:#fff;border-radius:12px;border:1px solid #e8ede9;padding:18px;cursor:pointer;transition:all .15s}
  .plot-card:hover{border-color:var(--green-400);box-shadow:0 2px 12px rgba(45,125,82,.1)}
  .plot-card .crop-icon{font-size:28px;margin-bottom:10px}
  .plot-card .plot-name{font-weight:600;font-size:14px;color:var(--gray-900)}
  .plot-card .plot-sub{font-size:12px;color:var(--gray-500);margin-top:3px}
  .plot-card .plot-stats{display:flex;gap:12px;margin-top:12px}
  .plot-card .plot-stat{font-size:12px;color:var(--gray-500)}
  .plot-card .plot-stat strong{color:var(--gray-900);display:block;font-size:14px;font-weight:600}
  .activity-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--gray-100);align-items:flex-start}
  .activity-item:last-child{border-bottom:none}
  .activity-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}
  .activity-dot-green{background:var(--green-500)}
  .activity-dot-amber{background:var(--amber-600)}
  .activity-dot-earth{background:var(--earth-400)}
  .activity-text{font-size:13px;color:var(--gray-700);line-height:1.5}
  .activity-time{font-size:11px;color:var(--gray-500);margin-top:2px}
  .report-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}
  .report-card{background:#fff;border-radius:12px;border:1px solid #e8ede9;padding:18px;text-align:center}
  .report-card .rc-value{font-family:'DM Serif Display',serif;font-size:26px;margin-top:6px}
  .report-card .rc-label{font-size:12px;color:var(--gray-500);font-weight:500}
  .rc-profit{color:var(--green-700)}.rc-cost{color:var(--red-600)}.rc-revenue{color:var(--blue-600)}
  .bar-chart{margin-top:16px}
  .bar-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}
  .bar-label{width:90px;font-size:12.5px;color:var(--gray-700);text-align:right;flex-shrink:0}
  .bar-track{flex:1;background:var(--gray-100);border-radius:4px;height:22px;overflow:hidden}
  .bar-fill{height:100%;border-radius:4px;display:flex;align-items:center;padding-left:8px;font-size:12px;font-weight:500;color:#fff;transition:width .5s}
  .bar-green{background:var(--green-500)}.bar-amber{background:var(--amber-600)}.bar-earth{background:var(--earth-400)}.bar-blue{background:var(--blue-600)}
  .section-title{font-family:'DM Serif Display',serif;font-size:22px;color:var(--green-800);margin-bottom:6px;font-weight:400}
  .section-desc{font-size:13px;color:var(--gray-500);margin-bottom:20px}
  .tag{display:inline-block;background:var(--green-100);color:var(--green-700);font-size:11px;padding:2px 8px;border-radius:4px;font-weight:500;margin-right:4px}
  .toast{position:fixed;bottom:24px;right:24px;background:var(--green-800);color:#fff;padding:12px 20px;border-radius:10px;font-size:13px;z-index:999;transform:translateY(80px);opacity:0;transition:all .3s;font-family:'DM Sans',sans-serif;max-width:320px}
  .toast.show{transform:translateY(0);opacity:1}

  /* ===== WEATHER WIDGET ===== */
  .weather-strip{display:grid;grid-template-columns:1fr 2fr;gap:16px;margin-bottom:24px}
  .weather-main{background:linear-gradient(135deg,var(--green-800),var(--green-600));border-radius:12px;padding:20px;color:#fff;position:relative;overflow:hidden}
  .weather-main::after{content:'';position:absolute;right:-20px;top:-20px;width:100px;height:100px;background:rgba(255,255,255,.06);border-radius:50%}
  .weather-temp{font-family:'DM Serif Display',serif;font-size:52px;font-weight:400;line-height:1;color:#fff}
  .weather-desc{font-size:13px;color:var(--green-200);margin-top:4px}
  .weather-loc{font-size:11px;color:var(--green-300);margin-top:8px;opacity:.8}
  .weather-meta{display:flex;gap:16px;margin-top:12px}
  .weather-meta span{font-size:12px;color:var(--green-200)}
  .weather-forecast{background:#fff;border-radius:12px;border:1px solid #e8ede9;padding:16px 20px}
  .forecast-title{font-size:12px;font-weight:600;color:var(--gray-500);letter-spacing:.04em;text-transform:uppercase;margin-bottom:12px}
  .forecast-days{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
  .forecast-day{text-align:center;padding:10px 6px;border-radius:8px;background:var(--green-50)}
  .forecast-day .day-name{font-size:11px;color:var(--gray-500);font-weight:500}
  .forecast-day .day-icon{font-size:20px;margin:6px 0}
  .forecast-day .day-temp{font-size:13px;font-weight:600;color:var(--gray-900)}
  .forecast-day .day-rain{font-size:10px;color:var(--blue-600);margin-top:2px}
  .alert-strip{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}
  .alert-pill{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:20px;font-size:12.5px;font-weight:500}
  .alert-warn{background:var(--amber-100);color:var(--amber-600);border:1px solid #f5d9a0}
  .alert-good{background:var(--green-100);color:var(--green-700);border:1px solid var(--green-300)}
  .alert-info{background:var(--blue-100);color:var(--blue-600);border:1px solid #a8d0f0}

  /* ===== AI ADVISOR ===== */
  .ai-chat-panel{display:flex;flex-direction:column;height:calc(100vh - 140px);min-height:500px}
  .ai-context-bar{background:var(--green-50);border:1px solid var(--green-200);border-radius:10px;padding:12px 16px;margin-bottom:16px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
  .ai-context-bar span{font-size:12px;color:var(--green-700)}
  .ai-context-tag{background:var(--green-100);color:var(--green-700);border:1px solid var(--green-200);padding:3px 10px;border-radius:6px;font-size:12px;font-weight:500}
  .chat-messages{flex:1;overflow-y:auto;padding:4px 0;display:flex;flex-direction:column;gap:14px}
  .chat-msg{display:flex;gap:10px;align-items:flex-start}
  .chat-msg.user{flex-direction:row-reverse}
  .msg-avatar{width:30px;height:30px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600}
  .msg-avatar.ai-av{background:var(--green-800);color:var(--green-200)}
  .msg-avatar.user-av{background:var(--earth-100);color:var(--earth-600)}
  .msg-bubble{max-width:78%;padding:11px 15px;border-radius:12px;font-size:13.5px;line-height:1.6;color:var(--gray-900)}
  .msg-bubble.ai{background:#fff;border:1px solid #e8ede9}
  .msg-bubble.user{background:var(--green-700);color:#fff;border-radius:12px 12px 4px 12px}
  .msg-bubble p{margin-bottom:6px}
  .msg-bubble p:last-child{margin-bottom:0}
  .msg-bubble ul{padding-left:16px;margin-top:4px}
  .msg-bubble li{margin-bottom:3px}
  .chat-typing{display:flex;gap:5px;align-items:center;padding:10px 14px;background:#fff;border:1px solid #e8ede9;border-radius:12px;width:fit-content}
  .typing-dot{width:7px;height:7px;border-radius:50%;background:var(--green-400);animation:typingAnim 1.2s infinite}
  .typing-dot:nth-child(2){animation-delay:.2s}
  .typing-dot:nth-child(3){animation-delay:.4s}
  @keyframes typingAnim{0%,60%,100%{opacity:.3;transform:scale(.8)}30%{opacity:1;transform:scale(1)}}
  .chat-input-row{display:flex;gap:10px;margin-top:14px;align-items:flex-end}
  .chat-input{flex:1;padding:10px 14px;border:1.5px solid var(--gray-300);border-radius:10px;font-size:13.5px;font-family:'DM Sans',sans-serif;resize:none;min-height:42px;max-height:120px;line-height:1.5}
  .chat-input:focus{outline:none;border-color:var(--green-500)}
  .quick-prompts{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
  .quick-prompt{padding:6px 12px;border-radius:20px;font-size:12px;background:#fff;border:1px solid var(--gray-300);cursor:pointer;color:var(--gray-700);transition:all .15s;font-family:'DM Sans',sans-serif}
  .quick-prompt:hover{border-color:var(--green-500);color:var(--green-700);background:var(--green-50)}

  /* ===== SMS PANEL ===== */
  .sms-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
  .sms-compose{background:#fff;border-radius:12px;border:1px solid #e8ede9;padding:20px}
  .sms-log{background:#fff;border-radius:12px;border:1px solid #e8ede9;padding:20px}
  .recipient-chips{display:flex;flex-wrap:wrap;gap:6px;padding:8px;border:1px solid var(--gray-300);border-radius:8px;min-height:42px;margin-bottom:12px;cursor:text}
  .recipient-chip{display:flex;align-items:center;gap:5px;background:var(--green-100);color:var(--green-700);padding:3px 10px;border-radius:20px;font-size:12px;font-weight:500}
  .chip-remove{cursor:pointer;font-size:14px;color:var(--green-500);line-height:1}
  .sms-char-count{font-size:11px;color:var(--gray-500);text-align:right;margin-top:4px}
  .sms-log-item{padding:12px 0;border-bottom:1px solid var(--gray-100)}
  .sms-log-item:last-child{border-bottom:none}
  .sms-log-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
  .sms-log-to{font-size:12.5px;font-weight:600;color:var(--gray-900)}
  .sms-log-time{font-size:11px;color:var(--gray-500)}
  .sms-log-text{font-size:13px;color:var(--gray-700);line-height:1.5}
  .sms-templates{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
  .sms-tpl{padding:5px 12px;border-radius:6px;font-size:12px;background:var(--earth-100);color:var(--earth-600);border:1px solid var(--earth-200);cursor:pointer;font-family:'DM Sans',sans-serif}
  .sms-tpl:hover{background:var(--earth-200)}

  /* ===== EXPORT PANEL ===== */
  .export-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}
  .export-card{background:#fff;border-radius:12px;border:1px solid #e8ede9;padding:20px;text-align:center;cursor:pointer;transition:all .2s}
  .export-card:hover{border-color:var(--green-400);box-shadow:0 4px 16px rgba(45,125,82,.1);transform:translateY(-2px)}
  .export-card .ex-icon{font-size:36px;margin-bottom:10px}
  .export-card .ex-title{font-size:14px;font-weight:600;color:var(--gray-900);margin-bottom:4px}
  .export-card .ex-desc{font-size:12px;color:var(--gray-500);line-height:1.5}
  .export-preview{background:#fff;border-radius:12px;border:1px solid #e8ede9;padding:20px}
  .preview-header{background:var(--green-800);color:#fff;border-radius:8px;padding:16px 20px;margin-bottom:16px;display:flex;justify-content:space-between;align-items:flex-start}
  .preview-farm{font-family:'DM Serif Display',serif;font-size:18px;font-weight:400}
  .preview-sub{font-size:11px;color:var(--green-300);margin-top:3px}
  .preview-date{font-size:11px;color:var(--green-300)}
  .preview-section{margin-bottom:14px}
  .preview-section-title{font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--gray-500);text-transform:uppercase;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid var(--gray-100)}
  .preview-kv{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;border-bottom:1px solid var(--gray-100)}
  .preview-kv:last-child{border-bottom:none}
  .preview-kv .k{color:var(--gray-500)}
  .preview-kv .v{font-weight:600;color:var(--gray-900)}

  @media(max-width:1400px){
    :root { --sidebar-w:220px; --header-h:60px; }
    .topbar{padding:0 18px}
    .topbar-title{font-size:18px}
    .topbar-right{gap:8px;flex-wrap:wrap;justify-content:flex-end}
    .topbar-right > span{display:none}
    .page{padding:18px 20px}
    .card{padding:16px}
    .stats-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:18px}
    .grid-2{gap:14px}
    .grid-3{grid-template-columns:1fr 1fr;gap:12px}
    .stat-card{padding:14px 16px}
    .stat-value{font-size:24px}
    .search-bar{width:170px}
    .search-bar:focus{width:220px}
  }

  @media(max-width:1200px){
    .search-bar-wrap{display:none}
    .topbar .btn.btn-ghost.btn-sm{display:none}
    .grid-3{grid-template-columns:1fr}
  }

  @media(max-width:900px){
    .stats-grid{grid-template-columns:1fr 1fr}
    .grid-2{grid-template-columns:1fr}
    .weather-strip{grid-template-columns:1fr}
    .plot-grid{grid-template-columns:1fr 1fr}
    .form-grid{grid-template-columns:1fr}
    .export-grid{grid-template-columns:1fr}
    .sms-grid{grid-template-columns:1fr}
    .report-summary{grid-template-columns:1fr}
    .main{margin-left:0;padding-bottom:110px}
    .sidebar{display:none}
  }

  @media(max-width:600px){
    .stats-grid{grid-template-columns:1fr}
    .plot-grid{grid-template-columns:1fr}
    .grid-3{grid-template-columns:1fr}
    .health-ring-wrap{grid-template-columns:1fr 1fr}
    .main{margin-left:0;padding-bottom:110px}
    .sidebar{display:none}
    .topbar{padding:0 16px}
    .topbar-title{font-size:18px}
    .search-bar-wrap{display:none}
    .mobile-dock{bottom:14px;gap:4px;padding:8px;max-width:98vw}
    .dock-scroll{gap:1px}
    .mobile-dock .dock-btn{min-width:60px;padding:6px 6px;font-size:9px}
    .mobile-dock .dock-icon{font-size:14px}
    .page{padding:16px 20px}
    .btn{padding:10px 18px;min-height:var(--touch-min)}
  }

  /* ===== ENHANCED VISUAL SYSTEM ===== */
  :root {
    --glow-green: 0 0 20px rgba(56,158,104,0.35);
    --glow-amber: 0 0 20px rgba(201,124,26,0.3);
    --card-shadow: 0 4px 24px rgba(26,58,42,0.1);
    --card-shadow-hover: 0 12px 40px rgba(26,58,42,0.2);
    --transition-smooth: all 0.35s cubic-bezier(0.4,0,0.2,1);
  }

  /* Sidebar enhancements */
  .sidebar {
    background: linear-gradient(180deg,#0d2318 0%,#1a3a2a 40%,#1e4d35 100%);
    box-shadow: 4px 0 32px rgba(0,0,0,0.4);
  }
  .sidebar::before {
    content:'';position:absolute;inset:0;
    background:url('https://images.unsplash.com/photo-1500382017468-9049fed747ef?w=400&q=60') center/cover no-repeat;
    opacity:0.04;pointer-events:none;z-index:0;
  }
  .sidebar > * { position: relative; z-index: 1; }
  .sidebar-logo { padding:24px 20px 20px; border-bottom:1px solid rgba(255,255,255,0.1); display:flex; align-items:center; gap:12px; }
  .sidebar-logo h1 {
    font-family:'Playfair Display',serif;font-size:24px;
    background:linear-gradient(135deg,#86d4a4,#fff);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
    letter-spacing:-0.02em;
  }
  .sidebar-logo .logo-leaf {
    display:inline-block;animation:leafSway 3s ease-in-out infinite;transform-origin:bottom center;
  }
  @keyframes leafSway{0%,100%{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}

  .sidebar-logo-img {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    object-fit: cover;
    box-shadow: var(--glow-green);
    animation: logoPulse 4s ease-in-out infinite;
    margin-right: 12px;
  }
  
  .auth-logo-img {
    max-width: 240px;
    height: auto;
    margin-bottom: 20px;
    filter: drop-shadow(0 4px 10px rgba(0,0,0,0.1));
  }

  .splash-logo-img {
    width: 100px;
    height: 100px;
    border-radius: 28px;
    object-fit: cover;
    box-shadow: 0 0 60px rgba(56,158,104,0.5);
    animation: splashLogoAnim 1s cubic-bezier(0.34,1.56,0.64,1);
    margin-bottom: 24px;
  }

  /* Logo icon area */
  .logo-icon-wrap {
    width:44px;height:44px;background:linear-gradient(135deg,var(--green-600),var(--green-400));
    border-radius:12px;display:flex;align-items:center;justify-content:center;
    font-size:22px;margin-bottom:0;box-shadow:var(--glow-green);
    animation:logoPulse 4s ease-in-out infinite;
  }
  @keyframes logoPulse{0%,100%{box-shadow:0 0 0 0 rgba(56,158,104,0.4)}50%{box-shadow:0 0 0 8px rgba(56,158,104,0)}}

  .nav-item {
    position:relative;overflow:hidden;border-radius:0 10px 10px 0;margin:2px 8px 2px 0;
    transition:var(--transition-smooth);
  }
  .nav-item::before {
    content:'';position:absolute;left:0;top:0;bottom:0;width:0;
    background:linear-gradient(90deg,rgba(56,158,104,0.3),transparent);
    transition:width 0.3s ease;
  }
  .nav-item:hover::before { width:100%; }
  .nav-item.active {
    background:linear-gradient(90deg,rgba(56,158,104,0.25),rgba(56,158,104,0.08));
    border-left-color:var(--green-300);box-shadow:inset 0 0 20px rgba(56,158,104,0.1);
  }
  .nav-item .icon { font-size:16px;filter:drop-shadow(0 0 4px rgba(134,212,164,0.4)); }

  /* Topbar enhancements */
  .topbar {
    background:rgba(255,255,255,0.95);backdrop-filter:blur(12px);
    border-bottom:1px solid rgba(56,158,104,0.1);
    box-shadow:0 2px 20px rgba(26,58,42,0.06);
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 24px;
    min-height: var(--header-h);
    height: auto;
    z-index: 500;
  }
  .topbar-right {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: nowrap; /* Change to nowrap but handle overflow */
  }
  @media (max-width: 1300px) {
    .topbar-right span { display: none; }
    .search-bar { width: 140px; }
  }
  @media (max-width: 1100px) {
    .topbar-right .btn-ghost, .topbar-right .currency-toggle { display: none; }
    .search-bar { width: 120px; }
  }
  
  .topbar-title {
    font-family:'Playfair Display',serif;font-size:22px;
    background:linear-gradient(135deg,var(--green-800),var(--green-600));
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  }

  /* Stat cards — animated */
  .stat-card {
    position:relative;overflow:hidden;cursor:default;
    transition:var(--transition-smooth);
    box-shadow:var(--card-shadow);border:1px solid rgba(255,255,255,0.8);
    min-width: 0;
  }
  .stat-card::before {
    content:'';position:absolute;top:-50%;right:-30%;
    width:120px;height:120px;border-radius:50%;
    background:radial-gradient(circle,rgba(56,158,104,0.08) 0%,transparent 70%);
    transition:var(--transition-smooth);
  }
  .stat-card:hover { transform:translateY(-4px);box-shadow:var(--card-shadow-hover); }
  .stat-card:hover::before { transform:scale(1.5); }
  .stat-card .stat-value { transition:var(--transition-smooth); }
  .stat-card:hover .stat-value { transform:scale(1.05); }
  .stat-green::before { background:radial-gradient(circle,rgba(56,158,104,0.12),transparent 70%); }
  .stat-amber::before { background:radial-gradient(circle,rgba(201,124,26,0.1),transparent 70%); }
  .stat-earth::before { background:radial-gradient(circle,rgba(122,92,66,0.1),transparent 70%); }
  .stat-blue::before { background:radial-gradient(circle,rgba(30,111,172,0.1),transparent 70%); }

  /* Animated counter effect */
  .stat-value { font-family:'Playfair Display',serif; }

  /* Cards */
  .card {
    box-shadow:var(--card-shadow);border:1px solid rgba(56,158,104,0.08);
    transition:var(--transition-smooth);
  }
  .card:hover { box-shadow:var(--card-shadow-hover); }

  /* ===== DASHBOARD HERO BANNER ===== */
  .dashboard-hero {
    position:relative;border-radius:16px;overflow:hidden;
    margin-bottom:24px;min-height:220px;
    background:linear-gradient(135deg,var(--green-900),var(--green-700));
    box-shadow:0 8px 40px rgba(26,58,42,0.3);
  }
  .hero-video {
    position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0.35;
  }
  .hero-bg-img {
    position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0.4;
    transition:transform 8s ease;
  }
  .dashboard-hero:hover .hero-bg-img { transform:scale(1.05); }
  .hero-overlay {
    position:absolute;inset:0;
    background:linear-gradient(135deg,rgba(13,35,24,0.85) 0%,rgba(30,77,53,0.7) 50%,rgba(45,125,82,0.4) 100%);
  }
  .hero-content {
    position:relative;z-index:1;height:100%;display:flex;flex-direction:column;
    justify-content:flex-end;padding:24px 28px;
  }
  .hero-season-badge {
    display:inline-flex;align-items:center;gap:6px;
    background:rgba(56,158,104,0.25);border:1px solid rgba(134,212,164,0.3);
    padding:4px 12px;border-radius:20px;font-size:11px;color:var(--green-200);
    font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px;width:fit-content;
    backdrop-filter:blur(8px);
  }
  .hero-title {
    font-family:'Playfair Display',serif;font-size:32px;color:#fff;
    line-height:1.15;margin-bottom:8px;text-shadow:0 2px 20px rgba(0,0,0,0.4);
  }
  .hero-title span { color:var(--green-300); }
  .hero-meta {
    display:flex;gap:20px;flex-wrap:wrap;
  }
  .hero-meta-item {
    display:flex;align-items:center;gap:6px;font-size:12.5px;color:rgba(255,255,255,0.8);
  }
  .hero-meta-item .dot { width:6px;height:6px;border-radius:50%;background:var(--green-400); }
  .hero-particles {
    position:absolute;inset:0;pointer-events:none;overflow:hidden;
  }
  .particle {
    position:absolute;width:3px;height:3px;border-radius:50%;
    background:rgba(134,212,164,0.6);animation:float linear infinite;
  }
  @keyframes float{
    0%{transform:translateY(100%) translateX(0);opacity:0}
    10%{opacity:1}
    90%{opacity:1}
    100%{transform:translateY(-100px) translateX(20px);opacity:0}
  }

  /* ===== FARMING IMAGE CARDS ===== */
  .farm-photo-strip {
    display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;
  }
  .farm-photo-card {
    border-radius:12px;overflow:hidden;height:110px;position:relative;cursor:pointer;
    box-shadow:0 4px 16px rgba(26,58,42,0.15);
    transition:var(--transition-smooth);
  }
  .farm-photo-card:hover { transform:scale(1.03);box-shadow:0 8px 32px rgba(26,58,42,0.25); }
  .farm-photo-card img {
    width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease;
  }
  .farm-photo-card:hover img { transform:scale(1.08); }
  .farm-photo-overlay {
    position:absolute;inset:0;
    background:linear-gradient(to top,rgba(13,35,24,0.75) 0%,transparent 60%);
    display:flex;align-items:flex-end;padding:10px 12px;
  }
  .farm-photo-label {
    font-size:11.5px;font-weight:600;color:#fff;letter-spacing:.03em;
    text-shadow:0 1px 4px rgba(0,0,0,0.5);
  }

  /* ===== VIDEO WIDGET ===== */
  .video-insight-card {
    position:relative;border-radius:14px;overflow:hidden;
    background:var(--green-900);height:160px;cursor:pointer;
    box-shadow:0 6px 28px rgba(26,58,42,0.25);
    transition:var(--transition-smooth);
  }
  .video-insight-card:hover { transform:translateY(-3px);box-shadow:0 12px 40px rgba(26,58,42,0.35); }
  .video-insight-card video {
    width:100%;height:100%;object-fit:cover;opacity:0.5;
  }
  .video-overlay {
    position:absolute;inset:0;
    background:linear-gradient(135deg,rgba(13,35,24,0.85),rgba(30,77,53,0.5));
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  }
  .play-btn {
    width:52px;height:52px;border-radius:50%;
    background:rgba(255,255,255,0.15);border:2px solid rgba(255,255,255,0.4);
    display:flex;align-items:center;justify-content:center;font-size:18px;
    transition:var(--transition-smooth);backdrop-filter:blur(4px);
  }
  .video-insight-card:hover .play-btn {
    background:rgba(56,158,104,0.4);border-color:var(--green-300);
    transform:scale(1.1);
  }
  .video-label {
    font-size:13px;font-weight:600;color:#fff;text-align:center;
    text-shadow:0 1px 6px rgba(0,0,0,0.5);
  }

  /* ===== SECTION HERO HEADERS ===== */
  .page-hero {
    position:relative;border-radius:14px;overflow:hidden;
    margin-bottom:24px;padding:28px 32px;
    background:linear-gradient(135deg,var(--green-900),var(--green-700));
  }
  .page-hero-bg {
    position:absolute;inset:0;background-size:cover;background-position:center;
    opacity:0.15;
  }
  .page-hero-overlay {
    position:absolute;inset:0;
    background:linear-gradient(90deg,rgba(13,35,24,0.9) 0%,rgba(30,77,53,0.7) 100%);
  }
  .page-hero-content { position:relative;z-index:1; }
  .page-hero .section-title { color:#fff;margin-bottom:4px; }
  .page-hero .section-desc { color:var(--green-200);margin-bottom:0;opacity:0.85; }
  .page-hero-icon {
    position:absolute;right:32px;top:50%;transform:translateY(-50%);
    font-size:80px;opacity:0.12;line-height:1;
  }

  /* ===== ENHANCED PLOT CARDS ===== */
  .plot-card {
    background:linear-gradient(135deg,#fff 0%,var(--green-50) 100%);
    transition:var(--transition-smooth);box-shadow:var(--card-shadow);
    position:relative;overflow:hidden;
  }
  .plot-card::after {
    content:'';position:absolute;top:0;right:0;width:60px;height:60px;
    background:radial-gradient(circle,rgba(56,158,104,0.1),transparent);
    border-radius:0 12px 0 60px;
  }
  .plot-card:hover { transform:translateY(-6px);box-shadow:var(--card-shadow-hover);border-color:var(--green-300); }

  /* ===== ANIMATED PROGRESS BARS ===== */
  .progress-fill { transition:width 1.2s cubic-bezier(0.4,0,0.2,1) !important; }
  .bar-fill { transition:width 1s cubic-bezier(0.4,0,0.2,1) !important; }

  /* ===== ENHANCED BUTTONS ===== */
  .btn-primary {
    background:linear-gradient(135deg,var(--green-700),var(--green-600));
    box-shadow:0 4px 14px rgba(45,125,82,0.35);
    transition:var(--transition-smooth);position:relative;overflow:hidden;
  }
  .btn-primary::before {
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,rgba(255,255,255,0.1),transparent);
    opacity:0;transition:opacity 0.2s;
  }
  .btn-primary:hover { transform:translateY(-2px);box-shadow:0 6px 20px rgba(45,125,82,0.5);background:linear-gradient(135deg,var(--green-600),var(--green-500)); }
  .btn-primary:hover::before { opacity:1; }
  .btn-ai {
    background:linear-gradient(135deg,#0d2318,var(--green-700));
    box-shadow:0 4px 14px rgba(13,35,24,0.4);}
  .btn-ai:hover { box-shadow:0 6px 20px rgba(13,35,24,0.6);transform:translateY(-1px); }

  /* ===== ENHANCED WEATHER CARD ===== */
  .weather-main {
    background:linear-gradient(135deg,#0d2318 0%,#1e4d35 50%,var(--green-600) 100%);
    position:relative;overflow:hidden;
  }
  .weather-main::before {
    content:'🌤';font-size:90px;position:absolute;right:-10px;top:-10px;
    opacity:0.08;line-height:1;animation:weatherFloat 6s ease-in-out infinite;
  }
  @keyframes weatherFloat{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-8px) rotate(5deg)}}

  /* ===== AI ADVISOR ENHANCEMENTS ===== */
  .msg-bubble.ai {
    background:linear-gradient(135deg,#fff,var(--green-50));
    border:1px solid rgba(56,158,104,0.15);
    box-shadow:0 2px 12px rgba(26,58,42,0.06);
  }
  .msg-avatar.ai-av {
    background:linear-gradient(135deg,var(--green-800),var(--green-600));
    box-shadow:var(--glow-green);font-size:11px;
  }
  .quick-prompt {
    transition:var(--transition-smooth);
  }
  .quick-prompt:hover { transform:translateY(-1px);box-shadow:0 4px 12px rgba(45,125,82,0.15); }

  /* ===== EXPORT CARDS ===== */
  .export-card {
    background:linear-gradient(135deg,#fff,var(--green-50));
    box-shadow:var(--card-shadow);
  }
  .export-card:hover {
    background:linear-gradient(135deg,var(--green-50),#fff);
    box-shadow:var(--card-shadow-hover);border-color:var(--green-400);
  }

  /* ===== TABLE ENHANCEMENTS ===== */
  tbody tr {
    transition:background 0.2s ease;animation:rowFade 0.4s ease forwards;
    opacity:0;
  }
  @keyframes rowFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
  tbody tr:nth-child(1){animation-delay:0.05s}
  tbody tr:nth-child(2){animation-delay:0.1s}
  tbody tr:nth-child(3){animation-delay:0.15s}
  tbody tr:nth-child(4){animation-delay:0.2s}
  tbody tr:nth-child(5){animation-delay:0.25s}
  tbody tr:nth-child(6){animation-delay:0.3s}
  tr:hover td { background:linear-gradient(90deg,var(--green-50),rgba(230,247,236,0.5)) !important; }

  /* ===== BADGE ENHANCEMENTS ===== */
  .badge {
    box-shadow:0 1px 4px rgba(0,0,0,0.08);letter-spacing:.02em;
    transition:transform 0.15s;
  }
  .badge:hover { transform:scale(1.05); }

  /* ===== MODAL ENHANCEMENTS ===== */
  .modal-overlay { backdrop-filter:blur(8px);background:rgba(0,0,0,0.5); }
  .modal {
    box-shadow:0 24px 80px rgba(0,0,0,0.25);border:1px solid rgba(255,255,255,0.5);
    animation:modalSlide 0.3s cubic-bezier(0.34,1.56,0.64,1);
  }
  @keyframes modalSlide{from{opacity:0;transform:scale(0.92) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}
  .modal-title { font-family:'Playfair Display',serif; }
  .form-control { transition:var(--transition-smooth); }
  .form-control:focus { box-shadow:0 0 0 3px rgba(56,158,104,0.15);border-color:var(--green-500); }

  /* ===== TOAST ENHANCEMENT ===== */
  .toast {
    background:linear-gradient(135deg,var(--green-900),var(--green-700));
    box-shadow:0 8px 32px rgba(13,35,24,0.4),var(--glow-green);
    border:1px solid rgba(134,212,164,0.2);
    border-radius:12px;
  }

  /* ===== FARM BADGE ANIMATED ===== */
  .farm-badge {
    background:linear-gradient(135deg,rgba(56,158,104,0.15),rgba(56,158,104,0.08));
    border:1px solid rgba(134,212,164,0.15);position:relative;overflow:hidden;
    display: flex;
    flex-direction: column;
    gap: 4px;
  }
  .farm-badge::before {
    content:'🌾';position:absolute;right:-5px;bottom:-5px;font-size:36px;opacity:0.1;
  }
  .role-pill {
    display: inline-block;
    align-self: flex-start;
    margin-top: 4px;
    font-size: 10px;
    padding: 2px 8px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.1);
    font-weight: 600;
  }

  /* ===== WEATHER STRIP MINI ===== */
  #dash-weather-strip > div {
    background:linear-gradient(135deg,#fff,var(--green-50));
    box-shadow:var(--card-shadow);border:1px solid rgba(56,158,104,0.1) !important;
  }

  /* ===== ACTIVITY ITEMS ===== */
  .activity-item { transition:background 0.2s;border-radius:8px;padding:10px 8px; }
  .activity-item:hover { background:var(--green-50); }

  /* ===== SMS COMPOSE ===== */
  .sms-compose,.sms-log { box-shadow:var(--card-shadow); }
  .recipient-chip {
    animation:chipPop 0.2s cubic-bezier(0.34,1.56,0.64,1);
  }
  @keyframes chipPop{from{transform:scale(0.5);opacity:0}to{transform:scale(1);opacity:1}}

  /* ===== CROP STAGE INDICATOR ===== */
  .stage-track {
    display:flex;gap:3px;margin-top:6px;
  }
  .stage-dot {
    flex:1;height:4px;border-radius:2px;background:var(--gray-100);
    transition:background 0.4s ease;
  }
  .stage-dot.filled { background:var(--green-500); }

  /* ===== LOADING ANIMATION ===== */
  .skeleton {
    background:linear-gradient(90deg,var(--gray-100) 25%,var(--green-50) 50%,var(--gray-100) 75%);
    background-size:200% 100%;animation:skeleton 1.5s infinite;border-radius:6px;
  }
  @keyframes skeleton{0%{background-position:200% 0}100%{background-position:-200% 0}}
  .skeleton-row{padding:12px 0;border-bottom:1px solid var(--border)}
  .page-loading{position:fixed;top:0;left:0;right:0;height:3px;z-index:9999;pointer-events:none}
  .page-loading .bar{height:100%;background:linear-gradient(90deg,var(--leaf),var(--harvest));width:0;border-radius:0 3px 3px 0;transition:width .4s ease}
  .page-loading.active .bar{width:60%}
  .page-loading.done .bar{width:100%;opacity:0;transition:width .2s ease,opacity .3s .2s}

  /* ===== SCROLLBAR STYLING ===== */
  ::-webkit-scrollbar{width:6px;height:6px}
  ::-webkit-scrollbar-track{background:var(--green-50)}
  ::-webkit-scrollbar-thumb{background:var(--green-300);border-radius:3px}
  ::-webkit-scrollbar-thumb:hover{background:var(--green-500)}

  /* ===== SECTION HEADER IMG CARDS ===== */
  .crop-img-row {
    display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px;
  }
  .crop-img-card {
    border-radius:10px;overflow:hidden;height:90px;position:relative;
    box-shadow:0 3px 12px rgba(26,58,42,0.12);transition:var(--transition-smooth);
  }
  .crop-img-card:hover{transform:scale(1.04);}
  .crop-img-card img{width:100%;height:100%;object-fit:cover;}
  .crop-img-card .cic-label{
    position:absolute;bottom:0;left:0;right:0;
    background:linear-gradient(to top,rgba(13,35,24,0.8),transparent);
    padding:6px 8px;font-size:11px;color:#fff;font-weight:600;
  }

  /* ===== REPORT CARDS ENHANCED ===== */
  .report-card {
    box-shadow:var(--card-shadow);
    background:linear-gradient(135deg,#fff,var(--green-50));
    transition:var(--transition-smooth);
  }
  .report-card:hover{transform:translateY(-3px);box-shadow:var(--card-shadow-hover);}

  /* ===== FLOATING ACTION INDICATOR ===== */
  .live-badge {
    display:inline-flex;align-items:center;gap:5px;
    background:rgba(56,158,104,0.1);border:1px solid rgba(56,158,104,0.25);
    padding:3px 10px;border-radius:20px;font-size:11px;color:var(--green-700);font-weight:600;
  }
  .live-dot {
    width:6px;height:6px;border-radius:50%;background:var(--green-500);
    animation:livePulse 2s ease-in-out infinite;
  }
  @keyframes livePulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(0.7)}}

  /* ===== PAGE TRANSITION ===== */
  .page.active {
    animation:pageReveal 0.4s cubic-bezier(0.4,0,0.2,1);
  }
  @keyframes pageReveal{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

  /* ===== NOTIFICATION COUNTER ===== */
  .nav-badge {
    background:var(--amber-600);color:#fff;font-size:10px;font-weight:700;
    padding:1px 6px;border-radius:10px;margin-left:auto;
  }
  
  /* ===== SIDEBAR & COLLAPSE ===== */
  .sidebar {
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    width: 260px;
    background: var(--green-900);
    color: #fff;
    z-index: 1000;
    transition: width 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    flex-direction: column;
    overflow-x: hidden;
  }

  .sidebar.collapsed {
    width: 80px;
  }

  .sidebar.collapsed .sidebar-logo h1,
  .sidebar.collapsed .sidebar-logo p,
  .sidebar.collapsed .nav-section,
  .sidebar.collapsed .nav-item {
    font-size: 0;
    padding-left: 0;
    justify-content: center;
  }
  
  .sidebar.collapsed .nav-item .icon {
    margin-right: 0;
    font-size: 20px;
  }

  .sidebar.collapsed .sidebar-footer,
  .sidebar.collapsed .sidebar-ticker {
    display: none;
  }

  .sidebar-collapse-btn {
    position: absolute;
    right: 10px;
    top: 20px;
    width: 24px;
    height: 24px;
    border-radius: 6px;
    border: 1px solid rgba(255,255,255,0.1);
    background: rgba(255,255,255,0.05);
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    transition: var(--transition-smooth);
  }

  .sidebar.collapsed .sidebar-collapse-btn {
    right: 50%;
    transform: translateX(50%);
  }

  .sidebar.collapsed .collapse-icon {
    transform: rotate(180deg);
  }

  .main {
    margin-left: 260px;
    transition: margin-left 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  }

  .sidebar.collapsed + .main {
    margin-left: 80px;
  }

  /* ===== MOBILE RESPONSIVENESS IMPROVEMENTS ===== */
  @media (max-width: 1024px) {
    .sidebar { width: 260px; }
    .main { margin-left: 260px; }
    .stats-grid { grid-template-columns: repeat(2, 1fr); }
  }

  @media (max-width: 768px) {
    .sidebar {
      left: -260px;
      width: 260px !important;
    }
    .sidebar.active {
      left: 0;
    }
    .main {
      margin-left: 0 !important;
    }
    .sidebar-collapse-btn {
      display: none; /* Use the mobile hamburger instead */
    }
    .topbar-right {
      gap: 8px;
    }
    .search-bar-wrap {
      display: none; /* Hide search on small screens or move to menu */
    }
    .currency-toggle {
      transform: scale(0.9);
    }
    .grid-2 {
      grid-template-columns: 1fr;
    }
    .stats-grid {
      grid-template-columns: 1fr;
    }
    .hero-title {
      font-size: 28px;
    }
  }

  @media (max-width: 480px) {
    .topbar-right span, .topbar-right .btn-ghost {
      display: none; /* Hide non-essential items on tiny screens */
    }
    .topbar-right .btn-primary {
      padding: 6px 12px;
      font-size: 12px;
    }
    .mobile-dock { padding:6px; gap:2px; max-width:100vw; }
    .mobile-dock .dock-btn { min-width:52px; padding:4px 4px; font-size:8px; }
    .mobile-dock .dock-icon { font-size:12px; }
    .dock-scroll { gap:1px; }
  }

  /* ===== SPLASH SCREEN ===== */
  #splash {
    position:fixed;inset:0;background:var(--green-950);z-index:20000;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    transition:opacity 0.6s cubic-bezier(0.4,0,0.2,1), visibility 0.6s;
    overflow: hidden;
  }
  #splash.hide { opacity:0;visibility:hidden; }
  .splash-logo {
    width:90px;height:90px;border-radius:28px;
    background:linear-gradient(135deg,var(--green-600),var(--green-400));
    display:flex;align-items:center;justify-content:center;font-size:44px;
    box-shadow:0 0 60px rgba(56,158,104,0.5);
    animation:splashLogoAnim 1s cubic-bezier(0.34,1.56,0.64,1);margin-bottom:24px;
  }
  @keyframes splashLogoAnim{from{transform:scale(0.3);opacity:0}to{transform:scale(1);opacity:1}}
  .splash-title { font-family:'Playfair Display',serif;font-size:40px;color:#fff;animation:splashFadeUp 0.8s 0.2s both;text-align:center; }
  .splash-sub { font-size:14px;color:var(--green-300);margin-top:8px;letter-spacing:.06em;animation:splashFadeUp 0.8s 0.35s both; }
  .splash-bar-wrap { width:200px;height:3px;background:rgba(255,255,255,0.1);border-radius:2px;margin-top:36px;overflow:hidden;animation:splashFadeUp 0.8s 0.5s both; }
  .splash-bar { height:100%;border-radius:2px;width:0%;background:linear-gradient(90deg,var(--green-400),var(--green-200));animation:splashProgress 3s 0.6s cubic-bezier(0.4,0,0.2,1) forwards; }
  @keyframes splashProgress{to{width:100%}}
  @keyframes splashFadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

  /* ===== DARK MODE ===== */
  body.dark-mode { background:#0f1f17;color:#d4e8da; }
  body.dark-mode .main { background:#0f1f17; }
  body.dark-mode .topbar { background:#1a2e22;border-color:#243d2e; }
  body.dark-mode .card { background:#1a2e22;border-color:#243d2e; }
  body.dark-mode .stat-card { background:#1a2e22;border-color:#243d2e; }
  body.dark-mode table { color:#b8d4c0; }
  body.dark-mode th { background:#243d2e;color:var(--green-300); }
  body.dark-mode td { border-color:#243d2e; }
  body.dark-mode tr:hover td { background:#1e3428 !important; }
  body.dark-mode .modal { background:#1a2e22;border-color:#243d2e; }
  body.dark-mode .form-control { background:#0f1f17;border-color:#2d4a38;color:#d4e8da; }
  body.dark-mode .btn-secondary { background:#243d2e;color:#b8d4c0;border-color:#2d4a38; }
  body.dark-mode .btn-ghost { background:transparent;color:#b8d4c0;border-color:#2d4a38; }
  body.dark-mode .msg-bubble.ai { background:#1a2e22;border-color:#243d2e;color:#d4e8da; }
  body.dark-mode .chat-input { background:#1a2e22;border-color:#2d4a38;color:#d4e8da; }
  body.dark-mode .quick-prompt { background:#1a2e22;border-color:#2d4a38;color:#b8d4c0; }
  body.dark-mode .card-title { color:#d4e8da; }
  body.dark-mode .weather-forecast { background:#1a2e22;border-color:#243d2e; }
  body.dark-mode .forecast-day { background:#243d2e; }
  body.dark-mode .export-card { background:#1a2e22;border-color:#243d2e; }
  body.dark-mode .report-card { background:#1a2e22;border-color:#243d2e; }
  body.dark-mode .plot-card { background:#1a2e22;border-color:#243d2e; }
  body.dark-mode #dash-weather-strip > div { background:#1a2e22 !important; }
  body.dark-mode .season-progress-card { background:#1a2e22;border-color:#243d2e; }
  body.dark-mode .health-ring-card { background:#1a2e22;border-color:#243d2e; }
  body.dark-mode .health-ring-card .ring-label { color:#d4e8da; }
  body.dark-mode .field-map-wrap { background:#1a2e22;border-color:#243d2e; }
  body.dark-mode .search-bar { background:#1a2e22;border-color:#2d4a38;color:#d4e8da; }
  body.dark-mode .notif-panel { background:#1a2e22;border-color:#243d2e; }
  body.dark-mode .notif-item:hover { background:#243d2e; }
  body.dark-mode .notif-btn,.dark-mode .dark-toggle { background:#1a2e22;border-color:#2d4a38; }
  body.dark-mode .notif-header,.dark-mode .notif-item { border-color:#243d2e; }
  body.dark-mode .glass-card { background:rgba(26,46,34,0.7);border-color:rgba(45,74,56,0.8); }
  body.dark-mode .milestone-dot { background:#1a2e22;border-color:#2d4a38; }
  body.dark-mode .season-milestones::before { background:#2d4a38; }

  /* ============================================================
     UI/UX POLISH — Smooth Transitions, Micro-animations, Glass
     ============================================================ */

  /* 1. Smooth dark-mode body transition */
  body {
    transition: background-color 0.5s ease, color 0.4s ease;
  }
  body.dark-mode .main,
  body.dark-mode .topbar,
  body.dark-mode .card,
  body.dark-mode .stat-card,
  body.dark-mode .modal,
  body.dark-mode .form-control,
  body.dark-mode .weather-forecast,
  body.dark-mode .forecast-day,
  body.dark-mode .export-card,
  body.dark-mode .report-card,
  body.dark-mode .plot-card,
  body.dark-mode .season-progress-card,
  body.dark-mode .health-ring-card,
  body.dark-mode .field-map-wrap,
  body.dark-mode .search-bar,
  body.dark-mode .notif-panel,
  body.dark-mode .btn-secondary,
  body.dark-mode .btn-ghost,
  body.dark-mode .msg-bubble.ai,
  body.dark-mode .chat-input,
  body.dark-mode .quick-prompt {
    transition: background-color 0.5s ease, border-color 0.4s ease, color 0.4s ease;
  }

  /* 2. Card scroll-reveal initial state (set via JS, animated by IntersectionObserver) */
  .card-reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s cubic-bezier(0.4,0,0.2,1),
                transform 0.6s cubic-bezier(0.4,0,0.2,1),
                box-shadow 0.35s ease;
  }
  .card-reveal.card-visible {
    opacity: 1;
    transform: translateY(0);
  }

  /* 3. Tactile button :active states */
  .btn:active {
    transform: scale(0.96) !important;
    transition-duration: 0.05s !important;
  }
  .btn-primary:active {
    box-shadow: 0 2px 8px rgba(45,125,82,0.3) !important;
  }
  .btn-ai:active {
    box-shadow: 0 2px 8px rgba(13,35,24,0.4) !important;
  }

  /* 4. Glassmorphism table row hover */
  tbody tr {
    transition: background 0.25s ease, box-shadow 0.25s ease;
  }
  tbody tr:hover td {
    background: linear-gradient(
      90deg,
      rgba(230,247,236,0.7) 0%,
      rgba(244,251,246,0.5) 50%,
      rgba(230,247,236,0.3) 100%
    ) !important;
    backdrop-filter: blur(2px);
  }
  body.dark-mode tbody tr:hover td {
    background: linear-gradient(
      90deg,
      rgba(30,52,40,0.8) 0%,
      rgba(36,61,46,0.5) 50%,
      rgba(30,52,40,0.3) 100%
    ) !important;
  }

  /* 5. Enhanced Notification Panel — Glassmorphism */
  .notif-panel {
    background: rgba(255,255,255,0.92);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(56,158,104,0.12);
    box-shadow: 0 12px 48px rgba(26,58,42,0.18), 0 0 0 1px rgba(255,255,255,0.3) inset;
    border-radius: 14px;
    transition: opacity 0.25s ease, transform 0.25s cubic-bezier(0.34,1.56,0.64,1);
  }
  body.dark-mode .notif-panel {
    background: rgba(26,46,34,0.92);
    border-color: rgba(45,74,56,0.5);
    box-shadow: 0 12px 48px rgba(0,0,0,0.4), 0 0 0 1px rgba(45,74,56,0.3) inset;
  }

  /* 6. Auth Card Glassmorphism */
  .auth-card {
    background: rgba(255,255,255,0.85);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid rgba(255,255,255,0.5);
    box-shadow: 0 24px 80px rgba(0,0,0,0.2), 0 0 0 1px rgba(255,255,255,0.15) inset;
    border-radius: 20px;
    transition: transform 0.4s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.4s ease;
  }
  .auth-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 28px 90px rgba(0,0,0,0.24), 0 0 0 1px rgba(255,255,255,0.2) inset;
  }
  .auth-overlay {
    background: linear-gradient(160deg, rgba(13,35,24,0.92), rgba(30,77,53,0.88));
    backdrop-filter: blur(6px);
  }

  /* 7. Avatar subtle ring animation on hover */
  .avatar {
    transition: transform 0.2s ease, box-shadow 0.2s ease;
  }
  .avatar:hover {
    transform: scale(1.1);
    box-shadow: 0 0 0 3px rgba(56,158,104,0.25);
  }

  /* 8. Smoother badge hover */
  .badge {
    transition: transform 0.15s ease, box-shadow 0.15s ease;
  }
  .badge:hover {
    transform: scale(1.06);
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
  }

  /* 9. Staggered row-fade with longer stagger */
  tbody tr:nth-child(7){animation-delay:0.35s}
  tbody tr:nth-child(8){animation-delay:0.4s}
  tbody tr:nth-child(9){animation-delay:0.45s}
  tbody tr:nth-child(10){animation-delay:0.5s}

  /* 10. Splash screen shimmer overlay */
  #splash::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
      135deg,
      transparent 30%,
      rgba(134,212,164,0.06) 50%,
      transparent 70%
    );
    background-size: 200% 200%;
    animation: splashShimmer 3s ease-in-out infinite;
    pointer-events: none;
  }
  @keyframes splashShimmer {
    0% { background-position: 200% 200%; }
    100% { background-position: -200% -200%; }
  }

  /* 11. Search bar focus glow */
  .search-bar:focus {
    box-shadow: 0 0 0 3px rgba(56,158,104,0.18);
    border-color: var(--green-500);
  }

  /* 12. Smooth sidebar ticker */
  .sidebar-ticker {
    overflow: hidden;
    white-space: nowrap;
  }
  .ticker-inner {
    display: inline-block;
    animation: tickerScroll 30s linear infinite;
  }
  @keyframes tickerScroll {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
  }

  /* 13. Toast entrance micro-animation */
  .toast.show {
    animation: toastSlideIn 0.35s cubic-bezier(0.34,1.56,0.64,1);
  }
  @keyframes toastSlideIn {
    from { transform: translateY(30px) scale(0.95); opacity: 0; }
    to { transform: translateY(0) scale(1); opacity: 1; }
  }

  /* 14. Notif button pulse when unread */
  .notif-btn {
    position: relative;
    transition: transform 0.15s ease;
  }
  .notif-btn:hover {
    transform: scale(1.08);
  }
  .notif-count {
    animation: notifPulse 2s ease-in-out infinite;
  }
  @keyframes notifPulse {
    0%,100% { transform: scale(1); }
    50% { transform: scale(1.15); }
  }


  /* Dark mode toggle */
  .dark-toggle { width:36px;height:36px;border-radius:50%;border:1px solid var(--gray-300);background:#fff;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:var(--transition-smooth); }
  body.dark-mode .dark-toggle { background:#1a2e22;border-color:#2d4a38; }
  .dark-toggle:hover { transform:scale(1.1);box-shadow:0 0 12px rgba(56,158,104,0.3); }

  /* ===== NOTIFICATION PANEL ===== */
  .notif-btn { position:relative;width:36px;height:36px;border-radius:50%;border:1px solid var(--gray-300);background:#fff;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:var(--transition-smooth); }
  .notif-btn:hover { transform:scale(1.1);box-shadow:0 0 12px rgba(56,158,104,0.2); }
  .notif-count { position:absolute;top:-3px;right:-3px;width:16px;height:16px;border-radius:50%;background:var(--red-600);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;animation:notifPop 0.4s cubic-bezier(0.34,1.56,0.64,1); }
  @keyframes notifPop{from{transform:scale(0)}to{transform:scale(1)}}
  .notif-panel { position:absolute;top:calc(100% + 10px);right:0;width:320px;background:#fff;border-radius:16px;border:1px solid rgba(56,158,104,0.12);box-shadow:0 16px 60px rgba(26,58,42,0.18);z-index:300;display:none;overflow:hidden;animation:panelSlide 0.25s cubic-bezier(0.34,1.56,0.64,1); }
  .notif-panel.open { display:block; }
  @keyframes panelSlide{from{opacity:0;transform:translateY(-10px) scale(0.96)}to{opacity:1;transform:translateY(0) scale(1)}}
  .notif-header { padding:14px 18px;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;align-items:center; }
  .notif-title { font-weight:700;font-size:14px;color:var(--gray-900); }
  .notif-clear { font-size:11px;color:var(--green-600);cursor:pointer;font-weight:500; }
  .notif-clear:hover { text-decoration:underline; }
  .notif-item { display:flex;gap:12px;padding:12px 18px;border-bottom:1px solid var(--gray-100);cursor:pointer;transition:background 0.15s;align-items:flex-start; }
  .notif-item:hover { background:var(--green-50); }
  .notif-item:last-child { border-bottom:none; }
  .notif-icon-wrap { width:36px;height:36px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:16px; }
  .notif-text { font-size:12.5px;color:var(--gray-700);line-height:1.5; }
  .notif-time { font-size:10.5px;color:var(--gray-500);margin-top:2px; }
  .notif-wrapper { position:relative; }

  /* ===== CROP HEALTH RINGS ===== */
  .health-ring-wrap { display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px; }
  .health-ring-card { background:#fff;border-radius:14px;border:1px solid rgba(56,158,104,0.1);padding:18px 14px;text-align:center;box-shadow:var(--card-shadow);transition:var(--transition-smooth);cursor:pointer; }
  .health-ring-card:hover { transform:translateY(-4px);box-shadow:var(--card-shadow-hover); }
  .ring-label { font-size:13px;font-weight:600;color:var(--gray-900);margin-top:8px; }
  .ring-sub { font-size:11px;color:var(--gray-500);margin-top:3px; }

  /* ===== RAIN ANIMATION ===== */
  .rain-drop { position:absolute;width:2px;border-radius:1px;background:linear-gradient(to bottom,transparent,rgba(100,180,255,0.7));animation:rainFall linear infinite; }
  @keyframes rainFall{0%{transform:translateY(-20px);opacity:0}10%{opacity:1}90%{opacity:1}100%{transform:translateY(180px);opacity:0}}
  .sun-glow { position:absolute;right:20px;top:15px;width:50px;height:50px;border-radius:50%;background:radial-gradient(circle,rgba(255,220,50,0.9),rgba(255,180,0,0.3),transparent);animation:sunPulse 3s ease-in-out infinite; }
  @keyframes sunPulse{0%,100%{transform:scale(1);opacity:0.8}50%{transform:scale(1.2);opacity:1}}

  /* ===== AI ADVISOR HERO ===== */
  .ai-hero { background:linear-gradient(135deg,#0d2318 0%,#1a3a2a 50%,#256642 100%);border-radius:16px;padding:28px 32px;margin-bottom:20px;position:relative;overflow:hidden; }
  .ai-hero::before { content:'';position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1416879595882-3373a0480b5b?w=800&q=40') center/cover;opacity:0.08; }
  .ai-hero-content { position:relative;z-index:1;display:flex;align-items:center;gap:20px; }
  .ai-avatar-large { width:72px;height:72px;border-radius:20px;flex-shrink:0;background:linear-gradient(135deg,var(--green-600),var(--green-400));display:flex;align-items:center;justify-content:center;font-size:34px;box-shadow:0 0 40px rgba(56,158,104,0.4);animation:aiGlow 3s ease-in-out infinite; }
  @keyframes aiGlow{0%,100%{box-shadow:0 0 20px rgba(56,158,104,0.3)}50%{box-shadow:0 0 50px rgba(56,158,104,0.6)}}
  .ai-hero-text h2 { font-family:'Playfair Display',serif;font-size:22px;color:#fff;margin-bottom:4px; }
  .ai-hero-text p { font-size:13px;color:var(--green-200);line-height:1.6; }
  .ai-status-dot { display:inline-flex;align-items:center;gap:6px;background:rgba(56,158,104,0.2);border:1px solid rgba(134,212,164,0.3);padding:4px 10px;border-radius:20px;font-size:11px;color:var(--green-300);margin-top:8px; }

  /* ===== SEASON PROGRESS ===== */
  .season-progress-card { background:#fff;border-radius:14px;border:1px solid rgba(56,158,104,0.1);padding:20px 24px;margin-bottom:24px;box-shadow:var(--card-shadow); }
  .season-milestones { display:flex;justify-content:space-between;margin-top:16px;position:relative; }
  .season-milestones::before { content:'';position:absolute;top:14px;left:0;right:0;height:3px;background:var(--gray-100);z-index:0; }
  .season-track { position:absolute;top:14px;left:0;height:3px;background:linear-gradient(90deg,var(--green-500),var(--green-300));z-index:1;transition:width 1.5s cubic-bezier(0.4,0,0.2,1);border-radius:2px; }
  .milestone { display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;z-index:2; }
  .milestone-dot { width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;border:2px solid var(--gray-200);background:#fff;transition:var(--transition-smooth); }
  .milestone-dot.done { background:var(--green-500);border-color:var(--green-500);color:#fff; }
  .milestone-dot.current { background:#fff;border-color:var(--green-500);box-shadow:0 0 0 4px rgba(56,158,104,0.2);animation:milestonePulse 2s ease-in-out infinite; }
  @keyframes milestonePulse{0%,100%{box-shadow:0 0 0 4px rgba(56,158,104,0.2)}50%{box-shadow:0 0 0 8px rgba(56,158,104,0.1)}}
  .milestone-label { font-size:10px;color:var(--gray-500);text-align:center;max-width:60px;font-weight:500; }
  .milestone-date { font-size:9.5px;color:var(--gray-400); }

  /* ===== QUICK ACTIONS DOCK ===== */
  /* ===== SEARCH BAR ===== */
  .search-bar-wrap { position:relative; }
  .search-bar { padding:7px 14px 7px 36px;border-radius:20px;border:1px solid var(--gray-300);font-size:13px;font-family:'DM Sans',sans-serif;background:#f7faf8;width:200px;transition:var(--transition-smooth);color:var(--gray-900); }
  .search-bar:focus { outline:none;border-color:var(--green-400);width:260px;background:#fff;box-shadow:0 0 0 3px rgba(56,158,104,0.1); }
  .search-icon { position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:13px;color:var(--gray-500);pointer-events:none; }

  /* ===== SIDEBAR TICKER ===== */
  .sidebar-ticker { padding:10px 16px;font-size:10.5px;color:var(--green-500);letter-spacing:.03em;border-top:1px solid rgba(255,255,255,0.06);overflow:hidden;white-space:nowrap; }
  .sidebar-ticker { flex-shrink:0; }
  .ticker-inner { display:inline-block;animation:tickerScroll 18s linear infinite; }
  @keyframes tickerScroll{from{transform:translateX(100%)}to{transform:translateX(-100%)}}

  /* ===== FIELD MAP ===== */
  .field-map-wrap { background:#fff;border-radius:14px;border:1px solid rgba(56,158,104,0.1);padding:20px;margin-bottom:20px;box-shadow:var(--card-shadow); }

  /* ===== GLASS CARD ===== */
  .glass-card { background:rgba(255,255,255,0.7);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.9);box-shadow:0 8px 32px rgba(26,58,42,0.1); }

  /* ===== DESKTOP COMPACT MODE (100% ZOOM FIT) ===== */
  @media (min-width: 901px) and (max-width: 1700px) {
    :root { --sidebar-w:210px; --header-h:58px; }
    .main { padding-bottom:120px; }
    .topbar { padding:0 14px; }
    .topbar-title { font-size:17px; }
    .topbar-right { gap:6px; }
    .topbar-right > span { display:none; }
    .search-bar { width:150px; font-size:12px; }
    .search-bar:focus { width:190px; }
    .btn { padding:6px 12px; font-size:12px; }
    .btn-sm { padding:4px 10px; font-size:11px; }

    .page { padding:14px 16px; }
    .card, .stat-card, .season-progress-card, .weather-forecast, .sms-compose, .sms-log, .export-card, .export-preview {
      padding:14px;
    }
    .card-title { font-size:14px; }
    .card-sub, .stat-meta, .section-desc { font-size:11px; }
    .section-title { font-size:18px; margin-bottom:4px; }

    .dashboard-hero { height:170px; margin-bottom:14px; }
    .hero-content { padding:14px 16px; }
    .hero-title { font-size:23px; margin-bottom:6px; }
    .hero-meta { gap:10px; }
    .hero-meta-item { font-size:11px; }

    .farm-photo-strip { grid-template-columns:repeat(2,1fr); gap:10px; margin-bottom:14px; }
    .farm-photo-card { height:86px; }
    .farm-photo-label { font-size:10.5px; }

    .stats-grid, .health-ring-wrap { grid-template-columns:repeat(2,1fr); gap:10px; margin-bottom:14px; }
    .stat-value { font-size:22px; }
    .grid-2 { gap:12px; }
    .grid-3 { grid-template-columns:1fr 1fr; gap:10px; }
    .video-insight-card { height:132px; }

    th, td { padding:8px 10px; }
    table { font-size:12.5px; }

    .mobile-dock { bottom:12px; padding:6px; max-width:100vw; gap:2px; }
    .mobile-dock .dock-btn { min-width:56px; padding:5px 5px; font-size:8.5px; }
    .mobile-dock .dock-icon { font-size:13px; }
  }

  /* ===== SHORT SCREEN SIDEBAR FIT ===== */
  @media (max-height: 900px) {
    .sidebar-logo { padding:14px 14px 12px; gap:10px; }
    .logo-icon-wrap { width:36px; height:36px; font-size:18px; }
    .sidebar-logo h1 { font-size:18px; }
    .sidebar-logo p { font-size:10px; }

    .nav { padding:6px 0; }
    .nav-section { padding:8px 14px 3px; font-size:9px; }
    .nav-item { padding:7px 14px; font-size:12.5px; }
    .nav-item .icon { font-size:14px; width:14px; }

    .sidebar-footer { padding:10px 14px; }
    .farm-badge { padding:8px 10px; }
    .farm-badge .name { font-size:12px; }
    .farm-badge .sub { font-size:10px; }

    .sidebar-ticker { padding:7px 10px; font-size:9px; }
  }

  .gps-toolbar { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:10px; }
  .gps-meta { font-size:12px; color:var(--gray-500); margin-bottom:12px; }
  .gps-landscape-container {
    position:relative; height:300px; border-radius:12px; overflow:hidden;
    border:1px solid rgba(56,158,104,0.18);
    background:#1a3a2a;
    margin-bottom:12px;
  }
  #gps-leaflet-map { position:absolute; inset:0; z-index:1; }
  .gps-landscape-container .leaflet-container { background:#213f2f; }
  .gps-hud {
    position:absolute; top:10px; left:10px; z-index:5; color:#fff;
    background:rgba(13,35,24,0.55); border:1px solid rgba(134,212,164,0.25);
    border-radius:10px; padding:7px 10px; font-size:11px; backdrop-filter:blur(6px);
    pointer-events:none;
  }
  /* ===== AUTH OVERLAY ===== */
  .auth-overlay {
    position: fixed; inset: 0; z-index: 10000;
    background: url('../images/Fieldbackground.jpg') center/cover no-repeat;
    display: none; align-items: center; justify-content: center;
    padding: 20px;
    transition: background-image 0.8s ease-in-out;
  }
  .auth-overlay::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(13,35,24,0.8), rgba(30,77,53,0.6));
    z-index: 1;
  }
  .auth-overlay.active { display: flex; animation: fadeIn 0.6s ease; }
  
  .auth-card {
    position: relative;
    z-index: 2;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    width: 440px; max-width: 100%; border-radius: 24px;
    padding: 40px; box-shadow: 0 30px 80px rgba(0,0,0,0.4);
    border: 1px solid rgba(255,255,255,0.2);
  }
  .auth-header { text-align: center; margin-bottom: 24px; }
  .auth-logo { font-size: 40px; margin-bottom: 12px; }
  .auth-header h2 { font-family: 'Playfair Display', serif; font-size: 24px; color: var(--green-900); }
  .auth-header p { font-size: 13px; color: var(--gray-500); margin-top: 6px; }
  .auth-switch a:hover { text-decoration: underline !important; }
  .currency-toggle .btn.active { background: #fff !important; color: var(--green-800) !important; box-shadow: 0 2px 8px rgba(0,0,0,0.1); }

  /* ===== UI/UX POLISH BLOCK ===== */

  /* --- 1. SCROLL-ANIMATE: Initial hidden state for IntersectionObserver --- */
  .scroll-animate {
    opacity: 0;
    transform: translateY(22px);
    transition: opacity 0.55s cubic-bezier(0.4,0,0.2,1), transform 0.55s cubic-bezier(0.4,0,0.2,1);
  }
  .scroll-animate.slide-left {
    transform: translateX(-22px);
  }
  .scroll-animate.slide-right {
    transform: translateX(22px);
  }
  .scroll-animate.visible {
    opacity: 1;
    transform: translate(0,0);
  }

  /* Stagger delays for groups of cards */
  .scroll-animate:nth-child(2) { transition-delay: 0.07s; }
  .scroll-animate:nth-child(3) { transition-delay: 0.14s; }
  .scroll-animate:nth-child(4) { transition-delay: 0.21s; }
  .scroll-animate:nth-child(5) { transition-delay: 0.28s; }
  .scroll-animate:nth-child(6) { transition-delay: 0.35s; }

  /* --- 2. BUTTON ACTIVE/TACTILE PRESS STATE --- */
  .btn:active,
  .btn-primary:active,
  .btn-secondary:active,
  .btn-ghost:active,
  .btn-ai:active {
    transform: scale(0.97) translateY(1px) !important;
    box-shadow: none !important;
    transition: transform 0.08s ease, box-shadow 0.08s ease !important;
  }
  /* Quick-action dock buttons */
  .dock-btn:active,
  .footer-btn:active,
  .quick-prompt:active {
    transform: scale(0.95) !important;
    transition: transform 0.08s ease !important;
  }
  /* Card header action */
  .card-header-action:active { opacity: 0.6; transition: opacity 0.1s; }

  /* --- 3. ENHANCED MODAL BACKDROP & SLIDE --- */
  .modal-overlay {
    backdrop-filter: blur(12px) saturate(1.5);
    -webkit-backdrop-filter: blur(12px) saturate(1.5);
    background: rgba(0,0,0,0.52);
    transition: opacity 0.25s ease, backdrop-filter 0.25s ease;
  }
  .modal {
    animation: modalBouncySlide 0.38s cubic-bezier(0.34,1.56,0.64,1) forwards;
    box-shadow: 0 32px 100px rgba(0,0,0,0.3), 0 0 0 1px rgba(255,255,255,0.08);
  }
  @keyframes modalBouncySlide {
    0%   { opacity:0; transform:scale(0.88) translateY(30px); }
    60%  { opacity:1; transform:scale(1.01) translateY(-4px); }
    100% { opacity:1; transform:scale(1)    translateY(0); }
  }

  /* --- 4. DARK MODE SMOOTH TRANSITION --- */
  /* Apply to body so dark mode toggle fades rather than snaps */
  body,
  body * {
    transition:
      background-color 0.35s cubic-bezier(0.4,0,0.2,1),
      border-color     0.35s cubic-bezier(0.4,0,0.2,1),
      color            0.25s cubic-bezier(0.4,0,0.2,1);
  }
  /* Exclude transitions that would hurt animations / interactions */
  body .btn,
  body .btn-primary,
  body .btn-secondary,
  body .btn-ghost,
  body .nav-item,
  body .stat-card,
  body .card,
  body .modal {
    transition:
      background-color 0.35s cubic-bezier(0.4,0,0.2,1),
      border-color     0.35s cubic-bezier(0.4,0,0.2,1),
      color            0.25s cubic-bezier(0.4,0,0.2,1),
      transform        0.2s  cubic-bezier(0.4,0,0.2,1),
      box-shadow       0.25s cubic-bezier(0.4,0,0.2,1);
  }

  /* --- 5. TABLE ROW GLASSMORPHISM HOVER --- */
  /* Replaces hard solid hover with a subtle glass sheen */
  tbody tr {
    position: relative;
    transition: background 0.2s ease, box-shadow 0.2s ease;
  }
  tbody tr:hover {
    background: rgba(56,158,104,0.06) !important;
    box-shadow: inset 4px 0 0 rgba(56,158,104,0.45);
  }
  body.dark-mode tbody tr:hover {
    background: rgba(56,158,104,0.12) !important;
    box-shadow: inset 4px 0 0 rgba(134,212,164,0.5);
  }
  /* Make the green-soft hover in dashboard-theme context also feel glassy */
  body.dash-theme tr:hover td {
    background: rgba(255,255,255,0.04) !important;
    backdrop-filter: blur(4px);
  }
  body.dark-mode.dash-theme tr:hover td {
    background: rgba(56,158,104,0.1) !important;
  }

  /* --- 6. DARK MODE SCROLLBAR --- */
  body.dark-mode ::-webkit-scrollbar-track { background: #0f1f17; }
  body.dark-mode ::-webkit-scrollbar-thumb { background: #2d4a38; }
  body.dark-mode ::-webkit-scrollbar-thumb:hover { background: var(--green-500); }

  /* --- 7. DARK MODE TOGGLE BUTTON ANIMATION --- */
  .dark-toggle {
    transition: transform 0.3s cubic-bezier(0.34,1.56,0.64,1),
                box-shadow 0.2s ease,
                background 0.35s ease !important;
  }
  .dark-toggle:active { transform: scale(0.88) rotate(20deg) !important; }

  /* ===== LUCIDE SVG ICON SYSTEM ===== */
  [data-lucide], .lucide {
    display: inline-block;
    width: 16px;
    height: 16px;
    vertical-align: middle;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
    flex-shrink: 0;
  }
  .nav-item .icon [data-lucide], .nav-item .icon .lucide {
    width: 18px;
    height: 18px;
  }
  .dock-icon [data-lucide], .dock-icon .lucide {
    width: 20px;
    height: 20px;
  }
  .page-hero-icon [data-lucide], .page-hero-icon .lucide {
    width: 64px;
    height: 64px;
    opacity: 0.15;
  }
  .play-btn [data-lucide], .play-btn .lucide {
    width: 24px;
    height: 24px;
  }
  .ex-icon [data-lucide], .ex-icon .lucide {
    width: 32px;
    height: 32px;
  }
  .ai-avatar-large [data-lucide], .ai-avatar-large .lucide {
    width: 40px;
    height: 40px;
  }
  .dark-toggle [data-lucide], .dark-toggle .lucide {
    width: 18px;
    height: 18px;
  }
  .notif-btn [data-lucide], .notif-btn .lucide {
    width: 20px;
    height: 20px;
  }
  .search-icon [data-lucide], .search-icon .lucide {
    width: 16px;
    height: 16px;
    color: var(--gray-500);
  }
  .footer-btn [data-lucide], .footer-btn .lucide {
    width: 14px;
    height: 14px;
  }
  .sb-season-icon [data-lucide], .sb-season-icon .lucide {
    width: 22px;
    height: 22px;
  }
  .close-btn [data-lucide], .close-btn .lucide {
    width: 18px;
    height: 18px;
  }
  body.dark-mode [data-lucide], body.dark-mode .lucide {
    stroke: currentColor;
  }
