/* ============================================================
   Care Box System — Frontend Styles
   Aesthetic: Clean Medical Luxury · Navy + Mint + Warm White
   Fonts: Raleway (headings) · Source Sans 3 (body)
   ============================================================ */

/* Fonts load via wp_enqueue (class-frontend). Settings → Frontend appearance overrides many variables in wp_head. */

/* ---- CSS Variables (defaults; Care Box injects --cb-primary, --cb-text, etc. in wp_head) ---- */
:root {
  --cb-navy:      #1B4F8A;
  --cb-navy-d:    #153C6A;
  --cb-navy-l:    #EBF4FF;
  --cb-navy-xl:   #F4F9FF;
  --cb-mint:      #10B981;
  --cb-mint-l:    #D1FAE5;
  --cb-orange:    #F59E0B;
  --cb-orange-l:  #FEF3C7;
  --cb-red:       #EF4444;
  --cb-red-l:     #FEE2E2;
  --cb-white:     #FFFFFF;
  --cb-bg:        #F8FAFF;
  --cb-surface:   #FFFFFF;
  --cb-border:    #E2ECF8;
  --cb-text:      #1A2744;
  --cb-primary-rgb: 27, 79, 138;
  /* Filled from wp_head; fallbacks match default navy */
  --cb-primary-gradient: var(--cb-navy);
  --cb-primary-gradient-hover: var(--cb-navy-d);
  --cb-brand-stop-a: var(--cb-navy);
  --cb-brand-stop-b: #2D7DD2;
  --cb-text-2:    #4D6080;
  --cb-text-3:    #8FA3BE;
  --cb-radius:    14px;
  --cb-radius-sm: 8px;
  --cb-shadow:    0 2px 8px rgba(27,79,138,.06), 0 8px 32px rgba(27,79,138,.06);
  --cb-shadow-md: 0 8px 32px rgba(27,79,138,.14);
  --cb-shadow-lg: 0 20px 60px rgba(27,79,138,.18);
  --cb-transition: all .25s cubic-bezier(.4,0,.2,1);
  --cb-max-w: 1100px;
}

/* ============================================================
   BASE
============================================================ */
.cb-wrap, .cb-account-wrap { 
  font-family: 'Source Sans 3', system-ui, sans-serif; 
  color: var(--cb-text);
  background: var(--cb-bg);
  min-height: 60vh;
  padding: 32px 20px 60px;
}
.cb-wrap *, .cb-account-wrap * { box-sizing: border-box; }
.cb-wrap h1, .cb-wrap h2, .cb-wrap h3,
.cb-account-wrap h1, .cb-account-wrap h2 { 
  font-family: 'Raleway', sans-serif; 
  margin: 0;
}

/* ============================================================
   PROGRESS BAR
============================================================ */
.cb-progress-bar {
  max-width: var(--cb-max-w);
  margin: 0 auto 32px;
}
.cb-progress-inner {
  display: flex;
  align-items: center;
  background: var(--cb-surface);
  border: 1px solid var(--cb-border);
  border-radius: 99px;
  padding: 8px 24px;
  box-shadow: var(--cb-shadow);
}
.cb-step-indicator {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  opacity: .45;
  transition: var(--cb-transition);
}
.cb-step-indicator.active,
.cb-step-indicator.done { opacity: 1; }
.cb-step-num {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--cb-border);
  color: var(--cb-text-2);
  font-weight: 700;
  font-size: 14px;
  font-family: 'Raleway', sans-serif;
  display: flex; align-items: center; justify-content: center;
  transition: var(--cb-transition);
  flex-shrink: 0;
}
.cb-step-indicator.active .cb-step-num {
  background: var(--cb-navy);
  color: #fff;
  box-shadow: 0 4px 12px rgba(27,79,138,.35);
}
.cb-step-indicator.done .cb-step-num {
  background: var(--cb-mint);
  color: #fff;
}
.cb-step-label { font-size: 13px; font-weight: 600; color: var(--cb-text-2); white-space: nowrap; }
.cb-step-indicator.active .cb-step-label { color: var(--cb-navy); }
.cb-step-connector { flex: 1; height: 2px; background: var(--cb-border); border-radius: 1px; margin: 0 8px; min-width: 20px; }

