:root{
  --bg:#f5fbf8; --panel:#ffffff; --text:#14352d; --muted:#6b7f78;
  --green:#1f6f5f; --green2:#2f9c72; --line:#dcebe5; --shadow:0 12px 30px rgba(22,61,51,.12);
}
*{box-sizing:border-box}
body{margin:0;font-family:"Segoe UI",Tahoma,sans-serif;background:var(--bg);color:var(--text)}
.app-header{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:16px 22px;background:linear-gradient(135deg,#1f6f5f,#2f9c72);color:#fff}
.app-header h1{font-size:22px;margin:0 0 4px}.app-header p{margin:0;opacity:.92}.badge{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.35);border-radius:999px;padding:8px 12px;white-space:nowrap}
.layout{display:grid;grid-template-columns:minmax(0,1.35fr) 460px;gap:16px;padding:16px;height:calc(100vh - 82px)}
.map-panel,.side-panel{min-height:0}.map-panel{position:relative;background:var(--panel);border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}
#map{height:100%;width:100%}.side-panel{display:flex;flex-direction:column;gap:14px;overflow:auto}.card{background:var(--panel);border:1px solid var(--line);border-radius:22px;padding:16px;box-shadow:var(--shadow)}
.card h2{font-size:18px;margin:0 0 12px}label{display:block;font-size:13px;color:var(--muted);margin:12px 0 6px}select,input{width:100%;padding:10px 12px;border:1px solid #cfe1da;border-radius:14px;background:#fff;color:var(--text);font-size:14px;outline:none}
.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.summary-grid div{background:#f2faf6;border:1px solid #dcebe5;border-radius:16px;padding:10px}.summary-grid span{display:block;font-size:12px;color:var(--muted)}.summary-grid b{font-size:15px}.story{line-height:1.55;margin:12px 0 0;color:#304d45}.chart-card{min-height:360px;flex:1}#chart{height:330px}
.map-legend{position:absolute;left:12px;bottom:12px;z-index:500;background:#fff;border-radius:14px;padding:10px 12px;box-shadow:var(--shadow);font-size:13px}.map-legend span{display:block;margin-top:4px}.dot{display:inline-block;width:11px;height:11px;border-radius:50%;margin-right:5px}.low{background:#7fcdbb}.mid{background:#fdd56a}.high{background:#e65f5c}
.tambon-control{position:absolute;top:12px;right:12px;z-index:1100;width:340px;max-width:calc(100% - 24px);background:rgba(255,255,255,.97);border:1px solid var(--line);border-radius:16px;padding:12px;box-shadow:var(--shadow)}
.tambon-control label{margin-top:0;font-weight:600}.tambon-search-row{display:flex;gap:6px}.tambon-search-row input{padding-right:30px}.clear-search-btn{flex:0 0 38px;border:1px solid var(--line);border-radius:12px;background:#f7fcf9;color:var(--muted);font-size:20px;cursor:pointer;line-height:1}.clear-search-btn:hover{background:#eaf7ef;color:#145a32}.search-help{margin-top:6px;color:var(--muted);font-size:12px;line-height:1.35}.suggestion-box{display:none;position:absolute;top:calc(100% - 8px);left:12px;right:12px;z-index:1200;max-height:245px;overflow-y:auto;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 12px 28px rgba(0,0,0,.16)}.suggestion-item{padding:9px 10px;border-bottom:1px solid #eef5f0;cursor:pointer;font-size:14px;line-height:1.35}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover,.suggestion-item.active{background:#eaf7ef}.suggestion-main{font-weight:700;color:#145a32}.suggestion-sub{margin-top:2px;color:var(--muted);font-size:12px}

/* Crop + manual Kc responsive layout */
.option-card{overflow:hidden}
.crop-kc-layout{display:grid;grid-template-columns:2fr 1fr;gap:12px;align-items:stretch;margin-top:4px}
.crop-period-group{min-width:0}
.kc-manual-box{background:#eef8f1;border:1px solid #bfe1cf;border-radius:18px;padding:12px;margin-top:12px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.55)}
.kc-toggle-label{display:flex;align-items:center;gap:8px;margin:0 0 10px;color:#145a32;font-weight:700;line-height:1.35}
.kc-toggle-label input{width:auto;flex:0 0 auto;accent-color:var(--green)}
#kcManualInput{margin-top:0;background:#fff}
#kcManualInput:disabled{background:#edf3f0;color:#8a9a94;cursor:not-allowed}
.kc-help{font-size:12px;color:#5d746c;margin-top:7px;line-height:1.35}

@media(max-width:900px){.app-header{display:block}.badge{display:inline-block;margin-top:8px}.layout{grid-template-columns:1fr;height:auto;padding:10px}.map-panel{height:auto;display:flex;flex-direction:column;padding:10px;gap:10px;overflow:visible}.tambon-control{position:static;width:100%;max-width:none;box-shadow:none;order:1}.suggestion-box{left:10px;right:10px;top:auto;max-height:220px}.map-legend{left:20px;bottom:20px}#map{order:2;height:58vh;min-height:420px;border-radius:16px;overflow:hidden}.side-panel{overflow:visible}.summary-grid{grid-template-columns:1fr 1fr}.chart-card{min-height:330px}#chart{height:300px}}


@media(max-width:900px){
  .crop-kc-layout{grid-template-columns:2fr 1fr;gap:10px}
}

@media(max-width:620px){
  .crop-kc-layout{grid-template-columns:1fr}
  .kc-manual-box{margin-top:2px}
}


/* ---- v2: fix Firefox/Edge clipping in manual Kc box ---- */
.option-card{
  overflow:visible;
}
.crop-kc-layout{
  align-items:start;
}
.kc-manual-box{
  margin-top:12px;
  min-width:0;
  min-height:0;
  display:flex;
  flex-direction:column;
  gap:8px;
  overflow:visible;
}
.kc-toggle-label{
  margin:0;
  align-items:flex-start;
}
.kc-toggle-label input{
  margin-top:2px;
}
#kcManualInput{
  flex:0 0 auto;
  min-height:42px;
  margin:0;
}
.kc-help{
  margin-top:0;
}

@media(max-width:900px){
  .crop-kc-layout{
    grid-template-columns:minmax(0,2fr) minmax(150px,1fr);
  }
}

@media(max-width:620px){
  .crop-kc-layout{
    grid-template-columns:1fr;
  }
  .kc-manual-box{
    margin-top:2px;
  }
}
