@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--color-earth:#5c4033;--color-earth-light:#8b6f5e;--color-earth-dark:#3e2a1e;--color-sage:#7a8b6f;--color-sage-light:#a3b396;--color-sage-dark:#5a6b4f;--color-sand:#d4c5a9;--color-sand-light:#ede6d6;--color-cream:#faf7f2;--color-white:#fff;--color-text:#2d2418;--color-text-secondary:#6b5e50;--color-border:#e0d8cc;--color-danger:#c0392b;--color-danger-light:#f8e6e4;--color-warning:#d4a017;--color-warning-light:#fff8e1;--color-success:#5a6b4f;--color-success-light:#edf5e8;--radius:8px;--shadow-sm:0 1px 2px #0000000f;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 24px #0000001a}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--color-cream);color:var(--color-text);font-family:Inter,-apple-system,sans-serif;line-height:1.5}.app{min-height:100vh;display:flex}.hamburger{z-index:150;background:var(--color-earth-dark);color:var(--color-sand-light);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow-md);border:none;justify-content:center;align-items:center;padding:8px;transition:background .15s;display:flex;position:fixed;top:12px;left:12px}.hamburger:hover{background:var(--color-earth)}.sidebar-overlay{z-index:130;background:#0006;position:fixed;inset:0}.sidebar{background:var(--color-earth-dark);width:240px;color:var(--color-sand-light);z-index:140;flex-direction:column;padding:24px 0;transition:left .25s;display:flex;position:fixed;top:0;bottom:0;left:-240px}.sidebar.open{left:0}.sidebar-logo{border-bottom:1px solid #ffffff1a;margin-bottom:16px;padding:0 24px 24px}.sidebar-logo h1{color:var(--color-sand-light);letter-spacing:-.3px;font-size:18px;font-weight:700}.sidebar-logo span{color:var(--color-earth-light);text-transform:uppercase;letter-spacing:1px;font-size:11px}.sidebar nav{flex:1}.sidebar a{color:var(--color-sand);align-items:center;gap:12px;padding:10px 24px;font-size:14px;font-weight:400;text-decoration:none;transition:all .15s;display:flex}.sidebar a:hover{color:var(--color-white);background:#ffffff0f}.sidebar a.active{color:var(--color-white);background:#ffffff1a;font-weight:500}.sidebar a svg{opacity:.7;width:18px;height:18px}.sidebar a.active svg{opacity:1}.main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:56px 16px 16px}@media (width>=600px){.main{padding:56px 24px 24px}}@media (width>=900px){.hamburger{display:none}.sidebar{left:0}.sidebar-overlay{display:none}.main{margin-left:240px;padding:32px}}@media (width<=599px){.page-header{flex-direction:column;align-items:flex-start;gap:10px}.page-header>div{flex-wrap:wrap}.stats-grid{grid-template-columns:1fr 1fr;gap:8px}.form-row{grid-template-columns:1fr}.modal{width:95%;max-width:95%;margin:8px}.kanban{flex-direction:column}.kanban-col{min-width:100%}table{font-size:12px}th,td{padding:8px 10px}}@media (width<=899px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header h2{color:var(--color-earth-dark);font-size:24px;font-weight:600}.card{background:var(--color-white);border-radius:var(--radius);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.card-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-header h3{font-size:15px;font-weight:600}.card-body{padding:20px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--color-white);border-radius:var(--radius);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);padding:20px}.stat-card .label{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);margin-bottom:4px;font-size:12px}.stat-card .value{color:var(--color-earth-dark);font-size:28px;font-weight:700}.stat-card .sub{color:var(--color-text-secondary);margin-top:2px;font-size:12px}.stat-card.warning{border-left:3px solid var(--color-warning)}.stat-card.success{border-left:3px solid var(--color-success)}.btn{border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--color-earth);color:#fff}.btn-primary:hover{background:var(--color-earth-dark)}.btn-secondary{background:var(--color-sand-light);color:var(--color-earth-dark);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-sand)}.btn-danger{background:var(--color-danger-light);color:var(--color-danger)}.btn-danger:hover{background:var(--color-danger);color:#fff}.btn-success{background:var(--color-success-light);color:var(--color-success)}.btn-success:hover{background:var(--color-success);color:#fff}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{border-radius:var(--radius);color:var(--color-text-secondary);cursor:pointer;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;padding:7px;transition:all .15s;display:inline-flex}.btn-icon:hover{background:var(--color-sand-light);border-color:var(--color-border);color:var(--color-earth-dark)}.card{overflow-x:auto}table{border-collapse:separate;border-spacing:0;width:100%;min-width:500px}thead{z-index:1;position:sticky;top:0}th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border);background:var(--color-bg);padding:12px 16px;font-size:11px;font-weight:600}td{border-bottom:1px solid var(--color-border);vertical-align:middle;padding:14px 16px;font-size:14px;transition:background .15s}tbody tr:nth-child(2n) td{background:var(--color-cream)}tr:last-child td{border-bottom:none}tbody tr:hover td{background:color-mix(in srgb, var(--color-sage) 8%, white)}.th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;align-items:center;gap:4px;display:inline-flex}th:has(.th-sortable){cursor:pointer}th:has(.th-sortable):hover{color:var(--color-earth-dark)}.th-sortable svg{opacity:.4;flex-shrink:0}th:has(.th-sortable):hover .th-sortable svg{opacity:1}.form-group{margin-bottom:16px}.form-group label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.3px;align-items:center;gap:4px;margin-bottom:4px;font-size:12px;font-weight:500;display:flex}.info-tooltip{cursor:help;display:inline-flex;position:relative}.info-tooltip .info-icon{color:var(--color-text-secondary);opacity:.5;transition:opacity .15s}.info-tooltip:hover .info-icon{opacity:1}.info-tooltip .info-bubble{background:var(--color-text);color:var(--color-white);text-transform:none;letter-spacing:0;border-radius:var(--radius);white-space:normal;z-index:300;pointer-events:none;width:max-content;max-width:220px;padding:6px 10px;font-size:11px;font-weight:400;line-height:1.4;display:none;position:absolute;bottom:calc(100% + 6px);left:0}.info-tooltip .info-bubble:after{content:"";border:5px solid #0000;border-top-color:var(--color-text);position:absolute;top:100%;left:10px}.info-tooltip:hover .info-bubble{display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-white);width:100%;color:var(--color-text);padding:8px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-earth);outline:none;box-shadow:0 0 0 3px #5c40331a}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.modal-overlay{z-index:200;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-white);width:90%;max-width:520px;max-height:85vh;box-shadow:var(--shadow-lg);border-radius:12px;overflow-y:auto}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h3{font-size:16px;font-weight:600}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:8px;padding:16px 24px;display:flex}.badge{border-radius:12px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger)}.badge-neutral{background:var(--color-sand-light);color:var(--color-text-secondary)}.empty-state{text-align:center;color:var(--color-text-secondary);padding:48px 24px}.empty-state svg{opacity:.3;width:48px;height:48px;margin-bottom:12px}.empty-state p{font-size:14px}.toast{background:var(--color-earth-dark);color:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:300;padding:12px 20px;font-size:14px;animation:.2s slideIn;position:fixed;bottom:24px;right:24px}.toast.error{background:var(--color-danger)}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.kanban{gap:10px;padding-bottom:8px;display:flex;overflow-x:auto}.kanban-col{background:var(--color-sand-light);border-radius:var(--radius);flex-direction:column;flex:1;min-width:180px;display:flex}.kanban-col-header{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border);justify-content:space-between;align-items:center;padding:10px 12px;font-size:11px;font-weight:600;display:flex}.kanban-col-header .count{background:var(--color-border);border-radius:10px;padding:1px 7px;font-size:10px}.kanban-col-body{flex-direction:column;flex:1;gap:6px;min-height:60px;padding:8px;display:flex}.kanban-card{background:var(--color-white);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);cursor:pointer;border-radius:6px;padding:10px;transition:box-shadow .15s}.kanban-card:hover{box-shadow:var(--shadow-md)}.kanban-card .kc-title{margin-bottom:4px;font-size:13px;font-weight:600}.kanban-card .kc-tags{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.kanban-card .kc-tag{border-radius:4px;padding:1px 6px;font-size:10px;font-weight:500}.kc-tag-id{background:var(--color-earth);color:#fff}.kc-tag-recipe{background:var(--color-sage-light);color:var(--color-sage-dark)}.kc-tag-date{background:var(--color-sand);color:var(--color-earth-dark)}.kc-tag-timer{background:var(--color-warning-light);color:var(--color-warning)}.kanban-move{justify-content:space-between;margin-top:8px;display:flex}.kanban-move button{border:1px solid var(--color-border);background:var(--color-white);cursor:pointer;color:var(--color-text-secondary);border-radius:4px;padding:2px 6px;font-size:10px}.kanban-move button:hover{background:var(--color-sand-light);color:var(--color-earth-dark)}.collapsible-panel{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-white);margin-bottom:12px;overflow:hidden}.collapsible-panel-header{background:var(--color-sand-light);cursor:pointer;width:100%;color:var(--color-earth-dark);border:none;align-items:center;gap:8px;padding:12px 16px;font-family:inherit;font-size:14px;font-weight:600;transition:background .15s;display:flex}.collapsible-panel-header:hover{background:var(--color-sand)}.collapsible-panel-body{border-top:1px solid var(--color-border);padding:16px}.collapsible-panel-body table{min-width:0}.warning-banner{border-radius:var(--radius);align-items:flex-start;gap:10px;margin-bottom:12px;padding:12px 16px;font-size:13px;line-height:1.4;display:flex}.warning-banner svg{flex-shrink:0;margin-top:1px}.warning-banner-error{background:var(--color-danger-light);border:1px solid var(--color-danger);color:var(--color-danger)}.warning-banner-warning{background:var(--color-warning-light);border:1px solid var(--color-warning);color:#7a5900}.warning-banner-success{background:var(--color-success-light);border:1px solid var(--color-success);color:var(--color-success)}.llm-summary-card{background:linear-gradient(135deg, var(--color-sand-light) 0%, var(--color-white) 100%);border:1px solid var(--color-earth-light);border-left:4px solid var(--color-earth);border-radius:var(--radius);margin-bottom:16px;padding:16px 20px;font-size:14px;line-height:1.6}.llm-summary-card p{color:var(--color-text)}.llm-suggestions{background:var(--color-white);border:1px solid var(--color-border);border-left:4px solid var(--color-sage);border-radius:var(--radius);margin-bottom:16px;padding:16px 20px}.llm-suggestions ul{margin:0;padding:0;list-style:none}.llm-suggestions li{color:var(--color-text);margin-bottom:8px;padding-left:20px;font-size:13px;line-height:1.5;position:relative}.llm-suggestions li:last-child{margin-bottom:0}.llm-suggestions li:before{content:"💡";position:absolute;top:0;left:0}.forecast-table{border-collapse:collapse;width:100%;min-width:500px}.forecast-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);background:var(--color-sand-light);padding:10px 16px;font-size:11px}.forecast-table td{border-bottom:1px solid var(--color-border);padding:10px 16px;font-size:13px}.forecast-table tr:last-child td{border-bottom:none}.forecast-table tr:hover td{background:var(--color-cream)}.forecast-row-shortfall td{background:#c0392b0f}.forecast-row-shortfall:hover td{background:#c0392b1a}.csv-upload-zone{border:2px dashed var(--color-border);border-radius:var(--radius);text-align:center;padding:24px;transition:border-color .15s,background .15s}.csv-upload-zone:hover{border-color:var(--color-earth-light);background:var(--color-sand-light)}.forecast-page{max-width:100%}.forecast-tabs{border-bottom:2px solid var(--color-border);gap:4px;margin-bottom:20px;display:flex}.forecast-tab{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-family:inherit;font-size:13px;font-weight:500;transition:color .15s,border-color .15s}.forecast-tab:hover{color:var(--color-earth)}.forecast-tab.active{color:var(--color-earth-dark);border-bottom-color:var(--color-earth);font-weight:600}.forecast-tab-content{animation:.2s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.planning-page{max-width:100%}.planning-textarea{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-white);width:100%;color:var(--color-text);resize:vertical;padding:12px 16px;font-family:inherit;font-size:14px;line-height:1.5;transition:border-color .15s}.planning-textarea:focus{border-color:var(--color-earth);outline:none;box-shadow:0 0 0 3px #5c40331a}.planning-loading{color:var(--color-text-secondary);justify-content:center;align-items:center;gap:10px;padding:32px;font-size:14px;display:flex}.planning-results{margin-top:16px}.planning-cost-item{background:var(--color-sand-light);border-radius:var(--radius);text-align:center;padding:12px 16px}.planning-cost-label{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);margin-bottom:4px;font-size:11px}.planning-cost-value{color:var(--color-earth-dark);font-size:18px;font-weight:700}.spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.badge-warning{background:var(--color-warning-light);color:var(--color-warning)}@media print{.sidebar,.sidebar-overlay,.hamburger{display:none!important}.main{max-width:100%!important;margin-left:0!important;padding:0!important}.app{display:block}.planning-page form,.forecast-tabs,.forecast-manual-form,.csv-upload-zone,.btn,select,input[type=file],input[type=number],input[type=text],input[type=date]{display:none!important}.collapsible-panel-body{display:block!important}.collapsible-panel-header{pointer-events:none;border-bottom:1px solid #ccc;background:0 0!important}.card{break-inside:avoid;border:1px solid #ddd;box-shadow:none!important}.forecast-table,table{font-size:12px;min-width:0!important}.planning-results,.llm-summary-card,.llm-suggestions,.warning-banner{break-inside:avoid}.planning-loading{display:none!important}.forecast-row-shortfall td{-webkit-print-color-adjust:exact;print-color-adjust:exact;background:#fde8e5!important}}.login-page{background:linear-gradient(135deg, var(--color-sand-light) 0%, var(--color-cream) 100%);justify-content:center;align-items:center;min-height:100vh;padding:16px;display:flex}.login-card{background:var(--color-white);box-shadow:var(--shadow-lg);border:1px solid var(--color-border);border-radius:12px;width:100%;max-width:400px;padding:40px 32px}.login-header{text-align:center;margin-bottom:32px}.login-header h1{color:var(--color-earth-dark);margin-bottom:4px;font-size:22px;font-weight:700}.login-header span{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:1px;font-size:12px}.login-form{flex-direction:column;gap:4px;display:flex}.login-error{color:var(--color-danger);text-align:center;background:var(--color-danger-light);border-radius:var(--radius);margin-bottom:8px;padding:8px;font-size:13px}.login-btn{background:var(--color-earth);width:100%;color:var(--color-white);border-radius:var(--radius);cursor:pointer;border:none;margin-top:8px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:background .15s}.login-btn:hover{background:var(--color-earth-dark)}.login-btn:disabled{opacity:.6;cursor:not-allowed}@media (width<=480px){.login-card{padding:32px 20px}}.sidebar-footer{border-top:1px solid #ffffff1a;justify-content:space-between;align-items:center;gap:8px;margin-top:auto;padding:16px 24px;display:flex}.sidebar-user{color:var(--color-sand);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.btn-logout{color:var(--color-sand);border-radius:var(--radius);cursor:pointer;white-space:nowrap;background:#ffffff14;border:1px solid #ffffff1f;align-items:center;gap:4px;padding:6px 10px;font-family:inherit;font-size:12px;transition:all .15s;display:inline-flex}.btn-logout:hover{color:var(--color-white);background:#ffffff26}