/* ============================================================
   STEPS (show/hide)
============================================================ */
.cb-step { display: none; max-width: var(--cb-max-w); margin: 0 auto; }
.cb-step.active { display: block; animation: cb-fadein .35s ease; }
@keyframes cb-fadein { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:none; } }

/* ============================================================
   STEP HEADER
============================================================ */
.cb-step-header { text-align: center; margin-bottom: 36px; }
.cb-step-title { 
  font-size: clamp(22px,4vw,32px); 
  font-weight: 800; 
  color: var(--cb-text);
  letter-spacing: -.5px;
  line-height: 1.2;
  margin-bottom: 12px;
}
.cb-step-subtitle { 
  font-size: 16px; 
  color: var(--cb-text-2);
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.6;
}

/* ============================================================
   POINTS BAR (sticky)
============================================================ */
.cb-points-bar {
  position: sticky;
  top: 32px;
  z-index: 100;
  background: var(--cb-surface);
  border: 1px solid var(--cb-border);
  border-radius: 16px;
  padding: 16px 24px;
  box-shadow: var(--cb-shadow-md);
  margin-bottom: 28px;
  transition: var(--cb-transition);
}
.cb-points-bar.at-limit { border-color: var(--cb-orange); }
.cb-points-bar-inner {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.cb-points-info { flex-shrink: 0; }
.cb-points-label { display: block; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--cb-text-3); margin-bottom: 4px; }
.cb-points-display { display: flex; align-items: baseline; gap: 2px; }
#cb-points-used { font-size: 28px; font-weight: 800; color: var(--cb-navy); font-family: 'Raleway', sans-serif; line-height: 1; transition: var(--cb-transition); }
.cb-points-sep  { font-size: 20px; color: var(--cb-text-3); font-weight: 300; }
#cb-points-max  { font-size: 18px; color: var(--cb-text-3); font-weight: 500; }
.cb-points-track { flex: 1; min-width: 120px; }
.cb-points-track-bg { height: 10px; background: var(--cb-border); border-radius: 5px; overflow: hidden; }
.cb-points-fill { height: 100%; background: linear-gradient(90deg, var(--cb-brand-stop-a), var(--cb-brand-stop-b)); border-radius: 5px; transition: width .4s cubic-bezier(.4,0,.2,1); width: 0%; }
.cb-points-bar.at-limit .cb-points-fill { background: linear-gradient(90deg, var(--cb-orange), #FBBF24); }
.cb-selected-count { font-size: 13px; color: var(--cb-text-2); font-weight: 500; flex-shrink: 0; }
.cb-selected-count #cb-items-count { font-weight: 700; color: var(--cb-navy); }

/* ============================================================
   PRODUCT CATEGORIES TABS
============================================================ */
.cb-cat-tabs { 
  display: flex; 
  gap: 8px; 
  margin-bottom: 24px; 
  overflow-x: auto;
  padding-bottom: 4px;
  scrollbar-width: none;
}
.cb-cat-tabs::-webkit-scrollbar { display: none; }
.cb-cat-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 18px;
  border-radius: 99px;
  border: 1.5px solid var(--cb-border);
  background: var(--cb-surface);
  font-size: 13px;
  font-weight: 600;
  color: var(--cb-text-2);
  cursor: pointer;
  white-space: nowrap;
  transition: var(--cb-transition);
}
.cb-cat-tab:hover { border-color: var(--cb-navy); color: var(--cb-navy); background: var(--cb-navy-l); }
.cb-cat-tab.active { background: var(--cb-navy); color: #fff; border-color: var(--cb-navy); }
.cb-cat-tab .cb-cat-count { 
  background: rgba(255,255,255,.25); 
  padding: 0 6px; 
  border-radius: 99px; 
  font-size: 11px;
}
.cb-cat-tab:not(.active) .cb-cat-count { background: var(--cb-border); color: var(--cb-text-3); }

/* ============================================================
   PRODUCT GRID + CARDS
============================================================ */
.cb-products-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 18px;
}
.cb-product-card {
  background: var(--cb-surface);
  border: 1.5px solid var(--cb-border);
  border-radius: var(--cb-radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: var(--cb-transition);
  cursor: pointer;
  position: relative;
}
.cb-product-card:hover { 
  border-color: var(--cb-navy); 
  box-shadow: var(--cb-shadow-md);
  transform: translateY(-2px);
}
.cb-product-card.selected { 
  border-color: var(--cb-navy); 
  background: var(--cb-navy-xl);
  box-shadow: 0 0 0 3px rgba(27,79,138,.15), var(--cb-shadow-md);
}
.cb-product-card.disabled { opacity: .45; pointer-events: none; }

/* Selected checkmark */
.cb-product-card.selected::after {
  content: '✓';
  position: absolute;
  top: 10px; right: 10px;
  width: 24px; height: 24px;
  background: var(--cb-navy);
  color: #fff;
  border-radius: 50%;
  font-size: 13px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 24px;
  text-align: center;
}

.cb-product-img-wrap { position: relative; aspect-ratio: 4/3; overflow: hidden; background: var(--cb-navy-xl); }
.cb-product-img { width: 100%; height: 100%; object-fit: contain; padding: 12px; transition: transform .3s ease; }
.cb-product-card:hover .cb-product-img { transform: scale(1.04); }
.cb-product-badge {
  position: absolute;
  bottom: 8px; left: 8px;
  background: var(--cb-navy);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 99px;
  letter-spacing: .03em;
}
.cb-product-body { padding: 14px 16px; flex: 1; }
.cb-product-name { font-size: 14px; font-weight: 700; color: var(--cb-text); margin-bottom: 6px; font-family: 'Raleway', sans-serif; line-height: 1.3; }
.cb-product-desc { font-size: 12px; color: var(--cb-text-3); line-height: 1.5; }
.cb-product-footer { padding: 12px 16px; border-top: 1px solid var(--cb-border); display: flex; align-items: center; justify-content: space-between; gap: 8px; }

.cb-add-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--cb-navy);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 8px 16px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--cb-transition);
  font-family: inherit;
  flex: 1;
  justify-content: center;
}
.cb-add-btn:hover { background: var(--cb-navy-d); }
.cb-product-card.selected .cb-add-btn { background: var(--cb-red); }
.cb-product-card.selected .cb-add-btn::before { content: '− '; }

