:root{
  --bg:#f5f2ec;--panel:#fffaf2;--panel2:#ffffff;--ink:#2c2924;--muted:#766f65;--line:#e4d9ca;
  --brand:#f4a32f;--brand2:#8a5b22;--danger:#b73932;--ok:#357a38;--holiday:#ffe1df;--break:#e7f3ff;
  --weekend:#f0ede8;--sticky:#fff7ea;--shadow:0 16px 40px rgba(69,47,14,.12);
}
*{box-sizing:border-box} body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:linear-gradient(145deg,#f7efe2,#f5f2ec 35%,#fffaf2);color:var(--ink)}
button,input,select,textarea{font:inherit} button{cursor:pointer}
.app-shell{min-height:100vh;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 18px;background:rgba(255,250,242,.88);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20;backdrop-filter:blur(10px)}
.brand{display:flex;flex-direction:column;gap:2px}.brand-title{font-weight:850;font-size:20px;letter-spacing:-.02em}.brand-sub{font-size:12px;color:var(--muted)}
.tabs{display:flex;gap:8px;flex-wrap:wrap}.tab{border:1px solid var(--line);background:#fff;border-radius:999px;padding:8px 12px;color:var(--ink)}.tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.pill{border:1px solid var(--line);border-radius:999px;background:#fff;padding:7px 10px}.save-state{font-size:12px;color:var(--muted)}.mobile-savebar{display:none}.mobile-savebar-actions{display:flex;gap:8px;align-items:center}
main{padding:18px;display:flex;flex-direction:column;gap:16px}.panel{background:rgba(255,255,255,.78);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);padding:16px}.panel.tight{padding:10px}.panel-title{font-size:18px;font-weight:800;margin:0 0 10px}.muted{color:var(--muted)}.tiny{font-size:12px}.grid{display:grid;gap:14px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{width:min(460px,100%);background:#fff;border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:26px}.login-card h1{margin:0 0 6px;font-size:28px}.login-card input{width:100%;border:1px solid var(--line);border-radius:16px;padding:14px;margin-top:16px}.primary{background:var(--ink);color:white;border:0;border-radius:16px;padding:11px 15px;font-weight:700}.ghost{background:white;border:1px solid var(--line);border-radius:14px;padding:9px 12px}.danger{background:#fff;border:1px solid #e5b5b2;color:var(--danger);border-radius:14px;padding:9px 12px}.primary:hover,.ghost:hover,.danger:hover{transform:translateY(-1px)}
.kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.kpi{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:12px}.kpi b{display:block;font-size:24px}.kpi span{color:var(--muted);font-size:12px}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px;background:white;max-height:calc(100vh - 245px)}table{border-collapse:separate;border-spacing:0;width:100%;font-size:13px}th,td{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:6px;vertical-align:middle}thead th{position:sticky;top:0;background:#fff;z-index:10;font-weight:800}.sticky-col{position:sticky;left:0;background:var(--sticky);z-index:8}.sticky-col-2{position:sticky;left:210px;background:var(--sticky);z-index:8}.sticky-head{z-index:14!important}.name-col{min-width:210px;max-width:210px}.team-col{min-width:120px;max-width:120px}.sum-col{min-width:70px;text-align:right;background:#fffdf9}.day-col{min-width:76px;text-align:center}.location-row td{background:#46351f!important;color:#fff;font-weight:800}.location-row .sticky-col{background:#46351f!important;color:#fff}.weekend{background:var(--weekend)!important}.holiday{background:var(--holiday)!important}.schoolbreak{background:var(--break)!important}.today{outline:2px solid var(--brand)}
.day-head{display:flex;flex-direction:column;gap:2px;align-items:center}.day-head b{font-size:13px}.day-head span{font-size:11px;color:var(--muted)}.cell-editor{display:flex;flex-direction:column;gap:3px;min-width:66px}.cell-editor select{width:100%;border:1px solid #dfd4c3;border-radius:8px;padding:3px;background:white;font-size:12px}.cell-editor input{width:100%;border:1px solid #eee0cf;border-radius:8px;padding:3px;text-align:right;font-size:11px}.cell-editor.status select{background:#f9f0ed}.cell-editor.work select{background:#eef8ee}.cell-editor.empty{opacity:.45}.cell-editor.has-note select{border-color:var(--brand)}
.searchbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.searchbar input,.searchbar select{border:1px solid var(--line);border-radius:14px;padding:9px 11px;background:#fff}.form-table input,.form-table select{width:100%;border:1px solid var(--line);border-radius:10px;padding:7px;background:white}.form-table th{text-align:left}.note-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--brand);margin-left:4px}.drawer{position:fixed;right:18px;bottom:18px;width:min(420px,calc(100vw - 36px));background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:0 24px 70px rgba(0,0,0,.22);padding:16px;z-index:30}.drawer h3{margin:0 0 8px}.drawer label{display:flex;flex-direction:column;gap:5px;margin:10px 0}.drawer input,.drawer select,.drawer textarea{border:1px solid var(--line);border-radius:12px;padding:9px}.drawer textarea{min-height:80px}.drawer-actions{display:flex;justify-content:space-between;gap:10px;margin-top:10px}.hidden{display:none!important}.toast{position:fixed;left:50%;bottom:20px;transform:translateX(-50%);background:#2d2924;color:white;border-radius:999px;padding:10px 14px;box-shadow:var(--shadow);z-index:40}.legend{display:flex;gap:8px;flex-wrap:wrap}.legend span{border:1px solid var(--line);background:#fff;border-radius:999px;padding:5px 8px;font-size:12px}.hint{background:#fff8df;border:1px solid #ead391;color:#5a4313;border-radius:16px;padding:10px 12px}
@media (max-width:900px){

  body.mobile-plan-view{overflow:hidden}
  body.mobile-plan-view .app-shell{height:100dvh;min-height:100dvh;overflow:hidden}
  body.mobile-plan-view .topbar{display:none}
  body.mobile-plan-view.mobile-menu-open .topbar{display:flex;position:fixed;left:8px;right:8px;top:8px;z-index:90;max-height:calc(100dvh - 90px);overflow:auto;opacity:1;pointer-events:auto;border:1px solid var(--line);border-radius:18px;box-shadow:0 20px 60px rgba(0,0,0,.22);background:rgba(255,250,242,.98)}
  body.mobile-plan-view .mobile-savebar{transform:translateY(0);opacity:1;pointer-events:auto}
  body.mobile-plan-view main{height:100dvh;min-height:0;overflow:hidden;display:flex;flex-direction:column;padding:8px 8px 74px;gap:8px}
  body.mobile-plan-view .planner-controls{flex:0 0 auto;padding:8px;border-radius:16px}
  body.mobile-plan-view .planner-table-panel{flex:1 1 auto;min-height:0;padding:4px;border-radius:16px;overflow:hidden}
  body.mobile-plan-view .planner-table-wrap{height:100%;min-height:0;max-height:none;overflow:auto;border-radius:14px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
  .topbar{position:static;align-items:flex-start;flex-direction:column;gap:8px;padding:10px 12px;max-height:220px;overflow:hidden;transition:max-height .22s ease,padding .22s ease,opacity .18s ease,border-color .18s ease}
  body.mobile-chrome-hidden .topbar{max-height:0;padding-top:0;padding-bottom:0;border-bottom-color:transparent;opacity:0;pointer-events:none}
  .brand-title{font-size:18px}.brand-sub{display:none}
  .tabs{width:100%;flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px}.tab{white-space:nowrap;padding:7px 10px}
  .toolbar{width:100%;gap:8px}.toolbar .ghost{padding:7px 10px}.save-state{min-width:70px}
  .mobile-savebar{position:fixed;left:10px;right:10px;bottom:10px;z-index:60;display:flex;align-items:center;justify-content:space-between;gap:10px;background:rgba(255,250,242,.96);border:1px solid var(--line);border-radius:18px;box-shadow:0 18px 50px rgba(0,0,0,.18);padding:8px 10px;transform:translateY(calc(100% + 18px));opacity:0;pointer-events:none;transition:transform .2s ease,opacity .2s ease;backdrop-filter:blur(10px)}
  body.mobile-chrome-hidden .mobile-savebar{transform:translateY(0);opacity:1;pointer-events:auto}
  .mobile-savebar .primary,.mobile-savebar .ghost{border-radius:14px;padding:8px 11px}
  main{padding:8px 8px 74px;gap:10px}.grid.two,.grid.three,.kpis{grid-template-columns:1fr}
  .sticky-col-2{position:static}.team-col{display:none}
  .table-wrap{max-height:none}
  .name-col{min-width:150px;max-width:150px}.day-col{min-width:88px}
  .planner-controls{padding:8px}.planner-controls .kpis,.planner-controls .legend{display:none}
  .planner-controls .searchbar{gap:6px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px}.planner-controls .searchbar>*{flex:0 0 auto}
  .planner-controls .ghost{padding:8px 10px;white-space:nowrap}
  .planner-table-panel{padding:4px;border-radius:16px}.planner-table-wrap{height:calc(100dvh - 190px);min-height:220px;max-height:none;overflow:auto;border-radius:14px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
  body.mobile-chrome-hidden .planner-table-wrap{height:calc(100dvh - 86px);min-height:250px}
  .planner-table-wrap .sum-col{display:none}.planner-table-wrap .name-col{min-width:145px;max-width:145px}.planner-table-wrap .day-col{min-width:92px}
  .planner-table-wrap th,.planner-table-wrap td{padding:5px}.planner-table-wrap thead th{top:0}
  .planner-table-wrap .sticky-col{left:0;position:sticky}.planner-table-wrap .name-col{z-index:9}
  .cell-editor{min-width:82px}.cell-editor select,.cell-editor input{font-size:14px;min-height:34px;padding:5px}.cell-editor input{text-align:center}
  .drawer{right:8px;bottom:8px;width:calc(100vw - 16px);max-height:calc(100dvh - 16px);overflow:auto}
}
@media (max-width:900px) and (orientation:landscape){
  main{padding:6px 6px 68px;gap:8px}.panel{border-radius:16px}.planner-controls{padding:6px}.planner-table-wrap{height:calc(100dvh - 160px);min-height:150px}.mobile-chrome-hidden .planner-table-wrap{height:calc(100dvh - 78px);min-height:210px}.planner-table-wrap .name-col{min-width:136px;max-width:136px}.planner-table-wrap .day-col{min-width:90px}
}
@media print{.topbar,.toolbar,.searchbar,.drawer,.toast,.no-print{display:none!important}main{padding:0}.panel{box-shadow:none;border:0}.table-wrap{max-height:none;overflow:visible;border:0}body{background:#fff}th,td{font-size:10px;padding:3px}.cell-editor input{display:none}.cell-editor select{border:0;background:transparent!important;text-align:center;appearance:none}}

/* v0.1.4: mobile compact plan controls */
.mobile-inline-action,.mobile-inline-state{display:none}
@media (max-width:900px){
  body.mobile-plan-view .mobile-savebar{display:none!important}
  body.mobile-plan-view main{padding:6px 6px 6px!important;gap:6px!important}
  body.mobile-plan-view .planner-controls{padding:5px!important;border-radius:14px!important}
  body.mobile-plan-view .planner-controls .searchbar{gap:5px!important;flex-wrap:nowrap!important;overflow-x:auto!important;align-items:center!important;padding-bottom:0!important;scrollbar-width:thin}
  body.mobile-plan-view .planner-controls .searchbar>*{flex:0 0 auto}
  body.mobile-plan-view .planner-controls .pill,
  body.mobile-plan-view .planner-controls .ghost,
  body.mobile-plan-view .planner-controls .primary{font-size:13px!important;line-height:1.1!important;padding:7px 9px!important;border-radius:12px!important;min-height:36px!important;white-space:nowrap!important}
  body.mobile-plan-view .planner-controls #monthSelect{max-width:150px!important}
  body.mobile-plan-view .planner-controls #addRowBtn{max-width:190px!important;overflow:hidden!important;text-overflow:ellipsis!important}
  body.mobile-plan-view .mobile-inline-action{display:inline-flex!important;align-items:center!important;justify-content:center!important}
  body.mobile-plan-view .mobile-inline-state{display:inline-block!important;font-size:11px!important;max-width:82px!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important;color:var(--muted)!important}
  body.mobile-plan-view .planner-table-panel{padding:3px!important;border-radius:14px!important;flex:1 1 auto!important;min-height:0!important}
  body.mobile-plan-view .planner-table-wrap{height:100%!important;min-height:0!important;max-height:none!important}
}
@media (max-width:900px) and (orientation:landscape){
  body.mobile-plan-view main{padding:4px!important;gap:5px!important}
  body.mobile-plan-view .planner-controls{padding:4px!important}
  body.mobile-plan-view .planner-controls .pill,
  body.mobile-plan-view .planner-controls .ghost,
  body.mobile-plan-view .planner-controls .primary{font-size:12px!important;min-height:32px!important;padding:5px 8px!important;border-radius:11px!important}
  body.mobile-plan-view .mobile-inline-state{max-width:70px!important;font-size:10px!important}
  body.mobile-plan-view .planner-controls #monthSelect{max-width:135px!important}
  body.mobile-plan-view .planner-controls #addRowBtn{max-width:170px!important}
}
