/* Shared role-home styles consolidated from per-view inline CSS */

/* Full-bleed container margin */
.container-fluid.full-bleed { padding-left: 7px !important; padding-right: 7px !important; box-sizing: border-box; }

/* Stronger rules to override layout/container padding coming from parent layout */
body > .container.flex-grow-1 > .container-fluid.full-bleed,
.container.flex-grow-1 > .container-fluid.full-bleed,
.container > .container-fluid.full-bleed {
  padding-left: 7px !important;
  padding-right: 7px !important;
}
.assessment-icon-small { width:20px; height:20px; }
.assessment-icon-small .assessment-main-icon { font-size:0.9rem; line-height:20px; }

/* Additional specific selectors covering common layout nesting (main element or extra wrapper) */
.container.flex-grow-1 > main > .container-fluid.full-bleed,
.container.flex-grow-1 main .container-fluid.full-bleed,
.container > main > .container-fluid.full-bleed,
body .container > main .container-fluid.full-bleed {
  padding-left: 7px !important;
  padding-right: 7px !important;
}

/* When rendering RoleHomePages, the body will include a `role-home-page` class.
   Use this to increase specificity and ensure outer padding + left-menu margin wins. */
body.role-home-page .container-fluid.full-bleed { padding-left: 7px !important; padding-right: 7px !important; }
body.role-home-page .container.flex-grow-1 > .container-fluid.full-bleed { padding-left: 7px !important; padding-right: 7px !important; }
body.role-home-page .container.flex-grow-1 > main > .container-fluid.full-bleed { padding-left: 7px !important; padding-right: 7px !important; }

/* Left menu margin specific when within role-home pages */
body.role-home-page aside.custom-col-left > #leftMenu, body.role-home-page aside.custom-col-2-5 > #leftMenu { margin-left: 7px !important; }
/* Also support new mini-drawer wrapper (#gdLeftMenu) inserted by _LeftMenu partial */
body.role-home-page aside.custom-col-left > #gdLeftMenu,
body.role-home-page aside.custom-col-2-5 > #gdLeftMenu,
aside.custom-col-left > #gdLeftMenu,
aside.custom-col-2-5 > #gdLeftMenu {
  margin-left: 7px !important;
}

/* Ensure inner #leftMenu doesn't add extra margin when wrapped */
body.role-home-page aside.custom-col-left #leftMenu,
body.role-home-page aside.custom-col-2-5 #leftMenu {
  margin-left: 0 !important;
}

/* Right-column card header visibility - do not override gradient headers */
aside.custom-col-2-5 .card-header:not(.bg-gradient-coins):not(.bg-gradient-refer),
aside.custom-col-right .card-header:not(.bg-gradient-coins):not(.bg-gradient-refer) {
  background-color: #e9ecef !important; /* slightly darker than page background */
  color: #495057 !important;
  border-bottom: 1px solid #dee2e6 !important;
}

/* Left menu base rules */
#leftMenu .menu-title { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#leftMenu { padding-left: 0 !important; border-right: 1px solid rgba(0,0,0,0.08); }

/* Ensure the left menu content sits 7px from the very left of the page container */
aside.custom-col-left > #leftMenu {
  margin-left: 7px !important;
}
#leftMenu .sidebar-item {
  background: #F5F7FA !important;
  color: #333 !important;
  border-left: 4px solid #dee2e6 !important;
  font-weight: 600 !important;
  padding: 0.75rem 1rem !important;
  margin-bottom: 2px !important;
}
#leftMenu .sidebar-item:hover {
  background: #E9ECEF !important;
  color: #212529 !important;
  border-left-color: #adb5bd !important;
}
#leftMenu .sidebar-item.active {
  background: #E6F0FF !important;
  color: #0B5ED7 !important;
  border-left-color: #0B5ED7 !important;
  box-shadow: 0 3px 10px rgba(11,94,215,0.2) !important;
  font-weight: 600 !important;
}