/* Qty Controls */
.cb-qty-control {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--cb-navy-l);
  border-radius: 8px;
  padding: 4px;
}
.cb-qty-btn {
  width: 28px; height: 28px;
  border-radius: 6px;
  border: none;
  background: var(--cb-surface);
  color: var(--cb-navy);
  font-size: 18px;
  font-weight: 700;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: var(--cb-transition);
  line-height: 1;
  font-family: inherit;
}
.cb-qty-btn:hover { background: var(--cb-navy); color: #fff; }
.cb-qty-val { font-size: 15px; font-weight: 700; color: var(--cb-navy); min-width: 20px; text-align: center; font-family: 'Raleway', sans-serif; }

/* Loading */
.cb-products-loading { text-align: center; padding: 80px 20px; }
.cb-spinner { width: 44px; height: 44px; border: 3px solid var(--cb-border); border-top-color: var(--cb-navy); border-radius: 50%; animation: cb-spin .7s linear infinite; margin: 0 auto 16px; }
@keyframes cb-spin { to { transform: rotate(360deg); } }
.cb-products-loading p { color: var(--cb-text-2); font-size: 15px; }

/* Empty state */
.cb-empty-state { text-align: center; padding: 80px 20px; }
.cb-empty-icon { font-size: 56px; margin-bottom: 16px; }
.cb-empty-state h3 { font-size: 20px; font-weight: 700; margin-bottom: 8px; }
.cb-empty-state p { color: var(--cb-text-2); }

/* ============================================================
   STEP 2 — USER FORM
============================================================ */
.cb-auth-toggle {
  display: flex;
  background: var(--cb-border);
  border-radius: 10px;
  padding: 4px;
  margin-bottom: 24px;
  max-width: 360px;
}
.cb-toggle-btn {
  flex: 1;
  padding: 10px 20px;
  border-radius: 8px;
  border: none;
  background: transparent;
  font-size: 14px;
  font-weight: 600;
  color: var(--cb-text-2);
  cursor: pointer;
  transition: var(--cb-transition);
  font-family: inherit;
}
.cb-toggle-btn.active { background: var(--cb-surface); color: var(--cb-navy); box-shadow: var(--cb-shadow); }

.cb-auth-panel { display: none; }
.cb-auth-panel.active { display: block; animation: cb-fadein .3s ease; }

.cb-form-section {
  background: var(--cb-surface);
  border: 1.5px solid var(--cb-border);
  border-radius: var(--cb-radius);
  padding: 24px;
  margin-bottom: 20px;
}
.cb-section-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 16px;
  font-weight: 700;
  color: var(--cb-navy);
  margin-bottom: 20px;
  font-family: 'Raleway', sans-serif;
}
.cb-section-title svg { opacity: .7; }

