:root{
  --bg:#121416;
  --panel:#1a1d21;
  --panel-2:#20242a;
  --panel-3:#272c33;
  --border:#2f353e;
  --border-2:#434c58;
  --text:#edf1f5;
  --muted:#9aa3af;
  --danger:#c77878;
  --success:#7ab58e;
  --warning:#d6a261;
  --radius-xl:24px;
  --radius-lg:18px;
  --radius-md:14px;
  --shadow:0 10px 28px rgba(0,0,0,.22);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif}
body{min-height:100vh}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
input,select,textarea{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:14px;padding:13px 14px;outline:none;width:100%}
input:focus,select:focus,textarea:focus{border-color:#5f6a78}
textarea{resize:vertical;min-height:140px}
.card,.login-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow)}
.btn{border:1px solid var(--border-2);background:var(--panel-2);color:var(--text);padding:12px 16px;border-radius:999px;font-weight:700}
.btn:hover{background:var(--panel-3)}
.btn-primary{background:#2b3139}
.btn-primary:hover{background:#343c46}
.btn-secondary{background:var(--panel-2)}
.danger-soft{border-color:#5a3b3b;color:#f2d0d0}
.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px}
.login-card{width:min(100%,420px);padding:28px}
.login-brand{display:flex;align-items:center;gap:16px;margin-bottom:24px}
.brand-mark{width:64px;height:64px;border-radius:18px;background:var(--panel-2);border:1px solid var(--border-2);display:grid;place-items:center;flex:0 0 auto}
.brand-mark svg{width:26px;height:26px}
.login-brand h1{margin:0 0 4px;font-size:1.7rem}
.login-brand p{margin:0;color:var(--muted)}
.login-form{display:grid;gap:12px}
.login-form label{font-size:.95rem;color:var(--muted)}
.login-error{background:#332325;border:1px solid #5a383c;color:#f4cfd2;padding:12px 14px;border-radius:14px}
.login-btn{margin-top:4px;width:100%}
.app-shell{max-width:1600px;margin:0 auto;padding:16px}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px;position:sticky;top:0;z-index:20;background:rgba(26,29,33,.96);backdrop-filter:blur(10px)}
.brand-wrap{display:flex;align-items:center;gap:14px;min-width:0}
.brand-text h1{margin:0 0 3px;font-size:1.65rem;line-height:1.05}
.brand-text p{margin:0;color:var(--muted)}
.topnav{display:flex;gap:10px;flex-wrap:wrap}
.logout-form{margin-left:auto}
.main-content{padding-top:18px}
.view{display:none}
.view.active{display:block}
.stats-grid{display:grid;gap:16px;margin-bottom:18px}
.stats-grid.five{grid-template-columns:repeat(5,minmax(0,1fr))}
.stat-card{padding:22px}
.stat-label{color:var(--muted);font-size:.98rem;margin-bottom:10px}
.stat-value{font-size:2rem;font-weight:800;letter-spacing:-.03em}
.section-card{padding:20px}
.section-header.compact{margin-bottom:16px}
.section-header h2{margin:0 0 6px;font-size:1.55rem}
.section-header p{margin:0;color:var(--muted)}
.toolbar-card{padding:16px 18px;margin-bottom:16px}
.toolbar{display:grid;grid-template-columns:minmax(260px,1.3fr) repeat(2,minmax(180px,.8fr)) auto;gap:14px;align-items:end}
.field{display:grid;gap:8px}
.field,
.field input,
.field select,
.field textarea{min-width:0}
.field label{font-size:.92rem;color:var(--muted)}
.toolbar-actions,.form-actions{display:flex;gap:10px;flex-wrap:wrap}
.desktop-table-wrap{overflow:auto}
.leads-table{width:100%;border-collapse:collapse;min-width:1120px}
.leads-table th,.leads-table td{padding:14px 12px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}
.leads-table th{font-size:.92rem;color:var(--muted);font-weight:700}
.checkbox-col{width:46px}
.row-check,.master-check{width:18px;height:18px;accent-color:#697488}
.badge{display:inline-flex;align-items:center;padding:7px 10px;border-radius:999px;border:1px solid var(--border-2);background:var(--panel-2)}
.table-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.link-btn{border:none;background:none;color:#d8dee7;padding:0;font-weight:700}
.link-btn.delete{color:#efbbbb}
.mobile-leads-list{display:none;gap:14px}
.lead-pagination{
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
  margin-top:18px;
}
.pagination-btn{
  min-width:44px;
  padding:10px 14px;
}
.pagination-btn.active{
  background:#343c46;
  border-color:#5e6977;
}
.lead-card{padding:16px}
.lead-card-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:14px}
.lead-card h3{margin:0 0 4px;font-size:1.1rem}
.lead-sub{color:var(--muted);font-size:.95rem}
.lead-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:14px}
.mini{background:var(--panel-2);border:1px solid var(--border);border-radius:14px;padding:10px}
.mini-label{color:var(--muted);font-size:.82rem;margin-bottom:4px}
.mini-value{font-weight:600}
.form-card{padding:20px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
#createdAtDisplay{color:var(--muted);background:var(--panel-2)}
.field.full{grid-column:1/-1}
.mini.full-width{grid-column:1/-1}
.pipeline-board{display:grid;grid-template-columns:repeat(6,minmax(250px,1fr));gap:14px;overflow-x:auto;padding-bottom:6px;align-items:start}
.pipeline-column{background:var(--panel-2);border:1px solid var(--border);border-radius:20px;padding:14px;min-height:260px;transition:border-color .15s ease, background .15s ease}
.pipeline-column.drag-over{border-color:#5e6977;background:#232932}
.pipeline-column h3{margin:0 0 10px;font-size:1.05rem}
.pipeline-badge{display:inline-flex;align-items:center;padding:7px 11px;border-radius:999px;border:1px solid var(--border-2);color:var(--muted);margin-bottom:12px;background:var(--panel-3)}
.pipeline-list{display:flex;flex-direction:column;gap:10px;min-height:120px}
.pipeline-empty{color:var(--muted);padding:6px 2px}
.lead-chip,.lead-card,.leads-table tbody tr{transition:background .15s ease,border-color .15s ease}
.lead-chip{background:var(--panel-3);border:1px solid var(--border-2);border-radius:16px;padding:12px;cursor:grab;user-select:none}
.lead-chip:active{cursor:grabbing}
.chip-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px}
.chip-company{display:block;font-size:.98rem;line-height:1.3}
.chip-meta{color:var(--muted);font-size:.9rem}
.chip-edit{width:34px;height:34px;border-radius:10px;border:1px solid var(--border-2);background:var(--panel-2);color:var(--text);display:grid;place-items:center;flex:0 0 auto}
.chip-edit svg{width:15px;height:15px}
.priority-high{background:rgba(157,63,63,.16)!important;border-color:rgba(199,120,120,.42)!important}
.priority-medium{background:rgba(154,106,45,.16)!important;border-color:rgba(214,162,97,.42)!important}
.priority-low{background:rgba(54,119,74,.14)!important;border-color:rgba(122,181,142,.34)!important}
.toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%,18px);background:#222830;border:1px solid var(--border-2);color:var(--text);padding:12px 16px;border-radius:14px;opacity:0;pointer-events:none;transition:.18s ease;z-index:60}
.toast.show{opacity:1;transform:translate(-50%,0)}
@media (max-width: 1180px){
  .stats-grid.five{grid-template-columns:repeat(2,minmax(0,1fr))}
  .toolbar{grid-template-columns:1fr 1fr;}
  .toolbar-actions{grid-column:1/-1}
}
@media (max-width: 860px){
  .app-shell{padding:12px}
  .topbar{padding:14px;align-items:flex-start;flex-wrap:wrap}
  .topnav{width:100%;order:3}
  .logout-form{margin-left:0}
  .stats-grid.five{grid-template-columns:1fr 1fr}
  .desktop-table-wrap{display:none}
  .mobile-leads-list{display:grid}
  .lead-pagination{
    display:flex;
    justify-content:center;
    gap:8px;
  }
  .pagination-btn{
    width:auto;
    min-width:42px;
    border-radius:14px;
    padding:11px 14px;
  }
  .form-grid{grid-template-columns:1fr}
  .form-card{
    overflow:hidden;
  }
  .form-grid,
  .form-grid .field{
    width:100%;
    max-width:100%;
    min-width:0;
    overflow:hidden;
  }
  .form-grid input[type="date"],
  .form-grid input[readonly]{
    display:block;
    inline-size:100%;
    max-inline-size:100%;
    min-inline-size:0;
    -webkit-appearance:none;
    appearance:none;
  }
  #followUp,
  #createdAtDisplay{
    width:100%;
    max-width:100%;
  }
}
@media (max-width: 620px){
  .stats-grid.five{grid-template-columns:1fr}
  .toolbar{grid-template-columns:1fr}
  .lead-grid{grid-template-columns:1fr}
  .brand-text h1{font-size:1.4rem}
  .brand-mark{width:56px;height:56px}
  .nav-item,.btn{width:100%;justify-content:center}
  .topnav,.toolbar-actions,.form-actions,.table-actions{display:grid;grid-template-columns:1fr}
}


/* === v6 stability/style fixes === */
.topbar .nav-tabs,
.header-actions .nav-tabs,
.nav-tabs {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}

.nav-tab,
button.nav-tab,
a.nav-tab {
  appearance: none;
  -webkit-appearance: none;
  border: 1px solid #3b4353 !important;
  background: #171b23 !important;
  color: #e7ebf3 !important;
  border-radius: 14px !important;
  padding: 12px 18px !important;
  line-height: 1.1;
  font-weight: 600;
  box-shadow: none !important;
  text-decoration: none;
  transition: background .15s ease, border-color .15s ease, color .15s ease;
}

.nav-tab:hover,
button.nav-tab:hover,
a.nav-tab:hover {
  background: #1d2330 !important;
  border-color: #4a5364 !important;
}

.nav-tab.active,
button.nav-tab.active,
a.nav-tab.active {
  background: #242c39 !important;
  border-color: #5a6478 !important;
  color: #ffffff !important;
}

.logout-button,
button.logout-button,
.header-logout {
  display: none !important;
}

.brand-icon,
.logo-badge,
.app-icon,
.sidebar-logo,
.header-logo {
  cursor: pointer;
}

.notes-actions,
.form-actions,
.actions-row {
  margin-top: 24px !important;
}

textarea + .form-actions,
textarea + .actions-row {
  margin-top: 24px !important;
}

.form-section .form-actions,
.form-section .actions-row,
.lead-form .form-actions,
.lead-form .actions-row {
  padding-top: 4px;
}

@media (max-width: 768px) {
  .nav-tab,
  button.nav-tab,
  a.nav-tab {
    padding: 11px 16px !important;
    border-radius: 14px !important;
    font-size: 0.98rem !important;
  }
  .notes-actions,
  .form-actions,
  .actions-row {
    margin-top: 28px !important;
  }
}


/* v7 logout icon fix */
.icon-logout-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  text-decoration: none;
  color: #eef2f7 !important;
  font-size: 42px;
  font-weight: 700;
  line-height: 1;
}
.icon-logout-link:hover {
  color: #ffffff !important;
}
.floating-logout {
  position: fixed;
  top: 18px;
  left: 18px;
  width: 64px;
  height: 64px;
  border-radius: 18px;
  border: 1px solid #3b4353;
  background: #171b23;
  z-index: 9999;
}


/* v8 remove top-right logout */
.logout-button,
.header-logout,
.topbar .logout-button,
.topbar .header-logout,
.header-actions .logout-button,
.header-actions .header-logout,
a[href*="logout"]:not(.icon-logout-link),
button[onclick*="logout"],
button[data-action="logout"] {
  display: none !important;
}








/* v11: explicit visible logout arrow */
.brand-mark{
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}

.brand-logout-arrow{
  display:flex !important;
  align-items:center;
  justify-content:center;
  width:100%;
  height:100%;
  text-decoration:none !important;
  color:#ffffff !important;
}

.brand-logout-arrow svg{
  width:30px;
  height:30px;
  stroke:currentColor;
  fill:none;
  stroke-width:2.2;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.brand-logout-arrow:hover,
.brand-logout-arrow:focus,
.brand-logout-arrow:visited{
  color:#ffffff !important;
  text-decoration:none !important;
  opacity:0.92;
}

.floating-logout,
.icon-logout-link{
  display:none !important;
}


/* v12 logout arrow visible */
.brand-logout-arrow.icon-logout-link{
  display:flex !important;
  align-items:center;
  justify-content:center;
  width:100%;
  height:100%;
  color:#ffffff !important;
  text-decoration:none !important;
}
.brand-logout-arrow.icon-logout-link:hover,
.brand-logout-arrow.icon-logout-link:focus,
.brand-logout-arrow.icon-logout-link:visited{
  color:#ffffff !important;
  text-decoration:none !important;
  opacity:.92;
}


.lead-link{
  color:#e7eefc;
  text-decoration:underline;
  text-underline-offset:2px;
  word-break:break-word;
}
.lead-link:hover{
  color:#ffffff;
}


.phone-link{
  color:#e7eefc;
  text-decoration:underline;
  text-underline-offset:2px;
  font-weight:600;
}
.phone-link:hover{
  color:#ffffff;
}


/* v15 pipeline fit */
.pipeline-board,
.pipeline,
.pipeline-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
  gap: 14px !important;
  align-items: start;
  width: 100%;
  overflow: visible !important;
}

.pipeline-column,
.pipeline-stage,
.kanban-column {
  min-width: 0 !important;
  width: 100% !important;
}

.pipeline-column .lead-card,
.pipeline-stage .lead-card,
.kanban-column .lead-card,
.pipeline-column .pipeline-card,
.pipeline-stage .pipeline-card,
.kanban-column .pipeline-card {
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box;
}

.pipeline-column .lead-card *,
.pipeline-stage .lead-card *,
.kanban-column .lead-card *,
.pipeline-column .pipeline-card *,
.pipeline-stage .pipeline-card *,
.kanban-column .pipeline-card * {
  word-break: break-word;
}

.pipeline-wrapper,
.pipeline-scroll,
.pipeline-container {
  overflow-x: visible !important;
}

@media (max-width: 1100px) {
  .pipeline-board,
  .pipeline,
  .pipeline-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 700px) {
  .pipeline-board,
  .pipeline,
  .pipeline-grid {
    grid-template-columns: 1fr !important;
  }
}


/* v17 csv button row */
.csv-row{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.csv-row .btn{
  flex:0 0 auto;
}

.toolbar-actions > .btn,
.csv-row .btn{
  box-sizing:border-box;
  width:140px;
  height:50px;
  padding:0 16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1;
}

.lead-company-cell{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}

.table-subline{
  margin-top:6px;
  color:var(--muted);
  font-size:.85rem;
  line-height:1.4;
}

.followup-display{
  display:grid;
  gap:4px;
}

.followup-state{
  color:#e88989;
  font-size:.8rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.03em;
}

.followup-state.overdue{
  color:#ff6f6f;
}

.source-badge{
  background:#26303b;
  border-color:#445162;
  font-size:.78rem;
  padding:5px 9px;
}

.calculator-details{
  margin-top:18px;
  padding:18px;
  background:var(--panel-2);
}

.lead-notes{
  margin-top:18px;
  padding:18px;
  background:var(--panel-2);
}

.lead-notes .section-header{
  display:grid;
  grid-template-columns:1fr;
  align-items:start;
  gap:28px;
  margin-bottom:30px;
}

.lead-notes .section-header > div{
  min-width:0;
}

.lead-notes .section-header .btn{
  justify-self:start;
  margin-left:0;
  margin-top:4px;
  flex:0 0 auto;
}

.lead-notes-list{
  display:grid;
  gap:10px;
}

.lead-note{
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--panel-3);
  padding:12px;
}

.lead-note-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:var(--muted);
  font-size:.82rem;
  margin-bottom:8px;
}

