/* ═══════════════════════════════════════════════════════════════════
   Society SaaS Manager — Frontend CSS v3.0
   Resident Portal + Registration — Modern, mobile-first
   ═══════════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root {
  --ssm-primary:   #0f2744;
  --ssm-primary2:  #1a4a7a;
  --ssm-teal:      #0d9488;
  --ssm-teal2:     #0f766e;
  --ssm-green:     #16a34a;
  --ssm-red:       #dc2626;
  --ssm-yellow:    #d97706;
  --ssm-text:      #1f2937;
  --ssm-muted:     #6b7280;
  --ssm-border:    #e2e8f0;
  --ssm-bg:        #f8fafc;
  --ssm-card:      #ffffff;
  --ssm-radius:    12px;
  --ssm-shadow:    0 2px 12px rgba(0,0,0,.07);
  --ssm-shadow-lg: 0 8px 40px rgba(0,0,0,.12);
}

/* ── Base ─────────────────────────────────────────────────────────── */
.ssm-register-wrap, .ssm-portal, .ssm-login-wrap,
.ssm-portal-gated, .ssm-portal-not-linked, .ssm-lw {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--ssm-text); line-height: 1.6; -webkit-font-smoothing: antialiased;
}

/* ════ REGISTRATION ═══════════════════════════════════════════════ */
.ssm-register-wrap { max-width: 700px; margin: 0 auto; padding: 32px 20px; }