/* Submenu rules */
.submenu-container { background-color: #F8F9FA !important; border-left: 3px solid #E9ECEF !important; margin-left: 8px !important; padding: 4px 0 !important; }
.submenu-container .list-group-item {
  background: #FAFBFC !important;
  color: #495057 !important;
  border-left: 3px solid #E9ECEF !important;
  padding: 0.65rem 1rem 0.65rem 2rem !important;
  font-size: 0.95rem !important;
  font-weight: 500 !important;
  margin-bottom: 1px !important;
}
.submenu-container .list-group-item:hover { background: #E9ECEF !important; color: #212529 !important; }
.submenu-container .list-group-item.active { background: #D0E5FF !important; color: #0d6efd !important; }

/* Level 4 */
.level4-container .list-group-item { background: #FFFFFF !important; color: #6c757d !important; }
.level4-container .list-group-item.active { background: #C7DDFF !important; color: #084298 !important; }

/* Chevron indicators */
#leftMenu .sidebar-item .chevron { color: #495057 !important; opacity: 1 !important; visibility: visible !important; display: inline-block !important; font-weight: 600 !important; font-size: 1.1em !important; }
#leftMenu .sidebar-item:hover .chevron { color: #212529 !important; }
#leftMenu .sidebar-item.active .chevron { color: #0B5ED7 !important; }
.submenu-container .chevron { color: #6c757d !important; opacity: 0.8 !important; }
.submenu-container .list-group-item.active .chevron { color: #0d6efd !important; opacity: 1 !important; }
.level4-container .chevron { color: #6c757d !important; opacity: 0.7 !important; }

/* Visual depth indicators kept minimal to avoid duplication */
#leftMenu .sidebar-item::before { content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 4px; height: 60%; background: #dee2e6; border-radius: 0 2px 2px 0; }
#leftMenu .sidebar-item.active::before { background: #0B5ED7; }

/* Layout gap rules to provide thin spacing between columns */
.row > aside:first-of-type { padding-right: 2px !important; }
.row > main { padding-left: 2px !important; padding-right: 2px !important; }
.row > aside:last-of-type { padding-left: 2px !important; /* keep right outer gap inside container */ padding-right: 7px !important; }

/* Ensure left menu and main content align to same top baseline when gd-leftmenu uses absolute toggle */
.gd-leftmenu { display: flex; align-items: flex-start; }
.gd-leftmenu .card { margin-top: 0; }
.row > aside:first-of-type .gd-leftmenu { padding-top: 0; }

/* Card and header styles for parent profile forms */
.card { border-radius: 4px; border: 1px solid #e9ecef; }
.pin-header { background-color: #e9ecef; color: #495057; }
.pin-header h3 { margin: 0; }
.pin-header h6 { margin: 0; color: #6c757d; }

/* Form focus / selection visual */
input:focus, select:focus, textarea:focus { background-color: #f8f9fa !important; outline: none !important; box-shadow: none !important; }
.btn:focus, .btn:active, .btn.active { background-color: #f8f9fa !important; color: #212529 !important; border-color: #dee2e6 !important; box-shadow: none !important; }

/* Small helper for injected content alignment */
#mainContent.gd-no-top-gap > *:first-child { margin-top: 0 !important; padding-top: 0 !important; }

/* Responsive column aliases kept in views; base widths preserved here if needed */
@media (min-width: 768px) {
  .custom-col-2-5 { flex: 0 0 20.8333333%; max-width: 20.8333333%; }
  .custom-col-7 { flex: 0 0 54.1666667%; max-width: 54.1666667%; }
}

/* Mobile Responsive Styles for Role Home Pages */
@media (max-width: 767px) {
  /* Stack all columns vertically on mobile */
  .custom-col-2-5, .custom-col-7,
  .custom-col-left, .custom-col-center, .custom-col-right {
    flex: 0 0 100% !important;
    max-width: 100% !important;
    margin-bottom: 1rem;
  }

  /* Full width main content on mobile */
  main.custom-col-7, main.custom-col-center {
    padding: 0 10px !important;
  }

  /* Reduce container padding on mobile */
  .container-fluid.full-bleed {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  body.role-home-page .container-fluid.full-bleed,
  body.role-home-page .container.flex-grow-1 > .container-fluid.full-bleed,
  body.role-home-page .container.flex-grow-1 > main > .container-fluid.full-bleed {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  /* Adjust column gaps on mobile */
  .row > aside:first-of-type,
  .row > main,
  .row > aside:last-of-type {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Dashboard header adjustments */
  .container-fluid.bg-white {
    padding: 0.75rem 10px !important;
  }

  .container-fluid.bg-white h5 {
    font-size: 1.1rem !important;
  }

  .container-fluid.bg-white .container {
    padding: 0 !important;
  }

  /* Card adjustments for mobile */
  .card {
    margin-bottom: 1rem;
    border-radius: 12px;
  }

  .card-header {
    padding: 0.75rem 1rem !important;
    font-size: 0.95rem !important;
  }

  .card-body {
    padding: 1rem !important;
  }

  /* Right column (Company News, etc.) full width on mobile */
  aside.custom-col-2-5:last-child,
  aside.custom-col-right {
    display: block !important;
    order: 3; /* Show after main content */
  }

  /* Left menu now stays fixed-width on mobile and does not change page layout state */

  /* Ensure row has no horizontal overflow */
  .row.gx-0 {
    margin-left: 0;
    margin-right: 0;
  }

  /* Adjust GD Coins and Refer sections for mobile */
  .coins-balance-badge {
    font-size: 1rem;
    padding: 0.4rem 0.8rem;
  }

  .coin-earn-box {
    padding: 0.6rem;
    margin-bottom: 0.5rem;
  }

  .coins-visual-wrapper {
    padding: 1.5rem 0.5rem;
  }

  /* Referral code box mobile adjustments */
  .referral-code-box {
    padding: 0.8rem;
  }

  .referral-code-display {
    font-size: 1.1rem !important;
  }
}

/* GD Coins and Refer section styles (shared for Student/Parent pages) */
.gd-coins-section .card { border-radius: 15px; }
.bg-gradient-coins { background: linear-gradient(135deg, #f093fb 0%, #f5576c 100%); }
/* Ensure gradient wins over generic card-header rules */
.card-header.bg-gradient-coins { background: linear-gradient(135deg, #f093fb 0%, #f5576c 100%) !important; color: #fff !important; }
.coin-icon-header { animation: coinRotate 3s ease-in-out infinite; }
@keyframes coinRotate { 0%,100%{ transform: rotateY(0deg); } 50% { transform: rotateY(180deg); } }
.coins-balance-badge {
  background: rgba(255,255,255,0.2);
  padding: 0.5rem 1rem;
  border-radius: 25px;
  backdrop-filter: blur(10px);
  border: 2px solid rgba(255,255,255,0.3);
  font-size: 1.1rem;
}
.coin-earn-box { padding: 0.75rem; background: #f8f9fa; border-radius: 8px; transition: all 0.3s ease; border: 1px solid #dee2e6; }
.coin-earn-box:hover { background: #e9ecef; transform: translateY(-3px); box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
.coin-icon-wrapper { width: 35px; height: 35px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.coin-icon-wrapper i { font-size: 1.1rem; }
.coins-visual-wrapper { position: relative; padding: 2rem 1rem; }
.coin-stack-animation { position: relative; display: inline-block; animation: float 3s ease-in-out infinite; }
@keyframes float { 0%,100% { transform: translateY(0px);} 50% { transform: translateY(-20px);} }
.coin-glow { position: absolute; bottom: -10px; left: 50%; transform: translateX(-50%); width: 80%; height: 20px; background: radial-gradient(ellipse, rgba(255,193,7,0.3) 0%, transparent 70%); border-radius: 50%; animation: glowPulse 3s ease-in-out infinite; }
@keyframes glowPulse { 0%,100% { opacity: 0.3; transform: translateX(-50%) scale(1);} 50% { opacity: 0.6; transform: translateX(-50%) scale(1.2);} }

.refer-section .card { border-radius: 15px; }
.bg-gradient-refer { background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); }
/* Ensure refer gradient wins over generic card-header rules */
.card-header.bg-gradient-refer { background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important; color: #fff !important; }
.referral-code-box { background: rgba(255,255,255,0.95); border: 2px dashed #667eea; border-radius: 12px; padding: 1rem; text-align: center; transition: all 0.3s ease; }
.referral-code-box:hover { border-color: #764ba2; box-shadow: 0 4px 12px rgba(102,126,234,0.3); }
.referral-code { font-size: 1.5rem; font-weight: 700; color: #667eea; letter-spacing: 2px; font-family: 'Courier New', monospace; }
.refer-method-box { padding: 1rem; background: #f8f9fa; border-radius: 12px; transition: all 0.3s ease; border: 2px solid transparent; cursor: pointer; text-align: center; }
.refer-method-box:hover { background: white; border-color: #667eea; transform: translateY(-5px); box-shadow: 0 5px 15px rgba(102,126,234,0.2); }
.refer-method-box-compact { padding: 0.5rem 0.25rem; }
.refer-icon-wrapper { width: 60px; height: 60px; border-radius: 50%; display:flex; align-items:center; justify-content:center; margin:0 auto 0.75rem; transition: all 0.3s ease; }
.refer-icon-compact { width: 40px; height: 40px; margin:0 auto 0.4rem; }
.refer-method-box:hover .refer-icon-wrapper { transform: scale(1.1) rotate(5deg); }
.refer-icon-wrapper i { font-size: 1.75rem; }
.refer-icon-compact i { font-size: 1.25rem; }
.refer-benefit-item { padding: 0.75rem; background: white; border-radius: 8px; border-left: 3px solid #667eea; margin-bottom: 0.5rem; transition: all 0.3s ease; }
.refer-benefit-item:hover { transform: translateX(5px); box-shadow: 0 2px 8px rgba(0,0,0,0.1); }

/* Assessment section styles (shared between StudentHome and ParentHome) */
.assessment-section {
  background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%);
  padding: 0;
  border-radius: 15px;
}
.assessment-section .card { border-radius: 15px; overflow: hidden; }
.assessment-icon-wrapper {
  width: 80px;
  height: 80px;
  background: linear-gradient(135deg, #0d6efd 0%, #0a58ca 100%);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 20px rgba(13,110,253,0.3);
  transition: all 0.3s ease;
  animation: rh-pulse 2s infinite;
}
@keyframes rh-pulse { 0%,100% { transform: scale(1);} 50% { transform: scale(1.05);} }
.assessment-icon-wrapper:hover { transform: scale(1.1) rotate(5deg); box-shadow: 0 12px 30px rgba(13,110,253,0.4); }
.assessment-main-icon { color: white; font-size: 1.5rem; line-height: 80px; }
.assessment-title { font-size: 1.75rem; font-weight: 700; color: #212529; }
.assessment-details .detail-box { padding: 0.75rem; background: white; border-radius: 8px; transition: all 0.3s ease; border-left: 3px solid #0d6efd; }
.assessment-details .detail-box:hover { transform: translateX(5px); box-shadow: 0 2px 8px rgba(0,0,0,0.1); }
.assessment-details .detail-box i { font-size: 1.25rem; vertical-align: middle; }
.assessment-details .detail-box strong { display: block; margin-bottom: 0.25rem; color: #212529; }
.assessment-instructions ul { list-style: none; padding-left: 1.5rem; }
.assessment-instructions ul li { position: relative; margin-bottom: 0.5rem; }
.assessment-instructions ul li::before { content: "✓"; position: absolute; left: -1.5rem; color: #198754; font-weight: bold; }


