@font-face{font-family:CA Sansation;font-style:normal;font-weight:400;font-display:swap;src:url(/brand/fonts/Sansation-Regular.ttf)format("truetype")}@font-face{font-family:CA Sansation;font-style:normal;font-weight:700;font-display:swap;src:url(/brand/fonts/Sansation-Bold.ttf)format("truetype")}@font-face{font-family:CA Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/brand/fonts/Inter-Variable.ttf)format("truetype")}@font-face{font-family:CA Inter;font-style:italic;font-weight:100 900;font-display:swap;src:url(/brand/fonts/Inter-Italic-Variable.ttf)format("truetype")}:root{--background:#f4f2ed;--surface:#ffffffe6;--surface-solid:#fff;--ink:#223248;--muted:#617083;--charcoal:#4e4b48;--line:#1a4ea229;--blue:#1a4ea2;--blue-bright:#1c8ece;--blue-deep:#0a2d68;--yellow:#fbd872;--red:#d22730;--green:#087f5b;--shadow:0 24px 70px #0a2d6824;--radius-lg:28px;--radius-md:18px;--radius-sm:12px}*{box-sizing:border-box}html{min-height:100%}body{color:var(--ink);background-blend-mode:normal, normal, normal, multiply;background-color:#0000;background-image:radial-gradient(circle at 15% 8%,#1c8ece33,#0000 34rem),radial-gradient(circle at 88% 0,#fbd8723d,#0000 30rem),linear-gradient(135deg,#f4f2edf5,#eff6fbf5),url(/brand/elements/ca-concrete.webp);background-position:0 0,0 0,0 0,0 0;background-repeat:repeat,repeat,repeat,repeat;background-size:auto,auto,auto,auto;background-attachment:fixed;background-origin:padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box;min-height:100%;margin:0;font-family:CA Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;position:relative}body:before{content:"";opacity:.28;pointer-events:none;z-index:0;background:linear-gradient(#f4f2ed40,#f4f2ede0),url(/brand/elements/ca-water-overlay.webp) top/cover no-repeat;position:fixed;inset:0}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}.shell{z-index:1;max-width:1220px;margin:0 auto;padding:22px;position:relative}.topbar{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);z-index:20;background:#ffffffd1;border:1px solid #ffffffc7;border-radius:999px;justify-content:space-between;align-items:center;gap:18px;margin:0 0 28px;padding:12px 14px 12px 20px;display:flex;position:sticky;top:14px;box-shadow:0 18px 48px #0a2d681f}.brand{color:var(--ink);align-items:center;gap:14px;min-width:0;display:inline-flex}.brand:hover{text-decoration:none}.brand-logo{object-fit:contain;width:172px;max-width:172px;height:auto}.brand-text{border-left:2px solid var(--yellow);color:var(--blue-deep);letter-spacing:.16em;text-transform:uppercase;padding-left:14px;font-family:CA Sansation,CA Inter,sans-serif;font-size:12px;font-weight:700;line-height:1.1}.nav,.auth-controls,.action-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.location-nav{flex:0 385px;grid-template-columns:repeat(3,max-content);justify-content:center;align-items:center;gap:5px 6px;min-width:300px;max-width:100%;display:grid}.location-pill{color:var(--blue-deep);letter-spacing:.055em;text-transform:uppercase;white-space:nowrap;background:#1a4ea214;border:1px solid #1a4ea21f;border-radius:999px;padding:6px 8px;font-size:9px;font-weight:900}.topbar .nav{justify-content:flex-end}.topbar .nav>a:not(.button){color:var(--blue-deep);border-radius:999px;padding:9px 12px;font-size:13px;font-weight:800}.topbar .nav>a:not(.button):hover{background:#1a4ea214;text-decoration:none}.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid #ffffffd1;padding:26px;position:relative;overflow:hidden}.card:before{background:linear-gradient(90deg, var(--blue), var(--blue-bright) 48%, var(--yellow));content:"";height:5px;position:absolute;inset:0 0 auto}.grid{gap:18px;display:grid}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.hero{grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr);align-items:center;gap:22px;min-height:290px;padding:34px;display:grid}.signin-card{text-align:center;place-items:center;min-height:360px;padding:56px 28px;display:grid}.signin-copy{justify-items:center;gap:20px;display:grid}.signin-copy h1{margin-bottom:0}.hero:after{content:"";opacity:.12;background:url(/brand/elements/ca-pool-flags-blue.png) 50%/contain no-repeat;width:260px;height:128px;position:absolute;top:22px;right:22px}.hero>*{z-index:1;position:relative}.hero h1,.page-intro h1,.hero p,.page-intro p{max-width:760px}.hero-panel{color:#fff;background:linear-gradient(135deg,#0a2d68f5,#1a4ea2f0),url(/brand/elements/ca-water-overlay.webp) 50%/cover no-repeat;border:1px solid #ffffff2e;border-radius:24px;min-height:168px;padding:24px;box-shadow:inset 0 1px #ffffff2e}.hero-panel strong{letter-spacing:-.01em;margin:8px 0 10px;font-family:CA Sansation,CA Inter,sans-serif;font-size:26px;display:block}.hero-panel p{color:#ffffffc7;margin:0}.hero .action-row{grid-column:1/-1}.stats-strip{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;display:grid}.stat{padding:22px 24px}.stat span{color:var(--muted);letter-spacing:.12em;text-transform:uppercase;font-size:12px;font-weight:850;display:block}.stat strong{color:var(--blue-deep);margin-top:10px;font-family:CA Sansation,CA Inter,sans-serif;font-size:42px;line-height:1;display:block}.page-intro{padding:32px}.record-header{justify-content:space-between;align-items:flex-start;gap:18px;display:flex}h1,h2,h3{color:var(--blue-deep);letter-spacing:-.025em;margin:0 0 14px;font-family:CA Sansation,CA Inter,sans-serif;font-weight:700;line-height:1.05}h1{font-size:clamp(38px,5vw,64px)}h2{font-size:clamp(24px,3vw,32px)}h3{font-size:18px}p{color:var(--muted);margin:0 0 18px;line-height:1.65}.eyebrow,.section-kicker{color:var(--blue);letter-spacing:.16em;text-transform:uppercase;margin-bottom:12px;font-size:11px;font-weight:900;line-height:1;display:inline-flex}.hero-panel .section-kicker{color:var(--yellow)}.section-heading{border-bottom:1px solid var(--line);margin-bottom:22px;padding-bottom:18px}.section-heading.compact{margin-bottom:14px;padding-bottom:12px}.section-heading p{max-width:760px;margin:0}label{color:#31445c;gap:8px;font-size:13px;font-weight:850;display:grid}input,select,textarea{border-radius:var(--radius-sm);color:var(--ink);font:inherit;background:#fffffff0;border:1px solid #1a4ea233;outline:none;width:100%;min-height:44px;padding:11px 12px;transition:border-color .16s,box-shadow .16s,background .16s}input:focus,select:focus,textarea:focus{border-color:var(--blue-bright);background:#fff;box-shadow:0 0 0 4px #1c8ece24}input[type=file]{padding:9px}input[type=file]::file-selector-button{color:var(--blue-deep);cursor:pointer;background:#1a4ea21a;border:0;border-radius:999px;margin-right:12px;padding:8px 12px;font-weight:850}textarea{resize:vertical;min-height:132px}.optional-label{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:11px;font-weight:800}.date-combo{grid-template-columns:minmax(0,1fr) 44px;align-items:center;gap:8px;display:grid;position:relative}.calendar-trigger{border-radius:var(--radius-sm);box-shadow:none;min-height:44px;padding:0}.calendar-trigger:hover{box-shadow:0 8px 18px #1a4ea22e}.native-date-picker{opacity:0;pointer-events:none;width:1px;height:1px;min-height:1px;padding:0;position:absolute;top:100%;right:0}button,.button{background:linear-gradient(135deg, var(--blue), var(--blue-deep));color:#fff;cursor:pointer;border:0;border-radius:999px;justify-content:center;align-items:center;gap:8px;min-height:42px;padding:11px 18px;font-weight:900;text-decoration:none;transition:box-shadow .16s,transform .16s,background .16s;display:inline-flex;box-shadow:0 12px 24px #1a4ea238}button:hover,.button:hover{text-decoration:none;transform:translateY(-1px);box-shadow:0 16px 30px #1a4ea247}button.secondary,.button.secondary{box-shadow:none;color:var(--blue-deep);background:#fff;border:1px solid #1a4ea22e}button.secondary:hover,.button.secondary:hover{background:#1a4ea214}button.danger{background:linear-gradient(135deg, var(--red), #a61922)}button:disabled{box-shadow:none;cursor:not-allowed;opacity:.58;transform:none}.contract-form>button[type=submit]{justify-self:start;min-width:180px;font-size:16px}.muted{color:var(--muted)}.pill{color:var(--blue-deep);background:#1a4ea21a;border:1px solid #1a4ea21f;border-radius:999px;max-width:100%;padding:7px 11px;font-size:12px;font-weight:900;display:inline-flex}.success{color:var(--green);font-weight:800}.error{color:var(--red);font-weight:800}.table{border-collapse:collapse;width:100%}.table th,.table td{border-bottom:1px solid var(--line);text-align:left;vertical-align:top;padding:14px 10px}.table th{color:var(--muted);letter-spacing:.12em;text-transform:uppercase;font-size:11px;font-weight:950}.table tbody tr:hover{background:#1c8ece0d}.section{margin-top:20px}.form-section{padding:28px}.admin-panel{overflow-x:auto}.admin-split{grid-template-columns:minmax(260px,.42fr) minmax(0,1fr);align-items:start;gap:22px;display:grid}.office-selector,.customer-selector{grid-template-columns:minmax(220px,.45fr) minmax(0,1fr);align-items:end;gap:14px;display:grid}.office-summary,.customer-summary{border-radius:var(--radius-md);background:#1a4ea212;border:1px solid #1a4ea21f;gap:4px;min-height:66px;padding:13px 16px;display:grid}.office-summary strong,.customer-summary strong{color:var(--blue-deep);font-weight:900}.office-summary span,.customer-summary span{color:var(--muted);font-size:13px;font-weight:700}.search-row{align-items:center;gap:10px;display:flex}.search-row input{flex:1;min-width:0}.salesforce-results{grid-column:1/-1;gap:10px;margin-top:4px;display:grid}.salesforce-result{border-radius:var(--radius-md);box-shadow:none;color:var(--text);text-align:left;background:#fff;border:1px solid #1a4ea224;justify-content:stretch;align-items:start;gap:3px;min-height:0;padding:12px 14px;display:grid}.salesforce-result:hover{box-shadow:none;background:#1a4ea20f}.salesforce-result strong{color:var(--blue-deep)}.salesforce-result span{color:var(--muted);font-size:13px}.checkbox-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.checkbox-row label{background:#ffffffb3;border:1px solid #1a4ea224;border-radius:999px;align-items:center;gap:8px;padding:8px 12px;font-weight:800;display:flex}.checkbox-row input{accent-color:var(--blue);width:auto;min-height:auto}.water-body-card,.season-card{background:linear-gradient(#ffffffdb,#f4f8fcdb),url(/brand/elements/ca-water-overlay.webp) 50%/cover no-repeat;border:1px solid #1a4ea21f;border-radius:22px;padding:18px}.season-card{gap:12px;display:grid}.estimate-card{background:linear-gradient(135deg, var(--blue-deep), var(--blue));color:#fff;border-radius:20px;margin:22px 0 0;padding:18px 20px;font-weight:850}.payment-editor{background:#1a4ea20a;border:1px solid #1a4ea21f;border-radius:22px;padding:18px}.payment-editor-header{justify-content:space-between;align-items:start;gap:18px;display:flex}.payment-editor-header p{margin-bottom:0}.toggle-row{white-space:nowrap;background:#fff;border:1px solid #1a4ea224;border-radius:999px;align-items:center;gap:8px;padding:9px 13px;display:flex}.toggle-row input{accent-color:var(--blue);width:auto;min-height:auto}.payment-actions{margin:16px 0 8px}.payment-table input{min-width:118px}.payment-summary{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.payment-summary span{color:var(--muted);background:#fff;border:1px solid #1a4ea21f;border-radius:999px;padding:8px 12px;font-size:13px;font-weight:800}.payment-summary strong{color:var(--blue-deep)}pre{color:#f7fbff;background:#10284f;border-radius:18px;padding:18px;line-height:1.55;overflow-x:auto}@media (max-width:920px){.topbar,.record-header{border-radius:24px;flex-direction:column;align-items:flex-start}.topbar .nav,.location-nav{justify-content:flex-start}.hero,.grid-2,.grid-3,.admin-split,.office-selector,.customer-selector,.stats-strip{grid-template-columns:1fr}.hero{padding:28px}.hero .action-row{grid-column:auto}}@media (max-width:560px){.shell{padding:12px}.brand{flex-direction:column;align-items:flex-start}.brand-text{border-left:0;border-top:2px solid var(--yellow);padding-top:10px;padding-left:0}.card,.page-intro,.form-section{border-radius:22px;padding:22px}h1{font-size:36px}button,.button{width:100%}}
