:root{--bg:#f8f6f2;--surface:#fff;--surface-2:#f5f3ef;--gold:#c99a2e;--gold-soft:#f3dfaa;--heading:#2f2924;--text:#6f6a63;--border:#e7d5a7;--danger:#b42318;--shadow:0 18px 45px rgba(47,41,36,.10);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--bg);color:var(--heading)}*{box-sizing:border-box}html{width:100%;max-width:100%;overflow-x:hidden;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{width:100%;max-width:100%;overflow-x:hidden;margin:0;background:radial-gradient(circle at top left,#fff8e8 0,#f8f6f2 36%,#f1ede5 100%);color:var(--heading)}#root{width:100%;max-width:100%;overflow-x:hidden}body.dark-mode{--bg:#1e1b18;--surface:#2a2520;--surface-2:#332d27;--heading:#fff;--text:#d0cbc4;--border:#4a433d;--gold-soft:#5c4618;background:radial-gradient(circle at top left,#4b3512 0,#1e1b18 34%,#14110f 100%)}button,select,input,textarea{font:inherit}button{border:0;border-radius:16px;background:var(--gold);color:#fff;padding:12px 16px;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;gap:8px}button:hover{filter:brightness(.98);transform:translateY(-1px)}.app-shell{min-height:100vh;display:flex;padding-left:292px}.sidebar{width:292px;background:linear-gradient(180deg,#3a3025,#2f2924 62%,#211b16);color:white;padding:24px;display:flex;flex-direction:column;gap:26px;position:fixed;left:0;top:0;bottom:0;height:100dvh;overflow-y:auto;overscroll-behavior:contain;box-shadow:12px 0 35px rgba(47,41,36,.12);z-index:20}.brand,.drawer-profile{display:flex;gap:13px;align-items:center}.brand span,.drawer-profile span,.usercard span,.muted,.eyebrow{display:block;color:var(--text);font-size:13px;margin-top:4px}.brand span,.drawer-profile span,.usercard span{color:#d7c9aa}.logo,.login-logo,.avatar{width:48px;height:48px;border-radius:18px;background:linear-gradient(135deg,var(--gold),#8f6518);color:white;display:grid;place-items:center;font-weight:950;letter-spacing:.5px;box-shadow:0 12px 30px rgba(201,154,46,.30)}.avatar{width:42px;height:42px;border-radius:16px}.brand b{font-size:16px}nav{display:grid;gap:8px}.sidebar nav button,.mobile-nav button{background:transparent;color:#e9ddc5;text-align:left;justify-content:flex-start}.sidebar nav button.active,.sidebar nav button:hover,.mobile-nav button.active,.mobile-nav button:hover{background:rgba(201,154,46,.18);color:#fff}.sidebar-bottom{margin-top:auto;display:grid;gap:12px}.usercard{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);padding:12px;border-radius:20px}.logout-btn{background:rgba(255,255,255,.11);color:#fff;justify-content:center}.sidebar small,.drawer-footer small{color:#d7c9aa;text-align:center}.mobile-appbar{display:none}.drawer-overlay,.mobile-drawer{display:none}main{flex:1;padding:28px;max-width:1540px;margin:0 auto;width:100%;min-width:0;overflow-x:hidden}.topbar{display:flex;gap:16px;align-items:center;justify-content:space-between;margin-bottom:24px}.topbar h1{margin:0;font-size:34px;letter-spacing:-.03em}.top-actions{display:flex;align-items:center;gap:10px}.topbar select,.form input,.form select,.form textarea{border:1px solid var(--border);background:var(--surface);border-radius:16px;padding:12px;color:var(--heading);min-height:46px}.topbar select{min-width:340px}.ghost,.theme-toggle{background:var(--surface);border:1px solid var(--border);color:var(--heading);box-shadow:0 8px 24px rgba(47,41,36,.06)}.theme-toggle.active{background:var(--gold);color:white;border-color:var(--gold)}.notif-trigger{position:relative;width:44px;height:44px;padding:0;border-radius:16px;background:var(--surface);border:1px solid var(--border);color:var(--heading);box-shadow:0 8px 24px rgba(47,41,36,.06);display:grid;place-items:center}.notif-trigger i{position:absolute;right:-4px;top:-5px;min-width:18px;height:18px;border-radius:999px;background:var(--gold);color:#fff;font-size:11px;font-style:normal;font-weight:950;line-height:18px;display:grid;place-items:center;box-shadow:0 6px 14px rgba(201,154,46,.34);border:1px solid rgba(255,255,255,.82)}.notif-popover{position:fixed;right:28px;top:86px;z-index:60;width:min(340px,calc(100vw - 32px));background:var(--surface);border:1px solid var(--border);border-radius:24px;padding:20px;box-shadow:var(--shadow)}.notif-popover h3{margin:0 0 12px}.notif-popover p{margin:10px 0;color:var(--text)}.icon-only{width:38px;height:38px;padding:0;border-radius:14px;display:grid;place-items:center;background:var(--surface-2);color:var(--heading)}.notif-popover .close{position:absolute;right:12px;top:12px}.cards{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:14px}.metric,.panel{background:rgba(255,255,255,.84);border:1px solid var(--border);border-radius:26px;box-shadow:var(--shadow);backdrop-filter:blur(14px)}body.dark-mode .metric,body.dark-mode .panel{background:rgba(42,37,32,.88)}.metric{padding:18px;display:grid;gap:8px}.metric svg{color:var(--gold)}.metric span{font-size:13px;color:var(--text)}.metric strong{font-size:22px;line-height:1.15}.metric.danger strong,.badge.danger{color:var(--danger)}.grid{display:grid;gap:18px;min-width:0}.two{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.stack{display:grid;gap:18px;min-width:0}.panel{padding:22px;min-width:0;max-width:100%;overflow:hidden}.panel h2{margin:0 0 16px;font-size:20px}.row,.event-card{display:flex;align-items:center;justify-content:space-between;gap:14px;border-top:1px solid color-mix(in srgb,var(--border) 65%,transparent);padding:14px 0;min-width:0}.row:first-of-type,.event-card:first-of-type{border-top:0}.row>div,.event-card>div{min-width:0}.row strong,.row p,.event-card strong,.event-card p{overflow-wrap:anywhere}.row p,.event-card p{margin:4px 0 0;color:var(--text);font-size:13px}.badge{display:inline-flex;align-items:center;border-radius:999px;background:var(--surface-2);color:var(--text);padding:6px 10px;font-size:12px;font-weight:800;white-space:nowrap}.badge.approved,.badge.paid{background:#e8f7ee;color:#137333}.badge.submitted,.badge.partially_paid{background:#fff4db;color:#946200}.badge.rejected,.badge.overdue{background:#fde8e7;color:#b42318}.form{display:grid;gap:12px}.form textarea{min-height:140px;resize:vertical}.small{padding:8px 10px;border-radius:10px;font-size:12px}.event-card{display:grid;grid-template-columns:1.6fr auto auto auto}.report{background:var(--surface-2);border:1px dashed var(--gold);border-radius:20px;padding:20px}.login-page{min-height:100vh;display:grid;place-items:center;padding:22px;background:radial-gradient(circle at 50% -10%,#fff2c4 0,#f8e2a7 30%,#f8f6f2 68%,#efe7d6 100%);position:relative}.dark-mode .login-page{background:radial-gradient(circle at 50% -10%,#8f6518 0,#5c4618 34%,#2a2520 72%,#1e1b18 100%)}.login-mobile-card{width:min(430px,100%);min-height:min(760px,calc(100vh - 44px));background:rgba(255,255,255,.93);border:1px solid var(--border);border-radius:36px;padding:34px 24px 24px;box-shadow:0 26px 70px rgba(47,41,36,.18);display:flex;flex-direction:column;justify-content:flex-start;position:relative}.dark-mode .login-mobile-card{background:rgba(42,37,32,.94)}.login-mobile-header{text-align:center;display:grid;justify-items:center;gap:14px;margin:34px 0 34px}.login-logo.mobile-logo{width:92px;height:92px;border-radius:32px;font-size:28px;background:transparent;box-shadow:0 18px 40px rgba(201,154,46,.20)}.login-brand-copy{display:grid;gap:6px;justify-items:center}.login-mobile-header h1{margin:0;font-size:28px;line-height:1.1;letter-spacing:-.04em;color:var(--heading)}.login-brand-copy p{margin:0;color:var(--gold);font-size:14px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.login-tabs{display:grid;grid-template-columns:1fr 1fr;gap:10px;background:var(--surface-2);border:1px solid var(--border);border-radius:22px;padding:7px;margin-bottom:22px}.login-tabs button{height:48px;justify-content:center;border-radius:16px;background:transparent;color:var(--text);font-weight:900}.login-tabs button.active{background:linear-gradient(135deg,#e8bb55,#c99a2e);color:#fff;box-shadow:0 12px 24px rgba(201,154,46,.24)}.login-form{display:grid;gap:16px}.login-form.compact{gap:15px}.login-form label{display:grid;gap:8px;color:var(--heading);font-weight:850;font-size:13px}.login-field{display:flex;align-items:center;gap:10px;border:1px solid var(--border);background:var(--surface);border-radius:18px;padding:0 14px;min-height:54px;box-shadow:0 10px 24px rgba(47,41,36,.05)}.login-field svg{color:var(--gold);flex:0 0 auto}.login-field input,.login-field select{border:0;background:transparent;outline:0;color:var(--heading);min-height:52px;width:100%;padding:0;font:inherit}.field-action{width:34px;height:34px;padding:0;border-radius:12px;background:var(--surface-2);color:var(--heading);display:grid;place-items:center;flex:0 0 auto}.official-login-note{display:flex;align-items:center;gap:8px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:16px;padding:12px 14px;font-size:12px;font-weight:850;line-height:1.35}.official-login-note svg{color:var(--gold);flex:0 0 auto}.login-error{margin:0;color:var(--danger);font-size:13px;font-weight:850}.login-submit{width:100%;justify-content:center;min-height:56px;border-radius:18px;background:linear-gradient(135deg,#e8bb55,#c99a2e);box-shadow:0 16px 30px rgba(201,154,46,.24);font-size:16px;margin-top:6px}.login-theme{position:absolute;top:18px;right:18px;width:44px;height:44px;padding:0;display:grid;place-items:center;background:var(--surface-2);border:1px solid var(--border);color:var(--heading);z-index:3;border-radius:16px;box-shadow:0 10px 24px rgba(47,41,36,.08)}.dark-mode .login-theme{background:rgba(42,37,32,.9)}.bottom-nav{display:none}@media(max-width:1120px){.cards{grid-template-columns:repeat(3,1fr)}.two{grid-template-columns:1fr}.topbar{align-items:flex-start;display:grid}.top-actions{flex-wrap:wrap}.topbar select{min-width:0;width:100%}.event-card{grid-template-columns:1fr}}@media(max-width:760px){body{background:var(--bg)}.app-shell{display:block;width:100%;max-width:100%;overflow-x:hidden;padding-left:0}.sidebar{display:none}.mobile-appbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;height:66px;padding:10px 14px;background:rgba(248,246,242,.92);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}.dark-mode .mobile-appbar{background:rgba(30,27,24,.92)}.hamburger,.notif-btn{width:44px;height:44px;padding:0;border-radius:16px;background:var(--surface);border:1px solid var(--border);color:var(--heading);display:grid;place-items:center}.mobile-icons{display:flex;gap:8px}.notif-btn{position:relative}.notif-btn i{position:absolute;right:-4px;top:-5px;min-width:18px;height:18px;border-radius:999px;background:var(--gold);color:#fff;font-size:11px;font-style:normal;font-weight:950;line-height:18px;display:grid;place-items:center;box-shadow:0 6px 14px rgba(201,154,46,.34);border:1px solid rgba(255,255,255,.82)}.drawer-overlay{display:block;position:fixed;inset:0;background:rgba(30,27,24,.45);opacity:0;pointer-events:none;z-index:70;transition:.2s}.drawer-overlay.show{opacity:1;pointer-events:auto}.mobile-drawer{display:flex;position:fixed;left:0;top:0;bottom:0;width:min(330px,86vw);background:linear-gradient(180deg,#3a3025,#211b16);z-index:80;color:white;padding:20px;transform:translateX(-105%);transition:.24s ease;flex-direction:column;gap:20px;box-shadow:20px 0 50px rgba(0,0,0,.28)}.mobile-drawer.open{transform:translateX(0)}.drawer-profile{align-items:flex-start}.drawer-profile .icon-only{margin-left:auto;background:rgba(255,255,255,.12);color:white}.mobile-nav{gap:8px}.drawer-footer{margin-top:auto;display:grid;gap:10px}.drawer-footer .logout-btn{width:100%}main{padding:18px 14px 130px;width:100%;max-width:100vw}.topbar{display:none}.cards{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}.metric{border-radius:22px;padding:14px}.metric strong{font-size:18px}.panel{border-radius:24px;padding:18px}.panel h2{font-size:18px}.recharts-wrapper,.recharts-surface{max-width:100%!important}.row{align-items:flex-start;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.row button{grid-column:span 2}.bottom-nav{display:grid;grid-template-columns:repeat(5,1fr);position:fixed;left:14px;right:14px;bottom:14px;z-index:65;background:rgba(255,255,255,.94);border:1px solid var(--border);box-shadow:0 18px 45px rgba(47,41,36,.18);border-radius:28px;padding:8px;backdrop-filter:blur(18px)}.dark-mode .bottom-nav{background:rgba(42,37,32,.96)}.bottom-nav button{height:58px;padding:5px 2px;background:transparent;color:var(--text);border-radius:20px;display:grid;place-items:center;gap:2px;font-size:11px}.bottom-nav button span{width:32px;height:30px;border-radius:14px;display:grid;place-items:center}.bottom-nav button b{font-size:10px;line-height:1.05}.bottom-nav button.active{color:var(--heading);background:var(--gold-soft)}.bottom-nav button.active span{background:var(--gold);color:white}.notif-popover{top:74px;right:14px;left:14px;width:auto}.login-page{padding:16px;background:linear-gradient(180deg,#2f2924 0%,#4c3817 38%,#f8f6f2 38%,#f8f6f2 100%)}.dark-mode .login-page{background:linear-gradient(180deg,#14110f 0%,#3a2a10 38%,#1e1b18 38%,#1e1b18 100%)}.login-shell{display:block;border-radius:32px;max-width:430px}.login-hero{min-height:250px;padding:26px;justify-content:flex-end}.login-logo.big{width:60px;height:60px;border-radius:22px;font-size:20px;margin-bottom:34px}.login-hero h1{font-size:34px}.login-hero p{font-size:14px}.login-stats{display:none}.login-card{padding:24px;border-radius:0;background:rgba(255,255,255,.96)}.login-title h2{font-size:28px}.login-theme{top:12px;right:12px}.form input,.form select,.form textarea,.login-field input,.login-field select{font-size:16px}}@media(max-width:420px){.cards{grid-template-columns:1fr}.bottom-nav{left:8px;right:8px;bottom:8px}.bottom-nav button b{font-size:9px}}@media print{.sidebar,.topbar,.mobile-appbar,.bottom-nav,.mobile-drawer,.drawer-overlay,button{display:none!important}main{padding:0}.panel{box-shadow:none;border:0}.report{border:0}}
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:4px 0 16px}.tabs button{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:999px;padding:8px 12px;font-weight:700}.tabs button.active{background:linear-gradient(135deg,#e8bb55,#c99a2e);color:#2d1c08;border-color:transparent}.event-row-btn{display:block;width:100%;border:0;background:transparent;padding:0;margin:0;text-align:left;color:inherit}.event-row-btn:focus-visible{outline:2px solid #c99a2e;border-radius:18px}
.table-wrap{width:100%;overflow:auto;border:1px solid var(--border);border-radius:18px;background:var(--surface);margin-top:12px}table{width:100%;border-collapse:collapse;min-width:820px}th,td{padding:12px 14px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}th{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:linear-gradient(180deg,rgba(232,187,85,.16),rgba(201,154,46,.06));font-weight:900}td{color:var(--text);font-size:14px}tr:last-child td{border-bottom:0}td input,td select,.recipe-form input{width:100%;border:1px solid var(--border);border-radius:12px;padding:10px;background:var(--surface-soft);color:var(--text)}.row-actions{display:flex;gap:8px;flex-wrap:wrap}.small,.mini{border:1px solid var(--border);border-radius:12px;padding:8px 10px;background:var(--surface-soft);color:var(--text);font-weight:800}.small.active,.mini.active,.recipe-form button,.menu-recipes-page button:not(.small):not(.mini){border:0;background:linear-gradient(135deg,#e8bb55,#c99a2e);color:#2d1c08;border-radius:14px;padding:10px 14px;font-weight:900;display:inline-flex;align-items:center;gap:8px}.small.danger,.mini.danger{background:rgba(239,68,68,.1);color:#b91c1c;border-color:rgba(239,68,68,.25)}.recipe-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;align-items:end}.recipe-form label{display:grid;gap:6px;color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.04em}.recipe-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:14px}@media(max-width:760px){table{min-width:760px}.table-wrap{border-radius:16px}th,td{padding:10px}.recipe-form{grid-template-columns:1fr}.menu-recipes-page{padding-bottom:90px}}
.search-box{display:flex;align-items:center;gap:10px;border:1px solid var(--border);border-radius:16px;background:var(--surface-soft);padding:10px 12px;margin-bottom:12px;color:var(--muted)}.search-box input{border:0;background:transparent;outline:none;width:100%;color:var(--text);font-weight:700}.danger-row td{background:rgba(239,68,68,.06)}.danger-row td:first-child{border-left:4px solid #ef4444}.raw-materials-page .table-wrap td:first-child{font-weight:900;color:#8a5a12}.raw-materials-page .recipe-form button{align-self:end}
.purchase-lines{display:grid;gap:14px;margin:16px 0}.purchase-line{border:1px solid var(--border);background:linear-gradient(180deg,var(--surface),rgba(232,187,85,.06));border-radius:18px;padding:14px}.purchase-line-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.purchase-line-head>div{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.small.active{border-color:rgba(201,154,46,.35);background:rgba(232,187,85,.18);color:#7a4d0b}.purchase-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:12px}.purchase-actions button{border:0;background:linear-gradient(135deg,#e8bb55,#c99a2e);color:#2d1c08;border-radius:14px;padding:10px 14px;font-weight:900;display:inline-flex;align-items:center;gap:8px}.purchase-total{margin-left:auto;display:grid;gap:2px;text-align:right}.purchase-total span{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:900}.purchase-total strong{font-size:20px;color:var(--text)}@media(max-width:760px){.purchase-line-head,.purchase-actions{align-items:stretch;flex-direction:column}.purchase-total{text-align:left;margin-left:0}}
.kitchen-realization-page button:not(.small):not(.mini){border:0;background:linear-gradient(135deg,#e8bb55,#c99a2e);color:#2d1c08;border-radius:14px;padding:10px 14px;font-weight:900;display:inline-flex;align-items:center;gap:8px}.kitchen-realization-page .add-line{margin:14px 0}.kitchen-realization-page .add-line label{display:grid;gap:6px;color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.04em}.kitchen-realization-page .add-line input{border:1px solid var(--border);border-radius:12px;padding:10px;background:var(--surface-soft);color:var(--text)}

.image-logo{object-fit:contain;background:rgba(255,255,255,.08);padding:5px}.login-logo.image-logo{padding:0;background:transparent}.brand .image-logo,.drawer-profile .image-logo{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16)}

.upload-tile{border:1px dashed var(--gold);background:var(--surface-2);border-radius:18px;min-height:96px;display:grid;place-items:center;text-align:center;color:var(--heading);font-weight:850;cursor:pointer;padding:18px}.upload-tile input{display:none}.upload-tile svg{color:var(--gold)}

.schedule-view-header{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px;padding:14px;border:1px solid var(--border);border-radius:22px;background:linear-gradient(135deg,rgba(243,223,170,.58),rgba(255,255,255,.72))}.dark-mode .schedule-view-header{background:linear-gradient(135deg,rgba(92,70,24,.45),rgba(42,37,32,.72))}.schedule-view-header strong{display:block;color:var(--heading);font-size:15px}.schedule-view-header span{display:block;color:var(--text);font-size:12px;margin-top:3px}.segmented-control{display:flex;gap:7px;padding:6px;border:1px solid var(--border);border-radius:18px;background:var(--surface)}.segmented-control button{border-radius:13px;background:transparent;color:var(--text);padding:9px 12px;box-shadow:none}.segmented-control button.active{background:linear-gradient(135deg,#e8bb55,#c99a2e);color:#2d1c08}.schedule-detail-view{display:grid;gap:10px}.calendar-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:14px 0}.calendar-toolbar .secondary{background:var(--surface-2);border:1px solid var(--border);color:var(--heading);box-shadow:none}.calendar-title{text-align:center;display:grid;gap:3px}.calendar-title strong{text-transform:capitalize;font-size:18px}.calendar-title span{color:var(--text);font-size:12px;font-weight:800}.month-calendar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.weekday{text-align:center;color:var(--gold);font-weight:950;font-size:12px;text-transform:uppercase;letter-spacing:.06em;padding:8px}.month-cell{min-height:128px;border:1px solid var(--border);border-radius:18px;background:rgba(255,255,255,.78);padding:10px;display:grid;align-content:start;gap:8px;overflow:hidden}.dark-mode .month-cell{background:rgba(42,37,32,.78)}.month-cell.muted{opacity:.52}.month-cell.today{border-color:var(--gold);box-shadow:inset 0 0 0 1px var(--gold),0 10px 24px rgba(201,154,46,.14)}.month-cell.has-event{background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(243,223,170,.24))}.dark-mode .month-cell.has-event{background:linear-gradient(180deg,rgba(42,37,32,.92),rgba(92,70,24,.28))}.date-row{display:flex;align-items:center;justify-content:space-between;gap:6px}.date-row strong{font-size:14px}.date-row span{font-size:10px;font-weight:950;color:#2d1c08;background:var(--gold-soft);border-radius:999px;padding:4px 7px}.plan-stack{display:grid;gap:6px}.plan-pill{width:100%;display:grid;text-align:left;gap:2px;border-radius:13px;padding:8px 9px;background:linear-gradient(135deg,#e8bb55,#c99a2e);color:#2d1c08;box-shadow:0 8px 18px rgba(201,154,46,.22);font-weight:900}.plan-pill span{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.plan-pill small{font-size:10px;color:rgba(45,28,8,.78);font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.plan-pill.ready,.plan-pill.running{background:linear-gradient(135deg,#f1c76a,#b98118)}.plan-pill.completed,.plan-pill.closed{background:linear-gradient(135deg,#d7c9aa,#9d865d)}.more-plans{color:var(--gold);font-size:11px;font-weight:950}
@media(max-width:760px){.events-page{display:grid;grid-template-columns:1fr}.schedule-view-header,.calendar-toolbar{align-items:stretch;flex-direction:column}.segmented-control{width:100%}.segmented-control button{flex:1;justify-content:center}.month-calendar{gap:5px}.weekday{font-size:10px;padding:5px}.month-cell{min-height:104px;border-radius:14px;padding:7px}.date-row span{display:none}.plan-pill{padding:6px;border-radius:10px}.plan-pill span{font-size:10px}.plan-pill small{font-size:9px}}

.events-page{grid-template-columns:1fr}.event-create-form{grid-template-columns:repeat(4,minmax(0,1fr));align-items:end}.event-create-form button{justify-content:center}.events-page>.panel{width:100%}.events-page>.panel:last-child{grid-column:1/-1}@media(max-width:1120px){.event-create-form{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.event-create-form{grid-template-columns:1fr}}

.forms-page{display:grid;grid-template-columns:minmax(0,1fr);gap:18px;width:100%;align-items:start}.forms-page>.panel{width:100%;max-width:100%;grid-column:1/-1}.form-ba-grid{grid-template-columns:repeat(4,minmax(0,1fr));align-items:end}.form-ba-grid .upload-tile{min-height:54px}.status-form-list{display:grid;gap:12px}.status-form-row{display:grid;grid-template-columns:minmax(220px,1fr) auto auto;align-items:center;gap:14px}.status-form-row .row-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}@media(max-width:1120px){.form-ba-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.status-form-row{grid-template-columns:1fr;align-items:flex-start}.status-form-row .row-actions{justify-content:flex-start}}@media(max-width:760px){.forms-page{gap:14px}.forms-page>.panel{border-radius:22px;padding:16px;overflow:visible}.form-ba-grid{display:grid;grid-template-columns:1fr;gap:12px}.form-ba-grid label,.form-ba-grid button{width:100%;min-width:0}.form-ba-grid .upload-tile{display:flex;align-items:center;justify-content:center;gap:10px;min-height:58px;padding:12px;border-radius:16px}.form-ba-grid .upload-tile span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-form-list{gap:10px}.status-form-row{display:grid;grid-template-columns:minmax(0,1fr);gap:10px;border:1px solid var(--border);border-radius:18px;background:var(--surface);padding:14px}.status-form-row>div:first-child{width:100%;min-width:0}.status-form-row .badge{width:max-content}.status-form-row .row-actions{display:grid;grid-template-columns:1fr 1fr;width:100%;gap:8px}.status-form-row .row-actions .small{width:100%;justify-content:center;min-height:40px;padding:9px 8px;font-size:12px}.status-form-row .row-actions .small:first-child{grid-column:1/-1}}@media(max-width:380px){.status-form-row .row-actions{grid-template-columns:1fr}}

/* Mobile hardening pass: keep every menu readable on phone */
@media(max-width:760px){
  main{overflow-x:hidden}
  .grid,.stack,.two,.events-page,.purchases-page,.kitchen-realization-page,.raw-materials-page,.menu-recipes-page{grid-template-columns:minmax(0,1fr)!important;width:100%;max-width:100%;gap:14px}
  .panel{width:100%;max-width:100%;overflow:hidden}
  .panel h2{line-height:1.2;overflow-wrap:anywhere}
  .form,.recipe-form{grid-template-columns:minmax(0,1fr)!important;width:100%}
  .form label,.recipe-form label,.form input,.form select,.form textarea,.recipe-form input,.recipe-form select,.recipe-form textarea{min-width:0;width:100%;max-width:100%}
  button{max-width:100%;white-space:normal;text-align:center;justify-content:center}
  .row{display:grid!important;grid-template-columns:minmax(0,1fr)!important;align-items:start!important;gap:8px!important;width:100%}
  .row>*,.event-card>*{min-width:0;max-width:100%;overflow-wrap:anywhere}
  .row span:not(.badge),.row strong,.row small{display:block;max-width:100%;overflow-wrap:anywhere}
  .row .badge{width:max-content;max-width:100%}
  .row button{grid-column:auto;width:100%}
  .event-card{display:grid!important;grid-template-columns:minmax(0,1fr)!important;gap:8px;border:1px solid var(--border);border-radius:18px;background:var(--surface);padding:14px;margin-bottom:10px}
  .tabs{display:flex;overflow-x:auto;flex-wrap:nowrap;gap:8px;padding-bottom:6px;margin-inline:-2px;scroll-snap-type:x proximity}
  .tabs button{flex:0 0 auto;white-space:nowrap;scroll-snap-align:start}
  .cards{grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important}
  .metric{min-width:0;overflow:hidden}.metric strong{overflow-wrap:anywhere}
  .report{padding:16px;border-radius:18px;overflow:hidden}.report h2,.report p{overflow-wrap:anywhere}.report button{width:100%;margin-top:8px}
  .table-wrap{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.table-wrap:before{content:'Geser tabel ke samping';display:block;padding:8px 10px;color:var(--text);font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.04em;background:var(--surface-2);border-bottom:1px solid var(--border)}
  table{min-width:680px}th,td{white-space:normal;overflow-wrap:anywhere}
  .schedule-view-header{display:grid;grid-template-columns:1fr;gap:10px}.segmented-control{width:100%;display:grid;grid-template-columns:1fr 1fr}.segmented-control button{justify-content:center}
  .calendar-toolbar{display:grid;grid-template-columns:44px 1fr 44px}.calendar-title strong{font-size:15px}.month-calendar{overflow-x:auto;padding-bottom:4px}.month-grid,.week-grid{min-width:650px}
  .purchase-line{padding:12px;border-radius:16px;overflow:hidden}.purchase-line-head{align-items:stretch!important}.purchase-line-head>div{display:grid;grid-template-columns:1fr;gap:8px}.purchase-actions button,.purchase-line button{width:100%;justify-content:center}.purchase-total{text-align:left!important;margin-left:0!important}
  .row-actions{display:grid!important;grid-template-columns:1fr 1fr;width:100%;gap:8px}.row-actions .small,.row-actions .mini{width:100%;justify-content:center}
  .search-box{width:100%;min-width:0}.search-box input{min-width:0}
}
@media(max-width:420px){.cards{grid-template-columns:minmax(0,1fr)!important}.row-actions{grid-template-columns:1fr!important}.bottom-nav{left:8px;right:8px;bottom:8px;border-radius:22px}.bottom-nav button b{font-size:9px}.panel{padding:14px;border-radius:20px}main{padding-left:10px;padding-right:10px}}

/* Brand name must stay one line in sidebar/drawer */
.brand b,.drawer-profile b{font-size:14px;line-height:1;letter-spacing:-.04em;white-space:nowrap;display:block}.brand>div,.drawer-profile>div{min-width:0}.brand span,.drawer-profile span{white-space:nowrap}
@media(max-width:380px){.drawer-profile b{font-size:13px;letter-spacing:-.05em}}

/* v1.0.2: table readability pass — keep imported master-data columns from sticking together */
.table-wrap{overflow-x:auto;scrollbar-gutter:stable;background:var(--surface)}
.table-wrap table{border-collapse:separate;border-spacing:0;table-layout:auto}
.table-wrap th,.table-wrap td{padding:14px 18px;line-height:1.45;vertical-align:top;border-right:1px solid color-mix(in srgb,var(--border) 55%,transparent)}
.table-wrap th:last-child,.table-wrap td:last-child{border-right:0}
.table-wrap th{white-space:nowrap}
.table-wrap td{min-width:96px}
.table-wrap td:first-child,.table-wrap th:first-child{position:sticky;left:0;z-index:2;background:var(--surface);box-shadow:8px 0 16px rgba(47,41,36,.05)}
.table-wrap th:first-child{z-index:3;background:linear-gradient(180deg,rgba(232,187,85,.22),rgba(201,154,46,.10))}
.raw-materials-page table{min-width:1120px}
.raw-materials-page th:nth-child(1),.raw-materials-page td:nth-child(1){min-width:110px}
.raw-materials-page th:nth-child(2),.raw-materials-page td:nth-child(2){min-width:260px}
.raw-materials-page th:nth-child(3),.raw-materials-page td:nth-child(3){min-width:170px}
.raw-materials-page th:nth-child(4),.raw-materials-page td:nth-child(4){min-width:150px;text-align:right}
.raw-materials-page th:nth-child(5),.raw-materials-page td:nth-child(5){min-width:130px;white-space:nowrap}
.raw-materials-page th:nth-child(7),.raw-materials-page td:nth-child(7){min-width:170px}
.menu-recipes-page table{min-width:1280px}
.menu-recipes-page th:nth-child(1),.menu-recipes-page td:nth-child(1){min-width:110px}
.menu-recipes-page th:nth-child(2),.menu-recipes-page td:nth-child(2){min-width:280px}
.menu-recipes-page th:nth-child(3),.menu-recipes-page td:nth-child(3){min-width:170px}
.menu-recipes-page th:nth-child(5),.menu-recipes-page td:nth-child(5),.menu-recipes-page th:nth-child(6),.menu-recipes-page td:nth-child(6){min-width:150px;text-align:right;white-space:nowrap}
.menu-recipes-page th:nth-child(8),.menu-recipes-page td:nth-child(8){min-width:170px}
.menu-recipes-page th:nth-child(9),.menu-recipes-page td:nth-child(9){min-width:210px}
.kitchen-realization-page table,.purchases-page table{min-width:1100px}
@media(max-width:760px){
  .table-wrap th,.table-wrap td{padding:12px 14px;line-height:1.4}
  .raw-materials-page table{min-width:1040px}
  .menu-recipes-page table{min-width:1220px}
  .table-wrap td:first-child,.table-wrap th:first-child{box-shadow:6px 0 12px rgba(47,41,36,.08)}
}

/* v1.0.3: form spacing pass — Realisasi Dapur and Form BA */
.kitchen-realization-page .panel > .recipe-form,
.forms-page .form-ba-grid{
  display:grid!important;
  gap:18px 20px!important;
  align-items:end!important;
  width:100%;
}
.kitchen-realization-page .panel > .recipe-form{
  grid-template-columns:minmax(190px,.8fr) minmax(320px,1.45fr) minmax(280px,1.25fr) minmax(150px,.65fr) minmax(170px,.75fr)!important;
}
.forms-page .form-ba-grid{
  grid-template-columns:minmax(360px,1.35fr) minmax(240px,.9fr) minmax(260px,1fr) minmax(190px,.75fr)!important;
}
.kitchen-realization-page .panel > .recipe-form label,
.forms-page .form-ba-grid label{
  min-width:0;
  display:grid;
  gap:9px;
}
.kitchen-realization-page .panel > .recipe-form input,
.kitchen-realization-page .panel > .recipe-form select,
.forms-page .form-ba-grid input,
.forms-page .form-ba-grid select,
.forms-page .form-ba-grid .upload-tile{
  width:100%;
  min-width:0;
  min-height:52px;
}
.kitchen-realization-page .panel > .recipe-form select,
.forms-page .form-ba-grid select{
  white-space:normal;
  text-overflow:ellipsis;
}
.forms-page .form-ba-grid .upload-tile{
  min-height:52px;
  padding:10px 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}
.forms-page .form-ba-grid .upload-tile span{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.forms-page .form-ba-grid button{
  min-height:52px;
  width:100%;
  justify-content:center;
}
@media(max-width:1280px){
  .kitchen-realization-page .panel > .recipe-form{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .forms-page .form-ba-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}
}
@media(max-width:760px){
  .kitchen-realization-page .panel > .recipe-form,
  .forms-page .form-ba-grid{grid-template-columns:minmax(0,1fr)!important;gap:14px!important}
  .kitchen-realization-page .panel > .recipe-form label,
  .forms-page .form-ba-grid label{gap:8px}
  .kitchen-realization-page .panel > .recipe-form input,
  .kitchen-realization-page .panel > .recipe-form select,
  .forms-page .form-ba-grid input,
  .forms-page .form-ba-grid select,
  .forms-page .form-ba-grid .upload-tile,
  .forms-page .form-ba-grid button{min-height:54px}
}

/* v1.1.2: Jadwal Event table format */
.schedule-table-card{display:grid;gap:14px}.schedule-table-title{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;border:1px solid var(--border);border-radius:22px;padding:16px;background:linear-gradient(135deg,rgba(255,255,255,.86),rgba(243,223,170,.34));box-shadow:0 12px 28px rgba(47,41,36,.06)}.dark-mode .schedule-table-title{background:linear-gradient(135deg,rgba(42,37,32,.88),rgba(92,70,24,.28))}.schedule-table-title strong{display:block;font-size:18px;color:var(--heading)}.schedule-table-title span{display:block;margin-top:4px;color:var(--text);font-size:13px;line-height:1.45}.schedule-table-title b{white-space:nowrap;border-radius:999px;background:var(--gold-soft);color:#2d1c08;padding:8px 12px;font-size:12px}.schedule-table-wrap{margin-top:0;border-radius:22px;box-shadow:0 14px 32px rgba(47,41,36,.08)}.schedule-table{min-width:1180px;border-collapse:separate;border-spacing:0}.schedule-table th{position:sticky;top:0;z-index:2;background:linear-gradient(180deg,#f6e7be,#ead197);color:#4a3410;border-bottom:1px solid rgba(201,154,46,.45);text-align:left}.dark-mode .schedule-table th{background:linear-gradient(180deg,#5c4618,#3a3025);color:#ffe7ac}.schedule-table td{padding:14px 16px;border-right:1px solid color-mix(in srgb,var(--border) 70%,transparent);vertical-align:top;cursor:pointer}.schedule-table td:last-child{border-right:0}.schedule-table tr{transition:.18s ease}.schedule-table tbody tr:hover{background:rgba(243,223,170,.24)}.schedule-table tbody tr.selected{background:linear-gradient(90deg,rgba(232,187,85,.26),rgba(255,255,255,.44))}.dark-mode .schedule-table tbody tr.selected{background:linear-gradient(90deg,rgba(201,154,46,.22),rgba(42,37,32,.54))}.schedule-table td strong{display:block;color:var(--heading);font-size:14px;line-height:1.35}.schedule-table td small{display:block;margin-top:4px;color:var(--text);font-size:12px;line-height:1.35;max-width:260px}.schedule-table td:first-child{position:sticky;left:0;z-index:1;background:var(--surface);text-align:center;color:var(--gold);font-weight:950}.schedule-table th:first-child{position:sticky;left:0;z-index:3}.dark-mode .schedule-table td:first-child{background:var(--surface)}.schedule-table .badge{margin-bottom:4px;text-transform:uppercase}.schedule-detail-view{display:block}@media(max-width:760px){.schedule-table-title{display:grid;gap:10px;padding:14px;border-radius:18px}.schedule-table-title strong{font-size:16px}.schedule-table-title b{width:max-content}.schedule-table{min-width:1060px}.schedule-table td{padding:12px}.schedule-table td strong{font-size:13px}.schedule-table td small{font-size:11px}}

/* v1.1.4: Detail Event sheet format */
.event-detail-sheet{display:grid;gap:16px}.event-detail-hero{display:flex;align-items:stretch;justify-content:space-between;gap:16px;border:1px solid var(--border);border-radius:24px;padding:18px;background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(243,223,170,.42));box-shadow:0 14px 34px rgba(47,41,36,.07)}.dark-mode .event-detail-hero{background:linear-gradient(135deg,rgba(42,37,32,.9),rgba(92,70,24,.32))}.event-detail-hero span,.detail-field span,.event-detail-note span,.event-detail-status span{display:block;font-size:11px;font-weight:950;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);margin-bottom:6px}.event-detail-hero h3{margin:0;color:var(--heading);font-size:26px;letter-spacing:-.03em}.event-detail-hero p{margin:6px 0 0;color:var(--text);font-weight:800}.event-detail-status{min-width:220px;border:1px solid var(--border);border-radius:18px;background:var(--surface);padding:12px}.event-detail-status select{width:100%;border:0;background:var(--gold-soft);color:#2d1c08;border-radius:14px;padding:10px 12px;font-weight:950;text-transform:uppercase}.event-detail-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.detail-field{min-height:92px;border:1px solid var(--border);border-radius:20px;background:var(--surface);padding:15px;display:grid;align-content:center;box-shadow:0 10px 24px rgba(47,41,36,.04)}.detail-field.wide{grid-column:span 2}.detail-field strong{color:var(--heading);font-size:16px;line-height:1.35;overflow-wrap:anywhere}.event-detail-note{border:1px dashed var(--gold);border-radius:20px;background:var(--surface-2);padding:16px}.event-detail-note p{margin:0;color:var(--text);line-height:1.55}@media(max-width:1120px){.event-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.detail-field.wide{grid-column:span 2}}@media(max-width:760px){.event-detail-hero{display:grid;padding:15px;border-radius:20px}.event-detail-hero h3{font-size:21px}.event-detail-status{min-width:0}.event-detail-grid{grid-template-columns:minmax(0,1fr)}.detail-field,.detail-field.wide{grid-column:auto;min-height:76px}.detail-field strong{font-size:15px}}

/* v1.1.6: Detail Event biodata + menu tables */
.detail-section-title{display:flex;justify-content:space-between;align-items:flex-end;gap:14px;margin-top:4px}.detail-section-title strong{color:var(--heading);font-size:18px}.detail-section-title span{color:var(--text);font-size:13px;text-align:right}.event-biodata-wrap,.menu-choice-wrap{border-radius:22px;box-shadow:0 14px 32px rgba(47,41,36,.07)}.event-biodata-table{min-width:980px;border-collapse:separate;border-spacing:0}.event-biodata-table th{width:180px;background:linear-gradient(180deg,#f6e7be,#ead197);color:#4a3410;text-align:left;font-size:12px;letter-spacing:.06em;text-transform:uppercase;border-right:1px solid rgba(201,154,46,.32)}.dark-mode .event-biodata-table th{background:linear-gradient(180deg,#5c4618,#3a3025);color:#ffe7ac}.event-biodata-table td{font-weight:850;color:var(--heading);background:var(--surface);min-width:240px}.event-biodata-table th,.event-biodata-table td{padding:14px 16px;border-bottom:1px solid color-mix(in srgb,var(--border) 70%,transparent);vertical-align:top}.event-biodata-table tr:last-child th,.event-biodata-table tr:last-child td{border-bottom:0}.menu-choice-table{min-width:1120px;border-collapse:separate;border-spacing:0}.menu-choice-table th{background:linear-gradient(180deg,#f6e7be,#ead197);color:#4a3410;text-align:left;font-size:13px;text-transform:uppercase;letter-spacing:.04em}.dark-mode .menu-choice-table th{background:linear-gradient(180deg,#5c4618,#3a3025);color:#ffe7ac}.menu-choice-table th,.menu-choice-table td{width:25%;padding:14px 16px;border-right:1px solid color-mix(in srgb,var(--border) 70%,transparent);vertical-align:top}.menu-choice-table th:last-child,.menu-choice-table td:last-child{border-right:0}.menu-choice-table tbody tr:hover{background:rgba(243,223,170,.18)}.menu-choice-cell strong{display:block;color:var(--heading);font-size:14px;line-height:1.35}.menu-choice-cell small{display:block;margin-top:4px;color:var(--text);font-size:12px;font-weight:800}@media(max-width:760px){.detail-section-title{display:grid;align-items:start}.detail-section-title span{text-align:left}.event-biodata-table{min-width:820px}.menu-choice-table{min-width:980px}.event-biodata-table th,.event-biodata-table td,.menu-choice-table th,.menu-choice-table td{padding:12px}.menu-choice-cell strong{font-size:13px}}

/* v1.1.7: editable Detail Event */
.event-detail-actions{display:flex;align-items:stretch;gap:12px}.event-detail-actions>button{align-self:flex-start;background:var(--surface);border:1px solid var(--border);color:var(--heading)}.event-edit-form{display:grid;gap:14px;border:1px solid var(--border);border-radius:24px;background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(243,223,170,.24));padding:16px;box-shadow:0 12px 28px rgba(47,41,36,.06)}.dark-mode .event-edit-form{background:linear-gradient(135deg,rgba(42,37,32,.9),rgba(92,70,24,.22))}.event-edit-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.event-edit-grid label{display:grid;gap:7px;color:var(--heading);font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.04em}.event-edit-grid label.wide{grid-column:span 2}.event-edit-grid label.note{grid-column:span 4}.event-edit-grid input,.event-edit-grid select,.event-edit-grid textarea{width:100%;border:1px solid var(--border);background:var(--surface);color:var(--heading);border-radius:15px;padding:11px 12px;min-height:46px;text-transform:none;letter-spacing:0;font-weight:700}.event-edit-grid textarea{min-height:92px}.event-edit-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}@media(max-width:1120px){.event-edit-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.event-edit-grid label.note{grid-column:span 2}}@media(max-width:760px){.event-detail-actions{display:grid}.event-edit-grid{grid-template-columns:minmax(0,1fr)}.event-edit-grid label.wide,.event-edit-grid label.note{grid-column:auto}.event-edit-actions{justify-content:stretch}.event-edit-actions button{justify-content:center}}

/* v1.1.9: editable menu choices with dropdown rows */
.detail-section-title button{flex:0 0 auto;background:var(--surface);border:1px solid var(--border);color:var(--heading)}.menu-editor-panel{display:grid;gap:14px;border:1px solid var(--border);border-radius:24px;background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(243,223,170,.24));padding:16px;box-shadow:0 12px 28px rgba(47,41,36,.06)}.dark-mode .menu-editor-panel{background:linear-gradient(135deg,rgba(42,37,32,.9),rgba(92,70,24,.22))}.menu-editor-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.menu-editor-column{border:1px solid var(--border);border-radius:18px;background:var(--surface);padding:12px;min-height:180px}.menu-editor-column>strong{display:block;margin-bottom:10px;color:var(--gold);font-size:12px;text-transform:uppercase;letter-spacing:.05em}.menu-editor-lines{display:grid;gap:10px;max-height:360px;overflow:auto;padding-right:4px}.menu-editor-line{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center}.menu-editor-line select{width:100%;min-height:42px;border:1px solid var(--border);background:var(--surface-2);color:var(--heading);border-radius:14px;padding:9px;font-weight:850}.menu-editor-line .danger{background:#fde8e7;color:var(--danger);border:1px solid #f4b7b3}.menu-editor-column button:disabled{opacity:.55;cursor:not-allowed;filter:none;transform:none}@media(max-width:1120px){.menu-editor-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.detail-section-title button{width:max-content}.menu-editor-grid{grid-template-columns:minmax(0,1fr)}.menu-editor-lines{max-height:300px}.menu-editor-line{grid-template-columns:minmax(0,1fr)}.menu-editor-line .danger{justify-content:center}}

.form-file-link{border:0;background:transparent;color:var(--gold);font-weight:850;display:inline-flex;align-items:center;gap:8px;padding:0;text-align:left;cursor:pointer}.form-file-link:hover{text-decoration:underline}.preview-modal{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.64);display:grid;place-items:center;padding:24px}.preview-card{width:min(92vw,920px);max-height:88vh;background:var(--surface);border:1px solid var(--border);border-radius:26px;box-shadow:0 30px 90px rgba(0,0,0,.38);padding:16px;display:grid;gap:12px}.preview-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.preview-card img,.preview-card iframe{width:100%;max-height:72vh;object-fit:contain;border-radius:18px;background:#111;border:1px solid var(--border)}.preview-card iframe{height:72vh}.preview-card p{margin:0;color:var(--muted);font-weight:700;word-break:break-word}@media(max-width:760px){.preview-modal{padding:12px}.preview-card{border-radius:20px;padding:12px}.preview-card img,.preview-card iframe{max-height:68vh}.preview-card iframe{height:68vh}}

.kitchen-menu-groups{display:grid;gap:16px;margin:16px 0}.kitchen-menu-group{border:1px solid var(--border);background:var(--surface-2);border-radius:20px;padding:14px}.kitchen-menu-group h3{margin:0 0 10px;font-size:16px;color:var(--heading)}.kitchen-menu-group table p{margin:.2rem 0 0;color:var(--muted);font-size:12px}.kitchen-menu-group tr.selected{background:rgba(201,154,46,.14)}

.form-submit-meta{margin:.25rem 0;color:var(--muted);font-size:12px}

.equipment-page{display:grid;gap:18px}.equipment-compare-grid{display:grid;grid-template-columns:1fr;gap:18px;align-items:start}.equipment-form{grid-template-columns:2fr 1.4fr repeat(3,.8fr);align-items:end}.equipment-form .wide{grid-column:span 2}.equipment-event-filter{grid-template-columns:1fr}.modal-form{grid-template-columns:repeat(2,minmax(0,1fr))}.modal-form .wide{grid-column:1/-1}.equipment-modal-card{max-width:680px}.panel-actions{display:flex;justify-content:flex-end;margin:-6px 0 10px}.compact-table{overflow-x:auto}.compact-table table{width:100%;min-width:0;table-layout:fixed;border-collapse:separate;border-spacing:0}.compact-table th,.compact-table td{padding:10px 12px;vertical-align:top;overflow:hidden;text-overflow:ellipsis}.compact-table th{white-space:nowrap}.compact-table .num{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}.compact-table .col-num{width:68px}.compact-table .col-code{width:110px}.compact-table .col-cat{width:130px}.compact-table .col-status{width:120px}.compact-table .col-action{width:90px}.compact-table .code-cell{white-space:normal;overflow-wrap:anywhere;font-size:12px;color:var(--muted)}.movement-table .col-item{width:auto}.movement-table .col-code{width:104px}.summary-table .col-item{width:auto}.database-table .col-item{width:26%}.equipment-compare-grid table p,.equipment-page table p{margin:.2rem 0 0;color:var(--muted);font-size:12px}.danger-row{background:rgba(225,77,77,.07)}@media(max-width:1200px){.equipment-form{grid-template-columns:repeat(2,minmax(0,1fr))}.equipment-form .wide{grid-column:span 2}.equipment-event-filter{grid-template-columns:1fr}.modal-form{grid-template-columns:repeat(2,minmax(0,1fr))}.modal-form .wide{grid-column:1/-1}.equipment-modal-card{max-width:680px}.panel-actions{display:flex;justify-content:flex-end;margin:-6px 0 10px}.equipment-compare-grid{grid-template-columns:1fr}.compact-table table{min-width:680px}}@media(max-width:900px){.modal-form{grid-template-columns:1fr}.equipment-form{grid-template-columns:1fr}.equipment-form .wide{grid-column:auto}.compact-table table{min-width:640px}}

.equipment-list-table{display:grid;gap:8px}.equipment-list-head,.equipment-list-row{display:grid;grid-template-columns:minmax(150px,1fr) 54px 58px 58px 70px;gap:8px;align-items:center}.equipment-list-head{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);padding:0 0 8px}.equipment-list-head span:not(:first-child),.equipment-list-num{text-align:right;font-variant-numeric:tabular-nums}.equipment-list-row{padding:10px;border:1px solid var(--border);border-radius:14px;background:var(--surface-soft)}.equipment-list-item{min-width:0}.equipment-list-item strong{display:block;white-space:normal;overflow-wrap:anywhere}.equipment-list-item p{margin:2px 0 0;color:var(--muted);font-size:12px}.equipment-list-item small{display:block;margin-top:3px;color:var(--muted);font-size:11px;overflow-wrap:anywhere}@media(max-width:560px){.equipment-list-head,.equipment-list-row{grid-template-columns:minmax(120px,1fr) 42px 48px 48px 58px;gap:6px}.equipment-list-row{padding:8px}.equipment-list-row .small{padding:7px 8px;font-size:11px}.equipment-list-head{font-size:10px}}

.wuc-modal-shell{align-items:center;padding:18px}.hris-style-modal{max-width:760px;width:min(760px,calc(100vw - 28px));padding:0;overflow:hidden;border-radius:24px}.hris-modal-header{display:flex;justify-content:space-between;gap:16px;padding:22px 24px;background:linear-gradient(135deg,rgba(201,154,46,.16),rgba(47,41,36,.05));border-bottom:1px solid var(--border)}.hris-modal-header span{font-size:11px;font-weight:800;color:var(--accent);letter-spacing:.08em}.hris-modal-header h3{margin:4px 0 2px;font-size:22px}.hris-modal-header p{margin:0;color:var(--muted)}.hris-modal-body{display:grid;gap:14px;padding:18px;background:var(--surface-soft);max-height:min(68vh,620px);overflow:auto}.hris-section{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:16px}.hris-section-title{display:flex;justify-content:space-between;gap:16px;margin-bottom:14px}.hris-section-title strong{font-size:15px}.hris-section-title span{color:var(--muted);font-size:12px;text-align:right}.hris-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px}.hris-form-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.hris-form-grid label{font-weight:700;color:var(--muted);font-size:12px}.hris-form-grid input,.hris-form-grid select{margin-top:7px;background:var(--surface);border:1px solid var(--border);border-radius:13px;padding:12px 13px}.hris-form-grid .wide{grid-column:1/-1}.hris-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;background:var(--surface);border-top:1px solid var(--border)}@media(max-width:640px){.wuc-modal-shell{padding:10px}.hris-style-modal{width:calc(100vw - 16px);border-radius:20px}.hris-modal-header{padding:18px}.hris-modal-header h3{font-size:18px}.hris-modal-body{padding:12px;max-height:70vh}.hris-section-title{display:block}.hris-section-title span{text-align:left;display:block;margin-top:4px}.hris-form-grid,.hris-form-grid.three{grid-template-columns:1fr}.hris-modal-footer{position:sticky;bottom:0}}

@media(min-width:901px){.equipment-page .panel{max-width:100%}.equipment-list-head,.equipment-list-row{grid-template-columns:minmax(260px,1fr) 90px 90px 90px 96px}.equipment-list-row{padding:14px 16px}.equipment-list-item strong{font-size:15px}.equipment-list-num{font-size:15px;font-weight:700}.equipment-page .compact-table table{min-width:0}}

.events-top-action{display:flex;justify-content:flex-end;margin-bottom:14px}.events-top-action button{box-shadow:0 14px 30px rgba(201,154,46,.18)}.event-create-modal{max-width:820px;width:min(820px,calc(100vw - 28px))}
@media(max-width:640px){.events-top-action{justify-content:stretch}.events-top-action button{width:100%;justify-content:center}.event-create-modal{width:calc(100vw - 16px)}}

@media(min-width:641px){.event-create-modal{max-width:980px;width:min(980px,calc(100vw - 48px))}.event-create-modal .hris-modal-body{padding:20px}.event-create-modal .hris-section{padding:18px}.event-create-modal .hris-section-title{align-items:flex-end;border-bottom:1px solid var(--border);padding-bottom:12px;margin-bottom:16px}.event-create-modal .hris-form-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;align-items:stretch}.event-create-modal .hris-form-grid label{display:flex;flex-direction:column;justify-content:space-between;min-height:82px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:10px;color:var(--text);font-size:11px;font-weight:800;letter-spacing:.025em;text-transform:uppercase}.event-create-modal .hris-form-grid input,.event-create-modal .hris-form-grid select,.event-create-modal .hris-form-grid textarea{width:100%;margin-top:8px;border-radius:10px;background:var(--surface-soft);font-size:14px;text-transform:none;letter-spacing:0}.event-create-modal .hris-form-grid .wide{grid-column:span 2}.event-create-modal .hris-form-grid .note{grid-column:1/-1;min-height:112px}.event-create-modal .hris-form-grid .note textarea{min-height:68px;resize:vertical}}

@media(min-width:641px){.event-create-modal .hris-form-grid{grid-template-columns:repeat(3,minmax(0,1fr));grid-auto-flow:row dense}.event-create-modal .hris-form-grid .wide{grid-column:span 1}.event-create-modal .hris-form-grid .note{grid-column:1/-1}}
.menu-autocomplete{position:relative;flex:1;min-width:0}.menu-autocomplete input{width:100%}.menu-suggestions{position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:20;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:6px;display:grid;gap:4px;max-height:220px;overflow:auto}.menu-suggestions button{width:100%;background:transparent;color:var(--text);border:0;border-radius:10px;padding:8px 10px;text-align:left;display:grid;gap:2px;box-shadow:none}.menu-suggestions button:hover{background:var(--surface-soft)}.menu-suggestions small{color:var(--muted);font-size:11px}
.schedule-filter-bar{display:flex;align-items:flex-end;justify-content:flex-end;gap:10px;flex-wrap:wrap}.schedule-filter-bar label{display:grid;gap:5px;color:var(--muted);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.schedule-filter-bar select{min-width:120px;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text);padding:9px 10px;font-weight:800}.schedule-filter-bar .schedule-tabs{align-self:flex-end}
@media(max-width:640px){.schedule-filter-bar{width:100%;justify-content:stretch}.schedule-filter-bar label{flex:1;min-width:130px}.schedule-filter-bar select{width:100%;min-width:0}.schedule-filter-bar .schedule-tabs{width:100%}}

/* Realisasi Dapur modal — HPP calculator style, WUC palette */
.kitchen-realization-modal{width:min(1180px,calc(100vw - 28px));max-height:calc(100dvh - 28px);overflow:hidden;display:flex;flex-direction:column;padding:0;background:var(--surface);border:1px solid var(--border);border-radius:30px;box-shadow:0 28px 80px rgba(47,41,36,.22)}
.kitchen-realization-modal .hris-modal-header{background:linear-gradient(135deg,rgba(243,223,170,.72),rgba(255,255,255,.94));border-bottom:1px solid var(--border);padding:22px 24px;display:flex;justify-content:space-between;gap:18px;align-items:flex-start}
.dark-mode .kitchen-realization-modal .hris-modal-header{background:linear-gradient(135deg,rgba(92,70,24,.52),rgba(42,37,32,.94))}
.kitchen-realization-modal .hris-modal-header span{display:block;color:var(--gold);font-size:12px;font-weight:950;letter-spacing:.12em;text-transform:uppercase;margin-bottom:5px}
.kitchen-realization-modal .hris-modal-header h3{margin:0;color:var(--heading);font-size:24px;letter-spacing:-.03em}
.kitchen-realization-modal .hris-modal-header p{margin:6px 0 0;color:var(--text);font-size:13px;font-weight:750}
.kitchen-realization-modal-body{padding:22px 24px;overflow:auto;display:grid;gap:16px;background:linear-gradient(180deg,rgba(255,255,255,.72),rgba(243,223,170,.10))}
.dark-mode .kitchen-realization-modal-body{background:linear-gradient(180deg,rgba(42,37,32,.82),rgba(92,70,24,.12))}
.hpp-modal-summary{margin-bottom:0;grid-template-columns:repeat(3,minmax(0,1fr))}
.hpp-modal-table{margin-top:0;border-radius:22px;box-shadow:0 14px 36px rgba(47,41,36,.08)}
.hpp-modal-table table{min-width:900px}
.hpp-modal-table th{background:linear-gradient(180deg,rgba(232,187,85,.24),rgba(201,154,46,.08));color:#7a4d0b}
.hpp-modal-table td:first-child,.hpp-modal-table th:first-child{min-width:300px}
.hpp-modal-table td:nth-child(2),.hpp-modal-table th:nth-child(2){min-width:150px;text-align:right}
.hpp-modal-table td:nth-child(3),.hpp-modal-table th:nth-child(3),.hpp-modal-table td:nth-child(4),.hpp-modal-table th:nth-child(4){min-width:170px;text-align:right;white-space:nowrap}
.hpp-modal-table input{background:var(--surface-2);font-weight:800;color:var(--heading)}
.kitchen-realization-modal .add-line{margin:0;border:1px dashed var(--gold);border-radius:18px;background:rgba(243,223,170,.20);padding:14px}
.kitchen-realization-modal .hris-modal-footer{border-top:1px solid var(--border);padding:16px 24px;display:flex;justify-content:flex-end;gap:10px;background:var(--surface)}
@media(max-width:760px){.kitchen-realization-modal{width:calc(100vw - 18px);max-height:calc(100dvh - 18px);border-radius:24px}.kitchen-realization-modal .hris-modal-header{padding:18px}.kitchen-realization-modal .hris-modal-header h3{font-size:20px}.kitchen-realization-modal-body{padding:16px}.hpp-modal-summary{grid-template-columns:1fr}.kitchen-realization-modal .hris-modal-footer{padding:14px 16px;display:grid;grid-template-columns:1fr}.kitchen-realization-modal .hris-modal-footer button{width:100%;justify-content:center}}

/* Keep Input Realisasi modal centered in viewport even inside filtered/scrolling page containers */
.kitchen-realization-overlay{
  position:fixed!important;
  inset:0!important;
  z-index:3000!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:16px!important;
  overflow:hidden!important;
  overscroll-behavior:contain;
}
.kitchen-realization-overlay .kitchen-realization-modal{
  margin:0!important;
  width:min(1180px,calc(100vw - 32px))!important;
  max-height:calc(100dvh - 32px)!important;
  transform:none!important;
}
.kitchen-realization-overlay .kitchen-realization-modal-body{
  max-height:calc(100dvh - 250px)!important;
  overflow:auto!important;
}
@media(max-width:640px){
  .kitchen-realization-overlay{align-items:flex-start!important;padding:10px!important;overflow:auto!important}
  .kitchen-realization-overlay .kitchen-realization-modal{width:calc(100vw - 20px)!important;max-height:none!important}
  .kitchen-realization-overlay .kitchen-realization-modal-body{max-height:70dvh!important}
}

/* Bahan Baku: compact one-line table + edit modal */
.raw-materials-page .raw-materials-table-wrap{overflow-x:auto}
.raw-materials-page .raw-materials-table{min-width:960px!important;table-layout:auto}
.raw-materials-page .raw-materials-table th,
.raw-materials-page .raw-materials-table td{white-space:nowrap;vertical-align:middle}
.raw-materials-page .raw-materials-table th:nth-child(1),.raw-materials-page .raw-materials-table td:nth-child(1){min-width:92px!important}
.raw-materials-page .raw-materials-table th:nth-child(2),.raw-materials-page .raw-materials-table td:nth-child(2){min-width:260px!important;max-width:360px;overflow:hidden;text-overflow:ellipsis}
.raw-materials-page .raw-materials-table th:nth-child(3),.raw-materials-page .raw-materials-table td:nth-child(3){min-width:150px!important}
.raw-materials-page .raw-materials-table th:nth-child(4),.raw-materials-page .raw-materials-table td:nth-child(4){min-width:130px!important;text-align:right}
.raw-materials-page .raw-materials-table th:nth-child(5),.raw-materials-page .raw-materials-table td:nth-child(5){min-width:110px!important}
.raw-materials-page .raw-materials-table th:nth-child(6),.raw-materials-page .raw-materials-table td:nth-child(6){min-width:150px!important}
.raw-materials-page .raw-materials-table th:nth-child(7),.raw-materials-page .raw-materials-table td:nth-child(7){min-width:90px!important;text-align:right}
.raw-material-edit-overlay{position:fixed!important;inset:0!important;z-index:3000!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:16px!important;overflow:auto!important;overscroll-behavior:contain}
.raw-material-edit-modal{width:min(780px,calc(100vw - 32px));max-height:calc(100dvh - 32px);overflow:hidden;display:flex;flex-direction:column}
.raw-material-edit-modal .hris-modal-body{overflow:auto}
.raw-material-edit-footer{justify-content:space-between!important;align-items:center}.raw-material-edit-footer>div{display:flex;gap:10px;align-items:center}
@media(max-width:640px){.raw-material-edit-overlay{align-items:flex-start!important;padding:10px!important}.raw-material-edit-modal{width:calc(100vw - 20px);max-height:none}.raw-material-edit-footer{display:grid!important;gap:10px}.raw-material-edit-footer>div{justify-content:flex-end}}