.cb-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.cb-field-small { max-width: 120px; }

.cb-field { margin-bottom: 16px; }
.cb-field:last-child { margin-bottom: 0; }
.cb-field label { 
  display: block; 
  font-size: 13px; 
  font-weight: 600; 
  color: var(--cb-text-2); 
  margin-bottom: 7px; 
  letter-spacing: .01em;
}
.cb-field label .required { color: var(--cb-red); margin-left: 2px; }

.cb-field input,
.cb-field select,
.cb-field textarea {
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid var(--cb-border);
  border-radius: var(--cb-radius-sm);
  font-size: 15px;
  color: var(--cb-text);
  background: var(--cb-bg);
  font-family: 'Source Sans 3', sans-serif;
  transition: var(--cb-transition);
  appearance: none;
  -webkit-appearance: none;
}
.cb-field select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238FA3BE' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
}
.cb-field input:focus,
.cb-field select:focus,
.cb-field textarea:focus {
  border-color: var(--cb-navy);
  outline: none;
  background: var(--cb-surface);
  box-shadow: 0 0 0 4px rgba(27,79,138,.1);
}
.cb-field input.error,
.cb-field select.error { border-color: var(--cb-red); box-shadow: 0 0 0 4px rgba(239,68,68,.1); }
.cb-field-hint { display: block; font-size: 12px; color: var(--cb-text-3); margin-top: 5px; }
.cb-field-hint.error { color: var(--cb-red); }

/* Password field */
.cb-password-wrap { position: relative; }
.cb-password-wrap input { padding-right: 44px; }
.cb-pw-toggle { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); background: none; border: none; cursor: pointer; color: var(--cb-text-3); padding: 4px; }
.cb-pw-toggle:hover { color: var(--cb-navy); }

