ClickInventories – London's best Online Bookable Property Inventory Service Click To Call Us Now
Click To Call Us Now

Limited Time Offer — Save 10% on Your First Inventory Report

CLICKSERVICES2026 Apply the code when you pay at booking to receive your discount instantly.
Our Services

Comprehensive Inventory Reports

Get accurate and highly descriptive property inventory reports with high-resolution photos. Our experienced clerks with an eye for detail will ensure that you have no nasty surprises.

Inventory and condition report

Best Inventory and Condition Report 2026

Book your inventory and condition report online today with Click Inventories LTD, trusted by landlords and letting agents across London. Inventory & Condition Reports Comprehensive property inventory with full condition reporting, carried out by AIIC-accredited clerks. ✓ All prices inclusive of VAT — no hidden fees 🏢 Flat 🏠 House…

Book Now →
Mid-term Inspection

Click Inventories LTD: Mid-term inspection

Professional Mid-Term Inspection Services in London See Our Prices / Book Now A mid-term inspection is an essential part of responsible property management, providing landlords and letting agents with a thorough assessment of a rental property's condition during an active tenancy. At Click Inventories, our mid-term inspection service is carried…

Book Now →
inventory check-in report

Inventory & Check-In Reports for London Properties

[vc_row][vc_column][vc_column_text]Beginning a new tenancy, the critical first step revolves around the Inventory Check-In Report, diligently compiled by Click Inventories LTD. This fundamental document doesn't just capture the property's initial condition but also sets an unmistakable benchmark for future evaluations, thereby playing a central role in the tenancy process​1​.[/vc_column_text][/vc_column][vc_column][vc_text_separator title="Price List"][/vc_column][/vc_row][vc_row][vc_column][vc_raw_html]<style>@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Plus+Jakarta+Sans:wght@600;700;800&display=swap');:root{--ci-teal:#0D9488;--ci-teal-dark:#0F766E;--ci-teal-deeper:#115E59;--ci-teal-light:#CCFBF1;--ci-teal-50:#F0FDFA;--ci-teal-100:#E6FAF5;--ci-amber:#D97706;--ci-amber-light:#FEF3C7;--ci-amber-bg:#FFFBEB;--ci-gold:#B45309;--ci-green:#059669;--ci-green-light:#D1FAE5;--ci-red:#DC2626;--ci-white:#FFFFFF;--ci-gray-50:#F9FAFB;--ci-gray-100:#F3F4F6;--ci-gray-200:#E5E7EB;--ci-gray-300:#D1D5DB;--ci-gray-400:#9CA3AF;--ci-gray-500:#6B7280;--ci-gray-600:#4B5563;--ci-gray-700:#374151;--ci-gray-800:#1F2937;--ci-gray-900:#111827;--ci-radius:10px;--ci-radius-lg:14px}#ci-checkin-v3 *{margin:0;padding:0;box-sizing:border-box}#ci-checkin-v3{font-family:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;max-width:940px;margin:0 auto;color:var(--ci-gray-800);line-height:1.5}#ci-checkin-v3 .ci-page-head{text-align:center;padding:32px 20px 8px}#ci-checkin-v3 .ci-page-head h1{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:30px;font-weight:800;color:var(--ci-teal-deeper);letter-spacing:-0.5px;margin-bottom:8px}#ci-checkin-v3 .ci-page-head p{font-size:15px;color:var(--ci-gray-500);max-width:620px;margin:0 auto}#ci-checkin-v3 .ci-toggle-wrap{display:flex;align-items:center;justify-content:center;gap:14px;padding:24px 20px 20px}#ci-checkin-v3 .ci-toggle-label{font-size:14px;font-weight:600;color:var(--ci-gray-500);transition:color .2s;cursor:pointer;user-select:none}#ci-checkin-v3 .ci-toggle-label.active{color:var(--ci-teal-deeper)}#ci-checkin-v3 .ci-toggle-track{width:56px;height:30px;background:var(--ci-teal);border-radius:15px;position:relative;cursor:pointer;transition:background .3s;flex-shrink:0;box-shadow:inset 0 1px 3px rgba(0,0,0,.15)}#ci-checkin-v3 .ci-toggle-thumb{width:24px;height:24px;background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 4px rgba(0,0,0,.15)}#ci-checkin-v3 .ci-toggle-track.house .ci-toggle-thumb{transform:translateX(26px)}#ci-checkin-v3 .ci-pricing-table-wrap{padding:0 20px 12px;overflow-x:auto}#ci-checkin-v3 .ci-pricing-table{width:100%;border-collapse:separate;border-spacing:0;border-radius:var(--ci-radius-lg);overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.06),0 4px 16px rgba(13,148,136,.08)}#ci-checkin-v3 .ci-pricing-table thead th{background:linear-gradient(135deg,var(--ci-teal-deeper),var(--ci-teal));color:#fff;padding:16px 12px;font-size:13px;font-weight:700;text-align:center;text-transform:uppercase;letter-spacing:.8px;border:none}#ci-checkin-v3 .ci-pricing-table thead th:first-child{text-align:left;padding-left:24px;width:160px}#ci-checkin-v3 .ci-pricing-table tbody tr{transition:all .15s;cursor:pointer}#ci-checkin-v3 .ci-pricing-table tbody tr:hover{background:var(--ci-teal-50)}#ci-checkin-v3 .ci-pricing-table tbody tr.selected{background:var(--ci-teal-100)}#ci-checkin-v3 .ci-pricing-table tbody td{padding:14px 12px;text-align:center;font-size:14px;color:var(--ci-gray-700);border-bottom:1px solid var(--ci-gray-100);transition:all .15s}#ci-checkin-v3 .ci-pricing-table tbody td:first-child{text-align:left;padding-left:24px;font-weight:600;color:var(--ci-gray-800)}#ci-checkin-v3 .ci-pricing-table tbody tr:last-child td{border-bottom:none}#ci-checkin-v3 .ci-pricing-table .ci-price-cell{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-weight:700;font-size:16px;color:var(--ci-teal-deeper)}#ci-checkin-v3 .ci-pricing-table .ci-price-cell span{font-size:12px;color:var(--ci-gray-400);font-weight:500;font-family:'DM Sans',sans-serif}#ci-checkin-v3 .ci-row-book{display:inline-flex;align-items:center;gap:5px;padding:7px 16px;background:var(--ci-teal);color:#fff;border:none;border-radius:6px;font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}#ci-checkin-v3 .ci-row-book:hover{background:var(--ci-teal-dark);transform:translateY(-1px);box-shadow:0 2px 8px rgba(13,148,136,.3)}#ci-checkin-v3 .ci-row-book svg{width:13px;height:13px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}#ci-checkin-v3 .ci-pricing-table tbody tr.selected .ci-row-book{background:var(--ci-teal-deeper)}#ci-checkin-v3 .ci-pricing-table tbody tr.selected td:first-child{position:relative}#ci-checkin-v3 .ci-pricing-table tbody tr.selected td:first-child::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--ci-teal)}#ci-checkin-v3 .ci-callout{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;margin:16px 20px 0;background:var(--ci-teal-50);border:1.5px solid var(--ci-teal-light);border-radius:var(--ci-radius);font-size:13.5px;color:var(--ci-teal-dark)}#ci-checkin-v3 .ci-callout svg{width:18px;height:18px;stroke:var(--ci-teal);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}#ci-checkin-v3 .ci-callout a{color:var(--ci-teal-dark);font-weight:700;text-decoration:underline;text-underline-offset:2px}#ci-checkin-v3 .ci-form-widget{max-width:560px;margin:32px auto 0;background:var(--ci-white);border-radius:var(--ci-radius-lg);box-shadow:0 4px 24px rgba(13,148,136,.1),0 1px 3px rgba(0,0,0,.06);overflow:hidden}#ci-checkin-v3 .ci-fw-header{background:linear-gradient(135deg,var(--ci-teal-deeper),var(--ci-teal) 60%,#14B8A6);padding:20px 28px;color:#fff;position:relative;overflow:hidden}#ci-checkin-v3 .ci-fw-header::before{content:'';position:absolute;top:-30px;right:-30px;width:100px;height:100px;background:rgba(255,255,255,.06);border-radius:50%}#ci-checkin-v3 .ci-fw-header-row{display:flex;align-items:center;gap:12px;position:relative;z-index:1}#ci-checkin-v3 .ci-fw-icon{width:40px;height:40px;background:rgba(255,255,255,.15);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}#ci-checkin-v3 .ci-fw-icon svg{width:22px;height:22px;stroke:#fff;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}#ci-checkin-v3 .ci-fw-header h3{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:18px;font-weight:800;letter-spacing:-.2px}#ci-checkin-v3 .ci-fw-header p{font-size:13px;opacity:.85}#ci-checkin-v3 .ci-fw-header .ci-fw-selection{font-size:13px;opacity:.9;margin-top:4px;font-weight:500}#ci-checkin-v3 .ci-fw-body{padding:24px 28px 28px}#ci-checkin-v3 .ci-label{font-size:13px;font-weight:600;color:var(--ci-gray-700);margin-bottom:8px;display:flex;align-items:center;gap:6px}#ci-checkin-v3 .ci-step{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--ci-teal);color:#fff;font-size:11px;font-weight:700;flex-shrink:0}#ci-checkin-v3 .ci-rooms-section{margin-bottom:20px}#ci-checkin-v3 .ci-rooms-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--ci-gray-50);border:1.5px solid var(--ci-gray-200);border-radius:8px;margin-bottom:8px}#ci-checkin-v3 .ci-rooms-row-label{font-size:14px;font-weight:500;color:var(--ci-gray-700)}#ci-checkin-v3 .ci-counter{display:flex;align-items:center;gap:8px}#ci-checkin-v3 .ci-counter-btn{width:30px;height:30px;border-radius:6px;border:1.5px solid var(--ci-gray-300);background:var(--ci-white);font-size:16px;font-weight:600;color:var(--ci-gray-600);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}#ci-checkin-v3 .ci-counter-btn:hover{border-color:var(--ci-teal);color:var(--ci-teal)}#ci-checkin-v3 .ci-counter-val{width:30px;text-align:center;font-size:15px;font-weight:700;color:var(--ci-gray-800)}#ci-checkin-v3 .ci-rooms-hint{font-size:12px;color:var(--ci-gray-500);line-height:1.5;padding:4px 4px 0}#ci-checkin-v3 .ci-rooms-hint svg{width:13px;height:13px;stroke:var(--ci-gray-400);fill:none;stroke-width:2;vertical-align:-2px;margin-right:3px;stroke-linecap:round;stroke-linejoin:round}#ci-checkin-v3 .ci-furnished-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--ci-gray-50);border:1.5px solid var(--ci-gray-200);border-radius:8px;cursor:pointer;transition:all .2s;margin-bottom:8px}#ci-checkin-v3 .ci-furnished-row:hover{border-color:var(--ci-teal);background:var(--ci-teal-50)}#ci-checkin-v3 .ci-furnished-row.active{border-color:var(--ci-teal);background:var(--ci-teal-100)}#ci-checkin-v3 .ci-furnished-left{display:flex;align-items:center;gap:10px}#ci-checkin-v3 .ci-chk{width:20px;height:20px;border-radius:5px;border:2px solid var(--ci-gray-300);display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}#ci-checkin-v3 .ci-furnished-row.active .ci-chk{background:var(--ci-teal);border-color:var(--ci-teal)}#ci-checkin-v3 .ci-chk svg{width:12px;height:12px;stroke:#fff;fill:none;stroke-width:2.5;opacity:0;transition:opacity .2s}#ci-checkin-v3 .ci-furnished-row.active .ci-chk svg{opacity:1}#ci-checkin-v3 .ci-furnished-price{font-size:13px;font-weight:600;color:var(--ci-teal-dark)}#ci-checkin-v3 .ci-cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}#ci-checkin-v3 .ci-cal-nav button{width:34px;height:34px;border-radius:8px;border:1.5px solid var(--ci-gray-200);background:var(--ci-white);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}#ci-checkin-v3 .ci-cal-nav button:hover{border-color:var(--ci-teal);background:var(--ci-teal-50)}#ci-checkin-v3 .ci-cal-nav button svg{width:16px;height:16px;stroke:var(--ci-gray-600);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}#ci-checkin-v3 .ci-cal-title{font-size:15px;font-weight:700;color:var(--ci-gray-800)}#ci-checkin-v3 .ci-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}#ci-checkin-v3 .ci-cal-dow{text-align:center;font-size:11px;font-weight:600;color:var(--ci-gray-400);padding:4px 0 8px;text-transform:uppercase;letter-spacing:.5px}#ci-checkin-v3 .ci-cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;border-radius:8px;cursor:pointer;transition:all .15s;border:1.5px solid transparent;color:var(--ci-gray-700)}#ci-checkin-v3 .ci-cal-day:hover:not(.disabled):not(.empty){background:var(--ci-teal-50);border-color:var(--ci-teal)}#ci-checkin-v3 .ci-cal-day.selected{background:var(--ci-teal)!important;color:#fff!important;border-color:var(--ci-teal-dark)!important;font-weight:700;box-shadow:0 2px 8px rgba(13,148,136,.35)}#ci-checkin-v3 .ci-cal-day.disabled{color:var(--ci-gray-300);cursor:not-allowed}#ci-checkin-v3 .ci-cal-day.empty{cursor:default}#ci-checkin-v3 .ci-cal-day.premium{background:var(--ci-amber-bg);border:1.5px dashed var(--ci-amber);color:var(--ci-gold);font-weight:600}#ci-checkin-v3 .ci-cal-day.premium:hover:not(.disabled){background:var(--ci-amber-light);border-color:var(--ci-gold)}#ci-checkin-v3 .ci-cal-day.premium.selected{background:var(--ci-amber)!important;color:#fff!important;border-style:solid!important;border-color:var(--ci-gold)!important}#ci-checkin-v3 .ci-cal-day.today:not(.selected){border-color:var(--ci-teal);font-weight:700}#ci-checkin-v3 .ci-cal-legend{display:flex;gap:16px;padding-top:8px;border-top:1px solid var(--ci-gray-100)}#ci-checkin-v3 .ci-cal-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--ci-gray-500)}#ci-checkin-v3 .ci-cal-legend-dot{width:14px;height:14px;border-radius:4px;flex-shrink:0}#ci-checkin-v3 .ci-cal-legend-dot.avail{background:var(--ci-teal-50);border:1.5px solid var(--ci-teal)}#ci-checkin-v3 .ci-cal-legend-dot.prem{background:var(--ci-amber-bg);border:1.5px dashed var(--ci-amber)}#ci-checkin-v3 .ci-notice{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;border-radius:8px;font-size:12.5px;line-height:1.5;margin-bottom:16px}#ci-checkin-v3 .ci-notice.amber{background:var(--ci-amber-bg);border:1px solid var(--ci-amber-light);color:var(--ci-gold)}#ci-checkin-v3 .ci-notice.teal{background:var(--ci-teal-50);border:1px solid var(--ci-teal-light);color:var(--ci-teal-dark)}#ci-checkin-v3 .ci-notice svg{width:16px;height:16px;flex-shrink:0;margin-top:1px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}#ci-checkin-v3 .ci-input-group{margin-bottom:16px}#ci-checkin-v3 .ci-input{width:100%;padding:11px 14px;border:1.5px solid var(--ci-gray-200);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ci-gray-800);background:var(--ci-white);transition:border-color .2s,box-shadow .2s}#ci-checkin-v3 .ci-input::placeholder{color:var(--ci-gray-400)}#ci-checkin-v3 .ci-input:focus{outline:none;border-color:var(--ci-teal);box-shadow:0 0 0 3px rgba(13,148,136,.1)}#ci-checkin-v3 .ci-input-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}#ci-checkin-v3 .ci-select{width:100%;padding:11px 14px;border:1.5px solid var(--ci-gray-200);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ci-gray-800);background:var(--ci-white);cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}#ci-checkin-v3 .ci-select:focus{outline:none;border-color:var(--ci-teal);box-shadow:0 0 0 3px rgba(13,148,136,.1)}#ci-checkin-v3 .ci-textarea{width:100%;padding:11px 14px;border:1.5px solid var(--ci-gray-200);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ci-gray-800);resize:vertical;min-height:70px;transition:border-color .2s,box-shadow .2s}#ci-checkin-v3 .ci-textarea:focus{outline:none;border-color:var(--ci-teal);box-shadow:0 0 0 3px rgba(13,148,136,.1)}#ci-checkin-v3 .ci-promo-row{display:flex;gap:8px;margin-bottom:20px}#ci-checkin-v3 .ci-promo-row .ci-input{flex:1}#ci-checkin-v3 .ci-promo-btn{padding:11px 18px;background:var(--ci-gray-100);border:1.5px solid var(--ci-gray-200);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;color:var(--ci-gray-600);cursor:pointer;white-space:nowrap;transition:all .2s}#ci-checkin-v3 .ci-promo-btn:hover{background:var(--ci-teal-50);border-color:var(--ci-teal);color:var(--ci-teal-dark)}#ci-checkin-v3 .ci-promo-msg{font-size:12px;margin-top:6px;font-weight:500}#ci-checkin-v3 .ci-promo-msg.success{color:var(--ci-green)}#ci-checkin-v3 .ci-promo-msg.error{color:var(--ci-red)}#ci-checkin-v3 .ci-breakdown{background:var(--ci-gray-50);border:1.5px solid var(--ci-gray-200);border-radius:var(--ci-radius);padding:16px;margin-bottom:20px}#ci-checkin-v3 .ci-bk-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:13.5px;color:var(--ci-gray-600)}#ci-checkin-v3 .ci-bk-row.fee{color:var(--ci-amber)}#ci-checkin-v3 .ci-bk-row.discount{color:var(--ci-green)}#ci-checkin-v3 .ci-bk-divider{height:1px;background:var(--ci-gray-200);margin:8px 0}#ci-checkin-v3 .ci-bk-total{display:flex;justify-content:space-between;align-items:center;padding:6px 0 0;font-size:16px;font-weight:700;color:var(--ci-gray-900)}#ci-checkin-v3 .ci-bk-total span:last-child{color:var(--ci-teal-dark);font-size:20px}#ci-checkin-v3 .ci-pay-btn{width:100%;padding:15px;background:linear-gradient(135deg,var(--ci-teal-dark),var(--ci-teal));color:#fff;border:none;border-radius:var(--ci-radius);font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px rgba(13,148,136,.3);display:flex;align-items:center;justify-content:center;gap:8px}#ci-checkin-v3 .ci-pay-btn:hover{background:linear-gradient(135deg,var(--ci-teal-deeper),var(--ci-teal-dark));transform:translateY(-1px)}#ci-checkin-v3 .ci-pay-btn:disabled{background:var(--ci-gray-300);cursor:not-allowed;box-shadow:none;transform:none}#ci-checkin-v3 .ci-pay-btn svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}#ci-checkin-v3 .ci-reserve-btn{width:100%;padding:14px;background:var(--ci-white);color:var(--ci-teal-dark);border:2px solid var(--ci-teal);border-radius:var(--ci-radius);font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:10px}#ci-checkin-v3 .ci-reserve-btn:hover{background:var(--ci-teal-50);transform:translateY(-1px)}#ci-checkin-v3 .ci-reserve-btn:disabled{color:var(--ci-gray-300);border-color:var(--ci-gray-300);cursor:not-allowed;transform:none}#ci-checkin-v3 .ci-reserve-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}#ci-checkin-v3 .ci-footer{text-align:center;padding:14px 28px;background:var(--ci-gray-50);border-top:1px solid var(--ci-gray-100)}#ci-checkin-v3 .ci-footer p{font-size:11px;color:var(--ci-gray-400)}#ci-checkin-v3 .ci-footer a{color:var(--ci-teal);text-decoration:none}@media(max-width:640px){#ci-checkin-v3 .ci-pricing-table thead th{font-size:11px;padding:12px 6px}#ci-checkin-v3 .ci-pricing-table tbody td{padding:10px 6px;font-size:13px}#ci-checkin-v3 .ci-pricing-table .ci-price-cell{font-size:14px}#ci-checkin-v3 .ci-pricing-table tbody td:first-child{padding-left:12px}#ci-checkin-v3 .ci-pricing-table thead th:first-child{padding-left:12px;width:auto}#ci-checkin-v3 .ci-row-book{padding:6px 10px;font-size:11.5px}#ci-checkin-v3 .ci-fw-body{padding:18px 18px 22px}#ci-checkin-v3 .ci-fw-header{padding:16px 18px}#ci-checkin-v3 .ci-input-row{grid-template-columns:1fr}#ci-checkin-v3 .ci-page-head h1{font-size:24px}}</style><div id="ci-checkin-v3"><div class="ci-page-head"><h1>Check-In Reports</h1><p>Professional check-in inventory reports across London. Select your property size to book instantly.</p><div style="display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:8px 18px;background:var(--ci-teal-50);border:1.5px solid var(--ci-teal-light);border-radius:20px;"><svg style="width:16px;height:16px;stroke:var(--ci-teal);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;" viewBox="0 0 24 24"><polyline points="20 6 9 17 4 12"/></svg><span style="font-size:13.5px;font-weight:700;color:var(--ci-teal-dark);">All prices inclusive of VAT — no hidden fees</span></div></div><div class="ci-toggle-wrap"><span class="ci-toggle-label active" id="cv3-lbl-flat" onclick="cv3Toggle()">🏢 Flat</span><div class="ci-toggle-track" id="cv3-toggle" onclick="cv3Toggle()"><div class="ci-toggle-thumb"></div></div><span class="ci-toggle-label" id="cv3-lbl-house" onclick="cv3Toggle()">🏠 House</span></div><div class="ci-pricing-table-wrap"><table class="ci-pricing-table"><thead><tr><th>Property Size</th><th>Check-In Price</th><th></th></tr></thead><tbody id="cv3-tbody"></tbody></table></div><div class="ci-callout"><svg viewBox="0 0 24 24"><path d="M22 16.92v3a2 2 0 01-2.18 2 19.79 19.79 0 01-8.63-3.07 19.5 19.5 0 01-6-6 19.79 19.79 0 01-3.07-8.67A2 2 0 014.11 2h3a2 2 0 012 1.72c.13.81.36 1.6.68 2.35a2 2 0 01-.45 2.11L8.09 9.91a16 16 0 006 6l1.27-1.27a2 2 0 012.11-.45c.75.32 1.54.55 2.35.68A2 2 0 0122 16.92z"/></svg><span>Property larger than 5 bedrooms? Please <a href="tel:02034888072">call us on 020 3488 8072</a> or <a href="mailto:info@clickinventories.co.uk">email us</a> for a bespoke quote.</span></div><div class="ci-form-widget" id="cv3-form"><div class="ci-fw-header"><div class="ci-fw-header-row"><div class="ci-fw-icon"><svg viewBox="0 0 24 24"><path d="M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2"/><rect x="9" y="3" width="6" height="4" rx="1"/><path d="M9 14l2 2 4-4"/></svg></div><div><h3>Book Your Check-In</h3><p>Complete the details below</p><div class="ci-fw-selection" id="cv3-selection">Select a property size from the table above</div></div></div></div><div class="ci-fw-body"><div class="ci-label"><span class="ci-step">1</span> Additional Rooms &amp; Furnished</div><div class="ci-rooms-section"><div class="ci-furnished-row" id="cv3-furnished" onclick="cv3ToggleFurnished()"><div class="ci-furnished-left"><div class="ci-chk"><svg viewBox="0 0 24 24"><polyline points="20 6 9 17 4 12"/></svg></div><span style="font-size:13.5px;font-weight:500;color:var(--ci-gray-700);">Furnished property</span></div><span class="ci-furnished-price">+£10</span></div><div class="ci-rooms-row"><span class="ci-rooms-row-label">Extra bathrooms</span><div class="ci-counter"><button class="ci-counter-btn" onclick="cv3Rooms('bath',-1)">−</button><span class="ci-counter-val" id="cv3-bath-count">0</span><button class="ci-counter-btn" onclick="cv3Rooms('bath',1)">+</button></div></div><div class="ci-rooms-row"><span class="ci-rooms-row-label">Other rooms <span style="font-size:12px;color:var(--ci-gray-400);">(utility, garage, conservatory, etc.)</span></span><div class="ci-counter"><button class="ci-counter-btn" onclick="cv3Rooms('other',-1)">−</button><span class="ci-counter-val" id="cv3-other-count">0</span><button class="ci-counter-btn" onclick="cv3Rooms('other',1)">+</button></div></div><div class="ci-rooms-hint"><svg viewBox="0 0 24 24"><circle cx="12" cy="12" r="10"/><line x1="12" y1="16" x2="12" y2="12"/><line x1="12" y1="8" x2="12.01" y2="8"/></svg>Base price includes 1 bathroom, 1 kitchen &amp; 1 lounge. Additional rooms are £10 each.</div></div><div class="ci-label"><span class="ci-step">2</span> Select Date</div><div style="margin-bottom:20px;"><div class="ci-cal-nav"><button onclick="cv3CalNav(-1)"><svg viewBox="0 0 24 24"><polyline points="15 18 9 12 15 6"/></svg></button><span class="ci-cal-title" id="cv3-cal-title"></span><button onclick="cv3CalNav(1)"><svg viewBox="0 0 24 24"><polyline points="9 18 15 12 9 6"/></svg></button></div><div class="ci-cal-grid" id="cv3-cal-grid"></div><div class="ci-cal-legend"><div class="ci-cal-legend-item"><div class="ci-cal-legend-dot avail"></div>Available</div><div class="ci-cal-legend-item"><div class="ci-cal-legend-dot prem"></div>Sun / Bank Hol (+£50)</div></div></div><div class="ci-notice amber" id="cv3-premium-notice" style="display:none;"><svg viewBox="0 0 24 24"><circle cx="12" cy="12" r="10"/><line x1="12" y1="8" x2="12" y2="12"/><line x1="12" y1="16" x2="12.01" y2="16"/></svg><span>Sunday / Bank Holiday bookings include a <strong>£50 premium fee</strong>.</span></div><div class="ci-label"><span class="ci-step">3</span> Property &amp; Contact Details</div><div class="ci-input-group"><input type="text" class="ci-input" id="cv3-address" placeholder="Property address (first line) *" required /></div><div class="ci-input-group"><div class="ci-input-row"><input type="text" class="ci-input" id="cv3-postcode" placeholder="Postcode *" oninput="cv3CheckPostcode()" required /><select class="ci-select" id="cv3-time" onchange="cv3CheckPeak()" required><option value="">Select time slot *</option><option value="09:00-10:00" data-peak="true">9:00 – 10:00 AM ⭐ Peak (+£50)</option><option value="10:00-11:00">10:00 – 11:00 AM</option><option value="11:00-12:00">11:00 AM – 12:00 PM</option><option value="12:00-13:00">12:00 – 1:00 PM</option><option value="13:00-14:00">1:00 – 2:00 PM</option><option value="14:00-15:00">2:00 – 3:00 PM</option><option value="15:00-16:00">3:00 – 4:00 PM</option><option value="16:00-17:00">4:00 – 5:00 PM</option><option value="17:00-18:00">5:00 – 6:00 PM</option><option value="18:00-19:00">6:00 – 7:00 PM</option></select></div></div><div class="ci-notice amber" id="cv3-oof-notice" style="display:none;"><svg viewBox="0 0 24 24"><circle cx="12" cy="12" r="10"/><line x1="12" y1="8" x2="12" y2="12"/><line x1="12" y1="16" x2="12.01" y2="16"/></svg><span>Postcode outside standard London coverage. A <strong>£25 out-of-area fee</strong> has been added.</span></div><div class="ci-notice amber" id="cv3-peak-notice" style="display:none;"><svg viewBox="0 0 24 24"><circle cx="12" cy="12" r="10"/><line x1="12" y1="8" x2="12" y2="12"/><line x1="12" y1="16" x2="12.01" y2="16"/></svg><span>The <strong>9:00 AM</strong> slot is peak time — <strong>+£50 fee</strong> applied.</span></div><div class="ci-input-group"><div class="ci-input-row"><input type="text" class="ci-input" id="cv3-name" placeholder="Your full name *" required /><input type="tel" class="ci-input" id="cv3-phone" placeholder="Phone number *" required /></div></div><div class="ci-input-group"><input type="email" class="ci-input" id="cv3-email" placeholder="Email address *" required /></div><div class="ci-input-group"><textarea class="ci-textarea" id="cv3-notes" placeholder="Additional notes (key collection, access info, etc.)"></textarea></div><div class="ci-label"><span class="ci-step">4</span> Promo Code</div><div class="ci-promo-row"><input type="text" class="ci-input" id="cv3-promo" placeholder="Enter promo code" /><button class="ci-promo-btn" onclick="cv3ApplyPromo()">Apply</button></div><div class="ci-promo-msg" id="cv3-promo-msg"></div><div class="ci-notice teal" id="cv3-pay-benefit" style="display:none;"><svg viewBox="0 0 24 24"><path d="M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10z"/></svg><span><strong>Pay now &amp; save 10%</strong> — your report will be sent immediately on completion, no delays waiting on payment.</span></div><div class="ci-breakdown" id="cv3-breakdown" style="display:none;"></div><button class="ci-pay-btn" id="cv3-pay-btn" disabled onclick="cv3PayNow()"><svg viewBox="0 0 24 24"><rect x="1" y="4" width="22" height="16" rx="2" ry="2"/><line x1="1" y1="10" x2="23" y2="10"/></svg><span id="cv3-pay-label">Select property size to continue</span></button><button class="ci-reserve-btn" id="cv3-reserve-btn" disabled onclick="cv3Reserve()"><svg viewBox="0 0 24 24"><rect x="3" y="4" width="18" height="18" rx="2" ry="2"/><line x1="16" y1="2" x2="16" y2="6"/><line x1="8" y1="2" x2="8" y2="6"/><line x1="3" y1="10" x2="21" y2="10"/></svg><span id="cv3-reserve-label">Reserve without paying</span></button><div style="text-align:center;margin-top:8px;font-size:11.5px;color:var(--ci-gray-400);line-height:1.5;display:none;" id="cv3-reserve-note">Reserve now, pay later — your report will be held until payment is received.</div></div><div id="cv3-success" class="ci-confirmation-msg" style="display:none;background:#e8f5e9;border:2px solid #4caf50;border-radius:10px;padding:24px 20px;margin:18px 0 12px;text-align:center;"><div style="font-size:2em;margin-bottom:8px;">&#10004;</div><div style="font-size:1.15em;font-weight:700;color:#2e7d32;margin-bottom:6px;">Booking Confirmed!</div><div id="cv3-success-detail" style="font-size:0.97em;color:#333;">Your check-in report has been booked successfully. A confirmation email will be sent to you shortly.</div></div><div class="ci-footer"><p>Click Inventories Ltd &bull; <a href="mailto:info@clickinventories.co.uk">info@clickinventories.co.uk</a> &bull; London</p></div></div></div><script>(function(){'use strict';const FLAT_PRICES={checkin:[125,140,160,185,210,235]};const HOUSE_MULT=1.15;const BED_LABELS=['Studio','1 Bed','2 Bed','3 Bed','4 Bed','5 Bed'];const BANK_HOLIDAYS=['2025-01-01','2025-04-18','2025-04-21','2025-05-05','2025-05-26','2025-08-25','2025-12-25','2025-12-26','2026-01-01','2026-04-03','2026-04-06','2026-05-04','2026-05-25','2026-08-31','2026-12-25','2026-12-28','2027-01-01','2027-03-26','2027-03-29','2027-05-03','2027-05-31','2027-08-30','2027-12-27','2027-12-28'];const LONDON=['EC','WC','E','N','NW','SE','SW','W'];let S={isHouse:false,beds:null,furnished:false,extraBath:0,extraOther:0,selectedDate:null,calMonth:new Date().getMonth(),calYear:new Date().getFullYear(),promoApplied:false,promoDiscount:0,outOfArea:false,premiumDay:false,peakTime:false};function getPrice(service,beds){const base=FLAT_PRICES[service][beds];return(S.isHouse&&beds>=3)?Math.round(base*HOUSE_MULT):base;}function fmtPrice(p){return '\u00a3'+p;}window.cv3Toggle=function(){S.isHouse=!S.isHouse;document.getElementById('cv3-toggle').classList.toggle('house',S.isHouse);document.getElementById('cv3-lbl-flat').classList.toggle('active',!S.isHouse);document.getElementById('cv3-lbl-house').classList.toggle('active',S.isHouse);buildTable();updatePrice();};function buildTable(){const tbody=document.getElementById('cv3-tbody');tbody.innerHTML='';BED_LABELS.forEach((label,i)=>{const tr=document.createElement('tr');if(S.beds===i)tr.classList.add('selected');tr.innerHTML='<td>'+label+'</td><td class="ci-price-cell">'+fmtPrice(getPrice('checkin',i))+'</td><td><button class="ci-row-book" onclick="cv3SelectBed('+i+');event.stopPropagation();"><svg viewBox="0 0 24 24"><rect x="3" y="4" width="18" height="18" rx="2" ry="2"/><line x1="16" y1="2" x2="16" y2="6"/><line x1="8" y1="2" x2="8" y2="6"/><line x1="3" y1="10" x2="21" y2="10"/></svg>Book Now</button></td>';tr.addEventListener('click',()=>cv3SelectBed(i));tbody.appendChild(tr);});}window.cv3SelectBed=function(beds){S.beds=beds;buildTable();updateSelection();updatePrice();document.getElementById('cv3-form').scrollIntoView({behavior:'smooth',block:'start'});};function updateSelection(){const el=document.getElementById('cv3-selection');if(S.beds!==null){const type=S.isHouse?'House':'Flat';el.innerHTML='<strong>'+BED_LABELS[S.beds]+' '+type+'</strong> \u2014 Check-In from <strong>'+fmtPrice(getPrice('checkin',S.beds))+'</strong>';}else{el.textContent='Select a property size from the table above';}}window.cv3ToggleFurnished=function(){S.furnished=!S.furnished;document.getElementById('cv3-furnished').classList.toggle('active',S.furnished);updatePrice();};window.cv3Rooms=function(type,d){if(type==='bath'){S.extraBath=Math.max(0,Math.min(10,S.extraBath+d));document.getElementById('cv3-bath-count').textContent=S.extraBath;}else{S.extraOther=Math.max(0,Math.min(10,S.extraOther+d));document.getElementById('cv3-other-count').textContent=S.extraOther;}updatePrice();};function isPremium(y,m,d){const date=new Date(y,m,d);if(date.getDay()===0)return true;const ds=y+'-'+String(m+1).padStart(2,'0')+'-'+String(d).padStart(2,'0');return BANK_HOLIDAYS.includes(ds);}function renderCal(){const y=S.calYear,m=S.calMonth;document.getElementById('cv3-cal-title').textContent=new Date(y,m).toLocaleDateString('en-GB',{month:'long',year:'numeric'});const grid=document.getElementById('cv3-cal-grid');grid.innerHTML='';['Mon','Tue','Wed','Thu','Fri','Sat','Sun'].forEach(d=>{const el=document.createElement('div');el.className='ci-cal-dow';el.textContent=d;grid.appendChild(el);});let startDay=new Date(y,m,1).getDay()-1;if(startDay<0)startDay=6;for(let i=0;i<startDay;i++){const el=document.createElement('div');el.className='ci-cal-day empty';grid.appendChild(el);}const today=new Date();today.setHours(0,0,0,0);const days=new Date(y,m+1,0).getDate();for(let d=1;d<=days;d++){const el=document.createElement('div');el.className='ci-cal-day';el.textContent=d;const dt=new Date(y,m,d);dt.setHours(0,0,0,0);if(dt<today){el.classList.add('disabled');}else{if(isPremium(y,m,d))el.classList.add('premium');if(dt.getTime()===today.getTime())el.classList.add('today');if(S.selectedDate&&S.selectedDate.getTime()===dt.getTime())el.classList.add('selected');el.addEventListener('click',()=>{S.selectedDate=new Date(y,m,d);S.premiumDay=isPremium(y,m,d);document.getElementById('cv3-premium-notice').style.display=S.premiumDay?'flex':'none';renderCal();updatePrice();});}grid.appendChild(el);}}window.cv3CalNav=function(dir){S.calMonth+=dir;if(S.calMonth>11){S.calMonth=0;S.calYear++;}if(S.calMonth<0){S.calMonth=11;S.calYear--;}renderCal();};window.cv3CheckPostcode=function(){const pc=document.getElementById('cv3-postcode').value.trim().toUpperCase().replace(/\s+/g,'');if(pc.length<2){S.outOfArea=false;document.getElementById('cv3-oof-notice').style.display='none';updatePrice();return;}const match=LONDON.some(p=>pc.startsWith(p)&&pc.slice(p.length).length>0&&/^\d/.test(pc.slice(p.length)));S.outOfArea=!match;document.getElementById('cv3-oof-notice').style.display=S.outOfArea?'flex':'none';updatePrice();};window.cv3CheckPeak=function(){const sel=document.getElementById('cv3-time');const opt=sel.options[sel.selectedIndex];S.peakTime=(opt&&opt.dataset.peak==='true');document.getElementById('cv3-peak-notice').style.display=S.peakTime?'flex':'none';updatePrice();};window.cv3ApplyPromo=function(){const code=document.getElementById('cv3-promo').value.trim().toUpperCase();const msg=document.getElementById('cv3-promo-msg');if(code==='CLICKSERVICES2026'){S.promoApplied=true;S.promoDiscount=10;msg.textContent='\u2713 CLICKSERVICES2026 applied \u2014 10% off!';msg.className='ci-promo-msg success';}else{S.promoApplied=false;S.promoDiscount=0;msg.textContent='\u2717 Invalid promo code.';msg.className='ci-promo-msg error';}updatePrice();};function updatePrice(){const bb=document.getElementById('cv3-breakdown');const payBtn=document.getElementById('cv3-pay-btn');const resBtn=document.getElementById('cv3-reserve-btn');const payLbl=document.getElementById('cv3-pay-label');const resLbl=document.getElementById('cv3-reserve-label');const benefit=document.getElementById('cv3-pay-benefit');const resNote=document.getElementById('cv3-reserve-note');if(S.beds===null){bb.style.display='none';payBtn.disabled=true;resBtn.disabled=true;payLbl.textContent='Select property size to continue';resLbl.textContent='Reserve without paying';benefit.style.display='none';resNote.style.display='none';return;}const base=getPrice('checkin',S.beds);const label=BED_LABELS[S.beds];const type=S.isHouse?'House':'Flat';let rows=[],sub=base;rows.push({l:'Check-In \u2014 '+label+' '+type,a:base});if(S.furnished){rows.push({l:'Furnished property',a:10});sub+=10;}if(S.extraBath>0){const e=S.extraBath*10;rows.push({l:'Extra bathrooms \u00d7 '+S.extraBath,a:e});sub+=e;}if(S.extraOther>0){const e=S.extraOther*10;rows.push({l:'Other rooms \u00d7 '+S.extraOther,a:e});sub+=e;}if(S.premiumDay){rows.push({l:'Sunday / Bank Holiday fee',a:50,t:'fee'});sub+=50;}if(S.peakTime){rows.push({l:'Peak time fee (9:00 AM)',a:50,t:'fee'});sub+=50;}if(S.outOfArea){rows.push({l:'Out of area fee',a:25,t:'fee'});sub+=25;}let disc=0;if(S.promoApplied){disc=Math.round(sub*S.promoDiscount/100);rows.push({l:'Promo ('+S.promoDiscount+'% off)',a:-disc,t:'discount'});}const total=sub-disc;let html='';rows.forEach((r,i)=>{const cls=r.t?'ci-bk-row '+r.t:'ci-bk-row';html+='<div class="'+cls+'"><span>'+r.l+'</span><span>'+(i===0?'':(r.a<0?'\u2212':'+'))+'\u00a3'+Math.abs(r.a)+'</span></div>';});html+='<div class="ci-bk-divider"></div>';html+='<div class="ci-bk-total"><span>Total</span><span>\u00a3'+total+'</span></div>';bb.innerHTML=html;bb.style.display='block';const ready=S.selectedDate!==null;payBtn.disabled=!ready;resBtn.disabled=!ready;payLbl.textContent=ready?'Pay \u00a3'+total+' Now \u2014 Save 10%':'Select a date to continue';resLbl.textContent=ready?'Reserve \u2014 \u00a3'+total+' (pay later)':'Reserve without paying';benefit.style.display='flex';resNote.style.display=ready?'block':'none';}function validate(){const fields=['cv3-address','cv3-postcode','cv3-name','cv3-phone','cv3-email'];const vals=fields.map(id=>document.getElementById(id).value.trim());const time=document.getElementById('cv3-time').value;if(vals.some(v=>!v)||!time){alert('Please complete all required fields (address, postcode, time slot, name, email, phone).');return false;}if(!/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(vals[4])){alert('Please enter a valid email address.');return false;}return true;}function buildPayload(type){const base=getPrice('checkin',S.beds);let sub=base;if(S.furnished)sub+=10;sub+=(S.extraBath+S.extraOther)*10;if(S.premiumDay)sub+=50;if(S.peakTime)sub+=50;if(S.outOfArea)sub+=25;const disc=(type==='pay_now'&&S.promoApplied)?Math.round(sub*S.promoDiscount/100):0;return{paymentType:type,service:'checkin',serviceName:'Check-In Report',propertyType:S.isHouse?'house':'flat',bedrooms:S.beds,bedroomLabel:BED_LABELS[S.beds],basePrice:base,furnished:S.furnished,extraBathrooms:S.extraBath,extraOtherRooms:S.extraOther,totalExtraRooms:S.extraBath+S.extraOther,date:S.selectedDate.toLocaleDateString('en-GB',{weekday:'long',day:'numeric',month:'long',year:'numeric'}),dateISO:S.selectedDate.toISOString().split('T')[0],premiumDay:S.premiumDay,premiumFee:S.premiumDay?50:0,peakTime:S.peakTime,peakTimeFee:S.peakTime?50:0,outOfArea:S.outOfArea,outOfAreaFee:S.outOfArea?25:0,promoCode:(type==='pay_now'&&S.promoApplied)?'CLICKSERVICES2026':null,promoDiscount:disc,subtotal:sub,total:sub-disc,currency:'GBP',address:document.getElementById('cv3-address').value.trim(),postcode:document.getElementById('cv3-postcode').value.trim().toUpperCase(),timePreference:document.getElementById('cv3-time').value,customerName:document.getElementById('cv3-name').value.trim(),customerPhone:document.getElementById('cv3-phone').value.trim(),customerEmail:document.getElementById('cv3-email').value.trim(),notes:document.getElementById('cv3-notes').value.trim(),bookedAt:new Date().toISOString()};}window.cv3PayNow=function(){if(S.beds===null||!S.selectedDate)return;if(!validate())return;const p=buildPayload('pay_now');console.log('=== CLICK INVENTORIES CHECK-IN PAYMENT ===',JSON.stringify(p,null,2));payNow(p);};window.cv3Reserve=function(){if(S.beds===null||!S.selectedDate)return;if(!validate())return;const p=buildPayload('reserve');console.log('=== CLICK INVENTORIES CHECK-IN RESERVATION ===',JSON.stringify(p,null,2));payNow(p);};window.payNow=window.payNow||function(p){var fd=new FormData();fd.append('action','ci_checkin_booking');if(typeof ciCheckinAjax!=='undefined')fd.append('nonce',ciCheckinAjax.nonce);Object.keys(p).forEach(function(k){fd.append(k,p[k]);});var ajaxUrl=(typeof ciCheckinAjax!=='undefined')?ciCheckinAjax.url:'/wp-admin/admin-ajax.php';fetch(ajaxUrl,{method:'POST',body:fd}).then(function(r){return r.json();}).then(function(d){console.log('Booking email:',d);var cv3s=document.getElementById('cv3-success');if(cv3s){cv3s.style.display='block';cv3s.scrollIntoView({behavior:'smooth',block:'center'});}}).catch(function(e){console.log('Email error:',e);});alert((p.paymentType==='pay_now'?'\ud83d\udcb3 PAYING NOW':'\ud83d\udcc5 RESERVATION')+'\n\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\n'+p.serviceName+' \u2014 '+p.bedroomLabel+' '+p.propertyType+'\n'+p.address+', '+p.postcode+'\n'+p.date+' \u00b7 '+p.timePreference+'\n'+(p.premiumDay?'\u26a1 Premium day \u00b7 ':'')+(p.peakTime?'\u26a1 Peak time \u00b7 ':'')+(p.promoCode?'\ud83c\udff7 '+p.promoCode+' ':'')+'\n\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\nTotal: \u00a3'+p.total+'\n'+(p.paymentType==='reserve'?'\u26a0 Report held until payment':'\u2713 Report sent on completion')+'\n\n'+p.customerName+' \u00b7 '+p.customerEmail);};buildTable();renderCal();updatePrice();})();</script>[/vc_raw_html][/vc_column][/vc_row][vc_row][vc_column][vc_column_text]…

