:root{
  --ink:#0d0b08;--paper:#fff9ef;--sand:#f0d1a3;--sand2:#f8e6c9;--accent:#b7772d;
  --ok:#208047;--warn:#d98806;--bad:#b42318;--muted:#746958;--line:#ead6b8;
  --shadow:0 18px 50px rgba(20,13,5,.13)
}
*{box-sizing:border-box;min-width:0}
html,body{margin:0;width:100%;max-width:100%;overflow-x:hidden;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:linear-gradient(135deg,var(--paper),#f4d9b0);color:var(--ink);touch-action:manipulation;-webkit-text-size-adjust:100%}
button,input,select,textarea{font:inherit;max-width:100%}a{color:inherit}.login-body{min-height:100vh;display:grid;place-items:center;padding:24px}.login-shell{width:min(1050px,100%);display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:center}.brand-card,.login-card,.panel{background:rgba(255,249,239,.94);border:1px solid rgba(13,11,8,.08);border-radius:28px;box-shadow:var(--shadow);padding:28px}.brand-card{text-align:center}.login-logo{width:190px;max-width:70%;border-radius:18px;box-shadow:0 10px 25px rgba(0,0,0,.10)}.brand-card h1,.login-card h1{font-size:clamp(2rem,5vw,4rem);margin:.3em 0 .1em}.brand-card p,.muted{color:var(--muted)}.small{font-size:.9rem}.stack{display:grid;gap:12px}.segmented{display:grid;grid-template-columns:1fr 1fr;background:var(--sand2);padding:6px;border-radius:16px;gap:6px}.segmented label{display:flex;gap:7px;align-items:center;justify-content:center;border-radius:12px;padding:10px;background:#fff8}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:10px 12px;background:#fff;color:var(--ink)}textarea{min-height:75px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:13px;padding:10px 14px;background:#ede0cb;color:var(--ink);font-weight:800;text-decoration:none;cursor:pointer}.btn.primary,.btn.publish{background:var(--ink);color:#fff}.btn.publish{background:var(--ok)}.danger-btn{background:#fee4e2;color:var(--bad)}.alert{padding:13px 15px;border-radius:15px;margin:10px 0;font-weight:750}.alert.ok,.okline{background:#dcfae6;color:#075e35}.alert.danger{background:#fee4e2;color:#912018}.alert.warn,.status-row.warn{background:#fef0c7;color:#93370d}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:10px 18px;background:rgba(13,11,8,.96);color:white;box-shadow:0 8px 30px rgba(0,0,0,.18);max-width:100%}.topbrand{display:flex;align-items:center;gap:12px}.topbrand img{width:54px;height:54px;object-fit:cover;border-radius:12px;background:var(--sand)}.topbrand span{display:block;color:#d9c7ab;font-size:.88rem}.topbar nav{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.topbar nav a{padding:8px 10px;border-radius:10px;text-decoration:none;color:#fff;background:rgba(255,255,255,.08);white-space:nowrap}.topbar nav a.active{background:var(--sand);color:var(--ink)}.admin-wrap,.worker-wrap{width:min(1500px,100%);margin:auto;padding:22px;display:grid;gap:22px}.panel h1,.panel h2{margin-top:0}.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}.toolbar,.actions-line,.inline-form{display:flex;gap:12px;align-items:end;flex-wrap:wrap;margin:12px 0}.toolbar label{min-width:190px;flex:1}.status-row{padding:12px 15px;border-radius:15px;margin:12px 0;font-weight:800}.table-scroll{overflow:auto;border-radius:18px;border:1px solid var(--line);background:white;max-width:100%}table{width:100%;border-collapse:collapse;background:white}th,td{border-bottom:1px solid var(--line);padding:10px;text-align:left;vertical-align:top}thead th{position:sticky;top:0;background:#fff3dd;z-index:1}.schedule-table{min-width:1250px}.schedule-table th:first-child,.schedule-table td:first-child{position:sticky;left:0;background:#fffaf1;z-index:2}.worker-head{min-width:160px}.worker-head span{display:block;font-size:.83rem;color:var(--muted);font-weight:600}.shift-cell{min-width:150px}.mobile-day{display:none}.shift-cell .times{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:7px 0}.shift-cell .note{font-size:.88rem}.shift-cell.not-work .times,.shift-cell.not-work .note{opacity:.36}.total{min-width:105px;font-weight:900;border-left:4px solid transparent}.total span{display:block;font-size:.85rem}.total.ok{color:var(--ok);border-left-color:var(--ok)}.total.warn{color:var(--warn);border-left-color:var(--warn)}.total.bad{color:var(--bad);border-left-color:var(--bad)}.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}.mini-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px}.mini-card h3{margin-top:0}.pill{display:inline-block;background:var(--sand2);border:1px solid var(--line);border-radius:999px;padding:4px 8px;margin:2px;font-size:.85rem}.employee-form{background:#fffaf3;border:1px solid var(--line);border-radius:18px;padding:15px;margin:10px 0;display:grid;gap:10px}.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}.check{display:flex;align-items:center;gap:8px}.check input{width:auto}.check-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px}.check-grid label{background:white;padding:9px;border-radius:12px;border:1px solid var(--line)}.check-grid input{width:auto}.worker-hero{display:flex;align-items:center;gap:16px;padding:16px 22px;background:var(--ink);color:#fff}.worker-hero img{width:76px;height:76px;object-fit:cover;border-radius:17px;background:var(--sand)}.worker-hero h1{margin:0}.worker-hero p{margin:2px 0;color:#d9c7ab}.worker-hero .btn{margin-left:auto}.worker-week-nav{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.total-box{font-size:1.2rem;background:#fff3dd;border:1px solid var(--line);border-radius:18px;padding:15px;margin:10px 0}.worker-days{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}.day-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:16px}.day-card h3{margin:0 0 12px}.shift-badge{display:grid;gap:4px;border-radius:16px;padding:12px;margin:8px 0;background:#f7f1e7;border:1px solid var(--line)}.shift-badge.work{background:#dcfae6}.shift-badge.free{background:#eef2f6}.shift-badge.vacation{background:#e0f2fe}.shift-badge.sick{background:#fee4e2}.shift-badge.unavailable{background:#fef0c7}.shift-badge em{color:var(--muted)}
@media(max-width:900px){
  .login-body{padding:14px}.login-shell{grid-template-columns:1fr;gap:14px}.brand-card,.login-card,.panel{border-radius:20px;padding:16px}.brand-card{padding:14px}.login-logo{width:130px}.topbar{position:static;align-items:flex-start;flex-direction:column;padding:10px 12px}.topbar nav{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;justify-content:stretch}.topbar nav a{text-align:center;white-space:normal}.admin-wrap,.worker-wrap{padding:10px;gap:12px}.toolbar,.actions-line,.inline-form{display:grid;grid-template-columns:1fr;align-items:stretch}.toolbar label{min-width:0;width:100%}.btn{width:100%}.table-scroll{overflow:visible;border:0;background:transparent}.schedule-table,.schedule-table thead,.schedule-table tbody,.schedule-table tr,.schedule-table th,.schedule-table td{display:block;width:100%;min-width:0}.schedule-table{background:transparent}.schedule-table thead{display:none}.schedule-table tr.schedule-worker-row{background:#fff;border:1px solid var(--line);border-radius:20px;margin:0 0 16px;padding:12px;box-shadow:0 8px 22px rgba(20,13,5,.07)}.schedule-table th:first-child,.schedule-table td:first-child,.schedule-table th,.schedule-table td{position:static;background:transparent;border-bottom:0;padding:8px 0}.worker-head{font-size:1.05rem;border-bottom:1px solid var(--line)!important;margin-bottom:8px}.shift-cell{border-top:1px solid #f1e1ca!important;padding-top:12px!important}.mobile-day{display:block;font-weight:900;margin-bottom:6px;color:var(--accent)}.shift-cell .times{grid-template-columns:1fr 1fr}.total{border-left:0;border-top:2px solid var(--line)!important;margin-top:8px;padding-top:12px!important}.admin-list,.admin-list thead,.admin-list tbody,.admin-list tr,.admin-list th,.admin-list td{display:block;width:100%}.admin-list thead{display:none}.admin-list tr{background:#fff;border:1px solid var(--line);border-radius:18px;margin:0 0 12px;padding:10px}.admin-list td{border:0;padding:8px 0}.admin-list td::before{content:attr(data-label);display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:900;margin-bottom:3px}.worker-hero{align-items:flex-start;padding:12px}.worker-hero img{width:56px;height:56px}.worker-hero .btn{margin-left:0;width:auto}.worker-days,.cards-grid{grid-template-columns:1fr}.grid-2{grid-template-columns:1fr}.check-grid{grid-template-columns:1fr}
}
@media print{body{background:white}.no-print,.topbar,.worker-hero{display:none!important}.admin-wrap,.worker-wrap{padding:0;width:100%}.panel{box-shadow:none;border:0;padding:0}.table-scroll{overflow:visible;border:0}.schedule-table{min-width:0;font-size:9px}.mobile-day{display:none}.shift-cell select,.shift-cell input{border:0;padding:0;background:transparent}.shift-cell .note:placeholder-shown{display:none}th,td{padding:4px}.schedule-table th:first-child,.schedule-table td:first-child,thead th{position:static}.cards-grid{display:none}}
.carry-info{font-weight:900;color:var(--muted)}
.carry-info.debt{color:var(--warn)}
.carry-info.credit{color:var(--ok)}
.total em{display:block;font-size:.72rem;color:var(--muted);font-style:normal;margin-top:3px}
.ok-text{color:var(--ok)}.warn-text{color:var(--warn)}.bad-text{color:var(--bad)}
@media print{
  @page{size:A4 landscape;margin:5mm}
  html,body{width:297mm;min-height:210mm;overflow:visible!important;background:white!important}
  .schedule-print-area{page-break-inside:avoid;break-inside:avoid;transform-origin:top left}
  .schedule-table{width:100%!important;table-layout:fixed!important;font-size:7px!important;line-height:1.05!important}
  .schedule-table th,.schedule-table td{padding:2px!important;word-break:normal!important;overflow:hidden!important}
  .worker-head{min-width:0!important;width:22mm!important}
  .worker-head span{font-size:6px!important;line-height:1.05!important}
  .shift-cell{min-width:0!important;width:auto!important}
  .shift-cell .times{display:block!important;margin:0!important}
  .shift-cell input[type="time"]{display:inline!important;width:46%!important;font-size:7px!important;margin:0!important}
  .shift-cell select{font-size:7px!important;white-space:normal!important}
  .shift-cell .note{display:none!important}
  .total{min-width:0!important;width:18mm!important;font-size:7px!important}
  .panel h1,.panel h2,.status-row{font-size:10px!important;margin:2px 0!important;padding:2px!important}
}

/* v4: administración móvil/PC sin scroll lateral y horarios por acordeón */
html, body { max-width:100%; overflow-x:hidden; }
*, *::before, *::after { box-sizing:border-box; }
img, table { max-width:100%; }
.schedule-accordion{display:grid;gap:12px;margin-top:14px;max-width:100%;}
.employee-schedule-card{background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:0 8px 22px rgba(20,13,5,.06);overflow:hidden;max-width:100%;}
.employee-schedule-card summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;background:#fffaf1;}
.employee-schedule-card summary::-webkit-details-marker{display:none;}
.employee-schedule-card summary::before{content:'▸';font-weight:900;color:var(--accent);transition:transform .15s ease;}
.employee-schedule-card[open] summary::before{transform:rotate(90deg);}
.worker-summary-main{display:grid;gap:3px;min-width:0;flex:1;}
.worker-summary-main strong{font-size:1.05rem;}
.worker-summary-main small{color:var(--muted);font-weight:700;line-height:1.25;}
.employee-schedule-card .total{min-width:110px;border-left:0;text-align:right;padding:0;}
.employee-week-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;padding:14px;max-width:100%;}
.day-editor{background:#fff;border:1px solid var(--line);border-radius:16px;padding:10px;min-width:0;}
.day-editor h4{margin:0 0 8px;font-size:.9rem;color:var(--accent);}
.day-editor select,.day-editor input{font-size:.9rem;min-width:0;}
.day-editor .times{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:7px 0;}
.print-only{display:none!important;}
.compact-print-table{width:100%;border-collapse:collapse;table-layout:fixed;background:white;}
.compact-print-table th,.compact-print-table td{border:1px solid #111;padding:3px;text-align:center;vertical-align:middle;line-height:1.05;}
.compact-print-table th:first-child,.compact-print-table td:first-child{text-align:left;width:26mm;font-weight:800;}
.print-sheet h1,.print-sheet p{margin:0 0 4px;text-align:center;}
@media(max-width:1150px){.employee-week-grid{grid-template-columns:repeat(4,minmax(0,1fr));}}
@media(max-width:760px){.employee-schedule-card summary{align-items:flex-start;}.employee-schedule-card .total{text-align:left;min-width:86px}.employee-week-grid{grid-template-columns:1fr}.day-editor .times{grid-template-columns:1fr 1fr;}.worker-summary-main small{font-size:.78rem}}

@media print{
  @page{size:A4 landscape;margin:4mm}
  html,body{width:297mm;min-height:210mm;overflow:visible!important;background:white!important;}
  .no-print,.topbar,.worker-hero,.schedule-form,.worker-days,.total-box,.worker-week-nav{display:none!important;}
  .print-only{display:block!important;}
  .admin-wrap,.worker-wrap{padding:0!important;margin:0!important;width:100%!important;max-width:100%!important;}
  .panel{box-shadow:none!important;border:0!important;padding:0!important;margin:0!important;background:white!important;}
  .print-sheet{page-break-inside:avoid;break-inside:avoid;width:100%;}
  .print-sheet h1{font-size:12px!important;line-height:1.05!important;}
  .print-sheet p{font-size:9px!important;}
  .compact-print-table{font-size:7px!important;line-height:1!important;page-break-inside:avoid;break-inside:avoid;}
  .compact-print-table th,.compact-print-table td{padding:1.5px!important;word-break:normal!important;overflow:hidden!important;}
  .compact-print-table th:first-child,.compact-print-table td:first-child{width:24mm!important;}
}

/* v5: acordeón de horarios más limpio y exportación/impresión unificada */
.schedule-accordion{
  gap:14px;
}
.employee-schedule-card{
  border-radius:22px;
  border:1px solid rgba(13,11,8,.10);
  box-shadow:0 10px 28px rgba(20,13,5,.08);
  background:#fffdf8;
}
.employee-schedule-card summary,
.employee-schedule-card summary.employee-row-summary{
  list-style:none;
  cursor:pointer;
  display:grid;
  grid-template-columns:32px minmax(0,1fr) auto;
  align-items:center;
  gap:12px;
  padding:15px 18px;
  background:linear-gradient(90deg,#fffaf1,#fff);
  border-left:6px solid var(--sand);
}
.employee-schedule-card summary::before{content:none!important;display:none!important;}
.employee-open-indicator{
  width:26px;height:26px;border-radius:999px;
  display:grid;place-items:center;
  background:#f3dfbf;border:1px solid var(--line);
  color:var(--ink);font-weight:900;
}
.employee-open-indicator::before{content:'+';line-height:1;}
.employee-schedule-card[open] .employee-open-indicator::before{content:'−';}
.worker-summary-main strong{font-size:1.08rem;line-height:1.15;}
.worker-summary-main small{display:block;color:var(--muted);font-weight:700;}
.worker-summary-main .edit-hint{font-size:.78rem;color:#9b6a2e;font-weight:800;margin-top:3px;}
.worker-summary-status{
  display:grid;gap:2px;justify-items:end;text-align:right;
  min-width:112px;padding:8px 10px;border-radius:14px;
  background:#f7f1e7;border:1px solid var(--line);font-weight:900;
}
.worker-summary-status span{font-size:.82rem;}
.worker-summary-status em{display:block;font-size:.70rem;color:var(--muted);font-style:normal;}
.worker-summary-status.ok{background:#dcfae6;color:var(--ok);border-color:#abefc6;}
.worker-summary-status.warn{background:#fef0c7;color:var(--warn);border-color:#fedf89;}
.worker-summary-status.bad{background:#fee4e2;color:var(--bad);border-color:#fecdca;}
.employee-schedule-card[open] summary.employee-row-summary{border-bottom:1px solid var(--line);}
.employee-week-grid{background:#fffaf3;}
.day-editor{box-shadow:inset 0 1px 0 rgba(255,255,255,.6);}
.day-editor h4{font-size:.92rem;letter-spacing:.01em;}
@media(max-width:760px){
  .employee-schedule-card summary,.employee-schedule-card summary.employee-row-summary{grid-template-columns:28px minmax(0,1fr);}
  .worker-summary-status{grid-column:2;justify-items:start;text-align:left;width:100%;min-width:0;}
}

@media print{
  @page{size:A4 landscape;margin:4mm;}
  html,body{width:297mm!important;height:auto!important;min-height:0!important;background:#fff!important;overflow:visible!important;}
  .no-print,.topbar,.worker-hero,.schedule-form,.worker-days,.total-box,.worker-week-nav,.alert{display:none!important;}
  .print-only{display:block!important;}
  .worker-wrap,.admin-wrap{display:block!important;width:100%!important;max-width:100%!important;margin:0!important;padding:0!important;}
  .panel{display:block!important;width:100%!important;max-width:100%!important;margin:0!important;padding:0!important;border:0!important;box-shadow:none!important;background:#fff!important;}
  .panel>h2:not(.print-keep), .panel>.total-box{display:none!important;}
  .print-sheet{display:block!important;width:287mm!important;max-width:287mm!important;margin:0 auto!important;page-break-inside:avoid!important;break-inside:avoid!important;overflow:hidden!important;}
  .print-sheet h1{font-size:12px!important;line-height:1!important;margin:0 0 2mm!important;text-align:center!important;}
  .print-sheet p{font-size:8px!important;line-height:1!important;margin:0 0 2mm!important;text-align:center!important;}
  .compact-print-table,.worker-print-table{width:100%!important;max-width:100%!important;border-collapse:collapse!important;table-layout:fixed!important;font-size:7px!important;line-height:1!important;page-break-inside:avoid!important;break-inside:avoid!important;}
  .compact-print-table th,.compact-print-table td,.worker-print-table th,.worker-print-table td{border:1px solid #111!important;padding:1.2px!important;text-align:center!important;vertical-align:middle!important;word-break:normal!important;overflow:hidden!important;}
  .compact-print-table th:first-child,.compact-print-table td:first-child,.worker-print-table th:first-child,.worker-print-table td:first-child{width:25mm!important;text-align:left!important;font-weight:800!important;}
  .worker-print-table th:last-child,.worker-print-table td:last-child,.compact-print-table th:last-child,.compact-print-table td:last-child{width:16mm!important;}
}


/* v6: acordeones de horario como botones anchos, más claros y sin aspecto de texto suelto */
.schedule-accordion{display:grid;gap:12px;margin-top:14px;max-width:100%;}
.employee-schedule-card{border:0!important;background:transparent!important;box-shadow:none!important;overflow:visible!important;margin:0!important;max-width:100%;}
.employee-schedule-card summary.employee-row-summary,
.employee-schedule-card summary{
  width:100%!important;
  display:grid!important;
  grid-template-columns:36px minmax(0,1fr) auto!important;
  align-items:center!important;
  gap:14px!important;
  padding:14px 16px!important;
  border:2px solid #21170d!important;
  border-radius:18px!important;
  background:linear-gradient(135deg,#fff8ed,#f1d4a8)!important;
  color:var(--ink)!important;
  box-shadow:0 8px 18px rgba(20,13,5,.10)!important;
  cursor:pointer!important;
  min-height:68px!important;
}
.employee-schedule-card summary.employee-row-summary:hover{filter:brightness(.985);transform:translateY(-1px);}
.employee-schedule-card[open] summary.employee-row-summary{border-radius:18px 18px 0 0!important;border-bottom-color:var(--line)!important;}
.employee-open-indicator{width:28px;height:28px;border-radius:999px;background:var(--ink);display:grid;place-items:center;color:#fff;font-weight:900;flex:0 0 auto;}
.employee-open-indicator::before{content:'+'!important;font-size:19px;line-height:1;}
.employee-schedule-card[open] .employee-open-indicator::before{content:'−'!important;}
.worker-summary-main{display:grid!important;gap:2px!important;min-width:0!important;}
.worker-summary-main strong{font-size:1.05rem!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.worker-summary-main small{font-size:.82rem!important;color:#5f5140!important;font-weight:800!important;white-space:normal!important;}
.worker-summary-main .edit-hint{display:none!important;}
.worker-summary-status{min-width:128px!important;box-shadow:inset 0 0 0 1px rgba(0,0,0,.04);}
.employee-week-grid{border:2px solid #21170d;border-top:0;border-radius:0 0 18px 18px;padding:12px;background:#fffaf3!important;}

/* v6: trabajadores organizados por locales */
.employee-location-groups{display:grid;gap:18px;margin-top:16px;}
.location-employee-group{background:#fff;border:1px solid var(--line);border-radius:22px;padding:16px;box-shadow:0 8px 22px rgba(20,13,5,.06);}
.location-employee-group h3{margin:0 0 12px;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.location-employee-group h3 span{font-size:.82rem;background:var(--sand2);border:1px solid var(--line);border-radius:999px;padding:5px 9px;color:var(--muted);}
.employee-list-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;}
.employee-admin-card{background:#fffaf3;border:1px solid var(--line);border-radius:18px;padding:13px;}
.employee-admin-card.is-inactive{opacity:.58;}
.employee-admin-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.employee-admin-head strong{display:block;font-size:1rem;}
.employee-admin-head small{display:block;color:var(--muted);font-weight:750;margin-top:2px;}
.employee-admin-head details{min-width:92px;text-align:right;}
.employee-admin-head details>summary{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:12px;padding:8px 11px;background:#ede0cb;font-weight:900;cursor:pointer;list-style:none;}
.employee-admin-head details>summary::-webkit-details-marker{display:none;}
.employee-admin-locations{margin-top:10px;}
.admin-create-box{background:#fffaf3;border:1px solid var(--line);border-radius:18px;padding:12px;margin:12px 0;}
.admin-create-box>summary{font-weight:900;cursor:pointer;}

@media(max-width:760px){
  .employee-schedule-card summary.employee-row-summary,.employee-schedule-card summary{grid-template-columns:32px minmax(0,1fr)!important;}
  .worker-summary-status{grid-column:1 / -1!important;width:100%!important;justify-items:start!important;text-align:left!important;min-width:0!important;}
  .employee-admin-head{display:grid;grid-template-columns:1fr;}
  .employee-admin-head details{min-width:0;text-align:left;}
}

/* v6: impresión compacta real para trabajador, igual que administración */
@media print{
  @page{size:A4 landscape;margin:3mm;}
  body.worker-body{background:#fff!important;width:297mm!important;max-width:297mm!important;overflow:visible!important;}
  body.worker-body .no-print,
  body.worker-body .worker-hero,
  body.worker-body .worker-days,
  body.worker-body .total-box,
  body.worker-body .worker-week-nav,
  body.worker-body .alert{display:none!important;}
  body.worker-body .worker-wrap{display:block!important;width:100%!important;max-width:100%!important;margin:0!important;padding:0!important;}
  body.worker-body .panel{display:block!important;width:100%!important;max-width:100%!important;margin:0!important;padding:0!important;border:0!important;box-shadow:none!important;background:#fff!important;overflow:visible!important;}
  body.worker-body .panel>h2{display:none!important;}
  body.worker-body .print-only,
  body.worker-body .worker-print-sheet{display:block!important;visibility:visible!important;}
  body.worker-body .worker-print-sheet{width:291mm!important;max-width:291mm!important;margin:0 auto!important;padding:0!important;page-break-inside:avoid!important;break-inside:avoid!important;overflow:hidden!important;}
  body.worker-body .worker-print-sheet h1{font-size:12px!important;line-height:1!important;margin:0 0 1.5mm!important;text-align:center!important;}
  body.worker-body .worker-print-sheet p{font-size:8px!important;line-height:1!important;margin:0 0 2mm!important;text-align:center!important;}
  body.worker-body .worker-print-table{width:100%!important;max-width:100%!important;border-collapse:collapse!important;table-layout:fixed!important;font-size:6.5px!important;line-height:1!important;page-break-inside:avoid!important;break-inside:avoid!important;}
  body.worker-body .worker-print-table th,
  body.worker-body .worker-print-table td{border:1px solid #111!important;padding:1px!important;text-align:center!important;vertical-align:middle!important;word-break:normal!important;overflow:hidden!important;height:auto!important;}
  body.worker-body .worker-print-table th:first-child,
  body.worker-body .worker-print-table td:first-child{width:25mm!important;text-align:left!important;font-weight:900!important;}
  body.worker-body .worker-print-table th:last-child,
  body.worker-body .worker-print-table td:last-child{width:15mm!important;}
}


/* v7: desplegables del creador de horarios con presencia clara de botón */
.schedule-accordion{
  display:grid!important;
  gap:14px!important;
  margin-top:18px!important;
  width:100%!important;
}
.employee-schedule-card{
  display:block!important;
  width:100%!important;
  border:0!important;
  background:transparent!important;
  margin:0!important;
  padding:0!important;
}
.employee-schedule-card > summary,
.employee-schedule-card > summary.employee-row-summary{
  appearance:none!important;
  -webkit-appearance:none!important;
  list-style:none!important;
  width:100%!important;
  min-height:78px!important;
  display:grid!important;
  grid-template-columns:42px minmax(0,1fr) minmax(120px,auto) auto!important;
  align-items:center!important;
  gap:14px!important;
  padding:15px 18px!important;
  border:2px solid #16100a!important;
  border-radius:20px!important;
  background:linear-gradient(135deg,#17110b 0%,#2a1c10 38%,#b9782c 100%)!important;
  color:#fff!important;
  box-shadow:0 12px 26px rgba(24,14,4,.22), inset 0 1px 0 rgba(255,255,255,.22)!important;
  cursor:pointer!important;
  user-select:none!important;
  transition:transform .15s ease, box-shadow .15s ease, filter .15s ease!important;
}
.employee-schedule-card > summary::-webkit-details-marker{display:none!important;}
.employee-schedule-card > summary::marker{content:''!important;}
.employee-schedule-card > summary:hover{
  transform:translateY(-2px)!important;
  box-shadow:0 16px 32px rgba(24,14,4,.28), inset 0 1px 0 rgba(255,255,255,.22)!important;
  filter:saturate(1.03)!important;
}
.employee-schedule-card[open] > summary.employee-row-summary,
.employee-schedule-card[open] > summary{
  border-radius:20px 20px 0 0!important;
  background:linear-gradient(135deg,#0d0b08 0%,#23170d 45%,#9f6423 100%)!important;
}
.employee-open-indicator{
  width:34px!important;
  height:34px!important;
  border-radius:999px!important;
  background:#fff!important;
  color:#17110b!important;
  display:grid!important;
  place-items:center!important;
  font-weight:1000!important;
  box-shadow:0 5px 14px rgba(0,0,0,.22)!important;
}
.employee-open-indicator::before{content:'+'!important;font-size:24px!important;line-height:1!important;}
.employee-schedule-card[open] .employee-open-indicator::before{content:'−'!important;font-size:25px!important;}
.employee-schedule-card .worker-summary-main strong{
  color:#fff!important;
  font-size:1.16rem!important;
  letter-spacing:.01em!important;
}
.employee-schedule-card .worker-summary-main small{
  color:#f7e5c8!important;
  font-weight:750!important;
  line-height:1.25!important;
}
.employee-schedule-card .worker-summary-main .edit-hint{
  display:block!important;
  color:#ffe7b8!important;
  font-size:.78rem!important;
  text-transform:uppercase!important;
  letter-spacing:.04em!important;
  margin-top:4px!important;
}
.employee-schedule-card .worker-summary-status{
  min-width:122px!important;
  justify-items:center!important;
  text-align:center!important;
  border:1px solid rgba(255,255,255,.65)!important;
  border-radius:16px!important;
  background:rgba(255,255,255,.92)!important;
  box-shadow:none!important;
}
.employee-schedule-card .worker-summary-status.ok{color:var(--ok)!important;}
.employee-schedule-card .worker-summary-status.warn{color:var(--warn)!important;}
.employee-schedule-card .worker-summary-status.bad{color:var(--bad)!important;}
.employee-schedule-card .worker-summary-status em{color:#5f5140!important;}
.worker-summary-cta{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:38px!important;
  padding:8px 13px!important;
  border-radius:999px!important;
  background:#fff!important;
  color:#17110b!important;
  font-weight:1000!important;
  white-space:nowrap!important;
  box-shadow:0 6px 14px rgba(0,0,0,.18)!important;
}
.employee-week-grid{
  border:2px solid #16100a!important;
  border-top:0!important;
  border-radius:0 0 20px 20px!important;
  padding:14px!important;
  background:#fff8ec!important;
  box-shadow:0 10px 24px rgba(24,14,4,.10)!important;
}
@media(max-width:760px){
  .employee-schedule-card > summary,
  .employee-schedule-card > summary.employee-row-summary{
    grid-template-columns:38px minmax(0,1fr)!important;
    min-height:0!important;
    padding:14px!important;
  }
  .employee-schedule-card .worker-summary-status{
    grid-column:1 / -1!important;
    width:100%!important;
    justify-items:start!important;
    text-align:left!important;
  }
  .worker-summary-cta{
    grid-column:1 / -1!important;
    width:100%!important;
  }
}

/* v8: bloqueos visuales por turnos en otros locales */
.locked-shifts{
  display:grid!important;
  gap:6px!important;
  margin:8px 0 10px!important;
}
.locked-shift{
  border:1px solid #b42318!important;
  background:#fee4e2!important;
  color:#912018!important;
  border-radius:11px!important;
  padding:7px 8px!important;
  font-size:.82rem!important;
  font-weight:900!important;
  line-height:1.2!important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.55)!important;
}
.shift-cell.has-locked-conflict{
  border-color:#d92d20!important;
  background:#fff1f0!important;
  box-shadow:0 0 0 2px rgba(217,45,32,.16)!important;
}
.locked-conflict-msg{
  margin-top:8px!important;
  border-radius:10px!important;
  padding:7px 8px!important;
  background:#d92d20!important;
  color:#fff!important;
  font-weight:900!important;
  font-size:.78rem!important;
  line-height:1.25!important;
}
.btn.is-disabled-by-conflict,
.btn:disabled{
  opacity:.45!important;
  cursor:not-allowed!important;
  filter:grayscale(.3)!important;
}
.shift-cell.not-work .locked-shifts,
.shift-cell.not-work .locked-shift{
  opacity:1!important;
}

/* v10: recupera los 4 campos 2x2 de la v8, y deja solo 2 campos si hay turno bloqueado en otro local */
.day-editor .times.times-full-four{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:7px 0;}
.day-editor .times.times-locked-two{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:7px 0;padding:8px;background:#fff7ec;border:1px solid rgba(112,27,21,.22);border-radius:12px;}
.single-slot-note{margin:6px 0 0;font-size:12px;font-weight:800;color:#8d342d;line-height:1.25;}

/* v11 · Avisos de horarios publicados */
.notify-dot {
  display: inline-block;
  width: .7rem;
  height: .7rem;
  margin-left: .35rem;
  border-radius: 999px;
  background: #d72626;
  box-shadow: 0 0 0 4px rgba(215, 38, 38, .18), 0 0 18px rgba(215, 38, 38, .55);
  vertical-align: middle;
}

.worker-notification-banner {
  position: sticky;
  top: 0;
  z-index: 50;
  margin: .75rem auto 0;
  width: min(940px, calc(100vw - 1rem));
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .65rem;
  padding: .75rem .9rem;
  border: 2px solid #2a160d;
  border-radius: 18px;
  background: linear-gradient(135deg, #ffe2af, #fff7e8);
  color: #17100a;
  box-shadow: 0 12px 30px rgba(0,0,0,.16);
}

.worker-notification-banner strong { font-size: 1rem; }
.worker-notification-banner span { flex: 1; color: #4e4132; font-size: .92rem; }
.worker-notification-banner button {
  border: 0;
  border-radius: 999px;
  padding: .55rem .85rem;
  background: #15110c;
  color: #fff4df;
  font-weight: 800;
}

.notify-permission-btn {
  white-space: nowrap;
  border-color: #d9ae68 !important;
  background: #fff2d8 !important;
  color: #1b130b !important;
}

@media (max-width: 720px) {
  .worker-hero { gap: .55rem; }
  .notify-permission-btn { width: 100%; order: 4; }
  .worker-notification-banner {
    align-items: stretch;
    flex-direction: column;
  }
  .worker-notification-banner button { width: 100%; }
}

/* v12 · Web Push real y vista trabajador limpia */
.worker-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-left:auto;justify-content:flex-end;}
.worker-actions .btn{margin-left:0!important;}
.worker-actions .btn.ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);}
.notify-permission-btn:disabled{opacity:.85!important;cursor:default!important;}
@media(max-width:720px){
  .worker-hero{display:grid;grid-template-columns:56px 1fr;align-items:center;}
  .worker-actions{grid-column:1 / -1;width:100%;display:grid;grid-template-columns:1fr;}
  .worker-actions .btn{width:100%!important;}
}


/* v13 · Vista trabajador limpia y botón Salir arriba a la derecha */
.worker-logout-btn{
  margin-left:auto!important;
  width:auto!important;
  align-self:flex-start;
  background:rgba(255,255,255,.14)!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.28)!important;
  white-space:nowrap;
}
.notify-permission-btn[data-state="enabled"]{
  background:#fee4e2!important;
  color:#912018!important;
  border-color:#f5a9a4!important;
}
@media(max-width:720px){
  .worker-hero{grid-template-columns:56px 1fr auto!important;}
  .worker-logout-btn{grid-column:3;grid-row:1;width:auto!important;padding:9px 12px!important;}
  .worker-actions{grid-column:1 / -1;width:100%;display:grid;grid-template-columns:1fr;}
  .worker-actions .notify-permission-btn{width:100%!important;}
}

/* v14: exportación compacta optimizada para ocupar A4 horizontal completo */
@media print{
  @page{size:A4 landscape;margin:6mm;}
  html,body{width:297mm!important;min-height:210mm!important;margin:0!important;padding:0!important;background:#fff!important;overflow:visible!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;}
  body *{box-shadow:none!important;}
  .no-print,.topbar,.worker-hero,.worker-week-nav,.worker-days,.total-box,.alert,.schedule-form,.toolbar,.actions-line,.cards-grid{display:none!important;}
  .admin-wrap,.worker-wrap{display:block!important;width:100%!important;max-width:none!important;margin:0!important;padding:0!important;}
  .panel{display:block!important;width:100%!important;max-width:none!important;margin:0!important;padding:0!important;border:0!important;background:#fff!important;box-shadow:none!important;overflow:visible!important;}
  .panel>h1,.panel>h2,.panel>.panel-head{display:none!important;}
  .print-only,.print-sheet,.worker-print-sheet{display:block!important;visibility:visible!important;}

  .print-sheet{
    width:285mm!important;
    height:198mm!important;
    max-width:285mm!important;
    max-height:198mm!important;
    margin:0 auto!important;
    padding:0!important;
    overflow:hidden!important;
    break-inside:avoid!important;
    page-break-inside:avoid!important;
    page-break-after:avoid!important;
    background:#fff!important;
  }
  .print-sheet h1{
    height:9mm!important;
    margin:0!important;
    padding:0!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    font-size:18px!important;
    line-height:1!important;
    letter-spacing:.02em!important;
    text-align:center!important;
    color:#111!important;
  }
  .print-sheet p{
    height:7mm!important;
    margin:0 0 2mm!important;
    padding:0!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    font-size:11px!important;
    line-height:1!important;
    text-align:center!important;
    color:#111!important;
  }

  .compact-print-table{
    width:285mm!important;
    height:180mm!important;
    max-height:180mm!important;
    table-layout:fixed!important;
    border-collapse:collapse!important;
    border:1.4px solid #111!important;
    background:#fff!important;
    color:#111!important;
    font-size:10px!important;
    line-height:1.12!important;
  }
  .compact-print-table thead{display:table-header-group!important;}
  .compact-print-table tbody{display:table-row-group!important;}
  .compact-print-table tr{display:table-row!important;break-inside:avoid!important;page-break-inside:avoid!important;}
  .compact-print-table th,.compact-print-table td{
    display:table-cell!important;
    border:1px solid #111!important;
    padding:2.2mm 1.4mm!important;
    text-align:center!important;
    vertical-align:middle!important;
    word-break:normal!important;
    overflow-wrap:anywhere!important;
    overflow:hidden!important;
    background:#fff!important;
    color:#111!important;
  }
  .compact-print-table th{
    height:10mm!important;
    background:#111!important;
    color:#fff!important;
    font-size:10px!important;
    font-weight:900!important;
    text-transform:uppercase!important;
    letter-spacing:.03em!important;
  }
  .compact-print-table th:first-child,.compact-print-table td:first-child{
    width:34mm!important;
    text-align:left!important;
    font-weight:900!important;
    font-size:10px!important;
  }
  .compact-print-table th:last-child,.compact-print-table td:last-child{
    width:18mm!important;
    font-weight:900!important;
  }
  .compact-print-table td:not(:first-child):not(:last-child){font-size:9.6px!important;font-weight:750!important;}

  /* Impresión del trabajador: sustituye la fila larguísima por tarjetas de día que llenan el A4 */
  body.worker-body .worker-print-sheet{width:285mm!important;height:198mm!important;max-width:285mm!important;max-height:198mm!important;margin:0 auto!important;overflow:hidden!important;}
  body.worker-body .worker-print-table{display:none!important;}
  .worker-print-grid{
    display:grid!important;
    grid-template-columns:repeat(7,1fr)!important;
    gap:2.2mm!important;
    width:285mm!important;
    height:168mm!important;
    margin-top:2mm!important;
  }
  .worker-print-day{
    display:flex!important;
    flex-direction:column!important;
    min-width:0!important;
    border:1.4px solid #111!important;
    border-radius:3mm!important;
    overflow:hidden!important;
    background:#fff!important;
    color:#111!important;
    break-inside:avoid!important;
  }
  .worker-print-day h3{
    margin:0!important;
    padding:2.5mm 1mm!important;
    background:#111!important;
    color:#fff!important;
    font-size:12px!important;
    line-height:1!important;
    text-align:center!important;
    text-transform:uppercase!important;
  }
  .worker-print-day-content{
    flex:1!important;
    display:flex!important;
    flex-direction:column!important;
    justify-content:center!important;
    gap:2mm!important;
    padding:2.4mm!important;
    font-size:10.5px!important;
    line-height:1.18!important;
    text-align:center!important;
  }
  .worker-print-shift{
    border:1px solid #222!important;
    border-radius:2mm!important;
    padding:2mm 1.2mm!important;
    background:#f7f7f7!important;
    font-weight:850!important;
  }
  .worker-print-shift strong{display:block!important;font-size:10px!important;margin-bottom:1.2mm!important;}
  .worker-print-shift span{display:block!important;font-size:11.5px!important;font-weight:950!important;}
  .worker-print-shift em{display:block!important;font-size:8.5px!important;margin-top:1mm!important;font-style:normal!important;}
  .worker-print-empty{color:#555!important;font-weight:800!important;font-size:11px!important;}
}


/* v15: impresión A4 horizontal bonita, con logo y mejor aprovechamiento del espacio */
@media print{
  @page{size:A4 landscape;margin:6mm;}
  html,body{width:297mm!important;min-height:210mm!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background:#fff!important;}
  .status-row,.schedule-meta,.record-log,.worker-published-dot,.worker-notice{display:none!important;}

  .print-sheet,.admin-print-sheet,.worker-print-sheet{width:285mm!important;height:198mm!important;max-width:285mm!important;max-height:198mm!important;margin:0 auto!important;padding:0!important;overflow:hidden!important;background:#fff!important;}

  .print-brand-header{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:8mm!important;height:22mm!important;margin:0 0 3mm!important;padding:0 1mm!important;}
  .print-brand-left{display:flex!important;align-items:center!important;gap:4mm!important;min-width:0!important;}
  .print-brand-logo{width:18mm!important;height:18mm!important;object-fit:contain!important;flex:0 0 18mm!important;}
  .print-brand-kicker{font-size:8px!important;font-weight:900!important;letter-spacing:.22em!important;color:#8b6a27!important;text-transform:uppercase!important;margin-bottom:1mm!important;}
  .print-brand-header h1{margin:0!important;padding:0!important;font-size:18px!important;line-height:1.05!important;color:#111!important;text-align:left!important;}
  .print-brand-meta{display:flex!important;align-items:center!important;justify-content:flex-end!important;gap:2mm!important;flex-wrap:wrap!important;max-width:110mm!important;}
  .print-chip{display:inline-flex!important;align-items:center!important;justify-content:center!important;padding:1.3mm 2.6mm!important;border-radius:999px!important;background:#111!important;color:#fff!important;font-size:8.5px!important;font-weight:800!important;line-height:1!important;white-space:nowrap!important;}

  .admin-print-sheet .compact-print-table{width:285mm!important;height:auto!important;min-height:169mm!important;max-height:169mm!important;border:1.4px solid #161616!important;table-layout:fixed!important;border-collapse:collapse!important;}
  .admin-print-sheet .compact-print-table th,.admin-print-sheet .compact-print-table td{border:1px solid #222!important;padding:2.1mm 1.4mm!important;vertical-align:middle!important;}
  .admin-print-sheet .compact-print-table th{background:#111!important;color:#fff!important;font-size:10px!important;font-weight:900!important;}
  .admin-print-sheet .compact-print-table td{font-size:9.5px!important;line-height:1.15!important;font-weight:700!important;color:#111!important;}
  .admin-print-sheet .compact-print-table th:first-child,.admin-print-sheet .compact-print-table td:first-child{width:36mm!important;font-size:10px!important;font-weight:900!important;text-align:left!important;background:#faf7ef!important;}
  .admin-print-sheet .compact-print-table th:last-child,.admin-print-sheet .compact-print-table td:last-child{width:18mm!important;font-weight:900!important;background:#faf7ef!important;}
  .admin-print-sheet .compact-print-table td:not(:first-child):not(:last-child){font-size:9.2px!important;}

  body.worker-body .worker-print-table{display:none!important;}
  body.worker-body .worker-print-sheet{width:285mm!important;height:198mm!important;}
  body.worker-body .worker-brand-header{margin-bottom:3.5mm!important;}
  body.worker-body .worker-print-grid{display:grid!important;grid-template-columns:repeat(4,1fr)!important;grid-template-rows:repeat(2,1fr)!important;gap:2.4mm!important;width:285mm!important;height:171mm!important;margin:0!important;}
  body.worker-body .worker-print-day{display:flex!important;flex-direction:column!important;min-width:0!important;border:1.3px solid #1b1b1b!important;border-radius:3mm!important;overflow:hidden!important;background:#fffdf8!important;box-shadow:none!important;}
  body.worker-body .worker-print-day h3{margin:0!important;padding:2.2mm 1mm!important;background:linear-gradient(90deg,#0f0f0f,#2a2a2a)!important;color:#fff!important;font-size:11px!important;line-height:1!important;text-transform:uppercase!important;text-align:center!important;letter-spacing:.05em!important;}
  body.worker-body .worker-print-day-content{flex:1!important;display:flex!important;flex-direction:column!important;justify-content:flex-start!important;gap:1.6mm!important;padding:2mm!important;font-size:9.4px!important;line-height:1.2!important;text-align:center!important;overflow:hidden!important;}
  body.worker-body .worker-print-shift{border:1px solid #d7caa3!important;border-radius:2mm!important;padding:1.8mm 1.2mm!important;background:#fff!important;}
  body.worker-body .worker-print-shift strong{display:block!important;font-size:8.5px!important;line-height:1.1!important;margin-bottom:1mm!important;color:#8b6a27!important;text-transform:uppercase!important;letter-spacing:.05em!important;}
  body.worker-body .worker-print-shift span{display:block!important;font-size:11px!important;line-height:1.12!important;font-weight:900!important;color:#111!important;}
  body.worker-body .worker-print-shift em{display:block!important;font-size:7.6px!important;line-height:1.15!important;margin-top:1mm!important;font-style:normal!important;color:#444!important;}
  body.worker-body .worker-print-empty{display:flex!important;align-items:center!important;justify-content:center!important;min-height:100%!important;color:#6a6a6a!important;font-size:10.5px!important;font-weight:800!important;}
  body.worker-body .worker-print-summary .worker-print-day-content{justify-content:center!important;gap:2mm!important;background:linear-gradient(180deg,#fffaf0,#fff)!important;}
  body.worker-body .worker-print-summary .summary-card{background:#fff!important;border-color:#cab87a!important;}
}


/* v18: estado correcto de notificaciones, modal oculto real y exportación móvil más compacta */
.modal-backdrop[hidden]{display:none!important;}
.modal-backdrop{
  position:fixed!important;
  inset:0!important;
  z-index:99999!important;
  display:none!important;
  align-items:center!important;
  justify-content:center!important;
  padding:18px!important;
  background:rgba(0,0,0,.58)!important;
  backdrop-filter:blur(4px)!important;
}
.modal-backdrop.active{display:flex!important;}
.confirm-modal{
  width:min(420px,100%)!important;
  background:#fffaf0!important;
  color:#111!important;
  border:1px solid rgba(0,0,0,.16)!important;
  border-radius:24px!important;
  box-shadow:0 22px 60px rgba(0,0,0,.28)!important;
  padding:24px!important;
}
.confirm-modal h2{margin:0 0 10px!important;font-size:22px!important;line-height:1.08!important;}
.confirm-modal p{margin:0 0 18px!important;color:#4d4638!important;line-height:1.35!important;}
.confirm-actions{display:flex!important;gap:10px!important;justify-content:flex-end!important;}
.confirm-actions .btn{width:auto!important;}

.worker-actions{
  display:grid!important;
  grid-column:1 / -1!important;
  width:100%!important;
  grid-template-columns:1fr!important;
  margin-top:10px!important;
}
.notify-wide-btn{
  width:100%!important;
  min-height:50px!important;
  border-radius:16px!important;
  font-weight:900!important;
}
.worker-top-actions{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:8px!important;
  margin-left:auto!important;
}
.notify-icon-btn{
  width:42px!important;
  height:42px!important;
  min-width:42px!important;
  padding:0!important;
  border-radius:999px!important;
  align-items:center!important;
  justify-content:center!important;
  font-size:18px!important;
  line-height:1!important;
}
@media (max-width:700px){
  .confirm-actions{display:grid!important;grid-template-columns:1fr 1fr!important;}
  .confirm-actions .btn{width:100%!important;}
}

/* v18 print final: plantilla del trabajador más baja y estrecha para móvil/Chrome */
@media print{
  @page{size:A4 landscape;margin:3mm;}
  html,body{
    width:297mm!important;
    height:210mm!important;
    min-height:0!important;
    max-height:210mm!important;
    margin:0!important;
    padding:0!important;
    overflow:hidden!important;
    background:#fff!important;
    -webkit-print-color-adjust:exact!important;
    print-color-adjust:exact!important;
  }

  body.worker-body *{box-shadow:none!important;}
  body.worker-body .worker-hero,
  body.worker-body .worker-week-nav,
  body.worker-body .worker-days,
  body.worker-body .total-box,
  body.worker-body .alert,
  body.worker-body .no-print,
  body.worker-body main.worker-wrap > .panel > h2,
  .modal-backdrop{
    display:none!important;
    visibility:hidden!important;
  }

  body.worker-body .worker-wrap,
  body.worker-body .panel{
    display:block!important;
    width:100%!important;
    max-width:none!important;
    height:auto!important;
    min-height:0!important;
    margin:0!important;
    padding:0!important;
    border:0!important;
    background:#fff!important;
    overflow:hidden!important;
  }

  body.worker-body .print-only,
  body.worker-body .worker-print-sheet{
    display:block!important;
    visibility:visible!important;
  }

  body.worker-body .worker-print-sheet{
    width:252mm!important;
    height:176mm!important;
    max-width:252mm!important;
    max-height:176mm!important;
    margin:0 auto!important;
    padding:0!important;
    overflow:hidden!important;
    page-break-before:avoid!important;
    page-break-after:avoid!important;
    page-break-inside:avoid!important;
    break-before:avoid!important;
    break-after:avoid!important;
    break-inside:avoid!important;
    background:#fff!important;
  }

  body.worker-body .print-brand-header{
    display:flex!important;
    align-items:center!important;
    justify-content:space-between!important;
    gap:4mm!important;
    height:14mm!important;
    margin:0 0 1.5mm!important;
    padding:0!important;
  }
  body.worker-body .print-brand-logo{
    width:12mm!important;
    height:12mm!important;
    object-fit:contain!important;
    flex:0 0 12mm!important;
  }
  body.worker-body .print-brand-left{gap:2.8mm!important;}
  body.worker-body .print-brand-kicker{
    font-size:6px!important;
    margin-bottom:.4mm!important;
    letter-spacing:.14em!important;
    color:#8b6a27!important;
  }
  body.worker-body .print-brand-header h1{
    font-size:12px!important;
    line-height:1!important;
    margin:0!important;
    padding:0!important;
    text-align:left!important;
    color:#111!important;
  }
  body.worker-body .print-brand-meta{
    gap:1mm!important;
    max-width:100mm!important;
    display:flex!important;
    justify-content:flex-end!important;
    flex-wrap:wrap!important;
  }
  body.worker-body .print-chip{
    padding:.8mm 1.6mm!important;
    font-size:6.4px!important;
    line-height:1!important;
    border-radius:999px!important;
    background:#111!important;
    color:#fff!important;
  }

  body.worker-body .worker-print-table{display:none!important;}

  body.worker-body .worker-print-grid{
    display:grid!important;
    grid-template-columns:repeat(4,1fr)!important;
    grid-template-rows:repeat(2,1fr)!important;
    gap:1.35mm!important;
    width:252mm!important;
    height:160mm!important;
    max-height:160mm!important;
    margin:0!important;
    padding:0!important;
    overflow:hidden!important;
    page-break-inside:avoid!important;
    break-inside:avoid!important;
  }

  body.worker-body .worker-print-day{
    display:flex!important;
    flex-direction:column!important;
    min-width:0!important;
    min-height:0!important;
    border:1px solid #1b1b1b!important;
    border-radius:2mm!important;
    overflow:hidden!important;
    background:#fffdf8!important;
    page-break-inside:avoid!important;
    break-inside:avoid!important;
  }
  body.worker-body .worker-print-day h3{
    margin:0!important;
    padding:1.25mm .6mm!important;
    background:#111!important;
    color:#fff!important;
    font-size:8px!important;
    line-height:1!important;
    text-transform:uppercase!important;
    text-align:center!important;
    letter-spacing:.035em!important;
  }
  body.worker-body .worker-print-day-content{
    flex:1!important;
    display:flex!important;
    flex-direction:column!important;
    justify-content:flex-start!important;
    gap:.8mm!important;
    padding:1mm!important;
    font-size:7.2px!important;
    line-height:1.08!important;
    text-align:center!important;
    overflow:hidden!important;
  }
  body.worker-body .worker-print-shift{
    border:1px solid #d7caa3!important;
    border-radius:1.3mm!important;
    padding:.85mm .65mm!important;
    background:#fff!important;
    overflow:hidden!important;
  }
  body.worker-body .worker-print-shift strong{
    display:block!important;
    font-size:6.1px!important;
    line-height:1!important;
    margin-bottom:.45mm!important;
    color:#8b6a27!important;
    text-transform:uppercase!important;
    letter-spacing:.03em!important;
  }
  body.worker-body .worker-print-shift span{
    display:block!important;
    font-size:8.1px!important;
    line-height:1.03!important;
    font-weight:900!important;
    color:#111!important;
  }
  body.worker-body .worker-print-shift em{
    display:block!important;
    font-size:5.7px!important;
    line-height:1.05!important;
    margin-top:.35mm!important;
    color:#444!important;
    font-style:normal!important;
  }
  body.worker-body .worker-print-empty{
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    min-height:100%!important;
    color:#666!important;
    font-size:7.8px!important;
    font-weight:800!important;
  }
  body.worker-body .worker-print-summary .worker-print-day-content{
    justify-content:center!important;
    gap:1mm!important;
    background:linear-gradient(180deg,#fffaf0,#fff)!important;
  }
}


/* v20: opciones de exportación del trabajador */
.worker-export-options{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin:12px 0 16px;
}
.worker-export-options .btn{
  width:100%;
  text-align:center;
}
.worker-export-options .subtle{
  grid-column:1 / -1;
  background:#fffaf0;
}
@media (max-width:700px){
  .worker-export-options{
    grid-template-columns:1fr;
  }
}


/* v22: solo una opción de descarga del horario del trabajador */
.worker-export-options.single-export-option{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:0!important;
}
.worker-export-options.single-export-option .btn{
  width:100%!important;
  min-height:52px!important;
  font-size:16px!important;
  font-weight:900!important;
}


/* v24: acciones y transparencia de trabajadores */
.employee-admin-head{
  gap:12px;
}
.employee-card-actions{
  display:flex;
  align-items:flex-start;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}
.employee-card-actions details{
  min-width:0;
}
.compact-danger{
  padding:9px 12px!important;
  font-size:13px!important;
}
.vacation-small{
  display:block;
  margin-top:3px;
  color:#8b6a27;
  font-weight:800;
}
@media (max-width:700px){
  .employee-card-actions{
    width:100%;
    justify-content:stretch;
    display:grid;
    grid-template-columns:1fr 1fr;
  }
  .employee-card-actions .btn,
  .employee-card-actions summary{
    width:100%;
    text-align:center;
  }
}


/* v25: vacaciones visibles para trabajador */
.worker-body .total-box strong{
  word-break:normal;
}


/* v26: exportación + calendario */
.worker-export-options.single-export-option{
  grid-template-columns:1fr 1fr!important;
  gap:10px!important;
}
.worker-export-options.single-export-option .btn{
  min-height:52px!important;
}
@media (max-width:700px){
  .worker-export-options.single-export-option{
    grid-template-columns:1fr!important;
  }
}


/* v27: Mis datos del trabajador y panel principal limpio */
.worker-data-box{
  margin:12px 0 16px;
  border:1px solid rgba(0,0,0,.12);
  border-radius:18px;
  background:#fffaf0;
  overflow:hidden;
}
.worker-data-box summary{
  cursor:pointer;
  list-style:none;
  padding:15px 16px;
  font-weight:900;
  color:#111;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.worker-data-box summary::-webkit-details-marker{display:none;}
.worker-data-box summary::after{
  content:'+';
  width:28px;
  height:28px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#111;
  color:#fff;
  font-weight:900;
}
.worker-data-box[open] summary::after{
  content:'−';
}
.worker-data-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
  padding:0 16px 16px;
}
.worker-data-grid div{
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  background:#fff;
  padding:12px;
}
.worker-data-grid span{
  display:block;
  font-size:12px;
  color:#7b6b4a;
  font-weight:800;
  letter-spacing:.04em;
  margin-bottom:4px;
}
.worker-data-grid strong{
  display:block;
  font-size:15px;
  color:#111;
}
.worker-data-wide{
  grid-column:1 / -1;
}
.worker-export-options.single-export-option{
  grid-template-columns:1fr!important;
}
@media (max-width:700px){
  .worker-data-grid{
    grid-template-columns:1fr;
  }
}
@media print{
  .worker-data-box{display:none!important;}
}


/* v28: estado de borrador compartido */
.status-row strong{
  font-weight:900;
}


/* v30: los botones de guardar/publicar nunca aparecen capados por conflictos visuales */
.schedule-form .actions-line button[name="action"][value="save_schedule"],
.schedule-form .actions-line button[name="action"][value="publish_schedule"]{
  opacity:1!important;
  filter:none!important;
  pointer-events:auto!important;
  cursor:pointer!important;
}
.schedule-form .actions-line button[name="action"][value="save_schedule"]{
  background:#2f2d28!important;
  color:#fff!important;
}
.schedule-form .actions-line button[name="action"][value="publish_schedule"]{
  background:linear-gradient(135deg,#111 0%,#3b2a14 100%)!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.12)!important;
  box-shadow:0 10px 22px rgba(0,0,0,.16)!important;
}
.schedule-form.has-client-conflicts .actions-line::after{
  content:'Hay avisos visuales de solape. Puedes seguir editando, guardar o publicar.';
  display:block;
  grid-column:1 / -1;
  margin-top:8px;
  padding:10px 12px;
  border-radius:12px;
  background:#fff3cd;
  color:#7a4b00;
  font-weight:800;
  font-size:13px;
}


/* v32: publicar vuelve a verse como botón disponible, no como desactivado */
.btn.publish{
  background:linear-gradient(135deg,#111 0%,#3b2a14 100%)!important;
  color:#fff!important;
}


/* v33: botón Publicar horario en verde solicitado */
.btn.publish,
.schedule-form .actions-line button[name="action"][value="publish_schedule"]{
  background:#00FF00!important;
  background-image:none!important;
  color:#000!important;
  border:1px solid #00cc00!important;
  box-shadow:0 10px 22px rgba(0,255,0,.18)!important;
}


/* v34: botón Publicar horario en verde definitivo */
.btn.publish,
.schedule-form .actions-line button[name="action"][value="publish_schedule"]{
  background:#1BC222!important;
  background-image:none!important;
  color:#fff!important;
  border:1px solid #159b1b!important;
  box-shadow:0 10px 22px rgba(27,194,34,.22)!important;
}


/* v35: regalo/perdón de horas semanales */
.forgive-hours-box{
  margin:12px 14px 16px;
  padding:13px;
  border:1px solid rgba(27,194,34,.28);
  border-radius:15px;
  background:#f0fff1;
}
.forgive-hours-box.is-hidden{
  display:none!important;
}
.forgive-hours-box label{
  display:grid;
  gap:6px;
}
.forgive-hours-box span{
  font-weight:900;
  color:#125c17;
}
.forgive-hours-box small{
  color:#315d34;
  line-height:1.35;
}
.forgive-hours-box input{
  max-width:180px;
  border:1px solid rgba(0,0,0,.16);
  border-radius:12px;
  padding:10px;
  font-weight:800;
}


/* v36: regalar horas con horas/minutos y botón aplicar */
.forgive-hours-box{
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  align-items:end;
}
.forgive-copy{
  display:grid;
  gap:6px;
}
.forgive-controls{
  display:flex;
  align-items:end;
  gap:8px;
  flex-wrap:wrap;
}
.forgive-controls label{
  display:grid;
  gap:5px;
  font-weight:900;
  color:#125c17;
  font-size:13px;
}
.forgive-controls input{
  width:86px;
}
.apply-forgive-btn{
  background:#1BC222!important;
  color:#fff!important;
  border:1px solid #159b1b!important;
  min-height:40px;
}
.install-help-card{
  margin-top:14px;
}
.install-help-card h2{
  margin:0 0 8px;
}
.install-help-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.install-help-grid div{
  background:#fffaf0;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  padding:12px;
}
.install-help-grid ol{
  margin:8px 0 0;
  padding-left:20px;
}
.install-help-grid li{
  margin:5px 0;
}
@media (max-width:700px){
  .forgive-hours-box{
    grid-template-columns:1fr;
  }
  .forgive-controls{
    display:grid;
    grid-template-columns:1fr 1fr;
  }
  .forgive-controls .apply-forgive-btn{
    grid-column:1 / -1;
  }
  .forgive-controls input{
    width:100%;
  }
  .install-help-grid{
    grid-template-columns:1fr;
  }
}


/* v37: regalar horas solo aplica al pulsar Aplicar */
.forgive-pending-note{
  grid-column:1 / -1;
  color:#93370d!important;
  background:#fef0c7;
  border-radius:10px;
  padding:7px 9px;
  font-weight:900;
}


/* v38: instrucciones de instalación plegadas y ocultas en PWA instalada */
.install-details{
  width:100%;
}
.install-details summary,
.worker-install-hint summary{
  cursor:pointer;
  list-style:none;
  font-weight:900;
  color:#111;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.install-details summary::-webkit-details-marker,
.worker-install-hint summary::-webkit-details-marker{
  display:none;
}
.install-details summary::after,
.worker-install-hint summary::after{
  content:'+';
  width:28px;
  height:28px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#111;
  color:#fff;
  font-weight:900;
  flex:0 0 auto;
}
.install-details[open] summary::after,
.worker-install-hint[open] summary::after{
  content:'−';
}
.worker-install-hint{
  margin:8px 0 16px;
  padding:12px 14px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  background:#fffaf0;
  opacity:.88;
}
.worker-install-hint summary{
  font-size:14px;
}
.compact-install-grid{
  margin-top:12px;
}
.compact-install-grid div{
  background:#fff;
}
.browser-install-help[hidden]{
  display:none!important;
}


/* v40: roles y vista tareas Local */
.local-body{
  min-height:100vh;
  background:#f4d9b0;
  overflow-x:hidden;
}
.local-task-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:18px 26px;
  background:#111;
  color:#fff;
}
.local-brand{
  display:flex;
  align-items:center;
  gap:16px;
}
.local-brand img{
  width:72px;
  height:72px;
  object-fit:contain;
  background:#fff8ea;
  border-radius:999px;
  padding:6px;
}
.local-brand h1{
  margin:0;
  font-size:32px;
  line-height:1;
}
.local-brand p{
  margin:6px 0 0;
  color:#c9a24a;
  font-weight:900;
}
.local-task-wrap{
  padding:22px;
  max-width:1500px;
  margin:0 auto;
}
.local-task-create{
  background:#fffaf0;
  border:1px solid rgba(0,0,0,.08);
  border-radius:22px;
  padding:18px;
  margin-bottom:18px;
}
.local-task-create h2{
  margin:0 0 12px;
}
.local-task-form{
  display:grid;
  grid-template-columns:1fr 220px 160px;
  gap:12px;
}
.local-task-form input,
.local-task-edit input,
.task-admin-form input,
.task-admin-form select,
.task-edit-form input{
  border:1px solid rgba(0,0,0,.16);
  border-radius:14px;
  padding:12px;
  font-weight:800;
  background:#fff;
}
.local-task-columns{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  align-items:start;
}
.local-task-column{
  background:#fffaf0;
  border-radius:24px;
  padding:18px;
  min-height:480px;
}
.local-task-column h2{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin:0 0 14px;
}
.local-task-column h2 span{
  background:#111;
  color:#fff;
  border-radius:999px;
  padding:6px 11px;
  font-size:15px;
}
.local-task-list{
  display:grid;
  gap:12px;
}
.local-task-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.10);
  border-radius:18px;
  padding:14px;
}
.local-task-card.done{
  opacity:.78;
  background:#eefcf0;
}
.local-task-card h3{
  margin:0 0 8px;
}
.local-task-edit{
  display:grid;
  gap:9px;
}
.local-task-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.local-task-actions .btn{
  width:auto;
}
.done-column{
  background:#f0fff1;
}
.admin-task-groups{
  display:grid;
  gap:16px;
}
.admin-task-list{
  display:grid;
  gap:10px;
}
.admin-task-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.10);
  border-radius:16px;
  padding:12px;
}
.admin-task-card.done{
  background:#eefcf0;
}
.task-edit-form{
  display:grid;
  grid-template-columns:1fr 180px auto;
  gap:10px;
  align-items:center;
}
.task-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
@media (max-width:900px){
  .local-task-columns,
  .local-task-form,
  .task-edit-form{
    grid-template-columns:1fr;
  }
  .local-task-header{
    align-items:flex-start;
    flex-direction:column;
  }
}


/* v41: tareas tipo checklist */
.checklist-task-card{
  padding:0;
  overflow:hidden;
}
.check-task-form{
  display:grid;
  grid-template-columns:64px 1fr 64px;
  align-items:stretch;
  min-height:82px;
}
.task-check-btn,
.task-delete-btn{
  border:0;
  cursor:pointer;
  font-weight:1000;
  font-size:32px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.task-check-btn{
  background:#e7fbe9;
  color:#159b1b;
  border-right:1px solid rgba(0,0,0,.08);
}
.task-check-btn:hover{
  background:#1BC222;
  color:#fff;
}
.task-delete-btn{
  background:#fff1f0;
  color:#b42318;
  border-left:1px solid rgba(0,0,0,.08);
}
.task-delete-btn:hover{
  background:#f04438;
  color:#fff;
}
.check-task-content{
  display:grid;
  align-content:center;
  gap:5px;
  padding:14px 18px;
  min-width:0;
}
.check-task-content strong{
  font-size:22px;
  line-height:1.1;
  color:#111;
  word-break:break-word;
}
.check-task-content small{
  font-size:15px;
  color:#7b6b4a;
  font-weight:900;
}
.task-confirm-modal[hidden]{
  display:none!important;
}
.task-confirm-modal.active{
  display:flex!important;
}
@media (max-width:700px){
  .check-task-form{
    grid-template-columns:54px 1fr 54px;
  }
  .check-task-content strong{
    font-size:18px;
  }
}


/* v42: acceso de tareas asociado a Locales */
.local-card-admin details summary{
  cursor:pointer;
  list-style:none;
}
.local-card-admin details summary::-webkit-details-marker{display:none;}
.local-credentials-form{
  display:grid;
  gap:10px;
  margin:12px 0;
}
.local-credentials-form label{
  display:grid;
  gap:5px;
  font-weight:900;
}
.local-credentials-form input{
  border:1px solid rgba(0,0,0,.16);
  border-radius:12px;
  padding:10px;
}
.local-card-task-preview{
  margin-top:12px;
  padding:12px;
  border-radius:14px;
  background:#fffaf0;
}
.local-card-task-preview p{
  margin:6px 0;
}
.local-admin-detail{
  padding:0;
}
.local-admin-detail > summary{
  cursor:pointer;
  list-style:none;
  padding:14px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.local-admin-detail > summary::-webkit-details-marker{display:none;}
.local-admin-columns{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  padding:0 16px 16px;
}
.task-history-box{
  margin-top:12px;
}
.task-history-box summary{
  cursor:pointer;
  font-weight:900;
  margin-bottom:10px;
}
.admin-task-card.history{
  opacity:.72;
}
@media (max-width:900px){
  .local-admin-columns{
    grid-template-columns:1fr;
  }
}


/* v43: locales siempre visibles como paneles desplegables */
.local-create-form{
  margin-bottom:16px;
}
.locales-admin-list{
  display:grid;
  gap:14px;
}
.local-admin-panel{
  background:#fff;
  border:1px solid rgba(0,0,0,.10);
  border-radius:20px;
  overflow:hidden;
}
.local-admin-panel > summary{
  cursor:pointer;
  list-style:none;
  display:grid;
  grid-template-columns:1fr auto;
  gap:14px;
  align-items:center;
  padding:16px 18px;
  background:#fffaf0;
}
.local-admin-panel > summary::-webkit-details-marker{display:none;}
.local-admin-main{
  display:grid;
  gap:4px;
}
.local-admin-main strong{
  font-size:20px;
  color:#111;
}
.local-admin-main em{
  font-style:normal;
  color:#7b6b4a;
  font-weight:800;
}
.local-admin-stats{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
  color:#111;
  font-weight:800;
}
.local-admin-stats b{
  background:#111;
  color:#fff;
  border-radius:999px;
  padding:4px 8px;
}
.local-admin-content{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  padding:16px;
}
.local-admin-block{
  background:#fffaf0;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  padding:13px;
}
.local-admin-block h3{
  margin:0 0 10px;
}
.local-mini-task-list{
  display:grid;
  gap:7px;
  margin-bottom:10px;
}
.local-mini-task-list p{
  margin:0;
  padding:9px 10px;
  background:#fff;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.07);
  display:grid;
  gap:3px;
}
.local-mini-task-list span{
  color:#7b6b4a;
  font-size:13px;
  font-weight:800;
}
@media (max-width:1100px){
  .local-admin-content{
    grid-template-columns:1fr 1fr;
  }
}
@media (max-width:700px){
  .local-admin-panel > summary{
    grid-template-columns:1fr;
  }
  .local-admin-stats{
    justify-content:flex-start;
  }
  .local-admin-content{
    grid-template-columns:1fr;
  }
}


/* v44: asegurar visibilidad de los locales en Admin > Locales */
.locales-admin-list{
  display:grid!important;
  gap:14px!important;
  margin-top:18px!important;
}
.local-admin-panel{
  display:block!important;
  visibility:visible!important;
}
.local-admin-panel > summary{
  min-height:72px;
}


/* v46: Admin > Locales más limpio y ordenado */
.locales-panel-v46 .panel-head{
  margin-bottom:14px;
}
.create-location-box{
  border:1px solid rgba(0,0,0,.10);
  border-radius:18px;
  background:#fffaf0;
  padding:0;
  margin-bottom:18px;
  overflow:hidden;
}
.create-location-box > summary{
  cursor:pointer;
  list-style:none;
  padding:16px 18px;
  font-weight:1000;
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.create-location-box > summary::-webkit-details-marker{display:none;}
.create-location-box > summary::after{content:'+';background:#111;color:#fff;width:28px;height:28px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;}
.create-location-box[open] > summary::after{content:'−';}
.location-create-grid,
.local-edit-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  padding:0 18px 18px;
  align-items:end;
}
.location-create-grid label,
.local-edit-grid label{
  display:grid;
  gap:5px;
  font-weight:900;
}
.location-create-grid input,
.local-edit-grid input{
  border:1px solid rgba(0,0,0,.16);
  border-radius:13px;
  padding:11px;
}
.local-list-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin:8px 0 12px;
}
.local-list-header h3{margin:0;}
.local-list-header span{
  font-weight:900;
  color:#7b6b4a;
}
.locales-clean-list{
  display:grid;
  gap:14px;
}
.local-detail-window{
  border:1px solid rgba(0,0,0,.10);
  border-radius:20px;
  background:#fff;
  overflow:hidden;
}
.local-detail-window > summary{
  cursor:pointer;
  list-style:none;
  display:grid;
  grid-template-columns:1fr auto;
  gap:14px;
  align-items:center;
  padding:16px 18px;
  background:#fffaf0;
}
.local-detail-window > summary::-webkit-details-marker{display:none;}
.local-row-title{
  display:grid;
  gap:4px;
}
.local-row-title strong{
  font-size:20px;
}
.local-row-title em{
  font-style:normal;
  color:#7b6b4a;
  font-weight:800;
}
.local-row-badges{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.local-row-badges b{
  background:#111;
  color:#fff;
  border-radius:999px;
  padding:6px 10px;
  font-size:13px;
}
.local-window-content{
  padding:16px;
  display:grid;
  gap:16px;
}
.local-window-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.local-window-top h3{
  margin:0;
  font-size:24px;
}
.local-status-actions,
.local-delete-form{
  margin:0;
}
.local-edit-box{
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  background:#fffaf0;
  overflow:hidden;
}
.local-edit-box > summary{
  cursor:pointer;
  list-style:none;
  padding:14px 16px;
  font-weight:1000;
}
.local-edit-box > summary::-webkit-details-marker{display:none;}
.local-edit-grid{
  padding:0 16px 16px;
}
.local-task-management{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:14px;
}
.local-task-management section{
  background:#fffaf0;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  padding:14px;
}
.local-task-management h4{
  margin:0 0 10px;
}
@media (max-width:1100px){
  .location-create-grid,
  .local-edit-grid,
  .local-task-management{
    grid-template-columns:1fr 1fr;
  }
}
@media (max-width:700px){
  .location-create-grid,
  .local-edit-grid,
  .local-task-management,
  .local-detail-window > summary{
    grid-template-columns:1fr;
  }
  .local-row-badges{
    justify-content:flex-start;
  }
}


/* v47: locales en ventana modal + tareas en tiempo real */
.local-row-button{
  width:100%;
  border:1px solid rgba(0,0,0,.10);
  border-radius:18px;
  background:#fffaf0;
  padding:16px 18px;
  cursor:pointer;
  display:grid;
  grid-template-columns:1fr auto;
  gap:14px;
  align-items:center;
  text-align:left;
  color:#111;
}
.local-row-button:hover{
  border-color:rgba(27,194,34,.45);
  box-shadow:0 12px 28px rgba(0,0,0,.08);
}
.local-admin-modal[hidden]{
  display:none!important;
}
.local-admin-modal.active{
  position:fixed;
  inset:0;
  z-index:99999;
  display:block;
}
.local-admin-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(4px);
}
.local-admin-modal-window{
  position:relative;
  width:min(1180px, calc(100vw - 28px));
  max-height:calc(100vh - 28px);
  overflow:auto;
  margin:14px auto;
  background:#fff8ea;
  border-radius:24px;
  box-shadow:0 24px 80px rgba(0,0,0,.32);
  border:1px solid rgba(0,0,0,.12);
}
.local-modal-header{
  position:sticky;
  top:0;
  z-index:2;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:18px 20px;
  background:#111;
  color:#fff;
}
.local-modal-header h3{
  margin:0;
  font-size:26px;
}
.local-modal-header p{
  margin:5px 0 0;
  color:#c9a24a;
  font-weight:900;
}
.modal-close-x{
  width:44px;
  height:44px;
  border-radius:999px;
  border:0;
  background:#fff;
  color:#111;
  font-size:30px;
  font-weight:900;
  cursor:pointer;
}
body.modal-open{
  overflow:hidden;
}
@media (max-width:700px){
  .local-row-button{
    grid-template-columns:1fr;
  }
  .local-admin-modal-window{
    width:calc(100vw - 12px);
    max-height:calc(100vh - 12px);
    margin:6px auto;
    border-radius:18px;
  }
}


/* v48: página propia de administración de cada local */
.local-row-link{
  text-decoration:none;
}
.local-page-admin{
  max-width:1500px;
}
.local-page-header{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:16px;
  align-items:center;
  margin-bottom:16px;
}
.local-page-header h1{
  margin:0;
}
.local-page-header p{
  margin:4px 0 0;
  color:#7b6b4a;
  font-weight:900;
}
.local-page-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:14px;
}
.local-page-actions form{
  margin:0;
}
.local-add-task-form{
  display:grid;
  grid-template-columns:1fr 200px auto;
  gap:10px;
}
.local-page-task-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:14px;
  align-items:start;
}
.local-page-task-grid .panel h2{
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.local-page-task-grid .panel h2 span{
  background:#111;
  color:#fff;
  border-radius:999px;
  padding:4px 9px;
  font-size:14px;
}
@media (max-width:1100px){
  .local-page-task-grid{
    grid-template-columns:1fr;
  }
}
@media (max-width:700px){
  .local-page-header{
    grid-template-columns:1fr;
  }
  .local-add-task-form{
    grid-template-columns:1fr;
  }
}


/* v49: tareas del admin más legibles y sin columna histórico */
.local-page-task-grid{
  grid-template-columns:1fr 1fr!important;
}
.local-admin-task-card{
  padding:14px!important;
}
.local-task-admin-form{
  display:grid;
  gap:12px;
}
.local-task-admin-form label{
  display:grid;
  gap:6px;
  font-weight:900;
  color:#111;
}
.local-task-title-row input{
  width:100%;
  font-size:17px;
  font-weight:900;
}
.local-task-meta-row{
  display:grid;
  grid-template-columns:180px 1fr;
  gap:12px;
  align-items:end;
}
.local-task-admin-form input{
  border:1px solid rgba(0,0,0,.16);
  border-radius:13px;
  padding:11px;
  background:#fff;
}
.local-task-meta-row .task-actions{
  justify-content:flex-start;
}
@media (max-width:1100px){
  .local-page-task-grid{
    grid-template-columns:1fr!important;
  }
}
@media (max-width:700px){
  .local-task-meta-row{
    grid-template-columns:1fr;
  }
}


/* v50: modal de confirmación para acciones de tareas en admin */
.task-confirm-modal[hidden]{
  display:none!important;
}
.task-confirm-modal.active{
  display:flex!important;
}
.confirm-modal{
  background:#fff8ea;
  border-radius:22px;
  padding:22px;
  width:min(420px, calc(100vw - 32px));
  box-shadow:0 22px 70px rgba(0,0,0,.28);
  border:1px solid rgba(0,0,0,.14);
}
.confirm-modal h2{
  margin:0 0 10px;
}
.confirm-modal p{
  margin:0 0 18px;
  font-weight:800;
}
.confirm-actions{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  flex-wrap:wrap;
}


/* v52: segunda confirmación escrita para eliminar local */
.typed-confirm-wrap{
  margin:14px 0 18px;
}
.typed-confirm-wrap label{
  display:grid;
  gap:8px;
  font-weight:900;
  color:#111;
}
.typed-confirm-wrap input{
  border:1px solid rgba(0,0,0,.18);
  border-radius:12px;
  padding:12px;
  font-weight:900;
  background:#fff;
}
.confirm-actions .btn:disabled{
  opacity:.45;
  cursor:not-allowed;
}


/* v53: segunda confirmación real para eliminar local */
.typed-confirm-wrap input{
  text-transform:none!important;
}


/* v54: Proveedores */
.suppliers-panel .panel-head{
  margin-bottom:14px;
}
.supplier-create-grid,
.supplier-edit-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  padding:0 18px 18px;
  align-items:end;
}
.supplier-create-grid label,
.supplier-edit-grid label,
.supplier-product-add-grid label,
.supplier-product-edit-form label{
  display:grid;
  gap:6px;
  font-weight:900;
}
.supplier-create-grid input,
.supplier-create-grid textarea,
.supplier-edit-grid input,
.supplier-edit-grid textarea,
.supplier-product-add-grid input,
.supplier-product-edit-form input{
  border:1px solid rgba(0,0,0,.16);
  border-radius:13px;
  padding:11px;
  background:#fff;
}
.supplier-comments-field{
  grid-column:1 / -1;
}
.supplier-comments-field textarea{
  min-height:82px;
  resize:vertical;
}
.suppliers-clean-list{
  display:grid;
  gap:12px;
}
.supplier-row-link{
  display:grid;
  grid-template-columns:1fr auto;
  gap:14px;
  align-items:center;
  text-decoration:none;
  color:#111;
  background:#fffaf0;
  border:1px solid rgba(0,0,0,.10);
  border-radius:18px;
  padding:16px 18px;
}
.supplier-row-link:hover{
  border-color:rgba(27,194,34,.45);
  box-shadow:0 12px 28px rgba(0,0,0,.08);
}
.supplier-row-title{
  display:grid;
  gap:4px;
}
.supplier-row-title strong{
  font-size:20px;
}
.supplier-row-title em{
  font-style:normal;
  color:#7b6b4a;
  font-weight:800;
}
.supplier-page-admin{
  max-width:1400px;
}
.supplier-order-list{
  display:grid;
  gap:10px;
}
.supplier-order-row{
  display:grid;
  grid-template-columns:1fr 140px 140px;
  gap:10px;
  align-items:center;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  padding:12px;
}
.supplier-order-row strong{
  font-size:18px;
}
.supplier-order-row input{
  border:1px solid rgba(0,0,0,.16);
  border-radius:12px;
  padding:10px;
  font-weight:900;
  text-align:center;
}
.supplier-order-row span{
  font-weight:900;
  color:#7b6b4a;
}
.supplier-product-add-grid{
  display:grid;
  grid-template-columns:1fr 1fr auto;
  gap:12px;
  align-items:end;
  padding:0 18px 18px;
}
.supplier-products-admin-list{
  display:grid;
  gap:12px;
  margin-top:12px;
}
.supplier-product-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.10);
  border-radius:16px;
  padding:12px;
}
.supplier-product-card.inactive{
  opacity:.55;
}
.supplier-product-edit-form{
  display:grid;
  grid-template-columns:1fr 180px auto;
  gap:10px;
  align-items:end;
}
@media (max-width:1000px){
  .supplier-create-grid,
  .supplier-edit-grid,
  .supplier-product-add-grid,
  .supplier-product-edit-form,
  .supplier-order-row{
    grid-template-columns:1fr;
  }
}
@media (max-width:700px){
  .supplier-row-link{
    grid-template-columns:1fr;
  }
}


/* v55: Pedido rápido proveedor con modal y WhatsApp */
.supplier-panel-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  margin-bottom:14px;
}
.supplier-panel-head h2{
  margin:0;
}
.supplier-order-row{
  grid-template-columns:1fr 140px 140px 48px!important;
}
.supplier-product-delete-form{
  margin:0;
  display:flex;
  justify-content:flex-end;
}
.supplier-product-x{
  width:42px;
  height:42px;
  border-radius:999px;
  border:0;
  background:#fff1f0;
  color:#b42318;
  font-size:28px;
  font-weight:1000;
  cursor:pointer;
}
.supplier-product-x:hover{
  background:#f04438;
  color:#fff;
}
.supplier-order-actions{
  margin-top:18px;
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.product-modal[hidden]{
  display:none!important;
}
.product-modal.active{
  display:flex!important;
}
.product-modal-box{
  width:min(560px, calc(100vw - 32px));
}
.product-modal .supplier-product-add-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  padding:0;
}
@media (max-width:1000px){
  .supplier-order-row{
    grid-template-columns:1fr!important;
  }
  .supplier-panel-head{
    flex-direction:column;
  }
}


/* v56: dirección de local y selector en pedidos */
.supplier-order-location{
  margin:14px 0 16px;
  padding:14px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  background:#fffaf0;
}
.supplier-order-location label{
  display:grid;
  gap:7px;
  font-weight:900;
  color:#111;
}
.supplier-order-location select{
  border:1px solid rgba(0,0,0,.16);
  border-radius:13px;
  padding:12px;
  background:#fff;
  font-weight:900;
}


/* v57: pedido rápido persistente, compacto en móvil y avisos en modal */
.supplier-order-location select option{
  font-weight:700;
}
.order-warning-modal[hidden]{
  display:none!important;
}
.order-warning-modal.active{
  display:flex!important;
}
@media (max-width:1000px){
  .supplier-order-row{
    grid-template-columns:minmax(0,1fr) 72px auto 42px!important;
    gap:7px!important;
    align-items:center!important;
    padding:9px!important;
  }
  .supplier-order-row strong{
    font-size:14px!important;
    line-height:1.1!important;
    min-width:0;
    word-break:break-word;
  }
  .supplier-order-row input{
    width:100%!important;
    min-width:0!important;
    padding:8px 6px!important;
    font-size:14px!important;
  }
  .supplier-order-row span{
    font-size:12px!important;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .supplier-product-x{
    width:34px!important;
    height:34px!important;
    font-size:24px!important;
  }
}
@media (max-width:420px){
  .supplier-order-row{
    grid-template-columns:minmax(0,1fr) 58px minmax(40px,auto) 32px!important;
    gap:5px!important;
  }
  .supplier-order-row strong{
    font-size:12px!important;
  }
  .supplier-order-row span{
    font-size:11px!important;
  }
  .supplier-product-x{
    width:30px!important;
    height:30px!important;
    font-size:20px!important;
  }
}


/* v58: menú hamburguesa de administración */
.admin-topbar-v58{
  position:sticky;
  top:0;
  z-index:1000;
}
.admin-menu-toggle{
  border:1px solid rgba(255,255,255,.18);
  background:#fff8ea;
  color:#111;
  border-radius:14px;
  padding:10px 12px;
  display:flex;
  align-items:center;
  gap:5px;
  cursor:pointer;
  font-weight:1000;
  box-shadow:0 8px 20px rgba(0,0,0,.16);
}
.admin-menu-toggle span{
  display:block;
  width:18px;
  height:2px;
  background:#111;
  border-radius:999px;
}
.admin-menu-toggle b{
  margin-left:6px;
}
.admin-menu-toggle.is-open{
  background:#1BC222;
  color:#fff;
}
.admin-menu-toggle.is-open span{
  background:#fff;
}
.admin-menu-panel[hidden]{
  display:none!important;
}
.admin-menu-panel.is-open{
  position:absolute;
  top:calc(100% + 10px);
  right:16px;
  width:min(320px, calc(100vw - 32px));
  display:grid!important;
  grid-template-columns:1fr;
  gap:8px;
  padding:12px;
  background:#111;
  border:1px solid rgba(255,255,255,.16);
  border-radius:18px;
  box-shadow:0 22px 70px rgba(0,0,0,.32);
}
.admin-menu-panel.is-open a{
  display:block;
  padding:13px 14px;
  border-radius:12px;
  text-decoration:none;
  color:#fff;
  font-weight:900;
  background:rgba(255,255,255,.06);
}
.admin-menu-panel.is-open a.active{
  background:#1BC222;
  color:#fff;
}
.admin-menu-panel.is-open a:hover{
  background:rgba(255,255,255,.14);
}
@media (max-width:700px){
  .admin-topbar-v58{
    gap:10px;
  }
  .admin-menu-toggle b{
    display:none;
  }
  .admin-menu-panel.is-open{
    right:10px;
    width:calc(100vw - 20px);
  }
}


/* v59: menú completo en escritorio, botón Menú solo cuando no cabe */
.admin-topbar-v58{
  position:sticky;
  top:0;
  z-index:1000;
}
.admin-menu-toggle{
  display:none!important;
  border:1px solid rgba(27,194,34,.45);
  background:#1BC222;
  color:#111;
  border-radius:999px;
  padding:10px 18px;
  cursor:pointer;
  font-weight:1000;
  box-shadow:0 8px 20px rgba(27,194,34,.20);
}
.admin-menu-toggle.is-open{
  background:#111;
  color:#fff;
}
.admin-menu-panel{
  display:flex!important;
  flex-wrap:nowrap;
  gap:8px;
  align-items:center;
  position:static!important;
  width:auto!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  padding:0!important;
}
.admin-menu-panel[hidden]{
  display:flex!important;
}
.admin-menu-panel a{
  white-space:nowrap;
}

/* A partir de aquí pasa a modo botón porque el menú ya suele no caber en una línea */
@media (max-width:1180px){
  .admin-menu-toggle{
    display:inline-flex!important;
    align-items:center;
    justify-content:center;
  }
  .admin-menu-panel[hidden]{
    display:none!important;
  }
  .admin-menu-panel{
    display:none!important;
  }
  .admin-menu-panel.is-open{
    position:absolute!important;
    top:calc(100% + 10px)!important;
    right:16px!important;
    width:min(320px, calc(100vw - 32px))!important;
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:8px!important;
    padding:12px!important;
    background:#111!important;
    border:1px solid rgba(27,194,34,.35)!important;
    border-radius:18px!important;
    box-shadow:0 22px 70px rgba(0,0,0,.32)!important;
  }
  .admin-menu-panel.is-open a{
    display:block!important;
    padding:13px 14px!important;
    border-radius:12px!important;
    text-decoration:none!important;
    color:#fff!important;
    font-weight:900!important;
    background:rgba(255,255,255,.06)!important;
  }
  .admin-menu-panel.is-open a.active{
    background:#1BC222!important;
    color:#111!important;
  }
  .admin-menu-panel.is-open a:hover{
    background:rgba(27,194,34,.25)!important;
  }
}
@media (max-width:700px){
  .admin-menu-panel.is-open{
    right:10px!important;
    width:calc(100vw - 20px)!important;
  }
}


/* v60: ajustes menú, pedido rápido y móvil */
.admin-topbar-v58{
  position:sticky!important;
  top:0!important;
  z-index:1000!important;
}
.admin-menu-toggle{
  margin-left:auto!important;
  background:#F0D1A3!important;
  color:#111!important;
  border:1px solid rgba(0,0,0,.12)!important;
  box-shadow:0 8px 20px rgba(0,0,0,.16)!important;
}
.admin-menu-toggle.is-open{
  background:#111!important;
  color:#F0D1A3!important;
}
@media (max-width:1180px){
  .admin-topbar-v58{
    display:flex!important;
    align-items:center!important;
    justify-content:space-between!important;
  }
  .admin-menu-toggle{
    margin-left:auto!important;
    flex:0 0 auto!important;
  }
  .admin-menu-panel.is-open{
    right:8px!important;
    left:auto!important;
    width:min(360px, calc(100vw - 16px))!important;
    max-width:calc(100vw - 16px)!important;
    overflow-x:hidden!important;
    box-sizing:border-box!important;
  }
  .admin-menu-panel.is-open a{
    white-space:normal!important;
    overflow-wrap:anywhere!important;
    line-height:1.2!important;
  }
}
@media (max-width:700px){
  .admin-menu-panel.is-open{
    right:8px!important;
    width:calc(100vw - 16px)!important;
  }
}

/* Pedido rápido: mantener columnas alineadas aunque cambie la unidad */
.supplier-order-row{
  grid-template-columns:minmax(160px,1fr) 110px 120px 42px!important;
  align-items:center!important;
}
.supplier-order-row .supplier-order-qty{
  width:100%!important;
  box-sizing:border-box!important;
}
.supplier-order-row span{
  display:block!important;
  min-width:0!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
@media (max-width:1000px){
  .supplier-order-row{
    grid-template-columns:minmax(0,1fr) 64px 74px 32px!important;
    gap:6px!important;
  }
  .supplier-order-row strong{
    min-width:0!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    white-space:nowrap!important;
    word-break:normal!important;
  }
  .supplier-order-row span{
    font-size:11px!important;
    text-align:left!important;
  }
  .supplier-order-row .supplier-order-qty{
    min-width:0!important;
    text-align:center!important;
  }
}

/* Evitar que selectores e inputs de semana desborden en móvil */
.toolbar,
.panel-head,
.inline-form,
.week-picker,
form{
  max-width:100%;
  box-sizing:border-box;
}
.toolbar input,
.toolbar select,
.toolbar button,
.inline-form input,
.inline-form select,
.inline-form textarea,
input[type="week"],
input[type="date"],
input[name="week_start"]{
  max-width:100%!important;
  min-width:0!important;
  box-sizing:border-box!important;
}
@media (max-width:700px){
  .toolbar,
  .inline-form{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:10px!important;
    overflow:hidden!important;
  }
  .toolbar label,
  .inline-form label{
    min-width:0!important;
    width:100%!important;
  }
  .toolbar input,
  .toolbar select,
  .toolbar button{
    width:100%!important;
  }
  .admin-wrap,
  .panel{
    overflow-x:hidden!important;
  }
}


/* v61: cabecera alineada, menú en sitio del antiguo Salir y mejoras móvil */
.admin-topbar-v58{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:16px!important;
}
.admin-topbar-v58 .topbrand{
  margin-right:auto!important;
  justify-content:flex-start!important;
  text-align:left!important;
  flex:1 1 auto!important;
  min-width:0!important;
}
.admin-topbar-v58 .topbrand div{
  text-align:left!important;
}
.admin-topbar-v58 .topbrand img{
  flex:0 0 auto!important;
}
.admin-menu-toggle{
  margin-left:12px!important;
  flex:0 0 auto!important;
  order:2!important;
  background:#F0D1A3!important;
  color:#111!important;
}
.admin-menu-panel{
  order:1!important;
}
.admin-menu-panel.is-open a.active{
  background:#F0D1A3!important;
  color:#111!important;
}
@media (min-width:1181px){
  .admin-menu-toggle{
    display:none!important;
  }
  .admin-menu-panel{
    order:2!important;
    flex:0 1 auto!important;
    justify-content:flex-end!important;
  }
}

/* El menú desplegado no debe cortarse por abajo en móvil */
@media (max-width:1180px){
  .admin-topbar-v58{
    overflow:visible!important;
  }
  .admin-menu-panel.is-open{
    position:fixed!important;
    top:76px!important;
    right:8px!important;
    left:8px!important;
    width:auto!important;
    max-height:calc(100vh - 88px)!important;
    overflow-y:auto!important;
    -webkit-overflow-scrolling:touch!important;
    z-index:99999!important;
  }
}
@media (max-width:520px){
  .admin-menu-panel.is-open{
    top:70px!important;
    max-height:calc(100vh - 78px)!important;
  }
}

/* Inputs de semana: que sean legibles, no cortados */
input[type="week"],
input[name="week_start"]{
  min-height:44px!important;
  height:auto!important;
  line-height:1.2!important;
  padding:10px 12px!important;
  font-size:16px!important;
  width:100%!important;
  max-width:100%!important;
}
.toolbar label{
  overflow:visible!important;
}
@media (max-width:700px){
  .toolbar input[type="week"],
  .toolbar input[name="week_start"]{
    min-width:0!important;
    width:100%!important;
    display:block!important;
  }
  .toolbar{
    align-items:stretch!important;
  }
}


/* v62: correcciones finales menú, inputs y limpieza de horas */
.admin-topbar-v58{
  display:flex!important;
  align-items:flex-start!important;
  justify-content:space-between!important;
  gap:12px!important;
}
.admin-topbar-v58 .topbrand{
  align-self:flex-start!important;
}
.admin-menu-toggle{
  align-self:flex-start!important;
  margin-top:0!important;
  margin-left:auto!important;
  background:#F0D1A3!important;
  color:#111!important;
}
.admin-menu-panel.is-open{
  border-color:#F0D1A3!important;
}

/* Mantener el botón Menú arriba a la derecha en móvil */
@media (max-width:1180px){
  .admin-topbar-v58{
    align-items:flex-start!important;
  }
  .admin-menu-toggle{
    position:relative!important;
    top:0!important;
    right:0!important;
    align-self:flex-start!important;
  }
  .admin-menu-panel.is-open{
    border:1px solid #F0D1A3!important;
  }
}

/* Inputs de semana: no recortar a la derecha, dar anchura mínima útil y permitir scroll interno del panel */
.toolbar{
  overflow:visible!important;
}
.toolbar label{
  min-width:0!important;
}
input[type="week"],
input[name="week_start"]{
  box-sizing:border-box!important;
  width:100%!important;
  max-width:100%!important;
  min-width:12.5rem!important;
  padding:10px 9px!important;
  font-size:15px!important;
}
@media (max-width:700px){
  .toolbar{
    overflow-x:auto!important;
    padding-bottom:4px!important;
  }
  .toolbar input[type="week"],
  .toolbar input[name="week_start"]{
    min-width:0!important;
    width:100%!important;
    font-size:14px!important;
    padding-left:8px!important;
    padding-right:8px!important;
  }
}

/* Horarios en móvil: placeholders/labels de hora más pequeños y sin superposición */
@media (max-width:700px){
  .times input[type="time"],
  .shift-time{
    font-size:11px!important;
    padding:7px 3px!important;
    min-width:0!important;
    letter-spacing:-0.03em!important;
  }
  .times-full-four{
    gap:4px!important;
  }
  .times-locked-two{
    gap:4px!important;
  }
}
@media (max-width:390px){
  .times input[type="time"],
  .shift-time{
    font-size:10px!important;
    padding-left:2px!important;
    padding-right:2px!important;
  }
}

.clear-shift-times-btn{
  width:100%;
  border:1px dashed rgba(0,0,0,.18);
  background:#fffaf0;
  color:#7b4b00;
  border-radius:10px;
  padding:7px 8px;
  font-weight:900;
  font-size:12px;
  cursor:pointer;
  margin-top:6px;
}
.clear-shift-times-btn:hover{
  background:#F0D1A3;
  color:#111;
}


/* v63: menú realmente arriba derecha, sin verde al tocar, calendario completo */
.admin-topbar-v58{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto!important;
  align-items:start!important;
  gap:10px!important;
}
.admin-topbar-v58 .topbrand{
  grid-column:1!important;
  grid-row:1!important;
  align-self:start!important;
  margin:0!important;
  padding:0!important;
}
.admin-menu-toggle{
  grid-column:2!important;
  grid-row:1!important;
  align-self:start!important;
  justify-self:end!important;
  margin:0!important;
  transform:none!important;
  background:#F0D1A3!important;
  color:#111!important;
  -webkit-tap-highlight-color:transparent!important;
}
.admin-menu-toggle:hover,
.admin-menu-toggle:focus,
.admin-menu-toggle:active,
.admin-menu-toggle.is-open{
  background:#F0D1A3!important;
  color:#111!important;
  outline:none!important;
  box-shadow:0 8px 20px rgba(0,0,0,.16)!important;
}
.admin-menu-panel.is-open{
  border:1px solid #F0D1A3!important;
}
.admin-menu-panel.is-open a,
.admin-menu-panel.is-open a:hover,
.admin-menu-panel.is-open a:focus,
.admin-menu-panel.is-open a:active{
  -webkit-tap-highlight-color:transparent!important;
}
.admin-menu-panel.is-open a.active,
.admin-menu-panel.is-open a.active:hover,
.admin-menu-panel.is-open a.active:focus,
.admin-menu-panel.is-open a.active:active{
  background:#F0D1A3!important;
  color:#111!important;
}
@media (max-width:1180px){
  .admin-menu-panel.is-open{
    position:fixed!important;
    top:max(76px, env(safe-area-inset-top) + 66px)!important;
    left:8px!important;
    right:8px!important;
    width:auto!important;
    max-height:calc(100dvh - 88px)!important;
    overflow-y:auto!important;
    overscroll-behavior:contain!important;
  }
}
@media (max-width:520px){
  .admin-menu-panel.is-open{
    top:max(70px, env(safe-area-inset-top) + 60px)!important;
    max-height:calc(100dvh - 78px)!important;
  }
}

/* Calendario / semana: evitar recorte derecho en iPhone */
.toolbar{
  width:100%!important;
  max-width:100%!important;
  overflow:visible!important;
}
.toolbar label{
  display:block!important;
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
}
.toolbar input[type="date"],
.toolbar input[type="week"],
.toolbar input[name="week_start"]{
  display:block!important;
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
  box-sizing:border-box!important;
  -webkit-appearance:none!important;
  appearance:none!important;
  padding:10px 12px!important;
  padding-right:38px!important;
  overflow:visible!important;
  text-align:center!important;
}
@media (max-width:700px){
  .toolbar{
    display:grid!important;
    grid-template-columns:minmax(0,1fr)!important;
    overflow:visible!important;
  }
  .toolbar input[type="date"],
  .toolbar input[type="week"],
  .toolbar input[name="week_start"]{
    font-size:15px!important;
    line-height:1.2!important;
  }
}

/* Modal para quitar horas */
.clear-hours-modal[hidden]{
  display:none!important;
}
.clear-hours-modal.active{
  display:flex!important;
}


/* v64: fecha de tareas/locales sin recorte y aviso si no se incluye fecha */
.local-add-task-form,
.local-task-form{
  overflow:visible!important;
}
.local-add-task-form input[type="date"],
.local-task-form input[type="date"],
.local-task-date-input{
  display:block!important;
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
  box-sizing:border-box!important;
  -webkit-appearance:none!important;
  appearance:none!important;
  padding:12px 42px 12px 12px!important;
  font-size:16px!important;
  line-height:1.2!important;
  text-align:center!important;
  overflow:visible!important;
}
@media (max-width:700px){
  .local-add-task-form,
  .local-task-form{
    display:grid!important;
    grid-template-columns:minmax(0,1fr)!important;
    gap:12px!important;
  }
  .local-add-task-form input[type="date"],
  .local-task-form input[type="date"],
  .local-task-date-input{
    font-size:15px!important;
    padding-left:10px!important;
    padding-right:44px!important;
  }
}
.empty-date-modal[hidden]{
  display:none!important;
}
.empty-date-modal.active{
  display:flex!important;
}


/* v65: administradores en modal */
.admin-create-modal[hidden]{
  display:none!important;
}
.admin-create-modal.active{
  display:flex!important;
}
.admin-create-form{
  display:grid;
  gap:12px;
}
.admin-create-form label{
  display:grid;
  gap:6px;
  font-weight:900;
}
.admin-create-form input{
  border:1px solid rgba(0,0,0,.16);
  border-radius:13px;
  padding:12px;
  background:#fff;
}
.admins-panel-v65 .panel-head{
  align-items:center;
}


/* v66: reforzar modal de fecha vacía */
.empty-date-modal.active{
  z-index:999999!important;
}


/* v67: fecha opcional con placeholder visual, sin modal */
.date-placeholder-wrap{
  position:relative;
  width:100%;
  max-width:100%;
}
.date-placeholder-wrap input[type="date"]{
  position:relative;
  z-index:1;
  background:#fff!important;
  color:transparent!important;
}
.date-placeholder-wrap.has-value input[type="date"],
.date-placeholder-wrap input[type="date"]:focus{
  color:#111!important;
}
.date-placeholder-wrap::before{
  content:attr(data-placeholder);
  position:absolute;
  left:12px;
  right:42px;
  top:50%;
  transform:translateY(-50%);
  color:#9b9b9b;
  font-weight:900;
  pointer-events:none;
  z-index:2;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.date-placeholder-wrap.has-value::before,
.date-placeholder-wrap:focus-within::before{
  display:none;
}
.empty-date-modal{
  display:none!important;
}


/* v68: vista general de trabajadores por locales */
.workers-local-cards{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:14px;
  margin-top:18px;
}
.worker-local-card{
  display:grid;
  gap:8px;
  padding:18px;
  border-radius:20px;
  background:#fffaf0;
  border:1px solid rgba(0,0,0,.10);
  text-decoration:none;
  color:#111;
  box-shadow:0 10px 28px rgba(0,0,0,.06);
}
.worker-local-card:hover{
  border-color:#F0D1A3;
  box-shadow:0 14px 34px rgba(0,0,0,.10);
}
.worker-local-card strong{
  font-size:22px;
}
.worker-local-card span{
  color:#7b6b4a;
  font-weight:900;
}
.worker-local-card.unassigned{
  background:#111;
  color:#fff;
}
.worker-local-card.unassigned span{
  color:#F0D1A3;
}
.workers-local-page .employee-list-cards{
  margin-top:0;
}


/* v69 */
.local-edit-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  padding:0 16px 16px;
}
.local-edit-actions form{
  margin:0;
}


/* v70: trabajadores por local, edición clara */
.worker-edit-card{
  overflow:visible;
}
.worker-edit-details{
  margin-top:12px;
  border-top:1px solid rgba(0,0,0,.08);
  padding-top:12px;
}
.worker-edit-details > summary{
  cursor:pointer;
  list-style:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  user-select:none;
}
.worker-edit-details > summary::-webkit-details-marker{
  display:none;
}
.worker-edit-details[open] > summary{
  background:#F0D1A3;
  color:#111;
}
.worker-edit-form-wrap{
  margin-top:12px;
  padding:12px;
  border-radius:16px;
  background:#fffaf0;
  border:1px solid rgba(0,0,0,.08);
}
.workers-local-page .employee-admin-head{
  align-items:flex-start;
}
@media (max-width:700px){
  .workers-local-page .employee-admin-head{
    display:grid;
    gap:12px;
  }
  .workers-local-page .employee-admin-head form{
    width:100%;
  }
  .workers-local-page .employee-admin-head .compact-danger{
    width:100%;
  }
  .worker-edit-details > summary{
    width:100%;
  }
}


/* v72: eliminar trabajador dentro de editar */
.delete-worker-form{
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid rgba(0,0,0,.10);
}
.delete-worker-form .danger-btn{
  width:100%;
}
.task-confirm-modal[hidden]{
  display:none!important;
}
.task-confirm-modal.active{
  display:flex!important;
}


/* v73: botón actualizar en menú admin */
.admin-refresh-btn{
  border:0;
  cursor:pointer;
  white-space:nowrap;
  font-family:inherit;
}
.admin-menu-panel .admin-refresh-btn{
  padding:10px 12px;
  border-radius:999px;
  background:#F0D1A3;
  color:#111;
  font-weight:1000;
}
.admin-menu-panel .admin-refresh-btn:hover,
.admin-menu-panel .admin-refresh-btn:focus,
.admin-menu-panel .admin-refresh-btn:active{
  background:#F0D1A3!important;
  color:#111!important;
  outline:none!important;
}
.admin-menu-panel .admin-refresh-btn:disabled{
  opacity:.65;
  cursor:wait;
}
@media (max-width:1180px){
  .admin-menu-panel.is-open .admin-refresh-btn{
    display:block!important;
    width:100%!important;
    padding:13px 14px!important;
    border-radius:12px!important;
    text-align:left!important;
    background:#F0D1A3!important;
    color:#111!important;
    font-weight:1000!important;
  }
}


/* v74: diferenciar Actualizar y Salir en el menú */
.admin-menu-panel .admin-refresh-btn,
.admin-menu-panel.is-open .admin-refresh-btn{
  background:#fff!important;
  color:#111!important;
  text-align:center!important;
  justify-content:center!important;
  align-items:center!important;
}
.admin-menu-panel.is-open .admin-refresh-btn{
  display:flex!important;
  width:100%!important;
}
.admin-menu-panel .admin-refresh-btn:hover,
.admin-menu-panel .admin-refresh-btn:focus,
.admin-menu-panel .admin-refresh-btn:active{
  background:#fff!important;
  color:#111!important;
}
.admin-menu-panel .admin-logout-link,
.admin-menu-panel.is-open .admin-logout-link{
  background:#5A1717!important;
  color:#fff!important;
  text-align:center!important;
}
.admin-menu-panel .admin-logout-link:hover,
.admin-menu-panel .admin-logout-link:focus,
.admin-menu-panel .admin-logout-link:active{
  background:#7A1F1F!important;
  color:#fff!important;
}
@media (max-width:1180px){
  .admin-menu-panel.is-open .admin-logout-link{
    display:block!important;
    width:100%!important;
    box-sizing:border-box!important;
  }
}


/* v79: Ajustes seguros por archivo */
.settings-form{
  display:grid;
  gap:16px;
}
.settings-form label{
  display:grid;
  gap:8px;
  font-weight:1000;
}
.settings-form textarea{
  width:100%;
  min-height:190px;
  border:1px solid rgba(0,0,0,.16);
  border-radius:16px;
  padding:14px;
  background:#fff;
  font-family:inherit;
  font-size:16px;
  line-height:1.35;
  box-sizing:border-box;
}
.settings-help,
.settings-preview{
  background:#fffaf0;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  padding:14px;
}
.settings-help p{
  margin:6px 0;
}
.settings-help code{
  background:#111;
  color:#F0D1A3;
  border-radius:8px;
  padding:3px 7px;
  font-weight:900;
}
.settings-preview pre{
  white-space:pre-wrap;
  margin:10px 0 0;
  font-family:inherit;
  background:#fff;
  border-radius:12px;
  padding:12px;
  border:1px solid rgba(0,0,0,.08);
}


/* v80: Ajustes en tarjetas desplegables */
.settings-options{
  display:grid;
  gap:14px;
}
.settings-option-card{
  border:1px solid rgba(0,0,0,.10);
  border-radius:18px;
  background:#fffaf0;
  overflow:hidden;
}
.settings-option-card > summary{
  cursor:pointer;
  list-style:none;
  padding:18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.settings-option-card > summary::-webkit-details-marker{
  display:none;
}
.settings-option-card > summary::after{
  content:'+';
  width:30px;
  height:30px;
  border-radius:999px;
  background:#111;
  color:#F0D1A3;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:1000;
  flex:0 0 auto;
}
.settings-option-card[open] > summary::after{
  content:'−';
}
.settings-option-card > summary strong{
  display:block;
  font-size:20px;
}
.settings-option-card > summary em{
  display:block;
  margin-top:4px;
  font-style:normal;
  color:#7b6b4a;
  font-weight:800;
}
.settings-option-card .settings-form{
  padding:0 18px 18px;
}


/* v81: Recetario */
.recipe-admin-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.recipe-admin-grid{
  display:grid;
  gap:18px;
}
.recipe-admin-category{
  border:1px solid rgba(0,0,0,.10);
  border-radius:20px;
  background:#fffaf0;
  padding:16px;
}
.recipe-admin-category-head,
.recipe-admin-subcategory-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:12px;
}
.recipe-admin-category h3,
.recipe-admin-subcategory h4{
  margin:0;
}
.recipe-admin-subcategory{
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  background:#fff;
  padding:12px;
  margin-top:12px;
}
.recipe-products-list{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:12px;
}
.recipe-product-card-admin{
  display:grid;
  grid-template-columns:92px 1fr;
  gap:12px;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  padding:10px;
}
.recipe-product-card-admin img,
.recipe-product-placeholder{
  width:92px;
  height:92px;
  border-radius:12px;
  object-fit:cover;
  background:#111;
  color:#F0D1A3;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  text-align:center;
}
.recipe-product-admin-body h5{
  margin:0 0 6px;
  font-size:17px;
}
.recipe-product-admin-body p{
  margin:0 0 8px;
  color:#6b5b3e;
  font-weight:700;
}
.recipe-inline-form,
.recipe-product-edit-form,
.recipe-create-form{
  display:grid;
  gap:10px;
  margin-top:10px;
}
.recipe-inline-form label,
.recipe-product-edit-form label,
.recipe-create-form label{
  display:grid;
  gap:6px;
  font-weight:900;
}
.recipe-inline-form input,
.recipe-inline-form select,
.recipe-product-edit-form input,
.recipe-product-edit-form select,
.recipe-product-edit-form textarea,
.recipe-create-form input,
.recipe-create-form select,
.recipe-create-form textarea{
  border:1px solid rgba(0,0,0,.16);
  border-radius:12px;
  padding:10px;
  background:#fff;
  font-family:inherit;
}
.recipe-product-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.simple-modal[hidden]{
  display:none!important;
}
.simple-modal.active{
  display:flex!important;
}
.recipe-form-modal{
  width:min(650px, calc(100vw - 28px));
}
.local-mini-nav{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.local-recipe-categories{
  display:grid;
  gap:14px;
}
.local-recipe-category,
.local-recipe-subcategory{
  border:1px solid rgba(0,0,0,.10);
  border-radius:18px;
  background:#fffaf0;
  padding:12px;
}
.local-recipe-subcategory{
  background:#fff;
  margin-top:10px;
}
.local-recipe-category > summary,
.local-recipe-subcategory > summary{
  cursor:pointer;
  font-weight:1000;
  font-size:20px;
  list-style:none;
}
.local-recipe-category > summary::-webkit-details-marker,
.local-recipe-subcategory > summary::-webkit-details-marker{
  display:none;
}
.local-recipe-products{
  display:grid;
  gap:12px;
  margin-top:12px;
}
.local-recipe-product{
  display:grid;
  grid-template-columns:110px 1fr;
  gap:12px;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  padding:12px;
}
.local-recipe-product img{
  width:110px;
  height:110px;
  border-radius:14px;
  object-fit:cover;
}
.local-recipe-product h4{
  margin:0 0 8px;
}
.local-recipe-product p{
  margin:0;
  white-space:normal;
  line-height:1.35;
}
@media (max-width:700px){
  .recipe-admin-category-head,
  .recipe-admin-subcategory-head{
    display:grid;
  }
  .recipe-product-card-admin,
  .local-recipe-product{
    grid-template-columns:84px 1fr;
  }
  .recipe-product-card-admin img,
  .recipe-product-placeholder,
  .local-recipe-product img{
    width:84px;
    height:84px;
  }
  .local-mini-nav{
    justify-content:flex-start;
  }
}


/* v85: recetario local plegado y modal de producto */
.local-mini-nav .danger-soft{
  background:#5A1717!important;
  color:#fff!important;
}
.local-recipe-category,
.local-recipe-subcategory{
  overflow:hidden;
}
.local-recipe-category > summary,
.local-recipe-subcategory > summary{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
}
.local-recipe-category > summary::after,
.local-recipe-subcategory > summary::after{
  content:'+';
  width:30px;
  height:30px;
  border-radius:999px;
  background:#111;
  color:#F0D1A3;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:1000;
  flex:0 0 auto;
}
.local-recipe-category[open] > summary::after,
.local-recipe-subcategory[open] > summary::after{
  content:'−';
}
.local-recipe-product-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(130px,1fr));
  gap:12px;
  margin-top:12px;
}
.local-recipe-product-tile{
  border:1px solid rgba(0,0,0,.10);
  border-radius:16px;
  background:#fff;
  padding:10px;
  display:grid;
  gap:8px;
  cursor:pointer;
  text-align:center;
  font-family:inherit;
  color:#111;
  box-shadow:0 8px 20px rgba(0,0,0,.05);
}
.local-recipe-product-tile img,
.recipe-tile-placeholder{
  width:100%;
  aspect-ratio:1/1;
  border-radius:12px;
  object-fit:cover;
  background:#111;
  color:#F0D1A3;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:1000;
}
.local-recipe-product-tile strong{
  font-size:15px;
  line-height:1.15;
}
.recipe-detail-modal[hidden]{
  display:none!important;
}
.recipe-detail-modal.active{
  display:flex!important;
}
.recipe-detail-box{
  position:relative;
  width:min(640px, calc(100vw - 28px));
  max-height:calc(100dvh - 40px);
  overflow:auto;
}
.recipe-detail-close{
  position:absolute;
  top:10px;
  right:10px;
  width:38px;
  height:38px;
  border:0;
  border-radius:999px;
  background:#111;
  color:#F0D1A3;
  font-size:24px;
  font-weight:1000;
  cursor:pointer;
}
.recipe-detail-box img{
  width:100%;
  max-height:360px;
  object-fit:cover;
  border-radius:16px;
  margin-bottom:14px;
}
.recipe-detail-box h2{
  margin:0 0 10px;
}
.recipe-detail-box p{
  margin:0;
  white-space:pre-wrap;
  line-height:1.45;
  font-weight:700;
}
@media (max-width:700px){
  .local-recipe-product-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .local-mini-nav{
    display:grid;
    grid-template-columns:1fr 1fr;
  }
}


/* v86: recetario local en cuadrícula compacta tipo app */
.local-recipe-product-grid{
  display:grid!important;
  grid-template-columns:repeat(auto-fill, minmax(130px, 1fr))!important;
  gap:12px!important;
  align-items:start!important;
}
.local-recipe-product-tile{
  width:100%!important;
  max-width:180px!important;
  justify-self:start!important;
  border:1px solid rgba(0,0,0,.10)!important;
  border-radius:16px!important;
  background:#fff!important;
  padding:8px!important;
  display:grid!important;
  grid-template-rows:96px auto!important;
  gap:7px!important;
  cursor:pointer!important;
  text-align:center!important;
  font-family:inherit!important;
  color:#111!important;
  box-shadow:0 8px 20px rgba(0,0,0,.05)!important;
  overflow:hidden!important;
}
.local-recipe-product-tile img,
.local-recipe-product-tile .recipe-tile-placeholder{
  width:100%!important;
  height:96px!important;
  aspect-ratio:auto!important;
  border-radius:12px!important;
  object-fit:cover!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
.local-recipe-product-tile strong{
  display:-webkit-box!important;
  -webkit-line-clamp:2!important;
  -webkit-box-orient:vertical!important;
  overflow:hidden!important;
  font-size:13px!important;
  line-height:1.15!important;
  min-height:30px!important;
}
@media (min-width:900px){
  .local-recipe-product-grid{
    grid-template-columns:repeat(auto-fill, minmax(145px, 1fr))!important;
  }
  .local-recipe-product-tile{
    max-width:170px!important;
    grid-template-rows:105px auto!important;
  }
  .local-recipe-product-tile img,
  .local-recipe-product-tile .recipe-tile-placeholder{
    height:105px!important;
  }
}
@media (max-width:700px){
  .local-recipe-product-grid{
    grid-template-columns:repeat(3, minmax(0, 1fr))!important;
    gap:9px!important;
  }
  .local-recipe-product-tile{
    max-width:none!important;
    grid-template-rows:82px auto!important;
    padding:7px!important;
    border-radius:14px!important;
  }
  .local-recipe-product-tile img,
  .local-recipe-product-tile .recipe-tile-placeholder{
    height:82px!important;
    border-radius:10px!important;
  }
  .local-recipe-product-tile strong{
    font-size:12px!important;
  }
}
@media (max-width:420px){
  .local-recipe-product-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr))!important;
  }
  .local-recipe-product-tile{
    grid-template-rows:92px auto!important;
  }
  .local-recipe-product-tile img,
  .local-recipe-product-tile .recipe-tile-placeholder{
    height:92px!important;
  }
}


/* v87: evitar bloqueo visual al subir fotos desde móvil */
.recipe-product-edit-form.is-submitting,
.recipe-create-form.is-submitting{
  opacity:.72;
  pointer-events:none;
}
.recipe-product-edit-form.is-submitting::after,
.recipe-create-form.is-submitting::after{
  content:'Guardando imagen...';
  display:block;
  margin-top:10px;
  font-weight:1000;
  color:#111;
  background:#F0D1A3;
  border-radius:12px;
  padding:10px;
  text-align:center;
}


/* v89: vista trabajador admin descargable y recetario admin plegable, sin romper tarjetas */
.admin-worker-card-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:8px;
}
.admin-worker-card-head h3{
  margin:0;
}
.admin-worker-download-btn{
  white-space:nowrap;
  padding:8px 10px!important;
  font-size:12px!important;
}
.admin-worker-cards-grid{
  align-items:start;
}
.admin-worker-mini-card{
  overflow:hidden;
}

.recipe-admin-details{
  overflow:hidden;
}
.recipe-admin-category-summary,
.recipe-admin-subcategory-summary{
  cursor:pointer;
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  font-weight:1000;
}
.recipe-admin-category-summary::-webkit-details-marker,
.recipe-admin-subcategory-summary::-webkit-details-marker{
  display:none;
}
.recipe-admin-category-summary{
  font-size:22px;
  padding:4px 0 12px;
}
.recipe-admin-subcategory-summary{
  font-size:18px;
  padding:4px 0 10px;
}
.recipe-admin-category-summary::after,
.recipe-admin-subcategory-summary::after{
  content:'+';
  width:30px;
  height:30px;
  border-radius:999px;
  background:#111;
  color:#F0D1A3;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:1000;
  flex:0 0 auto;
}
.recipe-admin-category[open] > .recipe-admin-category-summary::after,
.recipe-admin-subcategory[open] > .recipe-admin-subcategory-summary::after{
  content:'−';
}
.recipe-admin-category-content,
.recipe-admin-subcategory-content{
  padding-top:8px;
  border-top:1px solid rgba(0,0,0,.08);
}
.recipe-admin-category-head{
  padding-top:4px;
}
@media (max-width:700px){
  .admin-worker-card-head{
    display:grid;
  }
  .admin-worker-download-btn{
    width:100%;
  }
}


/* v91: acción eliminar borrador */
.actions-line .danger-btn{
  background:#5A1717!important;
  color:#fff!important;
}
.actions-line .danger-btn:hover,
.actions-line .danger-btn:focus,
.actions-line .danger-btn:active{
  background:#7A1F1F!important;
  color:#fff!important;
}

/* Marca blanca */
.settings-grid-inline{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:14px;
  align-items:end;
}
.settings-grid-inline input[type="color"]{
  width:100%;
  min-height:46px;
  padding:4px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.18);
  background:#fff;
}
.settings-form input[type="file"]{
  padding:12px;
  background:#fff;
  border:1px dashed rgba(0,0,0,.22);
  border-radius:14px;
}

/* Fase 3 · Producto marca blanca */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin-top:12px}
.kpi-card{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:14px;box-shadow:0 8px 24px rgba(0,0,0,.05)}
.kpi-card strong{display:block;font-size:1.8rem;line-height:1;color:var(--brand-primary,#0c0b09)}
.kpi-card span{display:block;margin-top:6px;color:#6b5b4b;font-size:.9rem}
.badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 9px;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.02em}
.badge.ok{background:#e8f9ed;color:#167331}
.badge.danger{background:#ffe7e7;color:#9b1c1c}
.row-muted{opacity:.72;background:rgba(0,0,0,.025)}
.grid-form label.full{grid-column:1/-1}
.grid-form textarea{width:100%;border:1px solid rgba(0,0,0,.15);border-radius:12px;padding:10px;font:inherit;resize:vertical;background:#fff}


/* =========================================================
   v99 · Rediseño premium estilo producto SaaS hostelería
   Capa visual: no cambia la lógica de la app.
   ========================================================= */
:root{
  --ink:#14110c;
  --paper:#fff9ef;
  --paper-2:#f8eddc;
  --surface:#fffaf1;
  --surface-2:#fff5e5;
  --sand:#c8a46b;
  --sand2:#f3e2c3;
  --accent:#b7894f;
  --ok:#2f7d42;
  --warn:#c98921;
  --bad:#c0392b;
  --muted:#7b6b55;
  --line:#ead9bd;
  --shadow:0 22px 70px rgba(39,27,12,.13);
  --shadow-soft:0 12px 34px rgba(39,27,12,.08);
  --radius-xl:28px;
  --radius-lg:22px;
  --radius-md:16px;
}
html,body{
  background:
    radial-gradient(circle at 12% 0%, rgba(255,255,255,.9) 0 20%, transparent 44%),
    linear-gradient(135deg,#fffaf1 0%,#f5dec0 100%) !important;
  color:var(--ink);
  letter-spacing:-.01em;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg,rgba(255,255,255,.48),transparent 36%,rgba(255,255,255,.25)),
    radial-gradient(circle at 92% 12%,rgba(200,164,107,.14),transparent 28%);
  z-index:-1;
}
h1,h2,.panel h1,.panel h2,.brand-card h1,.login-card h1,.portal-title{
  font-family:Georgia,"Times New Roman",serif;
  letter-spacing:-.055em;
  line-height:.96;
  color:var(--ink);
}
h3,h4{letter-spacing:-.025em;}
a{color:inherit}
.muted,.small{color:var(--muted)!important}

/* Cards, panels and containers */
.brand-card,.login-card,.panel,.mini-card,.day-card,.employee-form,.location-employee-group,.admin-create-box,
.local-task-card,.recipe-card,.provider-card,.task-card,.employee-admin-card{
  background:linear-gradient(180deg,rgba(255,253,247,.96),rgba(255,247,232,.93)) !important;
  border:1px solid rgba(200,164,107,.33) !important;
  border-radius:var(--radius-xl) !important;
  box-shadow:var(--shadow-soft) !important;
}
.panel{
  padding:clamp(16px,2.3vw,28px) !important;
}
.panel-head{
  align-items:center;
  padding-bottom:12px;
  border-bottom:1px solid rgba(200,164,107,.24);
  margin-bottom:12px;
}
.panel h1,.panel h2{margin-bottom:8px}
.cards-grid{gap:16px}

/* Inputs and buttons */
input,select,textarea{
  background:#fffaf3 !important;
  border:1px solid rgba(200,164,107,.42) !important;
  border-radius:14px !important;
  padding:11px 13px !important;
  color:var(--ink) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.75);
}
input:focus,select:focus,textarea:focus{
  outline:3px solid rgba(47,125,66,.16);
  border-color:rgba(47,125,66,.55) !important;
}
.btn,button.btn,.sa-btn{
  border-radius:14px !important;
  border:1px solid rgba(200,164,107,.35) !important;
  background:linear-gradient(180deg,#fff8eb,#eed9b7) !important;
  color:var(--ink) !important;
  font-weight:850 !important;
  box-shadow:0 8px 18px rgba(39,27,12,.08);
  transition:transform .15s ease, box-shadow .15s ease, filter .15s ease;
}
.btn:hover,.sa-btn:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(39,27,12,.12)}
.btn.primary,.btn.publish,.sa-btn.primary,
button[type="submit"].primary{
  background:linear-gradient(180deg,#368a4e,#26703b) !important;
  color:#fff !important;
  border-color:rgba(47,125,66,.45) !important;
}
.danger-btn,.sa-btn.danger{
  background:linear-gradient(180deg,#fee4e2,#ffd0cc) !important;
  color:#9b241c !important;
  border-color:#f6b8b3 !important;
}
.pill,.sa-badge,.status-row{
  border-radius:999px !important;
  border:1px solid rgba(200,164,107,.35);
}

/* Top bars: current app, but premium */
.topbar,.worker-hero,.local-task-header{
  background:linear-gradient(180deg,#17130d,#0d0b08) !important;
  color:#fff !important;
  border-bottom:1px solid rgba(200,164,107,.28);
  box-shadow:0 20px 55px rgba(15,10,4,.22) !important;
}
.topbar{
  padding:12px 18px !important;
  gap:14px !important;
}
.topbrand img,.worker-hero img,.local-brand img{
  background:linear-gradient(135deg,#f4d9b0,#c8a46b) !important;
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 10px 24px rgba(0,0,0,.20);
}
.topbrand strong{font-weight:950;letter-spacing:-.02em}
.topbrand span,.worker-hero p{color:#d9c7ab!important}
.topbar nav{
  gap:7px !important;
}
.topbar nav a{
  background:rgba(255,255,255,.06) !important;
  border:1px solid rgba(255,255,255,.08);
  color:#f9f1e2 !important;
  border-radius:13px !important;
  padding:9px 11px !important;
  font-weight:800;
}
.topbar nav a.active,.topbar nav a:hover{
  background:linear-gradient(180deg,#d7b87f,#b98a4d) !important;
  color:#17130d !important;
}
.admin-menu-toggle{
  background:linear-gradient(180deg,#d7b87f,#b98a4d)!important;
  color:#17130d!important;
  border:0!important;
  border-radius:13px!important;
  padding:10px 13px!important;
  font-weight:900!important;
}

/* Main wraps */
.admin-wrap,.worker-wrap,.local-wrap{
  width:min(1520px,100%) !important;
  padding:clamp(12px,2vw,26px) !important;
  gap:18px !important;
}

/* Tables */
.table-scroll{
  border:1px solid rgba(200,164,107,.34) !important;
  border-radius:24px !important;
  background:#fffaf1 !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
table{
  background:#fffaf1 !important;
}
th,td{
  border-bottom:1px solid rgba(200,164,107,.22) !important;
}
thead th{
  background:linear-gradient(180deg,#fff5df,#f4e2c3) !important;
  color:#3a2b19 !important;
  font-weight:950 !important;
}
.schedule-table th:first-child,.schedule-table td:first-child{
  background:#fff7e8 !important;
}
.shift-cell{
  background:rgba(255,250,241,.65);
}
.shift-cell input,.shift-cell select{
  background:#fffdf8 !important;
}
.total{
  background:rgba(255,250,241,.92)!important;
  border-radius:12px;
}
.total.ok{color:var(--ok)!important}
.total.warn{color:var(--warn)!important}
.total.bad{color:var(--bad)!important}

/* Status blocks */
.alert{
  border-radius:18px !important;
  border:1px solid rgba(200,164,107,.28);
  box-shadow:0 8px 18px rgba(39,27,12,.05);
}
.alert.ok,.okline{background:#e6f6e8!important;color:#1f6c36!important;border-color:#b6dfbd!important}
.alert.warn,.status-row.warn{background:#fff1d0!important;color:#8f5a08!important;border-color:#f0c77d!important}
.alert.danger{background:#fee4e2!important;color:#912018!important;border-color:#f2b8b4!important}

/* Worker view as mobile-app friendly cards */
.worker-hero{
  border-radius:0 0 26px 26px;
  padding:16px 22px !important;
}
.worker-top-actions{display:flex;gap:8px;align-items:center;margin-left:auto}
.worker-week-nav,.toolbar,.actions-line,.inline-form{
  background:rgba(255,250,241,.62);
  border:1px solid rgba(200,164,107,.22);
  border-radius:22px;
  padding:12px;
}
.total-box{
  background:linear-gradient(180deg,#fff8eb,#f5e1c4)!important;
  border:1px solid rgba(200,164,107,.35)!important;
  border-radius:24px!important;
  box-shadow:var(--shadow-soft);
}
.day-card{
  overflow:hidden;
  position:relative;
}
.day-card::before{
  content:"";
  position:absolute;
  left:0;right:0;top:0;height:5px;
  background:linear-gradient(90deg,#c8a46b,#2f7d42);
}
.shift-badge{
  border-radius:18px!important;
  border:1px solid rgba(200,164,107,.28)!important;
}
.shift-badge.work{background:#e8f6e9!important}
.shift-badge.free{background:#f1f2f0!important}
.shift-badge.vacation{background:#eaf4ff!important}
.shift-badge.sick{background:#fee7e4!important}
.shift-badge.unavailable{background:#fff2d1!important}

/* Admin accordion and employee cards */
.employee-schedule-card > summary,
.employee-schedule-card > summary.employee-row-summary{
  background:linear-gradient(135deg,#fffaf1,#f1d6aa)!important;
  border:1px solid rgba(34,23,13,.78)!important;
  box-shadow:0 14px 28px rgba(39,27,12,.10)!important;
}
.employee-open-indicator{
  background:linear-gradient(180deg,#17130d,#0d0b08)!important;
}
.employee-week-grid{
  background:#fffaf3!important;
  border-color:rgba(34,23,13,.78)!important;
}
.worker-summary-status{border-radius:16px!important}

/* Local / tasks / recetario */
.local-task-header{
  border-radius:0 0 28px 28px;
  padding:16px 20px;
}
.local-mini-nav a{
  border-radius:14px!important;
}
.local-task-grid,.recipe-grid{
  gap:16px!important;
}

/* Portal/root login */
body.login-body .portal-card,
body.login-body .login-card,
body.login-body .brand-card{
  background:linear-gradient(180deg,rgba(255,253,247,.97),rgba(255,247,232,.95))!important;
  border:1px solid rgba(200,164,107,.35)!important;
  box-shadow:0 28px 80px rgba(39,27,12,.16)!important;
}
.portal-title::after,.brand-card h1::after,.login-card h1::after{
  content:"";
  display:block;
  width:68px;
  height:5px;
  border-radius:99px;
  background:#2f7d42;
  margin:16px auto 0;
}

/* Superadmin v99 look */
body.superadmin-body{
  background:
    radial-gradient(circle at 10% 0%, rgba(255,255,255,.9), transparent 34%),
    linear-gradient(135deg,#fffaf1,#f5dec0) !important;
  color:var(--ink)!important;
}
.sa-shell{
  background:transparent!important;
}
.sa-sidebar{
  background:linear-gradient(180deg,#17130d,#0d0b08)!important;
  border-right:1px solid rgba(200,164,107,.28)!important;
  box-shadow:20px 0 60px rgba(20,13,5,.18);
}
.sa-brand img,.sa-brand .sa-logo-fallback{
  background:linear-gradient(135deg,#f4d9b0,#c8a46b)!important;
  color:#17130d!important;
}
.sa-menu a{
  border:1px solid transparent!important;
  border-radius:15px!important;
}
.sa-menu a.active,.sa-menu a:hover{
  background:linear-gradient(180deg,#d7b87f,#b98a4d)!important;
  color:#17130d!important;
}
.sa-main{
  max-width:1380px!important;
  padding:clamp(14px,2vw,28px)!important;
}
.sa-panel,.sa-login-card,.sa-company-card,.sa-kpi,.sa-admin-card,.sa-preview,.sa-empty{
  background:linear-gradient(180deg,rgba(255,253,247,.97),rgba(255,247,232,.95))!important;
  border:1px solid rgba(200,164,107,.34)!important;
  box-shadow:var(--shadow-soft)!important;
  border-radius:26px!important;
}
.sa-page-head h1{
  font-family:Georgia,"Times New Roman",serif!important;
  letter-spacing:-.055em!important;
  color:var(--ink)!important;
}
.sa-kpi strong{color:var(--ink)!important}
.sa-kpi span,.sa-muted,.sa-panel-desc{color:var(--muted)!important}
.sa-company-card:hover{
  transform:translateY(-3px)!important;
  box-shadow:0 20px 45px rgba(39,27,12,.14)!important;
}
.sa-mobile-top{
  background:linear-gradient(180deg,#17130d,#0d0b08)!important;
  color:#fff!important;
}
.sa-mobile-nav{
  background:linear-gradient(180deg,#fffaf1,#f1d6aa)!important;
  border:1px solid rgba(200,164,107,.3)!important;
  border-radius:18px!important;
}

/* Modals */
.modal,.confirm-modal,.sa-modal{
  border-radius:28px!important;
  background:linear-gradient(180deg,#fffdf7,#fff4e2)!important;
  border:1px solid rgba(200,164,107,.4)!important;
  box-shadow:0 28px 90px rgba(20,13,5,.28)!important;
}
.sa-modal-backdrop,.modal-backdrop{
  background:rgba(20,13,5,.48)!important;
  backdrop-filter:blur(5px);
}

/* Responsive polish */
@media(max-width:900px){
  html,body{background:linear-gradient(180deg,#fffaf1,#f5dec0)!important}
  .topbar{
    position:sticky!important;
    top:0!important;
    border-radius:0 0 22px 22px;
  }
  .topbar nav{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .brand-card,.login-card,.panel{
    border-radius:22px!important;
    padding:16px!important;
  }
  .admin-wrap,.worker-wrap{
    padding:12px!important;
  }
  .worker-hero{
    position:sticky;
    top:0;
    z-index:22;
    display:grid;
    grid-template-columns:auto 1fr;
    align-items:center;
  }
  .worker-hero .worker-top-actions{
    grid-column:1 / -1;
    width:100%;
    margin-left:0;
    display:grid;
    grid-template-columns:1fr 1fr;
  }
  .worker-days,.cards-grid,.employee-list-cards{
    grid-template-columns:1fr!important;
  }
  .day-card,.mini-card,.employee-admin-card{
    border-radius:22px!important;
  }
  .table-scroll{
    border-radius:0!important;
    box-shadow:none!important;
  }
  .schedule-table tr.schedule-worker-row{
    background:linear-gradient(180deg,#fffdf7,#fff4e2)!important;
    border-color:rgba(200,164,107,.35)!important;
    box-shadow:var(--shadow-soft)!important;
  }
  .mobile-day{
    color:#9c6e2e!important;
  }
  .sa-shell{
    display:block!important;
  }
  .sa-main{
    padding:12px!important;
  }
  .sa-panel,.sa-company-card,.sa-kpi{
    border-radius:22px!important;
  }
  .sa-kpis{
    grid-template-columns:1fr 1fr!important;
  }
}
@media(max-width:560px){
  .sa-kpis{grid-template-columns:1fr!important}
  .topbar nav{grid-template-columns:1fr!important}
  .portal-title,.brand-card h1,.login-card h1{
    font-size:clamp(2.1rem,11vw,3rem)!important;
  }
  .toolbar,.actions-line,.inline-form,.worker-week-nav{
    border-radius:18px!important;
    padding:10px!important;
  }
}

/* Print remains compact and neutral */
@media print{
  body{background:#fff!important}
  .topbar,.worker-hero,.local-task-header{box-shadow:none!important}
}


/* =========================================================
   v101 · Ajustes de marca ordenados en el panel cliente
   ========================================================= */
.settings-brand-panel .panel-head{
  margin-bottom:18px;
}
.settings-brand-card > summary{
  background:linear-gradient(135deg,#fffaf1,#f2ddba);
  border:1px solid rgba(200,164,107,.34);
  border-radius:22px;
  padding:16px 18px;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(39,27,12,.07);
}
.settings-brand-card > summary strong{
  font-size:1.15rem;
}
.settings-brand-card > summary em{
  display:block;
  color:var(--muted);
  font-style:normal;
  margin-top:3px;
}
.settings-brand-form{
  margin-top:18px;
}
.settings-brand-layout{
  display:grid;
  gap:18px;
}
.settings-block{
  background:linear-gradient(180deg,rgba(255,253,247,.98),rgba(255,247,232,.94));
  border:1px solid rgba(200,164,107,.32);
  border-radius:24px;
  padding:18px;
  box-shadow:0 12px 28px rgba(39,27,12,.07);
}
.settings-block-head{
  display:flex;
  gap:12px;
  align-items:flex-start;
  margin-bottom:16px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(200,164,107,.22);
}
.settings-block-icon{
  width:42px;
  height:42px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:linear-gradient(180deg,#d7b87f,#b98a4d);
  box-shadow:0 8px 18px rgba(39,27,12,.10);
  flex:0 0 auto;
}
.settings-block h3{
  margin:0;
  font-size:1.08rem;
}
.settings-block p{
  margin:.25rem 0 0;
  color:var(--muted);
}
.settings-media-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:14px;
}
.settings-upload-card{
  background:rgba(255,250,241,.72);
  border:1px solid rgba(200,164,107,.25);
  border-radius:20px;
  padding:14px;
}
.settings-image-preview{
  margin-top:12px;
  display:grid;
  gap:8px;
}
.settings-image-preview img{
  max-width:180px;
  max-height:110px;
  object-fit:contain;
  background:#fff;
  border:1px solid rgba(200,164,107,.25);
  border-radius:18px;
  padding:10px;
  box-shadow:0 8px 18px rgba(39,27,12,.06);
}
.settings-icon-preview img{
  width:84px;
  height:84px;
  max-width:84px;
  max-height:84px;
}
.settings-note{
  margin:12px 0 0!important;
  font-size:.92rem;
  background:#fff8eb;
  border:1px solid rgba(200,164,107,.28);
  border-radius:16px;
  padding:10px 12px;
}
.settings-color-grid input[type="color"]{
  min-height:48px;
  padding:5px!important;
}
.settings-help-compact{
  margin-top:12px;
}
.settings-help-compact p{
  margin:5px 0;
}
.settings-whatsapp-preview{
  margin-top:14px;
}
.settings-whatsapp-preview pre{
  white-space:pre-wrap;
  margin:8px 0 0;
  background:#17130d;
  color:#fff6e6;
  border-radius:18px;
  padding:14px;
  overflow:auto;
  border:1px solid rgba(200,164,107,.25);
}
.settings-save-bar{
  position:sticky;
  bottom:12px;
  z-index:10;
  margin-top:18px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  background:rgba(255,250,241,.94);
  border:1px solid rgba(200,164,107,.38);
  border-radius:22px;
  padding:14px;
  box-shadow:0 18px 45px rgba(39,27,12,.14);
  backdrop-filter:blur(8px);
}
.settings-save-bar strong,
.settings-save-bar span{
  display:block;
}
.settings-save-bar span{
  color:var(--muted);
  font-size:.9rem;
  margin-top:2px;
}
@media(max-width:760px){
  .settings-block{
    padding:14px;
    border-radius:20px;
  }
  .settings-block-head{
    display:grid;
    grid-template-columns:42px 1fr;
  }
  .settings-save-bar{
    position:static;
    display:grid;
    grid-template-columns:1fr;
  }
  .settings-save-bar .btn{
    width:100%;
  }
}


/* v102 · Proveedores WhatsApp/email + recetario robusto */
.supplier-order-actions{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.supplier-order-actions .muted{
  margin:0;
  flex:1 1 240px;
}
.supplier-row-title em{
  line-height:1.45;
}
.recipe-product-card-admin img,
.local-recipe-product-tile img,
#recipeDetailImage{
  background:#fff8eb;
  object-fit:cover;
}
.recipe-product-placeholder,
.recipe-tile-placeholder{
  border:1px dashed rgba(200,164,107,.55);
  background:rgba(255,248,235,.82);
  color:var(--muted);
  display:grid;
  place-items:center;
  text-align:center;
}


/* v103 · Ajustes de marca por desplegables independientes */
.settings-options-accordion{
  display:block;
}
.settings-options-accordion .settings-brand-form{
  margin-top:0;
}
.settings-subsection{
  padding:0!important;
  overflow:hidden;
}
.settings-subsection > summary.settings-block-head{
  cursor:pointer;
  list-style:none;
  margin:0!important;
  padding:16px 18px;
  border:0!important;
  border-bottom:0!important;
  align-items:center;
}
.settings-subsection > summary.settings-block-head::-webkit-details-marker{
  display:none;
}
.settings-subsection .settings-block-title{
  display:grid;
  gap:3px;
  min-width:0;
  flex:1;
}
.settings-subsection .settings-block-title strong{
  font-size:1.06rem;
  color:var(--ink);
}
.settings-subsection .settings-block-title em{
  font-style:normal;
  color:var(--muted);
  font-size:.92rem;
  line-height:1.35;
}
.settings-block-chevron{
  margin-left:auto;
  width:32px;
  height:32px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:rgba(200,164,107,.18);
  border:1px solid rgba(200,164,107,.32);
  color:#7a5627;
  font-weight:900;
  transition:transform .18s ease, background .18s ease;
}
.settings-subsection[open] .settings-block-chevron{
  transform:rotate(180deg);
  background:rgba(47,125,66,.14);
  color:#26703b;
}
.settings-subsection .settings-block-content{
  padding:0 18px 18px;
  border-top:1px solid rgba(200,164,107,.22);
}
.settings-subsection:not([open]){
  box-shadow:0 8px 20px rgba(39,27,12,.055)!important;
}
.settings-subsection:not([open]) .settings-block-head{
  border-bottom:0!important;
}
.settings-subsection[open]{
  box-shadow:0 16px 34px rgba(39,27,12,.09)!important;
}
.settings-subsection[open] > summary.settings-block-head{
  background:linear-gradient(135deg,rgba(255,250,241,.95),rgba(242,221,186,.76));
}
@media(max-width:760px){
  .settings-subsection > summary.settings-block-head{
    grid-template-columns:42px 1fr 32px;
    padding:14px;
  }
  .settings-subsection .settings-block-content{
    padding:0 14px 14px;
  }
}