/* Insurance info box */
.cb-insurance-info-box {
  display: flex;
  gap: 10px;
  background: var(--cb-navy-l);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 20px;
}
.cb-insurance-info-box svg { flex-shrink: 0; color: var(--cb-navy); margin-top: 1px; }
.cb-insurance-info-box p { font-size: 13px; color: var(--cb-navy); line-height: 1.6; margin: 0; }
.cb-insurance-section { border-color: rgba(27,79,138,.2); background: linear-gradient(135deg,#fff,var(--cb-navy-xl)); }

/* Pflegegrad selector */
.cb-pflegegrad-group { display: flex; gap: 8px; flex-wrap: wrap; }
.cb-radio-card { display: flex; }
.cb-radio-card input[type=radio] { display: none; }
.cb-radio-face {
  padding: 10px 18px;
  border: 1.5px solid var(--cb-border);
  border-radius: 10px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  color: var(--cb-text-2);
  transition: var(--cb-transition);
  text-align: center;
  min-width: 60px;
}
.cb-radio-face:hover { border-color: var(--cb-navy); color: var(--cb-navy); background: var(--cb-navy-l); }
.cb-radio-card input:checked + .cb-radio-face { background: var(--cb-navy); color: #fff; border-color: var(--cb-navy); }

/* GDPR */
.cb-gdpr-section { background: var(--cb-bg); }
.cb-checkbox-label { display: flex; gap: 12px; align-items: flex-start; cursor: pointer; font-size: 13px; color: var(--cb-text-2); line-height: 1.6; }
.cb-checkbox-label input[type=checkbox] { 
  width: 18px; height: 18px; 
  border: 1.5px solid var(--cb-border); 
  border-radius: 4px; 
  flex-shrink: 0; 
  margin-top: 2px; 
  accent-color: var(--cb-navy);
}
.cb-checkbox-label a { color: var(--cb-navy); }

/* Returning user */
.cb-returning-user {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--cb-mint-l);
  border: 1.5px solid var(--cb-mint);
  border-radius: var(--cb-radius);
  padding: 16px 20px;
  margin-bottom: 24px;
}
.cb-returning-avatar { font-size: 28px; }
.cb-returning-info { flex: 1; }
.cb-returning-info strong { display: block; font-size: 15px; color: var(--cb-text); }
.cb-returning-info span  { display: block; font-size: 13px; color: var(--cb-text-2); margin-top: 2px; }
.cb-link-btn { background: none; border: 1px solid var(--cb-mint); color: #065F46; font-size: 13px; font-weight: 600; padding: 6px 14px; border-radius: 6px; cursor: pointer; font-family: inherit; transition: var(--cb-transition); }
.cb-link-btn:hover { background: var(--cb-mint); color: #fff; }

/* ============================================================
   STEP NAV
============================================================ */
.cb-step-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--cb-border);
}

/* ============================================================
   BUTTONS
============================================================ */
.cb-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  border-radius: var(--cb-radius-sm);
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  border: 2px solid transparent;
  transition: var(--cb-transition);
  font-family: 'Raleway', sans-serif;
  text-decoration: none;
  white-space: nowrap;
  letter-spacing: -.01em;
}
.cb-btn:hover { text-decoration: none; }
.cb-btn:disabled { opacity: .55; cursor: not-allowed; }

.cb-btn-primary { background: var(--cb-primary-gradient); color: #fff; }
.cb-btn-primary:hover:not(:disabled) {
  background: var(--cb-primary-gradient-hover);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(var(--cb-primary-rgb), 0.35);
}

.cb-btn-success { background: var(--cb-mint); color: #fff; }
.cb-btn-success:hover:not(:disabled) { background: #059669; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(16,185,129,.3); }

.cb-btn-ghost { background: transparent; color: var(--cb-text-2); border-color: var(--cb-border); }
.cb-btn-ghost:hover { background: var(--cb-surface); color: var(--cb-text); }

.cb-btn-outline { background: transparent; color: var(--cb-navy); border-color: var(--cb-navy); }
.cb-btn-outline:hover { background: var(--cb-navy-l); }

.cb-btn-full { width: 100%; justify-content: center; }
.cb-btn-large { padding: 16px 36px; font-size: 17px; }

/* Loading state */
.cb-btn.loading { position: relative; color: transparent !important; }
.cb-btn.loading::after { 
  content: ''; 
  position: absolute; 
  width: 18px; height: 18px; 
  border: 2.5px solid rgba(255,255,255,.4); 
  border-top-color: #fff; 
  border-radius: 50%; 
  animation: cb-spin .7s linear infinite;
}

/* ============================================================
   STEP 3 — SUMMARY
============================================================ */
.cb-summary-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr)); gap: 20px; margin-bottom: 24px; }

.cb-summary-card {
  background: var(--cb-surface);
  border: 1.5px solid var(--cb-border);
  border-radius: var(--cb-radius);
  overflow: hidden;
}
.cb-summary-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--cb-border);
  background: var(--cb-bg);
}
.cb-summary-card-header h3 { font-size: 15px; font-weight: 700; margin: 0; }
.cb-edit-link { font-size: 13px; color: var(--cb-navy); font-weight: 600; cursor: pointer; background: none; border: none; padding: 4px 10px; border-radius: 6px; transition: var(--cb-transition); font-family: inherit; }
.cb-edit-link:hover { background: var(--cb-navy-l); }

