:root{
  --bg:#f5fbfa;
  --card:#ffffff;
  --text:#173132;
  --muted:#6c8081;
  --line:#dbe9e8;
  --primary:#10b3a3;
  --primary-dark:#0a8d81;
  --primary-soft:#e8faf7;
  --danger:#e05858;
  --warning:#ffb547;
  --success:#24a56a;
  --shadow:0 12px 35px rgba(16, 71, 67, .08);
  --radius:20px;
  --sidebar:270px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);height:auto!important;min-height:100%;overflow-y:auto!important;overflow-x:hidden;overscroll-behavior:auto}
body.modal-open{overflow:visible!important}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
img{max-width:100%;display:block}
.container{max-width:1280px;margin:0 auto;padding:0 18px}
.hidden{display:none!important}
.muted{color:var(--muted)}
.pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#eef7f6;color:var(--primary-dark);font-weight:600;font-size:13px}
.btn{border:0;border-radius:14px;padding:12px 16px;font-weight:700;cursor:pointer;transition:.2s;display:inline-flex;align-items:center;justify-content:center;gap:10px}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 10px 24px rgba(16,179,163,.22)}
.btn-primary:hover{background:var(--primary-dark)}
.btn-secondary{background:#fff;border:1px solid var(--line);color:var(--text)}
.btn-danger{background:var(--danger);color:#fff}
.btn-warning{background:var(--warning);color:#172728}
.btn-ghost{background:transparent;color:var(--primary-dark)}
.btn-sm{padding:9px 12px;border-radius:12px;font-size:14px}
.card{background:var(--card);border:1px solid rgba(219,233,232,.8);border-radius:var(--radius);box-shadow:var(--shadow)}
.page-section{padding:24px 0}
.hero{padding:26px 0 16px}
.header{position:sticky;top:0;z-index:20;background:rgba(245,251,250,.92);backdrop-filter:blur(8px);border-bottom:1px solid rgba(219,233,232,.7)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 0}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;font-size:22px}
.brand-badge{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,var(--primary),#73e0d7);display:grid;place-items:center;color:#fff;box-shadow:0 12px 30px rgba(16,179,163,.22)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:22px;align-items:start}
.hero-title{font-size:42px;line-height:1.04;margin:14px 0 12px;max-width:730px}
.hero-sub{font-size:17px;color:var(--muted);max-width:740px;line-height:1.6}
.motivation{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:20px}
.motivation .card{padding:18px;border-radius:18px;transition:transform .2s ease, box-shadow .2s ease}
.motivation .card:hover{transform:translateY(-2px)}
.motivation .icon{width:42px;height:42px;border-radius:14px;background:var(--primary-soft);display:grid;place-items:center;color:var(--primary-dark);margin-bottom:12px}
.motivation .badge{display:inline-block;margin-bottom:10px;padding:6px 10px;border-radius:999px;font-size:11px;font-weight:800;letter-spacing:.04em;background:#111827;color:#fff}
.motivation .note{margin-top:8px;font-size:13px;color:#64748b;line-height:1.45}
.motivation .card.primary{background:linear-gradient(135deg,#eef6ff,#f9fbff);border:1px solid #cfe3ff;box-shadow:0 10px 24px rgba(55,120,255,.08)}
.motivation .card.social{background:#f8fbfc}
.motivation .card.safe{background:#f0fdf4;border:1px solid #bbf7d0}
.motivation .card.safe .badge{background:#15803d}
.motivation .card.hidden{opacity:0;transform:translateY(8px)}
.motivation .card.show{opacity:1;transform:translateY(0);animation:pulseGlow 2.2s infinite}
@keyframes pulseGlow{0%{box-shadow:0 0 0 rgba(55,120,255,0)}50%{box-shadow:0 0 18px rgba(55,120,255,.18)}100%{box-shadow:0 0 0 rgba(55,120,255,0)}}
.grid-main{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:20px;align-items:start;overflow:visible}
.sticky{position:sticky;top:20px;align-self:start}
.panel{padding:20px}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.field label{font-size:14px;font-weight:700}
.field input,.field select,.field textarea{border:1px solid var(--line);background:#fff;border-radius:14px;padding:13px 14px;outline:none;min-height:46px}
.field textarea{min-height:110px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(16,179,163,.08)}
.hint{font-size:12px;color:var(--muted)}
.home-calc{margin-top:22px}
.step{margin-bottom:16px;overflow:visible}
.step-head{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:1px solid transparent;cursor:pointer}
.step.active .step-head{border-bottom-color:var(--line)}
.step-body{padding:20px;display:none}
.step.active .step-body{display:block}
.step-meta{display:flex;gap:10px;align-items:center;color:var(--muted);font-size:13px}
.option-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.option-card,.chip,.carousel-card,.toggle-card{border:1px solid var(--line);padding:14px;border-radius:18px;background:#fff;cursor:pointer;transition:.2s}
.option-card.active,.chip.active,.carousel-card.active,.toggle-card.active{border-color:var(--primary);box-shadow:0 0 0 4px rgba(16,179,163,.08);background:var(--primary-soft)}
.option-card .big{font-weight:800}
.chip-group,.toggle-group{display:flex;flex-wrap:wrap;gap:10px}
.chip{display:inline-flex;align-items:center;gap:8px;min-height:46px}
.carousel{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;overflow:auto;padding-bottom:4px}
.carousel-card h4{margin:0 0 6px;font-size:16px}
.carousel-card small{display:block;color:var(--muted);margin-bottom:10px}
.cleaning-type-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.cleaning-type-grid .carousel-card{min-height:132px;display:flex;flex-direction:column;justify-content:space-between}
.cleaning-type-grid .carousel-card h4{font-size:17px;line-height:1.25}
.cleaning-type-grid .carousel-card small{font-size:13px}
@media (max-width:560px){.cleaning-type-grid{grid-template-columns:1fr}.cleaning-type-grid .carousel-card{min-height:auto}}
.desc-toggle{font-weight:700;color:var(--primary-dark);cursor:pointer;font-size:14px;margin-top:8px}
.desc-content{display:none;font-size:13px;line-height:1.55;color:#284647;margin-top:10px}
.desc-content.open{display:block}
.motivation-delayed{opacity:0;transform:translateY(8px);transition:opacity .35s ease, transform .35s ease}
.motivation-delayed.show{opacity:1;transform:translateY(0)}
.season-info-card{padding:14px 16px;border:1px solid var(--line);border-radius:14px;background:#f8fcfc;min-height:46px}
.row{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.counter{display:flex;align-items:center;border:1px solid var(--line);border-radius:16px;overflow:visible;background:#fff}
.counter button{width:48px;height:48px;border:0;background:#fff;font-size:20px;cursor:pointer;color:var(--primary-dark)}
.counter span{flex:1;text-align:center;font-weight:800}
.switch{display:flex;gap:10px;flex-wrap:wrap}
.switch button{flex:1;min-width:120px}
.range-wrap{display:flex;align-items:center;gap:14px}
.range-wrap input[type=range]{flex:1}
.service-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.service-item{display:flex;justify-content:space-between;gap:12px;padding:14px;border:1px solid var(--line);border-radius:16px;background:#fff}
.summary-box{padding:22px}
.summary-line,.fin-line{display:flex;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px dashed #e5efee}
.summary-line:last-child,.fin-line:last-child{border-bottom:0}
.summary-total{font-size:34px;font-weight:800;margin:10px 0 8px}
.time-badge{display:inline-flex;padding:10px 14px;border-radius:14px;background:#eff9f7;font-weight:700;color:var(--primary-dark)}
.offer-box{margin-top:10px;padding-top:10px;border-top:1px solid var(--line)}
.app-shell{display:grid;grid-template-columns:260px minmax(0,1fr);gap:20px;align-items:start;overflow:visible}
.sidebar{position:sticky;top:20px;align-self:start;overflow:visible}
.side-nav{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.nav-link{padding:13px 14px;border-radius:14px;font-weight:700;color:#345;display:flex;align-items:center;gap:12px}
.nav-link.active,.nav-link:hover{background:var(--primary-soft);color:var(--primary-dark)}
.content-card{padding:20px}
.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse;background:#fff}
th,td{padding:14px 10px;border-bottom:1px solid #edf5f4;text-align:left;font-size:14px;vertical-align:top}
th{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.status{display:inline-flex;align-items:center;padding:7px 10px;border-radius:999px;font-size:12px;font-weight:700}
.s-new{background:#edf7ff;color:#246ea8}.s-accepted{background:#edfdf9;color:#118166}.s-progress{background:#fff8e8;color:#a56c12}.s-done{background:#eef7ff;color:#2d5ea7}.s-cancel{background:#ffefef;color:#aa4747}.s-paid{background:#eefcf3;color:#1f8b54}.s-pending{background:#fff8e8;color:#a56c12}.s-rejected{background:#ffefef;color:#aa4747}
.cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.order-card{padding:18px}
.order-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:12px 0}
.metric-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.metric{padding:18px}
.metric .v{font-size:28px;font-weight:800;margin-top:6px}
.fab-ratings{position:fixed;right:18px;bottom:96px;z-index:30;display:flex;flex-direction:column;gap:10px}
.fab-rate{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);padding:12px 14px;border-radius:16px;max-width:290px;display:flex;gap:12px;align-items:flex-start}
.mobile-sticky-order{display:none;position:fixed;left:12px;right:12px;bottom:12px;z-index:25;padding:10px 12px;border-radius:18px;background:#132c2b;color:#fff;box-shadow:0 18px 40px rgba(4,18,18,.26)}
.mobile-sticky-order .btn{width:auto}
.toast-wrap{position:fixed;right:16px;top:90px;z-index:100;display:flex;flex-direction:column;gap:10px}
.toast{min-width:260px;max-width:360px;background:#112524;color:#fff;padding:14px 16px;border-radius:16px;box-shadow:0 16px 30px rgba(0,0,0,.16);animation:slideIn .25s ease}
@keyframes slideIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.modal-backdrop{position:fixed;inset:0;background:rgba(17,29,29,.48);display:none;align-items:center;justify-content:center;padding:18px;z-index:80;pointer-events:none}
.modal-backdrop.show{display:flex;pointer-events:auto}
.modal{width:min(760px,100%);max-height:92vh;overflow:auto;background:#fff;border-radius:24px;box-shadow:0 30px 50px rgba(0,0,0,.18)}
.modal-header{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.modal-body{padding:22px}
.modal-close{width:42px;height:42px;border-radius:12px;border:1px solid var(--line);background:#fff;cursor:pointer}
.footer{padding:28px 0 36px;color:var(--muted)}
.stars{display:flex;gap:6px;font-size:24px;color:#ccc;cursor:pointer}
.stars .active{color:#ffbf3f}
.rating-radios{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0 16px}
.rating-radios input{display:none}
.rating-radios label{border:1px solid var(--line);border-radius:14px;padding:10px 12px;background:#fff;cursor:pointer;display:flex;align-items:center;gap:8px;min-width:68px;justify-content:center;font-weight:700;transition:.18s ease}
.rating-radios label:hover,.rating-radios .star-option:hover{border-color:var(--brand);transform:translateY(-1px)}
.rating-radios .star-option{border:1px solid var(--line);border-radius:14px;padding:10px 12px;background:#fff;cursor:pointer;display:flex;align-items:center;gap:8px;min-width:68px;justify-content:center;font-weight:700;transition:.18s ease}
.rating-radios .star-option.active{background:#ecfdf5;border-color:var(--brand);color:var(--brand-700);box-shadow:0 0 0 3px rgba(22,163,74,.1)}
.rating-radios input:checked + label{background:#ecfdf5;border-color:var(--brand);color:var(--brand-700);box-shadow:0 0 0 3px rgba(22,163,74,.1)}
.rating-prompt{margin:8px 0 12px;padding:12px 14px;border-radius:14px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412}
.rating-note-card{padding:12px 14px;border-radius:14px;background:#f8fafc;border:1px solid var(--line);margin-top:10px}
.object-tags-box{margin-top:16px;padding:14px;border-radius:18px;background:#f8fafc;border:1px solid var(--line)}
.object-tags-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.object-tag{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border-radius:999px;border:1px solid var(--line);background:#fff;font-size:13px;font-weight:700;color:#334155}
.object-tag.good{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.object-tag.neutral{background:#fffbeb;border-color:#fde68a;color:#92400e}.object-tag.caution{background:#fff7ed;border-color:#fed7aa;color:#9a3412}
.object-tag-input{display:inline-flex;align-items:center;gap:7px;padding:9px 11px;border-radius:999px;border:1px solid var(--line);background:#fff;cursor:pointer;font-weight:800;font-size:13px;transition:.16s ease}
.object-tag-input input{display:none}.object-tag-input:hover{transform:translateY(-1px);border-color:var(--brand)}
.object-tag-input:has(input:checked){background:#ecfdf5;border-color:var(--brand);color:var(--brand-700);box-shadow:0 0 0 3px rgba(16,179,163,.10)}
.object-insight{margin:10px 0 0;padding:12px;border-radius:16px;background:#f8fafc;border:1px solid var(--line)}
.recurring-card{padding:16px;border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:0 10px 26px rgba(17,29,29,.06)}
.recurring-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}
.recurring-title{font-size:16px;font-weight:900;color:#123332}
.recurring-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.recurring-pill{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;background:#f1f8f8;border:1px solid var(--line);font-size:12px;font-weight:800;color:#345}
.recurring-off{opacity:.58}
.auto-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 9px;border-radius:999px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;font-size:12px;font-weight:900;margin:4px 6px 4px 0}
.auto-badge.pending{background:#fff7ed;border-color:#fed7aa;color:#9a3412}

.urgent-cleaner-box{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 10px;align-items:center}
.urgent-badge,.urgent-countdown{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;font-size:12px;font-weight:900}
.urgent-badge{background:#fff7ed;border:1px solid #fdba74;color:#c2410c}
.urgent-countdown{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}
.auto-confirm-box{margin:10px 0;padding:12px 14px;border-radius:16px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412}
.manual-date-row{display:grid;grid-template-columns:1fr 150px auto;gap:8px;align-items:end;margin-top:8px}
.recurring-mode-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}
.recurring-mode-tabs label{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--line);border-radius:14px;background:#fff;font-weight:800;cursor:pointer}
.recurring-mode-tabs input{accent-color:var(--primary)}
@media(max-width:820px){.manual-date-row{grid-template-columns:1fr 1fr}.manual-date-row button{grid-column:1/-1}}

.cleaning-hints-box{border:1px solid rgba(15,23,42,.08);background:#f8fbff;border-radius:16px;padding:14px;margin-bottom:16px}
.cleaning-hints-box h4{margin:0 0 8px}
.checklist-box{border:1px solid rgba(16,179,163,.18);background:#f2fffc;border-radius:16px;padding:14px}
.checklist-list{display:grid;gap:10px;margin-top:12px}
.checkline{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;border:1px solid rgba(15,23,42,.08);border-radius:14px;background:#fff}
.checkline input{margin-top:4px;transform:scale(1.15)}
.checkline.done{border-color:rgba(16,179,163,.35);background:#f0fdfa}
.checklist-saved{display:grid;gap:8px;margin-top:10px}
.checklist-saved .item{display:flex;gap:8px;align-items:flex-start;padding:8px 10px;border:1px solid rgba(15,23,42,.06);border-radius:12px;background:#fff}
.fake-card{border-radius:24px;padding:20px;background:linear-gradient(135deg,#123f52,#1e9d91);color:#fff;min-height:220px;box-shadow:var(--shadow)}
.hamburger{display:none}
.rate-note{font-size:13px;color:var(--muted)}
.inline-actions{display:flex;gap:8px;flex-wrap:wrap}
.print-sheet{padding:28px;background:#fff;color:#111}
.map-link{color:var(--primary-dark);font-weight:700}

@media (max-width: 980px){
  .hero-grid,.grid-main,.app-shell{grid-template-columns:1fr}
  .metric-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 820px){
  .sticky,.sidebar{position:static;top:auto;max-height:none}

  .motivation,.option-grid,.row,.row-3,.cards-grid,.service-list,.metric-grid,.carousel{grid-template-columns:1fr}
  .hero-title{font-size:34px}
  .summary-total{font-size:28px}
  .header-inner{padding:12px 0}
  .sidebar{display:none}
  .sidebar.show{display:block}
  .hamburger{display:inline-flex}
  .mobile-sticky-order{display:flex;align-items:center;justify-content:space-between;gap:12px}
  .fab-ratings{bottom:86px}
}

.motivation{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:20px}
.motivation .card{padding:14px 16px;border-radius:18px;transition:transform .2s ease, box-shadow .2s ease}
.motivation .card:hover{transform:translateY(-2px)}
.motivation .badge{display:none}
.motivation .icon{width:auto;height:auto;border-radius:0;background:transparent;display:inline-grid;place-items:center;color:var(--primary-dark);margin:0;flex:0 0 auto;font-size:16px}
.motivation .headline{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:800;line-height:1.3;margin-bottom:8px}
.motivation .muted{font-size:13px;line-height:1.45}
.motivation .note{margin-top:6px;font-size:12px;color:#64748b;line-height:1.45}
.motivation .card.primary{background:linear-gradient(135deg,#eef6ff,#f9fbff);border:1px solid #cfe3ff;box-shadow:0 10px 24px rgba(55,120,255,.08)}
.motivation .card.social{background:#f8fbfc;border:1px solid #e6eef5}
.motivation .card.safe{background:#f0fdf4;border:1px solid #bbf7d0}
.motivation .card.hidden{opacity:0;transform:translateY(8px)}
.motivation .card.show{opacity:1;transform:translateY(0);animation:pulseGlow 2.2s infinite}
.motivation-modal-grid{display:grid;gap:12px}
.motivation-modal-card{padding:16px 18px;border-radius:16px;border:1px solid var(--line);background:#f8fbfc}
.motivation-modal-card.safe{background:#f0fdf4;border-color:#bbf7d0}
.motivation-modal-card.primary{background:linear-gradient(135deg,#eef6ff,#f9fbff);border-color:#cfe3ff}
.motivation-modal-title{display:flex;align-items:center;gap:10px;font-weight:800;margin-bottom:8px}


/* final sticky safety override */
.page-section,.container,.grid-main,.app-shell,.main-column{overflow:visible!important}
@media (min-width:821px){
  .sidebar,.sticky{position:sticky!important;top:20px!important;align-self:start!important}
}


@media (max-width: 820px){
  .motivation{
    display:flex !important;
    overflow-x:auto;
    gap:10px;
    margin-top:14px;
    padding-bottom:4px;
    scroll-snap-type:x proximity;
  }
  .motivation::-webkit-scrollbar{display:none}
  .motivation .card{
    min-width:260px;
    flex:0 0 260px;
    padding:12px 14px;
    border-radius:16px;
    scroll-snap-align:start;
  }
  .motivation .headline{
    font-size:14px;
    margin-bottom:6px;
  }
  .motivation .muted{
    font-size:12px;
    line-height:1.35;
  }
  .motivation .note{
    font-size:11px;
    line-height:1.35;
    margin-top:5px;
  }
}


/* desktop layout hotfix */
.hero-grid{grid-template-columns:minmax(0,1fr) 320px;max-width:320px;justify-self:end}
@media (max-width: 980px){
  .hero-grid,.grid-main,.app-shell{grid-template-columns:1fr!important}
  .summary-box{max-width:none;justify-self:stretch}
}


.guest-orders-card{position:sticky;top:20px;align-self:start}
@media (max-width: 980px){.guest-orders-card{position:static;top:auto}}


.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:22px;align-items:start}
.guest-orders-card{position:sticky;top:20px;align-self:start}
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr}
  .guest-orders-card{position:static;top:auto}
}


/* clean landing layout */
.landing-page{overflow:visible}
.landing-shell{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:22px;align-items:start}
.landing-main{min-width:0}
.landing-aside{min-width:0}
.landing-aside .guest-orders-card{position:sticky;top:20px;align-self:start}
.landing-hero .motivation{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:20px}
.landing-hero .motivation .card{min-width:0}
@media (max-width: 1100px){
  .landing-shell{grid-template-columns:1fr}
  .landing-aside .guest-orders-card{position:static;top:auto}
}
@media (max-width: 820px){
  .landing-hero .motivation{display:flex!important;overflow-x:auto;gap:10px;padding-bottom:4px;scroll-snap-type:x proximity}
  .landing-hero .motivation::-webkit-scrollbar{display:none}
  .landing-hero .motivation .card{min-width:260px;flex:0 0 260px;scroll-snap-align:start}
}



@media (max-width: 820px){
  .landing-hero .motivation{scroll-behavior:smooth}
  .landing-hero .motivation .card{scroll-snap-align:center}
}

/* anti-overlap final fix */
.hero-grid,.grid-main,.landing-layout,.landing-side,.landing-main,.summary-box,.guest-orders-card{position:relative}
.guest-orders-card{z-index:12; pointer-events:auto}
.guest-orders-card *{pointer-events:auto}
.summary-box{z-index:4}
.landing-main{z-index:2}
.landing-side{z-index:6}
.sticky,.sidebar{z-index:10}
.guest-orders-card .btn{position:relative; z-index:15}
.guest-orders-card input{position:relative; z-index:15}


/* final clickability fix for guest orders card */
.guest-orders-card{position:relative!important;z-index:50!important;pointer-events:auto!important}
.guest-orders-card .panel,.guest-orders-card .field,.guest-orders-card .btn,.guest-orders-card input{position:relative!important;z-index:60!important;pointer-events:auto!important}


/* landing aside strongest click layer */
.landing-aside{position:relative!important;z-index:80!important;pointer-events:auto!important}
.landing-aside *{pointer-events:auto!important}
.landing-aside .guest-orders-card{position:sticky;top:20px;z-index:90!important}


.guest-orders-card{position:relative!important;z-index:70!important;pointer-events:auto!important}
.guest-orders-card form,.guest-orders-card input,.guest-orders-card button{position:relative!important;z-index:71!important;pointer-events:auto!important}


.guest-orders-card{position:relative!important;z-index:90!important;pointer-events:auto!important}
.guest-orders-card *{pointer-events:auto!important}


.top-cleaners-block{margin:24px 0 32px}
.top-cleaners-header{text-align:center;margin-bottom:14px}
.top-cleaners-header h3{margin:0;font-size:18px}
.top-cleaners-header .subtitle{font-size:13px;color:#777;margin-top:4px}
.top-cleaners-list{display:flex;gap:14px;justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;padding-bottom:6px;scroll-snap-type:x proximity}
.top-cleaners-list::-webkit-scrollbar{display:none}
.cleaner-card{
  display:flex;gap:10px;align-items:center;background:#fff;border:1px solid #eee;border-radius:12px;
  padding:10px 12px;min-width:220px;flex:0 0 220px;scroll-snap-align:start;transition:.2s;box-shadow:0 4px 12px rgba(0,0,0,.03)
}
.cleaner-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.06)}
.cleaner-card .cleaner-thumb img{width:42px;height:42px;border-radius:50%;object-fit:cover}
.cleaner-card .cleaner-thumb .brand-badge{width:42px;height:42px;border-radius:50%}
.cleaner-card .name{font-size:14px;font-weight:600}
.cleaner-card .meta{font-size:12px;color:#888}
.cleaner-card .rating{font-size:12px;color:#444}
@media (max-width:768px){
  .top-cleaners-list{overflow-x:auto;flex-wrap:nowrap;padding-bottom:6px;justify-content:flex-start}
  .top-cleaners-list::-webkit-scrollbar{display:none}
  .cleaner-card{flex:0 0 auto;min-width:210px}
}


.photo-report-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px;margin-top:10px}
.photo-report-item{border:1px solid var(--line);border-radius:14px;padding:8px;background:#fff}
.photo-report-item img{width:100%;height:90px;object-fit:cover;border-radius:10px;display:block}
.photo-report-item .muted{font-size:11px;margin-top:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}


/* STEP 4 visual and quantity controls */
.step4-service-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.step4-service-card{border:1px solid rgba(15,23,42,.08);border-radius:20px;background:#fff;padding:16px;box-shadow:0 4px 18px rgba(15,23,42,.04)}
.step4-service-card.active{border-color:#99f6e4;background:linear-gradient(180deg,#f0fdfa,#fff)}
.step4-service-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.step4-service-title{font-weight:850;font-size:15px;line-height:1.3}
.step4-service-desc{font-size:12px;color:#64748b;line-height:1.45;margin-top:6px}
.step4-service-price{display:inline-flex;align-items:center;padding:7px 10px;border-radius:999px;background:#f8fafc;font-size:12px;font-weight:800;white-space:nowrap}
.step4-service-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px}
.step4-qty{display:flex;align-items:center;gap:8px}
.step4-qty button{width:32px;height:32px;border:none;border-radius:10px;background:#eef2f7;font-weight:900;cursor:pointer}
.step4-qty span{min-width:28px;text-align:center;font-weight:900}
@media(max-width:820px){.step4-service-grid{grid-template-columns:1fr}}


/* FINAL STEP2 REDESIGN */
.step2-modern-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px}
.step2-modern-card{border:1px solid rgba(15,23,42,.08);border-radius:22px;padding:18px;background:#fff;box-shadow:0 6px 22px rgba(15,23,42,.04);transition:.2s ease}
.step2-modern-card.active{border-color:#99f6e4;background:linear-gradient(180deg,#f0fdfa,#fff)}
.step2-modern-card:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(15,23,42,.08)}
.step2-modern-top{display:flex;justify-content:space-between;gap:12px}
.step2-modern-left{display:flex;gap:12px}
.step2-modern-icon{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:#f1f5f9;font-size:20px}
.step2-modern-title{font-size:16px;font-weight:850;line-height:1.3}
.step2-modern-desc{font-size:13px;color:#64748b;line-height:1.45;margin-top:6px}
.step2-modern-badge{margin-top:14px;display:inline-flex;padding:8px 12px;border-radius:999px;background:#f8fafc;font-size:12px;font-weight:800}
.step2-modern-toggle{appearance:none;width:52px;height:30px;border-radius:999px;background:#dbe4ea;position:relative;cursor:pointer}
.step2-modern-toggle:checked{background:#14b8a6}
.step2-modern-toggle:after{content:'';position:absolute;top:4px;left:4px;width:22px;height:22px;border-radius:50%;background:#fff;transition:.2s ease}
.step2-modern-toggle:checked:after{left:26px}


/* STEP4 unified cards */
.step4-modern-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.step4-modern-card{border:1px solid rgba(15,23,42,.08);border-radius:22px;padding:18px;background:#fff;box-shadow:0 6px 22px rgba(15,23,42,.04);transition:.2s ease}
.step4-modern-card.active{border-color:#99f6e4;background:linear-gradient(180deg,#f0fdfa,#fff)}
.step4-modern-card:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(15,23,42,.08)}
.step4-modern-top{display:flex;justify-content:space-between;gap:12px}
.step4-modern-left{display:flex;gap:12px}
.step4-modern-icon{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:#f1f5f9;font-size:20px}
.step4-modern-title{font-size:16px;font-weight:850;line-height:1.3}
.step4-modern-desc{font-size:13px;color:#64748b;line-height:1.45;margin-top:6px}
.step4-modern-price{margin-top:14px;display:inline-flex;padding:8px 12px;border-radius:999px;background:#f8fafc;font-size:12px;font-weight:800}
.step4-modern-toggle{appearance:none;width:52px;height:30px;border-radius:999px;background:#dbe4ea;position:relative;cursor:pointer}
.step4-modern-toggle:checked{background:#14b8a6}
.step4-modern-toggle:after{content:'';position:absolute;top:4px;left:4px;width:22px;height:22px;border-radius:50%;background:#fff;transition:.2s ease}
.step4-modern-toggle:checked:after{left:26px}
.step4-modern-qty{display:flex;align-items:center;gap:8px;margin-top:14px}
.step4-modern-qty button{width:32px;height:32px;border:none;border-radius:10px;background:#eef2f7;font-weight:900;cursor:pointer}
.step4-modern-qty span{min-width:28px;text-align:center;font-weight:900}
.step4-modern-total{margin-top:10px;font-size:13px;font-weight:800;color:#0f766e}
.step4-popular{display:inline-flex;margin-top:10px;padding:5px 10px;border-radius:999px;background:#eff6ff;color:#2563eb;font-size:11px;font-weight:800}
@media(max-width:820px){.step4-modern-grid{grid-template-columns:1fr}}



/* FIX: compact mobile toggles in additional services */
.step4-modern-card,.step4-modern-top,.step4-modern-left{min-width:0;box-sizing:border-box}
.step4-modern-top{align-items:flex-start}
.step4-modern-left{flex:1 1 auto;overflow:hidden}
.step4-modern-left > div:last-child{min-width:0}
.step4-modern-title,.step4-modern-desc{overflow-wrap:anywhere;word-break:normal}
.step4-modern-toggle{flex:0 0 52px;min-width:52px;max-width:52px;box-sizing:border-box}
@media(max-width:480px){
  .step4-modern-card{padding:14px;border-radius:18px}
  .step4-modern-icon{width:40px;height:40px;border-radius:14px;font-size:17px;flex:0 0 40px}
  .step4-modern-left{gap:10px}
  .step4-modern-title{font-size:14px;line-height:1.25}
  .step4-modern-desc{font-size:12px;line-height:1.35}
  .step4-modern-price{margin-top:10px;padding:7px 10px;white-space:normal}
}

/* QUICK PHONE ORDER */
.quick-phone-order{
  margin:22px 0 18px;
  padding:18px;
  border-radius:24px;
  background:linear-gradient(135deg,#f0fdfa,#ffffff);
  border:1px solid #bbf7d0;
  box-shadow:0 10px 30px rgba(15,118,110,.08);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px
}
.quick-phone-left{
  display:flex;
  align-items:center;
  gap:14px
}
.quick-phone-icon{
  width:54px;
  height:54px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:#14b8a6;
  color:#fff;
  font-size:22px
}
.quick-phone-title{
  font-size:18px;
  font-weight:900
}
.quick-phone-sub{
  margin-top:4px;
  color:#64748b;
  font-size:14px
}
.quick-phone-number{
  font-weight:900;
  font-size:18px;
  white-space:nowrap
}
.quick-phone-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end
}
.mobile-call-sticky{
  display:none;
  position:fixed;
  left:12px;
  right:12px;
  bottom:12px;
  z-index:60;
  padding:12px;
  border-radius:20px;
  background:#0f766e;
  color:#fff;
  box-shadow:0 12px 36px rgba(15,118,110,.3);
  align-items:center;
  justify-content:space-between;
  gap:12px
}
.mobile-call-sticky a{
  color:#fff;
  text-decoration:none
}
.mobile-call-sticky .call-main{
  font-weight:900
}
.mobile-call-sticky .call-sub{
  font-size:12px;
  opacity:.85;
  margin-top:2px
}
.mobile-call-sticky .call-btn{
  background:#fff;
  color:#0f766e;
  padding:10px 14px;
  border-radius:14px;
  font-weight:900;
  white-space:nowrap
}
@media(max-width:820px){
  .quick-phone-order{
    flex-direction:column;
    align-items:stretch
  }
  .quick-phone-actions{
    justify-content:stretch
  }
  .quick-phone-actions .btn{
    width:100%;
    justify-content:center
  }
  .mobile-call-sticky{
    display:flex
  }
  body{
    padding-bottom:84px
  }
}


/* REPEAT LAST ORDERS */
.repeat-orders-block{margin:18px 0 18px}
.repeat-orders-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:12px}
.repeat-orders-title{font-size:20px;font-weight:900}
.repeat-orders-sub{color:#64748b;font-size:14px;margin-top:4px}
.repeat-orders-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.repeat-order-card{border:1px solid rgba(15,23,42,.08);border-radius:22px;background:#fff;box-shadow:0 6px 22px rgba(15,23,42,.04);padding:16px;min-height:126px;display:flex;flex-direction:column;justify-content:space-between;gap:12px}
.repeat-order-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.repeat-order-type{font-weight:900;font-size:16px;line-height:1.25}
.repeat-order-meta{color:#64748b;font-size:13px;line-height:1.45;margin-top:5px}
.repeat-order-price{padding:7px 10px;border-radius:999px;background:#f0fdfa;color:#0f766e;font-size:13px;font-weight:900;white-space:nowrap}
.repeat-order-address{color:#475569;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.repeat-order-bottom{display:flex;justify-content:space-between;align-items:center;gap:10px}
@media(max-width:820px){.repeat-orders-grid{display:flex;overflow-x:auto;gap:12px;padding-bottom:4px;scroll-snap-type:x proximity}.repeat-orders-grid::-webkit-scrollbar{display:none}.repeat-order-card{min-width:84%;scroll-snap-align:start}}


/* PHONE ORDER COMPROMISE FIX */
.compact-phone-help{
  margin:14px 0 12px!important;
  padding:12px 14px!important;
  border-radius:18px!important;
  background:#fff!important;
  border:1px solid rgba(15,23,42,.08)!important;
  box-shadow:0 4px 18px rgba(15,23,42,.04)!important
}
.compact-phone-help .quick-phone-icon{
  width:40px!important;
  height:40px!important;
  border-radius:14px!important;
  background:#f1f5f9!important;
  color:#0f766e!important;
  font-size:18px!important
}
.compact-phone-help .quick-phone-title{
  font-size:15px!important;
  font-weight:850!important
}
.compact-phone-help .quick-phone-sub{
  font-size:12px!important;
  line-height:1.35!important
}
.quick-phone-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:9px 12px;
  border-radius:14px;
  background:#f8fafc;
  color:#0f766e;
  font-weight:850;
  text-decoration:none;
  white-space:nowrap
}
@media(max-width:820px){
  .mobile-call-sticky{display:none!important}
  body{padding-bottom:0!important}
  .compact-phone-help{
    flex-direction:row!important;
    align-items:center!important
  }
  .compact-phone-help .quick-phone-actions{
    justify-content:flex-end!important
  }
  .quick-phone-link{
    font-size:13px;
    padding:8px 10px
  }
}
@media(max-width:560px){
  .compact-phone-help{
    display:flex!important;
    gap:10px!important
  }
  .compact-phone-help .quick-phone-sub{
    display:none
  }
}


/* MINIMAL KITCHEN TOGGLE — UI only, keeps kitchen boolean logic */
.kitchen-min-field{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:48px;padding:2px 0}
.kitchen-min-title{font-size:14px;font-weight:700}
.kitchen-min-toggle{position:relative;width:52px;height:30px;border:0;border-radius:999px;background:#d7dee5;cursor:pointer;transition:.2s ease;padding:0;flex:0 0 auto}
.kitchen-min-toggle:after{content:'';position:absolute;top:4px;left:4px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 2px 8px rgba(15,23,42,.18);transition:.2s ease}
.kitchen-min-toggle.active{background:var(--primary)}
.kitchen-min-toggle.active:after{left:26px}


/* DESKTOP SUMMARY SAFETY: keep total calculation on the right */
@media (min-width:981px){
  .grid-main{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:20px;align-items:start;overflow:visible}
  .grid-main > .sticky{position:sticky;top:20px;align-self:start}
}
@media (max-width:980px){
  .grid-main{grid-template-columns:1fr}
  .grid-main > .sticky{position:static;top:auto}
}


/* STEP 1 SAFE VISUAL GRID */
.step1-area-kitchen-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(220px,.72fr);
  gap:18px;
  align-items:end;
  margin-bottom:16px;
}
.step1-counters-row{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  align-items:end;
  margin-bottom:16px;
}
.step1-area-kitchen-row .field,
.step1-counters-row .field{margin-bottom:0}

/* MINIMAL KITCHEN TOGGLE */
.kitchen-min-field{
  min-height:48px;
  border:1px solid var(--line);
  border-radius:16px;
  background:#fff;
  padding:8px 12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.kitchen-min-title{font-size:14px;font-weight:800}
.kitchen-min-toggle{
  position:relative;
  width:52px;
  height:30px;
  border:0;
  border-radius:999px;
  background:#d7dee5;
  cursor:pointer;
  transition:.2s ease;
  padding:0;
  flex:0 0 auto;
}
.kitchen-min-toggle:after{
  content:'';
  position:absolute;
  top:4px;
  left:4px;
  width:22px;
  height:22px;
  border-radius:50%;
  background:#fff;
  box-shadow:0 2px 8px rgba(15,23,42,.18);
  transition:.2s ease;
}
.kitchen-min-toggle.active{background:var(--primary)}
.kitchen-min-toggle.active:after{left:26px}

/* ROOM LEVEL SEGMENTED CONTROL */
.room-level-wrap{margin:8px 0 16px}
.room-level-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.room-level-title{font-size:14px;font-weight:800}
.room-level-hint{font-size:12px;color:var(--muted);white-space:nowrap}
.room-level-segment{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  background:#fff;
  max-width:460px;
}
.room-level-btn{
  border:0;
  background:transparent;
  padding:14px 12px;
  font-weight:700;
  cursor:pointer;
  transition:.18s ease;
}
.room-level-btn:hover{background:#f8fbfb}
.room-level-btn.active{background:var(--primary-soft);color:var(--primary-dark)}
.room-level-btn + .room-level-btn{border-left:1px solid var(--line)}

/* FINAL DESKTOP CALCULATOR LAYOUT RESTORE */
@media (min-width:821px){
  .grid-main{
    display:grid!important;
    grid-template-columns:minmax(0,1fr) 320px!important;
    gap:20px!important;
    align-items:start!important;
    overflow:visible!important;
  }
  .grid-main > .card{min-width:0!important}
  .grid-main > aside.card.summary-box.sticky{
    position:sticky!important;
    top:20px!important;
    align-self:start!important;
    width:320px!important;
    max-width:320px!important;
    z-index:10!important;
  }
}
@media(max-width:820px){
  .grid-main{grid-template-columns:1fr!important}
  .grid-main > aside.card.summary-box.sticky{
    position:static!important;
    width:auto!important;
    max-width:none!important;
  }
  .step1-area-kitchen-row,
  .step1-counters-row{
    grid-template-columns:1fr;
    gap:14px;
  }
  .room-level-head{
    align-items:flex-start;
    flex-direction:column;
    gap:4px;
  }
  .room-level-segment{max-width:none}
}


/* ADMIN ORDER DETAIL PHOTO REVIEW */
.admin-detail-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin:12px 0;
}
.admin-detail-card{
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff;
  padding:14px;
}
.admin-detail-card h4{
  margin:0 0 8px;
}
.admin-photo-section{
  margin-top:12px;
}
@media(max-width:820px){
  .admin-detail-grid{grid-template-columns:1fr}
}


/* CUSTOMER ORDERS MOBILE CARDS */

.order-list-clean{display:grid;gap:14px}
.order-clean-card{border:1px solid rgba(15,23,42,.08);border-radius:24px;background:#fff;box-shadow:0 12px 34px rgba(15,23,42,.055);padding:16px;display:grid;gap:13px;overflow:hidden}
.order-clean-card.order-history-card{background:#fbfdff;box-shadow:0 8px 24px rgba(15,23,42,.04)}
.order-clean-top{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:start}
.order-date-tile{width:62px;min-width:62px;border-radius:18px;background:linear-gradient(180deg,#eff6ff,#fff);border:1px solid #dbeafe;text-align:center;padding:8px 6px;color:#1d4ed8}
.order-date-tile .day{font-size:22px;font-weight:950;line-height:1}
.order-date-tile .month{font-size:11px;font-weight:850;text-transform:uppercase;margin-top:3px}
.order-date-tile .time{font-size:12px;font-weight:900;margin-top:5px;color:#0f172a}
.order-clean-main{min-width:0}
.order-clean-title{font-size:18px;font-weight:950;line-height:1.22;margin:0 0 4px;color:#0f172a}
.order-clean-sub{color:var(--muted);font-size:13px;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.order-clean-side{text-align:right;display:grid;gap:7px;justify-items:end}
.order-clean-price{font-size:19px;font-weight:950;color:var(--primary-dark);white-space:nowrap}
.order-clean-badges{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.order-confirm-panel{background:#fff7ed;border:1px solid #fed7aa;border-radius:18px;padding:13px;display:grid;gap:10px;color:#9a3412}
.order-confirm-panel strong{display:block;color:#7c2d12;margin-bottom:2px}
.order-confirm-panel .order-main-actions{margin-top:2px}
.order-clean-info{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:8px}
.order-clean-info .info-chip{background:#f8fafc;border:1px solid rgba(15,23,42,.06);border-radius:16px;padding:10px 12px;min-width:0}
.order-clean-info .info-chip span{display:block;color:var(--muted);font-size:11px;margin-bottom:3px}
.order-clean-info .info-chip b{display:block;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.order-clean-person{display:flex;align-items:center;gap:10px;border:1px solid rgba(15,23,42,.06);background:#fff;border-radius:16px;padding:10px 12px}
.order-clean-person .avatar-small{width:34px;height:34px;border-radius:50%;object-fit:cover;background:#eef2ff}
.order-clean-actions{border-top:1px solid rgba(15,23,42,.06);padding-top:12px}
.order-main-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.order-main-actions .btn-primary{min-width:150px}
@media(max-width:820px){.order-clean-card{border-radius:22px;padding:14px}.order-clean-top{grid-template-columns:auto 1fr}.order-clean-side{grid-column:1/-1;text-align:left;justify-items:start;display:flex;justify-content:space-between;align-items:center;gap:10px}.order-clean-info{grid-template-columns:1fr}.order-main-actions{display:grid;grid-template-columns:1fr 1fr}.order-main-actions .btn{width:100%;justify-content:center}.order-main-actions .btn-primary{grid-column:1/-1;min-width:0}.order-date-tile{width:58px;min-width:58px}.order-clean-price{font-size:18px}}
@media(max-width:440px){.order-main-actions{grid-template-columns:1fr}.order-clean-side{display:grid}.order-clean-badges{width:100%}}

.customer-orders-mobile{display:none}
.customer-order-mobile-card{
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff;
  padding:14px;
  margin-bottom:12px;
  box-shadow:0 6px 18px rgba(15,23,42,.04);
}
.customer-order-mobile-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}
.customer-order-mobile-title{font-weight:900;line-height:1.25}
.customer-order-mobile-price{font-weight:900;color:var(--primary-dark);white-space:nowrap}
.customer-order-mobile-meta{display:grid;gap:8px;margin:10px 0}
.customer-order-mobile-line{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:8px 0;
  border-bottom:1px dashed #e5efee;
  font-size:13px;
}
.customer-order-mobile-line:last-child{border-bottom:0}
.customer-order-mobile-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}
.customer-order-mobile-actions .btn{flex:1 1 140px}
@media(max-width:820px){
  .customer-orders-table{display:none!important}
  .customer-orders-mobile{display:block}
}


/* ORDER COMPLEXITY STAGE 1 */
.complexity-card{
  margin:12px 0 16px;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid var(--line);
  background:#fff;
}
.complexity-card.medium{
  border-color:#fde68a;
  background:#fffbeb;
}
.complexity-card.high{
  border-color:#fed7aa;
  background:#fff7ed;
}
.complexity-card.crew{
  border-color:#fecaca;
  background:#fff1f2;
}
.complexity-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.complexity-title{
  font-weight:900;
  line-height:1.25;
}
.complexity-text{
  margin-top:5px;
  color:var(--muted);
  font-size:13px;
  line-height:1.45;
}
.complexity-score{
  padding:7px 10px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  font-weight:900;
  white-space:nowrap;
  font-size:12px;
}
.complexity-reasons{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:10px;
}
.complexity-reason{
  padding:5px 8px;
  border-radius:999px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(15,23,42,.08);
  font-size:12px;
  font-weight:700;
}


/* CLEANER DELAY STAGE 1 */
.delay-notice{
  margin:12px 0;
  padding:13px 14px;
  border-radius:16px;
  border:1px solid #fed7aa;
  background:#fff7ed;
  color:#9a3412;
}
.delay-notice.client{
  border-color:#bae6fd;
  background:#f0f9ff;
  color:#075985;
}
.delay-notice-title{
  font-weight:900;
  margin-bottom:5px;
}
.delay-notice-text{
  font-size:13px;
  line-height:1.45;
}
.delay-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.delay-option{
  border:1px solid var(--line);
  background:#fff;
  border-radius:14px;
  padding:11px 12px;
  cursor:pointer;
  font-weight:800;
}
.delay-option.active{
  border-color:var(--primary);
  background:var(--primary-soft);
  color:var(--primary-dark);
}
@media(max-width:560px){
  .delay-grid{grid-template-columns:1fr}
}



    /* Stable calculator step navigation */
    .calc-grid-sticky-layout{display:grid!important;grid-template-columns:minmax(0,1fr) 320px!important;gap:20px!important;align-items:start!important;overflow:visible!important}
    .calc-left-col{grid-column:1 / 2!important;min-width:0!important;overflow:visible!important}
    .calc-left-col > .calc-nav-outer{position:relative!important;width:100%!important;max-width:100%!important;margin:0 0 10px!important;padding:0!important;background:transparent!important}
    .calc-left-col > .calc-nav-outer.is-floating{position:fixed!important;top:72px!important;left:max(18px, calc((100vw - 1280px)/2 + 18px))!important;width:min(calc(100vw - 396px), 904px)!important;max-width:min(calc(100vw - 396px), 904px)!important;z-index:500!important}
    .calc-left-col > .calc-nav-outer .calc-step-nav{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:6px!important;width:100%!important;max-width:100%!important;margin:0!important;padding:6px!important;border:1px solid rgba(219,233,232,.9)!important;border-radius:16px!important;background:rgba(255,255,255,.96)!important;box-shadow:0 10px 24px rgba(16,71,67,.12)!important;overflow:hidden!important}
    .calc-step-pill{min-width:0!important;width:100%!important;min-height:38px!important;padding:6px 7px!important;border-radius:12px!important;display:flex!important;align-items:center!important;gap:6px!important;text-align:left!important}
    .calc-step-dot{width:20px!important;height:20px!important;min-width:20px!important;font-size:11px!important}
    .calc-step-text b{font-size:11.5px!important;line-height:1.1!important;white-space:nowrap!important}
    .calc-step-text small{display:none!important}
    .calc-grid-sticky-layout > .summary-box.sticky{grid-column:2 / 3!important;position:sticky!important;top:72px!important;align-self:start!important;z-index:70!important}
    #calc-step-1,#calc-step-2,#calc-step-3,#calc-step-4{scroll-margin-top:138px!important}
    @media(max-width:900px){
      .calc-grid-sticky-layout{display:block!important}
      .calc-left-col > .calc-nav-outer.is-floating{top:0!important;left:0!important;right:0!important;width:100%!important;max-width:100%!important;padding:0 8px!important;background:rgba(245,251,250,.96)!important}
      .calc-left-col > .calc-nav-outer .calc-step-nav{grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:5px!important;border-radius:0 0 14px 14px!important}
      .calc-step-pill{justify-content:center!important;padding:6px 4px!important;gap:4px!important}
      .calc-step-text b{font-size:10.5px!important}
      .calc-step-dot{width:18px!important;height:18px!important;min-width:18px!important;font-size:10px!important}
      .calc-grid-sticky-layout > .summary-box.sticky{position:static!important;width:auto!important;max-height:none!important;overflow:visible!important}
      #calc-step-1,#calc-step-2,#calc-step-3,#calc-step-4{scroll-margin-top:84px!important}
    }

    /* Visual restore: logo and calculator nav without ugly borders */
    .brand-icon-link,
    .brand-text-link{
      appearance:none!important;
      -webkit-appearance:none!important;
      border:0!important;
      background:transparent!important;
      box-shadow:none!important;
      outline:0!important;
      padding:0!important;
      margin:0!important;
      cursor:pointer!important;
    }
    .brand-icon-link:focus,
    .brand-text-link:focus{
      outline:none!important;
      box-shadow:none!important;
    }
    .brand-text-link{
      font:inherit!important;
      font-weight:800!important;
      color:inherit!important;
      line-height:1!important;
    }
    .brand-xl{
      color:#a100ff!important;
      font-weight:900!important;
    }

    .calc-left-col > .calc-nav-outer .calc-step-nav{
      border:0!important;
      background:rgba(255,255,255,.78)!important;
      box-shadow:0 8px 22px rgba(16,71,67,.07)!important;
      padding:5px!important;
      border-radius:14px!important;
    }
    .calc-step-pill{
      border:0!important;
      box-shadow:none!important;
      background:transparent!important;
    }
    .calc-step-pill.active{
      background:var(--primary-soft)!important;
      box-shadow:none!important;
    }
    .calc-step-pill.error{
      background:#fff1f2!important;
      box-shadow:none!important;
    }
    .calc-step-pill.done .calc-step-dot{
      background:#dcfce7!important;
      color:#15803d!important;
    }
    .calc-step-pill.error .calc-step-dot{
      background:#ef4444!important;
      color:#fff!important;
    }


    /* Fix calculator quick step panel visual alignment */
    .calc-left-col > .calc-nav-outer .calc-step-nav{
      display:grid!important;
      grid-template-columns:repeat(4,minmax(0,1fr))!important;
      gap:8px!important;
      align-items:stretch!important;
      padding:6px!important;
      overflow:hidden!important;
    }
    .calc-step-pill{
      display:flex!important;
      align-items:center!important;
      justify-content:flex-start!important;
      gap:8px!important;
      min-width:0!important;
      width:100%!important;
      height:42px!important;
      min-height:42px!important;
      padding:0 10px!important;
      border-radius:12px!important;
      line-height:1!important;
      white-space:nowrap!important;
      overflow:hidden!important;
    }
    .calc-step-dot{
      display:inline-flex!important;
      align-items:center!important;
      justify-content:center!important;
      width:22px!important;
      height:22px!important;
      min-width:22px!important;
      max-width:22px!important;
      border-radius:999px!important;
      font-size:12px!important;
      font-weight:900!important;
      line-height:1!important;
      flex:0 0 22px!important;
    }
    .calc-step-text{
      display:block!important;
      min-width:0!important;
      overflow:hidden!important;
      line-height:1!important;
    }
    .calc-step-text b{
      display:block!important;
      font-size:12px!important;
      line-height:1.1!important;
      white-space:nowrap!important;
      overflow:hidden!important;
      text-overflow:ellipsis!important;
    }
    .calc-step-text small{
      display:none!important;
    }
    .calc-step-pill.active{
      box-shadow:none!important;
    }
    @media(max-width:900px){
      .calc-left-col > .calc-nav-outer .calc-step-nav{
        gap:5px!important;
        padding:5px!important;
      }
      .calc-step-pill{
        height:38px!important;
        min-height:38px!important;
        padding:0 5px!important;
        gap:4px!important;
        justify-content:center!important;
      }
      .calc-step-dot{
        width:18px!important;
        height:18px!important;
        min-width:18px!important;
        max-width:18px!important;
        flex-basis:18px!important;
        font-size:10px!important;
      }
      .calc-step-text b{
        font-size:10.5px!important;
      }
    }


    /* Clean customer cleaning journal */
    .journal-clean-page{display:grid;gap:16px}
    .journal-clean-hero{padding:18px;display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:16px;align-items:start;background:linear-gradient(135deg,#ffffff,#f7fffd)}
    .journal-clean-hero h3{font-size:24px;margin:12px 0 6px}
    .journal-clean-hero p{max-width:760px;line-height:1.5}
    .journal-clean-filter{display:grid;gap:8px}
    .journal-clean-filter label{font-size:13px;font-weight:800;color:var(--muted)}
    .journal-clean-filter input{border:1px solid var(--line);background:#fff;border-radius:14px;padding:12px 14px;min-height:44px}
    .journal-clean-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
    .journal-clean-summary .card{padding:14px 16px;box-shadow:0 8px 22px rgba(15,23,42,.045)}
    .journal-clean-summary span{display:block;color:var(--muted);font-size:12px;font-weight:800}
    .journal-clean-summary b{display:block;font-size:28px;margin-top:4px;color:var(--text)}
    .journal-clean-summary small{display:block;color:var(--muted);font-size:12px}
    .journal-clean-list{display:grid;gap:14px}
    .journal-clean-card{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:22px;box-shadow:0 12px 30px rgba(15,23,42,.055);padding:16px;display:grid;gap:14px}
    .journal-clean-top{display:grid;grid-template-columns:48px minmax(0,1fr) auto;gap:12px;align-items:start}
    .journal-clean-icon{width:48px;height:48px;border-radius:16px;background:var(--primary-soft);color:var(--primary-dark);display:grid;place-items:center;font-size:18px}
    .journal-clean-main{min-width:0}
    .journal-clean-main h3{margin:8px 0 6px;font-size:18px;line-height:1.2;color:#0f172a}
    .journal-clean-address{color:var(--muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .journal-clean-price{font-size:21px;font-weight:950;color:var(--primary-dark);white-space:nowrap}
    .journal-clean-badges{display:flex;flex-wrap:wrap;gap:6px}
    .journal-badge{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:850;background:#f1f5f9;color:#334155}
    .journal-badge.auto{background:#eef6ff;color:#1d4ed8}
    .journal-badge.ok{background:#ecfdf5;color:#047857}
    .journal-badge.status{background:#f8fafc;color:#0f172a}
    .journal-clean-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
    .journal-clean-grid>div{background:#f8fafc;border:1px solid rgba(15,23,42,.05);border-radius:16px;padding:10px 12px;min-width:0}
    .journal-clean-grid span{display:block;font-size:11px;color:var(--muted);margin-bottom:4px}
    .journal-clean-grid b{display:block;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .journal-clean-details{border-top:1px solid rgba(15,23,42,.07);padding-top:10px}
    .journal-clean-details summary{cursor:pointer;font-weight:850;color:var(--primary-dark);list-style:none;display:inline-flex;gap:8px;align-items:center}
    .journal-clean-details summary::-webkit-details-marker{display:none}
    .journal-clean-checklist{margin-top:12px;background:#fbfdff;border:1px solid rgba(15,23,42,.06);border-radius:16px;padding:12px;overflow:auto}
    @media(max-width:820px){
      .journal-clean-hero{grid-template-columns:1fr}
      .journal-clean-summary{grid-template-columns:1fr}
      .journal-clean-top{grid-template-columns:42px minmax(0,1fr)}
      .journal-clean-price{grid-column:2;justify-self:start;font-size:18px}
      .journal-clean-grid{grid-template-columns:1fr 1fr}
    }
    @media(max-width:520px){
      .journal-clean-grid{grid-template-columns:1fr}
      .journal-clean-card{padding:14px;border-radius:18px}
    }


    /* Fix calculator jump on option clicks */
    .calc-left-col{
      padding-top:0!important;
    }
    .calc-left-col > .calc-nav-outer.is-floating + .card{
      margin-top:0!important;
    }
    .calc-left-col.nav-floating-active{
      padding-top:58px!important;
    }
    @media(max-width:900px){
      .calc-left-col.nav-floating-active{
        padding-top:48px!important;
      }
    }


    /* Rating modal favorite cleaner visual fix */
    .rating-cleaner-card{
      display:grid!important;
      grid-template-columns:54px minmax(0,1fr) 54px!important;
      gap:12px!important;
      align-items:center!important;
      margin:12px 0 8px!important;
      padding:12px!important;
      border:1px solid rgba(15,23,42,.08)!important;
      border-radius:18px!important;
      background:#fbfdff!important;
    }
    .rating-cleaner-card .avatar-small,
    .rating-cleaner-card img{
      width:48px!important;
      height:48px!important;
      border-radius:16px!important;
      object-fit:cover!important;
    }
    .rating-cleaner-info{min-width:0!important}
    .rating-cleaner-name{
      font-size:17px!important;
      font-weight:900!important;
      color:var(--text)!important;
      margin-bottom:4px!important;
    }
    .favorite-heart-btn{
      appearance:none!important;
      -webkit-appearance:none!important;
      width:44px!important;
      height:44px!important;
      min-width:44px!important;
      border-radius:14px!important;
      border:1px solid var(--line)!important;
      background:#fff!important;
      box-shadow:0 6px 16px rgba(15,23,42,.06)!important;
      display:grid!important;
      place-items:center!important;
      padding:0!important;
      margin:0!important;
      cursor:pointer!important;
      color:#94a3b8!important;
      font-size:0!important;
      line-height:1!important;
    }
    .favorite-heart-btn::before{
      content:'♡';
      font-size:28px!important;
      line-height:1!important;
      font-weight:900!important;
      color:#0f172a!important;
    }
    .favorite-heart-btn.active{
      background:#fff1f2!important;
      border-color:#fecdd3!important;
    }
    .favorite-heart-btn.active::before{
      content:'♥';
      color:#e11d48!important;
    }
    .favorite-heart-btn:hover{
      transform:translateY(-1px);
      border-color:#fecdd3!important;
    }

.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}

    /* Admin orders/archive responsive layout */
    .admin-orders-group{min-width:0;overflow:hidden}
    .admin-orders-group-head{gap:12px;align-items:flex-start}
    .admin-orders-table-wrap{width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;padding-bottom:4px}
    .admin-orders-table{min-width:1040px;width:100%;table-layout:fixed;border-collapse:collapse}
    .admin-orders-table th,.admin-orders-table td{vertical-align:top;white-space:normal;word-break:break-word}
    .admin-orders-table th{font-size:12px}
    .admin-orders-table td{font-size:13px}
    .admin-col-id{width:120px}
    .admin-col-customer{width:170px}
    .admin-col-cleaner{width:145px}
    .admin-col-datetime{width:125px}
    .admin-col-type{width:150px}
    .admin-col-price{width:95px;font-weight:900}
    .admin-col-payment{width:130px}
    .admin-col-rating{width:120px}
    .admin-col-status{width:140px}
    .admin-col-actions{width:230px}
    .admin-order-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
    .admin-order-actions .btn{white-space:nowrap}
    .admin-order-actions .pill{font-size:11px;padding:7px 9px}
    .admin-orders-mobile-list{display:none}
    .admin-order-mobile-card{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:18px;box-shadow:0 8px 24px rgba(15,23,42,.045);padding:14px;display:grid;gap:12px}
    .admin-order-mobile-card.late{border-color:#fecaca;background:#fffafa}
    .admin-order-mobile-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
    .admin-order-mobile-id{font-weight:950;color:#0f172a}
    .admin-order-mobile-price{font-weight:950;color:var(--primary-dark);white-space:nowrap}
    .admin-order-mobile-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
    .admin-order-mobile-grid>div{background:#f8fafc;border:1px solid rgba(15,23,42,.05);border-radius:14px;padding:9px 10px;min-width:0}
    .admin-order-mobile-grid span{display:block;color:var(--muted);font-size:11px;margin-bottom:4px}
    .admin-order-mobile-grid b,.admin-order-mobile-grid small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
    .admin-order-mobile-grid small{color:var(--muted);font-size:12px;margin-top:2px}
    .admin-delay-card{font-size:12px}
    @media(max-width:1100px){
      .admin-orders-table{min-width:980px}
      .admin-col-actions{width:205px}
    }
    @media(max-width:760px){
      .admin-orders-table-wrap{display:none}
      .admin-orders-mobile-list{display:grid;gap:12px}
      .admin-orders-group{padding:14px!important}
      .admin-orders-group-head{margin-bottom:12px}
      .admin-order-actions{display:grid;grid-template-columns:1fr 1fr}
      .admin-order-actions .btn,.admin-order-actions .pill{width:100%;justify-content:center}
    }
    @media(max-width:460px){
      .admin-order-mobile-grid{grid-template-columns:1fr}
      .admin-order-actions{grid-template-columns:1fr}
    }


    /* Admin orders/archive desktop grid layout */
    .admin-orders-group{min-width:0;overflow:hidden}
    .admin-orders-group-head{gap:12px;align-items:flex-start;margin-bottom:14px}
    .admin-orders-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:12px}
    .admin-order-grid-card{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:18px;box-shadow:0 8px 24px rgba(15,23,42,.045);padding:14px;display:grid;gap:11px;min-width:0}
    .admin-order-grid-card.late{border-color:#fecaca;background:#fffafa}
    .admin-order-grid-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
    .admin-order-grid-id{font-weight:950;color:#0f172a;line-height:1.2;word-break:break-word}
    .admin-order-grid-type{color:var(--muted);font-size:12px;margin-top:4px;line-height:1.25}
    .admin-order-grid-price{font-size:18px;font-weight:950;color:var(--primary-dark);white-space:nowrap}
    .admin-order-grid-status{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
    .admin-late-mini{display:inline-flex;align-items:center;gap:5px;border-radius:999px;background:#fff1f2;color:#991b1b;font-size:11px;font-weight:850;padding:6px 9px}
    .admin-order-grid-info{display:grid;grid-template-columns:1fr 1fr;gap:8px}
    .admin-order-grid-info>div{background:#f8fafc;border:1px solid rgba(15,23,42,.05);border-radius:14px;padding:9px 10px;min-width:0}
    .admin-order-grid-info span{display:block;color:var(--muted);font-size:11px;margin-bottom:4px}
    .admin-order-grid-info b,.admin-order-grid-info small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
    .admin-order-grid-info small{color:var(--muted);font-size:12px;margin-top:2px}
    .admin-delay-compact{background:#fff1f2;border:1px solid #fecaca;color:#991b1b;border-radius:14px;padding:10px;font-size:12px}
    .admin-order-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
    .admin-order-actions .btn{white-space:nowrap;padding:8px 10px}
    .admin-order-actions .pill{font-size:11px;padding:7px 9px}
    @media(min-width:1180px){
      .admin-orders-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
    }
    @media(max-width:860px){
      .admin-orders-grid{grid-template-columns:1fr}
      .admin-order-actions{display:grid;grid-template-columns:1fr 1fr}
      .admin-order-actions .btn,.admin-order-actions .pill{width:100%;justify-content:center}
    }
    @media(max-width:460px){
      .admin-order-grid-info{grid-template-columns:1fr}
      .admin-order-actions{grid-template-columns:1fr}
    }


    /* Customer live cleaner card in My Orders */
    .customer-cleaner-live-card{
      display:grid;
      grid-template-columns:54px minmax(0,1fr);
      gap:12px;
      align-items:start;
      padding:13px;
      border:1px solid rgba(16,179,163,.16);
      border-radius:18px;
      background:linear-gradient(135deg,#f7fffd,#ffffff);
      box-shadow:0 8px 22px rgba(16,71,67,.045);
    }
    .customer-cleaner-live-card.empty{
      border-color:rgba(15,23,42,.08);
      background:#f8fafc;
    }
    .customer-cleaner-avatar{
      width:54px;
      height:54px;
      border-radius:18px;
      object-fit:cover;
      background:#eef7f6;
      display:grid;
      place-items:center;
      color:var(--primary-dark);
      font-size:20px;
      box-shadow:0 6px 14px rgba(15,23,42,.06);
    }
    .customer-cleaner-body{min-width:0}
    .customer-cleaner-top{
      display:flex;
      justify-content:space-between;
      gap:10px;
      align-items:flex-start;
    }
    .customer-cleaner-name{
      font-size:17px;
      font-weight:950;
      color:#0f172a;
      line-height:1.15;
    }
    .customer-cleaner-status{
      margin-top:4px;
      display:flex;
      align-items:center;
      gap:6px;
      color:var(--primary-dark);
      font-size:12px;
      font-weight:850;
    }
    .live-dot{
      width:8px;
      height:8px;
      border-radius:999px;
      background:var(--success);
      box-shadow:0 0 0 4px rgba(36,165,106,.12);
      flex:0 0 8px;
    }
    .customer-cleaner-rating{
      border-radius:999px;
      padding:6px 9px;
      background:#fff7ed;
      color:#9a3412;
      font-weight:950;
      font-size:12px;
      white-space:nowrap;
    }
    .customer-cleaner-facts{
      display:flex;
      flex-wrap:wrap;
      gap:6px;
      margin-top:9px;
    }
    .customer-cleaner-facts span{
      display:inline-flex;
      align-items:center;
      gap:5px;
      border-radius:999px;
      background:#fff;
      border:1px solid rgba(15,23,42,.06);
      padding:6px 8px;
      color:#334155;
      font-size:11px;
      font-weight:800;
    }
    .customer-cleaner-note{
      margin-top:9px;
      color:var(--muted);
      font-size:12px;
      line-height:1.45;
    }
    @media(max-width:520px){
      .customer-cleaner-live-card{
        grid-template-columns:46px minmax(0,1fr);
        padding:11px;
      }
      .customer-cleaner-avatar{
        width:46px;
        height:46px;
        border-radius:15px;
      }
      .customer-cleaner-top{
        display:grid;
        gap:6px;
      }
      .customer-cleaner-rating{
        justify-self:start;
      }
    }


    /* Safe yellow 2XL logo */
    .brand-logo-v8{
      display:flex;
      align-items:center;
      gap:10px;
      user-select:none;
      line-height:1;
    }
    .brand-logo-v8 .logo-word{
      font-size:28px;
      font-weight:950;
      color:#111827;
      letter-spacing:-.03em;
    }
    .brand-logo-v8 .logo-pill{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      height:36px;
      min-width:70px;
      padding:0 13px;
      border-radius:12px;
      background:#facc15;
      color:#111827;
      font-size:26px;
      font-weight:950;
      box-shadow:0 8px 18px rgba(250,204,21,.25);
    }
    .brand-text-link{
      border:0!important;
      background:transparent!important;
      padding:0!important;
      box-shadow:none!important;
    }
    @media(max-width:640px){
      .brand-logo-v8 .logo-word{font-size:23px}
      .brand-logo-v8 .logo-pill{height:31px;min-width:58px;font-size:21px;border-radius:10px}
    }


    /* Admin finance report */
    .admin-finance-page{display:grid;gap:16px}
    .admin-finance-settings{background:linear-gradient(135deg,#ffffff,#f7fffd)}
    .finance-report-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
    .finance-report-card{border:1px solid rgba(15,23,42,.08);border-radius:18px;background:#fff;padding:14px;box-shadow:0 8px 22px rgba(15,23,42,.04)}
    .finance-report-card.good{background:#f0fdf4;border-color:#bbf7d0}
    .finance-report-card span{display:block;color:var(--muted);font-size:12px;font-weight:850}
    .finance-report-card b{display:block;font-size:22px;margin-top:5px;color:#0f172a}
    .finance-report-card small{display:block;margin-top:4px;color:var(--muted);font-size:12px}
    .finance-profit-total{margin-top:16px;border-radius:22px;background:#0f172a;color:#fff;padding:18px;display:flex;justify-content:space-between;gap:16px;align-items:center}
    .finance-profit-total span{font-weight:850;color:#cbd5e1}
    .finance-profit-total b{font-size:32px}
    @media(max-width:900px){.finance-report-grid{grid-template-columns:1fr 1fr}}
    @media(max-width:560px){.finance-report-grid{grid-template-columns:1fr}.finance-profit-total{display:grid}.finance-profit-total b{font-size:26px}}


    /* Customer delay alert restored */
    .client-delay-important,
    .customer-order-delay-strip{
      border:1px solid #fed7aa;
      border-left:6px solid #f97316;
      background:linear-gradient(135deg,#fff7ed,#ffffff);
      border-radius:18px;
      padding:13px 14px;
      box-shadow:0 10px 24px rgba(249,115,22,.10);
      color:#7c2d12;
    }
    .client-delay-important-title,
    .customer-order-delay-title{
      display:flex;
      align-items:center;
      gap:8px;
      font-weight:950;
      color:#9a3412;
      margin-bottom:6px;
    }
    .client-delay-important-title i,
    .customer-order-delay-title i{
      width:26px;
      height:26px;
      min-width:26px;
      border-radius:999px;
      display:grid;
      place-items:center;
      background:#ffedd5;
      color:#ea580c;
    }
    .client-delay-important-text,
    .customer-order-delay-text{
      font-size:13px;
      line-height:1.45;
      color:#7c2d12;
    }
    .client-delay-important-time,
    .customer-order-delay-time{
      margin-top:8px;
      display:inline-flex;
      align-items:center;
      gap:6px;
      border-radius:999px;
      background:#fff;
      border:1px solid #fed7aa;
      color:#9a3412;
      padding:7px 10px;
      font-size:12px;
      font-weight:900;
    }
    .customer-order-delay-strip{
      margin:2px 0 0;
    }


/* Recovery stable build */
.safe-render-error{
  border:1px solid #fecaca;
  background:#fff1f2;
  color:#991b1b;
  padding:12px 14px;
  border-radius:14px;
  font-weight:700;
}



/* =========================================================
   iPhone / narrow mobile layout hotfix — V3.0.1
   Keeps desktop UI intact, prevents customer calculator overflow
   ========================================================= */
html, body{
  width:100%;
  max-width:100%;
  overflow-x:hidden!important;
  -webkit-text-size-adjust:100%;
}
#app{
  width:100%;
  max-width:100vw;
  overflow-x:hidden;
}
.container,
.card,
.panel,
.content-card,
.step,
.step-head,
.step-body,
.summary-box,
.app-shell,
.grid-main,
.calc-grid-sticky-layout,
.calc-left-col,
.main-column,
.landing-shell,
.landing-main,
.landing-aside{
  min-width:0;
  box-sizing:border-box;
}
input, select, textarea, button{
  max-width:100%;
  box-sizing:border-box;
}

@media (max-width:820px){
  body{overflow-x:hidden!important;}
  .container{
    width:100%!important;
    max-width:100%!important;
    padding-left:max(12px, env(safe-area-inset-left))!important;
    padding-right:max(12px, env(safe-area-inset-right))!important;
  }
  .page-section{padding:14px 0!important;}
  .hero{padding:14px 0 8px!important;}
  .header-inner{gap:10px!important;}
  .brand{font-size:18px!important;min-width:0!important;}
  .brand-badge{width:40px!important;height:40px!important;min-width:40px!important;}
  .header .btn{padding:10px 12px!important;font-size:13px!important;}

  .hero-grid,
  .landing-shell,
  .grid-main,
  .calc-grid-sticky-layout,
  .app-shell{
    display:block!important;
    width:100%!important;
    max-width:100%!important;
    overflow-x:hidden!important;
  }
  .landing-main,
  .landing-aside,
  .calc-left-col,
  .grid-main > *,
  .app-shell > *,
  .main-column{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
  }

  .home-calc{margin-top:14px!important;width:100%!important;max-width:100%!important;}
  .hero-title{font-size:28px!important;line-height:1.1!important;overflow-wrap:anywhere;}
  .hero-sub{font-size:14px!important;line-height:1.45!important;}

  .card,.panel,.content-card,.step,.summary-box{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    overflow:hidden!important;
    border-radius:18px!important;
  }
  .panel,.content-card{padding:14px!important;}
  .step{margin-bottom:12px!important;}
  .step-head{
    padding:14px!important;
    gap:10px!important;
    align-items:flex-start!important;
  }
  .step-head > div{min-width:0!important;}
  .step-head b{display:block;line-height:1.25;overflow-wrap:anywhere;}
  .step-meta{font-size:12px!important;line-height:1.35!important;overflow-wrap:anywhere;}
  .step-body{padding:14px!important;overflow:hidden!important;}

  .row,
  .row-3,
  .option-grid,
  .service-list,
  .cleaning-type-grid,
  .step2-modern-grid,
  .step4-modern-grid,
  .cards-grid,
  .metric-grid{
    display:grid!important;
    grid-template-columns:minmax(0,1fr)!important;
    gap:10px!important;
    width:100%!important;
    max-width:100%!important;
  }

  .field{margin-bottom:12px!important;min-width:0!important;}
  .field input,
  .field select,
  .field textarea{
    width:100%!important;
    min-width:0!important;
    font-size:16px!important; /* prevents iOS zoom */
  }
  .range-wrap{display:grid!important;grid-template-columns:1fr!important;gap:8px!important;width:100%!important;}
  .range-wrap input[type=range]{width:100%!important;min-width:0!important;}
  .counter{width:100%!important;min-width:0!important;}

  .chip-group,
  .toggle-group,
  .switch,
  .inline-actions,
  .order-main-actions{
    width:100%!important;
    max-width:100%!important;
  }
  .inline-actions{display:grid!important;grid-template-columns:1fr!important;gap:8px!important;}
  .btn,
  .chip,
  .option-card,
  .carousel-card,
  .toggle-card,
  .service-item{
    max-width:100%!important;
    min-width:0!important;
    white-space:normal!important;
    overflow-wrap:anywhere!important;
  }
  .switch button{min-width:0!important;width:100%!important;}

  .summary-box{
    position:static!important;
    top:auto!important;
    padding:16px!important;
    margin-top:12px!important;
  }
  .summary-total{font-size:26px!important;line-height:1.1!important;}
  .summary-line,
  .fin-line{
    display:grid!important;
    grid-template-columns:minmax(0,1fr) auto!important;
    align-items:start!important;
    gap:8px!important;
    font-size:13px!important;
  }
  .summary-line span,
  .summary-line b,
  .fin-line span,
  .fin-line b{
    min-width:0!important;
    overflow-wrap:anywhere!important;
  }
  .summary-line b,.fin-line b{text-align:right!important;}

  .mobile-sticky-order{
    left:max(10px, env(safe-area-inset-left))!important;
    right:max(10px, env(safe-area-inset-right))!important;
    bottom:max(10px, env(safe-area-inset-bottom))!important;
    width:auto!important;
    max-width:calc(100vw - 20px)!important;
    box-sizing:border-box!important;
    border-radius:18px!important;
  }
  .mobile-sticky-order .btn{min-width:0!important;}

  .table-wrap{max-width:100%!important;overflow-x:auto!important;-webkit-overflow-scrolling:touch;}
  table{min-width:680px;}
}

@media (max-width:430px){
  .container{padding-left:10px!important;padding-right:10px!important;}
  .hero-title{font-size:25px!important;}
  .landing-hero .motivation .card,
  .motivation .card{
    min-width:calc(100vw - 40px)!important;
    flex-basis:calc(100vw - 40px)!important;
  }
  .step-head,.step-body,.panel,.content-card{padding:12px!important;}
  .summary-total{font-size:24px!important;}
}


/* =========================================================
   V3.0.3 — iPhone client header/topbar alignment fix
   Fixes logout/menu buttons after mobile hotfix without touching desktop
   ========================================================= */
@media (max-width:820px){
  .header{overflow:hidden!important;}
  .header-inner{
    display:grid!important;
    grid-template-columns:minmax(0,1fr) auto!important;
    align-items:center!important;
    gap:8px!important;
    min-height:64px!important;
  }
  .header .brand{
    width:auto!important;
    max-width:100%!important;
    min-width:0!important;
    overflow:hidden!important;
  }
  .header .brand-text-link,
  .header .brand-logo-v8{
    min-width:0!important;
    max-width:100%!important;
  }
  .header .inline-actions{
    width:auto!important;
    max-width:44vw!important;
    min-width:0!important;
    display:flex!important;
    grid-template-columns:none!important;
    flex-direction:column!important;
    align-items:stretch!important;
    justify-content:center!important;
    gap:5px!important;
    margin-left:auto!important;
  }
  .header .inline-actions .pill{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    padding:5px 8px!important;
    font-size:12px!important;
    line-height:1.15!important;
    justify-content:flex-start!important;
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
  }
  .header .inline-actions .btn{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    padding:7px 10px!important;
    min-height:34px!important;
    font-size:13px!important;
    line-height:1!important;
    justify-content:center!important;
    white-space:nowrap!important;
  }
  .app-shell > section{min-width:0!important;width:100%!important;max-width:100%!important;}
  .topbar{
    display:grid!important;
    grid-template-columns:minmax(0,1fr) auto!important;
    align-items:start!important;
    gap:10px!important;
    width:100%!important;
    max-width:100%!important;
    overflow:hidden!important;
  }
  .topbar > div{min-width:0!important;max-width:100%!important;}
  .topbar h2{
    font-size:24px!important;
    line-height:1.12!important;
    overflow-wrap:anywhere!important;
  }
  .topbar .muted{font-size:14px!important;line-height:1.3!important;}
  .topbar .hamburger{
    width:auto!important;
    min-width:104px!important;
    max-width:118px!important;
    padding:10px 12px!important;
    justify-content:center!important;
    white-space:nowrap!important;
    align-self:start!important;
  }
}
@media (max-width:430px){
  .header-inner{grid-template-columns:minmax(0,1fr) minmax(118px,40vw)!important;}
  .header .inline-actions{max-width:40vw!important;}
  .brand-badge{width:38px!important;height:38px!important;min-width:38px!important;}
  .brand-logo-v8 .logo-word{font-size:20px!important;letter-spacing:-.8px!important;}
  .brand-logo-v8 .logo-pill{font-size:18px!important;padding:2px 5px!important;}
  .topbar h2{font-size:23px!important;}
  .topbar .hamburger{min-width:104px!important;max-width:112px!important;}
}
@media (max-width:360px){
  .header-inner{grid-template-columns:minmax(0,1fr) 112px!important;}
  .header .inline-actions{max-width:112px!important;}
  .brand-logo-v8 .logo-word{font-size:18px!important;}
  .brand-logo-v8 .logo-pill{font-size:16px!important;}
  .topbar{grid-template-columns:1fr!important;}
  .topbar .hamburger{width:100%!important;max-width:100%!important;}
}

/* V3.0.2: стабильная панель быстрого доступа калькулятора на iPhone */
@media (max-width: 900px){
  .calc-left-col > .calc-nav-outer.is-floating,
  .calc-left-col > .calc-nav-outer.is-mobile-floating{
    position:fixed!important;
    top:0!important;
    left:0!important;
    right:0!important;
    width:100vw!important;
    max-width:100vw!important;
    z-index:9999!important;
    padding:calc(env(safe-area-inset-top, 0px) + 4px) 8px 6px!important;
    background:rgba(245,251,250,.98)!important;
    -webkit-backdrop-filter:blur(10px)!important;
    backdrop-filter:blur(10px)!important;
    transform:translate3d(0,0,0)!important;
    will-change:transform!important;
    contain:layout paint!important;
  }
  .calc-left-col > .calc-nav-outer.is-floating .calc-step-nav,
  .calc-left-col > .calc-nav-outer.is-mobile-floating .calc-step-nav{
    width:100%!important;
    max-width:100%!important;
    display:grid!important;
    grid-template-columns:repeat(4,minmax(0,1fr))!important;
    gap:5px!important;
    margin:0!important;
    border-radius:14px!important;
    box-sizing:border-box!important;
    overflow:visible!important;
  }
  .calc-left-col > .calc-nav-outer.is-floating + .card,
  .calc-left-col > .calc-nav-outer.is-mobile-floating + .card{
    margin-top:58px!important;
  }
  #calc-step-1,#calc-step-2,#calc-step-3,#calc-step-4{
    scroll-margin-top:calc(env(safe-area-inset-top, 0px) + 82px)!important;
  }
}

/* =========================================================
   V3.0.3 — iPhone client header/topbar alignment fix
   Fixes logout/menu buttons after mobile hotfix without touching desktop
   ========================================================= */
@media (max-width:820px){
  .header{overflow:hidden!important;}
  .header-inner{
    display:grid!important;
    grid-template-columns:minmax(0,1fr) auto!important;
    align-items:center!important;
    gap:8px!important;
    min-height:64px!important;
  }
  .header .brand{
    width:auto!important;
    max-width:100%!important;
    min-width:0!important;
    overflow:hidden!important;
  }
  .header .brand-text-link,
  .header .brand-logo-v8{
    min-width:0!important;
    max-width:100%!important;
  }
  .header .inline-actions{
    width:auto!important;
    max-width:44vw!important;
    min-width:0!important;
    display:flex!important;
    grid-template-columns:none!important;
    flex-direction:column!important;
    align-items:stretch!important;
    justify-content:center!important;
    gap:5px!important;
    margin-left:auto!important;
  }
  .header .inline-actions .pill{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    padding:5px 8px!important;
    font-size:12px!important;
    line-height:1.15!important;
    justify-content:flex-start!important;
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
  }
  .header .inline-actions .btn{
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    padding:7px 10px!important;
    min-height:34px!important;
    font-size:13px!important;
    line-height:1!important;
    justify-content:center!important;
    white-space:nowrap!important;
  }
  .app-shell > section{min-width:0!important;width:100%!important;max-width:100%!important;}
  .topbar{
    display:grid!important;
    grid-template-columns:minmax(0,1fr) auto!important;
    align-items:start!important;
    gap:10px!important;
    width:100%!important;
    max-width:100%!important;
    overflow:hidden!important;
  }
  .topbar > div{min-width:0!important;max-width:100%!important;}
  .topbar h2{
    font-size:24px!important;
    line-height:1.12!important;
    overflow-wrap:anywhere!important;
  }
  .topbar .muted{font-size:14px!important;line-height:1.3!important;}
  .topbar .hamburger{
    width:auto!important;
    min-width:104px!important;
    max-width:118px!important;
    padding:10px 12px!important;
    justify-content:center!important;
    white-space:nowrap!important;
    align-self:start!important;
  }
}
@media (max-width:430px){
  .header-inner{grid-template-columns:minmax(0,1fr) minmax(118px,40vw)!important;}
  .header .inline-actions{max-width:40vw!important;}
  .brand-badge{width:38px!important;height:38px!important;min-width:38px!important;}
  .brand-logo-v8 .logo-word{font-size:20px!important;letter-spacing:-.8px!important;}
  .brand-logo-v8 .logo-pill{font-size:18px!important;padding:2px 5px!important;}
  .topbar h2{font-size:23px!important;}
  .topbar .hamburger{min-width:104px!important;max-width:112px!important;}
}
@media (max-width:360px){
  .header-inner{grid-template-columns:minmax(0,1fr) 112px!important;}
  .header .inline-actions{max-width:112px!important;}
  .brand-logo-v8 .logo-word{font-size:18px!important;}
  .brand-logo-v8 .logo-pill{font-size:16px!important;}
  .topbar{grid-template-columns:1fr!important;}
  .topbar .hamburger{width:100%!important;max-width:100%!important;}
}