.lead-note-text{
  color:var(--text);
  line-height:1.55;
  white-space:normal;
}

.calculator-details-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}

body.public-page{
  background:
    radial-gradient(circle at top left, rgba(225,231,239,.95), transparent 30%),
    radial-gradient(circle at top right, rgba(244,246,249,.9), transparent 24%),
    #f6f8fb;
  color:#18212b;
  overflow-x:hidden;
  width:100%;
  max-width:100%;
  position:relative;
  overscroll-behavior-x:none;
}

html:has(body.public-page){
  overflow-x:hidden;
  width:100%;
  max-width:100%;
}

body.public-page .card{
  background:rgba(255,255,255,.94);
  border:1px solid #d9e1ea;
  box-shadow:0 18px 44px rgba(27,39,51,.08);
  max-width:100%;
}

body.public-page .section-header h2,
body.public-page h1,
body.public-page h2,
body.public-page strong{
  color:#18212b;
}

body.public-page .section-header p,
body.public-page .field label,
body.public-page .summary-empty,
body.public-page .service-description,
body.public-page .calculator-status{
  color:#607081;
}

body.public-page input,
body.public-page select,
body.public-page textarea{
  background:#ffffff;
  color:#18212b;
  border:1px solid #d7dee8;
}

body.public-page input:focus,
body.public-page select:focus,
body.public-page textarea:focus{
  border-color:#8ca0b5;
  box-shadow:0 0 0 4px rgba(114,137,162,.12);
}

