/* ================================================================
   DAILA INVESTMENTS — Nivesh.com Inspired Theme
   Palette (extracted from logo + nivesh.com design):
     Deep Indigo : #2E1B8C  (logo 'Daila' lettering)
     Lime Green  : #7AC943  (logo accent squares)
     Mid Purple  : #5A2FC2  (hover/secondary states)
     Dark Navy   : #160E45  (topbar, footer)
     Light Bg    : #F4F3FF  (section backgrounds)
     Text Muted  : #6E6E9A
   Fonts: Nunito 700/800/900 + Inter 400/500
================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@600;700;800;900&family=Inter:wght@400;500;600&display=swap');

/* ── CSS Variables ── */
:root {
  --primary:  #2E1B8C;
  --hover:    #5A2FC2;
  --accent:   #7AC943;
  --dark:     #160E45;
  --light:    #F4F3FF;
  --muted:    #6E6E9A;
  --border:   #E0DDFA;
  --shadow:   0 4px 24px rgba(46,27,140,.10);
  --shadow-lg:0 12px 40px rgba(46,27,140,.18);
}

/* ── Reset & Base ── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: 'Inter', sans-serif; color: #3C3C5E; background: #fff; margin: 0; }
h1,h2,h3,h4,h5,h6 { font-family: 'Nunito', sans-serif; color: var(--dark); font-weight: 800; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; }

/* ── Spinner ── */
#spinner { opacity:0; visibility:hidden; transition: opacity .5s ease-out, visibility 0s linear .5s; z-index:99999; }
#spinner.show { transition: opacity .5s ease-out, visibility 0s linear 0s; visibility:visible; opacity:1; }

/* ── Back to Top ── */
.back-to-top {
  position:fixed; right:24px; bottom:24px; z-index:99;
  width:44px; height:44px; background:var(--primary); color:#fff;
  border-radius:12px; display:none; align-items:center; justify-content:center;
  font-size:1.1rem; box-shadow:0 4px 16px rgba(46,27,140,.35); transition:.3s;
}
.back-to-top:hover { background:var(--hover); }

