:root{--navy:#353f67;--dark:#273056;--pink:#e94b68;--cyan:#05a7a7;--sky:#4fc0ed;--line:#cfd6e6;--soft:#f4f7fb;--text:#111827}*{box-sizing:border-box}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:#f6f8fb;color:var(--text)}a{text-decoration:none;color:inherit}.login-bg{min-height:100vh;background:linear-gradient(rgba(50,61,100,.86),rgba(50,61,100,.86)),url('login-bg.jpg') center/cover;display:grid;place-items:center}.login-card{width:340px;background:rgba(45,55,94,.94);padding:28px;color:#fff;text-align:center}.brand{font-size:40px;font-weight:bold;margin-bottom:18px}.brand span{background:var(--pink);padding:4px 8px;border-radius:4px}.brand em{font-style:normal;font-weight:300}.field{width:100%;padding:10px;margin:7px 0;border:1px solid #91a0c5;background:#eef3ff}.btn{border:0;padding:11px 18px;background:var(--pink);color:#fff;cursor:pointer;font-weight:bold}.btn.cyan{background:var(--cyan)}.btn.dark{background:var(--dark)}.topbar{height:56px;background:var(--dark);color:#fff;display:flex;align-items:center;gap:20px;padding:0 18px}.topbar .logo{font-size:24px;font-weight:bold}.layout{display:flex;min-height:calc(100vh - 56px)}.side{width:230px;background:#fff;border-right:1px solid var(--line);padding:14px}.menu a{display:block;background:var(--pink);color:#fff;text-align:center;margin:0 0 6px;padding:11px;text-transform:uppercase}.main{flex:1;padding:18px;overflow:auto}.card{background:#fff;border:1px solid var(--line);box-shadow:0 2px 8px #0001;margin-bottom:16px}.card h2{margin:0;background:#eef2f8;padding:12px 14px;color:var(--dark);font-size:18px}.card-body{padding:14px}.grid{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:12px}.stat{background:#eef5ff;border-left:5px solid var(--sky);padding:14px}.table{width:100%;border-collapse:collapse;background:#fff}.table th{background:#1f1b68;color:#fff}.table th,.table td{border:1px solid #999;padding:7px;text-align:left}.form-grid{display:grid;grid-template-columns:180px 1fr;gap:10px;align-items:center}.tabs{display:flex;gap:4px;margin-bottom:8px}.tab{background:#a8d5e7;padding:10px 18px;border-radius:12px 12px 0 0}.tab.active{background:#209ab4;color:#fff}.calendar{display:grid;grid-template-columns:70px repeat(7,1fr);border:1px solid #8ca3c4;background:#fff}.cal-head,.time,.day{border-right:1px solid #8ca3c4;border-bottom:1px solid #d9e1ef;min-height:34px;padding:5px}.cal-head{background:#a9c4e6;text-align:center;font-weight:bold}.time{background:#f8fbff;color:#274069}.day{min-height:620px;position:relative;background:repeating-linear-gradient(to bottom,#fff 0,#fff 23px,#dce6f5 24px)}.booking{position:absolute;left:4px;right:4px;background:#f4a365;border:1px solid #904a16;padding:5px;font-size:12px;overflow:hidden}.booking.blue{background:#8fb0e1}.booking.cancel{background:#bbb}.day.red{background:#ffc9cd}.print-head{display:flex;justify-content:space-between;align-items:flex-start}.print-logo{font-size:34px}.notice{color:red;font-weight:bold;margin:25px 0}.split{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:900px){.layout{display:block}.side{width:auto}.grid,.split{grid-template-columns:1fr}.calendar{grid-template-columns:55px repeat(7,220px);overflow:auto}.main{padding:10px}}@media print{.topbar,.side,.no-print{display:none}.layout,.main{display:block;padding:0}.card{border:0;box-shadow:none}@page{margin:12mm}}
/* MOT Boss booking entry window - deliberately mirrors the desktop ATF Pro entry screen */
.mot-entry-shell{background:#fff;border:1px solid #9ca3af;max-width:1120px;margin:0 auto;box-shadow:0 18px 45px #0002}.mot-window-title{height:32px;background:#f4f6fb;color:#111;display:flex;align-items:center;justify-content:space-between;padding:0 8px;font-size:14px}.mot-x{font-size:24px;line-height:1;color:#111}.mot-entry-datebar{background:#333d67;color:#fff;font-size:18px;font-weight:bold;padding:11px 18px}.mot-tabs{height:36px;background:#fff;border-bottom:6px solid #1d9bb7;padding-left:8px}.mot-tabs span{display:inline-block;background:#bfe8f1;color:#19556a;border-radius:12px 12px 0 0;padding:8px 14px;font-size:13px}.mot-tabs span.active{background:#28a6bf;color:#fff;font-weight:bold}.mot-entry-panel{border:3px solid #1d9bb7;border-top:0;margin:0 4px 0 4px;display:grid;grid-template-columns:295px 1fr;gap:18px;padding:14px 8px 10px}.mot-left{padding-right:8px}.mini-cal{border:1px solid #999;background:#fff;width:290px;height:188px;text-align:center;padding:8px;font-size:14px}.mini-cal .mini-month{margin-bottom:8px}.mini-cal table{width:100%;border-collapse:collapse}.mini-cal th{font-weight:normal;color:#000}.mini-cal td{padding:1px 4px;color:#111}.mini-cal td.sel{border:1px solid #777;background:#dfe7f5}.mini-cal .today{font-size:12px;margin-top:4px}.cost-box{width:290px;margin-top:12px;background:#245ca4;color:#fff}.cost-box h3{margin:0;background:#1d579d;padding:12px 20px;font-size:20px}.cost-box dl{display:grid;grid-template-columns:1fr 80px;margin:0;padding:10px 24px 14px 24px;font-size:14px}.cost-box dt,.cost-box dd{margin:0;padding:1px 0}.cost-box dd{text-align:right}.cost-box .profit{padding-top:12px}.mot-form-area{font-size:14px;padding-top:10px}.form-row{display:grid;grid-template-columns:190px 180px 34px 34px 1fr;gap:5px;align-items:center;margin:6px 0}.form-row label{text-align:right;font-weight:bold;padding-right:12px}.form-row input,.form-row select,.form-row textarea,.mot-code-actions select{height:28px;border:1px solid #c8c8c8;background:#fff;border-radius:0;padding:3px 6px;font-size:14px;box-shadow:none}.form-row input.wide{grid-column:2/5}.form-row input.med{width:315px}.form-row input.wide2{grid-column:3/6}.form-row.short{grid-template-columns:190px 90px 90px 1fr}.lookup,.dots{height:26px;border:1px solid #c8c8c8;background:#fff;border-radius:4px}.mot-code-row{display:grid;grid-template-columns:190px 1fr;margin-top:8px}.mot-code-row>label{text-align:right;font-weight:bold;padding-right:12px;padding-top:22px}.mot-code-actions{display:grid;grid-template-columns:1fr 155px 170px;gap:8px;align-items:center;margin-bottom:4px}.mot-code-actions select{height:0;opacity:0;position:absolute}.add-code{background:#009688;color:#fff;border:0;height:38px;font-weight:bold}.lock{font-weight:normal!important;text-align:left!important;padding:0!important}.mot-code-table{width:100%;border-collapse:collapse;height:105px}.mot-code-table th,.mot-code-table td{border:1px solid #c6c6c6;padding:6px;text-align:left;font-size:14px}.mot-code-table th{background:#fff;color:#000;font-weight:normal}.mot-code-table input{width:60px;border:0;text-align:right}.tiny-del{border:1px solid #999;background:#fff;border-radius:4px;padding:4px 16px}.form-row.date-time{grid-template-columns:190px 170px 62px 62px 58px 1fr}.form-row.date-time label{text-align:right}.form-row.hires{grid-template-columns:190px 120px 100px 100px 150px 85px;margin-bottom:0}.form-row.hires label{text-align:right;font-weight:normal}.form-row.hires span{font-size:14px}.form-row.hires.inputs{margin-top:0}.form-row.hires.inputs label{font-size:13px;line-height:14px}.form-row.hires.inputs select{width:100%;height:28px}.form-row.notes{grid-template-columns:190px 1fr}.form-row.notes textarea{height:72px;resize:none}.mot-entry-footer{height:60px;display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:8px 8px;background:#fff}.mini-logo{margin-right:auto;font-size:28px;line-height:1}.mini-logo b{background:#e94b68;color:#fff;padding:2px 6px;border-radius:4px}.mini-logo span{background:#353f67;color:#fff;padding:2px 5px;border-radius:4px;font-weight:300}.foot-btn{border:0;color:#fff;font-size:14px;padding:14px 30px;min-width:160px}.foot-btn.dark{background:#333d67}.foot-btn.pink{background:#e94b68}.foot-btn.teal{background:#008f8f}@media(max-width:1000px){.mot-entry-panel{grid-template-columns:1fr}.mini-cal,.cost-box{width:100%}.form-row,.form-row.short,.form-row.date-time,.form-row.hires,.form-row.notes,.mot-code-row{grid-template-columns:1fr}.form-row label,.mot-code-row>label{text-align:left}.mot-entry-footer{height:auto;flex-wrap:wrap}.foot-btn{width:100%}}
.booking-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:9999;align-items:center;justify-content:center;padding:28px}.booking-modal.show{display:flex}.booking-modal-inner{width:min(1140px,96vw);height:min(720px,92vh);background:#fff;box-shadow:0 25px 70px #0008}.booking-modal iframe{width:100%;height:100%;border:0;background:#fff}
.update-message{padding:10px 12px;border-left:5px solid #1f7a1f;background:#eef9ee}.update-message.warn{border-color:#d28b00;background:#fff7e6}.update-message.bad{border-color:#c62828;background:#ffecec}.update-upload-form{display:flex;align-items:center;gap:12px;margin:12px 0 18px}.update-table{font-size:14px}.update-table code{font-size:12px}.update-table details summary{cursor:pointer;color:#001b70;font-weight:700}.update-table pre{white-space:pre-wrap;max-width:520px;background:#f5f5f5;border:1px solid #ccc;padding:8px;margin-top:8px;color:#111}

/* v0.1.4 - 5 minute diary and draggable overlay booking window */
.calendar5{display:grid;grid-template-columns:70px repeat(7,minmax(150px,1fr));grid-template-rows:34px repeat(var(--slot-count),16px);border:1px solid #8ca3c4;background:#fff;position:relative;overflow:auto;max-height:calc(100vh - 215px)}
.calendar5>.cal-head{position:sticky;top:0;z-index:5;background:#a9c4e6;text-align:center;font-weight:bold;border-right:1px solid #8ca3c4;border-bottom:1px solid #8ca3c4;padding:7px 5px;min-height:34px}.calendar5>.corner{left:0;z-index:8}.time5{position:sticky;left:0;z-index:4;background:#f8fbff;color:#274069;border-right:1px solid #8ca3c4;border-bottom:1px solid #d9e1ef;font-size:11px;line-height:16px;text-align:right;padding-right:6px}.slot5{display:block;border-right:1px solid #8ca3c4;border-bottom:1px solid #d9e1ef;background:#fff;min-height:16px}.slot5:nth-child(8n+1){border-bottom-color:#aebbd0}.slot5.red{background:#ffc9cd}.slot5:hover{outline:2px solid #209ab4;outline-offset:-2px;background:#e8f7fb}.booking5{z-index:6;margin:1px 4px;border:1px solid #904a16;padding:4px 5px;font-size:12px;line-height:15px;overflow:hidden;color:#000;box-shadow:0 1px 2px #0002}.booking5:hover{outline:2px solid #333d67;outline-offset:-2px}.booking-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:9999;align-items:center;justify-content:center;padding:28px}.booking-modal.show{display:flex}.booking-modal-inner{width:min(1120px,96vw);height:min(704px,92vh);background:#fff;box-shadow:0 25px 70px #0008;resize:both;overflow:hidden}.booking-modal iframe{width:100%;height:100%;border:0;background:#fff}.booking-modal.dragging,.booking-modal.dragging iframe{user-select:none}.mot-x-btn{border:0;background:transparent;cursor:pointer}.mot-window-title{cursor:move}@media(max-width:1000px){.calendar5{grid-template-columns:55px repeat(7,220px)}}

/* v0.1.9 - modal iframe must show ONLY the booking form, never the app shell/menu */
body.modal-body{background:transparent;margin:0;padding:0;overflow:hidden;}
body.modal-body .mot-entry-shell{margin:0;max-width:none;width:100%;min-width:960px;box-shadow:none;border:0;}
body.modal-body .mot-entry-panel{grid-template-columns:295px minmax(0,1fr);gap:18px;}
body.modal-body .mot-form-area{min-width:0;}
body.modal-body .mot-entry-footer{position:sticky;bottom:0;}
.booking-modal-inner{width:min(1120px,96vw);height:min(704px,92vh);}
.booking-modal iframe{display:block;}

/* v0.2.0 admin/company/settings cleanup */
.app-logo-img{max-height:40px;max-width:180px;display:block}.company-switch{display:flex;align-items:center;gap:7px;margin-left:auto}.company-switch select{height:30px;border:1px solid #7b86aa;background:#fff;color:#111}.toast,.modal-toast{position:fixed;right:22px;top:72px;z-index:20000;min-width:280px;max-width:520px;background:#ecfff0;border-left:6px solid #1f9d45;color:#0b2d16;box-shadow:0 12px 32px #0003;padding:14px 42px 14px 14px;font-weight:700}.toast.warn{background:#fff7e6;border-left-color:#d28b00;color:#3b2600}.toast.bad{background:#ffecec;border-left-color:#c62828;color:#4b0000}.toast button,.modal-toast button{position:absolute;right:8px;top:6px;border:0;background:transparent;font-size:22px;cursor:pointer}.modal-toast{top:12px;right:12px;background:#eef7ff;border-left-color:#209ab4;color:#092f3a}.mini-btn{display:inline-block;border:0;background:#333d67;color:#fff;padding:6px 9px;margin:1px;font-size:12px;cursor:pointer}.mini-btn.danger{background:#e94b68}.row-bad td{background:#ffe5e9!important}.admin-form{background:#f8fbff;border:1px solid #d7e0ef;padding:12px;margin-bottom:14px}.settings-code-table input[type="number"]{width:90px}.settings-code-table input[type="text"],.settings-code-table input:not([type]){width:260px}.pay-block{display:inline-block;background:#ffe5e9;color:#9c1027;border-left:5px solid #e94b68;padding:10px 12px;font-weight:bold}.restricted-slot{cursor:not-allowed;opacity:.75}.restricted-slot:hover{outline:2px solid #e94b68;outline-offset:-2px}
