/* ==========================================================================
   ConsultSmart — Brand tokens, Bootstrap 5 overrides, component styles
   ========================================================================== */

/* ── Consistent Rupee symbol font (U+20B9 only) ─────────────────────────── */
/* CS-Rupee aliases Inter (or fallbacks) for the single rupee glyph.
   Because unicode-range is U+20B9 only, every other character falls through
   to whatever font the element is already using. */
@font-face {
  font-family: 'CS-Rupee';
  src: local('Inter'), local('Noto Sans'), local('Segoe UI'), local('Roboto'), local('Arial');
  font-weight: 100 900;
  font-style: normal;
  unicode-range: U+20B9;
}
/* Helper class for inline use: <span class="rupee">₹</span> */
.rupee { font-family: 'CS-Rupee', inherit; font-feature-settings: 'tnum'; }

:root{
  --cs-navy:#0B1F3A; --cs-navy-mid:#162D50; --cs-navy-light:#1E3D6B;
  --cs-gold:#C9992A; --cs-gold-light:#E8B84B; --cs-gold-pale:#FDF3DC;
  --cs-slate:#4A5B73; --cs-slate-light:#7A8EA8;
  --cs-bg:#F7F9FC; --cs-surface:#FFFFFF; --cs-border:#DDE4ED;
  --cs-text:#0B1F3A; --cs-text-mid:#3A4D62; --cs-text-muted:#7A8EA8;
  --cs-success:#1A7A4E; --cs-success-bg:#EAF6F0;
  --cs-danger:#B91C1C;  --cs-danger-bg:#FEF2F2;
  --cs-warning:#D97706; --cs-warning-bg:#FEF9C3;
  --cs-radius-sm:6px; --cs-radius-md:10px; --cs-radius-lg:16px; --cs-radius-xl:24px;
  --cs-shadow-sm:0 1px 4px rgba(11,31,58,.08);
  --cs-shadow-md:0 4px 20px rgba(11,31,58,.12);
  --cs-shadow-lg:0 12px 40px rgba(11,31,58,.18);
  --cs-font-display:'CS-Rupee', 'Playfair Display', Georgia, serif;
  --cs-font-body:'CS-Rupee', 'DM Sans', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --cs-font-num:'Inter', 'DM Sans', system-ui, sans-serif;
  --cs-nav-h:80px;
}

