:root{--navy:#1A3A5C;--navy-light:#2A5580;--navy-dark:#0F2740;--orange:#E8722A;--orange-dark:#C25A1E;--green:#3DAA35;--green-light:#E8F5E7;--error:#DC2626;--warning:#F59E0B;--gray-50:#F9FAFB;--gray-100:#F0F2F5;--gray-200:#E5E7EB;--gray-300:#D1D5DB;--gray-400:#9CA3AF;--gray-500:#6B7280;--gray-600:#4B5563;--gray-700:#374151;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--shadow-sm:0 1px 3px rgba(0,0,0,.08);--shadow-md:0 4px 12px rgba(0,0,0,.1)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',-apple-system,sans-serif;color:var(--gray-700);line-height:1.6;background:#fff}
a{text-decoration:none;color:inherit}img{max-width:100%;height:auto}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:var(--radius-sm);font-weight:600;font-size:14px;border:none;cursor:pointer;transition:all .2s}
.btn-sm{padding:6px 14px;font-size:13px}.btn-lg{padding:14px 28px;font-size:15px}
.btn-primary{background:var(--orange);color:#fff}.btn-primary:hover{background:var(--orange-dark)}
.btn-outline{background:transparent;border:2px solid var(--navy);color:var(--navy)}.btn-outline:hover{background:var(--navy);color:#fff}
.btn-ghost{background:transparent;color:var(--navy)}.btn-ghost:hover{background:var(--gray-100)}
.btn-google{display:flex;align-items:center;gap:10px;width:100%;padding:12px;background:#fff;border:1px solid var(--gray-300);border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;justify-content:center}
.form-group{margin-bottom:14px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--gray-600);margin-bottom:4px}
.form-input{width:100%;padding:10px 14px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:14px;outline:none;transition:border-color .2s}.form-input:focus{border-color:var(--navy)}
select.form-input{appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%239CA3AF'/%3E%3C/svg%3E") no-repeat right 12px center;padding-right:32px}
.contact-strip{background:var(--navy-dark);color:#fff;font-size:12px;padding:6px 0}
.contact-strip__inner{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}
.contact-strip__phones{display:flex;gap:16px}.contact-strip__phones a{color:#fff;display:flex;align-items:center;gap:4px}
.contact-strip__social{display:flex;gap:12px}.contact-strip__social a{color:#fff;font-size:14px}
.header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--gray-200)}
.header__inner{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;align-items:center;height:64px}
.header__logo img{height:42px}.header__nav{display:flex;gap:24px;margin-left:40px}
.header__link{font-size:14px;font-weight:600;color:var(--gray-600);padding:8px 0;border-bottom:2px solid transparent}
.header__link:hover,.header__link.active{color:var(--navy);border-bottom-color:var(--orange)}
/* mega-menu dropdown */
.hnav-item{position:relative;display:flex;align-items:center}
.hnav-caret{font-size:9px;color:var(--gray-400)}
.hnav-drop{position:absolute;top:100%;left:0;min-width:220px;background:#fff;border:1px solid var(--gray-200);border-radius:10px;box-shadow:0 12px 32px rgba(15,23,42,.16);padding:6px;display:none;flex-direction:column;gap:1px;z-index:60}
.hnav-item:hover .hnav-drop{display:flex}
.hnav-drop__link{font-size:13.5px;font-weight:500;color:var(--gray-700);padding:8px 12px;border-radius:7px;white-space:nowrap}
.hnav-drop__link:hover{background:var(--gray-50);color:var(--navy)}
.header__actions{margin-left:auto;display:flex;align-items:center;gap:12px}.header__cart{font-size:20px}
.header__hamburger{display:none;background:none;border:none;font-size:24px;cursor:pointer;margin-left:auto}
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200}
.drawer{position:fixed;top:0;right:0;width:280px;height:100%;background:#fff;z-index:201;padding:20px;overflow-y:auto}
.drawer__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.drawer__logo{height:36px}
.drawer__close{background:none;border:none;font-size:24px;cursor:pointer}
.drawer__nav{display:flex;flex-direction:column;gap:4px}.drawer__nav a{padding:12px 16px;border-radius:var(--radius-sm);font-weight:600;color:var(--gray-700)}.drawer__nav a:hover{background:var(--gray-100)}
.hero{background:linear-gradient(135deg,var(--navy),var(--navy-light));color:#fff;padding:80px 20px;text-align:center}
.hero__inner{max-width:800px;margin:0 auto}.hero__title{font-size:40px;font-weight:800;line-height:1.2;margin-bottom:16px}
.hero__title .highlight{color:var(--orange)}.hero__subtitle{font-size:18px;opacity:.9;margin-bottom:32px}
.hero__ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.hero__stats{display:flex;gap:40px;justify-content:center;margin-top:48px}
.hero__stats .stat{text-align:center}.hero__stats .stat strong{display:block;font-size:28px}.hero__stats .stat span{font-size:13px;opacity:.8}
.section{padding:60px 20px}.section--gray{background:var(--gray-50)}
.section__inner{max-width:1200px;margin:0 auto}.section__title{font-size:28px;font-weight:700;color:var(--navy);text-align:center;margin-bottom:32px}
.page-hero{background:var(--navy);color:#fff;padding:40px 20px;text-align:center}.page-hero h1{font-size:32px;font-weight:700}
.course-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.course-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--gray-200);overflow:hidden;transition:all .2s;position:relative;display:block}
.course-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.course-card__badge{position:absolute;top:12px;left:12px;background:var(--orange);color:#fff;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;z-index:2}
.course-card__image{height:160px;background:linear-gradient(135deg,var(--navy),var(--navy-light));display:flex;align-items:center;justify-content:center;overflow:hidden}
.course-card__body{padding:16px}.course-card__level{font-size:11px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.5px}
.course-card__title{font-size:15px;font-weight:700;color:var(--navy);margin:4px 0;line-height:1.3}
.course-card__faculty{font-size:13px;color:var(--gray-500);margin-bottom:8px}
.course-card__pricing{display:flex;align-items:center;gap:8px}
.course-card__mrp{font-size:14px;color:var(--gray-400);text-decoration:line-through}
.course-card__price{font-size:20px;font-weight:800;color:var(--navy)}
.faculty-grid{display:flex;gap:24px;justify-content:center;flex-wrap:wrap}
.faculty-card{text-align:center;width:140px}
.faculty-card__avatar{width:80px;height:80px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;margin:0 auto 12px}
.faculty-card h4{font-size:14px;color:var(--navy)}.faculty-card p{font-size:12px;color:var(--gray-500)}
.mode-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.mode-card{text-align:center;padding:32px 20px;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--gray-200)}
.mode-card__icon{font-size:36px;margin-bottom:12px}.mode-card h3{font-size:18px;color:var(--navy);margin-bottom:8px}.mode-card p{font-size:14px;color:var(--gray-500)}
.cta-banner{background:var(--orange);color:#fff;padding:60px 20px;text-align:center}.cta-banner__inner{max-width:600px;margin:0 auto}
.cta-banner h2{font-size:28px;margin-bottom:12px}.cta-banner p{margin-bottom:20px}.cta-banner p a{color:#fff;text-decoration:underline}
.footer{background:var(--navy-dark);color:#fff;padding:48px 20px 24px}
.footer__inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}
.footer__logo{height:36px;margin-bottom:12px}.footer__col h4{font-size:15px;margin-bottom:12px;color:var(--orange)}
.footer__col a{display:block;font-size:14px;color:rgba(255,255,255,.7);margin-bottom:8px}.footer__col a:hover{color:#fff}
.footer__col p{font-size:13px;color:rgba(255,255,255,.7);line-height:1.6}
.footer__phones a{display:block;font-size:14px;color:rgba(255,255,255,.7);margin-top:4px}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:32px;padding-top:16px;text-align:center;font-size:13px;color:rgba(255,255,255,.5)}.footer__bottom a{color:var(--orange)}
.floating-btns{position:fixed;bottom:20px;right:12px;display:flex;flex-direction:column;gap:8px;z-index:90}
.float-btn{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:var(--shadow-md)}
.float-btn--call{background:var(--navy)}.float-btn--whatsapp{background:#25D366}.float-btn--telegram{background:#0088CC}
.filter-bar{margin-bottom:24px}.filter-bar__modes{display:flex;gap:8px;flex-wrap:wrap}
.mode-btn{padding:8px 20px;border-radius:20px;border:2px solid var(--gray-200);background:#fff;font-size:14px;font-weight:600;cursor:pointer}
.mode-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.product-detail{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.product-detail__image{width:100%;border-radius:var(--radius-lg)}
.product-detail__title{font-size:24px;font-weight:700;color:var(--navy);margin:8px 0}
.product-detail__faculty{font-size:15px;color:var(--gray-500);margin-bottom:16px}
.product-detail__pricing{display:flex;align-items:center;gap:12px;margin-top:16px}
.product-detail__mrp{font-size:18px;color:var(--gray-400);text-decoration:line-through}
.product-detail__price{font-size:32px;font-weight:800;color:var(--navy)}.product-detail__tax{font-size:12px;color:var(--gray-400)}
.inclusions-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:16px}
.inclusion-item{font-size:14px;padding:8px 12px;background:var(--gray-50);border-radius:var(--radius-sm)}
.detail-tiles{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:20px}
.detail-tile{padding:12px;background:var(--gray-50);border-radius:var(--radius-sm)}
.detail-tile strong{display:block;font-size:12px;color:var(--gray-500);text-transform:uppercase}.detail-tile span{font-size:14px;font-weight:600;color:var(--navy)}
.auth-page{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}
.auth-page__brand{background:linear-gradient(135deg,var(--navy),var(--navy-light));color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px}
.auth-page__logo{height:60px;margin-bottom:24px}.auth-page__brand h2{font-size:28px}
.auth-page__form{display:flex;flex-direction:column;justify-content:center;padding:40px;max-width:420px;margin:0 auto;width:100%}
.auth-tabs{display:flex;margin-bottom:24px}.auth-tab{flex:1;padding:12px;text-align:center;font-weight:700;font-size:15px;border:none;background:var(--gray-100);color:var(--gray-500);cursor:pointer}
.auth-tab:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.auth-tab:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.auth-tab.active{background:var(--navy);color:#fff}
.divider{text-align:center;margin:16px 0;position:relative}.divider::before{content:'';position:absolute;left:0;top:50%;width:100%;height:1px;background:var(--gray-200)}.divider span{background:#fff;padding:0 12px;position:relative;font-size:13px;color:var(--gray-400)}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.kpi-card{background:#fff;border-radius:var(--radius-md);padding:16px 20px;border:1px solid var(--gray-200)}
.kpi-card__label{font-size:12px;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.kpi-card__value{font-size:24px;font-weight:700;color:var(--navy)}
.status{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}
.status--confirmed,.status--success{background:#E8F5E7;color:#16a34a}.status--pending,.status--warning{background:#FEF3C7;color:#D97706}.status--processing,.status--info{background:#DBEAFE;color:#2563EB}
.status--cancelled,.status--danger{background:#FEE2E2;color:#DC2626}.status--refunded,.status--neutral{background:var(--gray-100,#F3F4F6);color:var(--gray-500,#6B7280)}
.data-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--gray-200);overflow:hidden}
.data-card__title{padding:16px 20px;font-size:16px;font-weight:700;color:var(--navy);border-bottom:1px solid var(--gray-100)}
.data-card__filters{display:flex;gap:8px;padding:16px 20px;flex-wrap:wrap}
.filter-input,.filter-select{padding:8px 14px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);font-size:13px;outline:none}
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:14px}
th{text-align:left;padding:10px 16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500);border-bottom:1px solid var(--gray-200);background:var(--gray-50)}
td{padding:12px 16px;border-bottom:1px solid var(--gray-100)}
.page__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page__header h1{font-size:24px;font-weight:700;color:var(--navy)}
.admin-layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--navy-dark);color:#fff;padding:20px 0;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50}
.sidebar__logo{padding:0 20px 20px;display:flex;align-items:center;gap:8px}.sidebar__logo img{height:36px}.sidebar__logo span{font-size:11px;background:var(--orange);padding:2px 8px;border-radius:4px;font-weight:700}
.sidebar__nav{flex:1;overflow-y:auto}.sidebar__section-label{padding:16px 20px 6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.4)}
.sidebar__link{display:flex;align-items:center;gap:10px;padding:10px 20px;color:rgba(255,255,255,.7);font-size:14px;font-weight:500;transition:all .15s}
.sidebar__link:hover,.sidebar__link.active{background:rgba(255,255,255,.08);color:#fff}
.sidebar__user{padding:16px 20px;border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:10px}
.sidebar__avatar{width:36px;height:36px;border-radius:50%;background:var(--orange);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
.sidebar__user-name{font-size:13px;font-weight:600}.sidebar__user-role{font-size:11px;color:rgba(255,255,255,.5)}
/* collapsible nav tree */
.sidebar__link--top{font-weight:600}
.sidebar__group-header{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 20px;background:none;border:0;color:rgba(255,255,255,.7);font-size:14px;font-weight:600;cursor:pointer;text-align:left;font-family:inherit;transition:all .15s}
.sidebar__group-header:hover{background:rgba(255,255,255,.08);color:#fff}
.sidebar__group-label{display:flex;align-items:center;gap:10px}
.sidebar__chevron{font-size:11px;opacity:.55;transition:transform .15s}
.sidebar__group-header.open .sidebar__chevron{transform:rotate(90deg)}
.sidebar__group-items .sidebar__link{padding-left:46px;font-weight:500;font-size:13.5px}
.sidebar__group-header--sub{padding:9px 20px 9px 46px;font-size:13.5px;font-weight:500}
.sidebar__group-items--sub .sidebar__link{padding-left:64px;font-size:13px}
/* toasts */
.toast-host{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:10px;z-index:1000}
.toast{display:flex;align-items:center;gap:10px;min-width:240px;max-width:380px;padding:12px 16px;border-radius:8px;font-size:14px;font-weight:500;color:#fff;cursor:pointer;box-shadow:0 8px 24px rgba(0,0,0,.18);animation:toast-in .25s ease}
.toast__icon{width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.toast--success{background:#16a34a}.toast--error{background:#DC2626}.toast--info{background:#2563EB}.toast--warning{background:#D97706}
@keyframes toast-in{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
/* modal */
.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.5);display:flex;align-items:flex-start;justify-content:center;padding:60px 16px;z-index:900;animation:fade-in .15s ease}
.modal-box{background:#fff;border-radius:var(--radius-lg,12px);width:100%;max-width:560px;box-shadow:0 24px 64px rgba(0,0,0,.25);animation:modal-in .2s ease;max-height:85vh;display:flex;flex-direction:column}
.modal-box--sm{max-width:420px}.modal-box--lg{max-width:820px}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--gray-100)}
.modal-head h3{font-size:16px;font-weight:700;color:var(--navy)}
.modal-close{background:none;border:0;font-size:16px;color:var(--gray-400);cursor:pointer;line-height:1}
.modal-close:hover{color:var(--navy)}
.modal-body{padding:20px;overflow-y:auto}
.modal-foot{padding:14px 20px;border-top:1px solid var(--gray-100);display:flex;gap:8px;justify-content:flex-end}
@keyframes fade-in{from{opacity:0}to{opacity:1}}
@keyframes modal-in{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
.main-content{margin-left:240px;flex:1;background:var(--gray-50);min-height:100vh}
/* admin top bar + notification bell */
.admin-topbar{position:sticky;top:0;z-index:40;display:flex;justify-content:flex-end;align-items:center;height:52px;padding:0 24px;background:#fff;border-bottom:1px solid var(--gray-200)}
.notif{position:relative}
.notif__bell{position:relative;background:none;border:0;font-size:20px;cursor:pointer;line-height:1;padding:6px;border-radius:8px}
.notif__bell:hover{background:var(--gray-100)}
.notif__badge{position:absolute;top:-2px;right:-2px;background:var(--error,#DC2626);color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.notif__backdrop{position:fixed;inset:0;z-index:45}
.notif__panel{position:absolute;right:0;top:46px;width:360px;max-width:90vw;background:#fff;border:1px solid var(--gray-200);border-radius:10px;box-shadow:0 16px 48px rgba(0,0,0,.16);z-index:46;animation:modal-in .15s ease;overflow:hidden}
.notif__head{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--gray-100);font-size:14px}
.notif__head a{font-size:12px;color:var(--orange)}
.notif__list{max-height:380px;overflow-y:auto}
.notif__empty{padding:28px 16px;text-align:center;color:var(--gray-400);font-size:13px}
.notif__item{display:flex;gap:10px;padding:11px 16px;border-bottom:1px solid var(--gray-50);cursor:pointer}
.notif__item:hover{background:var(--gray-50)}
.notif__dot{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.notif__dot--success{background:#E8F5E7}.notif__dot--warning{background:#FEF3C7}.notif__dot--error{background:#FEE2E2}.notif__dot--info{background:#DBEAFE}
.notif__title{font-size:13px;font-weight:600;color:var(--navy)}
.notif__msg{font-size:12px;color:var(--gray-500);margin-top:1px}
.notif__time{font-size:11px;color:var(--gray-400);margin-top:3px}
/* skeleton + new-row highlight */
.skel{background:linear-gradient(90deg,#eef1f5 25%,#f6f8fa 37%,#eef1f5 63%);background-size:400% 100%;animation:skel 1.2s ease infinite;border-radius:6px;display:inline-block}
@keyframes skel{0%{background-position:100% 0}100%{background-position:0 0}}
@keyframes pulse-row{0%{background:#FFF7ED}100%{background:transparent}}
.row-new{animation:pulse-row 2.6s ease}
.live-dot{font-size:11px;font-weight:700;color:var(--green,#16a34a);display:inline-flex;align-items:center;gap:4px}
.live-dot::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor;animation:livepulse 1.6s ease infinite}
@keyframes livepulse{0%,100%{opacity:1}50%{opacity:.3}}
.page{padding:24px}
@media(max-width:768px){.header__nav,.header__actions{display:none}.header__hamburger{display:block}.hero__title{font-size:28px}.hero__stats{gap:20px}.hero__stats .stat strong{font-size:20px}.course-grid{grid-template-columns:1fr 1fr}.mode-grid{grid-template-columns:1fr}.footer__inner{grid-template-columns:1fr}.product-detail{grid-template-columns:1fr}.auth-page{grid-template-columns:1fr}.auth-page__brand{display:none}.kpi-grid{grid-template-columns:repeat(2,1fr)}.sidebar{display:none}.main-content{margin-left:0}}
@media(max-width:480px){.course-grid{grid-template-columns:1fr}.hero{padding:48px 16px}.hero__ctas{flex-direction:column}}

/* ===== Phase 1: Home page + shell polish ===== */
.contact-strip__social a{display:inline-flex;align-items:center}
.contact-strip__phones a{display:inline-flex;align-items:center;gap:4px}
.contact-strip__phones>svg{flex-shrink:0}
.float-btn svg{width:22px;height:22px;fill:#fff;display:block}
.btn-green{background:var(--green);color:#fff}.btn-green:hover{background:#2d8a27}

/* Hero course buttons */
.hero__course-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:8px}
.hero__course-btn{padding:14px 28px;border-radius:var(--radius-md);font-weight:700;font-size:15px;min-width:200px;text-align:center;transition:transform .2s;color:#fff;display:inline-block}
.hero__course-btn:hover{transform:translateY(-2px)}
.hero__course-btn--foundation{background:linear-gradient(135deg,var(--orange),#d4611e)}
.hero__course-btn--inter{background:linear-gradient(135deg,var(--green),#2d8a27)}
.hero__course-btn--books{background:rgba(255,255,255,.12);border:2px solid rgba(255,255,255,.35)}
.hero__note{display:block;margin-top:8px;font-size:13px;opacity:.65}

/* Section label/subtitle */
.section__label{display:inline-block;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--orange);margin-bottom:8px}
.section__subtitle{font-size:16px;color:var(--gray-500);max-width:640px;margin:0 auto;text-align:center}
.section__header{text-align:center;margin-bottom:32px}

/* Highlights numbers */
.highlights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;text-align:center}
.highlight-item__number{font-size:36px;font-weight:800;color:var(--orange)}
.highlight-item__label{font-size:14px;color:var(--gray-600)}

/* Testimonials */
.testimonials-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.testimonial-mini{padding:20px;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--gray-200)}
.testimonial-mini__text{font-size:14px;color:var(--gray-600);font-style:italic;line-height:1.6;margin-bottom:14px}
.testimonial-mini__author{display:flex;align-items:center;gap:10px}
.testimonial-mini__avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff}
.testimonial-mini__name{font-size:13px;font-weight:600;color:var(--navy)}
.testimonial-mini__score{font-size:11px;color:var(--gray-500)}

/* Blog tiles */
.blog-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.blog-tile{border-radius:var(--radius-lg);overflow:hidden;background:#fff;border:1px solid var(--gray-200);transition:all .2s}
.blog-tile:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.blog-tile__image{height:110px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:30px}
.blog-tile__body{padding:14px}
.blog-tile__title{font-size:13px;font-weight:600;color:var(--navy);line-height:1.4;margin-bottom:6px}
.blog-tile__date{font-size:11px;color:var(--gray-400)}

/* Map */
.map-container{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);height:300px}
.map-container iframe{width:100%;height:100%;border:none;display:block}

/* Enquiry modal */
.enquiry-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}
.enquiry-modal{background:#fff;border-radius:var(--radius-lg);width:100%;max-width:420px;overflow:hidden;box-shadow:var(--shadow-md);position:relative}
.enquiry-modal__header{background:linear-gradient(135deg,var(--navy-dark),var(--navy));color:#fff;padding:24px 28px 20px;text-align:center}
.enquiry-modal__header h3{font-size:22px;margin-bottom:4px}.enquiry-modal__header p{font-size:14px;opacity:.75}
.enquiry-modal__close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.15);border:none;color:#fff;font-size:18px;cursor:pointer}
.enquiry-modal__body{padding:24px 28px 28px}

/* FOMO toast */
.fomo-toast{position:fixed;bottom:90px;left:24px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:14px 18px;display:flex;align-items:center;gap:12px;z-index:90;max-width:340px;border-left:4px solid var(--green)}
.fomo-toast__text{font-size:12px;color:var(--gray-600);line-height:1.4}.fomo-toast__text strong{color:var(--navy)}
.fomo-toast__time{font-size:10px;color:var(--gray-400);margin-top:2px}
.fomo-toast__close{position:absolute;top:6px;right:8px;background:none;border:none;color:var(--gray-400);font-size:14px;cursor:pointer}

@media(max-width:768px){
  .testimonials-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr 1fr}
  .highlights-grid{gap:12px}.highlight-item__number{font-size:26px}
  .hero__course-btn{min-width:unset;width:100%}
  .fomo-toast{left:12px;bottom:80px;max-width:260px}
}
@media(max-width:480px){.blog-grid{grid-template-columns:1fr}}

/* ===== Phase 2: Courses listing ===== */
.course-modes{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-width:680px;margin:0 auto 24px}
.course-mode-btn{display:block;padding:16px 20px;border-radius:var(--radius-md);font-weight:700;font-size:15px;text-align:center;cursor:pointer;border:none;color:#fff;transition:transform .2s,box-shadow .2s}
.course-mode-btn small{display:block;font-weight:400;font-size:11px;opacity:.85;margin-top:4px}
.course-mode-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.course-mode-btn.active{outline:3px solid rgba(0,0,0,.18);outline-offset:2px}
.course-mode-btn--regular{background:linear-gradient(135deg,var(--orange),#d4611e)}
.course-mode-btn--fastrack{background:linear-gradient(135deg,var(--green),#2d8a27)}
.course-mode-btn--combo{background:linear-gradient(135deg,#6366f1,#8b5cf6)}
.course-mode-btn--f2f{background:linear-gradient(135deg,#ec4899,#f472b6)}

.filter-bar2{display:flex;gap:10px;align-items:center;flex-wrap:wrap;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:12px;margin-bottom:24px}
.filter-search{flex:1;min-width:200px;display:flex;align-items:center;gap:8px;background:var(--gray-50);border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);padding:8px 12px}
.filter-search:focus-within{border-color:var(--navy)}
.filter-search svg{flex-shrink:0;color:var(--gray-400)}
.filter-search input{border:none;background:none;outline:none;width:100%;font-size:14px}
.filter-bar2 .filter-select{min-width:150px}

/* Card extras */
.course-card__image{font-size:42px;color:rgba(255,255,255,.45)}
.course-card__tags{display:flex;flex-wrap:wrap;gap:4px;margin:8px 0}
.course-card__tags span{font-size:10px;padding:2px 8px;background:var(--gray-100);border-radius:20px;color:var(--gray-600)}
.course-card__footer{display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid var(--gray-100);margin-top:8px}
.course-card__discount{font-size:11px;font-weight:700;color:var(--green);background:var(--green-light);padding:2px 8px;border-radius:20px}

/* Pagination */
.pagination{display:flex;justify-content:center;gap:6px;margin-top:32px;flex-wrap:wrap}
.pg-btn{min-width:38px;height:38px;padding:0 12px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);background:#fff;font-size:13px;font-weight:600;color:var(--gray-600);cursor:pointer}
.pg-btn:hover:not(:disabled){border-color:var(--navy);color:var(--navy)}
.pg-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.pg-btn:disabled{opacity:.4;cursor:not-allowed}

@media(max-width:768px){.course-modes{grid-template-columns:1fr 1fr}.filter-bar2{flex-direction:column;align-items:stretch}.filter-bar2 .filter-select,.filter-search{min-width:unset;width:100%}}
@media(max-width:480px){.course-modes{grid-template-columns:1fr}}

/* ===== Phase 3: Course Detail ===== */
.pd{max-width:760px;margin:0 auto;padding:8px 20px 48px}
.pd-img{aspect-ratio:16/9;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--navy),var(--navy-light));display:flex;align-items:center;justify-content:center;position:relative;margin-bottom:12px;font-size:72px;color:rgba(255,255,255,.25)}
.pd-img__badge{position:absolute;top:12px;left:12px;background:var(--orange);color:#fff;font-size:11px;font-weight:700;padding:4px 12px;border-radius:20px;text-transform:uppercase}
.pd-title{font-size:22px;font-weight:800;color:var(--navy);line-height:1.3;margin-bottom:6px}
.pd-subtitle{font-size:14px;color:var(--gray-500);margin-bottom:16px}
.tabs{display:flex;gap:0;border-bottom:2px solid var(--gray-200);margin-bottom:18px;overflow-x:auto}
.tab-btn{padding:10px 16px;background:none;border:none;font-size:14px;font-weight:600;color:var(--gray-500);cursor:pointer;white-space:nowrap;position:relative}
.tab-btn.active{color:var(--navy)}
.tab-btn.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:3px;background:var(--orange);border-radius:2px 2px 0 0}
.inclusions h4{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:10px}
.attributes{margin:16px 0 4px}.attributes label{display:block;font-size:13px;font-weight:600;color:var(--gray-600);margin-bottom:6px}
.detail-tile--full{grid-column:1/-1;text-align:left;background:var(--navy);color:#fff;padding:16px}
.detail-tile--full h4{font-size:14px;font-weight:700;margin-bottom:8px;color:var(--orange)}
.detail-tile--full p{font-size:13px;line-height:1.7;color:rgba(255,255,255,.85)}
.detail-tile--full .contact-line{margin-top:12px;font-size:13px;font-weight:700;color:var(--orange)}
.faculty-tab{display:flex;gap:16px;align-items:flex-start;padding:20px;background:var(--gray-50);border-radius:var(--radius-lg)}
.faculty-tab__avatar{width:70px;height:70px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;flex-shrink:0}
.faculty-tab__name{font-size:20px;font-weight:800;color:var(--navy)}
.faculty-tab__role{font-size:12px;color:var(--orange);font-weight:600;margin-bottom:8px}
.faculty-tab__bio{font-size:13px;color:var(--gray-600);line-height:1.6}
.faculty-tab__stats{display:flex;gap:20px;margin-top:12px;font-size:12px;color:var(--gray-500)}
.faculty-tab__stats strong{color:var(--navy)}
.added-msg{background:var(--green-light);color:var(--green);text-align:center;padding:10px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;margin-top:12px}
@media(max-width:480px){.faculty-tab{flex-direction:column}.detail-tiles{grid-template-columns:1fr}}

/* ===== Phase 4: Cart + Checkout ===== */
.header__cart{position:relative}
.header__cart-badge{position:absolute;top:-4px;right:-8px;background:var(--orange);color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;padding:0 4px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;line-height:1}
.cart-page{padding:20px 20px 48px}
.cart-page__title{font-size:28px;font-weight:800;color:var(--navy);margin-bottom:2px}
.cart-page__count{font-size:14px;color:var(--gray-500);display:block;margin-bottom:20px}
.cart-empty,.cart-success{text-align:center;padding:48px 20px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);color:var(--gray-600)}
.cart-success h2{font-size:24px;color:var(--navy);margin:8px 0}
.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start}
.cart-item{display:flex;gap:14px;padding:16px;border:1px solid var(--gray-200);border-radius:var(--radius-lg);margin-bottom:10px;background:#fff;transition:box-shadow .2s}
.cart-item:hover{box-shadow:var(--shadow-md)}
.cart-item__img{width:100px;height:75px;border-radius:var(--radius-md);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:32px;background:linear-gradient(135deg,var(--navy),var(--navy-light));color:rgba(255,255,255,.5)}
.cart-item__body{flex:1;min-width:0}
.cart-item__level{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--orange)}
.cart-item__title{display:block;font-size:15px;font-weight:700;color:var(--navy);line-height:1.3;margin:2px 0 4px}
.cart-item__faculty{font-size:12px;color:var(--gray-500)}
.cart-item__price{display:flex;align-items:baseline;gap:8px;margin-top:6px}
.cart-item__price-now{font-size:18px;font-weight:800;color:var(--navy)}
.cart-item__price-was{font-size:13px;color:var(--gray-400);text-decoration:line-through}
.cart-item__remove{background:none;border:none;color:var(--gray-400);cursor:pointer;padding:4px;align-self:flex-start;font-size:16px}
.cart-item__remove:hover{color:var(--error)}
.coupon-box{border:2px dashed var(--gray-200);border-radius:var(--radius-lg);padding:16px;margin-top:14px;background:var(--gray-50)}
.coupon-box h4{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:10px}
.coupon-input{display:flex;gap:8px}
.coupon-input input{flex:1;padding:10px 12px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:14px;text-transform:uppercase;outline:none}
.coupon-input input:focus{border-color:var(--navy)}
.order-summary{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;position:sticky;top:80px}
.order-summary__header{background:var(--navy);color:#fff;padding:16px 20px}
.order-summary__header h3{font-size:18px}
.order-summary__body{padding:20px}
.summary-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px}
.summary-row .label{color:var(--gray-600)}.summary-row .value{font-weight:600;color:var(--gray-800)}
.summary-row--green .value{color:var(--green)}
.summary-row--total{border-top:2px solid var(--gray-200);margin-top:8px;padding-top:12px}
.summary-row--total .label{font-size:16px;font-weight:700;color:var(--navy)}
.summary-row--total .value{font-size:22px;font-weight:800;color:var(--navy)}
.summary-savings{background:var(--green-light);color:var(--green);text-align:center;padding:10px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;margin:12px 0}
.summary-secure{text-align:center;font-size:11px;color:var(--gray-500);margin-top:12px}
.summary-payments{display:flex;justify-content:center;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--gray-100);flex-wrap:wrap}
.summary-payments span{font-size:11px;font-weight:600;color:var(--gray-400);background:var(--gray-100);padding:3px 8px;border-radius:var(--radius-sm)}
@media(max-width:768px){.cart-layout{grid-template-columns:1fr}.order-summary{position:static}}

/* ===== Phase 9: Checkout ===== */
.checkout-steps{display:flex;align-items:center;gap:8px;margin:8px 0 22px}
.checkout-step{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--gray-400)}
.checkout-step.active{color:var(--navy)}.checkout-step.done{color:var(--green)}
.checkout-step__num{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;background:var(--gray-100);color:var(--gray-400);flex-shrink:0}
.checkout-step.active .checkout-step__num{background:var(--navy);color:#fff}
.checkout-step.done .checkout-step__num{background:var(--green);color:#fff}
.checkout-step__bar{flex:1;height:2px;background:var(--gray-200);min-width:24px}
.pay-option{display:flex;gap:12px;align-items:flex-start;padding:14px 16px;border:1.5px solid var(--gray-200);border-radius:var(--radius-md);cursor:pointer;margin-bottom:10px;transition:border-color .2s,background .2s}
.pay-option:hover{border-color:var(--navy-light)}
.pay-option.selected{border-color:var(--navy);background:var(--gray-50)}
.pay-option input{margin-top:3px}
.pay-option__title{font-size:14px;font-weight:700;color:var(--navy)}
.pay-option__desc{font-size:12px;color:var(--gray-500);margin-top:2px}
.receipt-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:0;overflow:hidden;margin-bottom:20px}
.receipt-banner{padding:28px 24px;text-align:center;color:#fff}
.receipt-banner--ok{background:linear-gradient(135deg,var(--green),#2d8a27)}
.receipt-banner--pending{background:linear-gradient(135deg,var(--navy),var(--navy-light))}
.receipt-banner h2{font-size:24px;margin:8px 0 2px}
.receipt-body{padding:24px}
.receipt-meta{display:grid;grid-template-columns:1fr 1fr;gap:12px 24px;font-size:13px;margin-bottom:18px}
.receipt-meta .label{color:var(--gray-500);display:block;font-size:11px;text-transform:uppercase;letter-spacing:.5px}
.receipt-meta .value{font-weight:600;color:var(--gray-800)}
@media(max-width:600px){.receipt-meta{grid-template-columns:1fr}}

/* ===== Phase 5: Admin product forms ===== */
.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{background:#b91c1c}
.btn-success{background:var(--green);color:#fff}.btn-success:hover{background:#2d8a27}
.topbar__breadcrumb{font-size:13px;color:var(--gray-400)}.topbar__breadcrumb a{color:var(--gray-500)}.topbar__breadcrumb a:hover{color:var(--navy)}
.form-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--gray-200);padding:24px;margin-bottom:20px}
.form-card__title{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--gray-100)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-grid--3col{grid-template-columns:1fr 1fr 1fr}
.form-group--full{grid-column:1/-1}
.form-label .required{color:var(--error)}
.form-hint{font-size:11px;color:var(--gray-400);margin-top:4px}
.form-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.table-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;font-size:13px;color:var(--gray-500);border-top:1px solid var(--gray-200)}
.table-pagination{display:flex;align-items:center;gap:4px}
.table-pagination button{min-width:32px;height:32px;border:1px solid var(--gray-200);border-radius:var(--radius-sm);background:#fff;font-size:14px;color:var(--gray-600);cursor:pointer}
.table-pagination button:disabled{opacity:.4;cursor:not-allowed}
.tab-group{display:flex;gap:0;border-bottom:2px solid var(--gray-200);margin-bottom:20px;overflow-x:auto}
.tab-group__btn{padding:10px 20px;background:none;border:none;font-size:14px;font-weight:600;color:var(--gray-500);cursor:pointer;position:relative;white-space:nowrap}
.tab-group__btn.active{color:var(--navy)}
.tab-group__btn.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:3px;background:var(--orange);border-radius:2px 2px 0 0}
.toggle-switch{position:relative;width:40px;height:22px;display:inline-block}
.toggle-switch input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;inset:0;background:var(--gray-300);border-radius:22px;cursor:pointer;transition:.3s}
.toggle-slider::before{content:'';position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;left:3px;top:3px;transition:.3s}
.toggle-switch input:checked+.toggle-slider{background:var(--green)}
.toggle-switch input:checked+.toggle-slider::before{transform:translateX(18px)}
@media(max-width:768px){.form-grid,.form-grid--3col{grid-template-columns:1fr}}

/* ===== Phase 6: Orders ===== */
.status{display:inline-flex;align-items:center;gap:6px}
.status .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
@media(max-width:768px){.order-detail-grid{grid-template-columns:1fr !important}}

/* ===== Phase 8: Franchise ===== */
.franchise-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
@media(max-width:768px){.dash-grid{grid-template-columns:1fr !important}}

/* ===== Phase 11: Reviews & Ratings ===== */
.stars{color:#F5A623;letter-spacing:1px;font-size:16px;white-space:nowrap}
.stars--sm{font-size:13px}
.course-card__rating{display:flex;align-items:center;gap:6px;margin:2px 0 4px}
.course-card__rating-num{font-size:12px;color:var(--gray-500);font-weight:600}
.pd-rating{display:flex;align-items:center;gap:8px;margin:6px 0 4px}
.pd-rating strong{color:var(--navy)}
.pd-rating__count{font-size:13px;color:var(--gray-500);text-decoration:underline}
.reviews-section{padding:8px 0}
.reviews-summary{display:flex;gap:28px;align-items:center;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:20px;margin-bottom:20px;flex-wrap:wrap}
.reviews-summary__score{text-align:center;min-width:120px}
.reviews-summary__avg{font-size:42px;font-weight:800;color:var(--navy);line-height:1}
.reviews-summary__count{font-size:12px;color:var(--gray-500);margin-top:4px}
.reviews-summary__bars{flex:1;min-width:200px;display:flex;flex-direction:column;gap:4px}
.rating-bar{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--gray-500)}
.rating-bar__star{width:28px}
.rating-bar__track{flex:1;height:8px;background:var(--gray-200);border-radius:4px;overflow:hidden}
.rating-bar__fill{height:100%;background:#F5A623;border-radius:4px}
.rating-bar__num{width:24px;text-align:right}
.review-form{border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:18px;margin-bottom:20px}
.review-form h4{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:12px}
.review-form .form-input{margin-bottom:10px}
.star-input{display:flex;align-items:center;gap:4px;margin-bottom:12px}
.star-input__btn{background:none;border:none;font-size:26px;color:var(--gray-300);cursor:pointer;padding:0;line-height:1;transition:color .15s}
.star-input__btn.on{color:#F5A623}
.star-input__btn:hover{color:#F5A623}
.star-input__hint{font-size:12px;color:var(--gray-500);margin-left:8px}
.reviews-empty{color:var(--gray-400);text-align:center;padding:24px 0}
.reviews-list{display:flex;flex-direction:column;gap:14px}
.review-card{border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:16px}
.review-card__head{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.review-card__avatar{width:40px;height:40px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}
.review-card__who{flex:1;min-width:0}
.review-card__name{font-size:14px;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.review-card__date{font-size:12px;color:var(--gray-400);white-space:nowrap}
.review-card__title{font-size:14px;font-weight:600;color:var(--gray-800);margin-bottom:4px}
.review-card__text{font-size:14px;color:var(--gray-600);line-height:1.5}
.verified-badge{font-size:10px;font-weight:700;color:var(--green);background:var(--green-light);padding:2px 7px;border-radius:var(--radius-sm)}
@media(max-width:600px){.reviews-summary{gap:16px}}

/* ===== Phase 11: Faculty pages ===== */
.faculty-page{padding:20px 20px 48px}
.faculty-hero{text-align:center;padding:24px 0 28px}
.faculty-hero h1{font-size:30px;font-weight:800;color:var(--navy)}
.faculty-hero p{color:var(--gray-500);margin-top:6px}
.faculty-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
.faculty-card{display:flex;flex-direction:column;align-items:center;text-align:center;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:24px 18px;text-decoration:none;transition:box-shadow .2s,transform .2s}
.faculty-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.faculty-card__avatar,.faculty-profile__avatar{width:84px;height:84px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--navy-light));color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;overflow:hidden;flex-shrink:0}
.faculty-card__avatar img,.faculty-profile__avatar img{width:100%;height:100%;object-fit:cover}
.faculty-card__name{font-size:16px;font-weight:700;color:var(--navy);margin-top:12px}
.faculty-card__role{font-size:12px;font-weight:600;color:var(--orange);margin-top:2px}
.faculty-card__qual{font-size:12px;color:var(--gray-500);margin-top:4px}
.faculty-card__meta{display:flex;gap:12px;align-items:center;margin-top:10px;font-size:12px;color:var(--gray-500)}
.faculty-card__rating{display:flex;align-items:center;gap:4px}
.faculty-card__cta{margin-top:14px;font-size:13px;font-weight:600;color:var(--navy)}
.faculty-profile{display:flex;gap:24px;align-items:center;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:24px;margin:14px 0 20px}
.faculty-profile__avatar{width:110px;height:110px;font-size:38px}
.faculty-profile__info h1{font-size:26px;font-weight:800;color:var(--navy)}
.faculty-profile__role{font-size:14px;font-weight:600;color:var(--orange);margin-top:2px}
.faculty-profile__qual{font-size:13px;color:var(--gray-500);margin-top:4px}
.faculty-profile__stats{display:flex;gap:20px;margin-top:10px;font-size:14px;color:var(--gray-600)}
.faculty-profile__stats strong{color:var(--navy)}
.faculty-profile__subjects{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.subject-chip{font-size:12px;font-weight:600;color:var(--navy);background:var(--gray-100);padding:4px 10px;border-radius:20px}
.faculty-bio{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:20px;margin-bottom:24px}
.faculty-bio h3{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:8px}
.faculty-bio p{font-size:14px;color:var(--gray-600);line-height:1.6}
.faculty-courses__title{font-size:20px;font-weight:800;color:var(--navy);margin-bottom:14px}
@media(max-width:600px){.faculty-profile{flex-direction:column;text-align:center}.faculty-profile__stats{justify-content:center}.faculty-profile__subjects{justify-content:center}}

/* ===== Phase 11: Search ===== */
.header__search{font-size:18px;text-decoration:none;line-height:1}
.search-page{padding:20px 20px 48px}
.search-hero{text-align:center;padding:24px 0 18px}
.search-hero h1{font-size:30px;font-weight:800;color:var(--navy);margin-bottom:14px}
.search-box{position:relative;max-width:640px;margin:0 auto;display:flex;align-items:center}
.search-box svg{position:absolute;left:16px;color:var(--gray-400)}
.search-box input{width:100%;padding:14px 18px 14px 44px;border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);font-size:15px;outline:none;transition:border-color .2s,box-shadow .2s}
.search-box input:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(26,58,92,.1)}
.search-suggest{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:30;overflow:hidden;text-align:left}
.search-suggest__item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 16px;text-decoration:none;border-bottom:1px solid var(--gray-100)}
.search-suggest__item:last-child{border-bottom:none}
.search-suggest__item:hover{background:var(--gray-50)}
.search-suggest__title{font-size:14px;color:var(--navy);font-weight:600}
.search-suggest__meta{font-size:12px;color:var(--gray-400);white-space:nowrap}
.search-count{font-size:13px;color:var(--gray-500);margin:14px 0}

/* ===== Phase 12: Newsletter footer signup ===== */
.footer__newsletter{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;max-width:1200px;margin:0 auto 24px;padding:20px 24px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg)}
.footer__newsletter-text h4{font-size:17px;font-weight:700;color:#fff;margin:0}
.footer__newsletter-text p{font-size:13px;color:rgba(255,255,255,.6);margin-top:2px}
.footer__newsletter-form{display:flex;gap:8px;min-width:280px}
.footer__newsletter-form input{flex:1;padding:10px 14px;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);background:rgba(255,255,255,.1);color:#fff;font-size:14px;outline:none}
.footer__newsletter-form input::placeholder{color:rgba(255,255,255,.45)}
.footer__newsletter-done{color:#7CE38B;font-weight:600;font-size:14px}
.footer__newsletter-msg{font-size:12px;color:rgba(255,255,255,.7);width:100%;text-align:right}
@media(max-width:600px){.footer__newsletter{flex-direction:column;align-items:stretch}.footer__newsletter-msg{text-align:left}}

/* ===== Phase 13: CMS pages + Blog ===== */
.cms-page{padding:24px 20px 56px;max-width:1200px;margin:0 auto}
.cms-page .breadcrumb{text-align:center;font-size:13px;color:var(--gray-400);margin-bottom:4px}
.cms-page .breadcrumb a{color:var(--gray-500)}
.cms-page .breadcrumb a:hover{color:var(--orange)}
.cms-page__title{font-size:clamp(22px,2.6vw,30px);font-weight:800;color:var(--navy);margin:4px 0 22px;text-align:center}
.cms-page__body{font-size:15px;color:var(--gray-700);line-height:1.7;overflow-wrap:break-word}
.cms-page__body h2,.cms-page__body h3{color:var(--navy);margin:18px 0 8px}
.cms-page__body p{margin-bottom:12px}
.blog-page{padding:20px 20px 56px}
.blog-hero{text-align:center;padding:24px 0 28px}
.blog-hero h1{font-size:32px;font-weight:800;color:var(--navy)}
.blog-hero p{color:var(--gray-500);margin-top:6px}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.blog-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;text-decoration:none;transition:box-shadow .2s,transform .2s}
.blog-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.blog-card__img{height:160px;background:linear-gradient(135deg,var(--navy),var(--navy-light));display:flex;align-items:center;justify-content:center;font-size:42px;color:rgba(255,255,255,.5);overflow:hidden}
.blog-card__img img{width:100%;height:100%;object-fit:cover}
.blog-card__body{padding:16px}
.blog-card__cat{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--orange);margin-bottom:6px}
.blog-card__title{font-size:17px;font-weight:700;color:var(--navy);line-height:1.3;margin-bottom:6px}
.blog-card__excerpt{font-size:13px;color:var(--gray-600);line-height:1.5;margin-bottom:8px}
.blog-card__date{font-size:12px;color:var(--gray-400)}
.blog-post{padding:24px 20px 56px;max-width:800px}
.blog-post__title{font-size:32px;font-weight:800;color:var(--navy);line-height:1.2;margin:6px 0}
.blog-post__meta{font-size:13px;color:var(--gray-500);margin-bottom:18px}
.blog-post__img{width:100%;border-radius:var(--radius-lg);margin-bottom:20px}
.blog-post__body{font-size:16px;color:var(--gray-700);line-height:1.8}
.blog-post__body p{margin-bottom:16px}

/* ===== Contact page ===== */
.contact-page{padding:20px 20px 56px}
.contact-hero{text-align:center;padding:24px 0 28px}
.contact-hero h1{font-size:30px;font-weight:800;color:var(--navy)}
.contact-hero p{color:var(--gray-500);margin-top:6px}
.contact-info p{font-size:14px;color:var(--gray-700);line-height:1.5;margin-bottom:14px}
.contact-info a{color:var(--navy);font-weight:600}

/* ===== Phase 19: Users / Audit ===== */
.role-chip{display:inline-block;font-size:11px;font-weight:600;color:var(--navy);background:var(--gray-100);padding:2px 8px;border-radius:20px;margin:2px 3px 2px 0}
.export-json{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:14px;font-size:12px;max-height:340px;overflow:auto;white-space:pre-wrap;color:var(--gray-700)}

/* ===== Phase 16: Reports bars ===== */
.report-bars{display:flex;align-items:flex-end;gap:6px;height:160px;padding:12px 4px 0}
.report-bar{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}
.report-bar__fill{width:70%;min-height:2px;background:linear-gradient(180deg,var(--navy-light),var(--navy));border-radius:3px 3px 0 0;transition:height .3s}
.report-bar__label{font-size:10px;color:var(--gray-400);margin-top:6px;white-space:nowrap}

/* ===== Phase 11: Wishlist ===== */
.course-card{position:relative}
.course-card__heart{position:absolute;top:10px;right:10px;z-index:2;width:32px;height:32px;border-radius:50%;border:none;background:rgba(255,255,255,.92);color:var(--gray-400);font-size:17px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px rgba(0,0,0,.15);transition:transform .15s,color .15s}
.course-card__heart:hover{transform:scale(1.12);color:var(--error)}
.course-card__heart.on{color:var(--error)}
.wishlist-page{padding:20px 20px 48px}
.wishlist-page__title{font-size:28px;font-weight:800;color:var(--navy);margin-bottom:2px}
.wishlist-page__count{font-size:14px;color:var(--gray-500);display:block;margin-bottom:20px}

/* ===== Phase 10: Student Account ===== */
.account-page{padding:20px 20px 48px}
.account-page__title{font-size:28px;font-weight:800;color:var(--navy);margin-bottom:14px}
.account-greeting{font-size:15px;color:var(--gray-600);margin:14px 0}
.account-nav{display:flex;gap:4px;border-bottom:2px solid var(--gray-200);margin-bottom:20px;overflow-x:auto}
.account-nav__link{padding:10px 18px;font-size:14px;font-weight:600;color:var(--gray-500);text-decoration:none;position:relative;white-space:nowrap}
.account-nav__link:hover{color:var(--navy)}
.account-nav__link.active{color:var(--navy)}
.account-nav__link.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:3px;background:var(--orange);border-radius:2px 2px 0 0}
.account-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start;margin-top:20px}
@media(max-width:860px){.account-grid{grid-template-columns:1fr}}
.account-course-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--gray-100)}
.account-course-row:last-child{border-bottom:none}
.account-course-row__title{font-size:14px;font-weight:700;color:var(--navy);text-decoration:none;display:block}
.account-course-row__meta{font-size:12px;color:var(--gray-500);margin-top:2px}
.account-progress{font-size:12px;font-weight:700;color:var(--green);white-space:nowrap}
.course-access-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.course-access-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:18px;transition:box-shadow .2s}
.course-access-card:hover{box-shadow:var(--shadow-md)}
.course-access-card__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.course-access-card__badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 8px;border-radius:var(--radius-sm)}
.course-access-card__badge.is-active{background:#E8F5E7;color:#16a34a}
.course-access-card__badge.is-inactive{background:var(--gray-100);color:var(--gray-500)}
.course-access-card__date{font-size:11px;color:var(--gray-400)}
.course-access-card__title{display:block;font-size:15px;font-weight:700;color:var(--navy);text-decoration:none;line-height:1.3;margin-bottom:4px}
.course-access-card__meta{font-size:12px;color:var(--gray-500);margin-bottom:12px}
.progress-bar{height:7px;background:var(--gray-100);border-radius:4px;overflow:hidden}
.progress-bar__fill{height:100%;background:linear-gradient(90deg,var(--green),#2d8a27);border-radius:4px}
.progress-bar__label{font-size:11px;color:var(--gray-500);margin-top:4px}
.inline-alert{padding:9px 13px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:14px}
.inline-alert--ok{background:#E8F5E7;color:#16a34a}
.inline-alert--err{background:#FEF2F2;color:#DC2626}
.invoice-sheet{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:28px;margin-bottom:16px}
.invoice-head{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid var(--gray-100);padding-bottom:16px}
.invoice-head__title{font-size:22px;font-weight:800;color:var(--navy);margin:0}
.invoice-head__sub{font-size:13px;color:var(--gray-500);margin-top:2px}
.invoice-head__brand{text-align:right;font-size:14px;color:var(--navy)}
.invoice-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:40px}
@media print{body *{visibility:hidden}.invoice-sheet,.invoice-sheet *{visibility:visible}.invoice-sheet{position:absolute;left:0;top:0;width:100%;border:none}}

/* ============================================================
   Responsive admin shell — overflow fixes, fluid grids, drawer
   ============================================================ */
html,body{overflow-x:hidden;max-width:100%}
.admin-layout{position:relative}
/* min-width:0 lets the flex child shrink so wide tables scroll INSIDE their container (not the page) */
.main-content{min-width:0;max-width:100%;transition:margin-left .22s ease}
.page{padding:clamp(14px,2.2vw,26px)}
.page__header h1{font-size:clamp(19px,2.4vw,24px)}

/* sidebar: transitions, icon/label split, slim scrollbar */
.sidebar{transition:width .22s ease,transform .22s ease}
.sidebar__ico{width:20px;flex:0 0 auto;text-align:center;font-size:15px}
.sidebar__txt{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar__nav{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.25) transparent}
.sidebar__nav::-webkit-scrollbar{width:6px}
.sidebar__nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}
.sidebar__nav::-webkit-scrollbar-track{background:transparent}

/* top bar layout + toggle buttons */
.admin-topbar{justify-content:space-between;gap:10px}
.topbar__left{display:flex;align-items:center;gap:4px}
.topbar__right{display:flex;align-items:center;gap:10px;margin-left:auto}
.topbar__btn{background:none;border:0;font-size:19px;line-height:1;cursor:pointer;color:var(--gray-500);padding:6px 9px;border-radius:8px;transition:background .15s}
.topbar__btn:hover{background:var(--gray-100);color:var(--navy)}
.topbar__hamburger{display:none}

/* off-canvas drawer overlay (mobile) */
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:48}

/* table container: scroll INSIDE only, slim horizontal bar */
.table-wrap{max-width:100%;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--gray-300) transparent}
.table-wrap::-webkit-scrollbar{height:8px}
.table-wrap::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}

/* KPI cards: fluid + equal height + hover lift */
.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}
.kpi-card{transition:transform .15s ease,box-shadow .15s ease}
.kpi-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(15,23,42,.08)}

/* priority-based column hiding */
@media(max-width:1280px){.col-hide-lg{display:none!important}}
@media(max-width:992px){.col-hide-md{display:none!important}}

/* desktop-only compact (collapsed) sidebar */
@media(min-width:1025px){
  .admin-layout--collapsed .sidebar{width:68px}
  .admin-layout--collapsed .main-content{margin-left:68px}
  .admin-layout--collapsed .sidebar__txt,
  .admin-layout--collapsed .sidebar__chevron,
  .admin-layout--collapsed .sidebar__group-items,
  .admin-layout--collapsed .sidebar__user-info{display:none}
  .admin-layout--collapsed .sidebar__logo{justify-content:center;padding:0 8px 18px}
  .admin-layout--collapsed .sidebar__link,
  .admin-layout--collapsed .sidebar__group-header{justify-content:center;padding-left:0;padding-right:0}
  .admin-layout--collapsed .sidebar__group-label{gap:0}
  .admin-layout--collapsed .sidebar__user{justify-content:center}
}

/* tablet / mobile: sidebar becomes an off-canvas drawer; content reclaims full width */
@media(max-width:1024px){
  .sidebar{transform:translateX(-100%);box-shadow:0 0 40px rgba(0,0,0,.35);width:248px}
  .admin-layout--mobile-open .sidebar{transform:translateX(0)}
  .admin-layout--mobile-open .nav-overlay{display:block}
  .main-content{margin-left:0!important}
  .topbar__hamburger{display:inline-flex}
  .topbar__collapse{display:none}
}

/* small screens: stack header actions + filter rows */
@media(max-width:640px){
  .page__header{flex-wrap:wrap;gap:10px}
  .data-card__filters{flex-direction:column;align-items:stretch}
  .admin-topbar{padding:0 14px}
}