/* ── Button Overrides ── */
.btn { font-family:'Nunito',sans-serif; font-weight:700; border-radius:10px; transition:.3s; }
.btn-primary { background:var(--primary); border-color:var(--primary); color:#fff; }
.btn-primary:hover { background:var(--hover); border-color:var(--hover); color:#fff; }
.btn-secondary { background:var(--accent); border-color:var(--accent); color:#fff; }
.btn-secondary:hover { background:#69b835; border-color:#69b835; color:#fff; }
.btn-outline-primary { border-color:var(--primary); color:var(--primary); background:transparent; }
.btn-outline-primary:hover { background:var(--primary); color:#fff; }
.btn-outline-light { border-color:rgba(255,255,255,.6); color:#fff; background:transparent; }
.btn-outline-light:hover { background:rgba(255,255,255,.12); color:#fff; }
.btn-square,.btn-sm-square,.btn-lg-square { padding:0; display:flex; align-items:center; justify-content:center; font-weight:normal; }
.btn-square    { width:38px; height:38px; }
.btn-sm-square { width:32px; height:32px; }
.btn-lg-square { width:48px; height:48px; }
.btn-link { color:rgba(255,255,255,.5); display:block; padding:4px 0; font-family:'Inter',sans-serif; font-size:.84rem; transition:.2s; text-align:left; }
.btn-link::before { content:'› '; color:var(--accent); }
.btn-link:hover { color:var(--accent); padding-left:6px; }

/* ── Topbar ── */
.topbar { background:var(--dark); padding:9px 0; }
.topbar .t-info { font-size:.77rem; color:rgba(255,255,255,.55); display:inline-flex; align-items:center; gap:7px; margin-right:20px; }
.topbar .t-info i { color:var(--accent); }
.topbar .t-soc a { color:rgba(255,255,255,.35); font-size:.85rem; margin-left:14px; transition:.2s; }
.topbar .t-soc a:hover { color:var(--accent); }

/* ── Navbar ── */
.navbar { background:#fff !important; padding:0 32px; box-shadow:0 2px 20px rgba(46,27,140,.08) !important; }
.navbar.sticky-top { top:-120px; transition:.5s; }
.navbar .navbar-brand { padding:10px 0; display:flex; align-items:center; }
.navbar .navbar-brand img { height:50px; width:auto; object-fit:contain; }
.navbar .nav-link {
  font-family:'Nunito',sans-serif; font-weight:700; font-size:.88rem;
  color:var(--muted) !important; padding:26px 0 !important; margin:0 14px;
  border-bottom:3px solid transparent; transition:.2s; position:relative;
}
.navbar .nav-link:hover,
.navbar .nav-link.active { color:var(--primary) !important; border-bottom-color:var(--accent); }
.navbar .nav-cta {
  background:var(--primary); color:#fff !important;
  padding:10px 22px !important; border-radius:10px;
  margin-left:16px; font-family:'Nunito',sans-serif;
  font-weight:700; font-size:.88rem; border:none;
  transition:.3s; border-bottom:none !important;
}
.navbar .nav-cta:hover { background:var(--hover); border-bottom:none !important; }
.navbar .navbar-toggler { border:1.5px solid var(--border); border-radius:8px; padding:6px 10px; }
.navbar .dropdown-menu { border:none; box-shadow:var(--shadow); border-radius:14px; padding:8px; }
.navbar .dropdown-item { font-family:'Nunito',sans-serif; font-size:.87rem; font-weight:700; color:var(--dark); border-radius:8px; padding:8px 14px; transition:.2s; }
.navbar .dropdown-item:hover { background:var(--light); color:var(--primary); }
.navbar .dropdown-toggle::after { border:none; content:"\f107"; font-family:"Font Awesome 5 Free"; font-weight:900; margin-left:6px; vertical-align:middle; font-size:.75rem; }
@media(max-width:991.98px) {
  .navbar { padding:0 16px; }
  .navbar .nav-link { padding:12px 0 12px 12px !important; border-bottom:none; border-left:3px solid transparent; margin:0; }
  .navbar .nav-link:hover,.navbar .nav-link.active { border-left-color:var(--accent); border-bottom:none; }
  .navbar .navbar-nav { padding:10px 0; }
}
@media(min-width:992px) {
  .navbar .nav-item .dropdown-menu { display:block; top:150%; opacity:0; visibility:hidden; transition:.3s; }
  .navbar .nav-item:hover .dropdown-menu { top:100%; opacity:1; visibility:visible; }
}

/* ── Hero Carousel ── */
#header-carousel .carousel-item { min-height:600px; }
#header-carousel .carousel-item img { width:100%; height:600px; object-fit:cover; filter:brightness(.28); display:block; }
.carousel-caption { top:0; left:0; right:0; bottom:0; display:flex; align-items:center; text-align:left; z-index:2; }
.carousel-caption .cap-in { max-width:660px; }
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(122,201,67,.15); border:1px solid rgba(122,201,67,.4);
  color:var(--accent); font-size:.73rem; font-weight:700;
  letter-spacing:1.6px; text-transform:uppercase;
  padding:6px 16px; border-radius:50px; margin-bottom:18px;
}
.hero-quote-card {
  background:rgba(255,255,255,.07); backdrop-filter:blur(16px);
  border-left:4px solid var(--accent); border-radius:0 14px 14px 0;
  padding:22px 28px 18px; margin-bottom:24px;
}
.hero-quote-card blockquote { font-family:'Nunito',sans-serif; font-size:clamp(1.2rem,2.4vw,1.65rem); font-weight:800; color:#fff; line-height:1.4; margin:0 0 10px; }
.hero-quote-card .q-attr { font-size:.8rem; color:rgba(255,255,255,.5); font-weight:500; }
.hero-sub { font-size:.95rem; color:rgba(255,255,255,.6); margin-bottom:28px; }
.carousel-indicators { bottom:20px; }
.carousel-indicators button { width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,.3); border:none; margin:0 4px; transition:.3s; }
.carousel-indicators button.active { background:var(--accent); width:24px; border-radius:4px; }
@media(max-width:767px) {
  #header-carousel .carousel-item { min-height:480px; }
  #header-carousel .carousel-item img { height:480px; }
  .hero-quote-card blockquote { font-size:1.1rem; }
}

/* ── Section Labels & Titles ── */
.sec-tag {
  display:inline-block; background:rgba(122,201,67,.12); color:var(--accent);
  font-size:.72rem; font-weight:700; letter-spacing:1.8px; text-transform:uppercase;
  padding:5px 14px; border-radius:50px; margin-bottom:10px;
}
.sec-title { font-family:'Nunito',sans-serif; font-size:clamp(1.6rem,3vw,2.15rem); font-weight:900; color:var(--dark); line-height:1.25; margin-bottom:14px; }
.sec-lead { font-size:.95rem; color:var(--muted); line-height:1.8; }
.accent-bar { width:44px; height:4px; background:linear-gradient(90deg,var(--accent),#a8e06a); border-radius:2px; margin-bottom:18px; }

/* ── About Image Block ── */
.about-img-block { position:relative; border-radius:20px; overflow:hidden; min-height:420px; }
.about-img-block img { width:100%; height:100%; object-fit:cover; border-radius:20px; display:block; }
.exp-badge {
  position:absolute; top:24px; left:24px; background:var(--primary);
  border-radius:16px; padding:18px 22px; text-align:center;
  box-shadow:0 8px 32px rgba(46,27,140,.4); color:#fff;
}
.exp-badge .eb-num { font-family:'Nunito',sans-serif; font-size:2.2rem; font-weight:900; line-height:1; }
.exp-badge .eb-lbl { font-size:.7rem; font-weight:700; color:rgba(255,255,255,.65); margin-top:4px; text-transform:uppercase; letter-spacing:.5px; }

/* ── Feature Chips ── */
.feat-chip { display:flex; align-items:center; gap:12px; background:#fff; border:1.5px solid var(--border); border-radius:12px; padding:14px 16px; margin-bottom:10px; transition:.2s; }
.feat-chip:hover { border-color:var(--accent); box-shadow:var(--shadow); }
.feat-chip .fc-ico { width:40px; height:40px; min-width:40px; background:var(--light); border-radius:10px; display:flex; align-items:center; justify-content:center; }
.feat-chip .fc-ico img { width:24px; height:24px; object-fit:contain; }
.feat-chip h6 { font-family:'Nunito',sans-serif; font-size:.9rem; font-weight:800; color:var(--dark); margin:0; }

/* ── Insurance Stats Band ── */
.stats-band {
  background:linear-gradient(135deg, var(--primary) 0%, #4A28B0 60%, #6C3CE1 100%);
  position:relative; overflow:hidden;
}
.stats-band::before { content:''; position:absolute; top:-80px; right:-80px; width:320px; height:320px; background:rgba(255,255,255,.04); border-radius:50%; pointer-events:none; }
.stats-band::after { content:''; position:absolute; bottom:-60px; left:-40px; width:240px; height:240px; background:rgba(122,201,67,.06); border-radius:50%; pointer-events:none; }
.stat-col { text-align:center; padding:52px 24px; position:relative; z-index:2; }
.stat-col + .stat-col::before { content:''; position:absolute; left:0; top:20%; height:60%; width:1px; background:rgba(255,255,255,.12); }
.stat-num { font-family:'Nunito',sans-serif; font-size:2.8rem; font-weight:900; color:#fff; line-height:1; }
.stat-num.green { color:var(--accent); }
.stat-lbl { font-size:.77rem; color:rgba(255,255,255,.5); font-weight:700; margin-top:8px; text-transform:uppercase; letter-spacing:.8px; }
@media(max-width:767px) {
  .stat-col + .stat-col::before { display:none; }
  .stat-col { border-bottom:1px solid rgba(255,255,255,.1); padding:36px 20px; }
  .stat-col:last-child { border-bottom:none; }
}

/* ── MF Band ── */
.mf-band { background:var(--dark); }
.mf-col { text-align:center; padding:44px 20px; border-right:1px solid rgba(255,255,255,.07); }
.mf-col:last-child { border-right:none; }
.mf-ico { font-size:2rem; margin-bottom:12px; display:block; }
.mf-num { font-family:'Nunito',sans-serif; font-size:2.4rem; font-weight:900; color:var(--accent); line-height:1; }
.mf-lbl { font-size:.75rem; color:rgba(255,255,255,.38); font-weight:700; margin-top:6px; text-transform:uppercase; letter-spacing:.6px; }
@media(max-width:767px) { .mf-col { border-right:none; border-bottom:1px solid rgba(255,255,255,.07); } .mf-col:last-child { border-bottom:none; } }

/* ── Service Cards (Homepage) ── */
.service-item {
  background:#fff; border:1.5px solid var(--border);
  border-radius:18px; padding:28px 24px; height:100%; transition:.35s;
}
.service-item:hover { border-color:#8066D6; box-shadow:var(--shadow-lg); transform:translateY(-6px); }
.si-icon { width:64px; height:64px; border-radius:16px; display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.si-icon img { width:36px; height:36px; object-fit:contain; }
.si-icon.purple { background:rgba(90,47,194,.1); }
.si-icon.green  { background:rgba(122,201,67,.12); }
.si-icon.navy   { background:rgba(22,14,69,.08); }
.si-icon.indigo { background:rgba(46,27,140,.09); }
.service-item h4 { font-family:'Nunito',sans-serif; font-size:1.1rem; font-weight:800; color:var(--dark); margin-bottom:10px; }
.service-item p { font-size:.85rem; color:var(--muted); line-height:1.75; margin-bottom:16px; }
.service-item .btn-light { font-family:'Nunito',sans-serif; font-weight:700; font-size:.83rem; color:var(--primary); background:var(--light); border:none; border-radius:8px; padding:8px 16px; transition:.2s; }
.service-item .btn-light:hover { background:var(--primary); color:#fff; }

/* ── Why Choose (icons grid) ── */
.why-box { background:#fff; border:1.5px solid var(--border); border-radius:14px; padding:20px; text-align:center; height:100%; transition:.3s; }
.why-box:hover { border-color:#8066D6; box-shadow:var(--shadow); }
.why-ico { width:52px; height:52px; border-radius:13px; display:flex; align-items:center; justify-content:center; margin:0 auto 12px; background:var(--light); }
.why-ico img { width:28px; height:28px; object-fit:contain; }
.why-box h6 { font-family:'Nunito',sans-serif; font-size:.9rem; font-weight:800; color:var(--dark); margin:0; }

/* ── CTA / Appointment Band ── */
.cta-section {
  background:linear-gradient(135deg, var(--dark) 0%, #261570 50%, var(--primary) 100%);
  position:relative; overflow:hidden;
}
.cta-section::before { content:''; position:absolute; top:-60px; right:-60px; width:360px; height:360px; background:rgba(122,201,67,.06); border-radius:50%; pointer-events:none; }
.cta-section::after { content:''; position:absolute; bottom:-80px; left:-40px; width:260px; height:260px; background:rgba(255,255,255,.03); border-radius:50%; pointer-events:none; }
.cta-form-box {
  background:rgba(255,255,255,.08); backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.13); border-radius:20px; padding:34px;
}
.cta-form-box .ff { background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.18); color:#fff; border-radius:10px; padding:11px 14px; font-size:.87rem; font-family:'Inter',sans-serif; width:100%; outline:none; transition:.2s; }
.cta-form-box .ff::placeholder { color:rgba(255,255,255,.38); }
.cta-form-box .ff:focus { background:rgba(255,255,255,.16); border-color:var(--accent); }
.cta-form-box .ff option { background:var(--dark); color:#fff; }
.ff-lbl { font-size:.72rem; font-weight:700; color:rgba(255,255,255,.55); font-family:'Nunito',sans-serif; display:block; margin-bottom:5px; }

/* ── Blog Cards ── */
.blog-card { background:#fff; border:1.5px solid var(--border); border-radius:18px; overflow:hidden; height:100%; transition:.35s; }
.blog-card:hover { border-color:#8066D6; box-shadow:var(--shadow-lg); transform:translateY(-5px); }
.blog-thumb { height:160px; display:flex; align-items:center; justify-content:center; font-size:3.5rem; background:linear-gradient(135deg, var(--light), #e0daff); }
.blog-body { padding:22px; }
.blog-cat { font-size:.67rem; font-weight:700; letter-spacing:1.4px; text-transform:uppercase; color:var(--accent); background:rgba(122,201,67,.1); padding:3px 10px; border-radius:20px; display:inline-block; margin-bottom:10px; font-family:'Nunito',sans-serif; }
.blog-body h5 { font-family:'Nunito',sans-serif; font-size:.97rem; font-weight:800; color:var(--dark); line-height:1.4; margin-bottom:8px; }
.blog-body p { font-size:.83rem; color:var(--muted); line-height:1.65; margin:0; }
.blog-link { display:inline-flex; align-items:center; gap:5px; margin-top:12px; font-size:.82rem; font-weight:700; color:var(--primary); font-family:'Nunito',sans-serif; transition:.2s; }
.blog-link:hover { color:var(--accent); }

/* ── Testimonials ── */
.test-item { background:#fff; border:1.5px solid var(--border); border-radius:18px; padding:28px; }
.test-item .stars { color:var(--accent); font-size:.88rem; margin-bottom:14px; }
.test-item p { font-size:.88rem; color:var(--muted); line-height:1.78; font-style:italic; margin-bottom:18px; }
.test-item .t-auth { display:flex; align-items:center; gap:12px; padding-top:14px; border-top:1px solid var(--border); }
.test-item .t-auth img { width:42px; height:42px; border-radius:50%; object-fit:cover; }
.test-item .t-auth h6 { font-family:'Nunito',sans-serif; font-size:.9rem; font-weight:800; margin:0; color:var(--dark); }
.test-item .t-auth small { color:var(--muted); font-size:.74rem; }
.testimonial-left img,.testimonial-right img { width:60%; border-radius:10px; margin-bottom:16px; }
.testimonial-left { display:flex; flex-direction:column; align-items:flex-end; }
.testimonial-right { display:flex; flex-direction:column; align-items:flex-start; }
.testimonial-item img { width:80px !important; height:80px; border-radius:50%; object-fit:cover; }

/* ── Page Header ── */
.page-header {
  background:linear-gradient(135deg, var(--dark) 0%, var(--primary) 100%);
  padding:74px 0 38px; position:relative; overflow:hidden;
}
.page-header::after { content:''; position:absolute; bottom:-50px; right:-50px; width:240px; height:240px; background:rgba(122,201,67,.07); border-radius:50%; pointer-events:none; }
.page-header h1 { font-family:'Nunito',sans-serif; font-size:clamp(1.8rem,4vw,2.7rem); font-weight:900; color:#fff; margin-bottom:10px; }
.page-header .breadcrumb-item { font-weight:600; font-size:.84rem; }
.page-header .breadcrumb-item a { color:rgba(255,255,255,.5); }
.page-header .breadcrumb-item + .breadcrumb-item::before { color:rgba(255,255,255,.25); }
.page-header .breadcrumb-item.active { color:var(--accent); }

/* ── Facts Band (used in index + about) ── */
.facts { background:linear-gradient(135deg, var(--primary), #4A28B0); }
.facts-text { padding:80px 40px; }
.facts-counter { background:rgba(255,255,255,.94); padding:80px 40px; }
.facts-counter h1 { font-family:'Nunito',sans-serif; font-size:2.8rem; font-weight:900; color:var(--dark); }
.facts-counter p { color:var(--primary); font-weight:700; font-size:.9rem; margin-top:4px; }

/* ── Calculators ── */
.calc-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:8px; margin-top:24px; }
.cbtn { background:#fff; border:1.5px solid var(--border); border-radius:12px; padding:14px 6px; text-align:center; cursor:pointer; transition:.25s; }
.cbtn:hover, .cbtn.active { background:var(--primary); border-color:var(--primary); }
.cbtn .ci { font-size:1.2rem; display:block; margin-bottom:4px; }
.cbtn .cl { font-size:.64rem; font-weight:700; color:var(--muted); line-height:1.3; font-family:'Nunito',sans-serif; }
.cbtn:hover .cl, .cbtn.active .cl { color:#fff; }
.cbox { background:var(--light); border:1.5px solid var(--border); border-radius:14px; padding:26px; margin-top:12px; display:none; }
.cbox.show { display:block; animation:cboxIn .3s ease; }
@keyframes cboxIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:none; } }
.cbox h5 { font-family:'Nunito',sans-serif; font-size:1.05rem; font-weight:800; color:var(--dark); margin-bottom:18px; padding-bottom:12px; border-bottom:1px solid var(--border); }
.cform { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.fg { display:flex; flex-direction:column; gap:4px; }
.fg label { font-size:.73rem; font-weight:700; color:#444; font-family:'Nunito',sans-serif; }
.fg input, .fg select { border:1.5px solid var(--border); border-radius:8px; padding:9px 12px; font-size:.86rem; font-family:'Inter',sans-serif; background:#fff; outline:none; transition:.2s; width:100%; }
.fg input:focus, .fg select:focus { border-color:var(--primary); box-shadow:0 0 0 3px rgba(46,27,140,.08); }
.csub { grid-column:1/-1; background:var(--primary); color:#fff; border:none; padding:11px 24px; border-radius:10px; font-size:.88rem; font-weight:700; cursor:pointer; font-family:'Nunito',sans-serif; transition:.2s; margin-top:2px; }
.csub:hover { background:var(--hover); }
.cres { background:var(--dark); border-radius:12px; padding:18px 22px; margin-top:12px; display:none; flex-wrap:wrap; gap:24px; }
.cres.on { display:flex; }
.rl { font-size:.68rem; color:rgba(255,255,255,.4); font-weight:700; margin-bottom:3px; text-transform:uppercase; letter-spacing:.6px; }
.rv { font-family:'Nunito',sans-serif; font-size:1.35rem; font-weight:900; color:var(--accent); }
@media(max-width:767px) { .calc-grid { grid-template-columns:repeat(3,1fr); } .cform { grid-template-columns:1fr; } }
@media(max-width:479px) { .calc-grid { grid-template-columns:repeat(2,1fr); } }

/* ── Contact Forms ── */
.ctabs { display:flex; border:1.5px solid var(--border); border-radius:12px; overflow:hidden; width:fit-content; margin-bottom:28px; }
.ctab { padding:11px 22px; font-size:.83rem; font-weight:700; cursor:pointer; background:#fff; border:none; color:var(--muted); font-family:'Nunito',sans-serif; transition:.2s; }
.ctab.active { background:var(--primary); color:#fff; }
.ctab:not(:last-child) { border-right:1.5px solid var(--border); }
.cwrap { display:none; }
.cwrap.on { display:grid; grid-template-columns:1fr 1fr; gap:32px; }
@media(max-width:991px) { .cwrap.on { grid-template-columns:1fr; } }
.ccard { background:#fff; border:1.5px solid var(--border); border-radius:16px; padding:28px; }
.ccard h5 { font-family:'Nunito',sans-serif; font-size:1.05rem; font-weight:800; color:var(--dark); margin-bottom:4px; }
.ccard .ccard-sub { font-size:.78rem; color:var(--muted); margin-bottom:20px; }
.cfield { display:flex; flex-direction:column; gap:4px; margin-bottom:12px; }
.cfield label { font-size:.73rem; font-weight:700; color:#444; font-family:'Nunito',sans-serif; }
.cfield input, .cfield select, .cfield textarea { border:1.5px solid var(--border); border-radius:8px; padding:10px 12px; font-size:.86rem; font-family:'Inter',sans-serif; background:var(--light); outline:none; transition:.2s; width:100%; }
.cfield input:focus, .cfield select:focus, .cfield textarea:focus { border-color:var(--primary); background:#fff; box-shadow:0 0 0 3px rgba(46,27,140,.08); }
.cfield textarea { resize:vertical; min-height:80px; }
.csubmit { width:100%; background:var(--primary); color:#fff; border:none; padding:12px; border-radius:10px; font-size:.9rem; font-weight:700; cursor:pointer; font-family:'Nunito',sans-serif; transition:.2s; margin-top:4px; }
.csubmit:hover { background:var(--hover); }
.ok-msg { display:none; background:#edfce7; border:1px solid #a5d8a5; color:#1a6b2a; border-radius:8px; padding:10px 14px; font-size:.8rem; font-weight:600; margin-top:10px; text-align:center; }
.ok-msg.on { display:block; }
.ci-card { display:flex; gap:14px; align-items:flex-start; background:#fff; border:1.5px solid var(--border); border-radius:14px; padding:18px; margin-bottom:14px; }
.ci-ico { width:42px; height:42px; min-width:42px; background:var(--light); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; color:var(--primary); }
.ci-card h6 { font-family:'Nunito',sans-serif; font-size:.85rem; font-weight:800; color:var(--dark); margin-bottom:3px; }
.ci-card p { font-size:.78rem; color:var(--muted); line-height:1.55; margin:0; }

/* ── Knowledge / Blog Page ── */
.cat-filter { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:32px; }
.cat-pill { padding:7px 18px; border-radius:50px; border:1.5px solid var(--border); background:#fff; font-size:.78rem; font-weight:700; color:var(--muted); cursor:pointer; transition:.2s; font-family:'Nunito',sans-serif; }
.cat-pill:hover, .cat-pill.active { background:var(--primary); border-color:var(--primary); color:#fff; }
.article-card { background:#fff; border:1.5px solid var(--border); border-radius:16px; padding:28px 32px; margin-bottom:24px; transition:.3s; }
.article-card:hover { border-color:#8066D6; box-shadow:var(--shadow); }
.acat { background:rgba(122,201,67,.12); color:var(--accent); font-size:.68rem; font-weight:700; letter-spacing:1.2px; text-transform:uppercase; padding:3px 10px; border-radius:20px; display:inline-block; margin-bottom:10px; font-family:'Nunito',sans-serif; }
.article-card h2 { font-family:'Nunito',sans-serif; font-size:1.2rem; font-weight:800; color:var(--dark); margin-bottom:8px; }
.article-card .ameta { font-size:.73rem; color:#b0b0c8; margin-bottom:12px; }
.article-body { font-size:.9rem; line-height:1.82; color:#525270; }
.article-body h4 { font-family:'Nunito',sans-serif; color:var(--dark); font-size:.98rem; font-weight:800; margin:18px 0 8px; }
.article-body ul { padding-left:18px; margin-bottom:12px; }
.article-full { display:none; }
.article-full.open { display:block; }
.sidebar-widget { background:#fff; border:1.5px solid var(--border); border-radius:14px; padding:22px; margin-bottom:20px; }
.sidebar-widget h6 { font-family:'Nunito',sans-serif; font-weight:800; color:var(--dark); margin-bottom:14px; padding-bottom:8px; border-bottom:1px solid var(--border); font-size:.93rem; }
.rp-item { display:flex; gap:12px; align-items:flex-start; margin-bottom:12px; padding-bottom:12px; border-bottom:1px solid #f0f0f8; }
.rp-item:last-child { border-bottom:none; margin-bottom:0; padding-bottom:0; }
.rp-ico { width:40px; height:40px; min-width:40px; background:var(--light); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; }
.rp-item h6 { font-size:.79rem; font-weight:700; color:var(--dark); margin-bottom:2px; line-height:1.4; cursor:pointer; font-family:'Nunito',sans-serif; }
.rp-item h6:hover { color:var(--primary); }
.rp-item small { color:#c0c0d8; font-size:.7rem; }
.calc-cta { background:linear-gradient(135deg,var(--primary),var(--hover)); border-radius:14px; padding:22px; text-align:center; }

/* ── Services Page ── */
.svc-tab-nav { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:32px; }
.svc-tab-btn { padding:9px 22px; border-radius:50px; border:1.5px solid var(--border); background:#fff; font-size:.82rem; font-weight:700; color:var(--muted); cursor:pointer; transition:.2s; font-family:'Nunito',sans-serif; }
.svc-tab-btn:hover, .svc-tab-btn.active { background:var(--primary); border-color:var(--primary); color:#fff; }
.svc-section { display:none; }
.svc-section.on { display:block; }
.svc-detail-card { background:#fff; border:1.5px solid var(--border); border-radius:16px; padding:22px; margin-bottom:14px; transition:.3s; }
.svc-detail-card:hover { border-color:#8066D6; box-shadow:var(--shadow); }
.svc-detail-card h6 { font-family:'Nunito',sans-serif; font-size:.95rem; font-weight:800; color:var(--dark); margin-bottom:6px; }
.svc-detail-card p { font-size:.83rem; color:var(--muted); margin:0; line-height:1.65; }
.partner-tag { display:inline-flex; align-items:center; gap:8px; background:var(--light); border:1.5px solid var(--border); border-radius:10px; padding:7px 14px; font-size:.79rem; font-weight:700; color:var(--primary); font-family:'Nunito',sans-serif; margin:4px; }
.chk-item { display:flex; align-items:flex-start; gap:12px; background:#fff; border:1.5px solid var(--border); border-radius:12px; padding:16px; transition:.2s; margin-bottom:10px; }
.chk-item:hover { border-color:var(--accent); }
.chk-item .chk { color:var(--accent); margin-top:2px; }
.chk-item h6 { font-family:'Nunito',sans-serif; font-size:.88rem; font-weight:800; color:var(--dark); margin-bottom:3px; }
.chk-item p { font-size:.78rem; color:var(--muted); margin:0; line-height:1.5; }

/* ── Footer ── */
.footer { background:var(--dark); }
.footer-brand p { font-size:.84rem; color:rgba(255,255,255,.38); line-height:1.8; }
.footer h5 { font-family:'Nunito',sans-serif; font-size:.88rem; font-weight:800; color:rgba(255,255,255,.75); margin-bottom:18px; text-transform:uppercase; letter-spacing:.8px; }
.footer .f-link { display:block; font-size:.83rem; color:rgba(255,255,255,.38); margin-bottom:9px; transition:.2s; }
.footer .f-link::before { content:'› '; color:var(--accent); }
.footer .f-link:hover { color:var(--accent); padding-left:6px; }
.footer .f-row { display:flex; gap:10px; align-items:flex-start; margin-bottom:14px; }
.footer .f-row i { color:var(--accent); margin-top:3px; font-size:.85rem; }
.footer .f-row span { font-size:.81rem; color:rgba(255,255,255,.38); line-height:1.65; }
.footer .f-soc a { display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px; background:rgba(255,255,255,.05); border-radius:10px; color:rgba(255,255,255,.4); font-size:.85rem; margin-right:8px; transition:.2s; }
.footer .f-soc a:hover { background:var(--accent); color:#fff; }
.copyright { padding:20px 0; border-top:1px solid rgba(255,255,255,.06); font-size:.77rem; color:rgba(255,255,255,.25); }
.copyright a { color:var(--accent); }

/* ── Misc ── */
.appointment { background:linear-gradient(135deg, var(--dark), var(--primary)); }
.bg-primary-soft { background:var(--light); }