/* ===== Base ===== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--cs-font-body);background:var(--cs-bg);color:var(--cs-text);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--cs-navy);text-decoration:none;transition:color .15s}
a:hover{color:var(--cs-gold)}
.cs-display,.h1,h1{font-family:var(--cs-font-display);letter-spacing:-.5px}
h2,h3,h4,h5{font-family:var(--cs-font-display);letter-spacing:-.3px;color:var(--cs-navy)}
.bg-light{background:var(--cs-bg)!important}

/* ===== Buttons ===== */
.btn{font-family:var(--cs-font-body);font-weight:600;border-radius:var(--cs-radius-sm);transition:all .15s;border:1.5px solid transparent;padding:.55rem 1.1rem;font-size:.9rem;line-height:1.4;min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:.35rem}
.btn-navy{background:var(--cs-navy);color:#fff}
.btn-navy:hover{background:var(--cs-navy-light);color:#fff}
.btn-gold{background:var(--cs-gold);color:var(--cs-navy)}
.btn-gold:hover{background:var(--cs-gold-light);color:var(--cs-navy)}
.btn-ghost-light{background:transparent;border-color:rgba(255,255,255,.25);color:#fff}
.btn-ghost-light:hover{border-color:var(--cs-gold-light);color:var(--cs-gold-light)}
.btn-outline-navy{border-color:var(--cs-navy);color:var(--cs-navy);background:transparent}
.btn-outline-navy:hover{background:var(--cs-navy);color:#fff}
.btn-outline-gold{border-color:var(--cs-gold);color:var(--cs-gold);background:transparent}
.btn-outline-gold:hover{background:var(--cs-gold);color:var(--cs-navy)}
.btn-sm{padding:.4rem .9rem;font-size:.82rem;min-height:34px;line-height:1.3}
.btn-lg{padding:.75rem 1.4rem;font-size:1rem;min-height:48px}
/* Bootstrap nav-link/dropdown-item buttons should not inherit min-height */
.dropdown-item.btn,
.nav-link.btn{min-height:auto}

/* ===== Navbar ===== */
.cs-nav{background:var(--cs-navy);height:var(--cs-nav-h);position:sticky;top:0;z-index:1030;box-shadow:0 2px 20px rgba(0,0,0,.25);border-bottom:1px solid rgba(201,153,42,.32);padding-left:5%;padding-right:5%}
.cs-nav .container-xl{max-width:1140px;padding-left:0;padding-right:0}
/* Dashboard variant: nav spans the full width to match the dashboard's sidebar+main layout below. */
.cs-nav.is-dashboard{padding-left:1.25rem;padding-right:1.25rem}
.cs-nav.is-dashboard .container-xl{max-width:none}
.cs-nav.is-dashboard .cs-nav-actions{margin-left:auto}
.cs-nav .navbar-nav .nav-link{color:rgba(255,255,255,.7);font-size:.92rem;font-weight:400;padding:.25rem 1rem;transition:color .15s}
.cs-nav .navbar-nav .nav-link:hover,.cs-nav .navbar-nav .nav-link.active{color:#fff}
.cs-logo{display:flex;align-items:center;gap:11px;text-decoration:none}
.cs-logo:hover{text-decoration:none}
.cs-logo-shield{width:44px;height:52px;flex-shrink:0;filter:drop-shadow(0 3px 8px rgba(201,153,42,.4))}
.cs-logo-wordmark{display:flex;flex-direction:column;gap:2px;line-height:1}
.cs-logo-text{font-family:var(--cs-font-display);font-size:1.55rem;font-weight:700;color:#fff;letter-spacing:-.3px;line-height:1.1}
.cs-logo-text em{font-style:normal;color:var(--cs-gold-light)}
.cs-logo-tag{font-family:var(--cs-font-body);font-size:.68rem;font-weight:500;color:rgba(255,255,255,.42);letter-spacing:2.4px;text-transform:uppercase}
/* Light variant (use .cs-logo-light on the same <a>) for white backgrounds: */
.cs-logo-light .cs-logo-text{color:var(--cs-navy)}
.cs-logo-light .cs-logo-text em{color:var(--cs-gold)}
.cs-logo-light .cs-logo-tag{color:rgba(11,31,58,.42)}
@media (max-width:600px){.cs-logo-shield{width:36px;height:42px}.cs-logo-text{font-size:1.25rem}.cs-logo-tag{font-size:.58rem}}
.cs-logo-mark{width:36px;height:36px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;background:linear-gradient(135deg,#C9992A 0%,#E8B84B 60%,#a87c1f 100%);color:#fff;font-family:var(--cs-font-body);font-weight:800;font-size:.95rem;letter-spacing:-.02em;box-shadow:0 4px 14px -4px rgba(201,153,42,.55),inset 0 1px 0 rgba(255,255,255,.25)}
.cs-nav-actions{display:flex;gap:.6rem;align-items:center}

/* Dashboard navbar search */
.cs-nav-search{position:relative;display:inline-block}
.cs-nav-search i{position:absolute;left:.85rem;top:50%;transform:translateY(-50%);color:rgba(255,255,255,.55);font-size:.85rem;pointer-events:none;z-index:2}
.cs-nav-search input{width:220px;padding:.42rem .95rem .42rem 2.15rem;border-radius:100px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff;font-size:.82rem;font-family:var(--cs-font-body);transition:background .15s,border-color .15s,width .25s;outline:none}
.cs-nav-search input::placeholder{color:rgba(255,255,255,.5)}
.cs-nav-search input:focus{background:rgba(255,255,255,.15);border-color:var(--cs-gold-light);color:#fff;width:280px}
.cs-nav-search input:focus::placeholder{color:rgba(255,255,255,.7)}
.cs-nav-search input::-webkit-search-cancel-button{filter:invert(.8)}
/* Defeat Chrome autofill yellow + bold weight on form inputs */
input:-webkit-autofill,input:-webkit-autofill:hover,input:-webkit-autofill:focus,input:-webkit-autofill:active{
  -webkit-text-fill-color:var(--cs-navy)!important;
  -webkit-box-shadow:0 0 0 1000px #fff inset!important;
  transition:background-color 9999s ease-in-out 0s;
  font-weight:400!important;
}

.cs-avatar-nav{width:36px;height:36px;border-radius:50%;background:var(--cs-gold);color:var(--cs-navy);font-family:var(--cs-font-display);font-size:.85rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.2);cursor:pointer}
.cs-avatar-nav.client{background:var(--cs-gold-pale);color:var(--cs-gold);border:2px solid var(--cs-gold)}

/* ===== Hero ===== */
.cs-hero{background:linear-gradient(135deg,var(--cs-navy) 0%,var(--cs-navy-mid) 55%,#1C3A62 100%);padding:3.75rem 0 3.25rem;position:relative;overflow:hidden;color:#fff}
.cs-hero::before{content:'';position:absolute;top:-100px;right:-100px;width:480px;height:480px;background:radial-gradient(circle,rgba(201,153,42,.13) 0%,transparent 70%);border-radius:50%}
.cs-hero::after{content:'';position:absolute;bottom:-60px;left:8%;width:280px;height:280px;background:radial-gradient(circle,rgba(201,153,42,.06) 0%,transparent 70%);border-radius:50%}
/* Lift all container variants above the absolute-positioned decorative
   orbs — otherwise the orbs intercept clicks on hero CTAs (e.g. the
   "Browse Consultants" button sits right over the bottom-left orb). */
.cs-hero .container,
.cs-hero .container-xl,
.cs-hero .container-lg,
.cs-hero .container-md{position:relative;z-index:2}
.cs-hero::before,
.cs-hero::after{pointer-events:none}
.cs-hero h1{font-size:3rem;font-weight:700;color:#fff;line-height:1.12;margin-bottom:1.1rem;letter-spacing:-1px}
.cs-hero h1 em{font-style:normal;color:var(--cs-gold-light)}
.cs-hero-sub{font-size:1.05rem;color:rgba(255,255,255,.62);max-width:480px;font-weight:300;line-height:1.75;margin-bottom:1.8rem}
.cs-eyebrow{display:inline-flex;align-items:center;gap:.5rem;background:rgba(201,153,42,.14);border:1px solid rgba(201,153,42,.3);border-radius:100px;padding:.3rem .9rem;color:var(--cs-gold-light);font-size:.75rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase;margin-bottom:1.3rem}
.cs-eyebrow .dot{width:7px;height:7px;background:var(--cs-gold);border-radius:50%}
.cs-stat-row{display:flex;gap:2rem;flex-wrap:wrap;margin-top:1.5rem}
.cs-stat-row > div strong{display:block;font-family:var(--cs-font-display);font-size:1.6rem;font-weight:700;color:#fff}
.cs-stat-row > div span{font-size:.7rem;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.5px}

/* ===== Search card on hero ===== */
.cs-search-card{background:#fff;border-radius:var(--cs-radius-xl);padding:1.8rem;box-shadow:var(--cs-shadow-lg);color:var(--cs-text)}
.cs-search-card h3{font-family:var(--cs-font-display);font-size:1.25rem;color:var(--cs-navy);margin-bottom:.2rem}
.cs-search-card > p{font-size:.85rem;color:var(--cs-text-muted);margin-bottom:1.1rem}

/* ===== Sections ===== */
.cs-section{padding:2.75rem 0}
.cs-section-head .cs-eyebrow{background:transparent;border:none;padding:0;color:var(--cs-gold)}
.cs-section-head .cs-eyebrow::before{content:'';display:inline-block;width:8px;height:8px;background:var(--cs-gold);border-radius:50%;margin-right:.5rem;box-shadow:0 0 0 2px rgba(201,153,42,.2)}
.cs-section-title{font-family:var(--cs-font-display);font-size:2rem;font-weight:700;color:var(--cs-navy);line-height:1.2;letter-spacing:-.5px}
.cs-section-sub{font-size:.95rem;color:var(--cs-text-muted);font-weight:300;max-width:560px}

/* ===== Trust bar ===== */
.cs-trust-bar{background:#fff;border-top:1px solid var(--cs-border);border-bottom:1px solid var(--cs-border);padding:1rem 0}
.cs-trust-label{font-size:.7rem;font-weight:600;color:var(--cs-text-muted);text-transform:uppercase;letter-spacing:.8px;white-space:nowrap}
.cs-trust-logo{font-size:.85rem;font-weight:600;color:var(--cs-slate-light);opacity:.6}

/* ===== Category card ===== */
.cs-category-card{display:flex;align-items:center;gap:.8rem;padding:1.1rem;background:#fff;border:1px solid var(--cs-border);border-radius:var(--cs-radius-md);color:inherit;transition:all .15s;height:100%}
.cs-category-card:hover{border-color:var(--cs-navy);box-shadow:var(--cs-shadow-sm);color:inherit;transform:translateY(-2px)}
.cs-cat-icon{width:46px;height:46px;border-radius:var(--cs-radius-sm);background:linear-gradient(135deg,rgba(11,31,58,.06) 0%,rgba(201,153,42,.10) 100%);border:1px solid rgba(11,31,58,.08);display:flex;align-items:center;justify-content:center;color:var(--cs-navy);flex-shrink:0;transition:all .2s}
.cs-cat-icon svg{width:24px;height:24px;display:block}
.cs-category-card:hover .cs-cat-icon{background:linear-gradient(135deg,var(--cs-navy) 0%,var(--cs-navy-light) 100%);color:#E8B84B;border-color:transparent;box-shadow:0 4px 12px -2px rgba(11,31,58,.25)}
.cs-category-card strong{display:block;font-size:.88rem;color:var(--cs-navy);font-family:var(--cs-font-body);font-weight:600}
.cs-category-card small{font-size:.72rem;color:var(--cs-text-muted)}

/* ===== Consultant card ===== */
.cs-card{background:#fff;border:1px solid var(--cs-border);border-radius:var(--cs-radius-lg);padding:1.4rem;transition:all .2s;position:relative;overflow:hidden}
.cs-card.consultant-card{cursor:pointer}
.cs-card.consultant-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--cs-gold);opacity:0;transition:opacity .2s}
.cs-card.consultant-card:hover{box-shadow:var(--cs-shadow-md);transform:translateY(-2px);border-color:rgba(201,153,42,.3)}
.cs-card.consultant-card:hover::before{opacity:1}
.cs-card-title{font-size:1rem;font-weight:600;color:var(--cs-navy);font-family:var(--cs-font-body);margin:0}
.cs-card-title a{color:inherit}
.cs-card-bio{font-size:.82rem;color:var(--cs-text-muted);margin-bottom:1rem;font-weight:300;line-height:1.6}
.cs-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.9rem;border-top:1px solid var(--cs-border)}
.cs-rate{font-size:1rem;font-weight:700;color:var(--cs-navy)}
.cs-rate span{font-size:.72rem;font-weight:400;color:var(--cs-text-muted)}

/* ===== Avatars ===== */
.cs-avatar{width:48px;height:48px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:var(--cs-font-display);font-size:1rem;font-weight:700;flex-shrink:0;overflow:hidden}
.cs-avatar img,.cs-avatar-nav img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}
.cs-avatar-nav{overflow:hidden}
.cs-avatar.lg{width:64px;height:64px;font-size:1.2rem}
.cs-avatar.xl{width:84px;height:84px;font-size:1.6rem}
.cs-avatar.sm{width:36px;height:36px;font-size:.8rem}
.cs-avatar.md{width:44px;height:44px;font-size:.9rem}
.av-navy{background:var(--cs-navy);color:var(--cs-gold-light)}
.av-gold{background:var(--cs-gold-pale);color:var(--cs-gold);border:2px solid var(--cs-gold)}
.av-slate{background:#EBF0F7;color:var(--cs-navy)}
.av-teal{background:#E0F5F1;color:#0F6E56}
.av-coral{background:#FAECE7;color:#D85A30}
.av-violet{background:#EEE7FA;color:#6B3FA0}

/* ===== Tags & badges ===== */
.cs-tag{display:inline-block;background:#EEF2F8;color:var(--cs-slate);font-size:.7rem;font-weight:500;padding:.2rem .55rem;border-radius:100px;border:1px solid var(--cs-border)}
.cs-tag-gold{background:var(--cs-gold-pale);color:var(--cs-gold);border:1px solid rgba(201,153,42,.25);font-size:.7rem;font-weight:600;padding:.2rem .6rem;border-radius:100px}
.cs-badge-verified{background:var(--cs-success-bg);color:var(--cs-success);font-size:.7rem;font-weight:600;padding:.2rem .55rem;border-radius:100px;display:inline-flex;align-items:center;gap:3px}
.cs-badge-pro{background:rgba(201,153,42,.2);color:var(--cs-gold-light);font-size:.65rem;font-weight:600;padding:.2rem .55rem;border-radius:100px}

/* Sidebar plan badge — designed for dark navy backgrounds */
.cs-plan-badge{display:inline-flex;align-items:center;gap:.3rem;background:linear-gradient(135deg,var(--cs-gold) 0%,var(--cs-gold-light) 100%);color:var(--cs-navy);font-size:.72rem;font-weight:700;padding:.32rem .75rem;border-radius:100px;letter-spacing:.3px;box-shadow:0 1px 4px rgba(201,153,42,.35);white-space:nowrap}
.cs-plan-badge i{font-size:.72rem}
.cs-plan-badge.cs-plan-badge-verified{background:rgba(255,255,255,.95);color:var(--cs-success);box-shadow:0 1px 4px rgba(26,122,78,.25)}
.cs-role-badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.62rem;font-weight:700;padding:3px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.12em;line-height:1.3;white-space:nowrap;border:1px solid transparent}
.cs-role-badge i{font-size:.7rem}
.cs-role-badge.cs-role-client{background:rgba(255,255,255,.08);color:#BAE6FD;border-color:rgba(186,230,253,.25)}
.cs-role-badge.cs-role-consultant{background:rgba(232,184,75,.14);color:#FDF3DC;border-color:rgba(232,184,75,.35)}

/* ===== Stars ===== */
.cs-stars{color:var(--cs-gold);font-size:.82rem;display:inline-flex;align-items:center;gap:3px}
.cs-stars .count{color:var(--cs-text-muted);font-size:.75rem;font-weight:400}

/* ===== Forms ===== */
.cs-input,.form-control,.form-select{padding:.65rem .9rem;border:1.5px solid var(--cs-border);border-radius:var(--cs-radius-sm);font-family:var(--cs-font-body);font-size:.92rem;color:var(--cs-text);background:var(--cs-bg);transition:border-color .15s}
.cs-input:focus,.form-control:focus,.form-select:focus{border-color:var(--cs-navy-light);background:#fff;box-shadow:0 0 0 3px rgba(11,31,58,.08);outline:none}
.form-label{font-size:.72rem;font-weight:600;color:var(--cs-text-mid);text-transform:uppercase;letter-spacing:.6px;margin-bottom:.4rem}

/* ===== How-it-works (dark section) ===== */
.cs-hiw{background:var(--cs-navy);padding:5rem 0;color:#fff;position:relative;overflow:hidden}
.cs-hiw .cs-section-title{color:#fff}
.cs-hiw .cs-eyebrow{background:transparent;border:none;color:var(--cs-gold)}
.cs-step{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--cs-radius-lg);padding:1.7rem 1.3rem;text-align:center;height:100%}
.cs-step-num{width:42px;height:42px;border-radius:50%;background:rgba(201,153,42,.15);border:1px solid rgba(201,153,42,.35);color:var(--cs-gold-light);font-family:var(--cs-font-display);font-size:1rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;margin-bottom:.9rem}
.cs-step h4{font-size:.95rem;font-weight:600;color:#fff;margin-bottom:.4rem;font-family:var(--cs-font-body)}
.cs-step p{font-size:.78rem;color:rgba(255,255,255,.5);line-height:1.6;font-weight:300;margin:0}

/* ===== Testimonial ===== */
.cs-testi{background:#fff;border:1px solid var(--cs-border);border-radius:var(--cs-radius-lg);padding:1.6rem;height:100%}
.cs-testi .cs-stars{margin-bottom:.6rem}
.cs-testi blockquote{font-size:.85rem;color:var(--cs-text-mid);line-height:1.7;margin-bottom:1.1rem;font-style:italic}

/* ===== FAQ ===== */
.cs-faq-item{background:#fff;border:1px solid var(--cs-border);border-radius:var(--cs-radius-md);padding:1.1rem 1.3rem;cursor:pointer;margin-bottom:.7rem;transition:box-shadow .15s}
.cs-faq-item:hover{box-shadow:var(--cs-shadow-sm)}
.cs-faq-q{font-size:.92rem;font-weight:600;color:var(--cs-navy);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.cs-faq-q .ic{color:var(--cs-gold);font-size:1.2rem;transition:transform .2s}
.cs-faq-item.open .cs-faq-q .ic{transform:rotate(45deg)}
.cs-faq-a{display:none;margin-top:.7rem;font-size:.85rem;color:var(--cs-text-mid);line-height:1.7;font-weight:300}
.cs-faq-item.open .cs-faq-a{display:block}

/* ===== Footer ===== */
.cs-footer{background:var(--cs-navy);color:rgba(255,255,255,.6);padding:3.5rem 0 1.5rem}
.cs-footer h5{font-size:.72rem;font-weight:600;color:#fff;margin-bottom:.8rem;text-transform:uppercase;letter-spacing:.5px;font-family:var(--cs-font-body)}
.cs-footer ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:.5rem;margin:0}
.cs-footer a{color:rgba(255,255,255,.42);font-size:.78rem;font-weight:300}
.cs-footer a:hover{color:var(--cs-gold-light)}
.cs-footer .footer-brand p{font-size:.82rem;color:rgba(255,255,255,.42);margin-top:.7rem;font-weight:300;line-height:1.7}
.cs-footer-brand{display:inline-flex;align-items:center;gap:.7rem;text-decoration:none;margin-bottom:1.1rem}
.cs-footer-brand:hover{text-decoration:none}
.cs-footer-wordmark{font-family:var(--cs-font-display);font-size:1.4rem;font-weight:700;color:#fff;letter-spacing:-.3px;line-height:1}
.cs-footer-wordmark em{font-style:normal;color:var(--cs-gold-light)}
.cs-footer-tag{display:block;font-family:var(--cs-font-body);font-size:.6rem;font-weight:500;color:rgba(255,255,255,.4);letter-spacing:2px;text-transform:uppercase;margin-top:3px}
.cs-footer-blurb{font-size:.85rem;color:rgba(255,255,255,.5);line-height:1.7;max-width:380px;margin:0;font-weight:400}
.cs-footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:1.5rem;margin-top:2.5rem;display:flex;justify-content:space-between;font-size:.7rem;color:rgba(255,255,255,.28);flex-wrap:wrap;gap:.5rem}

/* ===== Auth (split screen) ===== */
.cs-auth{min-height:calc(100vh - var(--cs-nav-h));display:grid;grid-template-columns:1fr 1.15fr}
.cs-auth-left{background:linear-gradient(145deg,var(--cs-navy) 0%,var(--cs-navy-mid) 100%);padding:2.5rem 3rem;display:flex;flex-direction:column;justify-content:flex-start;color:#fff;position:relative;overflow:hidden}
.cs-auth-left::before{content:'';position:absolute;bottom:-80px;right:-80px;width:340px;height:340px;background:radial-gradient(circle,rgba(201,153,42,.14) 0%,transparent 70%);border-radius:50%}
.cs-auth-left h2{font-family:var(--cs-font-display);font-size:2.4rem;font-weight:700;color:#fff;line-height:1.2;margin-bottom:1rem;position:relative;z-index:1}
.cs-auth-left h2 em{font-style:normal;color:var(--cs-gold-light)}
.cs-auth-left > p{font-size:.92rem;color:rgba(255,255,255,.6);line-height:1.5;margin:0 0 1.3rem;max-width:380px;position:relative;z-index:1;font-weight:400}
.cs-auth-feature{
  display:flex;
  align-items:flex-start;        /* icon aligns with title, not vertical-mid of wrapped text */
  gap:.85rem;
  margin-bottom:1rem;            /* more breathing room between rows */
  position:relative;
  z-index:1;
}
.cs-auth-feature:last-child{ margin-bottom:0; }
/* Push the first feature card away from the intro paragraph above it. */
p + .cs-auth-feature,
.cs-auth-feature:first-of-type{ margin-top:1.75rem; }
.cs-auth-feature .ic{
  width:40px; height:40px;       /* slightly larger for visual weight */
  border-radius:10px;
  background:rgba(201,153,42,.15);
  border:1px solid rgba(201,153,42,.3);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.05rem;
  flex-shrink:0;
  margin-top:1px;                /* nudge to optically align with the title baseline */
}
.cs-auth-feature > div:last-child{ padding-top:1px; min-width:0; }   /* min-width:0 lets long lines wrap inside flex */
.cs-auth-feature strong{
  display:block;
  font-size:.9rem;
  font-weight:600;
  color:#fff;
  line-height:1.3;
  margin-bottom:.15rem;
}
.cs-auth-feature span{
  display:block;
  font-size:.78rem;
  color:rgba(255,255,255,.55);
  line-height:1.45;
}

/* ===== Auth hero stats showcase ===== */
.cs-auth-left .cs-eyebrow{margin:0 0 1.1rem;display:inline-flex;align-self:flex-start}
.cs-auth-left h2{font-size:2rem;line-height:1.2;margin:0 0 1.4rem;max-width:420px}
.cs-auth-left p{margin:0}
.cs-stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem;margin:0 0 1.4rem;position:relative;z-index:1;max-width:420px}
.cs-stat-tile{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--cs-radius-lg);padding:1.1rem 1.2rem;transition:background .2s,border-color .2s,transform .2s;position:relative;overflow:hidden}
.cs-stat-tile:hover{background:rgba(255,255,255,.08);border-color:rgba(201,153,42,.35);transform:translateY(-2px)}
.cs-stat-tile::before{content:'';position:absolute;top:0;left:0;width:30px;height:2px;background:var(--cs-gold);border-radius:0 0 2px 0;transition:width .25s}
.cs-stat-tile:hover::before{width:60%}
.cs-stat-tile-num{font-family:var(--cs-font-display);font-size:1.95rem;font-weight:700;color:#fff;line-height:1.05;margin-bottom:.2rem}
.cs-stat-tile-num span{font-size:1.1rem;color:var(--cs-gold-light);font-weight:600;margin-left:1px}
.cs-stat-tile-label{font-size:.72rem;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.6px;font-weight:500}

.cs-quote-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-left:3px solid var(--cs-gold);border-radius:var(--cs-radius-md);padding:1.2rem 1.3rem;margin:0;position:relative;z-index:1}
.cs-quote-card .cs-stars{color:var(--cs-gold);font-size:.8rem}
.cs-quote-card blockquote{font-size:.92rem;line-height:1.7;color:rgba(255,255,255,.85);font-style:italic;margin:0 0 .9rem;padding:0;border:none}
.cs-quote-card blockquote strong{color:var(--cs-gold-light);font-weight:600;font-style:normal}
.cs-quote-card figcaption{display:flex;align-items:center;gap:.65rem;font-style:normal}
.cs-quote-card figcaption strong{display:block;font-size:.82rem;color:#fff;font-weight:600;line-height:1.3}
.cs-quote-card figcaption small{font-size:.7rem;color:rgba(255,255,255,.55)}

.cs-auth-right{background:var(--cs-bg);display:flex;align-items:flex-start;justify-content:flex-start;padding:2.5rem 3rem 2.5rem 2.5rem}
.cs-auth-box{background:#fff;border-radius:var(--cs-radius-xl);padding:2.4rem 2.6rem;width:100%;max-width:620px;box-shadow:var(--cs-shadow-md)}
.cs-auth-box h3{font-size:1.6rem!important}
.cs-auth-box > p{font-size:.92rem!important}
.cs-auth-box .form-label{font-size:.78rem;margin-bottom:.4rem}
.cs-auth-box .form-control{padding:.7rem .9rem;font-size:.95rem}
.cs-auth-box .cs-social-btn{padding:.75rem 1rem;font-size:.92rem}
.cs-auth-box .role-pill{padding:.55rem 1rem;font-size:.9rem}
.cs-auth-box .btn-navy{padding:.85rem;font-size:1rem;font-weight:600}

/* ===== Login role chooser ===== */
.cs-role-grid{display:grid;grid-template-columns:1fr 1fr;gap:.65rem}
.cs-role-card{display:flex;align-items:center;gap:.7rem;padding:.85rem .95rem;border:2px solid var(--cs-border);border-radius:var(--cs-radius-md);cursor:pointer;background:#fff;transition:all .15s;position:relative;margin:0}
.cs-role-card:hover{border-color:var(--cs-navy)}
.cs-role-card.is-selected{border-color:var(--cs-navy);background:rgba(11,31,58,.04);box-shadow:0 0 0 4px rgba(11,31,58,.05)}
.cs-role-card .ic{width:36px;height:36px;border-radius:10px;background:var(--cs-bg);display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0;transition:background .15s}
.cs-role-card.is-selected .ic{background:var(--cs-gold-pale)}
.cs-role-card .body{flex:1;min-width:0;line-height:1.2}
.cs-role-card .body strong{display:block;color:var(--cs-navy);font-size:.85rem;font-weight:600}
.cs-role-card .body small{color:var(--cs-text-muted);font-size:.72rem;display:block;margin-top:.15rem}
.cs-role-card .check{position:absolute;top:-7px;right:-7px;color:var(--cs-navy);background:#fff;border-radius:50%;font-size:1.1rem;opacity:0;transform:scale(.6);transition:opacity .15s,transform .15s}
.cs-role-card.is-selected .check{opacity:1;transform:scale(1)}

.cs-role-banner{display:flex;align-items:center;gap:.5rem;padding:.55rem .85rem;background:linear-gradient(135deg,var(--cs-gold-pale),rgba(255,255,255,.5));border:1px solid rgba(201,153,42,.3);border-radius:var(--cs-radius-sm);color:var(--cs-navy);font-size:.82rem}
.cs-role-banner i{color:var(--cs-gold);font-size:1rem}
.cs-role-banner strong{font-weight:600}

@media (max-width: 480px){
  .cs-role-grid{grid-template-columns:1fr}
}
.cs-auth-box h3{margin-top:0}
.cs-auth-box .form-label{margin-bottom:.3rem}
.cs-auth-box .form-group,.cs-auth-box .mb-3{margin-bottom:.85rem!important}
.cs-auth-box .mb-2{margin-bottom:.6rem!important}
.cs-auth-tabs{display:flex;background:var(--cs-bg);border:1px solid var(--cs-border);border-radius:var(--cs-radius-sm);padding:.25rem;margin-bottom:1.25rem}
.cs-auth-tab{flex:1;padding:.6rem;border:none;background:transparent;color:var(--cs-text-muted);font-size:.85rem;font-weight:500;cursor:pointer;border-radius:4px;transition:all .15s}
.cs-auth-tab.active{background:var(--cs-navy);color:#fff}
.cs-auth-divider{display:flex;align-items:center;gap:.75rem;margin:.85rem 0;font-size:.78rem;color:var(--cs-text-muted)}
.cs-auth-divider::before,.cs-auth-divider::after{content:'';flex:1;height:1px;background:var(--cs-border)}
.cs-social-btn{display:flex;width:100%;align-items:center;justify-content:center;gap:.6rem;padding:.65rem;border:1.5px solid var(--cs-border);background:#fff;border-radius:var(--cs-radius-sm);font-size:.85rem;font-weight:500;color:var(--cs-text);cursor:pointer;margin-bottom:.5rem;transition:border-color .15s}
.cs-social-btn:hover{border-color:var(--cs-navy);color:var(--cs-text)}

/* OTP boxes */
.cs-otp-row{display:flex;gap:.6rem;justify-content:center;margin-bottom:.8rem}
.cs-otp-box{width:46px;height:54px;border:2px solid var(--cs-border);border-radius:var(--cs-radius-sm);text-align:center;font-size:1.4rem;font-weight:700;color:var(--cs-navy);font-family:var(--cs-font-display);outline:none;background:#fff}
.cs-otp-box:focus{border-color:var(--cs-navy);box-shadow:0 0 0 3px rgba(11,31,58,.12)}

/* ===== Dashboard layout ===== */
.cs-dash{display:grid;grid-template-columns:240px 1fr;min-height:calc(100vh - var(--cs-nav-h))}
.cs-dash-sidebar{background:var(--cs-navy);padding:0;position:sticky;top:var(--cs-nav-h);height:calc(100vh - var(--cs-nav-h));overflow-y:auto;display:flex;flex-direction:column;border-top:1px solid rgba(255,255,255,.06)}
.cs-dash-profile-mini{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem;padding:1.25rem .9rem 1rem;border-bottom:1px solid rgba(255,255,255,.08)}
.cs-dash-profile-mini .info{width:100%;display:flex;flex-direction:column;align-items:center;gap:.4rem}
.cs-dash-profile-mini h4{font-family:var(--cs-font-body);color:#fff;font-size:.95rem;font-weight:600;margin:0;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.cs-dash-profile-mini .meta{display:flex;align-items:center;justify-content:center;gap:.35rem;flex-wrap:wrap}
.cs-dash-profile-mini .cs-avatar{flex-shrink:0}
.cs-dash-profile-mini .cs-avatar.md{width:52px;height:52px;font-size:.95rem}
/* Tighter badges inside the sidebar profile so they sit on one row */
.cs-dash-profile-mini .cs-role-badge{font-size:.58rem;padding:3px 8px;letter-spacing:.1em}
.cs-dash-profile-mini .cs-plan-badge{font-size:.65rem;padding:.25rem .6rem;letter-spacing:.2px}
.cs-dash-profile-mini .cs-role-badge i,
.cs-dash-profile-mini .cs-plan-badge i{font-size:.66rem}
.cs-dash-nav{padding:.6rem .7rem;flex:1}
.cs-dash-nav-section{font-size:.6rem;font-weight:700;color:rgba(255,255,255,.28);letter-spacing:1.4px;text-transform:uppercase;padding:.8rem .4rem .35rem}
.cs-dash-nav-item{display:flex;align-items:center;gap:.65rem;padding:.55rem .85rem;border-radius:var(--cs-radius-sm);color:rgba(255,255,255,.55);font-size:.83rem;font-weight:400;cursor:pointer;transition:all .15s;margin-bottom:2px;text-decoration:none}
.cs-dash-nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.cs-dash-nav-item.active{background:rgba(201,153,42,.16);color:var(--cs-gold-light);font-weight:600}
.cs-dash-nav-item .ic{width:18px;text-align:center;font-size:.95rem}
.cs-dash-nav-item .badge-num{margin-left:auto;background:var(--cs-gold);color:var(--cs-navy);font-size:.65rem;font-weight:700;padding:.05rem .45rem;border-radius:100px}
.cs-dash-main{background:var(--cs-bg);overflow-y:auto}
.cs-dash-topbar{background:#fff;border-bottom:1px solid var(--cs-border);padding:.9rem 2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}
.cs-greeting{font-family:var(--cs-font-display);font-size:1.4rem;font-weight:700;color:var(--cs-navy);margin:0}

/* ===== Dashboard hero header (rich gradient banner) ===== */
.cs-dash-hero{background:linear-gradient(135deg,var(--cs-navy) 0%,var(--cs-navy-mid) 60%,#1C3A62 100%);padding:1.8rem 2rem 2rem;color:#fff;position:relative;overflow:hidden;border-bottom:1px solid var(--cs-navy-light)}
.cs-dash-hero::before{content:'';position:absolute;top:-80px;right:-80px;width:320px;height:320px;background:radial-gradient(circle,rgba(201,153,42,.16) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.cs-dash-hero::after{content:'';position:absolute;bottom:-60px;left:30%;width:200px;height:200px;background:radial-gradient(circle,rgba(201,153,42,.07) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.cs-dash-hero-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;position:relative;z-index:2}
.cs-dash-hero-greeting{display:flex;align-items:center;gap:.45rem;font-size:.7rem;font-weight:600;color:var(--cs-gold-light);text-transform:uppercase;letter-spacing:1px;margin-bottom:.4rem}
.cs-dash-hero-greeting .dot{width:6px;height:6px;background:var(--cs-gold);border-radius:50%;animation:cs-pulse 2s ease-in-out infinite}
.cs-dash-hero h1{font-family:var(--cs-font-display);font-size:1.9rem;font-weight:700;color:#fff;line-height:1.15;letter-spacing:-.4px;margin:0 0 .35rem}
.cs-dash-hero h1 em{font-style:normal;color:var(--cs-gold-light)}
.cs-dash-hero .meta{font-size:.82rem;color:rgba(255,255,255,.6);font-weight:400}
.cs-dash-hero .meta i{margin-right:.3rem;opacity:.7}
.cs-dash-hero .right-side{display:flex;flex-direction:column;align-items:flex-end;gap:.6rem;min-width:260px}

/* Today's focus card inside hero */
.cs-focus-card{background:rgba(255,255,255,.07);border:1px solid rgba(201,153,42,.3);border-radius:var(--cs-radius-lg);padding:1rem 1.1rem;backdrop-filter:blur(4px);display:flex;gap:.85rem;align-items:center;width:100%}
.cs-focus-card .ic{width:42px;height:42px;border-radius:10px;background:rgba(201,153,42,.18);border:1px solid rgba(201,153,42,.4);color:var(--cs-gold-light);font-size:1.2rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cs-focus-card .body{flex:1;min-width:0}
.cs-focus-card .label{font-size:.62rem;font-weight:700;color:var(--cs-gold-light);text-transform:uppercase;letter-spacing:.8px;margin-bottom:.15rem}
.cs-focus-card .title{font-size:.95rem;color:#fff;font-weight:600;line-height:1.3;margin-bottom:.15rem}
.cs-focus-card .sub{font-size:.75rem;color:rgba(255,255,255,.55)}
.cs-focus-card .cta-btn{background:var(--cs-gold);color:var(--cs-navy);border:none;padding:.45rem .95rem;border-radius:var(--cs-radius-sm);font-size:.78rem;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:.3rem;transition:background .15s;flex-shrink:0}
.cs-focus-card .cta-btn:hover{background:var(--cs-gold-light);color:var(--cs-navy)}

/* Quick action chips */
.cs-quick-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.2rem;position:relative;z-index:2}
.cs-quick-chip{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);color:rgba(255,255,255,.85);padding:.5rem .95rem;border-radius:100px;font-size:.78rem;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex;align-items:center;gap:.4rem}
.cs-quick-chip:hover{background:rgba(255,255,255,.13);border-color:var(--cs-gold);color:#fff;transform:translateY(-1px)}
.cs-quick-chip i{font-size:.95rem;color:var(--cs-gold-light)}
.cs-quick-chip.is-primary{background:var(--cs-gold);border-color:var(--cs-gold);color:var(--cs-navy);font-weight:700}
.cs-quick-chip.is-primary i{color:var(--cs-navy)}
.cs-quick-chip.is-primary:hover{background:var(--cs-gold-light);border-color:var(--cs-gold-light);color:var(--cs-navy)}

/* Inline mini-stats inside hero */
.cs-hero-mini-stats{display:flex;gap:1.4rem;margin-top:1.1rem;flex-wrap:wrap}
.cs-hero-mini-stats > div{padding-right:1.4rem;border-right:1px solid rgba(255,255,255,.13)}
.cs-hero-mini-stats > div:last-child{border-right:none;padding-right:0}
.cs-hero-mini-stats .num{font-family:var(--cs-font-display);font-size:1.35rem;font-weight:700;color:#fff;line-height:1;margin-bottom:.18rem}
.cs-hero-mini-stats .num em{font-style:normal;color:var(--cs-gold-light);font-size:.85rem;margin-left:1px}
.cs-hero-mini-stats .lbl{font-size:.65rem;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.6px}
.cs-dash-ticker{background:var(--cs-navy);padding:.5rem 2rem;color:rgba(255,255,255,.65);font-size:.78rem;display:flex;align-items:center;gap:1rem;overflow:hidden}
.cs-dash-ticker .live{font-size:.6rem;font-weight:700;color:var(--cs-gold-light);text-transform:uppercase;letter-spacing:1px;display:flex;align-items:center;gap:.35rem}
.cs-dash-ticker .live::before{content:'';width:6px;height:6px;border-radius:50%;background:#22c55e;display:inline-block}
.cs-dash-content{padding:1.6rem 2rem}

/* metric cards */
.cs-metric{background:#fff;border:1px solid var(--cs-border);border-radius:var(--cs-radius-lg);padding:1.1rem 1.2rem;position:relative;overflow:hidden;height:100%}
.cs-metric::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.cs-metric.m-blue::before{background:#3B82F6}
.cs-metric.m-gold::before{background:var(--cs-gold)}
.cs-metric.m-green::before{background:var(--cs-success)}
.cs-metric.m-violet::before{background:#8B5CF6}
.cs-metric.m-slate::before{background:#64748B}
.cs-metric-label{font-size:.65rem;font-weight:600;color:var(--cs-text-muted);text-transform:uppercase;letter-spacing:.6px}
.cs-metric-num{font-family:var(--cs-font-display);font-size:1.8rem;font-weight:700;color:var(--cs-navy);line-height:1;margin:.3rem 0}
.cs-metric-chg{font-size:.72rem;font-weight:500;color:var(--cs-success)}
.cs-metric-chg.muted{color:var(--cs-text-muted)}

/* ===== Blog magazine layout ===== */
.cs-blog-header{background:linear-gradient(180deg,var(--cs-navy) 0%,var(--cs-navy-mid) 100%);padding:3.5rem 0 2.2rem;color:#fff;position:relative;overflow:hidden}
.cs-blog-header::before{content:'';position:absolute;top:-100px;right:-100px;width:380px;height:380px;background:radial-gradient(circle,rgba(201,153,42,.13) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.cs-blog-header h1{font-family:var(--cs-font-display);font-size:2.6rem;font-weight:700;color:#fff;line-height:1.1;letter-spacing:-.5px;margin:.7rem 0 .8rem}
.cs-blog-header h1 em{font-style:normal;color:var(--cs-gold-light)}
.cs-blog-header p{font-size:1.05rem;color:rgba(255,255,255,.62);font-weight:300;max-width:560px;margin:0}
.cs-blog-search{position:relative;max-width:540px;margin-top:1.6rem}
.cs-blog-search input{width:100%;padding:.9rem 1.2rem .9rem 3rem;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.07);color:#fff;border-radius:100px;font-size:.95rem}
.cs-blog-search input::placeholder{color:rgba(255,255,255,.5)}
.cs-blog-search input:focus{outline:none;border-color:var(--cs-gold);background:rgba(255,255,255,.1)}
.cs-blog-search i{position:absolute;left:1.1rem;top:50%;transform:translateY(-50%);color:rgba(255,255,255,.5);font-size:1.05rem}

.cs-blog-cats{background:#fff;border-bottom:1px solid var(--cs-border);padding:1.1rem 0;position:sticky;top:var(--cs-nav-h);z-index:40}
.cs-blog-cats .inner{display:flex;flex-wrap:wrap;gap:.5rem}
.cs-blog-cat-pill{background:var(--cs-bg);border:1px solid var(--cs-border);color:var(--cs-text-mid);padding:.45rem 1rem;border-radius:100px;font-size:.82rem;font-weight:500;text-decoration:none;transition:all .15s;white-space:nowrap}
.cs-blog-cat-pill:hover{border-color:var(--cs-navy);color:var(--cs-navy)}
.cs-blog-cat-pill.active{background:var(--cs-navy);border-color:var(--cs-navy);color:#fff}
.cs-blog-cat-pill.active:hover{color:#fff}

/* Magazine cover grid */
.cs-mag-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:1.4rem;margin:2.5rem 0 3rem;align-items:stretch}
.cs-mag-feature{background:#fff;border:1px solid var(--cs-border);border-radius:var(--cs-radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s;cursor:pointer;height:100%}
.cs-mag-feature:hover{transform:translateY(-3px);box-shadow:var(--cs-shadow-md)}
.cs-mag-feature .cover{position:relative;aspect-ratio:16/9;background:linear-gradient(135deg,var(--cs-navy),var(--cs-navy-mid) 65%,#1C3A62);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--cs-font-display);font-size:3.5rem;font-weight:700;letter-spacing:-1px;overflow:hidden}
.cs-mag-feature .cover::before{content:'';position:absolute;top:-50%;right:-30%;width:60%;height:200%;background:radial-gradient(circle,rgba(201,153,42,.18) 0%,transparent 60%);pointer-events:none}
.cs-mag-feature .cover .badge-cat{position:absolute;top:1.2rem;left:1.2rem;background:rgba(201,153,42,.95);color:var(--cs-navy);font-size:.7rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:.3rem .8rem;border-radius:100px;backdrop-filter:blur(4px);font-family:var(--cs-font-body)}
.cs-mag-feature .body{padding:1.6rem 1.6rem 1.4rem;display:flex;flex-direction:column;flex-grow:1}
.cs-mag-feature h2{font-family:var(--cs-font-display);font-size:1.55rem;color:var(--cs-navy);line-height:1.25;margin:0 0 .7rem;letter-spacing:-.3px}
.cs-mag-feature .excerpt{color:var(--cs-text-mid);font-size:.95rem;line-height:1.65;margin-bottom:1.2rem}
.cs-mag-feature .meta-row{display:flex;align-items:center;gap:.6rem;margin-top:auto;padding-top:1rem;border-top:1px solid var(--cs-border)}
.cs-mag-feature .meta-row .name{font-size:.85rem;font-weight:600;color:var(--cs-navy)}
.cs-mag-feature .meta-row .time{font-size:.72rem;color:var(--cs-text-muted)}
.cs-mag-feature .read-link{margin-left:auto;color:var(--cs-gold);font-size:.82rem;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:.3rem;transition:gap .15s}
.cs-mag-feature:hover .read-link{gap:.55rem}

/* Secondary stack (right column) */
.cs-mag-side{display:grid;grid-template-rows:1fr 1fr;gap:1.4rem;height:100%;min-height:0}
.cs-mag-sec{background:#fff;border:1px solid var(--cs-border);border-radius:var(--cs-radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s;cursor:pointer;min-height:0}
.cs-mag-sec:hover{transform:translateY(-2px);box-shadow:var(--cs-shadow-sm)}
.cs-mag-sec .cover{position:relative;flex:1 1 auto;min-height:180px;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--cs-font-display);font-size:2.4rem;font-weight:700}
.cs-mag-sec .cover .badge-cat{position:absolute;top:.8rem;left:.8rem;background:rgba(255,255,255,.95);color:var(--cs-navy);font-size:.62rem;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:.18rem .55rem;border-radius:100px;font-family:var(--cs-font-body)}
.cs-mag-sec .body{padding:1.1rem 1.2rem 1.2rem;display:flex;flex-direction:column;flex:0 0 auto}
.cs-mag-sec h3{font-family:var(--cs-font-display);font-size:1.05rem;color:var(--cs-navy);line-height:1.3;margin:0 0 .55rem}
.cs-mag-sec .meta-row{display:flex;align-items:center;gap:.5rem;margin-top:auto;font-size:.7rem;color:var(--cs-text-muted)}
.cs-mag-sec .meta-row .name{font-weight:600;color:var(--cs-navy);font-size:.75rem}

/* Category color theming for covers */
.cs-cover-finance{background:linear-gradient(135deg,#0B1F3A,#1C3A62)!important}
.cs-cover-legal{background:linear-gradient(135deg,#162D50,#3D2B5C)!important}
.cs-cover-technology{background:linear-gradient(135deg,#0B3A4B,#1C6276)!important}
.cs-cover-marketing{background:linear-gradient(135deg,#5C2B2B,#C9992A)!important}
.cs-cover-hr{background:linear-gradient(135deg,#1A5544,#2D8364)!important}
.cs-cover-operations{background:linear-gradient(135deg,#3D2B5C,#6B3FA0)!important}
.cs-cover-healthcare{background:linear-gradient(135deg,#1A5544,#0B1F3A)!important}
.cs-cover-strategy{background:linear-gradient(135deg,#0B1F3A,#C9992A)!important}
.cs-cover-consulting{background:linear-gradient(135deg,#0B1F3A,#C9992A)!important}
.cs-cover-business{background:linear-gradient(135deg,#162D50,#0B3A4B)!important}
.cs-cover-esg{background:linear-gradient(135deg,#1A5544,#3D8364)!important}
.cs-cover-insights{background:linear-gradient(135deg,#3D2B5C,#1C3A62)!important}
.cs-cover-product{background:linear-gradient(135deg,#0B3A4B,#5C2B2B)!important}
.cs-cover-people{background:linear-gradient(135deg,#1A5544,#162D50)!important}

/* "Latest" section header */
.cs-section-divider{display:flex;align-items:end;justify-content:space-between;border-bottom:1px solid var(--cs-border);padding-bottom:.8rem;margin-bottom:1.4rem}
.cs-section-divider h2{font-family:var(--cs-font-display);font-size:1.5rem;color:var(--cs-navy);margin:0;letter-spacing:-.3px}
.cs-section-divider h2 small{font-family:var(--cs-font-body);font-size:.75rem;color:var(--cs-text-muted);font-weight:400;margin-left:.6rem;text-transform:uppercase;letter-spacing:.8px}

/* Article grid card (smaller, denser) */
.cs-mag-card{background:#fff;border:1px solid var(--cs-border);border-radius:var(--cs-radius-lg);overflow:hidden;display:flex;flex-direction:column;height:100%;transition:transform .2s,box-shadow .2s,border-color .2s;cursor:pointer}
.cs-mag-card:hover{transform:translateY(-2px);box-shadow:var(--cs-shadow-md);border-color:rgba(201,153,42,.3)}
/* Default cover gradient — guarantees a visible background even when the post's
   category doesn't match any of the `cs-cover-*` classes below (e.g. new
   categories like "Consulting Essentials" don't have a dedicated palette). */
.cs-mag-card .cover,
.cs-mag-feature .cover,
.cs-mag-sec .cover{background:linear-gradient(135deg,var(--cs-navy) 0%,var(--cs-navy-mid) 60%,var(--cs-gold) 130%)}
.cs-mag-card .cover{position:relative;aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--cs-font-display);font-size:2.2rem;font-weight:700;overflow:hidden}
.cs-mag-card .cover .badge-cat{position:absolute;top:.9rem;left:.9rem;background:rgba(255,255,255,.95);color:var(--cs-navy);font-size:.62rem;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:.2rem .6rem;border-radius:100px;font-family:var(--cs-font-body)}
.cs-mag-card .body{padding:1.1rem 1.3rem 1.2rem;display:flex;flex-direction:column;flex-grow:1}
.cs-mag-card h3{font-family:var(--cs-font-display);font-size:1.08rem;color:var(--cs-navy);line-height:1.32;margin:0 0 .8rem}
.cs-mag-card .meta-row{display:flex;align-items:center;gap:.55rem;margin-top:auto;font-size:.7rem;color:var(--cs-text-muted)}
.cs-mag-card .meta-row .name{font-weight:600;color:var(--cs-navy);font-size:.78rem}

/* Newsletter strip */
.cs-newsletter{background:linear-gradient(135deg,var(--cs-navy),var(--cs-navy-mid));border-radius:var(--cs-radius-xl);padding:2.4rem 2.4rem;color:#fff;display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center;margin:3rem 0 2rem;position:relative;overflow:hidden}
.cs-newsletter::before{content:'';position:absolute;right:-80px;top:-80px;width:280px;height:280px;background:radial-gradient(circle,rgba(201,153,42,.14) 0%,transparent 70%);border-radius:50%}
.cs-newsletter h3{font-family:var(--cs-font-display);font-size:1.7rem;color:#fff;margin:0 0 .5rem;letter-spacing:-.3px;position:relative;z-index:1}
.cs-newsletter h3 em{font-style:normal;color:var(--cs-gold-light)}
.cs-newsletter p{color:rgba(255,255,255,.65);font-size:.95rem;margin:0;position:relative;z-index:1}
.cs-newsletter form{display:flex;gap:.5rem;position:relative;z-index:1}
.cs-newsletter input{flex:1;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:var(--cs-radius-sm);padding:.75rem 1rem;color:#fff;font-size:.92rem}
.cs-newsletter input::placeholder{color:rgba(255,255,255,.5)}
.cs-newsletter input:focus{outline:none;border-color:var(--cs-gold)}

@media (max-width: 991.98px){
  .cs-mag-grid{grid-template-columns:1fr}
  .cs-blog-header h1{font-size:2rem}
  .cs-newsletter{grid-template-columns:1fr;padding:1.8rem}
}

/* ===== Pricing billing toggle ===== */
.cs-billing-toggle{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:100px}
.cs-billing-btn{background:transparent;border:none;color:rgba(255,255,255,.65);font-family:var(--cs-font-body);font-size:.85rem;font-weight:600;padding:.55rem 1.4rem;border-radius:100px;cursor:pointer;transition:background .18s,color .18s;display:inline-flex;align-items:center;gap:.5rem;line-height:1}
.cs-billing-btn:hover{color:#fff}
.cs-billing-btn.active{background:var(--cs-gold);color:var(--cs-navy)}
.cs-billing-btn.active:hover{color:var(--cs-navy)}
.cs-billing-save{background:rgba(201,153,42,.22);color:var(--cs-gold-light);font-size:.65rem;font-weight:700;padding:.16rem .55rem;border-radius:100px;letter-spacing:.3px;text-transform:uppercase}
.cs-billing-btn.active .cs-billing-save{background:rgba(11,31,58,.15);color:var(--cs-navy)}

/* ===== Pricing cards ===== */
.cs-plan{background:#fff;border:1px solid var(--cs-border);border-radius:var(--cs-radius-lg);padding:1.9rem;position:relative;height:100%;display:flex;flex-direction:column}
.cs-plan.is-featured{border-color:var(--cs-gold);background:linear-gradient(180deg,var(--cs-gold-pale) 0%,#fff 30%);box-shadow:var(--cs-shadow-md);transform:translateY(-6px)}
.cs-plan-tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--cs-gold);color:var(--cs-navy);font-size:.7rem;font-weight:700;padding:.3rem .9rem;border-radius:100px;text-transform:uppercase;letter-spacing:.5px}
.cs-plan h3{font-family:var(--cs-font-display);font-size:1.3rem;color:var(--cs-navy);margin-bottom:.4rem}
.cs-plan-price{margin:1rem 0 1.2rem;display:flex;align-items:baseline;gap:.3rem}
.cs-plan-price .amount{font-family:var(--cs-font-display);font-size:2.2rem;font-weight:700;color:var(--cs-navy);line-height:1}
.cs-plan-price .period{font-size:.85rem;color:var(--cs-text-muted)}
.cs-plan-features{list-style:none;padding:0;margin:0 0 1.5rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.cs-plan-features li{font-size:.85rem;color:var(--cs-text-mid);display:flex;gap:.55rem;align-items:flex-start}
.cs-plan-features li i{color:var(--cs-success);flex-shrink:0;margin-top:.1rem}

/* ===== Search / filter sidebar ===== */
.cs-filter-panel{background:#fff;border:1px solid var(--cs-border);border-radius:var(--cs-radius-lg);padding:1.3rem;position:sticky;top:calc(var(--cs-nav-h) + 1rem)}
.cs-filter-section{padding-bottom:1.1rem;margin-bottom:1.1rem;border-bottom:1px solid var(--cs-border)}
.cs-filter-section:last-child{border-bottom:0;margin-bottom:0;padding-bottom:0}
.cs-filter-title{font-size:.78rem;font-weight:600;color:var(--cs-navy);text-transform:uppercase;letter-spacing:.4px;margin-bottom:.7rem}
.cs-filter-option{display:flex;align-items:center;gap:.45rem;margin-bottom:.45rem;font-size:.82rem;color:var(--cs-text-mid)}
.cs-filter-option .count{margin-left:auto;font-size:.72rem;color:var(--cs-text-muted)}

/* result card list view */
.cs-result-card{background:#fff;border:1px solid var(--cs-border);border-radius:var(--cs-radius-lg);padding:1.4rem;display:flex;gap:1.2rem;transition:all .15s;margin-bottom:1rem;align-items:flex-start;width:100%}
.cs-rc-avatar{flex:0 0 64px;width:64px;text-decoration:none}
.cs-rc-body{flex:1 1 0;min-width:0}
.cs-rc-actions{flex:0 0 180px;width:180px;max-width:180px;display:flex;flex-direction:column;gap:.25rem}
.cs-rc-cta{display:flex;flex-direction:column;gap:.5rem;width:100%}
.cs-rc-cta .btn{width:100%}
.cs-result-card:hover{box-shadow:var(--cs-shadow-md);border-color:transparent}
.cs-avail-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#22c55e;margin-right:.35rem;vertical-align:middle}

/* ===== Profile page ===== */
.cs-profile-hero{background:#fff;border:1px solid var(--cs-border);border-radius:var(--cs-radius-lg);padding:1.8rem;margin-bottom:1.2rem}
.cs-profile-hero h1{font-size:1.8rem;font-weight:700;color:var(--cs-navy);margin-bottom:.3rem}
.cs-profile-role{font-size:.95rem;color:var(--cs-text-muted)}
.cs-profile-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.7rem}
.cs-profile-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.8rem;margin-top:1.3rem;padding-top:1.3rem;border-top:1px solid var(--cs-border)}
.cs-profile-meta > div{font-size:.82rem;color:var(--cs-text-mid);display:flex;align-items:center;gap:.5rem}
.cs-profile-section{background:#fff;border:1px solid var(--cs-border);border-radius:var(--cs-radius-lg);padding:1.6rem;margin-bottom:1.2rem}
.cs-profile-section h3{font-family:var(--cs-font-display);font-size:1.2rem;color:var(--cs-navy);margin-bottom:1rem}
.cs-profile-bio{font-size:.92rem;color:var(--cs-text-mid);line-height:1.75}
.cs-expertise-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.9rem}
.cs-expertise-item{padding:1rem;background:var(--cs-bg);border-radius:var(--cs-radius-md)}
.cs-expertise-item h5{font-size:.88rem;font-weight:600;color:var(--cs-navy);margin-bottom:.2rem;font-family:var(--cs-font-body)}
.cs-expertise-item p{font-size:.78rem;color:var(--cs-text-muted);margin:0}
.cs-exp-item{padding:1rem 0 1rem 1.1rem;border-left:2px solid var(--cs-gold);position:relative;margin-bottom:.7rem}
.cs-exp-item h5{font-size:.95rem;font-weight:600;color:var(--cs-navy);margin-bottom:.15rem;font-family:var(--cs-font-body)}
.cs-exp-co{font-size:.82rem;color:var(--cs-gold);font-weight:500}
.cs-exp-dur{font-size:.75rem;color:var(--cs-text-muted);margin-bottom:.4rem}
.cs-exp-item p{font-size:.85rem;color:var(--cs-text-mid);margin:0}
.cs-booking-card{background:#fff;border:1px solid var(--cs-border);border-radius:var(--cs-radius-lg);padding:1.5rem;margin-bottom:1rem}
.cs-booking-card .price-big{font-family:var(--cs-font-display);font-size:1.85rem;font-weight:700;color:var(--cs-navy);line-height:1.1;letter-spacing:-.02em;word-break:keep-all}
.cs-booking-card .price-note{font-size:.78rem;color:var(--cs-text-muted);margin-bottom:.9rem}
.cs-avail-banner{background:var(--cs-success-bg);color:var(--cs-success);font-size:.78rem;font-weight:500;padding:.55rem .8rem;border-radius:var(--cs-radius-sm);margin-bottom:1rem;display:flex;align-items:center;gap:.4rem}
.cs-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;padding-top:1.1rem;border-top:1px solid var(--cs-border);margin-top:1.1rem}
.cs-stats-row .snum{font-family:var(--cs-font-display);font-size:1.05rem;font-weight:700;color:var(--cs-navy);text-align:center}
.cs-stats-row .slabel{font-size:.68rem;color:var(--cs-text-muted);text-align:center;text-transform:uppercase;letter-spacing:.4px}

/* ===== Status pills ===== */
.cs-pill{font-size:.7rem;font-weight:600;padding:.18rem .55rem;border-radius:100px}
.cs-pill.success{background:var(--cs-success-bg);color:var(--cs-success)}
.cs-pill.warning{background:var(--cs-warning-bg);color:var(--cs-warning)}
.cs-pill.danger{background:var(--cs-danger-bg);color:var(--cs-danger)}
.cs-pill.info{background:#DBEAFE;color:#1E40AF}
.cs-pill.muted{background:var(--cs-bg);color:var(--cs-text-muted)}

/* progress bar */
.cs-progress{height:6px;background:var(--cs-border);border-radius:3px;overflow:hidden}
.cs-progress .fill{height:100%;background:linear-gradient(90deg,var(--cs-navy),var(--cs-gold));border-radius:3px}

/* toast */
.cs-toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--cs-navy);color:#fff;padding:.75rem 1.2rem;border-radius:var(--cs-radius-md);font-size:.85rem;font-weight:500;box-shadow:var(--cs-shadow-lg);display:none;align-items:center;gap:.5rem;z-index:9999}
.cs-toast.show{display:flex;animation:cs-toast-in .25s ease}
@keyframes cs-toast-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ===== Animations ===== */
@keyframes cs-fade-up{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.cs-fade-up{animation:cs-fade-up .35s ease}
@keyframes cs-pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:.7}}

/* ===== Responsive ===== */
@media (max-width: 991.98px){
  .cs-dash-hero{padding:1.4rem 1.3rem 1.5rem}
  .cs-dash-hero h1{font-size:1.55rem}
  .cs-dash-hero .right-side{min-width:100%;width:100%}
  .cs-hero-mini-stats > div{padding-right:1rem}
  .cs-hero-mini-stats .num{font-size:1.15rem}
  .cs-focus-card{padding:.85rem .95rem}
  .cs-focus-card .ic{width:36px;height:36px;font-size:1rem}
  .cs-focus-card .title{font-size:.88rem}
  .cs-hero h1{font-size:2.2rem}
  .cs-section{padding:2rem 0}
  .cs-section-title{font-size:1.6rem}
  .cs-auth{grid-template-columns:1fr}
  .cs-auth-left{padding:2.5rem;display:none}
  .cs-dash{grid-template-columns:1fr}
  .cs-dash-sidebar{position:fixed;top:var(--cs-nav-h);left:-260px;width:240px;transition:left .25s;z-index:100}
  .cs-dash-sidebar.open{left:0}
  .cs-result-card{flex-direction:column}
  .cs-rc-avatar,
  .cs-rc-actions{width:100%;max-width:100%;flex:0 0 auto}
  .cs-profile-meta{grid-template-columns:1fr}
  .cs-stats-row{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 575.98px){
  .cs-hero{padding:2.25rem 0}
  .cs-hero h1{font-size:1.75rem}
  .cs-search-card{padding:1.3rem}
  .cs-dash-content{padding:1rem}
  .cs-otp-box{width:36px;height:46px;font-size:1.1rem}
}

/* ═══════════════════════════════════════
   NUMERIC DISPLAY OVERRIDE
   Inter renders ₹ + tabular numerals cleanly. Override Playfair Display
   anywhere we show money / counts / stats so figures look modern + crisp.
═══════════════════════════════════════ */
.cs-num,
.cs-metric-num,
.cs-stat-num,
.cs-stat-tile-num,
.cs-stat-tile-num span,
.cs-rate,
.cs-rate span,
.price-big,
.cs-booking-card .price-big,
.cs-plan-price .amount,
.cs-plan-price .period,
.cs-hero-mini-stats .num,
.cs-hero-mini-stats .num em,
.cs-stat-row > div strong,
.cs-stats-row .snum,
.cs-step-num,
.badge-num,
.cs-metric-chg,
.cs-quote-card blockquote strong{
  font-family: var(--cs-font-num) !important;
  font-feature-settings: 'tnum' 1, 'lnum' 1, 'ss01' 1;
  font-variant-numeric: tabular-nums lining-nums;
  letter-spacing: -.015em;
}

/* Stat tile super-numbers — premium fintech look */
.cs-stat-tile-num,
.cs-metric-num,
.cs-stats-row .snum{
  font-weight: 700;
}
.cs-stat-tile-num span{
  font-weight: 600;
}

/* Per-page big numbers */
.cs-mag-feature h2,
.cs-blog-header h1,
.cs-dash-hero h1{
  /* keep these in Playfair — they're headlines, not numbers */
}

/* ──────── Mobile navbar (Bootstrap collapse) ──────── */
/* `.cs-nav` is sticky with a fixed 72px height; on mobile the collapse panel
   needs its own background + width or it visually leaks onto the hero. */
@media (max-width: 991.98px){
  .cs-nav{ height:auto; min-height:var(--cs-nav-h); }
  .cs-nav .navbar-toggler{ padding:.25rem .5rem; }
  .cs-nav .navbar-toggler:focus{ box-shadow:none; }
  .cs-nav .navbar-collapse{
    background:var(--cs-navy);
    margin:0 -1rem;            /* extend to container edges */
    padding:.5rem 1rem 1rem;
    border-top:1px solid rgba(255,255,255,.08);
    box-shadow:0 12px 24px -8px rgba(0,0,0,.4);
  }
  .cs-nav .navbar-nav{ flex-direction:column; gap:.15rem; margin:.25rem 0 .75rem; }
  .cs-nav .navbar-nav .nav-link{ padding:.65rem .5rem; font-size:1rem; border-radius:8px; }
  .cs-nav .navbar-nav .nav-link:hover,
  .cs-nav .navbar-nav .nav-link.active{ background:rgba(255,255,255,.06); color:#fff; }
  .cs-nav-actions{
    flex-direction:column;
    align-items:stretch;
    gap:.5rem;
    padding-top:.5rem;
    border-top:1px solid rgba(255,255,255,.08);
    margin-top:.25rem;
  }
  /* Full-width only for actual call-to-action buttons (e.g. "My Dashboard").
     Icon-only triggers (bell, avatar) must stay compact or absolute-positioned
     badges drift to the viewport edge. */
  .cs-nav-actions > .btn{ width:100%; padding:.6rem 1rem; }
  /* Icon-only controls — bell + avatar — sit centered on their own row. */
  .cs-nav-actions .dropdown{ width:auto; align-self:center; }
  .cs-nav-actions .cs-avatar-nav{ width:40px !important; height:40px !important; display:flex; }
  /* Search bar stays full-width since the input expects to fill the row. */
  .cs-nav-search{ display:block !important; width:100%; }
  .cs-nav-search input{ width:100% !important; }
  /* Stack the dashboard nav-actions vertically but center the icon row. */
  .cs-nav-actions{ align-items:stretch; }
  .cs-nav-actions .dropdown:has(> .cs-avatar-nav),
  .cs-nav-actions .dropdown:has(> [aria-label="Notifications"]){ align-self:center; }

  /* Dropdown menus (notifications, user) must stay inside the viewport.
     Bootstrap's `.dropdown-menu-end` aligns to the trigger's right edge — on a
     centered-icon row that pushes the panel off-screen left. Clamp width and
     re-anchor centered relative to the viewport instead. */
  .cs-nav-actions .dropdown-menu{
    min-width:0 !important;
    max-width:calc(100vw - 24px) !important;
    width:calc(100vw - 24px);
    left:50% !important;
    right:auto !important;
    transform:translateX(-50%) !important;
    margin-top:.5rem;
  }
}

/* ──────── Mobile auth pages (login/register/forgot/reset/2fa) ──────── */
/* On desktop `.cs-auth` is a 2-col grid (testimonial left, form right). On
   mobile the 2-col squeeze makes text unreadable — stack into one column,
   put the form first so the user sees it without scrolling, and shrink the
   social-proof block so it doesn't dominate the viewport. */
@media (max-width: 991.98px){
  .cs-auth{ display:block; min-height:auto; }
  .cs-auth-left,
  .cs-auth-right{ padding:1.5rem 1.1rem; }
  .cs-auth-right{ order:1; }       /* form first */
  .cs-auth-left{ order:2; }        /* testimonial below */
  .cs-auth-left h2{ font-size:1.45rem !important; line-height:1.25; margin:0 0 .9rem; max-width:none; }
  .cs-auth-left > p{ font-size:.85rem; margin-bottom:1rem; }
  .cs-auth-box{ padding:1.5rem 1.25rem; max-width:none; box-shadow:none; border:1px solid var(--cs-border); }
  .cs-auth-box h3{ font-size:1.2rem !important; }
  .cs-auth-box .form-control{ padding:.7rem .8rem; font-size:16px; /* 16px avoids iOS auto-zoom on focus */ }
  .cs-auth-tabs{ margin-bottom:1rem; }
  .cs-auth-tab{ font-size:.82rem; padding:.55rem; }
  .cs-social-btn{ padding:.7rem .9rem; font-size:.88rem; }
  .cs-auth-divider{ margin:.85rem 0; font-size:.72rem; }
  .cs-stat-grid{ grid-template-columns:repeat(2,1fr); gap:.6rem; margin-top:1rem; }
  .cs-stat-tile{ padding:.85rem .75rem; }
  .cs-stat-tile-num{ font-size:1.4rem !important; }
  .cs-stat-tile-label{ font-size:.68rem; }
  .cs-quote-card{ padding:1rem; margin-top:1rem; font-size:.85rem; }
  .cs-quote-card blockquote{ font-size:.85rem; }
  /* DOM-order swap via flexbox so "form first" actually wins */
  .cs-auth{ display:flex; flex-direction:column; }
}
@media (max-width: 480px){
  .cs-auth-left{ padding:1.25rem 1rem 1.5rem; }
  .cs-auth-right{ padding:1.25rem 1rem; }
  .cs-stat-grid{ grid-template-columns:1fr 1fr; }
  .cs-auth-left h2{ font-size:1.3rem !important; }
}

/* ──────── Mobile general (hero scaling, container padding, tap targets) ──────── */
/* Inline hero headings hard-code 2.4rem which wraps badly on phones.
   Cap large display sizes proportionally instead of hunting them down one by one. */
@media (max-width: 767.98px){
  /* Hero/section h1 + h2 — only when they're large in inline style */
  .cs-section-title{ font-size:1.5rem !important; line-height:1.25; }
  h1[style*="font-size:2.4rem"],
  h2[style*="font-size:2.4rem"]{ font-size:1.55rem !important; line-height:1.25 !important; }
  h1[style*="font-size:2.6rem"],
  h2[style*="font-size:2.6rem"]{ font-size:1.6rem !important; line-height:1.25 !important; }
  h1[style*="font-size:2.8rem"],
  h2[style*="font-size:2.8rem"]{ font-size:1.7rem !important; line-height:1.2 !important; }
  h1[style*="font-size:3"],
  h2[style*="font-size:3"]{ font-size:1.8rem !important; line-height:1.2 !important; }

  /* Card padding shrink so content uses more of the viewport */
  .cs-card{ padding:1rem !important; }
  .container-xl,
  .container-lg,
  .container{ padding-left:1rem !important; padding-right:1rem !important; }

  /* Bootstrap button minimum tap target (44x44 per WCAG/Apple) */
  .btn{ min-height:40px; }
  .btn-sm{ min-height:36px; }

  /* Form controls — keep 16px to prevent iOS auto-zoom */
  .form-control,
  .form-select{ font-size:16px !important; }

  /* Tables: force horizontal scroll on small screens even when not wrapped */
  table{ max-width:100%; }
}

/* ──────── Hero carousel (client view ↔ consultant view) ──────── */
.cs-hero-carousel{ position:relative; }
.cs-hero-slides{ position:relative; display:grid; grid-template-areas:"stack"; }
.cs-hero-slide{
  grid-area:stack;
  opacity:0;
  visibility:hidden;
  transition:opacity .6s ease;
  pointer-events:none;
}
.cs-hero-slide.is-active{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  z-index:2;
}
.cs-hero-dots{
  position:absolute;
  bottom:1.1rem;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:.5rem;
  z-index:5;
}
.cs-hero-dot{
  width:32px; height:4px;
  border:0;
  border-radius:100px;
  background:rgba(255,255,255,.22);
  padding:0;
  cursor:pointer;
  transition:background .25s, width .25s;
}
.cs-hero-dot:hover{ background:rgba(255,255,255,.4); }
.cs-hero-dot.is-active{ background:var(--cs-gold); width:48px; }

/* ─── Select2 brand polish ──────────────────────────────────────────
 * Matches Bootstrap's .form-control sizing + ConsultSmart's brand focus state.
 */
.select2-container--bootstrap-5 .select2-selection{
  border-color:var(--cs-border);
  font-family:var(--cs-font-body);
  font-size:.92rem;
  min-height:calc(1.5em + .9rem + 2px);
}
.select2-container--bootstrap-5.select2-container--focus .select2-selection,
.select2-container--bootstrap-5.select2-container--open .select2-selection{
  border-color:var(--cs-navy-light);
  box-shadow:0 0 0 3px rgba(11,31,58,.08);
}
.select2-container--bootstrap-5 .select2-results__option--highlighted{
  background-color:var(--cs-navy)!important;
  color:#fff!important;
}
.select2-container--bootstrap-5 .select2-selection--single .select2-selection__placeholder{
  color:var(--cs-text-muted);
}
