:root{
  --verd:#2e7d32; --verd-fosc:#1b5e20; --verd-clar:#e8f5e9;
  --gris:#5f6b66; --vora:#d7ddd9; --fons:#f6f8f6; --error:#c62828; --groc:#f9a825;
  --ombra:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
}
*{box-sizing:border-box}
body{font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  margin:0;color:#1f2a24;background:var(--fons);line-height:1.5;font-size:15px}
.wrap{max-width:880px;margin:0 auto;padding:24px 18px}
.wrap-wide{max-width:1100px}
h1{font-size:1.5rem;margin:.2em 0 .1em;color:var(--verd-fosc)}
h2{font-size:1.15rem;color:var(--verd-fosc);border-bottom:2px solid var(--verd-clar);padding-bottom:6px;margin-top:1.6em}
h3{font-size:1rem;margin:1.2em 0 .4em}
.sub{color:var(--gris);margin-top:0}
a{color:var(--verd)}
.card{background:#fff;border:1px solid var(--vora);border-radius:10px;padding:22px;box-shadow:var(--ombra);margin-bottom:18px}
label{display:block;font-weight:600;margin:14px 0 4px;font-size:.92rem}
.req{color:var(--error)}
input[type=text],input[type=email],input[type=tel],input[type=number],input[type=password],input[type=date],select,textarea{
  width:100%;padding:9px 11px;border:1px solid var(--vora);border-radius:7px;font:inherit;background:#fff}
input:focus,select:focus,textarea:focus{outline:2px solid var(--verd);border-color:var(--verd)}
textarea{min-height:72px;resize:vertical}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row>div{flex:1;min-width:180px}
.hint{font-size:.82rem;color:var(--gris);font-weight:400;margin-top:3px}
.btn{display:inline-block;background:var(--verd);color:#fff;border:0;border-radius:7px;
  padding:11px 20px;font:inherit;font-weight:600;cursor:pointer;text-decoration:none}
.btn:hover{background:var(--verd-fosc)}
.btn.sec{background:#fff;color:var(--verd);border:1px solid var(--verd)}
.btn.danger{background:var(--error)}
.btn.small{padding:6px 12px;font-size:.85rem}
.btn[disabled]{opacity:.5;cursor:not-allowed}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.msg{padding:12px 16px;border-radius:8px;margin:12px 0}
.msg.ok{background:var(--verd-clar);border:1px solid var(--verd);color:var(--verd-fosc)}
.msg.error{background:#ffebee;border:1px solid var(--error);color:var(--error)}
.msg.warn{background:#fff8e1;border:1px solid var(--groc);color:#8d6e00}
.checks{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:6px 16px;margin-top:6px}
.checks label{font-weight:400;margin:0;display:flex;align-items:center;gap:8px;font-size:.9rem}
.checks input{width:auto}
.checks label.occ{color:#b71c1c;text-decoration:line-through;opacity:.7}
table{width:100%;border-collapse:collapse;font-size:.9rem;background:#fff}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--vora);vertical-align:top}
th{background:var(--verd-clar);color:var(--verd-fosc);font-size:.82rem;text-transform:uppercase;letter-spacing:.03em}
tr:hover td{background:#fafdfa}
.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:.78rem;font-weight:600}
.badge.pendent{background:#fff8e1;color:#8d6e00}
.badge.aprovat{background:var(--verd-clar);color:var(--verd-fosc)}
.badge.rebutjat{background:#ffebee;color:var(--error)}
.topbar{background:var(--verd-fosc);color:#fff;padding:0}
.topbar .wrap{display:flex;align-items:center;gap:18px;padding:12px 18px}
.topbar a{color:#fff;text-decoration:none;font-weight:600;opacity:.9;position:relative}
.topbar a:hover,.topbar a.active{opacity:1;border-bottom:2px solid #fff;padding-bottom:2px}
.topbar .brand{font-size:1.05rem;margin-right:auto;white-space:nowrap;flex-shrink:0}
.brand-logo{height:22px;width:auto;vertical-align:middle;margin-right:5px}
.topbar .linkbtn{background:none;border:0;color:#fff;font:inherit;font-weight:600;cursor:pointer;opacity:.9;padding:0}
.topbar .linkbtn:hover{opacity:1;text-decoration:underline}
/* Badge estilo iOS: círculo rojo flotando en la esquina superior derecha */
.navcount{position:absolute;top:-8px;right:-14px;background:#ff3b30;color:#fff;
  min-width:18px;height:18px;border-radius:9px;padding:0 5px;box-sizing:border-box;
  font-size:.7rem;font-weight:700;line-height:18px;text-align:center;
  box-shadow:0 0 0 2px var(--verd-fosc)}
/* Detalle de petición */
.detall{width:100%;border-collapse:collapse;margin:6px 0 16px}
.detall th{width:200px;text-align:left;vertical-align:top;color:var(--verd-fosc);background:#f3f8f3;
  font-size:.85rem;padding:8px 12px;border-bottom:1px solid var(--vora);text-transform:none;letter-spacing:0}
.detall td{padding:8px 12px;border-bottom:1px solid var(--vora);vertical-align:top}
.detall h3{margin:18px 0 4px;color:var(--verd-fosc)}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin:14px 0}
.stat{background:#fff;border:1px solid var(--vora);border-radius:10px;padding:16px;text-align:center;box-shadow:var(--ombra)}
.stat .n{font-size:2rem;font-weight:700;color:var(--verd-fosc)}
.stat .l{color:var(--gris);font-size:.85rem}
.muted{color:var(--gris)}
.right{text-align:right}
.nowrap{white-space:nowrap}
.tag{display:inline-block;background:var(--verd-clar);color:var(--verd-fosc);border-radius:6px;padding:1px 8px;margin:2px;font-size:.82rem}
/* Calendari */
.cal-head{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.cal-head h2{border:0;margin:0;flex:1;text-align:center}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-grid .dow{font-weight:700;text-align:center;color:var(--gris);font-size:.8rem;padding:4px}
.day{aspect-ratio:1/1;border:1px solid var(--vora);border-radius:8px;padding:5px;cursor:pointer;
  display:flex;flex-direction:column;background:#fff;min-height:58px;transition:.1s}
.day:hover{border-color:var(--verd)}
.day .dn{font-weight:600}
.day .av{font-size:.72rem;margin-top:auto;font-weight:700;color:#16321f}
.day.empty{border:0;background:transparent;cursor:default}
.day.past{background:#f0f0f0!important;color:#aaa;cursor:not-allowed}
.day.blocked{background:#f0f0f0!important;color:#aaa;cursor:not-allowed}
.day.full{cursor:not-allowed}
.day.sel{background:var(--verd)!important;color:#fff;border-color:var(--verd-fosc)}
.day.sel .dn,.day.sel .av{color:#fff}
/* Calendari partit en dues franges (matí / tarda) */
.cal-grid2{gap:6px}
.day2{border:1px solid var(--vora);border-radius:10px;background:#fff;display:flex;flex-direction:column;
  min-height:88px;overflow:hidden}
.day2.empty{border:0;background:transparent}
.day2 .dn{font-weight:700;font-size:.8rem;padding:5px 8px 2px;line-height:1;color:#243b2c}
.day2.past,.day2.blocked{background:#f5f5f5;border-color:#e6e6e6}
.day2.past .dn,.day2.blocked .dn{color:#b8b8b8}
.day2 .halves{display:flex;flex-direction:column;flex:1;gap:3px;padding:4px 5px 5px}
.half{flex:1;display:flex;align-items:center;justify-content:space-between;gap:4px;border-radius:7px;
  padding:2px 8px;font-size:.72rem;color:#1c3a26;border:1px solid rgba(0,0,0,.1);
  background:#fff;user-select:none;min-height:24px;transition:box-shadow .08s,border-color .08s}
.half .hl{font-weight:600;opacity:.8}
.half .hl .curt{display:none}
.half .hv{font-weight:800}
.half.off{visibility:hidden}
.half[data-sel="1"]{cursor:pointer}
.half[data-sel="1"]:hover{border-color:var(--verd-fosc);box-shadow:inset 0 0 0 1.5px var(--verd-fosc)}
.half[data-sel="1"]:focus{outline:2px solid var(--verd-fosc);outline-offset:1px}
.half.blockedh{background:#ececec;border-color:#ddd;color:#9a9a9a}
.half.full{color:#8a1c1c;cursor:not-allowed}
.half.sel{background:var(--verd)!important;border-color:var(--verd-fosc);color:#fff}
.half.sel .hl{color:#eaf6ec;opacity:1}
.half.sel .hv{color:#fff}
.half.sel .hv::after{content:" ✓"}
@media (max-width:640px){
  .half .hl .llarg{display:none}
  .half .hl .curt{display:inline}
  .half{padding:2px 6px;font-size:.68rem}
  .day2{min-height:80px}
}
/* Fila en edició en línia (BD) */
tr.editrow{background:#f4faf5}
tr.editrow td{vertical-align:middle}
tr.editrow input[type=text],tr.editrow input[type=email]{padding:5px 8px;font-size:.88rem;min-width:90px}
.legend{display:flex;gap:16px;flex-wrap:wrap;margin:12px 0;font-size:.83rem;color:var(--gris)}
.legend span{display:inline-flex;align-items:center;gap:6px}
.dot{width:14px;height:14px;border-radius:4px;display:inline-block;border:1px solid var(--vora)}
.dot.free{background:#fff}.dot.full{background:#ffebee}.dot.sel{background:var(--verd)}
.selbar{position:sticky;bottom:0;background:#fff;border-top:1px solid var(--vora);padding:14px;
  display:flex;align-items:center;gap:12px;margin-top:16px;border-radius:0 0 10px 10px}
.selbar .dies{flex:1}
/* Configuracions: menú lateral de pestanyes (botons a l'esquerra, contingut a la dreta) */
.settings{display:flex;gap:22px;align-items:flex-start;margin-top:14px}
.settings-nav{flex:0 0 200px;display:flex;flex-direction:column;gap:6px;position:sticky;top:18px}
.settings-nav a{display:block;text-decoration:none;color:var(--verd-fosc);font-weight:600;
  padding:10px 14px;border-radius:8px;border:1px solid var(--vora);background:#fff}
.settings-nav a:hover{background:var(--verd-clar)}
.settings-nav a.active{background:var(--verd);color:#fff;border-color:var(--verd-fosc);box-shadow:var(--ombra)}
.settings-main{flex:1;min-width:0}
.settings.tabs-on .tabpane{display:none}
.settings.tabs-on .tabpane.active{display:block}
.tabpane>h2:first-child{margin-top:0}
@media (max-width:720px){
  .settings{flex-direction:column}
  .settings-nav{flex:1 1 auto;flex-direction:row;flex-wrap:wrap;position:static}
  .settings-nav a{flex:1 1 auto;text-align:center}
}