Book Now →
inventory and check-out report

Click Inventories: Inventory & Check-out

[vc_row][vc_column][vc_raw_html]<style>
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Plus+Jakarta+Sans:wght@600;700;800&display=swap');
:root{--ci-teal:#0D9488;--ci-teal-dark:#0F766E;--ci-teal-deeper:#115E59;--ci-teal-light:#CCFBF1;--ci-teal-50:#F0FDFA;--ci-teal-100:#E6FAF5;--ci-amber:#D97706;--ci-amber-light:#FEF3C7;--ci-amber-bg:#FFFBEB;--ci-gold:#B45309;--ci-green:#059669;--ci-green-light:#D1FAE5;--ci-red:#DC2626;--ci-white:#FFFFFF;--ci-gray-50:#F9FAFB;--ci-gray-100:#F3F4F6;--ci-gray-200:#E5E7EB;--ci-gray-300:#D1D5DB;--ci-gray-400:#9CA3AF;--ci-gray-500:#6B7280;--ci-gray-600:#4B5563;--ci-gray-700:#374151;--ci-gray-800:#1F2937;--ci-gray-900:#111827;--ci-radius:10px;--ci-radius-lg:14px}
#ci-checkout-v3 *{margin:0;padding:0;box-sizing:border-box}
#ci-checkout-v3{font-family:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;max-width:940px;margin:0 auto;color:var(--ci-gray-800);line-height:1.5}
#ci-checkout-v3 .ci-page-head{text-align:center;padding:32px 20px 8px}
#ci-checkout-v3 .ci-page-head h1{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:30px;font-weight:800;color:var(--ci-teal-deeper);letter-spacing:-0.5px;margin-bottom:8px}
#ci-checkout-v3 .ci-page-head p{font-size:15px;color:var(--ci-gray-500);max-width:620px;margin:0 auto}
#ci-checkout-v3 .ci-toggle-wrap{display:flex;align-items:center;justify-content:center;gap:14px;padding:24px 20px 20px}
#ci-checkout-v3 .ci-toggle-label{font-size:14px;font-weight:600;color:var(--ci-gray-500);transition:color 0.2s;cursor:pointer;user-select:none}
#ci-checkout-v3 .ci-toggle-label.active{color:var(--ci-teal-deeper)}
#ci-checkout-v3 .ci-toggle-track{width:56px;height:30px;background:var(--ci-teal);border-radius:15px;position:relative;cursor:pointer;transition:background 0.3s;flex-shrink:0;box-shadow:inset 0 1px 3px rgba(0,0,0,0.15)}
#ci-checkout-v3 .ci-toggle-thumb{width:24px;height:24px;background:white;border-radius:50%;position:absolute;top:3px;left:3px;transition:transform 0.3s cubic-bezier(0.4,0,0.2,1);box-shadow:0 1px 4px rgba(0,0,0,0.15)}
#ci-checkout-v3 .ci-toggle-track.house .ci-toggle-thumb{transform:translateX(26px)}
#ci-checkout-v3 .ci-pricing-table-wrap{padding:0 20px 12px;overflow-x:auto}
#ci-checkout-v3 .ci-pricing-table{width:100%;border-collapse:separate;border-spacing:0;border-radius:var(--ci-radius-lg);overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,0.06),0 4px 16px rgba(13,148,136,0.08)}
#ci-checkout-v3 .ci-pricing-table thead th{background:linear-gradient(135deg,var(--ci-teal-deeper) 0%,var(--ci-teal) 100%);color:white;padding:16px 12px;font-size:13px;font-weight:700;text-align:center;text-transform:uppercase;letter-spacing:0.8px;border:none}
#ci-checkout-v3 .ci-pricing-table thead th:first-child{text-align:left;padding-left:24px;width:160px}
#ci-checkout-v3 .ci-pricing-table tbody tr{transition:all 0.15s;cursor:pointer}
#ci-checkout-v3 .ci-pricing-table tbody tr:hover{background:var(--ci-teal-50)}
#ci-checkout-v3 .ci-pricing-table tbody tr.selected{background:var(--ci-teal-100)}
#ci-checkout-v3 .ci-pricing-table tbody td{padding:14px 12px;text-align:center;font-size:14px;color:var(--ci-gray-700);border-bottom:1px solid var(--ci-gray-100);transition:all 0.15s}
#ci-checkout-v3 .ci-pricing-table tbody td:first-child{text-align:left;padding-left:24px;font-weight:600;color:var(--ci-gray-800)}
#ci-checkout-v3 .ci-pricing-table tbody tr:last-child td{border-bottom:none}
#ci-checkout-v3 .ci-pricing-table .ci-price-cell{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-weight:700;font-size:16px;color:var(--ci-teal-deeper)}
#ci-checkout-v3 .ci-pricing-table .ci-price-cell span{font-size:12px;color:var(--ci-gray-400);font-weight:500;font-family:'DM Sans',sans-serif}
#ci-checkout-v3 .ci-row-book{display:inline-flex;align-items:center;gap:5px;padding:7px 16px;background:var(--ci-teal);color:white;border:none;border-radius:6px;font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:600;cursor:pointer;transition:all 0.2s;white-space:nowrap}
#ci-checkout-v3 .ci-row-book:hover{background:var(--ci-teal-dark);transform:translateY(-1px);box-shadow:0 2px 8px rgba(13,148,136,0.3)}
#ci-checkout-v3 .ci-row-book svg{width:13px;height:13px;stroke:white;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
#ci-checkout-v3 .ci-pricing-table tbody tr.selected .ci-row-book{background:var(--ci-teal-deeper)}
#ci-checkout-v3 .ci-pricing-table tbody tr.selected td:first-child{position:relative}
#ci-checkout-v3 .ci-pricing-table tbody tr.selected td:first-child::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--ci-teal)}
#ci-checkout-v3 .ci-callout{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;margin:16px 20px 0;background:var(--ci-teal-50);border:1.5px solid var(--ci-teal-light);border-radius:var(--ci-radius);font-size:13.5px;color:var(--ci-teal-dark)}
#ci-checkout-v3 .ci-callout svg{width:18px;height:18px;stroke:var(--ci-teal);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
#ci-checkout-v3 .ci-callout a{color:var(--ci-teal-dark);font-weight:700;text-decoration:underline;text-underline-offset:2px}
#ci-checkout-v3 .ci-form-widget{max-width:560px;margin:32px auto 0;background:var(--ci-white);border-radius:var(--ci-radius-lg);box-shadow:0 4px 24px rgba(13,148,136,0.10),0 1px 3px rgba(0,0,0,0.06);overflow:hidden}
#ci-checkout-v3 .ci-fw-header{background:linear-gradient(135deg,var(--ci-teal-deeper) 0%,var(--ci-teal) 60%,#14B8A6 100%);padding:20px 28px;color:white;position:relative;overflow:hidden}
#ci-checkout-v3 .ci-fw-header::before{content:'';position:absolute;top:-30px;right:-30px;width:100px;height:100px;background:rgba(255,255,255,0.06);border-radius:50%}
#ci-checkout-v3 .ci-fw-header-row{display:flex;align-items:center;gap:12px;position:relative;z-index:1}
#ci-checkout-v3 .ci-fw-icon{width:40px;height:40px;background:rgba(255,255,255,0.15);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
#ci-checkout-v3 .ci-fw-icon svg{width:22px;height:22px;stroke:white;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
#ci-checkout-v3 .ci-fw-header h3{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:18px;font-weight:800;letter-spacing:-0.2px}
#ci-checkout-v3 .ci-fw-header p{font-size:13px;opacity:0.85}
#ci-checkout-v3 .ci-fw-header .ci-fw-selection{font-size:13px;opacity:0.9;margin-top:4px;font-weight:500}
#ci-checkout-v3 .ci-fw-body{padding:24px 28px 28px}
#ci-checkout-v3 .ci-label{font-size:13px;font-weight:600;color:var(--ci-gray-700);margin-bottom:8px;display:flex;align-items:center;gap:6px}
#ci-checkout-v3 .ci-step{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--ci-teal);color:white;font-size:11px;font-weight:700;flex-shrink:0}
#ci-checkout-v3 .ci-rooms-section{margin-bottom:20px}
#ci-checkout-v3 .ci-rooms-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--ci-gray-50);border:1.5px solid var(--ci-gray-200);border-radius:8px;margin-bottom:8px}
#ci-checkout-v3 .ci-rooms-row-label{font-size:14px;font-weight:500;color:var(--ci-gray-700)}
#ci-checkout-v3 .ci-counter{display:flex;align-items:center;gap:8px}
#ci-checkout-v3 .ci-counter-btn{width:30px;height:30px;border-radius:6px;border:1.5px solid var(--ci-gray-300);background:var(--ci-white);font-size:16px;font-weight:600;color:var(--ci-gray-600);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s}
#ci-checkout-v3 .ci-counter-btn:hover{border-color:var(--ci-teal);color:var(--ci-teal)}
#ci-checkout-v3 .ci-counter-val{width:30px;text-align:center;font-size:15px;font-weight:700;color:var(--ci-gray-800)}
#ci-checkout-v3 .ci-rooms-hint{font-size:12px;color:var(--ci-gray-500);line-height:1.5;padding:4px 4px 0}
#ci-checkout-v3 .ci-rooms-hint svg{width:13px;height:13px;stroke:var(--ci-gray-400);fill:none;stroke-width:2;vertical-align:-2px;margin-right:3px;stroke-linecap:round;stroke-linejoin:round}
#ci-checkout-v3 .ci-furnished-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--ci-gray-50);border:1.5px solid var(--ci-gray-200);border-radius:8px;cursor:pointer;transition:all 0.2s;margin-bottom:8px}
#ci-checkout-v3 .ci-furnished-row:hover{border-color:var(--ci-teal);background:var(--ci-teal-50)}
#ci-checkout-v3 .ci-furnished-row.active{border-color:var(--ci-teal);background:var(--ci-teal-100)}
#ci-checkout-v3 .ci-furnished-left{display:flex;align-items:center;gap:10px}
#ci-checkout-v3 .ci-chk{width:20px;height:20px;border-radius:5px;border:2px solid var(--ci-gray-300);display:flex;align-items:center;justify-content:center;transition:all 0.2s;flex-shrink:0}
#ci-checkout-v3 .ci-furnished-row.active .ci-chk{background:var(--ci-teal);border-color:var(--ci-teal)}
#ci-checkout-v3 .ci-chk svg{width:12px;height:12px;stroke:white;fill:none;stroke-width:2.5;opacity:0;transition:opacity 0.2s}
#ci-checkout-v3 .ci-furnished-row.active .ci-chk svg{opacity:1}
#ci-checkout-v3 .ci-furnished-price{font-size:13px;font-weight:600;color:var(--ci-teal-dark)}
#ci-checkout-v3 .ci-cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
#ci-checkout-v3 .ci-cal-nav button{width:34px;height:34px;border-radius:8px;border:1.5px solid var(--ci-gray-200);background:var(--ci-white);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s}
#ci-checkout-v3 .ci-cal-nav button:hover{border-color:var(--ci-teal);background:var(--ci-teal-50)}
#ci-checkout-v3 .ci-cal-nav button svg{width:16px;height:16px;stroke:var(--ci-gray-600);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
#ci-checkout-v3 .ci-cal-title{font-size:15px;font-weight:700;color:var(--ci-gray-800)}
#ci-checkout-v3 .ci-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}
#ci-checkout-v3 .ci-cal-dow{text-align:center;font-size:11px;font-weight:600;color:var(--ci-gray-400);padding:4px 0 8px;text-transform:uppercase;letter-spacing:0.5px}
#ci-checkout-v3 .ci-cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;border-radius:8px;cursor:pointer;transition:all 0.15s;border:1.5px solid transparent;color:var(--ci-gray-700)}
#ci-checkout-v3 .ci-cal-day:hover:not(.disabled):not(.empty){background:var(--ci-teal-50);border-color:var(--ci-teal)}
#ci-checkout-v3 .ci-cal-day.selected{background:var(--ci-teal) !important;color:white !important;border-color:var(--ci-teal-dark) !important;font-weight:700;box-shadow:0 2px 8px rgba(13,148,136,0.35)}
#ci-checkout-v3 .ci-cal-day.disabled{color:var(--ci-gray-300);cursor:not-allowed}
#ci-checkout-v3 .ci-cal-day.empty{cursor:default}
#ci-checkout-v3 .ci-cal-day.premium{background:var(--ci-amber-bg);border:1.5px dashed var(--ci-amber);color:var(--ci-gold);font-weight:600}
#ci-checkout-v3 .ci-cal-day.premium:hover:not(.disabled){background:var(--ci-amber-light);border-color:var(--ci-gold)}
#ci-checkout-v3 .ci-cal-day.premium.selected{background:var(--ci-amber) !important;color:white !important;border-style:solid !important;border-color:var(--ci-gold) !important}
#ci-checkout-v3 .ci-cal-day.today:not(.selected){border-color:var(--ci-teal);font-weight:700}
#ci-checkout-v3 .ci-cal-legend{display:flex;gap:16px;padding-top:8px;border-top:1px solid var(--ci-gray-100)}
#ci-checkout-v3 .ci-cal-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--ci-gray-500)}
#ci-checkout-v3 .ci-cal-legend-dot{width:14px;height:14px;border-radius:4px;flex-shrink:0}
#ci-checkout-v3 .ci-cal-legend-dot.avail{background:var(--ci-teal-50);border:1.5px solid var(--ci-teal)}
#ci-checkout-v3 .ci-cal-legend-dot.prem{background:var(--ci-amber-bg);border:1.5px dashed var(--ci-amber)}
#ci-checkout-v3 .ci-notice{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;border-radius:8px;font-size:12.5px;line-height:1.5;margin-bottom:16px}
#ci-checkout-v3 .ci-notice.amber{background:var(--ci-amber-bg);border:1px solid var(--ci-amber-light);color:var(--ci-gold)}
#ci-checkout-v3 .ci-notice.teal{background:var(--ci-teal-50);border:1px solid var(--ci-teal-light);color:var(--ci-teal-dark)}
#ci-checkout-v3 .ci-notice svg{width:16px;height:16px;flex-shrink:0;margin-top:1px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
#ci-checkout-v3 .ci-input-group{margin-bottom:16px}
#ci-checkout-v3 .ci-input{width:100%;padding:11px 14px;border:1.5px solid var(--ci-gray-200);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ci-gray-800);background:var(--ci-white);transition:border-color 0.2s,box-shadow 0.2s}
#ci-checkout-v3 .ci-input::placeholder{color:var(--ci-gray-400)}
#ci-checkout-v3 .ci-input:focus{outline:none;border-color:var(--ci-teal);box-shadow:0 0 0 3px rgba(13,148,136,0.1)}
#ci-checkout-v3 .ci-input-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
#ci-checkout-v3 .ci-select{width:100%;padding:11px 14px;border:1.5px solid var(--ci-gray-200);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ci-gray-800);background:var(--ci-white);cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
#ci-checkout-v3 .ci-select:focus{outline:none;border-color:var(--ci-teal);box-shadow:0 0 0 3px rgba(13,148,136,0.1)}
#ci-checkout-v3 .ci-textarea{width:100%;padding:11px 14px;border:1.5px solid var(--ci-gray-200);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ci-gray-800);resize:vertical;min-height:70px;transition:border-color 0.2s,box-shadow 0.2s}
#ci-checkout-v3 .ci-textarea:focus{outline:none;border-color:var(--ci-teal);box-shadow:0 0 0 3px rgba(13,148,136,0.1)}
#ci-checkout-v3 .ci-promo-row{display:flex;gap:8px;margin-bottom:20px}
#ci-checkout-v3 .ci-promo-row .ci-input{flex:1}
#ci-checkout-v3 .ci-promo-btn{padding:11px 18px;background:var(--ci-gray-100);border:1.5px solid var(--ci-gray-200);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;color:var(--ci-gray-600);cursor:pointer;white-space:nowrap;transition:all 0.2s}
#ci-checkout-v3 .ci-promo-btn:hover{background:var(--ci-teal-50);border-color:var(--ci-teal);color:var(--ci-teal-dark)}
#ci-checkout-v3 .ci-promo-msg{font-size:12px;margin-top:6px;font-weight:500}
#ci-checkout-v3 .ci-promo-msg.success{color:var(--ci-green)}
#ci-checkout-v3 .ci-promo-msg.error{color:var(--ci-red)}
#ci-checkout-v3 .ci-breakdown{background:var(--ci-gray-50);border:1.5px solid var(--ci-gray-200);border-radius:var(--ci-radius);padding:16px;margin-bottom:20px}
#ci-checkout-v3 .ci-bk-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:13.5px;color:var(--ci-gray-600)}
#ci-checkout-v3 .ci-bk-row.fee{color:var(--ci-amber)}
#ci-checkout-v3 .ci-bk-row.discount{color:var(--ci-green)}
#ci-checkout-v3 .ci-bk-divider{height:1px;background:var(--ci-gray-200);margin:8px 0}
#ci-checkout-v3 .ci-bk-total{display:flex;justify-content:space-between;align-items:center;padding:6px 0 0;font-size:16px;font-weight:700;color:var(--ci-gray-900)}
#ci-checkout-v3 .ci-bk-total span:last-child{color:var(--ci-teal-dark);font-size:20px}
#ci-checkout-v3 .ci-pay-btn{width:100%;padding:15px;background:linear-gradient(135deg,var(--ci-teal-dark),var(--ci-teal));color:white;border:none;border-radius:var(--ci-radius);font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:16px;font-weight:700;cursor:pointer;transition:all 0.2s;box-shadow:0 4px 12px rgba(13,148,136,0.3);display:flex;align-items:center;justify-content:center;gap:8px}
#ci-checkout-v3 .ci-pay-btn:hover{background:linear-gradient(135deg,var(--ci-teal-deeper),var(--ci-teal-dark));transform:translateY(-1px)}
#ci-checkout-v3 .ci-pay-btn:disabled{background:var(--ci-gray-300);cursor:not-allowed;box-shadow:none;transform:none}
#ci-checkout-v3 .ci-pay-btn svg{width:18px;height:18px;stroke:white;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
#ci-checkout-v3 .ci-reserve-btn{width:100%;padding:14px;background:var(--ci-white);color:var(--ci-teal-dark);border:2px solid var(--ci-teal);border-radius:var(--ci-radius);font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:10px}
#ci-checkout-v3 .ci-reserve-btn:hover{background:var(--ci-teal-50);transform:translateY(-1px)}
#ci-checkout-v3 .ci-reserve-btn:disabled{color:var(--ci-gray-300);border-color:var(--ci-gray-300);cursor:not-allowed;transform:none}
#ci-checkout-v3 .ci-reserve-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
#ci-checkout-v3 .ci-footer{text-align:center;padding:14px 28px;background:var(--ci-gray-50);border-top:1px solid var(--ci-gray-100)}
#ci-checkout-v3 .ci-footer p{font-size:11px;color:var(--ci-gray-400)}
#ci-checkout-v3 .ci-footer a{color:var(--ci-teal);text-decoration:none}
@media (max-width:640px){
#ci-checkout-v3 .ci-pricing-table thead th{font-size:11px;padding:12px 6px}
#ci-checkout-v3 .ci-pricing-table tbody td{padding:10px 6px;font-size:13px}
#ci-checkout-v3 .ci-pricing-table .ci-price-cell{font-size:14px}
#ci-checkout-v3 .ci-pricing-table tbody td:first-child{padding-left:12px}
#ci-checkout-v3 .ci-pricing-table thead th:first-child{padding-left:12px;width:auto}
#ci-checkout-v3 .ci-row-book{padding:6px 10px;font-size:11.5px}
#ci-checkout-v3 .ci-fw-body{padding:18px 18px 22px}
#ci-checkout-v3 .ci-fw-header{padding:16px 18px}
#ci-checkout-v3 .ci-input-row{grid-template-columns:1fr}
#ci-checkout-v3 .ci-page-head h1{font-size:24px}
}
</style>
<div id="ci-checkout-v3">
  <div class="ci-page-head">
    <h1>Check-Out Reports</h1>
    <p>Professional check-out inventory reports across London. Select your property size to book instantly.</p>
    <div style="display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:8px 18px;background:var(--ci-teal-50);border:1.5px solid var(--ci-teal-light);border-radius:20px;">
      <svg style="width:16px;height:16px;stroke:var(--ci-teal);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;" viewBox="0 0 24 24"><polyline points="20 6 9 17 4 12"/></svg>
      <span style="font-size:13.5px;font-weight:700;color:var(--ci-teal-dark);">All prices inclusive of VAT — no hidden fees</span>
    </div>
  </div>
  <div class="ci-toggle-wrap">
    <span class="ci-toggle-label active" id="co3-lbl-flat" onclick="co3Toggle()">🏢 Flat</span>
    <div class="ci-toggle-track" id="co3-toggle" onclick="co3Toggle()">
      <div class="ci-toggle-thumb"></div>
    </div>
    <span class="ci-toggle-label" id="co3-lbl-house" onclick="co3Toggle()">🏠 House</span>
  </div>
  <div class="ci-pricing-table-wrap">
    <table class="ci-pricing-table">
      <thead>
        <tr>
          <th>Property Size</th>
          <th>Check-Out Price</th>
          <th></th>
        </tr>
      </thead>
      <tbody id="co3-tbody"></tbody>
    </table>
  </div>
  <div class="ci-callout">
    <svg viewBox="0 0 24 24"><path d="M22 16.92v3a2 2 0 01-2.18 2 19.79 19.79 0 01-8.63-3.07 19.5 19.5 0 01-6-6 19.79 19.79 0 01-3.07-8.67A2 2 0 014.11 2h3a2 2 0 012 1.72c.13.81.36 1.6.68 2.35a2 2 0 01-.45 2.11L8.09 9.91a16 16 0 006 6l1.27-1.27a2 2 0 012.11-.45c.75.32 1.54.55 2.35.68A2 2 0 0122 16.92z"/></svg>
    <span>Property larger than 5 bedrooms? Please <a href="tel:02034888072">call us on 020 3488 8072</a> or <a href="mailto:info@clickinventories.co.uk">email us</a> for a bespoke quote.</span>
  </div>
  <div class="ci-form-widget" id="co3-form">
    <div class="ci-fw-header">
      <div class="ci-fw-header-row">
        <div class="ci-fw-icon">
          <svg viewBox="0 0 24 24"><path d="M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2"/><rect x="9" y="3" width="6" height="4" rx="1"/><path d="M9 14l2 2 4-4"/></svg>
        </div>
        <div>
          <h3>Book Your Check-Out</h3>
          <p>Complete the details below</p>
          <div class="ci-fw-selection" id="co3-selection">Select a property size from the table above</div>
        </div>
      </div>
    </div>
    <div class="ci-fw-body">
      <div class="ci-label"><span class="ci-step">1</span> Additional Rooms &amp; Furnished</div>
      <div class="ci-rooms-section">
        <div class="ci-furnished-row" id="co3-furnished" onclick="co3ToggleFurnished()">
          <div class="ci-furnished-left">
            <div class="ci-chk"><svg viewBox="0 0 24 24"><polyline points="20 6 9 17 4 12"/></svg></div>
            <span style="font-size:13.5px;font-weight:500;color:var(--ci-gray-700);">Furnished property</span>
          </div>
          <span class="ci-furnished-price">+£10</span>
        </div>
        <div class="ci-rooms-row">
          <span class="ci-rooms-row-label">Extra bathrooms</span>
          <div class="ci-counter">
            <button class="ci-counter-btn" onclick="co3Rooms('bath',-1)">−</button>
            <span class="ci-counter-val" id="co3-bath-count">0</span>
            <button class="ci-counter-btn" onclick="co3Rooms('bath',1)">+</button>
          </div>
        </div>
        <div class="ci-rooms-row">
          <span class="ci-rooms-row-label">Other rooms <span style="font-size:12px;color:var(--ci-gray-400);">(utility, garage, conservatory, etc.)</span></span>
          <div class="ci-counter">
            <button class="ci-counter-btn" onclick="co3Rooms('other',-1)">−</button>
            <span class="ci-counter-val" id="co3-other-count">0</span>
            <button class="ci-counter-btn" onclick="co3Rooms('other',1)">+</button>
          </div>
        </div>
        <div class="ci-rooms-hint">
          <svg viewBox="0 0 24 24"><circle cx="12" cy="12" r="10"/><line x1="12" y1="16" x2="12" y2="12"/><line x1="12" y1="8" x2="12.01" y2="8"/></svg>
          Base price includes 1 bathroom, 1 kitchen &amp; 1 lounge. Additional rooms are £10 each.
        </div>
      </div>
      <div class="ci-label"><span class="ci-step">2</span> Add a Check-In at 50% Off</div>
      <div id="co3-upsell-section" style="margin-bottom:20px;">
        <div style="padding:16px;background:linear-gradient(135deg,var(--ci-green-light),#ECFDF5);border:1.5px solid #A7F3D0;border-radius:10px;position:relative;overflow:hidden;">
          <div style="position:absolute;top:-10px;right:-10px;width:60px;height:60px;background:rgba(5,150,105,0.08);border-radius:50%;"></div>
          <div style="display:flex;align-items:flex-start;gap:10px;position:relative;z-index:1;">
            <div style="width:36px;height:36px;background:var(--ci-green);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;">
              <svg style="width:20px;height:20px;stroke:white;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;" viewBox="0 0 24 24"><path d="M20.59 13.41l-7.17 7.17a2 2 0 01-2.83 0L2 12V2h10l8.59 8.59a2 2 0 010 2.82z"/><line x1="7" y1="7" x2="7.01" y2="7"/></svg>
            </div>
            <div style="flex:1;">
              <div style="font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:15px;font-weight:800;color:#065F46;margin-bottom:4px;">50% Off Follow-Up Check-In</div>
              <div style="font-size:13px;color:#047857;line-height:1.5;margin-bottom:10px;">Book your check-in together with this check-out and get it at <strong>half price</strong>. The check-in date can be confirmed later once the new tenancy is arranged.</div>
              <div style="font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:20px;font-weight:800;color:#065F46;margin-bottom:10px;" id="co3-upsell-price"></div>
              <div style="display:flex;gap:8px;flex-wrap:wrap;">
                <button onclick="co3AcceptUpsell()" id="co3-upsell-yes" style="padding:8px 20px;background:var(--ci-green);color:white;border:none;border-radius:6px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all 0.2s;">✓ Yes, add Check-In</button>
                <button onclick="co3DeclineUpsell()" id="co3-upsell-no" style="padding:8px 20px;background:white;color:var(--ci-gray-600);border:1.5px solid var(--ci-gray-300);border-radius:6px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all 0.2s;">No thanks</button>
              </div>
            </div>
          </div>
        </div>
        <div id="co3-upsell-accepted" style="display:none;padding:10px 14px;background:#ECFDF5;border:1px solid #A7F3D0;border-radius:8px;margin-top:8px;">
          <div style="display:flex;align-items:center;justify-content:space-between;">
            <div style="display:flex;align-items:center;gap:8px;">
              <svg style="width:16px;height:16px;stroke:var(--ci-green);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;" viewBox="0 0 24 24"><polyline points="20 6 9 17 4 12"/></svg>
              <span style="font-size:13px;font-weight:600;color:#065F46;">Check-In added at 50% off — date to be confirmed</span>
            </div>
            <button onclick="co3RemoveUpsell()" style="background:none;border:none;font-size:12px;color:var(--ci-gray-400);cursor:pointer;text-decoration:underline;">Remove</button>
          </div>
        </div>
      </div>
      <div class="ci-label"><span class="ci-step">3</span> Select Date</div>
      <div style="margin-bottom:20px;">
        <div class="ci-cal-nav">
          <button onclick="co3CalNav(-1)"><svg viewBox="0 0 24 24"><polyline points="15 18 9 12 15 6"/></svg></button>
          <span class="ci-cal-title" id="co3-cal-title"></span>
          <button onclick="co3CalNav(1)"><svg viewBox="0 0 24 24"><polyline points="9 18 15 12 9 6"/></svg></button>
        </div>
        <div class="ci-cal-grid" id="co3-cal-grid"></div>
        <div class="ci-cal-legend">
          <div class="ci-cal-legend-item"><div class="ci-cal-legend-dot avail"></div>Available</div>
          <div class="ci-cal-legend-item"><div class="ci-cal-legend-dot prem"></div>Sun / Bank Hol (+£50)</div>
        </div>
      </div>
      <div class="ci-notice amber" id="co3-premium-notice" style="display:none;">
        <svg viewBox="0 0 24 24"><circle cx="12" cy="12" r="10"/><line x1="12" y1="8" x2="12" y2="12"/><line x1="12" y1="16" x2="12.01" y2="16"/></svg>
        <span>Sunday / Bank Holiday bookings include a <strong>£50 premium fee</strong>.</span>
      </div>
      <div class="ci-label"><span class="ci-step">4</span> Property &amp; Contact Details</div>
      <div class="ci-input-group">
        <input type="text" class="ci-input" id="co3-address" placeholder="Property address (first line) *" required />
      </div>
      <div class="ci-input-group">
        <div class="ci-input-row">
          <input type="text" class="ci-input" id="co3-postcode" placeholder="Postcode *" oninput="co3CheckPostcode()" required />
          <select class="ci-select" id="co3-time" onchange="co3CheckPeak()" required>
            <option value="">Select time slot *</option>
            <option value="09:00-10:00" data-peak="true">9:00 – 10:00 AM ⭐ Peak (+£50)</option>
            <option value="10:00-11:00">10:00 – 11:00 AM</option>
            <option value="11:00-12:00">11:00 AM – 12:00 PM</option>
            <option value="12:00-13:00">12:00 – 1:00 PM</option>
            <option value="13:00-14:00">1:00 – 2:00 PM</option>
            <option value="14:00-15:00">2:00 – 3:00 PM</option>
            <option value="15:00-16:00">3:00 – 4:00 PM</option>
            <option value="16:00-17:00">4:00 – 5:00 PM</option>
            <option value="17:00-18:00">5:00 – 6:00 PM</option>
            <option value="18:00-19:00">6:00 – 7:00 PM</option>
          </select>
        </div>
      </div>
      <div class="ci-notice amber" id="co3-oof-notice" style="display:none;">
        <svg viewBox="0 0 24 24"><circle cx="12" cy="12" r="10"/><line x1="12" y1="8" x2="12" y2="12"/><line x1="12" y1="16" x2="12.01" y2="16"/></svg>
        <span>Postcode outside standard London coverage. A <strong>£25 out-of-area fee</strong> has been added.</span>
      </div>
      <div class="ci-notice amber" id="co3-peak-notice" style="display:none;">
        <svg viewBox="0 0 24 24"><circle cx="12" cy="12" r="10"/><line x1="12" y1="8" x2="12" y2="12"/><line x1="12" y1="16" x2="12.01" y2="16"/></svg>
        <span>The <strong>9:00 AM</strong> slot is peak time — <strong>+£50 fee</strong> applied.</span>
      </div>
      <div class="ci-input-group">
        <div class="ci-input-row">
          <input type="text" class="ci-input" id="co3-name" placeholder="Your full name *" required />
          <input type="tel" class="ci-input" id="co3-phone" placeholder="Phone number *" required />
        </div>
      </div>
      <div class="ci-input-group">
        <input type="email" class="ci-input" id="co3-email" placeholder="Email address *" required />
      </div>
      <div class="ci-input-group">
        <textarea class="ci-textarea" id="co3-notes" placeholder="Additional notes (key collection, access info, etc.)"></textarea>
      </div>
      <div class="ci-label"><span class="ci-step">5</span> Promo Code</div>
      <div class="ci-promo-row">
        <input type="text" class="ci-input" id="co3-promo" placeholder="Enter promo code" />
        <button class="ci-promo-btn" onclick="co3ApplyPromo()">Apply</button>
      </div>
      <div class="ci-promo-msg" id="co3-promo-msg"></div>
      <div class="ci-notice teal" id="co3-pay-benefit" style="display:none;">
        <svg viewBox="0 0 24 24"><path d="M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10z"/></svg>
        <span><strong>Pay now &amp; save 10%</strong> — your report will be sent immediately on completion, no delays waiting on payment.</span>
      </div>
      <div class="ci-breakdown" id="co3-breakdown" style="display:none;"></div>
      <button class="ci-pay-btn" id="co3-pay-btn" disabled onclick="co3PayNow()">
        <svg viewBox="0 0 24 24"><rect x="1" y="4" width="22" height="16" rx="2" ry="2"/><line x1="1" y1="10" x2="23" y2="10"/></svg>
        <span id="co3-pay-label">Select property size to continue</span>
      </button>
      <button class="ci-reserve-btn" id="co3-reserve-btn" disabled onclick="co3Reserve()">
        <svg viewBox="0 0 24 24"><rect x="3" y="4" width="18" height="18" rx="2" ry="2"/><line x1="16" y1="2" x2="16" y2="6"/><line x1="8" y1="2" x2="8" y2="6"/><line x1="3" y1="10" x2="21" y2="10"/></svg>
        <span id="co3-reserve-label">Reserve without paying</span>
      </button>
      <div style="text-align:center;margin-top:8px;font-size:11.5px;color:var(--ci-gray-400);line-height:1.5;display:none;" id="co3-reserve-note">
        Reserve now, pay later — your report will be held until payment is received.
      </div>
    </div><div id="co3-success" class="ci-confirmation-msg" style="display:none;background:#e8f5e9;border:2px solid #4caf50;border-radius:10px;padding:24px 20px;margin:18px 0 12px;text-align:center;"><div style="font-size:2em;margin-bottom:8px;">&#10004;</div><div style="font-size:1.15em;font-weight:700;color:#2e7d32;margin-bottom:6px;">Booking Confirmed!</div><div id="co3-success-detail" style="font-size:0.97em;color:#333;">Your check-out report has been booked successfully. A confirmation email will be sent to you shortly.</div></div>
    <div class="ci-footer">
      <p>Click Inventories Ltd &bull; <a href="mailto:info@clickinventories.co.uk">info@clickinventories.co.uk</a> &bull; London</p>
    </div>
  </div>
</div>
<script>

(function() {
  'use strict';
  const FLAT_PRICES = {
    checkout:  [115, 130, 150, 175, 200, 225],
    checkin:   [125, 140, 160, 185, 210, 235]
  };
  const HOUSE_MULT = 1.15;
  const BED_LABELS = ['Studio', '1 Bed', '2 Bed', '3 Bed', '4 Bed', '5 Bed'];
  const BANK_HOLIDAYS = [
    '2025-01-01','2025-04-18','2025-04-21','2025-05-05','2025-05-26',
    '2025-08-25','2025-12-25','2025-12-26',
    '2026-01-01','2026-04-03','2026-04-06','2026-05-04','2026-05-25',
    '2026-08-31','2026-12-25','2026-12-28',
    '2027-01-01','2027-03-26','2027-03-29','2027-05-03','2027-05-31',
    '2027-08-30','2027-12-27','2027-12-28'
  ];
  const LONDON = ['EC','WC','E','N','NW','SE','SW','W'];
  let S = {
    isHouse: false, beds: null, furnished: false, extraBath: 0, extraOther: 0,
    selectedDate: null, calMonth: new Date().getMonth(), calYear: new Date().getFullYear(),
    promoApplied: false, promoDiscount: 0, outOfArea: false, premiumDay: false,
    peakTime: false, upsellAccepted: false
  };
  function getPrice(service, beds) {
    const base = FLAT_PRICES[service][beds];
    return (S.isHouse && beds >= 3) ? Math.round(base * HOUSE_MULT) : base;
  }
  function fmtPrice(p) { return '£' + p; }
  window.co3Toggle = function() {
    S.isHouse = !S.isHouse;
    document.getElementById('co3-toggle').classList.toggle('house', S.isHouse);
    document.getElementById('co3-lbl-flat').classList.toggle('active', !S.isHouse);
    document.getElementById('co3-lbl-house').classList.toggle('active', S.isHouse);
    buildTable(); updateUpsellPrice(); updatePrice();
  };
  function buildTable() {
    const tbody = document.getElementById('co3-tbody');
    tbody.innerHTML = '';
    BED_LABELS.forEach((label, i) => {
      const tr = document.createElement('tr');
      if (S.beds === i) tr.classList.add('selected');
      tr.innerHTML = '<td>' + label + '</td><td class="ci-price-cell">' + fmtPrice(getPrice('checkout', i)) + '</td><td><button class="ci-row-book" onclick="co3SelectBed(' + i + '); event.stopPropagation();"><svg viewBox="0 0 24 24"><rect x="3" y="4" width="18" height="18" rx="2" ry="2"/><line x1="16" y1="2" x2="16" y2="6"/><line x1="8" y1="2" x2="8" y2="6"/><line x1="3" y1="10" x2="21" y2="10"/></svg> Book Now</button></td>';
      tr.addEventListener('click', () => co3SelectBed(i));
      tbody.appendChild(tr);
    });
  }
  window.co3SelectBed = function(beds) {
    S.beds = beds; buildTable(); updateSelection(); updateUpsellPrice(); updatePrice();
    document.getElementById('co3-form').scrollIntoView({ behavior: 'smooth', block: 'start' });
  };
  function updateSelection() {
    const el = document.getElementById('co3-selection');
    if (S.beds !== null) {
      const type = S.isHouse ? 'House' : 'Flat';
      el.innerHTML = '<strong>' + BED_LABELS[S.beds] + ' ' + type + '</strong> — Check-Out from <strong>' + fmtPrice(getPrice('checkout', S.beds)) + '</strong>';
    } else { el.textContent = 'Select a property size from the table above'; }
  }
  window.co3ToggleFurnished = function() {
    S.furnished = !S.furnished;
    document.getElementById('co3-furnished').classList.toggle('active', S.furnished);
    updatePrice();
  };
  window.co3Rooms = function(type, d) {
    if (type === 'bath') {
      S.extraBath = Math.max(0, Math.min(10, S.extraBath + d));
      document.getElementById('co3-bath-count').textContent = S.extraBath;
    } else {
      S.extraOther = Math.max(0, Math.min(10, S.extraOther + d));
      document.getElementById('co3-other-count').textContent = S.extraOther;
    }
    updatePrice();
  };
  function getCheckinPrice(beds) {
    const base = FLAT_PRICES.checkin[beds];
    return (S.isHouse && beds >= 3) ? Math.round(base * HOUSE_MULT) : base;
  }
  function updateUpsellPrice() {
    const el = document.getElementById('co3-upsell-price');
    if (S.beds !== null) {
      const full = getCheckinPrice(S.beds);
      const half = Math.round(full / 2);
      el.innerHTML = '<span style="text-decoration:line-through;color:var(--ci-gray-400);font-size:15px;font-weight:500;">£' + full + '</span> £' + half;
    } else { el.textContent = ''; }
  }
  window.co3AcceptUpsell = function() {
    S.upsellAccepted = true;
    document.getElementById('co3-upsell-yes').style.display = 'none';
    document.getElementById('co3-upsell-no').style.display = 'none';
    document.getElementById('co3-upsell-accepted').style.display = 'block';
    updatePrice();
  };
  window.co3DeclineUpsell = function() {
    S.upsellAccepted = false;
    document.getElementById('co3-upsell-yes').style.display = 'inline-block';
    document.getElementById('co3-upsell-no').style.display = 'inline-block';
    document.getElementById('co3-upsell-accepted').style.display = 'none';
    document.getElementById('co3-upsell-section').querySelector('div').style.opacity = '0.5';
    updatePrice();
  };
  window.co3RemoveUpsell = function() {
    S.upsellAccepted = false;
    document.getElementById('co3-upsell-yes').style.display = 'inline-block';
    document.getElementById('co3-upsell-no').style.display = 'inline-block';
    document.getElementById('co3-upsell-accepted').style.display = 'none';
    document.getElementById('co3-upsell-section').querySelector('div').style.opacity = '1';
    updatePrice();
  };
  function isPremium(y, m, d) {
    const date = new Date(y, m, d);
    if (date.getDay() === 0) return true;
    const ds = y + '-' + String(m+1).padStart(2,'0') + '-' + String(d).padStart(2,'0');
    return BANK_HOLIDAYS.includes(ds);
  }
  function renderCal() {
    const y = S.calYear, m = S.calMonth;
    document.getElementById('co3-cal-title').textContent = new Date(y, m).toLocaleDateString('en-GB', { month: 'long', year: 'numeric' });
    const grid = document.getElementById('co3-cal-grid');
    grid.innerHTML = '';
    ['Mon','Tue','Wed','Thu','Fri','Sat','Sun'].forEach(d => {
      const el = document.createElement('div');
      el.className = 'ci-cal-dow'; el.textContent = d;
      grid.appendChild(el);
    });
    let startDay = new Date(y, m, 1).getDay() - 1;
    if (startDay < 0) startDay = 6;
    for (let i = 0; i < startDay; i++) {
      const el = document.createElement('div');
      el.className = 'ci-cal-day empty';
      grid.appendChild(el);
    }
    const today = new Date(); today.setHours(0,0,0,0);
    const days = new Date(y, m + 1, 0).getDate();
    for (let d = 1; d <= days; d++) {
      const el = document.createElement('div');
      el.className = 'ci-cal-day'; el.textContent = d;
      const dt = new Date(y, m, d); dt.setHours(0,0,0,0);
      if (dt < today) { el.classList.add('disabled'); }
      else {
        if (isPremium(y, m, d)) el.classList.add('premium');
        if (dt.getTime() === today.getTime()) el.classList.add('today');
        if (S.selectedDate && S.selectedDate.getTime() === dt.getTime()) el.classList.add('selected');
        el.addEventListener('click', () => {
          S.selectedDate = new Date(y, m, d);
          S.premiumDay = isPremium(y, m, d);
          document.getElementById('co3-premium-notice').style.display = S.premiumDay ? 'flex' : 'none';
          renderCal(); updatePrice();
        });
      }
      grid.appendChild(el);
    }
  }
  window.co3CalNav = function(dir) {
    S.calMonth += dir;
    if (S.calMonth > 11) { S.calMonth = 0; S.calYear++; }
    if (S.calMonth < 0) { S.calMonth = 11; S.calYear--; }
    renderCal();
  };
  window.co3CheckPostcode = function() {
    const pc = document.getElementById('co3-postcode').value.trim().toUpperCase().replace(/\s+/g, '');
    if (pc.length < 2) { S.outOfArea = false; document.getElementById('co3-oof-notice').style.display = 'none'; updatePrice(); return; }
    const match = LONDON.some(p => pc.startsWith(p) && pc.slice(p.length).length > 0 && /^\d/.test(pc.slice(p.length)));
    S.outOfArea = !match;
    document.getElementById('co3-oof-notice').style.display = S.outOfArea ? 'flex' : 'none';
    updatePrice();
  };
  window.co3CheckPeak = function() {
    const sel = document.getElementById('co3-time');
    const opt = sel.options[sel.selectedIndex];
    S.peakTime = (opt && opt.dataset.peak === 'true');
    document.getElementById('co3-peak-notice').style.display = S.peakTime ? 'flex' : 'none';
    updatePrice();
  };
  window.co3ApplyPromo = function() {
    const code = document.getElementById('co3-promo').value.trim().toUpperCase();
    const msg = document.getElementById('co3-promo-msg');
    if (code === 'CLICKSERVICES2026') {
      S.promoApplied = true; S.promoDiscount = 10;
      msg.textContent = '✓ CLICKSERVICES2026 applied — 10% off!'; msg.className = 'ci-promo-msg success';
    } else {
      S.promoApplied = false; S.promoDiscount = 0;
      msg.textContent = '✗ Invalid promo code.'; msg.className = 'ci-promo-msg error';
    }
    updatePrice();
  };
  function updatePrice() {
    const bb = document.getElementById('co3-breakdown');
    const payBtn = document.getElementById('co3-pay-btn');
    const resBtn = document.getElementById('co3-reserve-btn');
    const payLbl = document.getElementById('co3-pay-label');
    const resLbl = document.getElementById('co3-reserve-label');
    const benefit = document.getElementById('co3-pay-benefit');
    const resNote = document.getElementById('co3-reserve-note');
    if (S.beds === null) {
      bb.style.display = 'none';
      payBtn.disabled = true; resBtn.disabled = true;
      payLbl.textContent = 'Select property size to continue';
      resLbl.textContent = 'Reserve without paying';
      benefit.style.display = 'none'; resNote.style.display = 'none';
      return;
    }
    const base = getPrice('checkout', S.beds);
    const label = BED_LABELS[S.beds];
    const type = S.isHouse ? 'House' : 'Flat';
    let rows = [], sub = base;
    rows.push({ l: 'Check-Out — ' + label + ' ' + type, a: base });
    if (S.upsellAccepted) {
      const ciHalf = Math.round(getCheckinPrice(S.beds) / 2);
      rows.push({ l: 'Check-In (50% off)', a: ciHalf, t: 'upsell' });
      sub += ciHalf;
    }
    if (S.furnished) { rows.push({ l: 'Furnished property', a: 10 }); sub += 10; }
    if (S.extraBath > 0) { const e = S.extraBath * 10; rows.push({ l: 'Extra bathrooms × ' + S.extraBath, a: e }); sub += e; }
    if (S.extraOther > 0) { const e = S.extraOther * 10; rows.push({ l: 'Other rooms × ' + S.extraOther, a: e }); sub += e; }
    if (S.premiumDay) { rows.push({ l: 'Sunday / Bank Holiday fee', a: 50, t: 'fee' }); sub += 50; }
    if (S.peakTime) { rows.push({ l: 'Peak time fee (9:00 AM)', a: 50, t: 'fee' }); sub += 50; }
    if (S.outOfArea) { rows.push({ l: 'Out of area fee', a: 25, t: 'fee' }); sub += 25; }
    let disc = 0;
    if (S.promoApplied) {
      disc = Math.round(sub * S.promoDiscount / 100);
      rows.push({ l: 'Promo (' + S.promoDiscount + '% off)', a: -disc, t: 'discount' });
    }
    const total = sub - disc;
    let html = '';
    rows.forEach((r, i) => {
      const cls = r.t ? 'ci-bk-row ' + r.t : 'ci-bk-row';
      html += '<div class="' + cls + '"><span>' + r.l + '</span><span>' + (i === 0 ? '' : (r.a < 0 ? '−' : '+')) + '£' + Math.abs(r.a) + '</span></div>';
    });
    html += '<div class="ci-bk-divider"></div>';
    html += '<div class="ci-bk-total"><span>Total</span><span>£' + total + '</span></div>';
    bb.innerHTML = html; bb.style.display = 'block';
    const ready = S.selectedDate !== null;
    payBtn.disabled = !ready; resBtn.disabled = !ready;
    payLbl.textContent = ready ? 'Pay £' + total + ' Now — Save 10%' : 'Select a date to continue';
    resLbl.textContent = ready ? 'Reserve — £' + total + ' (pay later)' : 'Reserve without paying';
    benefit.style.display = 'flex';
    resNote.style.display = ready ? 'block' : 'none';
  }
  function validate() {
    const fields = ['co3-address','co3-postcode','co3-name','co3-phone','co3-email'];
    const vals = fields.map(id => document.getElementById(id).value.trim());
    const time = document.getElementById('co3-time').value;
    if (vals.some(v => !v) || !time) {
      alert('Please complete all required fields (address, postcode, time slot, name, email, phone).');
      return false;
    }
    if (!/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(vals[4])) {
      alert('Please enter a valid email address.'); return false;
    }
    return true;
  }
  function buildPayload(type) {
    const base = getPrice('checkout', S.beds);
    let sub = base;
    if (S.upsellAccepted) sub += Math.round(getCheckinPrice(S.beds) / 2);
    if (S.furnished) sub += 10;
    sub += (S.extraBath + S.extraOther) * 10;
    if (S.premiumDay) sub += 50;
    if (S.peakTime) sub += 50;
    if (S.outOfArea) sub += 25;
    const disc = (type === 'pay_now' && S.promoApplied) ? Math.round(sub * S.promoDiscount / 100) : 0;
    return {
      paymentType: type, service: 'checkout', serviceName: 'Check-Out Report',
      propertyType: S.isHouse ? 'house' : 'flat', bedrooms: S.beds,
      bedroomLabel: BED_LABELS[S.beds], basePrice: base, furnished: S.furnished,
      extraBathrooms: S.extraBath, extraOtherRooms: S.extraOther,
      totalExtraRooms: S.extraBath + S.extraOther,
      upsellCheckin: S.upsellAccepted,
      upsellCheckinPrice: S.upsellAccepted ? Math.round(getCheckinPrice(S.beds) / 2) : 0,
      upsellCheckinFullPrice: S.upsellAccepted ? getCheckinPrice(S.beds) : 0,
      date: S.selectedDate.toLocaleDateString('en-GB', { weekday:'long', day:'numeric', month:'long', year:'numeric' }),
      dateISO: S.selectedDate.toISOString().split('T')[0],
      premiumDay: S.premiumDay, premiumFee: S.premiumDay ? 50 : 0,
      peakTime: S.peakTime, peakTimeFee: S.peakTime ? 50 : 0,
      outOfArea: S.outOfArea, outOfAreaFee: S.outOfArea ? 25 : 0,
      promoCode: (type === 'pay_now' && S.promoApplied) ? 'CLICKSERVICES2026' : null,
      promoDiscount: disc, subtotal: sub, total: sub - disc, currency: 'GBP',
      address: document.getElementById('co3-address').value.trim(),
      postcode: document.getElementById('co3-postcode').value.trim().toUpperCase(),
      timePreference: document.getElementById('co3-time').value,
      customerName: document.getElementById('co3-name').value.trim(),
      customerPhone: document.getElementById('co3-phone').value.trim(),
      customerEmail: document.getElementById('co3-email').value.trim(),
      notes: document.getElementById('co3-notes').value.trim(),
      bookedAt: new Date().toISOString()
    };
  }
  window.co3PayNow = function() {
    if (S.beds === null || !S.selectedDate) return;
    if (!validate()) return;
    const p = buildPayload('pay_now');
    console.log('=== CLICK INVENTORIES CHECK-OUT PAYMENT ===', JSON.stringify(p, null, 2));
    payNow(p);
  };
  window.co3Reserve = function() {
    if (S.beds === null || !S.selectedDate) return;
    if (!validate()) return;
    const p = buildPayload('reserve');
    console.log('=== CLICK INVENTORIES CHECK-OUT RESERVATION ===', JSON.stringify(p, null, 2));
    payNow(p);
  };
  window.payNow = window.payNow || function(p) {
    alert(
      (p.paymentType === 'pay_now' ? '💳 PAYING NOW' : '📅 RESERVATION') + '\n' +
      '━━━━━━━━━━━━━━━━━━━━━━━━\n' +
      p.serviceName + ' — ' + p.bedroomLabel + ' ' + p.propertyType + '\n' +
      p.address + ', ' + p.postcode + '\n' +
      p.date + ' · ' + p.timePreference + '\n' +
      (p.premiumDay ? '⚡ Premium day · ' : '') + (p.peakTime ? '⚡ Peak time · ' : '') +
      (p.upsellCheckin ? '🎉 Check-In at 50% off · ' : '') +
      (p.promoCode ? '🏷 ' + p.promoCode + ' ' : '') + '\n' +
      '━━━━━━━━━━━━━━━━━━━━━━━━\n' +
      'Total: £' + p.total + '\n' +
      (p.paymentType === 'reserve' ? '⚠ Report held until payment' : '✓ Report sent on completion') + '\n\n' +
      p.customerName + ' · ' + p.customerEmail
    );
 var co3s=document.getElementById('co3-success');if(co3s){co3s.style.display='block';co3s.scrollIntoView({behavior:'smooth',block:'center'});} };
  buildTable(); renderCal(); updatePrice();
})();

</script>[/vc_raw_html][/vc_column][/vc_row][vc_row][vc_column][vc_column_text] Ready to start a new tenancy? Remember, an inventory and check-out report are crucial. To meet this need, Click Inventories LTD is the ideal choice. Why Professional Inventory and Check-out Reports Matter An inventory and check-out report is far more than just a formality in the property management process.…

Book Now →

Residential & Commercial

Need an office or commercial building inventory carried out, please feel free to contact us.

Professional Property Inventory Reports for Landlords & Agents in London

Our detailed inspection services cover residential and commercial properties across London. From check-in to check-out, we deliver accurate property inventory reports with high-resolution photos that stand up in deposit disputes and keep your tenancy records compliant.

Book your property inventory report online in minutes — saving you time and money

Limited Time Offer

Save 10% on Your First Inventory Report

Use code CLICKSERVICES2026 at checkout

Apply the code when you pay at booking to receive your discount instantly.

[mnky_list_item icon_fontawesome=”fa fa-check-circle” size=”li_large” last_item=”last” icon_color=”#6dc78f”]Comprehensive Inventory Reports[/mnky_list_item]Get accurate and highly descriptive property inventory reports with high-resolution photos. Our experienced clerks with an eye for detail will ensure that you have no nasty surprises.[mnky_icons icon_type=”linecons” icon_size=”45px” icon_color=”#e74c3c” center_element=”icon-center-align” css_animation=”bottom-to-top” icon_linecons=”vc_li vc_li-calendar”]

72hr Turnaround

[mnky_icons icon_type=”linecons” icon_size=”45px” icon_color=”#3498db” center_element=”icon-center-align” css_animation=”bottom-to-top” css_animation_delay=”delay-200″ icon_linecons=”vc_li vc_li-search”]

Highly Detailed reports

[mnky_icons icon_type=”linecons” icon_size=”45px” icon_color=”#2ecc71″ center_element=”icon-center-align” css_animation=”bottom-to-top” css_animation_delay=”delay-400″ icon_linecons=”vc_li vc_li-camera”]

Hi-Def Images

[mnky_list_item icon_fontawesome=”fa fa-check-circle” size=”li_large” last_item=”last” icon_color=”#6dc78f”]Residential & Commercial[/mnky_list_item]Need an office or commercial building inventory carried out, please feel free to contact us.[mnky_icons icon_type=”linecons” icon_size=”45px” icon_color=”#3498db” center_element=”icon-center-align” css_animation=”bottom-to-top” icon_linecons=”vc_li vc_li-mail”]

Straight To Your Inbox

[mnky_icons icon_type=”linecons” icon_size=”45px” icon_color=”#e67e22″ center_element=”icon-center-align” css_animation=”bottom-to-top” css_animation_delay=”delay-200″ icon_linecons=”vc_li vc_li-key”]

Free Key Collection

[mnky_icons icon_type=”linecons” icon_size=”45px” icon_color=”#9b59b6″ center_element=”icon-center-align” css_animation=”bottom-to-top” css_animation_delay=”delay-400″ icon_linecons=”vc_li vc_li-bubble”]

Customer Care

Why don’t you have a look at our sample inventory report to familiarise yourself with our service?

Click to download PDF!

[mnky_list_item icon_fontawesome=”fa fa-check-circle” size=”li_large” last_item=”last” icon_color=”#6dc78f”]Inventory Report[/mnky_list_item]

A standalone inventory report is a comprehensive description of the property’s condition.  It describes fixtures, fittings, items and furniture (if applicable) within the property. We also include utility readings and fire alarm testing.

This service is for when a tenant doesn’t need to be checked in.

[mnky_retina_image img_url=”1377″ align=”retina-image-center” alt=”Professional property inventory reports service in London”][mnky_retina_image img_url=”1376″ align=”retina-image-center” width=”500″ height=”500″ alt=”Property inventory reports for landlords and tenants”][mnky_list_item icon_fontawesome=”fa fa-check-circle” size=”li_large” last_item=”last” icon_color=”#6dc78f”]Mid-Term Report[/mnky_list_item]This report is an inspection of a property whilst the tenancy is in duration.

This will highlight any damages, cleanliness and maintenance issues the agent/landlord will need to be aware of.

This is best used at quarterly intervals for high value property and for agents with high-value clients to ensure expensive property remains in top-spec condition.[mnky_list_item icon_fontawesome=”fa fa-check-circle” size=”li_large” last_item=”last” icon_color=”#6dc78f”]Inventory & Check-In[/mnky_list_item]

A check-in report is a comprehensive description of the property’s condition at the start of a tenancy between the landlord and tenant.  It describes fixtures, fittings, items and furniture (if applicable) within the property. We also include utility readings and fire alarm testing. We also check the tenant in, showing them all the important appliances around the property.

This helps to distinguish the condition of the property’s contents and décor, which will then be used for comparison once the tenancy is over.

[mnky_retina_image img_url=”1282″ align=”retina-image-center” alt=”Check-out property inventory reports London”][mnky_retina_image img_url=”1314″ align=”retina-image-center” alt=”Property inventory reports check-in service”][mnky_list_item icon_fontawesome=”fa fa-check-circle” size=”li_large” last_item=”last” icon_color=”#6dc78f”]Inventory & Check-Out[/mnky_list_item]As the tenancy comes to an end, this report will detail the important changes that have occurred during the length of the tenancy.

This will highlight any damages, cleanliness and maintenance issues the agent/landlord will need to be aware of.

Our property inventory reports ensure all keys, contact details and important documentation are collected for agents/landlords.[mnky_content_box static_shadow=”shadow” background=”#ffffff” custom_static_shadow=”0px 17px 35px rgba(74,74,115,0.1), 0px 5px 15px rgba(0,0,0,0.07)”]

For Agents / Landlords

As a landlord or estate agent, protect your property investment with our professional property inventory reports. In today’s complex property market, it’s essential to stay informed of any damages or missing items within your rental properties. Our experienced clerks ensure accurate and detailed reports with high-resolution photos, leaving you with peace of mind and less stress.

Benefits of using our property inventory reports service include:

Book Now

[/mnky_content_box][mnky_content_box static_shadow=”shadow” background=”#ffffff” custom_static_shadow=”0px 17px 35px rgba(74,74,115,0.1), 0px 5px 15px rgba(0,0,0,0.07)”]

For Tenants

Protect yourself and your deposit with our professional property inventory reports. Compliant with mandatory requirements, such as confirming smoke alarms were present and working, is crucial. Our experienced clerks provide detailed and accurate reports with high-resolution photos, guaranteeing:

Book Now

[/mnky_content_box]

    Why don't you have a look at our sample inventory report to familiarise yourself with our service?

    Download our professionally prepared sample report

    Click to download PDF!

    Why are good property inventory reports important?

    For Agents / Landlords

    Protect your property investment

    As a landlord or estate agent, protect your property investment with our professional property inventory reports. In today's complex property market, it's essential to stay informed of any damages or missing items within your rental properties. Our experienced clerks ensure accurate and detailed reports with high-resolution photos, leaving you with peace of mind and less stress.

    Benefits of using our property inventory reports service include:

    • Tenants are more likely to take care of the property, resulting in lower costs and less wear and tear for your rental properties.
    • Our reports serve as valuable evidence in court disputes, potentially saving you thousands of pounds in legal costs.
    • Hassle-free move-in and move-out process for all parties, allowing you to focus on more important business matters as a landlord or estate agent.
    • Avoid amateurism and protect your reputation by using professional inventory services for your rental properties.
    • Precise and well-written reports protect against potential oversights, securing valuable clients and building trust in your business as a landlord or estate agent.
    Book Now

    For Tenants

    Protect yourself and your deposit

    Protect yourself and your deposit with our professional property inventory reports. Compliant with mandatory requirements, such as confirming smoke alarms were present and working, is crucial. Our experienced clerks provide detailed and accurate reports with high-resolution photos, guaranteeing:

    • Protection against wrongful liability for costly repairs during your tenancy.
    • Strong evidence in deposit disputes, with high-quality reports and high-definition pictures, potentially saving you thousands of pounds.
    • Peace of mind during the move-in and move-out process, with accurate documentation of the property's condition.
    Book Now
    Additional Services

    More Than Just Inventories

    📸

    Property Photography

    [vc_row][vc_column][vc_gallery interval="3" images="2376,2377,2379,2380,2381,2382,2383,2384,2385" img_size="full"][vc_column_text] Book Your Photography Session [/vc_column_text][vc_column_text]Property photography is essential for showcasing your rental or commercial property in…

    Book Appointment Now
    📐

    Click Inventories LTD: Expert Floor Planning

    [vc_row][vc_column][vc_column_text] The Benefits of a Professional London Floor Plan Our London floor plan services offer numerous advantages that set them…

    Book Plan Now

    EPC + EICR + Gas Safety Certificate Bundle Services 2026

    [vc_row][vc_column][vc_raw_html]<!-- Click Inventories Certificate Booking Widget v2.0 -->

<!-- Copy and paste this entire block into WPCode, Custom HTML block, or similar -->

<div id="ci-booking-widget">

  <style>
    /* ========================================
       SCOPED STYLES - All prefixed with #ci-booking-widget
    ======================================== */
    #ci-booking-widget {
      --ci-brand-primary: #1a365d;
      --ci-brand-secondary: #2c5282;
      --ci-brand-accent: #ed8936;
      --ci-brand-accent-hover: #dd6b20;
      --ci-ink: #1a202c;
      --ci-ink-soft: #4a5568;
      --ci-ink-muted: #718096;
      --ci-surface: #ffffff;
      --ci-surface-raised: #f7fafc;
      --ci-surface-sunken: #edf2f7;
      --ci-border: #e2e8f0;
      --ci-border-focus: #cbd5e0;
      --ci-success: #38a169;
      --ci-success-soft: #c6f6d5;
      --ci-warning: #d69e2e;
      --ci-warning-soft: #fefcbf;
      --ci-error: #e53e3e;
      --ci-shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
      --ci-shadow-md: 0 4px 6px -1px rgba(0,0,0,0.1), 0 2px 4px -1px rgba(0,0,0,0.06);
      --ci-shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -2px rgba(0,0,0,0.05);
      --ci-radius-sm: 6px;
      --ci-radius-md: 10px;
      --ci-radius-lg: 16px;
      --ci-radius-xl: 24px;
      
      max-width: 1280px;
      margin: 0 auto;
      padding: 40px 24px 60px;
      font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
      color: var(--ci-ink);
      line-height: 1.5;
      box-sizing: border-box;
    }
    
    #ci-booking-widget , #ci-booking-widget ::before, #ci-booking-widget *::after {
      box-sizing: border-box;
      margin: 0;
      padding: 0;
    }
    /* Header */
    #ci-booking-widget .ci-header { text-align: center; margin-bottom: 32px; }
    #ci-booking-widget .ci-header h1 { font-size: clamp(1.75rem, 5vw, 2.5rem); font-weight: 700; color: var(--ci-brand-primary); letter-spacing: -0.02em; margin-bottom: 8px; }
    #ci-booking-widget .ci-header > p { font-size: 1.125rem; color: var(--ci-ink-soft); font-weight: 500; margin-bottom: 16px; }
    #ci-booking-widget .ci-trust-line { background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%); border: 1px solid #86efac; border-radius: var(--ci-radius-lg); padding: 14px 20px; font-size: 0.9375rem; color: #166534; font-weight: 600; margin-bottom: 20px; display: flex; align-items: center; justify-content: center; gap: 10px; flex-wrap: wrap; text-align: center; }
    #ci-booking-widget .ci-trust-line svg { width: 20px; height: 20px; color: var(--ci-success); flex-shrink: 0; }
    #ci-booking-widget .ci-badges { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin-top: 16px; }
    #ci-booking-widget .ci-badge { display: inline-flex; align-items: center; gap: 6px; background: var(--ci-surface); border: 1px solid var(--ci-border); padding: 8px 14px; border-radius: 999px; font-size: 0.8125rem; font-weight: 600; color: var(--ci-ink-soft); box-shadow: var(--ci-shadow-sm); }
    #ci-booking-widget .ci-badge svg { width: 16px; height: 16px; color: var(--ci-success); }
    /* Notice Banners */
    #ci-booking-widget .ci-notice { background: linear-gradient(135deg, #fffbeb 0%, #fef3c7 100%); border: 1px solid #fcd34d; border-radius: var(--ci-radius-lg); padding: 16px 20px; margin-bottom: 20px; display: flex; align-items: flex-start; gap: 12px; }
    #ci-booking-widget .ci-notice svg { width: 24px; height: 24px; color: #d97706; flex-shrink: 0; margin-top: 2px; }
    #ci-booking-widget .ci-notice h3 { font-weight: 700; color: #92400e; font-size: 0.9375rem; margin-bottom: 2px; }
    #ci-booking-widget .ci-notice p { color: #a16207; font-size: 0.875rem; font-weight: 500; margin: 0; }
    #ci-booking-widget .ci-info-box { background: var(--ci-surface-sunken); border: 1px solid var(--ci-border); border-radius: var(--ci-radius-md); padding: 12px 16px; margin-bottom: 20px; font-size: 0.8125rem; color: var(--ci-ink-soft); line-height: 1.6; }
    #ci-booking-widget .ci-info-box strong { color: var(--ci-ink); }
    /* Grid - WIDER CALENDAR COLUMN */
    #ci-booking-widget .ci-grid {
      display: grid;
      grid-template-columns: minmax(340px, 1.3fr) 1fr minmax(300px, 400px);
      gap: 24px;
      align-items: start;
    }
    @media (max-width: 1100px) {
      #ci-booking-widget .ci-grid { grid-template-columns: 1fr 1fr; }
      #ci-booking-widget .ci-grid > div:last-child { grid-column: span 2; }
    }
    @media (max-width: 768px) {
      #ci-booking-widget .ci-grid { grid-template-columns: 1fr; }
      #ci-booking-widget .ci-grid > div:last-child { grid-column: span 1; }
    }
    /* Card */
    #ci-booking-widget .ci-card { background: var(--ci-surface); border-radius: var(--ci-radius-xl); box-shadow: var(--ci-shadow-lg); overflow: hidden; border: 1px solid rgba(0,0,0,0.04); }
    #ci-booking-widget .ci-card-header { padding: 20px 24px 0; }
    #ci-booking-widget .ci-card-header h2 { font-size: 1.25rem; font-weight: 700; color: var(--ci-ink); margin-bottom: 4px; }
    #ci-booking-widget .ci-card-header p { font-size: 0.875rem; color: var(--ci-ink-muted); font-weight: 500; margin: 0; }
    #ci-booking-widget .ci-card-body { padding: 20px 24px 24px; }
    /* Calendar */
    #ci-booking-widget .ci-cal-nav { display: flex; align-items: center; justify-content: space-between; background: var(--ci-brand-primary); border-radius: var(--ci-radius-lg); padding: 14px 18px; margin-bottom: 16px; box-shadow: 0 4px 12px rgba(26, 54, 93, 0.25); }
    #ci-booking-widget .ci-cal-month { font-size: 1.25rem; font-weight: 700; color: white; letter-spacing: -0.01em; }
    #ci-booking-widget .ci-cal-btns { display: flex; gap: 8px; }
    #ci-booking-widget .ci-cal-btn { width: 40px; height: 40px; border: none; border-radius: var(--ci-radius-md); background: rgba(255,255,255,0.2); color: white; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.2s ease; font-weight: bold; }
    #ci-booking-widget .ci-cal-btn:hover { background: rgba(255,255,255,0.35); transform: scale(1.05); }
    #ci-booking-widget .ci-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
    #ci-booking-widget .ci-cal-dow { font-size: 0.6875rem; font-weight: 700; color: var(--ci-ink-muted); text-transform: uppercase; letter-spacing: 0.05em; text-align: center; padding: 8px 0; }
    #ci-booking-widget .ci-cal-day { aspect-ratio: 1; display: flex; align-items: center; justify-content: center; font-size: 0.875rem; font-weight: 600; border-radius: var(--ci-radius-md); cursor: pointer; transition: all 0.2s ease; background: var(--ci-surface-sunken); color: var(--ci-ink); border: 2px solid transparent; position: relative; }
    #ci-booking-widget .ci-cal-day:not(.ci-disabled):hover { background: #dbeafe; border-color: var(--ci-brand-secondary); transform: translateY(-2px); box-shadow: var(--ci-shadow-md); }
    #ci-booking-widget .ci-cal-day.ci-disabled { opacity: 0.3; cursor: not-allowed; background: transparent; }
    #ci-booking-widget .ci-cal-day.ci-empty { background: transparent; cursor: default; }
    #ci-booking-widget .ci-cal-day.ci-selected { background: var(--ci-brand-accent) !important; border-color: var(--ci-brand-accent) !important; color: white !important; transform: scale(1.05); box-shadow: 0 4px 12px rgba(237, 137, 54, 0.4); }
    #ci-booking-widget .ci-cal-day.ci-today::after { content: ''; position: absolute; bottom: 4px; width: 4px; height: 4px; border-radius: 50%; background: var(--ci-brand-accent); }
    #ci-booking-widget .ci-cal-day.ci-selected.ci-today::after { background: white; }
    #ci-booking-widget .ci-cal-hint { margin-top: 12px; font-size: 0.8125rem; color: var(--ci-ink-muted); display: flex; align-items: center; gap: 6px; }
    #ci-booking-widget .ci-cal-hint svg { width: 14px; height: 14px; }
    #ci-booking-widget .ci-selected-date-label { margin-top: 14px; padding: 10px 14px; background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%); border: 1px solid #93c5fd; border-radius: var(--ci-radius-md); font-size: 0.875rem; font-weight: 600; color: #1e40af; text-align: center; display: none; }
    #ci-booking-widget .ci-selected-date-label.ci-active { display: block; }
    /* Tabs */
    #ci-booking-widget .ci-tabs { display: flex; gap: 6px; padding: 0 24px; margin-bottom: -1px; position: relative; z-index: 1; flex-wrap: wrap; }
    #ci-booking-widget .ci-tab { padding: 12px 14px; font-size: 0.75rem; font-weight: 700; color: var(--ci-ink-muted); background: var(--ci-surface-sunken); border: 1px solid var(--ci-border); border-bottom: none; border-radius: var(--ci-radius-md) var(--ci-radius-md) 0 0; cursor: pointer; transition: all 0.2s ease; text-transform: uppercase; letter-spacing: 0.02em; }
    #ci-booking-widget .ci-tab:hover:not(.ci-active) { color: var(--ci-ink); background: var(--ci-surface-raised); }
    #ci-booking-widget .ci-tab.ci-active { background: var(--ci-surface); color: var(--ci-brand-primary); position: relative; }
    #ci-booking-widget .ci-tab.ci-active::after { content: ''; position: absolute; bottom: -1px; left: 0; right: 0; height: 2px; background: var(--ci-surface); }
    #ci-booking-widget .ci-panel { display: none; background: var(--ci-surface); border-top: 1px solid var(--ci-border); padding: 20px 24px 24px; animation: ciFadeIn 0.3s ease; }
    #ci-booking-widget .ci-panel.ci-active { display: block; }
    @keyframes ciFadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
    /* Offers */
    #ci-booking-widget .ci-offers { display: flex; flex-direction: column; gap: 10px; }
    #ci-booking-widget .ci-offer { display: flex; align-items: flex-start; gap: 14px; padding: 14px 16px; border: 2px solid var(--ci-border); border-radius: var(--ci-radius-lg); cursor: pointer; transition: all 0.2s ease; background: var(--ci-surface); }
    #ci-booking-widget .ci-offer:hover { border-color: var(--ci-border-focus); box-shadow: var(--ci-shadow-md); transform: translateY(-1px); }
    #ci-booking-widget .ci-offer.ci-selected { border-color: var(--ci-brand-accent); background: linear-gradient(135deg, #fffaf0 0%, #fff5eb 100%); box-shadow: 0 4px 12px rgba(237, 137, 54, 0.15); }
    #ci-booking-widget .ci-offer-radio { width: 20px; height: 20px; border: 2px solid var(--ci-border-focus); border-radius: 50%; flex-shrink: 0; margin-top: 2px; display: flex; align-items: center; justify-content: center; transition: all 0.2s ease; }
    #ci-booking-widget .ci-offer.ci-selected .ci-offer-radio { border-color: var(--ci-brand-accent); background: var(--ci-brand-accent); }
    #ci-booking-widget .ci-offer.ci-selected .ci-offer-radio::after { content: ''; width: 8px; height: 8px; background: white; border-radius: 50%; }
    #ci-booking-widget .ci-offer-content { flex: 1; min-width: 0; }
    #ci-booking-widget .ci-offer-title { font-weight: 700; font-size: 0.9375rem; color: var(--ci-ink); margin-bottom: 2px; }
    #ci-booking-widget .ci-offer-desc { font-size: 0.8125rem; color: var(--ci-ink-muted); font-weight: 500; }
    #ci-booking-widget .ci-offer-meta { text-align: right; flex-shrink: 0; }
    #ci-booking-widget .ci-offer-price { font-size: 1.25rem; font-weight: 700; color: var(--ci-ink); }
    #ci-booking-widget .ci-offer-save { display: inline-block; margin-top: 4px; padding: 3px 8px; background: var(--ci-success-soft); color: #166534; font-size: 0.6875rem; font-weight: 700; border-radius: 999px; text-transform: uppercase; }
    #ci-booking-widget .ci-offers-hint { margin-top: 14px; padding: 12px 14px; background: #fff7ed; border: 1px solid #fed7aa; border-radius: var(--ci-radius-md); font-size: 0.8125rem; color: #9a3412; font-weight: 600; }
    #ci-booking-widget .ci-offers-hint a { color: inherit; font-weight: 700; }
    #ci-booking-widget .ci-section-divider { margin: 16px 0 12px; padding-bottom: 8px; border-bottom: 1px solid var(--ci-border); font-size: 0.75rem; font-weight: 700; color: var(--ci-ink-muted); text-transform: uppercase; letter-spacing: 0.05em; }
    /* Basket */
    #ci-booking-widget .ci-sticky { position: sticky; top: 24px; }
    @media (max-width: 768px) { #ci-booking-widget .ci-sticky { position: static; } }
    #ci-booking-widget .ci-basket-date { background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%); border: 1px solid #93c5fd; border-radius: var(--ci-radius-lg); padding: 14px 16px; text-align: center; margin-bottom: 16px; }
    #ci-booking-widget .ci-basket-date-label { font-size: 0.75rem; font-weight: 700; color: #1e40af; text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 2px; }
    #ci-booking-widget .ci-basket-date-value { font-size: 1.125rem; font-weight: 600; color: #1e3a8a; }
    #ci-booking-widget .ci-basket-date.ci-empty .ci-basket-date-value { color: #3b82f6; font-size: 0.9375rem; }
    #ci-booking-widget .ci-basket-summary { background: var(--ci-surface-sunken); border: 1px solid var(--ci-border); border-radius: var(--ci-radius-lg); padding: 16px; }
    #ci-booking-widget .ci-basket-empty { text-align: center; padding: 20px 0; color: var(--ci-ink-muted); font-weight: 600; }
    #ci-booking-widget .ci-basket-items { display: flex; flex-direction: column; gap: 10px; }
    #ci-booking-widget .ci-basket-item { background: var(--ci-surface); border: 1px solid var(--ci-border); border-radius: var(--ci-radius-md); padding: 12px 14px; display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
    #ci-booking-widget .ci-basket-item-name { font-weight: 700; font-size: 0.9375rem; color: var(--ci-ink); margin-bottom: 4px; }
    #ci-booking-widget .ci-basket-item-includes { font-size: 0.8125rem; color: var(--ci-ink-muted); font-weight: 500; }
    #ci-booking-widget .ci-basket-item-price { font-size: 1rem; font-weight: 700; color: var(--ci-ink); white-space: nowrap; }
    #ci-booking-widget .ci-basket-fee { background: #fef3c7; border: 1px solid #fcd34d; }
    #ci-booking-widget .ci-basket-fee .ci-basket-item-name { color: #92400e; }
    #ci-booking-widget .ci-basket-fee .ci-basket-item-price { color: #92400e; }
    #ci-booking-widget .ci-basket-total { display: flex; justify-content: space-between; align-items: center; margin-top: 14px; padding-top: 14px; border-top: 2px dashed var(--ci-border); }
    #ci-booking-widget .ci-basket-total-label { font-weight: 700; color: var(--ci-ink); }
    #ci-booking-widget .ci-basket-total-value { font-size: 1.5rem; font-weight: 700; color: var(--ci-brand-primary); }
    /* Form */
    #ci-booking-widget .ci-form { margin-top: 20px; padding-top: 20px; border-top: 1px solid var(--ci-border); display: none; }
    #ci-booking-widget .ci-form.ci-active { display: block; animation: ciSlideUp 0.4s ease; }
    @keyframes ciSlideUp { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }
    #ci-booking-widget .ci-form-header { margin-bottom: 16px; }
    #ci-booking-widget .ci-form-header h3 { font-size: 1.125rem; font-weight: 700; color: var(--ci-ink); margin-bottom: 4px; }
    #ci-booking-widget .ci-form-header p { font-size: 0.8125rem; color: var(--ci-ink-muted); font-weight: 500; margin: 0; }
    #ci-booking-widget .ci-form-grid { display: grid; gap: 14px; }
    #ci-booking-widget .ci-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
    @media (max-width: 480px) { #ci-booking-widget .ci-form-row { grid-template-columns: 1fr; } }
    #ci-booking-widget .ci-field { display: flex; flex-direction: column; }
    #ci-booking-widget .ci-field label { font-size: 0.8125rem; font-weight: 700; color: var(--ci-ink); margin-bottom: 6px; }
    #ci-booking-widget .ci-field label.ci-required::after { content: ' *'; color: var(--ci-error); }
    #ci-booking-widget .ci-field input, #ci-booking-widget .ci-field select, #ci-booking-widget .ci-field textarea { padding: 12px 14px; border: 2px solid var(--ci-border); border-radius: var(--ci-radius-md); font-family: inherit; font-size: 0.9375rem; font-weight: 500; color: var(--ci-ink); background: var(--ci-surface); transition: all 0.2s ease; width: 100%; }
    #ci-booking-widget .ci-field input:focus, #ci-booking-widget .ci-field select:focus, #ci-booking-widget .ci-field textarea:focus { outline: none; border-color: var(--ci-brand-secondary); box-shadow: 0 0 0 3px rgba(44, 82, 130, 0.1); }
    #ci-booking-widget .ci-field textarea { min-height: 70px; resize: vertical; }
    #ci-booking-widget .ci-field select { cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23718096' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 40px; }
    #ci-booking-widget .ci-field-hint { margin-top: 4px; font-size: 0.75rem; color: var(--ci-ink-muted); }
    #ci-booking-widget .ci-postcode-status { margin-top: 6px; padding: 8px 12px; border-radius: var(--ci-radius-sm); font-size: 0.8125rem; font-weight: 600; display: none; }
    #ci-booking-widget .ci-postcode-status.ci-in-area { display: block; background: var(--ci-success-soft); color: #166534; border: 1px solid #86efac; }
    #ci-booking-widget .ci-postcode-status.ci-out-area { display: block; background: #fef3c7; color: #92400e; border: 1px solid #fcd34d; }
    #ci-booking-widget .ci-form-actions { display: flex; gap: 12px; margin-top: 20px; flex-wrap: wrap; }
    #ci-booking-widget .ci-btn { padding: 14px 24px; border: none; border-radius: var(--ci-radius-md); font-family: inherit; font-size: 0.9375rem; font-weight: 700; cursor: pointer; transition: all 0.2s ease; display: inline-flex; align-items: center; justify-content: center; gap: 8px; }
    #ci-booking-widget .ci-btn:disabled { opacity: 0.5; cursor: not-allowed; }
    #ci-booking-widget .ci-btn-secondary { background: var(--ci-surface-sunken); color: var(--ci-ink); }
    #ci-booking-widget .ci-btn-secondary:hover:not(:disabled) { background: var(--ci-border); }
    #ci-booking-widget .ci-btn-primary { background: var(--ci-brand-accent); color: white; flex: 1; }
    #ci-booking-widget .ci-btn-primary:hover:not(:disabled) { background: var(--ci-brand-accent-hover); transform: translateY(-2px); box-shadow: 0 6px 16px rgba(237, 137, 54, 0.35); }
    #ci-booking-widget .ci-btn-dark { background: var(--ci-brand-primary); color: white; flex: 1; }
    #ci-booking-widget .ci-btn-dark:hover:not(:disabled) { background: var(--ci-brand-secondary); transform: translateY(-2px); box-shadow: 0 6px 16px rgba(26, 54, 93, 0.35); }
    #ci-booking-widget .ci-form-disclaimer { margin-top: 14px; font-size: 0.75rem; color: var(--ci-ink-muted); line-height: 1.6; padding: 12px; background: var(--ci-surface-sunken); border-radius: var(--ci-radius-md); }
    /* Success */
    #ci-booking-widget .ci-success { display: none; margin-top: 20px; padding: 18px 20px; background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%); border: 1px solid #86efac; border-radius: var(--ci-radius-lg); }
    #ci-booking-widget .ci-success.ci-active { display: block; animation: ciScaleIn 0.4s ease; }
    @keyframes ciScaleIn { from { opacity: 0; transform: scale(0.95); } to { opacity: 1; transform: scale(1); } }
    #ci-booking-widget .ci-success-icon { width: 48px; height: 48px; background: var(--ci-success); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-bottom: 12px; }
    #ci-booking-widget .ci-success-icon svg { width: 24px; height: 24px; color: white; }
    #ci-booking-widget .ci-success h4 { font-size: 1.125rem; font-weight: 700; color: #065f46; margin-bottom: 4px; }
    #ci-booking-widget .ci-success p { font-size: 0.875rem; color: #047857; font-weight: 500; margin: 0; }
  </style>

  <!-- Header -->
  <header class="ci-header">
    <h1>Book Certificate Services</h1>
    <p>EPC, EICR and Gas Safety Certificate appointments</p>
    
    <!-- Trust Line -->
    <div class="ci-trust-line">
      <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10z"/></svg>
      <span><strong>Qualified, Certified Engineers</strong> — Our Gas Safe engineers, accredited EPC assessors, and qualified electricians are fully certified and insured.</span>
    </div>
    
    <div class="ci-badges">
      <span class="ci-badge">
        <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M22 11.08V12a10 10 0 1 1-5.93-9.14"/><polyline points="22 4 12 14.01 9 11.01"/></svg>
        Gas Safe Registered
      </span>
      <span class="ci-badge">
        <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M22 11.08V12a10 10 0 1 1-5.93-9.14"/><polyline points="22 4 12 14.01 9 11.01"/></svg>
        Accredited EPC Assessors
      </span>
      <span class="ci-badge">
        <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M22 11.08V12a10 10 0 1 1-5.93-9.14"/><polyline points="22 4 12 14.01 9 11.01"/></svg>
        Qualified Electricians
      </span>
    </div>
  </header>
  <!-- Notice -->
  <div class="ci-notice">
    <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><circle cx="12" cy="12" r="10"/><line x1="12" y1="8" x2="12" y2="12"/><line x1="12" y1="16" x2="12.01" y2="16"/></svg>
    <div>
      <h3>Appointment confirmation required</h3>
      <p>Request a date and pay now if you wish. We'll contact you within 24 hours to confirm the appointment time and assign the right operative.</p>
    </div>
  </div>

  <!-- Out of Area Info -->
  <div class="ci-info-box">
    <strong>Out of area fee (automatically applied):</strong> If your postcode is outside our London coverage areas (EC, WC, E, N, NW, SE, SW, W including districts such as E1W and W1K), a £35 travel fee will be added automatically.
  </div>

  <!-- Main Grid -->
  <div class="ci-grid">
    <!-- Calendar -->
    <div class="ci-card">
      <div class="ci-card-header">
        <h2>Select a date</h2>
        <p>Choose your preferred appointment day</p>
      </div>
      <div class="ci-card-body">
        <div class="ci-cal-nav">
          <span class="ci-cal-month" id="ciCalMonth"></span>
          <div class="ci-cal-btns">
            <button class="ci-cal-btn" id="ciPrevMonth" type="button" aria-label="Previous month">
              <svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5"><polyline points="15 18 9 12 15 6"/></svg>
            </button>
            <button class="ci-cal-btn" id="ciNextMonth" type="button" aria-label="Next month">
              <svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5"><polyline points="9 18 15 12 9 6"/></svg>
            </button>
          </div>
        </div>
        <div class="ci-cal-grid" id="ciCalGrid">
          <div class="ci-cal-dow">Mon</div>
          <div class="ci-cal-dow">Tue</div>
          <div class="ci-cal-dow">Wed</div>
          <div class="ci-cal-dow">Thu</div>
          <div class="ci-cal-dow">Fri</div>
          <div class="ci-cal-dow">Sat</div>
          <div class="ci-cal-dow">Sun</div>
        </div>
        <p class="ci-cal-hint">
          <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><circle cx="12" cy="12" r="10"/><line x1="12" y1="16" x2="12" y2="12"/><line x1="12" y1="8" x2="12.01" y2="8"/></svg>
          Sundays and past dates unavailable
        </p>
        <div class="ci-selected-date-label" id="ciSelectedDateLabel">
          <strong>Selected date:</strong> <span id="ciSelectedDateText"></span>
        </div>
      </div>
    </div>
    <!-- Services -->
    <div class="ci-card" style="overflow: visible;">
      <div class="ci-card-header">
        <h2>Choose a service</h2>
        <p>Select one option below</p>
      </div>
      <div class="ci-tabs">
        <button class="ci-tab ci-active" data-tab="singles" type="button">Single</button>
        <button class="ci-tab" data-tab="combos" type="button">Combos</button>
        <button class="ci-tab" data-tab="packages" type="button">Landlord</button>
      </div>
      
      <!-- Singles Panel -->
      <div class="ci-panel ci-active" data-panel="singles" id="ciPanelSingles">
        <div class="ci-offers" id="ciOffersSingles"></div>
        <div class="ci-offers-hint">Need multiple certificates? Switch to <strong>Combos</strong> to save.</div>
      </div>
      
      <!-- Combos Panel -->
      <div class="ci-panel" data-panel="combos" id="ciPanelCombos">
        <div class="ci-offers" id="ciOffersCombos"></div>
      </div>
      
      <!-- Packages Panel -->
      <div class="ci-panel" data-panel="packages" id="ciPanelPackages">
        <div class="ci-section-divider">1-2 Bedroom Properties</div>
        <div class="ci-offers" id="ciOffersPackages1to2"></div>
        
        <div class="ci-section-divider">3-4 Bedroom Properties</div>
        <div class="ci-offers" id="ciOffersPackages3to4"></div>
        
        <div class="ci-offers-hint" style="margin-top: 20px;">
          <strong>Prices shown apply to studios to 4 bedroom properties.</strong> For 5+ bedroom properties, an additional fee applies. We will confirm and agree this with you before the appointment is confirmed.<br><br>
          Got a 5+ bedroom property? Call us on <a href="tel:02034888072">020 3488 8072</a>.
        </div>
      </div>
    </div>
    <!-- Basket -->
    <div class="ci-sticky">
      <div class="ci-card">
        <div class="ci-card-header">
          <h2>Your Booking</h2>
        </div>
        <div class="ci-card-body">
          <div class="ci-basket-date ci-empty" id="ciBasketDate">
            <div class="ci-basket-date-label">Selected Date</div>
            <div class="ci-basket-date-value" id="ciBasketDateValue">Select a date on the calendar</div>
          </div>
          <div class="ci-basket-summary">
            <div class="ci-basket-empty" id="ciBasketEmpty">No service selected</div>
            <div id="ciBasketContent" style="display: none;">
              <div class="ci-basket-items" id="ciBasketItems"></div>
              <div class="ci-basket-total">
                <span class="ci-basket-total-label">Total</span>
                <span class="ci-basket-total-value" id="ciBasketTotal"></span>
              </div>
            </div>
          </div>
          <!-- Form -->
          <form class="ci-form" id="ciForm">
            <div class="ci-form-header">
              <h3>Your Details</h3>
              <p>We'll confirm your appointment within 24 hours</p>
            </div>
            <div class="ci-form-grid">
              <div class="ci-field">
                <label class="ci-required" for="ciName">Full name</label>
                <input type="text" id="ciName" name="name" required autocomplete="name">
              </div>
              <div class="ci-form-row">
                <div class="ci-field">
                  <label class="ci-required" for="ciEmail">Email</label>
                  <input type="email" id="ciEmail" name="email" required autocomplete="email">
                </div>
                <div class="ci-field">
                  <label class="ci-required" for="ciPhone">Phone</label>
                  <input type="tel" id="ciPhone" name="phone" required autocomplete="tel">
                </div>
              </div>
              <div class="ci-field">
                <label class="ci-required" for="ciPostcode">Postcode</label>
                <input type="text" id="ciPostcode" name="postcode" required autocomplete="postal-code" placeholder="e.g. SW1A 1AA" style="text-transform: uppercase;">
                <div class="ci-postcode-status" id="ciPostcodeStatus"></div>
              </div>
              <div class="ci-field">
                <label class="ci-required" for="ciAddress">Property address (excluding postcode)</label>
                <textarea id="ciAddress" name="address" required rows="2" placeholder="Street address, flat number, etc."></textarea>
              </div>
              <div class="ci-form-row">
                <div class="ci-field">
                  <label class="ci-required" for="ciType">Property type</label>
                  <select id="ciType" name="type" required>
                    <option value="">Select...</option>
                    <option value="residential">Residential</option>
                    <option value="hmo">HMO</option>
                    <option value="commercial">Commercial</option>
                  </select>
                </div>
                <div class="ci-field">
                  <label for="ciBeds">Bedrooms</label>
                  <select id="ciBeds" name="bedrooms">
                    <option value="">Select...</option>
                    <option value="studio">Studio</option>
                    <option value="1">1 Bedroom</option>
                    <option value="2">2 Bedrooms</option>
                    <option value="3">3 Bedrooms</option>
                    <option value="4">4 Bedrooms</option>
                    <option value="5+">5+ Bedrooms</option>
                  </select>
                </div>
              </div>
              <div class="ci-field">
                <label for="ciNotes">Access instructions or notes</label>
                <textarea id="ciNotes" name="notes" rows="2" placeholder="Access codes, parking info, tenant contact, etc."></textarea>
              </div>
            </div>
            <div class="ci-form-actions">
              <button class="ci-btn ci-btn-secondary" type="button" id="ciCancelBtn">Cancel</button>
              <button class="ci-btn ci-btn-primary" type="submit" id="ciRequestBtn">Request Booking</button>
              <button class="ci-btn ci-btn-dark" type="button" id="ciPayBtn" disabled>Pay Now</button>
            </div>
            <p class="ci-form-disclaimer">
              <strong>Payment does not confirm the appointment time.</strong> We will contact you within 24 hours to confirm availability and assign a qualified, certified operative. Paying now helps remove delays in certificate provision once the visit is completed.
            </p>
          </form>
          <!-- Success -->
          <div class="ci-success" id="ciSuccess">
            <div class="ci-success-icon">
              <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5"><polyline points="20 6 9 17 4 12"/></svg>
            </div>
            <h4>Request Received!</h4>
            <p>Thank you. We'll be in touch within 24 hours to confirm availability and assign your operative.</p>
          </div>
        </div>
      </div>
    </div>
  </div>


<script>
(function() {
  'use strict';
  
  // ========================================
  // PRICING CONFIGURATION
  // ========================================
  
  const PRICE_FLOORS = { EPC: 75, GAS: 80, EICR: 120 };
  const OUT_OF_AREA_FEE = 35;
  const IN_AREA_PREFIXES = ['EC', 'WC', 'E', 'N', 'NW', 'SE', 'SW', 'W'];
  const PACKAGE_UPLIFT = 20;
  
  // ========================================
  // OFFERS DATA
  // ========================================
  
  const SINGLES = [
    { id: 'epc', title: 'EPC (Energy Performance Certificate)', desc: 'Accredited assessment and certificate', includes: ['EPC'], price: 85 },
    { id: 'gas', title: 'Gas Safety Certificate (CP12)', desc: 'Gas Safe engineer inspection and certificate', includes: ['Gas Safety'], price: 85 },
    { id: 'eicr', title: 'EICR (Electrical Installation Condition Report)', desc: 'Qualified electrician safety testing and report', includes: ['EICR'], price: 170 }
  ];
  
  const COMBOS = [
    { id: 'cert-bundle', title: 'Cert Bundle', desc: 'EPC + Gas Safety', includes: ['EPC', 'Gas Safety'], price: 160, savings: 10 },
    { id: 'safety-duo', title: 'Safety Duo', desc: 'Gas Safety + EICR', includes: ['Gas Safety', 'EICR'], price: 230, savings: 25 },
    { id: 'full-compliance', title: 'Full Compliance', desc: 'EPC + Gas Safety + EICR', includes: ['EPC', 'Gas Safety', 'EICR'], price: 299, savings: 41 }
  ];
  
  const PACKAGES_1TO2 = [
    { id: 'landlord-essentials-1-2', title: 'Landlord Essentials (1-2 bed)', desc: 'EPC + Gas Safety + Check-In Inventory', includes: ['EPC', 'Gas Safety', 'Check-In Inventory'], price: 315, savings: 30 },
    { id: 'landlord-essentials-no-epc-1-2', title: 'Landlord Essentials \u2013 No EPC (1-2 bed)', desc: 'Gas Safety + Check-In Inventory', includes: ['Gas Safety', 'Check-In Inventory'], price: 240, savings: 20 },
    { id: 'landlord-standard-1-2', title: 'Landlord Standard (1-2 bed)', desc: 'EPC + Gas Safety + EICR + Check-In Inventory', includes: ['EPC', 'Gas Safety', 'EICR', 'Check-In Inventory'], price: 470, savings: 65 },
    { id: 'landlord-standard-no-epc-1-2', title: 'Landlord Standard \u2013 No EPC (1-2 bed)', desc: 'Gas Safety + EICR + Check-In Inventory', includes: ['Gas Safety', 'EICR', 'Check-In Inventory'], price: 395, savings: 50 },
    { id: 'landlord-premium-1-2', title: 'Landlord Premium (1-2 bed)', desc: 'EPC + Gas Safety + EICR + Check-In + Check-Out', includes: ['EPC', 'Gas Safety', 'EICR', 'Check-In', 'Check-Out'], price: 550, savings: 90 },
    { id: 'landlord-premium-no-epc-1-2', title: 'Landlord Premium \u2013 No EPC (1-2 bed)', desc: 'Gas Safety + EICR + Check-In + Check-Out', includes: ['Gas Safety', 'EICR', 'Check-In', 'Check-Out'], price: 475, savings: 75 }
  ];
  
  const PACKAGES_3TO4 = [
    { id: 'landlord-essentials-3-4', title: 'Landlord Essentials (3-4 bed)', desc: 'EPC + Gas Safety + Check-In Inventory', includes: ['EPC', 'Gas Safety', 'Check-In Inventory'], price: 365, savings: 35 },
    { id: 'landlord-essentials-no-epc-3-4', title: 'Landlord Essentials \u2013 No EPC (3-4 bed)', desc: 'Gas Safety + Check-In Inventory', includes: ['Gas Safety', 'Check-In Inventory'], price: 290, savings: 25 },
    { id: 'landlord-standard-3-4', title: 'Landlord Standard (3-4 bed)', desc: 'EPC + Gas Safety + EICR + Check-In Inventory', includes: ['EPC', 'Gas Safety', 'EICR', 'Check-In Inventory'], price: 540, savings: 75 },
    { id: 'landlord-standard-no-epc-3-4', title: 'Landlord Standard \u2013 No EPC (3-4 bed)', desc: 'Gas Safety + EICR + Check-In Inventory', includes: ['Gas Safety', 'EICR', 'Check-In Inventory'], price: 455, savings: 60 }
  ];
  
  const MONTHS = ['January','February','March','April','May','June','July','August','September','October','November','December'];
  
  // ========================================
  // STATE
  // ========================================
  let currentMonth = new Date();
  let selectedDate = null;
  let selectedOffer = null;
  let isOutOfArea = false;
  let postcodeChecked = false;
  
  // ========================================
  // DOM HELPERS
  // ========================================
  const widget = document.getElementById('ci-booking-widget');
  const $ = (sel) => widget.querySelector(sel);
  const $$ = (sel) => widget.querySelectorAll(sel);
  
  // ========================================
  // UTILITIES
  // ========================================
  const formatMoney = (n) => '\u00A3' + n;
  
  const formatDate = (d) => {
    const day = d.getDate();
    const s = ['th','st','nd','rd'][day % 10 > 3 ? 0 : (day % 100 - day % 10 !== 10) * day % 10];
    return MONTHS[d.getMonth()] + ' ' + day + s + ', ' + d.getFullYear();
  };
  
  const sameDay = (a, b) => a && b && a.getDate() === b.getDate() && a.getMonth() === b.getMonth() && a.getFullYear() === b.getFullYear();
  
  const validateEmail = (email) => /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(email);
  
  // ========================================
  // POSTCODE VALIDATION
  // ========================================
  function checkPostcode(postcode) {
    if (!postcode) return { valid: false, inArea: false };
    var clean = postcode.replace(/\s+/g, '').toUpperCase();
    var ukPostcodeRegex = /^[A-Z]{1,2}[0-9][0-9A-Z]?[0-9][A-Z]{2}$/;
    if (!ukPostcodeRegex.test(clean)) return { valid: false, inArea: false };
    var outwardMatch = clean.match(/^([A-Z]{1,2})([0-9]+[A-Z]?)/);
    if (!outwardMatch) return { valid: true, inArea: false };
    var areaLetters = outwardMatch[1];
    var inArea = IN_AREA_PREFIXES.some(function(prefix) {
      if (prefix.length === 2) return areaLetters === prefix;
      return areaLetters === prefix;
    });
    return { valid: true, inArea: inArea };
  }
  
  function handlePostcodeChange() {
    var postcodeInput = $('#ciPostcode');
    var statusEl = $('#ciPostcodeStatus');
    var postcode = postcodeInput.value.trim();
    if (!postcode) {
      statusEl.className = 'ci-postcode-status';
      statusEl.textContent = '';
      isOutOfArea = false;
      postcodeChecked = false;
      updateBasket();
      return;
    }
    var result = checkPostcode(postcode);
    if (!result.valid) {
      statusEl.className = 'ci-postcode-status';
      statusEl.textContent = '';
      isOutOfArea = false;
      postcodeChecked = false;
    } else if (result.inArea) {
      statusEl.className = 'ci-postcode-status ci-in-area';
      statusEl.textContent = '\u2713 Within London coverage area \u2013 no travel fee';
      isOutOfArea = false;
      postcodeChecked = true;
    } else {
      statusEl.className = 'ci-postcode-status ci-out-area';
      statusEl.textContent = '\u26A0 Outside London coverage \u2013 \u00A335 travel fee applies';
      isOutOfArea = true;
      postcodeChecked = true;
    }
    updateBasket();
  }
  
  // ========================================
  // CALENDAR
  // ========================================
  function renderCalendar() {
    var year = currentMonth.getFullYear();
    var month = currentMonth.getMonth();
    $('#ciCalMonth').textContent = MONTHS[month] + ' ' + year;
    var grid = $('#ciCalGrid');
    grid.querySelectorAll('.ci-cal-day').forEach(function(el) { el.remove(); });
    var first = new Date(year, month, 1);
    var last = new Date(year, month + 1, 0);
    var today = new Date(); today.setHours(0,0,0,0);
    var offset = first.getDay() === 0 ? 6 : first.getDay() - 1;
    selectedDate = null;
    updateSelectedDateLabel();
    for (var i = 0; i < offset; i++) {
      var c = document.createElement('div');
      c.className = 'ci-cal-day ci-empty ci-disabled';
      grid.appendChild(c);
    }
    for (var d = 1; d <= last.getDate(); d++) {
      var date = new Date(year, month, d);
      var c = document.createElement('div');
      c.className = 'ci-cal-day';
      c.textContent = d;
      var isPast = date < today;
      var isSunday = date.getDay() === 0;
      if (isPast || isSunday) {
        c.classList.add('ci-disabled');
      } else {
        (function(dt) {
          c.addEventListener('click', function() {
            selectedDate = dt;
            renderCalendarDays();
            updateSelectedDateLabel();
            updateBasket();
          });
        })(date);
      }
      if (sameDay(date, today)) c.classList.add('ci-today');
      if (sameDay(date, selectedDate)) c.classList.add('ci-selected');
      grid.appendChild(c);
    }
  }
  
  function renderCalendarDays() {
    var grid = $('#ciCalGrid');
    var days = grid.querySelectorAll('.ci-cal-day');
    var year = currentMonth.getFullYear();
    var month = currentMonth.getMonth();
    var today = new Date(); today.setHours(0,0,0,0);
    var dayNum = 1;
    var first = new Date(year, month, 1);
    var last = new Date(year, month + 1, 0);
    var offset = first.getDay() === 0 ? 6 : first.getDay() - 1;
    days.forEach(function(c, i) {
      if (i < offset || dayNum > last.getDate()) return;
      var date = new Date(year, month, dayNum);
      c.classList.toggle('ci-selected', sameDay(date, selectedDate));
      dayNum++;
    });
  }
  
  function updateSelectedDateLabel() {
    var label = $('#ciSelectedDateLabel');
    var text = $('#ciSelectedDateText');
    if (selectedDate) {
      text.textContent = formatDate(selectedDate);
      label.classList.add('ci-active');
    } else {
      label.classList.remove('ci-active');
    }
  }
  
  // ========================================
  // TABS
  // ========================================
  function setTab(name) {
    $$('.ci-tab').forEach(function(t) { t.classList.toggle('ci-active', t.dataset.tab === name); });
    $$('.ci-panel').forEach(function(p) { p.classList.toggle('ci-active', p.dataset.panel === name); });
  }
  
  // ========================================
  // OFFERS RENDERING
  // ========================================
  function createOfferElement(offer) {
    var div = document.createElement('div');
    div.className = 'ci-offer';
    div.dataset.id = offer.id;
    div.innerHTML = '<div class="ci-offer-radio"></div>' +
      '<div class="ci-offer-content">' +
      '<div class="ci-offer-title">' + offer.title + '</div>' +
      '<div class="ci-offer-desc">' + offer.desc + '</div>' +
      '</div>' +
      '<div class="ci-offer-meta">' +
      '<div class="ci-offer-price">' + formatMoney(offer.price) + '</div>' +
      (offer.savings ? '<div class="ci-offer-save">Save \u00A3' + offer.savings + '</div>' : '') +
      '</div>';
    div.addEventListener('click', function() { selectOffer(offer, div); });
    return div;
  }
  
  function renderOffers() {
    var singlesContainer = $('#ciOffersSingles');
    singlesContainer.innerHTML = '';
    SINGLES.forEach(function(o) { singlesContainer.appendChild(createOfferElement(o)); });
    var combosContainer = $('#ciOffersCombos');
    combosContainer.innerHTML = '';
    COMBOS.forEach(function(o) { combosContainer.appendChild(createOfferElement(o)); });
    var packages1to2Container = $('#ciOffersPackages1to2');
    packages1to2Container.innerHTML = '';
    PACKAGES_1TO2.forEach(function(o) { packages1to2Container.appendChild(createOfferElement(o)); });
    var packages3to4Container = $('#ciOffersPackages3to4');
    packages3to4Container.innerHTML = '';
    PACKAGES_3TO4.forEach(function(o) { packages3to4Container.appendChild(createOfferElement(o)); });
  }
  
  function selectOffer(offer, element) {
    $$('.ci-offer.ci-selected').forEach(function(el) { el.classList.remove('ci-selected'); });
    element.classList.add('ci-selected');
    selectedOffer = offer;
    updateBasket();
  }
  
  // ========================================
  // BASKET
  // ========================================
  function updateBasket() {
    var bd = $('#ciBasketDate');
    var bdv = $('#ciBasketDateValue');
    if (selectedDate) { bd.classList.remove('ci-empty'); bdv.textContent = formatDate(selectedDate); }
    else { bd.classList.add('ci-empty'); bdv.textContent = 'Select a date on the calendar'; }
    var basketEmpty = $('#ciBasketEmpty');
    var basketContent = $('#ciBasketContent');
    var basketItems = $('#ciBasketItems');
    var basketTotal = $('#ciBasketTotal');
    if (selectedOffer) {
      basketEmpty.style.display = 'none';
      basketContent.style.display = 'block';
      var total = selectedOffer.price;
      var itemsHTML = '<div class="ci-basket-item"><div>' +
        '<div class="ci-basket-item-name">' + selectedOffer.title + '</div>' +
        '<div class="ci-basket-item-includes">' + selectedOffer.includes.join(' \u2022 ') + '</div>' +
        '</div><div class="ci-basket-item-price">' + formatMoney(selectedOffer.price) + '</div></div>';
      if (isOutOfArea && postcodeChecked) {
        total += OUT_OF_AREA_FEE;
        itemsHTML += '<div class="ci-basket-item ci-basket-fee"><div>' +
          '<div class="ci-basket-item-name">Out of Area Travel Fee</div>' +
          '<div class="ci-basket-item-includes">Outside London coverage area</div>' +
          '</div><div class="ci-basket-item-price">' + formatMoney(OUT_OF_AREA_FEE) + '</div></div>';
      }
      basketItems.innerHTML = itemsHTML;
      basketTotal.textContent = formatMoney(total);
    } else {
      basketEmpty.style.display = 'block';
      basketContent.style.display = 'none';
    }
    var ready = selectedDate && selectedOffer;
    $('#ciForm').classList.toggle('ci-active', ready);
    $('#ciPayBtn').disabled = !ready;
  }
  
  // ========================================
  // FORM HANDLING (with email connection)
  // ========================================
  function handleSubmit(e) {
    e.preventDefault();
    if (!selectedDate || !selectedOffer) { alert('Please select a date and service.'); return; }
    var fd = new FormData($('#ciForm'));
    var data = Object.fromEntries(fd.entries());
    if (!data.name || !data.email || !data.phone || !data.postcode || !data.address || !data.type) {
      alert('Please complete all required fields.');
      return;
    }
    if (!validateEmail(data.email)) { alert('Please enter a valid email.'); return; }
    var postcodeResult = checkPostcode(data.postcode);
    if (!postcodeResult.valid) { alert('Please enter a valid UK postcode.'); return; }
    var finalTotal = selectedOffer.price;
    if (isOutOfArea) { finalTotal += OUT_OF_AREA_FEE; }
    var submitBtn = $('#ciRequestBtn');
    submitBtn.disabled = true;
    submitBtn.textContent = 'Sending...';
    var cfg = window.ciBookingConfig || {};
    var ajaxUrl = cfg.ajaxUrl || '/wp-admin/admin-ajax.php';
    var nonce = cfg.nonce || '';
    var formBody = new URLSearchParams();
    formBody.append('action', 'ci_booking_request');
    formBody.append('ci_nonce', nonce);
    formBody.append('name', data.name);
    formBody.append('email', data.email);
    formBody.append('phone', data.phone);
    formBody.append('postcode', data.postcode || '');
    formBody.append('address', data.address);
    formBody.append('type', data.type);
    formBody.append('bedrooms', data.bedrooms || '');
    formBody.append('notes', data.notes || '');
    formBody.append('service', selectedOffer.title);
    formBody.append('price', formatMoney(selectedOffer.price));
    formBody.append('date', formatDate(selectedDate));
    formBody.append('includes', selectedOffer.includes.join(', '));
    formBody.append('outOfArea', isOutOfArea ? 'yes' : 'no');
    formBody.append('travelFee', isOutOfArea ? OUT_OF_AREA_FEE : 0);
    formBody.append('total', formatMoney(finalTotal));
    fetch(ajaxUrl, {
      method: 'POST',
      headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
      body: formBody.toString()
    })
    .then(function(r) { return r.json(); })
    .then(function(result) {
      submitBtn.disabled = false;
      submitBtn.textContent = 'Request Booking';
      if (result.success) {
        $('#ciForm').classList.remove('ci-active');
        $('#ciSuccess').classList.add('ci-active');
        $('#ciSuccess').scrollIntoView({ behavior: 'smooth', block: 'center' });
      } else {
        alert('Issue sending request: ' + (result.data || 'Unknown error'));
      }
    })
    .catch(function(err) {
      submitBtn.disabled = false;
      submitBtn.textContent = 'Request Booking';
      console.log('Connection issue:', err);
      alert('Connection issue. Please try again or call us.');
    });
  }
  
  function handleCancel() {
    selectedDate = null;
    selectedOffer = null;
    isOutOfArea = false;
    postcodeChecked = false;
    $$('.ci-offer.ci-selected').forEach(function(el) { el.classList.remove('ci-selected'); });
    renderCalendar();
    updateSelectedDateLabel();
    updateBasket();
    $('#ciForm').reset();
    $('#ciPostcodeStatus').className = 'ci-postcode-status';
    $('#ciSuccess').classList.remove('ci-active');
  }
  
  /**
   * Pay Now hook for Braintree integration
   */
  function handlePay() {
    if (!selectedDate || !selectedOffer) { alert('Select a date and service first.'); return; }
    var amount = selectedOffer.price;
    if (isOutOfArea) { amount += OUT_OF_AREA_FEE; }
    console.log('Payment:', { amount: amount, offer: selectedOffer, date: selectedDate, outOfArea: isOutOfArea, travelFee: isOutOfArea ? OUT_OF_AREA_FEE : 0 });
    alert('Braintree hook \u2013 connect your payment flow here. Amount: \u00A3' + amount);
  }
  
  // ========================================
  // INITIALIZATION
  // ========================================
  function init() {
    renderCalendar();
    renderOffers();
    updateBasket();
    $('#ciPrevMonth').addEventListener('click', function() {
      currentMonth.setMonth(currentMonth.getMonth() - 1);
      renderCalendar();
      updateBasket();
    });
    $('#ciNextMonth').addEventListener('click', function() {
      currentMonth.setMonth(currentMonth.getMonth() + 1);
      renderCalendar();
      updateBasket();
    });
    $$('.ci-tab').forEach(function(t) { t.addEventListener('click', function() { setTab(t.dataset.tab); }); });
    $('#ciForm').addEventListener('submit', handleSubmit);
    $('#ciCancelBtn').addEventListener('click', handleCancel);
    $('#ciPayBtn').addEventListener('click', handlePay);
    var postcodeInput = $('#ciPostcode');
    if (postcodeInput) {
      postcodeInput.addEventListener('blur', handlePostcodeChange);
      postcodeInput.addEventListener('input', function() {
        clearTimeout(this.checkTimeout);
        this.checkTimeout = setTimeout(handlePostcodeChange, 500);
      });
    }
  }
  
  if (document.readyState === 'loading') document.addEventListener('DOMContentLoaded', init);
  else init();

})();
</script>

</div>

<!-- End Click Inventories Certificate Booking Widget v2.0 -->[/vc_raw_html][/vc_column][/vc_row][vc_row][vc_column][vc_column_text]EPC + EICR + Gas Safety Certificate Bundle If you need an EPC + EICR + Gas Safety Certificate Bundle,…

    Learn More →

    Ready to work?

    Book now and await your inventory report!

    Book Your Inventory Now →