.cb-summary-items { padding: 16px 20px; }
.cb-summary-item-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; border-bottom: 1px solid var(--cb-border); font-size: 14px; }
.cb-summary-item-row:last-child { border-bottom: none; }
.cb-summary-item-row .cb-item-qty { font-size: 12px; color: var(--cb-text-3); margin-left: 8px; }
.cb-summary-item-row .cb-item-pts { font-size: 12px; font-weight: 600; color: var(--cb-navy); }

.cb-summary-footer { display: flex; justify-content: space-between; align-items: center; padding: 14px 20px; background: var(--cb-navy-xl); border-top: 1px solid var(--cb-border); font-size: 15px; font-weight: 700; }
.cb-summary-footer strong { color: var(--cb-navy); }

.cb-summary-details { padding: 16px 20px; }
.cb-summary-detail-row { display: flex; justify-content: space-between; padding: 7px 0; border-bottom: 1px solid var(--cb-border); font-size: 14px; }
.cb-summary-detail-row:last-child { border-bottom: none; }
.cb-summary-detail-row span { color: var(--cb-text-3); }
.cb-summary-detail-row strong { text-align: right; }

/* Notices */
.cb-notice {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 16px 20px; border-radius: var(--cb-radius-sm);
  font-size: 14px; margin-bottom: 24px;
  line-height: 1.6;
}
.cb-notice-info { background: var(--cb-navy-l); color: var(--cb-navy); }
.cb-notice svg { flex-shrink: 0; margin-top: 2px; }

