:root{
  --navy: #00004D;     /* Deep Navy */
  --ivory: #FFFFFF;    /* Ivory */
  --orange: #D50032;   /* Muted Orange */
  --orange-2: #AA0028; /* Hover */

  --bg: var(--ivory);
  --text: var(--navy);
  --muted: rgba(27,38,59,.72);

  /* legacy vars */
  --blue: var(--navy);
  --blue-2: #00004D;

  --soft: rgba(27,38,59,.08);
  --soft2: rgba(198,123,88,.12);

  --card: #FFFEFB;
  --border: rgba(27,38,59,.14);
  --shadow: 0 14px 40px rgba(27,38,59,.12);
  --radius: 18px;
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:
    radial-gradient(circle at top left, rgba(213,0,50,.22), transparent 28%),
    radial-gradient(circle at top right, rgba(0,0,77,.22), transparent 34%),
    radial-gradient(circle at 50% 120%, rgba(0,0,77,.12), transparent 32%),
    linear-gradient(180deg, #f7f8ff 0%, #ffffff 24%, #fff7fa 100%);
  background-attachment: fixed;
  color: var(--text);
  line-height:1.55;
}
body::before{
  content:"";
  position:fixed;
  inset:-10% -8% auto auto;
  width:min(40vw, 520px);
  height:min(40vw, 520px);
  background: radial-gradient(circle, rgba(0,0,77,.12) 0%, rgba(0,0,77,0) 68%);
  pointer-events:none;
  z-index:-1;
}
body::after{
  content:"";
  position:fixed;
  inset:auto auto -18% -12%;
  width:min(46vw, 640px);
  height:min(46vw, 640px);
  background: radial-gradient(circle, rgba(213,0,50,.10) 0%, rgba(213,0,50,0) 72%);
  pointer-events:none;
  z-index:-1;
}

/* JS-only page load */
body{ opacity:1; transform:none; }
.js body.page-loading{
  opacity:0;
  transform: translateY(6px);
  transition: opacity .35s ease, transform .35s ease;
}
.js body.page-loaded{
  opacity:1;
  transform:none;
}

.container{
  max-width: var(--container);
  padding: 0 18px;
  margin: 0 auto;
}

a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
button{font:inherit}

/* make anchor sections offset for sticky header */
section{ scroll-margin-top: calc(var(--headerH) + 16px); }

/* ===== Icons (pure CSS masks via inline SVG style-ish) ===== */
.icon{
  width:18px;height:18px;display:inline-block;
  background: currentColor;
  -webkit-mask-size:contain; -webkit-mask-repeat:no-repeat; -webkit-mask-position:center;
  mask-size:contain; mask-repeat:no-repeat; mask-position:center;
}
.i-phone{ -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6.6 10.8c1.5 3 4 5.6 7 7l2.3-2.3c.3-.3.8-.4 1.2-.2 1.3.5 2.7.8 4.2.8.7 0 1.2.5 1.2 1.2V21c0 .7-.5 1.2-1.2 1.2C10.7 22.2 1.8 13.3 1.8 2.4 1.8 1.7 2.3 1.2 3 1.2H6.8c.7 0 1.2.5 1.2 1.2 0 1.5.3 2.9.8 4.2.1.4 0 .9-.3 1.2L6.6 10.8z'/%3E%3C/svg%3E"); mask-image: -webkit-mask-image; }
.i-telegram{ -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M21.7 4.3 2.9 11.6c-1.3.5-1.3 1.2-.2 1.5l4.8 1.5 1.8 5.6c.2.6.4.6.8.2l2.6-2.5 5.4 4c1 .6 1.7.3 2-.9l3.4-16.2c.4-1.5-.6-2.2-1.8-1.6zM9 14.3l9.9-6.2c.5-.3.9-.1.5.3l-8.1 7.3-.3 3.7c0 .3-.1.4-.3.4l-1.7-5.3z'/%3E%3C/svg%3E"); mask-image: -webkit-mask-image; }
.i-whatsapp{ -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2a10 10 0 0 0-8.6 15.1L2 22l5-1.3A10 10 0 1 0 12 2zm5.7 14.6c-.2.6-1.2 1.2-1.7 1.2-.5.1-1.1.1-1.8-.1-.4-.1-.9-.3-1.6-.6-2.8-1.2-4.6-4.1-4.7-4.3-.1-.2-1.1-1.5-1.1-2.9 0-1.4.7-2.1 1-2.3.2-.2.5-.3.8-.3h.6c.2 0 .5 0 .7.5.2.6.8 2.1.9 2.2.1.2.1.4 0 .6-.1.2-.2.4-.3.5-.2.2-.3.3-.4.5-.1.2-.2.4 0 .6.2.2.8 1.3 1.7 2.1 1.2 1.1 2.2 1.5 2.5 1.6.2.1.4.1.6-.1.2-.2.7-.8.9-1.1.2-.3.4-.2.7-.1.3.1 2 .9 2.3 1.1.3.2.5.2.5.4.1.2.1.9-.1 1.5z'/%3E%3C/svg%3E"); mask-image: -webkit-mask-image; }
.i-star{ -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 17.3 6.2 20.5l1.1-6.5-4.7-4.6 6.6-1 3-6 3 6 6.6 1-4.7 4.6 1.1 6.5z'/%3E%3C/svg%3E"); mask-image:-webkit-mask-image; }
.i-layers{ -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2 1 7l11 5 9-4.1V17h2V7L12 2zm0 9L1 6v2l11 5 11-5V6l-11 5zm0 4L1 10v2l11 5 11-5v-2l-11 5z'/%3E%3C/svg%3E"); mask-image:-webkit-mask-image; }
.i-target{ -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2a10 10 0 1 0 10 10A10 10 0 0 0 12 2zm0 18a8 8 0 1 1 8-8 8 8 0 0 1-8 8zm0-14a6 6 0 1 0 6 6 6 6 0 0 0-6-6zm0 10a4 4 0 1 1 4-4 4 4 0 0 1-4 4zm0-6a2 2 0 1 0 2 2 2 2 0 0 0-2-2z'/%3E%3C/svg%3E"); mask-image:-webkit-mask-image; }
.i-cap{ -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 3 1 9l11 6 9-4.9V17h2V9L12 3zm-6 9.6V16c0 1.7 2.7 3 6 3s6-1.3 6-3v-3.4l-6 3.3-6-3.3z'/%3E%3C/svg%3E"); mask-image:-webkit-mask-image; }
.i-calendar{ -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7 2h2v2h6V2h2v2h3v18H3V4h4V2zm14 6H3v12h18V8z'/%3E%3C/svg%3E"); mask-image:-webkit-mask-image; }
.i-globe{ -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2a10 10 0 1 0 10 10A10 10 0 0 0 12 2zm7.9 9h-3.2a15.7 15.7 0 0 0-1.4-6.2A8.1 8.1 0 0 1 19.9 11zM12 4.1c.9 1.2 1.9 3.3 2.4 6.9H9.6c.5-3.6 1.5-5.7 2.4-6.9zM4.1 13h3.2a15.7 15.7 0 0 0 1.4 6.2A8.1 8.1 0 0 1 4.1 13zm3.2-2H4.1a8.1 8.1 0 0 1 4.6-6.2A15.7 15.7 0 0 0 7.3 11zM12 19.9c-.9-1.2-1.9-3.3-2.4-6.9h4.8c-.5 3.6-1.5 5.7-2.4 6.9zM15.3 19.2a15.7 15.7 0 0 0 1.4-6.2h3.2a8.1 8.1 0 0 1-4.6 6.2z'/%3E%3C/svg%3E"); mask-image:-webkit-mask-image; }
.i-life{ -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 21s-7-4.6-9.5-9A6 6 0 0 1 12 4a6 6 0 0 1 9.5 8c-2.5 4.4-9.5 9-9.5 9zm0-11a2 2 0 1 0 2 2 2 2 0 0 0-2-2z'/%3E%3C/svg%3E"); mask-image:-webkit-mask-image; }
.i-check{ -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 16.2 4.8 12 3.4 13.4 9 19 21 7 19.6 5.6z'/%3E%3C/svg%3E"); mask-image:-webkit-mask-image; }
.i-chat{ -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4 4h16v11H7l-3 3V4zm4 5h8v2H8V9zm0-3h12v2H8V6zm0 6h10v2H8v-2z'/%3E%3C/svg%3E"); mask-image:-webkit-mask-image; }

/* ====== Top ribbon ====== */
.top-ribbon{
  background: linear-gradient(90deg, rgba(0,0,77,.10), rgba(213,0,50,.10));
  border-bottom: 1px solid var(--border);
}
.ribbon-inner{
  height: 44px;
  display:flex; align-items:center; justify-content:space-between;
  gap: 12px;
}
.chip{
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(213,0,50,.14);
  color: var(--blue-2);
  font-weight: 600;
}
.ribbon-right{
  display:flex; align-items:center; gap: 10px;
}
.ribbon-link{
  display:flex; align-items:center; gap:8px;
  font-size: 13px;
  color: var(--text);
  opacity: .88;
}
.ribbon-icon{
  width: 34px; height: 34px;
  border-radius: 999px;
  border: 1px solid var(--border);
  display:grid; place-items:center;
  background: #fff;
}
.ribbon-icon:hover{ transform: translateY(-1px); box-shadow: 0 8px 18px rgba(11,18,32,.08); }

.lang{
  display:flex; align-items:center; gap: 6px;
  padding-left: 8px;
}
.lang-btn{
  border: 0;
  background: transparent;
  font-weight: 700;
  font-size: 12px;
  color: var(--blue-2);
  opacity: .75;
  cursor: pointer;
}
.lang-btn.is-active{ opacity: 1; color: var(--orange); }
.lang-sep{ opacity:.35; font-size: 12px; }

/* ====== Topbar ====== */
.topbar{
  background: rgba(0,0,77,.06);
  border-bottom: 1px solid rgba(0,0,77,.10);
}
.topbar-inner{
  height: 44px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}
.topbar-left, .topbar-right{
  display:flex;
  align-items:center;
  gap: 10px;
}
.topbar-link{
  font-size: 13px;
  font-weight: 650;
  color: rgba(11,18,32,.75);
}
.topbar-link:hover{ color: var(--blue); }
.dot{ opacity:.35; font-size: 12px; }

[hidden]{ display:none !important; }

.nav-link.is-active{
  background: rgba(213,0,50,.12);
  color: var(--orange);
}
.nav.nav-pages .nav-pill{
  background: rgba(0,0,77,.06);
  border: 1px solid rgba(0,0,77,.12);
}
.nav.nav-pages .nav-pill.is-active{
  background: rgba(0,0,77,.10);
  color: var(--blue);
}

/* ====== Header ====== */
.header{
  position: sticky; top:0; z-index: 20;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
}
.header-inner{
  height: var(--headerH);
  display:flex; align-items:center; justify-content:space-between;
  gap: 16px;
}
.brand{
  display:flex; align-items:center; gap: 10px;
}
.brand.small .brand-name{ font-size: 15px; }
.brand-mark{
  width: 42px; height:42px;
  border-radius: 14px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, var(--blue), var(--orange));
  color: white; font-weight: 800;
  box-shadow: 0 10px 22px rgba(0,0,77,.18);
}
.brand-name{
  font-weight: 800;
  letter-spacing: -0.2px;
}
.brand-tag{
  font-size: 12px;
  color: rgba(11,18,32,.62);
  margin-top: -2px;
}

.nav{
  display:flex;
  gap: 14px;
  align-items:center;
}
.nav-link{
  font-size: 14px;
  font-weight: 600;
  color: rgba(11,18,32,.76);
  padding: 10px 10px;
  border-radius: 12px;
}
.nav-link:hover{ background: rgba(0,0,77,.08); color: var(--blue); }

.header-actions{
  display:flex; align-items:center; gap: 10px;
}

/* Mobile menu */
.burger{
  display:none;
  width: 44px; height: 44px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: #fff;
  cursor: pointer;
}
.burger span{
  display:block;
  width: 18px;
  height: 2px;
  background: rgba(11,18,32,.75);
  margin: 5px auto;
  border-radius: 2px;
}
.mobile-menu{
  border-top: 1px solid var(--border);
  background: rgba(255,255,255,.92);
}
.mobile-inner{
  padding: 12px 18px 18px;
  display:grid;
  gap: 10px;
}
.mobile-link{
  padding: 12px 12px;
  border-radius: 14px;
  font-weight: 650;
  background: rgba(0,0,77,.06);
}
.mobile-cta{
  margin-top: 8px;
  display:grid;
  gap: 10px;
}
.mobile-social{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

/* ====== Buttons ====== */
.btn{
  border: 1px solid transparent;
  padding: 12px 16px;
  border-radius: 14px;
  font-weight: 700;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 8px;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
}
.btn:hover{ transform: translateY(-1px); box-shadow: 0 12px 26px rgba(11,18,32,.10); }
.btn:active{ transform: translateY(0); box-shadow:none; }

.btn-primary{
  background: linear-gradient(135deg, var(--orange), var(--orange-2));
  color: #1b1306;
  border-color: rgba(213,0,50,.35);
}
.btn-outline{
  background: #fff;
  border-color: rgba(0,0,77,.22);
  color: var(--blue-2);
}
.btn-soft{
  background: rgba(0,0,77,.09);
  color: var(--blue-2);
  border-color: rgba(0,0,77,.12);
}
.btn-light{
  background: #fff;
  color: var(--blue-2);
}
.btn-ghost{
  background: transparent;
  border-color: rgba(255,255,255,.25);
  color: #fff;
}
.btn-ghost:hover{ background: rgba(255,255,255,.10); box-shadow:none; }

.circle-btn{
  width: 44px; height:44px;
  border-radius: 999px;
  border: 1px solid rgba(11,18,32,.18);
  background: #fff;
  font-size: 20px;
  display:grid; place-items:center;
  cursor:pointer;
}
.circle-btn.light{
  border-color: rgba(255,255,255,.35);
  background: rgba(255,255,255,.16);
  color: #fff;
}
.circle-btn:hover{ transform: translateY(-1px); }

/* ====== Sections ====== */
.section{
  padding: 64px 0;
}
.section-alt{
  background: linear-gradient(180deg, rgba(0,0,77,.05), rgba(213,0,50,.05));
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.h2{
  font-size: 34px;
  letter-spacing: -0.6px;
  margin: 0 0 18px;
}
.h2-invert{ color: #fff; }
.h3{ margin: 0 0 8px; font-size: 18px; }
.lead{
  font-size: 16px;
  color: var(--muted);
  margin-top: 0;
}
.section-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  margin-bottom: 18px;
}
.section-head.invert{ margin-bottom: 20px; }
.section-head.invert .carousel-controls{ display:flex; gap: 10px; }

/* ====== Hero ====== */
.hero{
  padding: 54px 0 24px;
  position: relative;
  overflow: hidden;
}
.hero::before{
  content:"";
  position:absolute;
  inset:-30% -20% auto -20%;
  height: 420px;
  background: radial-gradient(circle at 30% 40%, rgba(213,0,50,.18), transparent 55%),
              radial-gradient(circle at 70% 30%, rgba(0,0,77,.16), transparent 55%);
  pointer-events:none;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.2fr .9fr;
  gap: 26px;
  align-items:center;
  position: relative;
}
.pill{
  display:inline-flex;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(0,0,77,.10);
  color: var(--blue-2);
  font-weight: 700;
  font-size: 12px;
}
.hero-title{
  font-size: 44px;
  line-height: 1.08;
  letter-spacing: -1px;
  margin: 14px 0 12px;
}
.hero-sub{
  margin: 0 0 18px;
  color: rgba(11,18,32,.74);
  font-size: 15.5px;
}
.hero-actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}
.hero-metrics{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
}
.metric{
  padding: 12px 14px;
  border-radius: 16px;
  background: #fff;
  border: 1px solid var(--border);
  min-width: 160px;
}
.metric-num{
  font-weight: 900;
  font-size: 22px;
  color: var(--blue-2);
}
.metric-text{
  font-size: 13px;
  color: rgba(11,18,32,.65);
}

.hero-visual{
  position: relative;
  min-height: 360px;
}
.blob{
  width: 100%;
  border-radius: 26px;
  background: linear-gradient(135deg, rgba(0,0,77,.12), rgba(213,0,50,.16));
  padding: 12px;
  box-shadow: var(--shadow);
}
.blob img{
  width: 100%;
  height: 360px;
  object-fit: cover;
  border-radius: 20px;
}
.avatar{
  position:absolute;
  width: 86px; height: 86px;
  border-radius: 22px;
  background: #fff;
  padding: 8px;
  box-shadow: 0 12px 26px rgba(11,18,32,.12);
  border: 1px solid rgba(11,18,32,.10);
}
.avatar img{
  width: 100%; height:100%;
  border-radius: 18px;
  object-fit: cover;
}
.avatar.a1{ left: -14px; top: 50px; }
.avatar.a2{ right: -12px; top: 88px; }
.avatar.a3{ right: 22px; bottom: -10px; }

/* ====== Split layout ====== */
.split{
  display:grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 26px;
  align-items:center;
}
.split-media .media-card{
  border-radius: 26px;
  overflow:hidden;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  background: #fff;
}
.media-card img{
  height: 420px;
  width: 100%;
  object-fit: cover;
}
.note{
  margin-top: 14px;
  border-left: 4px solid var(--orange);
  padding: 10px 12px;
  background: rgba(213,0,50,.10);
  border-radius: 12px;
}
.note-strong{ font-weight: 900; color: var(--blue-2); }
.inline-actions{ display:flex; gap:12px; flex-wrap: wrap; margin-top: 14px; }

/* ====== Cards grid ====== */
.grid-4{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.card{
  border-radius: 18px;
  background: var(--card);
  border: 1px solid var(--border);
  padding: 16px;
  box-shadow: 0 10px 24px rgba(11,18,32,.07);
}
.card-icon{
  width: 44px; height:44px;
  border-radius: 16px;
  background: rgba(0,0,77,.10);
  color: var(--blue-2);
  display:grid; place-items:center;
  margin-bottom: 10px;
}

/* ====== Band (blue background) ====== */
.hero-band{
  background: linear-gradient(135deg, var(--blue-2), #12006b);
  color: #fff;
  position: relative;
  overflow:hidden;
}
.hero-band::before{
  content:"";
  position:absolute;
  inset:-50% -30% auto -30%;
  height: 520px;
  background: radial-gradient(circle at 25% 30%, rgba(213,0,50,.35), transparent 60%),
              radial-gradient(circle at 70% 35%, rgba(255,255,255,.16), transparent 60%);
  pointer-events:none;
}
.band-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 26px;
  align-items:center;
  position: relative;
}
.band-lead{ color: rgba(255,255,255,.85); }
.band-cta{ display:flex; gap: 12px; flex-wrap: wrap; margin-top: 14px; }
.band-blob{
  border-radius: 26px;
  padding: 10px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.18);
}
.band-blob img{
  width: 100%;
  height: 360px;
  object-fit: cover;
  border-radius: 20px;
}

/* ====== Achievements ====== */
.ach-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  align-items: start;
}
.stat-card{
  border-radius: 18px;
  border: 1px solid var(--border);
  background: #fff;
  padding: 16px;
}
.stat-num{
  font-size: 44px;
  font-weight: 900;
  color: var(--blue-2);
  letter-spacing: -1px;
}
.stat-text{ font-weight: 800; margin-top: 2px; }
.stat-sub{ color: rgba(11,18,32,.62); font-size: 13px; margin-top: 4px; }

.collage{
  grid-column: 2 / 3;
  grid-row: 1 / span 4;
  border-radius: 22px;
  border: 1px solid var(--border);
  padding: 12px;
  background: #fff;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  align-self: stretch;
}
.collage img{
  border-radius: 16px;
  height: 160px;
  object-fit: cover;
}

/* ====== Steps ====== */
.steps{
  display:grid;
  gap: 12px;
}
.step{
  border-radius: 18px;
  border: 1px solid var(--border);
  background: #fff;
  padding: 16px;
  display:flex;
  gap: 14px;
  align-items:flex-start;
}
.step-num{
  width: 44px; height:44px;
  border-radius: 16px;
  background: rgba(213,0,50,.15);
  color: #3A0011;
  display:grid; place-items:center;
  font-weight: 900;
}
.step-title{ font-weight: 900; }
.step-text{ color: rgba(11,18,32,.68); font-size: 14px; margin-top: 2px; }

/* ====== Carousel ====== */
.carousel{
  position: relative;
  overflow: hidden;
  border-radius: 22px;
}
.carousel-track{
  display:flex;
  gap: 14px;transition: transform .35s ease;
  padding: 4px 2px;
}
.carousel-dots{
  display:flex;
  justify-content:center;
  gap: 8px;
  margin-top: 14px;
}
.dot{
  width: 10px; height:10px;
  border-radius: 999px;
  border: 1px solid rgba(11,18,32,.28);
  background: rgba(255,255,255,.9);
  cursor:pointer;
  opacity: .65;
}
.dot.is-active{
  background: var(--orange);
  border-color: rgba(213,0,50,.65);
  opacity: 1;
}

/* Review card */
.review-card{
  flex: 0 0 calc((100% - 28px) / 3);
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 10px 20px rgba(11,18,32,.08);
}
.review-head{
  display:flex;
  gap: 12px;
  align-items:center;
  margin-bottom: 10px;
}
.review-avatar{
  width: 44px; height:44px;
  border-radius: 16px;
  overflow:hidden;
  border: 1px solid rgba(11,18,32,.10);
}
.review-avatar img{ width:100%; height:100%; object-fit:cover; }
.review-name{ font-weight: 900; }
.review-role{ color: rgba(11,18,32,.62); font-size: 13px; }
.review-text{ margin: 0; color: rgba(11,18,32,.74); }

/* News card */
.news-card{
  flex: 0 0 calc((100% - 28px) / 3);
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 18px;
  overflow:hidden;
}
.news-img img{
  width:100%;
  height: 180px;
  object-fit: cover;
}
.news-meta{
  display:flex;
  gap: 10px;
  align-items:center;
  padding: 12px 14px 6px;
  color: rgba(255,255,255,.80);
  font-size: 12px;
}
.tag{
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.18);
}
.news-title{
  margin: 0;
  padding: 0 14px;
  color: #fff;
  font-weight: 900;
  letter-spacing: -0.2px;
}
.news-text{
  margin: 10px 0 0;
  padding: 0 14px 16px;
  color: rgba(255,255,255,.82);
  font-size: 14px;
}
.news-cta{ margin-top: 16px; display:flex; justify-content:center; }

/* ====== Community ====== */
.community-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 26px;
  align-items:center;
}
.circle-stack{ position: relative; min-height: 340px; }
.circle-img{
  position:absolute;
  border-radius: 999px;
  overflow:hidden;
  border: 6px solid rgba(0,0,77,.10);
  box-shadow: 0 14px 30px rgba(11,18,32,.12);
}
.circle-img img{ width:100%; height:100%; object-fit: cover; }
.circle-img.big{ width: 240px; height:240px; right: 0; top: 10px; border-color: rgba(213,0,50,.20); }
.circle-img.mid{ width: 170px; height:170px; left: 20px; top: 80px; border-color: rgba(0,0,77,.18); }
.circle-img.small{ width: 130px; height:130px; left: 120px; bottom: 0; border-color: rgba(213,0,50,.18); }

/* ====== Partners ====== */
.partners-row{
  display:flex;
  gap: 18px;
  align-items:center;
  justify-content: space-between;
  flex-wrap: wrap;
}
.partner{
  flex: 1 1 160px;
  min-width: 160px;
  max-width: 220px;
  height: 86px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  display:grid;
  place-items:center;
  padding: 12px;
}
.partner img{
  max-height: 46px;
  width: auto;
  object-fit: contain;
  opacity: .9;
}

/* ====== Contact ====== */
.contact-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  align-items: stretch;
}
.contact-card{
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 18px;
  box-shadow: var(--shadow);
}
.contact-items{
  display:grid;
  gap: 12px;
  margin: 14px 0;
}
.contact-item{
  display:flex;
  gap: 12px;
  align-items:center;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: rgba(0,0,77,.06);
}
.contact-item:hover{ background: rgba(213,0,50,.10); }
.contact-label{ font-weight: 900; }
.contact-value{ color: rgba(11,18,32,.70); font-size: 13px; }

.contact-side{
  display:grid;
  gap: 12px;
}
.contact-illustration{
  background: linear-gradient(135deg, rgba(0,0,77,.10), rgba(213,0,50,.12));
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 12px;
  overflow:hidden;
}
.contact-illustration img{
  width: 100%;
  height: 320px;
  object-fit: cover;
  border-radius: 18px;
}
.small-note{
  color: rgba(11,18,32,.70);
  font-size: 13px;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px dashed rgba(11,18,32,.20);
  background: rgba(213,0,50,.08);
}

/* ====== Footer ====== */
.footer{
  padding: 28px 0;
  border-top: 1px solid var(--border);
  background: #fff;
}
.footer-inner{
  display:flex;
  justify-content:space-between;
  gap: 14px;
  align-items:center;
  flex-wrap: wrap;
}
.footer-links{
  display:flex;
  gap: 14px;
  flex-wrap: wrap;
  color: rgba(11,18,32,.70);
  font-weight: 650;
}
.footer-copy{
  color: rgba(11,18,32,.60);
  font-size: 13px;
  margin-top: 8px;
}

/* ===== Floating buttons ===== */
.float-social{
  position: fixed;
  right: 18px;
  bottom: 18px;
  display:grid;
  gap: 10px;
  z-index: 30;
}
.float-btn{
  width: 52px; height:52px;
  border-radius: 999px;
  display:grid; place-items:center;
  border: 1px solid rgba(11,18,32,.16);
  background: #fff;
  box-shadow: 0 12px 26px rgba(11,18,32,.12);
}
.float-btn.tg{ color: var(--blue); }
.float-btn.wa{ color: #1aa260; }
.float-btn:hover{ transform: translateY(-1px); }

.sticky-consult{
  position: fixed;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 30;
  border: 0;
  cursor:pointer;
  padding: 12px 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--orange), var(--orange-2));
  color: #1b1306;
  font-weight: 900;
  display:flex;
  align-items:center;
  gap: 10px;
  box-shadow: 0 18px 34px rgba(11,18,32,.14);
}
.sticky-consult:hover{ transform: translateY(-50%) scale(1.01); }

/* ===== Modal ===== */
.backdrop{
  position: fixed;
  inset:0;
  background: rgba(11,18,32,.52);
  display:grid;
  place-items:center;
  padding: 18px;
  z-index: 60;
}
/* Make sure HTML hidden attribute REALLY hides the modal */
.backdrop[hidden] { 
  display: none !important; 
}

.modal{
  width: min(560px, 100%);
  background: #fff;
  border-radius: 22px;
  border: 1px solid rgba(11,18,32,.12);
  box-shadow: 0 24px 60px rgba(11,18,32,.26);
  padding: 18px;
  position: relative;
}
.modal-close{
  position:absolute;
  right: 12px; top: 10px;
  width: 40px; height:40px;
  border-radius: 14px;
  border: 1px solid rgba(11,18,32,.12);
  background:#fff;
  cursor:pointer;
  font-size: 22px;
}
.modal-title{ margin: 6px 0 4px; font-size: 22px; font-weight: 900; }
.modal-sub{ margin: 0 0 12px; color: rgba(11,18,32,.70); }

.form{ display:grid; gap: 10px; }
.field{ display:grid; gap: 6px; }
.field-label{ font-weight: 800; font-size: 13px; color: rgba(11,18,32,.78); }
input, textarea{
  width: 100%;
  border-radius: 16px;
  border: 1px solid rgba(11,18,32,.14);
  padding: 12px 12px;
  outline: none;
  font: inherit;
}
input:focus, textarea:focus{
  border-color: rgba(0,0,77,.45);
  box-shadow: 0 0 0 4px rgba(0,0,77,.10);
}
.form-actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 6px;
}
.form-note{
  font-size: 13px;
  color: rgba(11,18,32,.70);
  min-height: 18px;
}

/* ===== Reveal ===== */
.reveal{ opacity:1; transform:none; }
.js .reveal{
  opacity:0;
  transform: translateY(14px);
  transition: opacity .55s ease, transform .55s ease;}
.js .reveal.is-visible{ opacity:1; transform:none; }

@media (prefers-reduced-motion: reduce){
  .js body.page-loading, .js .reveal, .carousel-track{
    transition: none !important;
    transform: none !important;
  }
  html{ scroll-behavior:auto; }
}

/* ===== Responsive ===== */
@media (max-width: 980px){
  .nav{ display:none; }
  .burger{ display:inline-block; }
  .hero-grid{ grid-template-columns: 1fr; }
  .split{ grid-template-columns: 1fr; }
  .band-grid{ grid-template-columns: 1fr; }
  .ach-grid{ grid-template-columns: 1fr; }
  .collage{ grid-column: auto; grid-row: auto; }
  .grid-4{ grid-template-columns: repeat(2, 1fr); }
  .review-card, .news-card{ flex: 0 0 82%; }
  .community-grid{ grid-template-columns: 1fr; }
  .contact-grid{ grid-template-columns: 1fr; }
  .sticky-consult{ display:none; } /* hide on small screens */
}

@media (max-width: 520px){
  .hero-title{ font-size: 34px; }
  .grid-4{ grid-template-columns: 1fr; }
  .avatar{ display:none; }
}

/* LMS links in header */
.auth-links{ display:flex; align-items:center; gap: 10px; }
.mobile-auth{ margin: 10px 0 14px; display:flex; flex-direction:column; gap: 6px; }

/* Make header actions wrap so LMS buttons stay visible */
.header-actions{ flex-wrap: wrap; justify-content:flex-end; }

/* LMS quick links under hero */
.lms-quick{
  display:flex;
  align-items:center;
  gap: 10px;
  flex-wrap: wrap;
  margin: 10px 0 0;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(0,0,77,.06);
  border: 1px solid rgba(0,0,77,.18);
}
.lms-label{
  font-weight: 700;
  color: #00004D;
  opacity: .9;
}

/* Keep header LMS links visible even on small screens (but smaller) */
@media (max-width: 980px){
  .auth-links{ display:flex; gap: 8px; }
  .auth-links .btn{ padding: 10px 12px; border-radius: 14px; font-size: 13px; }
}


/* =========================
   LMS Extras (forms / tables)
   ========================= */
.pageWrap{padding:48px 0 70px}
.panel{
  background:#fff;
  border:1px solid rgba(0,0,77,.12);
  box-shadow: 0 20px 60px rgba(13,38,76,.10);
  border-radius:18px;
  padding:18px;
}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width: 900px){.grid-2{grid-template-columns:1fr}}

.field{display:flex;flex-direction:column;gap:8px;margin:12px 0}
.field label{font-weight:700;color:#00004D}
.field input,.field textarea,.field select{
  padding:12px 12px;border-radius:14px;
  border:1px solid rgba(0,0,77,.18);
  outline:none;
  font-size:14px;
  background:#fff;
}

/* Global form controls (used across admin/LMS) */
.input, .select{
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(0,0,77,.18);
  outline:none;
  font-size:14px;
  background:#fff;
}
.select{ cursor:pointer; }
textarea.input{ min-height:110px; resize:vertical; }
.select option{ background:#fff; color:#00004D; }


.field textarea{min-height:110px;resize:vertical}
.sub{color:rgba(13,42,87,.72);line-height:1.6}
.hr{height:1px;background:rgba(0,0,77,.12);border:0;margin:18px 0}

.table{
  width:100%;border-collapse:collapse;
  border:1px solid rgba(0,0,77,.14);
  border-radius:14px;overflow:hidden;
}
.table th,.table td{
  padding:10px 12px;border-bottom:1px solid rgba(0,0,77,.10);
  text-align:left;font-size:14px;
}
.table th{background:rgba(0,0,77,.05);color:#00004D}
.table td{color:rgba(13,42,87,.78)}
.badgeSmall{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 10px;border-radius:999px;
  border:1px solid rgba(213,0,50,.35);
  background:rgba(213,0,50,.10);
  color:#8A0020;
  font-weight:800;font-size:12px;
}
.loaderLine{
  display:none;
  padding:12px 12px;border-radius:14px;
  border:1px dashed rgba(0,0,77,.22);
  color:rgba(13,42,87,.70);
  background:rgba(0,0,77,.04);
}
.loaderLine.show{display:block}
.kpiRow{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px}
.kpi{
  flex:1;min-width:200px;
  border-radius:16px;
  border:1px solid rgba(0,0,77,.14);
  background:rgba(0,0,77,.04);
  padding:12px;
}
.kpi b{display:block;color:#00004D;font-size:16px}
.kpi span{color:rgba(13,42,87,.70);font-size:13px}


/* =========================
   LMS Layout (Sidebar + Content)
   ========================= */
.lmsLayout{
  display:grid;
  grid-template-columns: 280px 1fr;
  gap: 16px;
  align-items:start;
}
@media (max-width: 980px){
  .lmsLayout{ grid-template-columns: 1fr; }
}

.sideNav{
  position: sticky;
  top: calc(var(--headerH) + 14px);
  padding: 16px;
}
.sideTitle{
  font-weight: 900;
  color: var(--text);
  margin-bottom: 10px;
  font-size: 15px;
}
.sideLink{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid transparent;
  color: rgba(13,42,87,.85);
  font-weight: 800;
  text-decoration:none;
  margin-bottom: 8px;
  background: rgba(0,0,77,.03);
}
.sideLink:hover{
  background: rgba(213,0,50,.10);
  border-color: rgba(213,0,50,.25);
}
.sideLink.active{
  background: rgba(213,0,50,.14);
  border-color: rgba(213,0,50,.35);
}
.sideUser{
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(0,0,77,.12);
}
.contentCol{ min-width: 0; }
.cardsGrid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}
@media (max-width: 1100px){ .cardsGrid{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 700px){ .cardsGrid{ grid-template-columns: 1fr; } }

.courseCard{
  border: 1px solid rgba(0,0,77,.14);
  border-radius: 18px;
  overflow:hidden;
  background: #fff;
  box-shadow: 0 18px 50px rgba(13,38,76,.08);
}
.courseCard .cover{
  height: 120px;
  background: linear-gradient(135deg, rgba(0,0,77,.10), rgba(213,0,50,.12));
  display:flex; align-items:center; justify-content:center;
  border-bottom: 1px solid rgba(0,0,77,.10);
}
.courseCard .cover img{ width:100%; height:100%; object-fit:cover; }
.courseCard .body{ padding: 12px; }
.courseCard h3{ margin:0 0 6px; font-size:16px; color: var(--text); }
.courseCard .sub{ margin:0 0 10px; }
.homeCourseCard{
  min-height: 100%;
  display:flex;
  flex-direction:column;
}
.homeCourseCard .body{
  min-height: 210px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap: 12px;
}
.homeCourseCard .sub{
  min-height: 72px;
}

.materials-page .pageWrap{
  padding-top: 64px;
}
.materials-page .pageWrap > .panel:first-child{
  position: relative;
  z-index: 1;
}
@media (max-width: 700px){
  .homeCourseCard .body{ min-height: 240px; }
  .homeCourseCard .sub{ min-height: 96px; }
  .materials-page .pageWrap{ padding-top: 72px; }
}

.progressBar{
  height: 10px;
  border-radius: 999px;
  background: rgba(0,0,77,.10);
  overflow:hidden;
}
.progressBar > span{
  display:block;
  height:100%;
  width: 0%;
  background: linear-gradient(90deg, var(--orange), var(--blue));
}
.topicList{ display:flex; flex-direction:column; gap:8px; }
.topicItem{
  display:flex; align-items:center; justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border-radius: 14px;
  border:1px solid rgba(0,0,77,.12);
  background: rgba(0,0,77,.03);
  cursor:pointer;
}
.topicItem:hover{ background: rgba(213,0,50,.10); border-color: rgba(213,0,50,.25); }
.topicItem.active{ background: rgba(213,0,50,.14); border-color: rgba(213,0,50,.35); }
.topicLeft{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.topicLeft b{ font-size:13px; color:#00004D; }
.topicLeft span{ font-size:12px; line-height:1.35; color: rgba(13,42,87,.65); }
.topicBadges{ display:flex; gap:6px; align-items:center; flex-shrink:0; }
.topicIcon{
  width:30px;
  height:30px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  border:1px solid rgba(213,0,50,.35);
  background:rgba(213,0,50,.10);
  color:#c26400;
  flex:0 0 auto;
}
.topicIcon svg{ width:15px; height:15px; fill: currentColor; display:block; }
.topicIcon-presentation{ box-shadow: inset 0 0 0 1px rgba(255,255,255,.18); }
.dotOk{ width:10px; height:10px; border-radius:999px; background: rgba(42,199,86,.9); }
.dotNo{ width:10px; height:10px; border-radius:999px; background: rgba(213,0,50,.9); }
.dotQuiz{ width:10px; height:10px; border-radius:999px; background: rgba(0,0,77,.9); }
.videoWrap{
  position: relative;
  border-radius: 16px;
  overflow:hidden;
  border: 1px solid rgba(0,0,77,.12);
  background: #000;
  padding-top: 56.25%;
}
.videoWrap iframe{
  position:absolute;
  top:0; left:0;
  width:100%; height:100%;
  border:0;
}

.modalOverlay{
  position: fixed;
  inset: 0;
  background: rgba(2,8,20,.55);
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 18px;
  z-index: 99;
}
.modalCard{
  width: min(520px, 100%);
  border-radius: 18px;
  background: #fff;
  border: 1px solid rgba(0,0,77,.14);
  box-shadow: 0 26px 80px rgba(2,8,20,.35);
  padding: 16px;
}
.modalActions{ display:flex; gap:10px; justify-content:flex-end; flex-wrap:wrap; }

.faqItem{ padding: 10px 0; border-bottom: 1px solid rgba(0,0,77,.12); }
.faqItem:last-child{ border-bottom: 0; }

/* Quiz UI */
.quizQ{ padding: 12px; border: 1px solid rgba(0,0,77,.12); border-radius: 16px; margin-bottom: 10px; background: rgba(0,0,77,.02); }
.quizQTitle{ font-weight: 900; color: #00004D; margin-bottom: 8px; }
.quizOpts{ display:flex; flex-direction:column; gap:8px; }
.optRow{ display:grid; grid-template-columns: 22px 1fr; align-items:flex-start; column-gap:12px; padding: 10px 12px; border-radius: 14px; border: 1px solid rgba(0,0,77,.12); background:#fff; cursor:pointer; }
.optRow input[type="radio"]{ margin-top:3px; }
.optRow:hover{ border-color: rgba(213,0,50,.35); background: rgba(213,0,50,.06); }
.optRow input{ margin-top: 3px; }

/* ======= Topic builder (Admin) ======= */
.topicCard{
  border:1px solid rgba(0,0,77,.14);
  background:rgba(0,0,77,.03);
  border-radius:16px;
  padding:12px;
  margin:12px 0;
}
.topicHeader{
  display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;
}
.topicHeader b{color:#00004D}
.topicGrid{
  display:grid;grid-template-columns:1.2fr 1.8fr .6fr;gap:10px;margin-top:10px;
}
@media (max-width: 900px){.topicGrid{grid-template-columns:1fr}}
.quizBox{
  margin-top:10px;
  padding:12px;
  border-radius:14px;
  border:1px dashed rgba(213,0,50,.45);
  background:rgba(213,0,50,.07);
}
.qCard{
  border:1px solid rgba(213,0,50,.25);
  background:#fff;
  border-radius:14px;
  padding:10px;
  margin-top:10px;
}
.qRow{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width: 900px){.qRow{grid-template-columns:1fr}}
.smallBtnRow{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
/* ======= LMS Quiz list ======= */
.quizItem{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px;border-radius:14px;border:1px solid rgba(0,0,77,.12);
  background:rgba(0,0,77,.03);
  margin-top:10px;
}
.quizItem b{color:#00004D}


/* Header (updated) */
.headerInner{display:flex;align-items:center;justify-content:space-between;gap:18px}
.headerActions{display:flex;align-items:center;gap:10px}
.iconBtn{width:44px;height:44px;border-radius:14px;border:1px solid rgba(0,0,77,.14);background:#fff;display:none;align-items:center;justify-content:center;gap:4px;flex-direction:column}
.iconBtn span{display:block;width:18px;height:2px;background:rgba(13,35,77,.75);border-radius:99px}
.mobileMenu{background:#fff;border-top:1px solid rgba(0,0,77,.10);padding:14px 0}
.mobileMenuInner{display:grid;gap:10px}
.mobile-link{display:block;padding:10px 12px;border-radius:14px;background:rgba(0,0,77,.03);border:1px solid rgba(0,0,77,.08)}
@media (max-width: 980px){
  .nav-links{display:none}
  .iconBtn{display:flex}
}

/* ===== Admin layout comfort ===== */
.adminGrid{
  grid-template-columns: 1fr 1.45fr;
  gap: 18px;
  align-items: start;
}
@media (max-width: 1100px){
  .adminGrid{ grid-template-columns: 1fr; }
}
.adminEditor{
  position: sticky;
  top: 92px;
  max-height: calc(100vh - 120px);
  overflow: auto;
}
@media (max-width: 1100px){
  .adminEditor{
    position: static;
    max-height: none;
    overflow: visible;
  }
}
.adminEditor textarea{
  min-height: 160px;
}
#topicsWrap{
  min-height: 140px;
}

/* ===== Consultations UI ===== */
#consultList .panel{
  border: 1px solid rgba(0,0,77,.12);
}
#consultList textarea

/* LMS access badges */
.badgeSmall.badgeWarn{
  background: rgba(255, 140, 0, .15);
  border: 1px solid rgba(255, 140, 0, .35);
  color: #ff8c00;
}
.courseCard.locked{
  opacity: .95;
}
.courseCard.locked .courseCover{
  filter: grayscale(35%);
}


/* Comments */
.commentList{ display:flex; flex-direction:column; gap:10px; }
.commentItem{ background: var(--card); border:1px solid var(--border); border-radius: 14px; padding:12px; }
.commentMeta{ display:flex; gap:10px; flex-wrap:wrap; align-items:center; font-size: 12px; color: var(--muted); }
.commentAuthor{ font-weight: 700; color: var(--text); }
.commentRole{ font-size:11px; padding:2px 8px; border-radius:999px; background: var(--soft2); color: var(--text); border: 1px solid rgba(198,123,88,.35); }
.commentText{ margin-top:8px; white-space:pre-wrap; }
.commentActions{ display:flex; gap:8px; flex-wrap:wrap; margin-top:10px; }
.commentForm textarea{ width:100%; min-height:90px; resize:vertical; padding:12px; border-radius: 14px; border:1px solid var(--border); background: var(--card); color: var(--text); }

/* ---- Admin editor extras ---- */
.pill-ok{ background: rgba(0,170,90,.12); color: rgba(0,110,60,1); }
.topicBlock{ border:1px solid rgba(11,18,32,.12); border-radius:14px; padding:12px; background: rgba(255,255,255,.65); }
.qCard{ border:1px dashed rgba(11,18,32,.20); border-radius:14px; padding:12px; background: rgba(245,242,232,.35); margin-bottom:10px; }

/* ---- Modules accordion (Course page) ---- */
.acc{
  border: 1px solid rgba(0,0,77,.12);
  border-radius: 14px;
  background: rgba(0,0,77,.02);
  overflow:hidden;
}
.acc + .acc{ margin-top: 10px; }
.acc summary{
  list-style:none;
  cursor:pointer;
  padding: 10px 12px;
  background: rgba(0,0,77,.04);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.acc summary::-webkit-details-marker{ display:none; }
.accTitle{ display:flex; flex-direction:column; gap:2px; }
.accBody{ padding: 10px 10px 12px; display:flex; flex-direction:column; gap:8px; }

.topicItem.disabled{
  opacity: .55;
  cursor: not-allowed;
}

.dotHw{ width:10px; height:10px; border-radius:999px; background: rgba(152, 75, 255, .95); }

.richText{
  font-size: 14px;
  line-height: 1.6;
  color: rgba(13,42,87,.92);
}

/* ---------------- Comments ---------------- */
.cItem{ border:1px solid rgba(255,255,255,.08); border-radius:14px; padding:12px; margin-bottom:10px; background: rgba(255,255,255,.03); }
.cMeta{ display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.cText{ margin-top:6px; line-height:1.5; white-space:normal; }
.cReplies{ margin-top:10px; padding-left:12px; border-left:2px solid rgba(213,0,50,.35); display:flex; flex-direction:column; gap:8px; }
.cReply{ background: rgba(0,0,0,.14); border-radius:12px; padding:10px; border:1px solid rgba(255,255,255,.06); }


/* Avatar circle (first letter) */
.avatarCircle{
  width:42px;
  height:42px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  color: #fff;
  letter-spacing:0.5px;
  background: #ff8a00;
  border:1px solid rgba(255,255,255,0.18);
  flex:0 0 auto;
}

details.acc{
  border:1px solid rgba(255,255,255,0.12);
  border-radius:14px;
  background: rgba(0,0,0,0.08);
  padding:10px 12px;
}
details.acc > summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
details.acc > summary::-webkit-details-marker{ display:none; }
details.acc > summary:after{
  content:"▾";
  opacity:0.75;
  font-size:14px;
}
details.acc[open] > summary:after{ content:"▴"; }
.accTitle{ font-weight:700; }


.accessToolbar .select, .accessToolbar input{
  min-height: 44px;
}
.accessSearchResults{
  max-height: 420px;
}
@media (max-width: 700px){
  .accessToolbar{
    flex-direction: column;
  }
  .accessToolbar > *{
    width: 100%;
  }
}

/* Scrollable lists / tables for admin panels */
.scrollList{
  max-height: 280px;
  overflow: auto;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 12px;
  padding: 8px;
  background: rgba(0,0,0,0.08);
}
.scrollList-sm{ max-height: 220px; }

.scrollTable{
  max-height: 420px;
  overflow: auto;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 12px;
}
.scrollTable .table{ margin: 0; }


.optionCard{ padding:10px 12px; border-radius:14px; border:1px solid rgba(0,0,77,.12); background:#fff; cursor:pointer; }
.optionCard:hover{ border-color: rgba(0,0,77,.25); }
.pill{ display:inline-flex; align-items:center; padding:4px 10px; border-radius:999px; font-size:12px; font-weight:700; background: rgba(0,0,77,.08); border:1px solid rgba(0,0,77,.15); }


.presentationStage{margin-top:12px;border:1px solid rgba(15,23,42,.08);border-radius:18px;background:#f8fafc;padding:12px;display:flex;justify-content:center;align-items:center;min-height:240px;overflow:hidden}.presentationImage,.presentationCanvas{display:block;max-width:100%;height:auto;border-radius:12px;box-shadow:0 10px 30px rgba(15,23,42,.12)}.presentationControls{display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-top:12px}


.tableWrap{width:100%;overflow:auto;-webkit-overflow-scrolling:touch}
.materialsToolbar{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;align-items:flex-end}
.materialsActions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.materialsFilter{min-width:260px}
@media (max-width:700px){
  .materialsToolbar,.materialsActions{align-items:stretch}
  .materialsFilter,.materialsActions .btn{width:100%;min-width:0}
}
.presentationStage{margin-top:12px;border:1px solid rgba(15,23,42,.08);border-radius:18px;background:#f8fafc;padding:12px;display:flex;justify-content:center;align-items:center;min-height:240px;overflow:hidden}
.presentationImage,.presentationCanvas{display:block;max-width:100%;height:auto;border-radius:12px;box-shadow:0 10px 30px rgba(15,23,42,.12)}
.presentationControls{display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-top:12px}
@media (max-width:700px){
  .presentationStage{min-height:180px;padding:10px}
  .presentationControls > .btn{flex:1 1 140px}
  .presentationControls > .sub{width:100%;text-align:center;order:-1}
}


.avatarCircle.hasImage{
  padding:0;
  overflow:hidden;
  color:transparent;
}
.avatarCircle.hasImage img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}


.brand-mark{
  position: relative;
  background: var(--navy);
  color: #fff;
}
.brand-mark::after{
  content:"";
  position:absolute;
  right:7px;
  top:7px;
  width:10px;
  height:10px;
  border-radius:999px;
  background: var(--orange);
  box-shadow: 0 0 0 3px rgba(255,255,255,.18);
}
.topbar{
  background: linear-gradient(90deg, rgba(0,0,77,.06), rgba(213,0,50,.06));
  border-bottom: 1px solid rgba(0,0,77,.10);
}
.header{
  background: rgba(255,255,255,.94);
  border-bottom: 1px solid rgba(0,0,77,.10);
}
.nav-link.is-active{
  background: rgba(213,0,50,.10);
  color: var(--orange);
}
.nav.nav-pages .nav-pill{
  background: rgba(0,0,77,.05);
  border: 1px solid rgba(0,0,77,.10);
}
.hero-facts{
  display:grid;
  gap:12px;
  margin-top:16px;
}
.miniCard{
  background:#fff;
  border:1px solid var(--border);
  border-radius:18px;
  padding:14px 16px;
  box-shadow: 0 14px 28px rgba(0,0,77,.08);
}
.miniCard.highlight{
  background: linear-gradient(135deg, rgba(0,0,77,.95), rgba(33,33,120,.95));
  color:#fff;
}
.miniCard.highlight .miniCard-text,
.miniCard.highlight .miniCard-title{ color:#fff; }
.miniCard-title{ font-weight:800; color:var(--blue-2); margin-bottom:4px; }
.miniCard-text{ font-size:14px; color:var(--muted); }
.tall-card img{ min-height:420px; }
.feature-grid-6{ grid-template-columns: repeat(3, 1fr); }
.featureCard{ min-height: 100%; }
.story-shell{
  background:#fff;
  border:1px solid var(--border);
  border-radius:26px;
  padding:24px;
  box-shadow: var(--shadow);
}
.story-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:22px;
  align-items:start;
}
.story-copy p{ margin:0 0 14px; color:var(--muted); }
.story-visual img{ width:100%; height:100%; min-height:420px; object-fit:cover; }
.catalog-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:16px;
}
.catalog-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:22px;
  padding:20px;
  box-shadow: var(--shadow);
  display:flex;
  flex-direction:column;
  gap:12px;
}
.catalog-card .btn{ width:max-content; margin-top:auto; }
.catalog-meta{
  display:inline-flex;
  width:max-content;
  padding:7px 11px;
  border-radius:999px;
  background: rgba(213,0,50,.08);
  border:1px solid rgba(213,0,50,.16);
  color: var(--orange);
  font-size:12px;
  font-weight:700;
}
@media (max-width: 980px){
  .feature-grid-6{ grid-template-columns: repeat(2, 1fr); }
  .story-grid, .catalog-grid{ grid-template-columns: 1fr; }
}
@media (max-width: 520px){
  .feature-grid-6{ grid-template-columns: 1fr; }
  .story-shell{ padding:18px; }
}


.panel,
.card,
.courseCard,
.media-card,
.kpi,
.metric,
.miniCard,
.featureCard,
.topicCard,
.quizQ,
.optionCard,
.acc,
.mobile-menu,
.sidebar,
.dashboardCard{
  background-color: rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
}

.modalCard-reset{
  width:min(640px, 100%);
}
.resetStep[hidden]{ display:none !important; }
.resetMethodGrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:12px;
  margin-top:14px;
}
.resetMethodCard{
  width:100%;
  text-align:left;
  border:1px solid rgba(0,0,77,.14);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,249,255,.95));
  padding:16px;
  display:flex;
  flex-direction:column;
  gap:8px;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.resetMethodCard:hover{
  transform:translateY(-1px);
  border-color: rgba(213,0,50,.32);
  box-shadow:0 16px 32px rgba(0,0,77,.10);
}
.resetMethodBadge{
  display:inline-flex;
  align-self:flex-start;
  padding:4px 10px;
  border-radius:999px;
  background:rgba(0,0,77,.08);
  color:#00004D;
  font-size:12px;
  font-weight:800;
}
.resetMethodBadge-wa{
  background:rgba(213,0,50,.10);
  color:#D50032;
}
.resetStepHead{
  display:flex;
  align-items:flex-start;
  gap:12px;
}
.resetOtpGuide{
  margin-top:14px;
  display:grid;
  gap:10px;
}
.resetOtpGuideItem{
  display:grid;
  grid-template-columns: 34px 1fr;
  gap:12px;
  align-items:flex-start;
  padding:12px;
  border-radius:16px;
  border:1px solid rgba(0,0,77,.10);
  background:rgba(0,0,77,.03);
}
.resetOtpGuideNum{
  width:34px;
  height:34px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, #00004D, #D50032);
  color:#fff;
  font-weight:800;
}
@media (max-width: 700px){
  .resetMethodGrid{ grid-template-columns: 1fr; }
  .resetStepHead{ flex-direction:column; }
}