.ssm-reg-hero {
  text-align: center; margin-bottom: 28px; padding: 36px 24px;
  background: linear-gradient(135deg, var(--ssm-primary) 0%, #1a4a7a 50%, #0d5c6e 100%);
  border-radius: var(--ssm-radius); color: #fff;
  box-shadow: var(--ssm-shadow-lg);
}
.ssm-reg-hero-icon { font-size: 3.5rem; margin-bottom: 10px; filter: drop-shadow(0 4px 8px rgba(0,0,0,.3)); }
.ssm-reg-hero h2   { margin: 0 0 8px; font-size: 1.8rem; font-weight: 800; }
.ssm-reg-hero p    { margin: 0; opacity: .85; font-size: .95rem; }

/* Step indicator */
.ssm-steps { display: flex; align-items: center; margin-bottom: 24px; gap: 0; }
.ssm-step  { display: flex; align-items: center; gap: 8px; font-size: .83rem; font-weight: 600; color: var(--ssm-muted); flex: none; }
.ssm-step span {
  width: 28px; height: 28px; border-radius: 50%;
  border: 2px solid var(--ssm-border);
  display: flex; align-items: center; justify-content: center;
  font-size: .78rem; font-weight: 700; background: #fff; transition: .3s;
}
.ssm-step.active       { color: var(--ssm-primary); }
.ssm-step.active span  { background: var(--ssm-primary); border-color: var(--ssm-primary); color: #fff; }
.ssm-step.done span    { background: var(--ssm-green); border-color: var(--ssm-green); color: #fff; }
.ssm-step.done span::before { content: '✓'; }
.ssm-step-line { flex: 1; height: 2px; background: var(--ssm-border); margin: 0 8px; }
.ssm-step-title { font-size: 1.05rem; font-weight: 700; color: var(--ssm-primary); margin: 0 0 16px; }

/* Form panels */
.ssm-step-panel {
  background: var(--ssm-card); border: 1px solid var(--ssm-border);
  border-radius: var(--ssm-radius); padding: 24px; margin-bottom: 16px;
  box-shadow: var(--ssm-shadow);
}
.ssm-form-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 14px; }
.ssm-fe-field { display: flex; flex-direction: column; margin-bottom: 14px; }
.ssm-fe-field.ssm-full { grid-column: 1 / -1; }
.ssm-fe-field label { font-size: .8rem; font-weight: 600; color: var(--ssm-text); margin-bottom: 5px; }
.ssm-req { color: var(--ssm-red); }
.ssm-fe-field input, .ssm-fe-field select, .ssm-fe-field textarea {
  padding: 10px 14px; border: 1.5px solid var(--ssm-border); border-radius: 8px;
  font-size: .9rem; width: 100%; box-sizing: border-box; transition: .2s;
  background: #fff; color: var(--ssm-text); font-family: 'Inter', sans-serif;
}
.ssm-fe-field input:focus, .ssm-fe-field select:focus, .ssm-fe-field textarea:focus {
  outline: none; border-color: var(--ssm-teal); box-shadow: 0 0 0 3px rgba(13,148,136,.1);
}
.ssm-fe-field input::placeholder, .ssm-fe-field textarea::placeholder { color: #9ca3af; }
.ssm-pass-wrap { position: relative; }
.ssm-pass-wrap input { padding-right: 44px; }
.ssm-pass-toggle {
  position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer; padding: 4px; color: var(--ssm-muted);
}

/* Nav buttons */
.ssm-step-nav { display: flex; gap: 10px; justify-content: flex-end; margin-top: 20px; padding-top: 14px; border-top: 1px solid var(--ssm-border); }
.ssm-btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 11px 22px; border-radius: 9px; font-size: .9rem; font-weight: 700; cursor: pointer; transition: .18s; border: none; text-decoration: none; font-family: 'Inter', sans-serif; }
.ssm-btn-primary { background: var(--ssm-primary); color: #fff; }
.ssm-btn-primary:hover { background: var(--ssm-primary2); }
.ssm-btn-primary:disabled { background: #94a3b8; cursor: not-allowed; }
.ssm-btn-outline { background: transparent; color: var(--ssm-primary); border: 1.5px solid var(--ssm-primary); }
.ssm-btn-outline:hover { background: #f0f4ff; }

/* Info box */
.ssm-info-box { background: #eff6ff; border-left: 4px solid var(--ssm-primary); border-radius: 0 8px 8px 0; padding: 12px 14px; font-size: .84rem; color: #1e40af; margin: 14px 0; }
.ssm-phone-wrap { display: flex; }
.ssm-phone-prefix { display: flex; align-items: center; padding: 0 10px; background: #f3f4f6; border: 1.5px solid var(--ssm-border); border-right: 0; border-radius: 8px 0 0 8px; font-size: .875rem; font-weight: 600; color: #374151; white-space: nowrap; }
.ssm-phone-wrap input { border-radius: 0 8px 8px 0 !important; border-left: 0 !important; flex: 1; }

/* Review card */
.ssm-review-card { background: #f8fafc; border: 1px solid var(--ssm-border); border-radius: 8px; padding: 16px; margin-bottom: 14px; }
.ssm-review-table { width: 100%; border-collapse: collapse; font-size: .875rem; }
.ssm-review-table td { padding: 7px 10px; border-bottom: 1px solid var(--ssm-border); }
.ssm-review-table td:first-child { color: var(--ssm-muted); width: 120px; font-weight: 600; }
.ssm-checkbox-label { display: flex; align-items: flex-start; gap: 8px; font-size: .875rem; cursor: pointer; }
.ssm-checkbox-label input { margin-top: 2px; width: 16px; height: 16px; cursor: pointer; flex: none; }
.ssm-checkbox-label a { color: var(--ssm-primary); }

/* Alerts */
.ssm-fe-error { background: #fef2f2; color: #b91c1c; border: 1px solid #fecaca; border-radius: 8px; padding: 10px 14px; font-size: .875rem; margin-bottom: 12px; }
.ssm-fe-msg   { border-radius: 8px; padding: 10px 14px; font-size: .875rem; margin-bottom: 12px; border: 1px solid; }
.ssm-fe-msg.success { background: #f0fdf4; color: #15803d; border-color: #bbf7d0; }
.ssm-fe-msg.error   { background: #fef2f2; color: #b91c1c; border-color: #fecaca; }

/* Done state */
.ssm-reg-done { text-align: center; padding: 40px 20px; background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: var(--ssm-radius); }
.ssm-done-icon { font-size: 4rem; margin-bottom: 12px; }
.ssm-reg-done h3 { font-size: 1.5rem; color: #15803d; margin: 0 0 8px; }
.ssm-done-sub { font-size: .84rem; color: var(--ssm-muted); margin-top: 8px !important; }

/* ════ RESIDENT PORTAL ═══════════════════════════════════════════ */
.ssm-portal { max-width: 840px; margin: 0 auto; font-family: 'Inter', -apple-system, sans-serif; }

.ssm-portal-topbar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 20px;
  background: linear-gradient(135deg, var(--ssm-primary) 0%, #1a4a7a 50%, #0d5c6e 100%);
  border-radius: var(--ssm-radius) var(--ssm-radius) 0 0;
  box-shadow: 0 2px 12px rgba(15,39,68,.2);
}
.ssm-portal-greeting { display: flex; align-items: center; gap: 12px; }
.ssm-portal-avatar {
  width: 42px; height: 42px; border-radius: 50%;
  background: rgba(255,255,255,.2); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 1.1rem; border: 2px solid rgba(255,255,255,.3);
}
.ssm-portal-name { color: #fff; font-weight: 700; font-size: .95rem; }
.ssm-portal-flat { color: rgba(255,255,255,.7); font-size: .8rem; }
.ssm-portal-logout {
  color: rgba(255,255,255,.75); font-size: .8rem; text-decoration: none;
  border: 1px solid rgba(255,255,255,.3); padding: 5px 12px;
  border-radius: 6px; transition: .2s;
}
.ssm-portal-logout:hover { background: rgba(255,255,255,.15); color: #fff; }

.ssm-portal-nav {
  display: flex; background: #fff;
  border-bottom: 2px solid var(--ssm-border);
  border-left: 1px solid var(--ssm-border);
  border-right: 1px solid var(--ssm-border);
  /* Fix: menu half-showing on narrow screens — scroll horizontally */
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;          /* Firefox */
  -ms-overflow-style: none;       /* IE/Edge */
  scroll-snap-type: x mandatory;
}
.ssm-portal-nav::-webkit-scrollbar { display: none; } /* Chrome/Safari */
.ssm-pnav-btn {
  flex: 0 0 auto;                 /* Fix: don't shrink — let nav scroll instead */
  min-width: 68px; max-width: 80px;
  background: none; border: none;
  border-bottom: 3px solid transparent; padding: 12px 8px;
  cursor: pointer; font-size: .75rem; font-weight: 600; color: var(--ssm-muted);
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  transition: .18s; margin-bottom: -2px; white-space: nowrap;
  scroll-snap-align: start;
}
.ssm-pnav-btn:hover { color: var(--ssm-primary); background: #f8fafc; }
.ssm-pnav-btn.active { color: var(--ssm-teal); border-bottom-color: var(--ssm-teal); }
.ssm-pnav-btn .pnav-icon { font-size: 1.2rem; }
.ssm-pnav-btn span { font-size: .68rem; }

.ssm-portal-body {
  background: #fff; border: 1px solid var(--ssm-border);
  border-top: none; border-radius: 0 0 var(--ssm-radius) var(--ssm-radius);
  padding: 20px; min-height: 320px;
}
.ssm-ptab-loading { color: #9ca3af; padding: 36px; text-align: center; font-style: italic; font-size: .875rem; }
.ssm-ptab-empty  { text-align: center; padding: 44px 20px; color: var(--ssm-muted); }
.ssm-ptab-empty::before { content: '📭'; display: block; font-size: 2.4rem; margin-bottom: 10px; }

/* Bill cards */
.ssm-bill-item {
  border: 1px solid var(--ssm-border); border-radius: 10px; padding: 16px;
  margin-bottom: 12px; display: flex; justify-content: space-between;
  align-items: center; flex-wrap: wrap; gap: 10px; transition: .2s;
}
.ssm-bill-item:hover { border-color: var(--ssm-teal); box-shadow: 0 2px 12px rgba(13,148,136,.1); }
.ssm-bill-month  { font-weight: 700; font-size: 1rem; color: var(--ssm-text); }
.ssm-bill-due    { font-size: .76rem; color: var(--ssm-muted); margin-top: 2px; }
.ssm-bill-amount { font-size: 1.3rem; font-weight: 800; color: var(--ssm-primary); }
.ssm-bill-balance-red   { color: var(--ssm-red);   font-size: .82rem; font-weight: 700; }
.ssm-bill-balance-green { color: var(--ssm-green); font-size: .82rem; font-weight: 700; }
.ssm-status-badge { display: inline-block; padding: 3px 10px; border-radius: 9999px; font-size: .7rem; font-weight: 700; }
.ssm-s-paid    { background: #dcfce7; color: #15803d; }
.ssm-s-pending { background: #dbeafe; color: #1d4ed8; }
.ssm-s-overdue { background: #fee2e2; color: #b91c1c; }
.ssm-s-partial { background: #fef3c7; color: #92400e; }

/* Pay now button */
.ssm-pay-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 18px; background: var(--ssm-teal); color: #fff;
  border: none; border-radius: 8px; font-weight: 700; font-size: .875rem;
  cursor: pointer; transition: .18s; font-family: 'Inter', sans-serif;
}
.ssm-pay-btn:hover { background: var(--ssm-teal2); }
.ssm-pay-btn:disabled { background: #94a3b8; cursor: not-allowed; }

/* Notice cards */
.ssm-notice-item {
  border-left: 4px solid var(--ssm-primary); background: #f8fafc;
  border-radius: 0 10px 10px 0; padding: 14px 16px; margin-bottom: 12px;
  transition: .2s;
}
.ssm-notice-item:hover { background: #f0f5ff; }
.ssm-notice-item.urgent   { border-left-color: #ea580c; background: #fff7ed; }
.ssm-notice-item.critical { border-left-color: var(--ssm-red); background: #fef2f2; }
.ssm-notice-title { font-weight: 700; margin: 0 0 5px; font-size: .95rem; }
.ssm-notice-body  { font-size: .875rem; color: var(--ssm-muted); margin: 0 0 6px; }
.ssm-notice-meta  { font-size: .74rem; color: #9ca3af; }

/* Complaint form */
.ssm-complaint-form { background: #f8fafc; border: 1px solid var(--ssm-border); border-radius: 10px; padding: 18px; margin-bottom: 20px; }
.ssm-complaint-form h4 { margin: 0 0 14px; font-size: .95rem; font-weight: 700; color: var(--ssm-primary); }

/* Gated / not-linked */
.ssm-portal-gated, .ssm-portal-not-linked { text-align: center; padding: 60px 20px; }
.ssm-gated-icon { font-size: 4rem; margin-bottom: 14px; }
.ssm-portal-gated h3, .ssm-portal-not-linked h3 { font-size: 1.4rem; margin-bottom: 8px; }

/* Already logged in */
.ssm-already-logged {
  background: #f0fdf4; border: 1px solid #bbf7d0;
  border-radius: 10px; padding: 20px; text-align: center;
}

/* ════ HIDE THEME LOGOUT LINK ON SSM PAGES ═══════════════════════ */
body.ssm-gate-page .nav-menu a[href*="action=logout"],
body.ssm-gate-page .main-navigation a[href*="action=logout"],
body.ssm-gate-page #site-navigation a[href*="action=logout"],
body.ssm-gate-page .ast-primary-menu a[href*="action=logout"],
body.ssm-gate-page header a[href*="action=logout"],
body.ssm-gate-page nav a[href*="action=logout"] { display: none !important; }
body.ssm-gate-page .nav-menu li:has(a[href*="action=logout"]),
body.ssm-gate-page .main-navigation li:has(a[href*="action=logout"]),
body.ssm-gate-page #site-navigation li:has(a[href*="action=logout"]),
body.ssm-gate-page header li:has(a[href*="action=logout"]),
body.ssm-gate-page nav li:has(a[href*="action=logout"]) { display: none !important; }

/* ════ RESPONSIVE ════════════════════════════════════════════════ */
@media(max-width: 600px) {
  .ssm-register-wrap, .ssm-portal { padding: 12px 8px; }
  .ssm-step { font-size: .72rem; }
  .ssm-step span { width: 24px; height: 24px; font-size: .68rem; }
  .ssm-steps { gap: 2px; }
  .ssm-step-line { margin: 0 4px; }
  .ssm-portal-topbar { flex-direction: column; align-items: flex-start; gap: 8px; }
  .ssm-portal-logout { align-self: flex-end; }
  .ssm-form-row { grid-template-columns: 1fr; }
  .ssm-reg-hero h2 { font-size: 1.4rem; }
}

/* ══ SSM Login Widget — shared across all login shortcodes ══════════ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

.ssm-lw *,.ssm-lw *::before,.ssm-lw *::after{box-sizing:border-box}
.ssm-lw{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;-webkit-font-smoothing:antialiased}

/* Split layout */
.ssm-lw--split{display:flex;min-height:100vh;width:100%}
.ssm-lw--center{display:flex;align-items:center;justify-content:center;min-height:100vh;
  background:linear-gradient(135deg,#f0f4ff 0%,#e8f5f5 100%);padding:20px}

/* Left Panel */
.ssm-lw-panel{flex:0 0 42%;display:flex;align-items:center;justify-content:center;
  padding:48px 40px;position:relative;overflow:hidden}
.ssm-lw-panel::after{content:'';position:absolute;bottom:-80px;right:-80px;width:320px;height:320px;
  border-radius:50%;background:rgba(255,255,255,.06)}
.ssm-lw-panel::before{content:'';position:absolute;top:-60px;left:-60px;width:240px;height:240px;
  border-radius:50%;background:rgba(255,255,255,.04)}
.ssm-lw-panel-inner{position:relative;z-index:1;max-width:340px;width:100%}
.ssm-lw-panel-logo{font-size:4rem;margin-bottom:16px;display:block;filter:drop-shadow(0 4px 12px rgba(0,0,0,.3))}
.ssm-lw-panel-brand{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:rgba(255,255,255,.55);margin-bottom:10px}
.ssm-lw-panel-title{font-size:2rem;font-weight:800;color:#fff;margin:0 0 14px;line-height:1.2}
.ssm-lw-panel-sub{font-size:.9rem;color:rgba(255,255,255,.7);margin:0 0 28px;line-height:1.6}
.ssm-lw-features{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.ssm-lw-features li{display:flex;align-items:center;gap:10px;font-size:.875rem;
  color:rgba(255,255,255,.85);font-weight:500}
.ssm-lw-features li::before{content:'✓';display:flex;align-items:center;justify-content:center;
  width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,.2);flex:none;
  font-size:.7rem;font-weight:800}
.ssm-lw-panel-footer{margin-top:40px;font-size:.72rem;color:rgba(255,255,255,.4);font-weight:500}

/* Right form area */
.ssm-lw-right{flex:1;display:flex;align-items:center;justify-content:center;
  background:#f8fafc;padding:32px 24px}

/* Box */
.ssm-lw-box{background:#fff;border-radius:20px;padding:36px 32px;width:100%;max-width:420px;
  box-shadow:0 4px 40px rgba(15,39,68,.10),0 1px 4px rgba(0,0,0,.04)}

/* Header */
.ssm-lw-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:24px}
.ssm-lw-icon{font-size:2.8rem;flex:none;line-height:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.12))}
.ssm-lw-heading{flex:1}
.ssm-lw-site{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  color:#9ca3af;margin-bottom:2px}
.ssm-lw-title{font-size:1.5rem;font-weight:800;color:#0f2744;margin:0 0 6px;line-height:1.2}
.ssm-lw-badge{display:inline-block;padding:2px 10px;border-radius:9999px;
  font-size:.68rem;font-weight:700;letter-spacing:.04em}

/* Messages */
.ssm-lw-msg{padding:12px 16px;border-radius:10px;font-size:.875rem;font-weight:500;
  margin-bottom:16px;display:flex;align-items:flex-start;gap:8px}
.ssm-lw-msg--error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}
.ssm-lw-msg--error::before{content:'⚠️';flex:none}
.ssm-lw-msg--success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}
.ssm-lw-msg--success::before{content:'✅';flex:none}

/* Fields */
.ssm-lw-field{margin-bottom:16px}
.ssm-lw-field label{display:block;font-size:.8rem;font-weight:600;color:#374151;margin-bottom:6px}
.ssm-lw-input{width:100%;padding:12px 16px;border:1.5px solid #e5e7eb;border-radius:10px;
  font-size:.95rem;font-family:inherit;color:#111827;background:#fff;
  transition:border-color .2s,box-shadow .2s;outline:none}
.ssm-lw-input:focus{border-color:#0d9488;box-shadow:0 0 0 3px rgba(13,148,136,.12)}
.ssm-lw-input::placeholder{color:#9ca3af}
.ssm-lw-pass-wrap{position:relative}
.ssm-lw-pass-wrap .ssm-lw-input{padding-right:48px}
.ssm-lw-tog{position:absolute;right:12px;top:50%;transform:translateY(-50%);
  background:none;border:none;cursor:pointer;color:#9ca3af;padding:4px;
  border-radius:6px;transition:color .2s;display:flex;align-items:center}
.ssm-lw-tog:hover{color:#374151}

/* Row */
.ssm-lw-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.ssm-lw-remember{display:flex;align-items:center;gap:7px;cursor:pointer;
  font-size:.84rem;color:#374151;font-weight:500}
.ssm-lw-remember input[type=checkbox]{width:16px;height:16px;accent-color:#0d9488;
  cursor:pointer;margin:0}
.ssm-lw-forgot{font-size:.84rem;color:#2563eb;text-decoration:none;font-weight:500}
.ssm-lw-forgot:hover{text-decoration:underline}

/* Submit */
.ssm-lw-submit{width:100%;padding:14px;border:none;border-radius:10px;color:#fff;
  font-size:1rem;font-weight:700;font-family:inherit;cursor:pointer;
  transition:opacity .2s,transform .1s;letter-spacing:.01em}
.ssm-lw-submit:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}
.ssm-lw-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}

/* Footer note */
.ssm-lw-footer-note{margin-top:16px;text-align:center;font-size:.75rem;color:#9ca3af}

/* Center-only layout */
.ssm-lw--center .ssm-lw-right{background:transparent;padding:0}
.ssm-lw--center .ssm-lw-box{box-shadow:0 8px 40px rgba(15,39,68,.14),0 1px 4px rgba(0,0,0,.06)}

/* Already logged in */
.ssm-lw-already{background:#f0fdf4;border:1px solid #86efac;border-radius:16px;
  padding:36px 24px;text-align:center;max-width:400px;margin:0 auto}
.ssm-lw-already-icon{font-size:3rem;margin-bottom:10px}

/* Responsive */
@media(max-width:900px){
  .ssm-lw--split{flex-direction:column}
  .ssm-lw-panel{flex:none;padding:32px 24px;min-height:auto}
  .ssm-lw-panel-title{font-size:1.6rem}
  .ssm-lw-features{display:grid;grid-template-columns:1fr 1fr}
  .ssm-lw-right{padding:24px 16px}
  .ssm-lw-box{padding:28px 20px}
}
@media(max-width:520px){
  .ssm-lw--split,.ssm-lw--center{min-height:auto}
  .ssm-lw-panel{padding:24px 20px}
  .ssm-lw-features{grid-template-columns:1fr}
  .ssm-lw-box{border-radius:16px;padding:24px 16px}
}

/* ── Admin bar offset: prevent WP admin bar overlapping SSM portal/gate menus ──
   Only society_admin sees the admin bar (gate_guard & flat_owner have it hidden via PHP).
   When society_admin views a frontend page with the bar visible, push the portal down. */
body.admin-bar .ssm-portal-topbar,
body.admin-bar .ssm-portal > *:first-child {
  /* No sticky positioning used on portal — no offset needed */
}
/* Gate menu header gets admin bar offset (gate topbar is position:sticky top:0) */
body.admin-bar .gate-topbar { top: 32px !important; }
@media screen and (max-width: 782px) {
  body.admin-bar .gate-topbar { top: 46px !important; }
}
/* Visitor-approval page — if it uses a sticky top menu, push it down */
body.admin-bar .ssm-va-topbar { top: 32px !important; }
@media screen and (max-width: 782px) {
  body.admin-bar .ssm-va-topbar { top: 46px !important; }
}

/* ── WordPress Admin bar + SSM portal: ensure content is not hidden under admin bar ──
   WordPress adds margin-top: 32px (46px on mobile) to <html> when admin bar is shown.
   This handles the edge case where a theme overrides that. */
body.admin-bar { padding-top: 0 !important; }
html.admin-bar  { margin-top: 32px !important; }
@media screen and (max-width: 782px) {
  html.admin-bar { margin-top: 46px !important; }
}
/* Ensure WP nav menu links are accessible even with admin bar */
body.admin-bar .ssm-portal-topbar,
body.admin-bar .ssm-portal-nav { position: relative; z-index: 90; }

/* ════════════════════════════════════════════════════════════════════
   RESIDENT PORTAL — COMPREHENSIVE MOBILE RESPONSIVE
   ════════════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* ── Portal wrapper ── */
  .ssm-portal { padding: 0 !important; overflow-x: hidden; }

  /* ── Top bar ── */
  .ssm-portal-topbar { padding: 10px 12px; flex-wrap: wrap; gap: 8px; }
  .ssm-portal-topbar h2 { font-size: 1rem; }

  /* ── Nav tabs: horizontal scroll ── */
  .ssm-portal-nav { gap: 0; padding: 0 8px; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; white-space: nowrap; display: flex; }
  .ssm-portal-nav::-webkit-scrollbar { display: none; }
  .ssm-portal-nav a, .ssm-portal-nav button { flex-shrink: 0; padding: 10px 10px; font-size: .75rem; }
  .ssm-portal-nav .ssm-nav-icon { font-size: .9rem; }

  /* ── Resident info card ── */
  .ssm-resident-card { padding: 12px; border-radius: 10px; margin: 8px; }
  .ssm-resident-name { font-size: 1rem; }

  /* ── Section panels ── */
  .ssm-portal-section { padding: 12px; margin: 8px; border-radius: 10px; }
  .ssm-portal-section h3 { font-size: .95rem; }

  /* ── Form rows: single column on small screens ── */
  .ssm-form-row { grid-template-columns: 1fr !important; gap: 10px; }
  .ssm-fe-field input,
  .ssm-fe-field select,
  .ssm-fe-field textarea { font-size: 16px !important; } /* prevent iOS zoom */
  .ssm-fe-field input[type="date"],
  .ssm-fe-field input[type="time"] { font-size: 16px !important; }

  /* ── Bill/Payment cards ── */
  .ssm-bill-card { padding: 12px; border-radius: 10px; }
  .ssm-bill-row { flex-direction: column; gap: 6px; }
  .ssm-bill-actions { flex-wrap: wrap; gap: 6px; }

  /* ── Visitor list items ── */
  .ssm-visitor-item { padding: 10px 12px; flex-direction: column; gap: 6px; }
  .ssm-visitor-actions { display: flex; gap: 6px; flex-wrap: wrap; }
  .ssm-visitor-actions button { flex: 1; font-size: .78rem; }

  /* ── Complaint/Notice items ── */
  .ssm-notice-item, .ssm-complaint-item { padding: 10px 12px; }

  /* ── Buttons ── */
  .ssm-btn { padding: 10px 16px; font-size: .875rem; }
  .ssm-btn-primary { width: 100%; justify-content: center; }

  /* ── Pre-approve form ── */
  #pa-visit-date, #pa-visit-time,
  #av-visit-date, #av-visit-time { width: 100% !important; font-size: 16px !important; }

  /* ── Delivery items ── */
  .ssm-delivery-item { flex-direction: column; gap: 6px; }

  /* ── Amenity cards ── */
  .ssm-amenity-card { padding: 10px; }

  /* ── Polls ── */
  .ssm-poll-option { padding: 10px 12px; }

  /* ── Account page ── */
  .ssm-account-field { flex-direction: column; gap: 4px; }
}

@media (max-width: 390px) {
  .ssm-portal-nav a, .ssm-portal-nav button { padding: 8px 8px; font-size: .68rem; }
  .ssm-portal-topbar { padding: 8px 10px; }
  .ssm-btn { font-size: .8rem; padding: 8px 12px; }
}