.cb-alert { display: flex; gap: 10px; align-items: flex-start; padding: 14px 18px; border-radius: var(--cb-radius-sm); font-size: 14px; margin: 16px 0; }
.cb-alert-success { background: var(--cb-mint-l); color: #065F46; }
.cb-alert-error   { background: var(--cb-red-l);  color: #991B1B; }

/* ============================================================
   SUCCESS SCREEN
============================================================ */
.cb-step-success { display: none; }
.cb-step-success.active { display: flex; align-items: center; justify-content: center; min-height: 50vh; }
.cb-success-wrap { text-align: center; max-width: 520px; margin: 0 auto; }
.cb-success-icon {
  width: 80px; height: 80px;
  background: var(--cb-mint);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 24px;
  box-shadow: 0 8px 32px rgba(16,185,129,.3);
  animation: cb-pop .5s cubic-bezier(.34,1.56,.64,1);
}
@keyframes cb-pop { from { transform: scale(0); opacity:0; } to { transform: scale(1); opacity:1; } }
.cb-success-icon svg { width: 36px; height: 36px; stroke: #fff; stroke-width: 3; }
.cb-success-wrap h2 { font-size: 28px; font-weight: 800; margin-bottom: 14px; color: var(--cb-text); }
.cb-success-wrap p  { font-size: 16px; color: var(--cb-text-2); line-height: 1.7; margin-bottom: 24px; }
.cb-success-order-id { display: inline-block; background: var(--cb-navy-l); color: var(--cb-navy); padding: 8px 20px; border-radius: 8px; font-size: 14px; font-weight: 600; margin-bottom: 24px; }

/* ============================================================
   AUTH BOX (login on account page)
============================================================ */
.cb-login-redirect { display: flex; align-items: center; justify-content: center; min-height: 50vh; padding: 40px 20px; }
.cb-auth-box { background: var(--cb-surface); border: 1.5px solid var(--cb-border); border-radius: var(--cb-radius); padding: 40px; max-width: 420px; width: 100%; box-shadow: var(--cb-shadow-md); text-align: center; }
.cb-auth-icon { font-size: 40px; margin-bottom: 16px; }
.cb-auth-box h2 { font-size: 22px; font-weight: 800; margin-bottom: 10px; }
.cb-auth-box p  { color: var(--cb-text-2); font-size: 15px; margin-bottom: 20px; }
.cb-or-register { margin-top: 16px; font-size: 14px; color: var(--cb-text-2); }
.cb-or-register a { color: var(--cb-navy); font-weight: 600; }

/* ============================================================
   ACCOUNT PAGE
============================================================ */
.cb-account-wrap { max-width: 1000px; margin: 0 auto; }

.cb-account-header {
  display: flex;
  align-items: center;
  gap: 18px;
  background: var(--cb-primary-gradient);
  border-radius: var(--cb-radius);
  padding: 28px 32px;
  margin-bottom: 28px;
  color: #fff;
  flex-wrap: wrap;
}
.cb-account-avatar {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: rgba(255,255,255,.2);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px;
  font-weight: 800;
  flex-shrink: 0;
  font-family: 'Raleway', sans-serif;
}
.cb-account-meta { flex: 1; }
.cb-account-meta h1 { font-size: 22px; font-weight: 800; color: #fff; margin-bottom: 4px; }
.cb-account-meta p  { font-size: 14px; color: rgba(255,255,255,.75); margin: 0; }
.cb-logout-btn { display: inline-flex; align-items: center; gap: 7px; background: rgba(255,255,255,.15); color: #fff; border: 1px solid rgba(255,255,255,.3); border-radius: 8px; padding: 8px 16px; font-size: 13px; font-weight: 600; cursor: pointer; text-decoration: none; transition: var(--cb-transition); font-family: inherit; }
.cb-logout-btn:hover { background: rgba(255,255,255,.25); text-decoration: none; color: #fff; }

/* Current Order Panel */
.cb-current-order {
  background: var(--cb-surface);
  border: 1.5px solid var(--cb-border);
  border-radius: var(--cb-radius);
  padding: 28px;
  margin-bottom: 24px;
}
.cb-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 24px;
}
.cb-section-head h2 { font-size: 20px; font-weight: 800; }

/* Status badge */
.cb-status-badge { display: inline-block; padding: 5px 14px; border-radius: 99px; font-size: 13px; font-weight: 700; }

/* Timeline */
.cb-timeline {
  display: flex;
  align-items: center;
  margin-bottom: 28px;
  overflow-x: auto;
  padding-bottom: 8px;
}
.cb-timeline-step { display: flex; flex-direction: column; align-items: center; gap: 8px; flex-shrink: 0; }
.cb-timeline-dot {
  width: 40px; height: 40px;
  border-radius: 50%;
  border: 2.5px solid var(--cb-border);
  background: var(--cb-surface);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px;
  transition: var(--cb-transition);
}
.cb-timeline-step.done .cb-timeline-dot   { background: var(--cb-mint); border-color: var(--cb-mint); color: #fff; font-size: 14px; font-weight: 700; }
.cb-timeline-step.active .cb-timeline-dot { background: var(--cb-navy); border-color: var(--cb-navy); box-shadow: 0 0 0 5px rgba(27,79,138,.15); }
.cb-timeline-label { font-size: 11px; font-weight: 600; color: var(--cb-text-3); text-align: center; white-space: nowrap; }
.cb-timeline-step.done .cb-timeline-label, .cb-timeline-step.active .cb-timeline-label { color: var(--cb-text-2); }

.cb-timeline-line { flex: 1; height: 2.5px; background: var(--cb-border); border-radius: 2px; min-width: 24px; transition: var(--cb-transition); }
.cb-tl-done { background: var(--cb-mint); }

/* Tracking box */
.cb-tracking-box {
  display: flex;
  align-items: center;
  gap: 16px;
  background: var(--cb-navy-l);
  border: 1.5px solid rgba(27,79,138,.2);
  border-radius: 10px;
  padding: 16px 20px;
  margin-bottom: 20px;
}
.cb-tracking-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--cb-text-3); flex-shrink: 0; }
.cb-tracking-number { font-family: monospace; font-size: 18px; font-weight: 700; color: var(--cb-navy); letter-spacing: 2px; }

/* Order items in account */
.cb-order-items-grid { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.cb-order-item-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--cb-navy-xl); border: 1px solid var(--cb-border);
  border-radius: 8px; padding: 6px 12px; font-size: 13px;
}
.cb-item-name { color: var(--cb-text); font-weight: 600; }
.cb-item-qty  { color: var(--cb-text-3); }
.cb-order-meta-row { display: flex; align-items: center; gap: 16px; font-size: 13px; color: var(--cb-text-3); flex-wrap: wrap; padding-top: 16px; border-top: 1px solid var(--cb-border); }
.cb-order-meta-row strong { color: var(--cb-text-2); }

/* Next Box CTA */
.cb-next-box-cta {
  display: flex;
  align-items: center;
  gap: 18px;
  background: linear-gradient(135deg, var(--cb-mint-l), #ECFDF5);
  border: 1.5px solid var(--cb-mint);
  border-radius: var(--cb-radius);
  padding: 24px 28px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}
.cb-cta-icon { font-size: 36px; }
.cb-cta-text { flex: 1; }
.cb-cta-text strong { display: block; font-size: 16px; font-weight: 700; color: var(--cb-text); margin-bottom: 4px; }
.cb-cta-text span   { display: block; font-size: 14px; color: var(--cb-text-2); }

.cb-next-box-locked {
  display: flex; align-items: center; gap: 10px;
  background: var(--cb-bg); border: 1px solid var(--cb-border);
  border-radius: var(--cb-radius); padding: 16px 20px;
  font-size: 14px; color: var(--cb-text-2); margin-bottom: 24px;
}

/* Order History */
.cb-order-history { margin-bottom: 24px; }
.cb-history-list { background: var(--cb-surface); border: 1.5px solid var(--cb-border); border-radius: var(--cb-radius); overflow: hidden; }
.cb-history-item {
  display: flex; align-items: center; gap: 16px;
  padding: 14px 20px; border-bottom: 1px solid var(--cb-border);
  font-size: 14px; transition: var(--cb-transition);
}
.cb-history-item:last-child { border-bottom: none; }
.cb-history-item:hover { background: var(--cb-bg); }
.cb-history-date { font-weight: 700; color: var(--cb-text); min-width: 100px; }
.cb-history-products { flex: 1; display: flex; flex-wrap: wrap; gap: 6px; }
.cb-history-products span { font-size: 12px; background: var(--cb-bg); border: 1px solid var(--cb-border); border-radius: 6px; padding: 2px 8px; color: var(--cb-text-2); }
.cb-history-status { flex-shrink: 0; }
.cb-history-points { font-size: 13px; color: var(--cb-text-3); font-weight: 600; flex-shrink: 0; }

/* Empty account */
.cb-empty-account { text-align: center; padding: 80px 20px; }
.cb-empty-account .cb-empty-icon { font-size: 64px; margin-bottom: 20px; }
.cb-empty-account h3 { font-size: 24px; font-weight: 800; margin-bottom: 12px; }
.cb-empty-account p  { color: var(--cb-text-2); font-size: 16px; max-width: 400px; margin: 0 auto 28px; }

/* ============================================================
   RESPONSIVE
============================================================ */
@media (max-width: 700px) {
  .cb-field-row { grid-template-columns: 1fr; }
  .cb-progress-inner { padding: 8px 14px; }
  .cb-step-label { display: none; }
  .cb-points-bar-inner { flex-direction: column; align-items: stretch; gap: 12px; }
  .cb-summary-grid { grid-template-columns: 1fr; }
  .cb-products-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }
  .cb-step-nav { flex-direction: column-reverse; gap: 12px; }
  .cb-step-nav .cb-btn { width: 100%; justify-content: center; }
  .cb-account-header { flex-direction: column; align-items: flex-start; }
  .cb-next-box-cta { flex-direction: column; }
  .cb-timeline { gap: 0; }
}

@media (max-width: 480px) {
  .cb-wrap, .cb-account-wrap { padding: 20px 14px 40px; }
  .cb-pflegegrad-group { gap: 6px; }
  .cb-radio-face { padding: 8px 12px; font-size: 13px; min-width: 48px; }
}