body.public-page .btn{
  border:1px solid #cad5e1;
  background:#f5f7fa;
  color:#18212b;
}

body.public-page .btn:hover{
  background:#eef2f6;
}

body.public-page .btn-primary{
  background:#1f2a36;
  border-color:#1f2a36;
  color:#ffffff;
}

body.public-page .btn-primary:hover{
  background:#2a3745;
  border-color:#2a3745;
}

.public-shell{
  width:100%;
  max-width:1280px;
  margin:0 auto;
  padding:32px 16px 48px;
  position:relative;
}

.public-top-actions{
  display:flex;
  justify-content:flex-end;
  margin-bottom:12px;
}

.public-hero{
  padding:32px;
  margin-bottom:18px;
}

.model-grid,
.package-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}

.package-grid{
  align-items:stretch;
  grid-template-columns:repeat(3,minmax(0,1fr));
}

.package-groups{
  display:grid;
  gap:14px;
}

.model-card{
  display:block;
  height:100%;
  cursor:pointer;
}

.model-radio,
.package-radio{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.model-card-content{
  display:flex;
  flex-direction:column;
  padding:18px;
  border:1px solid #d9e1ea;
  border-radius:18px;
  background:#fbfcfd;
  transition:border-color .16s ease, box-shadow .16s ease, transform .16s ease;
  min-height:148px;
  height:100%;
}

.model-card-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:10px;
}

.model-card-top strong{
  font-size:1.12rem;
}

.model-card-meta{
  margin-top:auto;
  padding-top:12px;
}

.model-prices{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:4px;
  margin-top:0;
}

.model-price-line{
  display:flex;
  align-items:baseline;
  gap:8px;
  flex-wrap:wrap;
}

.model-price-before{
  color:#8da0b4;
  text-decoration:line-through;
  text-decoration-thickness:2px;
  text-decoration-color:#c06a6a;
  font-size:.92em;
}

.model-price-current{
  color:#233f5d;
  font-weight:800;
}

.model-card.is-recommended .model-card-content{
  background:linear-gradient(180deg,#f3f7fb 0%,#edf4fb 100%);
}

.model-radio:checked + .model-card-content,
.package-radio:checked + .service-content{
  border-color:#5f7e9d;
  background:linear-gradient(180deg,#f3f7fb 0%,#eaf2f9 100%);
  box-shadow:0 14px 30px rgba(74,104,135,.14);
  border-width:2px;
}

.card-badge{
  display:inline-flex;
  align-items:center;
  padding:5px 10px;
  border-radius:999px;
  background:#ddeaf6;
  color:#244c73;
  font-size:.76rem;
  font-weight:700;
  white-space:nowrap;
}

.card-badge.bestseller{
  background:#1f2a36;
  color:#ffffff;
}

.package-badge{
  position:absolute;
  top:18px;
  right:-44px;
  z-index:2;
  min-width:160px;
  justify-content:center;
  transform:rotate(36deg);
  border-radius:0;
  padding:7px 16px;
  font-size:.72rem;
  letter-spacing:.03em;
  box-shadow:0 10px 24px rgba(31,42,54,.18);
}

.card-badge.subtle{
  background:#eef3f8;
  color:#5d7084;
}

.addon-included-badge{
  background:#e6f3ea;
  color:#2f6c48;
}

.feature-list{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:14px;
  align-content:flex-start;
}

.feature-chip{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  background:#ffffff;
  border:1px solid #dbe4ee;
  color:#516376;
  font-size:.82rem;
  font-weight:600;
}

.summary-model-card{
  padding:16px 18px;
  border:1px solid #dce5ee;
  border-radius:18px;
  background:#f8fbfd;
  margin-bottom:16px;
}

.summary-subline{
  margin-top:6px;
  color:#56687a;
  font-size:.95rem;
}

.eyebrow{
  margin:0 0 10px;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:#7b8a9a;
  font-size:.82rem;
  font-weight:700;
}

.calculator-layout{
  display:grid;
  grid-template-columns:minmax(0,1.4fr) minmax(0,.8fr);
  gap:18px;
  align-items:start;
  width:100%;
  max-width:100%;
}

.calculator-layout-mobile{
  display:none;
}

.calculator-layout > *{
  min-width:0;
  max-width:100%;
}

.calculator-summary-slot{
  min-width:0;
  max-width:100%;
  position:relative;
}

.calculator-card,
.calculator-summary{
  padding:22px;
}

.calculator-summary{
  position:relative;
  width:100%;
}

.calculator-summary.is-floating{
  position:fixed;
  top:24px;
  left:var(--summary-left);
  width:var(--summary-width);
  z-index:30;
}

.service-grid{
  display:grid;
  gap:12px;
  width:100%;
  max-width:100%;
  overflow-x:clip;
}

.service-card{
  display:block;
  cursor:pointer;
  min-width:0;
  max-width:100%;
  width:100%;
}

.package-card{
  height:100%;
}

.service-checkbox{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.service-checkbox:disabled + .service-content{
  cursor:default;
}

.service-content{
  display:block;
  background:#fbfcfd;
  border:1px solid #d9e1ea;
  border-radius:18px;
  padding:16px;
  transition:border-color .16s ease, background .16s ease, transform .16s ease, box-shadow .16s ease;
  min-width:0;
  max-width:100%;
  overflow:hidden;
  width:100%;
  min-height:168px;
}

.package-card .service-content{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:flex-start;
  min-height:232px;
  height:100%;
  padding:18px;
  position:relative;
}

.service-card:hover .service-content{
  border-color:#b8c6d4;
  background:#ffffff;
  box-shadow:0 10px 24px rgba(40,56,73,.08);
  transform:translateY(-1px);
}

.service-checkbox:checked + .service-content{
  border-color:#5f7e9d;
  background:linear-gradient(180deg,#f3f7fb 0%,#eaf2f9 100%);
  box-shadow:0 14px 30px rgba(74,104,135,.14);
  border-width:2px;
}

.service-checkbox:checked + .service-content .service-title-row strong{
  color:#16324d;
}

.service-checkbox:checked + .service-content .service-prices{
  color:#244c73;
}

.service-checkbox:checked + .service-content .service-description{
  color:#476178;
}

.package-radio:checked + .service-content{
  border-color:#35597d;
  background:linear-gradient(180deg,#f3f8fd 0%,#e9f1f8 100%);
  box-shadow:0 18px 36px rgba(53,89,125,.16);
}

.package-radio:checked + .service-content .service-title-row strong{
  color:#16324d;
}

.package-radio:checked + .service-content .service-prices{
  color:#23466a;
}

.service-title-row{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:8px;
  flex-wrap:wrap;
  width:100%;
}

.service-title-row strong{
  flex:1 1 240px;
  min-width:0;
  max-width:100%;
}

.service-prices{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
  color:#56687a;
  font-weight:700;
  font-size:.92rem;
}

.package-card .service-prices{
  margin-bottom:10px;
  padding-right:0;
  justify-content:flex-start;
  width:100%;
}

.package-card .service-prices span{
  white-space:nowrap;
}

.package-card .service-description{
  color:#607081;
  line-height:1.45;
  display:block;
  overflow:visible;
}

.calculator-contact-header{
  margin-top:22px;
}

.calculator-admin-access{
  margin-top:28px;
  padding-top:20px;
  border-top:1px solid #e0e6ee;
  display:flex;
  justify-content:center;
}

.calculator-admin-btn{
  width:auto !important;
  min-width:0;
  padding:6px 12px !important;
  font-size:.8rem;
  border-radius:999px !important;
  text-decoration:none !important;
  line-height:1.1;
}

.calculator-back-btn{
  text-decoration:none !important;
}

.calculator-admin-btn,
.calculator-back-btn,
.calculator-admin-btn:hover,
.calculator-back-btn:hover,
.calculator-admin-btn:focus,
.calculator-back-btn:focus,
.calculator-admin-btn:visited,
.calculator-back-btn:visited{
  text-decoration:none !important;
}

.summary-services{
  display:grid;
  gap:10px;
  width:100%;
  max-width:100%;
  overflow-x:clip;
}

.summary-service{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  padding:12px 14px;
  border-radius:14px;
  background:#f9fbfc;
  border:1px solid #dde4ec;
  flex-wrap:wrap;
  max-width:100%;
  overflow:hidden;
}

.summary-service span,
.summary-service strong{
  min-width:0;
  word-break:break-word;
}

.summary-empty{
  padding:12px 2px;
}

.summary-totals{
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid #e0e6ee;
  display:grid;
  gap:12px;
}

.summary-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
}

.summary-row strong{
  color:#18212b;
}

.calculator-status{
  min-height:24px;
  margin-top:18px;
}

.calculator-status.success{
  color:#2f6c48 !important;
}

.calculator-status.error{
  color:#a64a4a !important;
}

@media (min-width: 821px){
  .calculator-layout-desktop{
    grid-template-columns:minmax(0,1fr) 360px;
  }
}

@media (max-width: 820px){
  .calculator-layout{
    grid-template-columns:1fr;
  }

  .calculator-layout-desktop .calculator-summary{
    display:none;
  }

  .calculator-layout-mobile{
    display:block;
    margin-top:18px;
  }

  .calculator-summary-mobile{
    display:block;
    position:static;
  }

  .calculator-details-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 820px){
  .model-grid,
  .package-grid{
    grid-template-columns:1fr;
    gap:10px;
  }

  html,
  body,
  body.public-page,
  .public-shell,
  .calculator-layout,
  .calculator-layout > *,
  .calculator-card,
  .service-grid,
  .service-card,
  .service-content,
  .calculator-summary,
  .summary-services,
  .summary-service{
    max-width:100%;
  }

  .public-shell{
    padding:20px 12px 32px;
  }

  .public-top-actions{
    margin-bottom:10px;
  }

  .public-hero,
  .calculator-card,
  .calculator-summary{
    padding:18px;
    border-radius:18px;
  }

  .service-grid{
    gap:8px;
    overflow:visible;
  }

  .model-card-content,
  .summary-model-card{
    padding:14px;
    border-radius:16px;
    min-height:0;
  }

  .service-card{
    overflow:visible;
  }

  .service-content{
    padding:11px 12px;
    border-radius:14px;
    overflow:visible;
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    min-height:0;
  }

  .package-card .service-content{
    min-height:0;
    padding:14px;
    padding-top:44px;
  }

  .package-badge{
    top:12px;
    right:12px;
    min-width:auto;
    padding:5px 10px;
    font-size:.66rem;
    line-height:1;
    border-radius:999px;
    transform:none;
    letter-spacing:0;
    box-shadow:none;
  }

  .service-title-row{
    gap:4px;
    margin-bottom:4px;
    flex-direction:column;
    align-items:flex-start;
  }

  .model-card-top{
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
  }

  .service-title-row strong{
    flex:initial;
    font-size:.95rem;
    line-height:1.28;
  }

  .service-prices{
    justify-content:flex-start;
    gap:6px;
    font-size:.79rem;
    line-height:1.3;
  }

  .service-description{
    font-size:.84rem;
    line-height:1.4;
  }

  .form-actions{
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
  }

  .form-actions .btn{
    width:100%;
    padding:11px 14px;
  }

  .calculator-back-btn{
    font-size:.85rem;
    padding:8px 14px !important;
  }
}

@media (max-width: 620px){
  html,
  body,
  body.public-page,
  .public-shell,
  .calculator-layout,
  .calculator-layout > *,
  .calculator-card,
  .calculator-summary,
  .summary-services,
  .summary-service{
    overflow-x:hidden;
  }

  .public-top-actions{
    justify-content:flex-end;
  }

  .service-title-row,
  .summary-row,
  .summary-service{
    flex-direction:column;
    align-items:flex-start;
  }

  .service-content{
    padding:10px 11px;
    overflow:visible;
  }

  .package-card .service-content{
    padding:12px;
    padding-top:40px;
  }

  .package-badge{
    top:10px;
    right:10px;
    padding:4px 9px;
    font-size:.62rem;
    min-width:auto;
    line-height:1;
    border-radius:999px;
    transform:none;
    letter-spacing:0;
    box-shadow:none;
  }

  .feature-chip{
    font-size:.76rem;
    padding:5px 8px;
  }

  .service-title-row{
    gap:3px;
    margin-bottom:3px;
  }

  .service-title-row strong{
    font-size:.9rem;
    line-height:1.24;
  }

  .service-prices{
    gap:4px;
    font-size:.75rem;
  }

  .service-description{
    font-size:.8rem;
    line-height:1.34;
  }

  .public-hero h1{
    font-size:1.65rem;
    line-height:1.15;
  }

  .public-hero p,
  .section-header p{
    font-size:.92rem;
  }

  .calculator-admin-access,
  .calculator-admin-access .btn{
    width:auto;
  }
}
