/*
Theme Name: DTU East Campus
Theme URI: https://eastcampus.dtu.ac.in
Author: DTU East Campus Web Team
Author URI: https://eastcampus.dtu.ac.in
Description: Custom WordPress theme for DTU East Campus (USME), Delhi Technological University. Converted from a static HTML prototype. Built with native PHP templates, Gutenberg block support, and a custom theme.json color/typography system.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
Tested up to: 7.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: dtu-east-campus
Tags: education, custom-colors, custom-menu, full-width-template, theme-options, threaded-comments, translation-ready
*/

*{box-sizing:border-box;margin:0;padding:0}
:root{
--bg:#F7F8FC;--white:#FFFFFF;--dark:#0B1426;--blue:#1E4FD8;--blue-light:#EBF0FF;--blue-mid:#4B72F0;
--amber:#F5A623;--amber-light:#FFF8ED;--grey:#F0F2F7;--grey2:#E4E7EF;--text:#0B1426;--text2:#4A5568;--text3:#7B879A;
--green:#16A34A;--red:#DC2626;--border:#DDE2EE;
}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.6;overflow-x:hidden}
.page{display:none}.page.active{display:block}
/* ── Announcement Bar (Amity style) ── */
.ann-bar{background:var(--dark);padding:10px 2rem;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.ann-bar-left{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.ann-link{color:rgba(255,255,255,.85);font-size:12.5px;font-weight:500;cursor:pointer;white-space:nowrap;text-decoration:none}
.ann-link:hover{color:var(--amber)}
.ann-sep{color:rgba(255,255,255,.25);font-size:12px}
.ann-bar-right{display:flex;align-items:center;gap:16px}
.ann-icon{color:rgba(255,255,255,.8);font-size:14px;cursor:pointer;width:16px;text-align:center}
.ann-icon:hover{color:var(--amber)}

/* ── Main Nav (Amity style) ── */
nav{background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;padding:0 2rem;box-shadow:0 1px 12px rgba(0,0,0,.06)}
.nav-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:78px;gap:16px}
/* Brand */
.nav-brand{display:flex;align-items:center;gap:12px;cursor:pointer;text-decoration:none;flex-shrink:1;min-width:0}
.nav-logo{width:52px;height:52px;background:linear-gradient(135deg,var(--blue),var(--blue-mid));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;color:var(--amber);border:2px solid var(--amber)}
.nav-brand-text{display:flex;flex-direction:column;min-width:0;overflow:hidden}
.nav-brand .b1{font-size:19px;font-weight:800;color:var(--dark);letter-spacing:-0.01em;font-family:'Playfair Display',serif;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-brand .b2{font-size:11px;color:var(--text3);margin-top:2px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* Links */
.nav-links{display:flex;gap:6px;flex:1;justify-content:center}
.nav-link{padding:10px 14px;border-radius:7px;cursor:pointer;font-size:13px;font-weight:600;color:var(--dark);border:none;background:none;transition:all .15s;white-space:nowrap;display:flex;align-items:center;gap:5px;text-transform:uppercase;letter-spacing:0.02em}
.nav-link:hover{color:var(--blue)}
.nav-link.active{color:var(--blue)}
.nav-caret{font-size:9px;color:var(--text3)}

/* CTAs */
.nav-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.nav-wa{display:flex;align-items:center;gap:6px;background:#f0fdf4;border:1.5px solid #bbf7d0;color:#15803d;padding:7px 13px;border-radius:8px;cursor:pointer;font-size:12.5px;font-weight:600;border-style:solid;white-space:nowrap}
.nav-cta{background:var(--dark);color:#fff;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:700;border:none;white-space:nowrap;letter-spacing:0.04em;text-transform:uppercase;display:flex;align-items:center;gap:8px}
.nav-cta .arrow{color:var(--amber);font-weight:800}
main{max-width:1100px;margin:0 auto;padding:0 2rem}
h1{font-family:'Playfair Display',serif;font-weight:800;color:var(--dark)}
h2{font-family:'Playfair Display',serif;font-weight:700;color:var(--dark)}
.hero{padding:80px 0 60px;display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--blue-light);color:var(--blue);padding:5px 14px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;margin-bottom:20px}
.hero h1{font-size:42px;line-height:1.15;margin-bottom:16px}
.hero-sub{font-size:16px;color:var(--text2);line-height:1.65;margin-bottom:28px;max-width:500px}
.btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-primary{
  background:var(--blue);color:#fff;
  padding:13px 26px;border-radius:50px;
  font-size:14px;font-weight:600;border:none;cursor:pointer;
  letter-spacing:0.03em;
  box-shadow:0 4px 18px rgba(30,79,216,0.3);
  transition:all 0.2s;display:inline-flex;align-items:center;gap:8px;
}
.btn-primary:hover{background:#1743b8;transform:translateY(-1px);box-shadow:0 6px 24px rgba(30,79,216,0.4)}
.btn-wa{
  background:#25D366;color:#fff;
  padding:13px 26px;border-radius:50px;
  font-size:14px;font-weight:600;border:none;cursor:pointer;
  letter-spacing:0.03em;
  box-shadow:0 4px 18px rgba(37,211,102,0.25);
  transition:all 0.2s;display:inline-flex;align-items:center;gap:8px;
}
.btn-wa:hover{background:#1fb855;transform:translateY(-1px)}
.btn-outline{
  background:transparent;color:var(--blue);
  border:1.5px solid var(--blue);
  padding:12px 26px;border-radius:50px;
  font-size:14px;font-weight:600;cursor:pointer;
  letter-spacing:0.03em;
  transition:all 0.2s;display:inline-flex;align-items:center;gap:8px;
}
.btn-outline:hover{background:var(--blue-light)}
.trust-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.chip{display:flex;align-items:center;gap:5px;padding:5px 11px;background:var(--grey);border-radius:20px;font-size:12px;color:var(--text2);font-weight:500}
.chip-dot{width:6px;height:6px;border-radius:50%;background:var(--green)}
.hero-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 4px 24px rgba(0,0,0,.06)}
.hero-card-title{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:14px}
.stat-row{display:flex;border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:14px}
.stat-cell{flex:1;padding:14px 12px;text-align:center;border-right:1px solid var(--border)}
.stat-cell:last-child{border-right:none}
.stat-n{font-size:22px;font-weight:700;color:var(--blue);font-family:'Playfair Display',serif}
.stat-l{font-size:11px;color:var(--text3);margin-top:2px}
.cuet-check{background:var(--blue-light);border-radius:10px;padding:14px 16px}
.cuet-check p{font-size:12px;color:var(--text2);margin-bottom:8px;font-weight:500}
.cuet-input-row{display:flex;gap:8px}
.cuet-input{flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:7px;font-size:13px;outline:none;font-family:'Inter',sans-serif}
.cuet-btn{background:var(--blue);color:#fff;padding:8px 14px;border-radius:7px;font-size:12px;font-weight:600;border:none;cursor:pointer}
.cuet-result{margin-top:10px;font-size:12px;border-radius:7px;padding:8px 12px;display:none}
.cuet-result.good{background:#DCFCE7;color:#15803D;display:block}
.cuet-result.check{background:#FEF9C3;color:#854D0E;display:block}
.cuet-result.low{background:#FEE2E2;color:#991B1B;display:block}
.trust-bar{background:var(--dark);padding:18px 0}
.trust-bar-inner{max-width:1100px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
.tb-item{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.85);font-size:12px;font-weight:500}
.tb-icon{color:var(--amber)}
.section{padding:64px 0}
.gallery-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.gallery-tab{background:var(--grey);border:1px solid var(--border);color:var(--text2);padding:9px 18px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}
.gallery-tab:hover{background:var(--blue-light);color:var(--blue)}
.gallery-tab.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.gallery-note{background:var(--amber-light);border:1px solid #FFCD70;border-radius:8px;padding:10px 14px;font-size:12px;color:var(--text2);margin-bottom:24px}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.gallery-card{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--white);transition:transform .15s}
.gallery-card:hover{transform:translateY(-3px)}
.gallery-card.hidden{display:none}
.gallery-img{height:140px;display:flex;align-items:center;justify-content:center;font-size:40px}
.gallery-cap{padding:10px 12px;font-size:12.5px;font-weight:600;color:var(--text2)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.blog-card{border:1px solid var(--border);border-radius:14px;padding:22px;background:var(--white);cursor:pointer;transition:all .15s}
.blog-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.08);border-color:var(--blue)}
.blog-card-tag{display:inline-block;background:var(--blue-light);color:var(--blue);font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:0.04em;margin-bottom:12px}
.blog-card-title{font-family:'Playfair Display',serif;font-weight:700;font-size:17px;color:var(--dark);line-height:1.35;margin-bottom:10px}
.blog-card-excerpt{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:14px}
.blog-card-meta{font-size:11.5px;color:var(--text3);display:flex;gap:6px}
.blog-post-h1{font-size:32px;line-height:1.25}
.blog-post-meta{font-size:13px;color:var(--text3);margin-top:14px;margin-bottom:24px}
.blog-post-para{font-size:15px;color:var(--text2);line-height:1.8;margin-bottom:20px}
.blog-post-h2{font-family:'Playfair Display',serif;font-size:22px;color:var(--dark);margin:32px 0 14px}
.blog-post-cta{background:var(--blue-light);border-radius:14px;padding:24px;text-align:center;margin-top:36px}
.blog-post-cta-title{font-size:15px;font-weight:700;color:var(--dark);margin-bottom:14px}
.blog-pagination{display:flex;justify-content:center;gap:8px;margin-top:36px}
.blog-pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border:1px solid var(--border);border-radius:8px;color:var(--text2);text-decoration:none;font-size:13px;font-weight:600}
.blog-pagination .page-numbers.current{background:var(--blue);color:#fff;border-color:var(--blue)}
.blog-pagination .page-numbers:hover{border-color:var(--blue);color:var(--blue)}
.blog-post-content{font-size:15px;color:var(--text2);line-height:1.8}
.blog-post-content p{margin-bottom:20px}
.blog-post-content h2{font-family:'Playfair Display',serif;font-size:22px;color:var(--dark);margin:32px 0 14px}
.blog-post-content h3{font-family:'Playfair Display',serif;font-size:19px;color:var(--dark);margin:28px 0 12px}
.blog-post-content ul,.blog-post-content ol{margin:0 0 20px 24px}
.blog-post-content li{margin-bottom:8px}
.blog-post-content img{max-width:100%;border-radius:10px;margin:16px 0}
.blog-post-content blockquote{border-left:3px solid var(--blue);padding:12px 20px;color:var(--text3);font-style:italic;margin:24px 0}
.blog-post-content a{color:var(--blue)}
.section-eyebrow{font-size:11px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:10px}
.section h2{font-size:32px;margin-bottom:8px}
.section-sub{color:var(--text2);font-size:15px;margin-bottom:40px;max-width:560px}
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.bento-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:24px}
.bento-num{font-size:52px;font-weight:800;color:var(--blue-light);font-family:'Playfair Display',serif;line-height:1;margin-bottom:8px}
.bento-title{font-size:15px;font-weight:600;color:var(--dark);margin-bottom:8px}
.bento-body{font-size:13px;color:var(--text2);line-height:1.6}
.programs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.prog-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:24px;cursor:pointer;transition:border .2s}
.prog-card.featured{border:2px solid var(--blue)}
.prog-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;margin-bottom:12px}
.badge-govt{background:#EBF0FF;color:var(--blue)}
.badge-new{background:#DCFCE7;color:#15803D}
.prog-name{font-size:17px;font-weight:700;color:var(--dark);margin-bottom:4px}
.prog-detail{font-size:12px;color:var(--text3);margin-bottom:14px}
.prog-fee{font-size:22px;font-weight:700;color:var(--blue);font-family:'Playfair Display',serif}
.prog-fee-label{font-size:11px;color:var(--text3);margin-bottom:14px}
.prog-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.prog-tag{padding:3px 9px;background:var(--grey);border-radius:12px;font-size:11px;color:var(--text2)}
.prog-link{font-size:13px;font-weight:600;color:var(--blue);cursor:pointer}
.stats-highlight{background:var(--dark);border-radius:16px;padding:32px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin:48px 0}
.sh-item{text-align:center}
.sh-num{font-size:32px;font-weight:800;color:var(--amber);font-family:'Playfair Display',serif}
.sh-label{font-size:12px;color:rgba(255,255,255,.65);margin-top:4px}
.comp-table{width:100%;border-collapse:collapse;border:1px solid var(--border);border-radius:12px;overflow:hidden}
.comp-table th{background:var(--dark);color:#fff;padding:12px 16px;font-size:12px;font-weight:600;text-align:left}
.comp-table td{padding:12px 16px;font-size:13px;border-bottom:1px solid var(--border)}
.comp-table tr:last-child td{border-bottom:none}
.comp-table tr:nth-child(even) td{background:var(--grey)}
.tick{color:var(--green);font-weight:700}
.cross{color:var(--red);font-weight:700}
.partial{color:var(--amber);font-size:12px}
.dtu-col{color:var(--blue);font-weight:700}
.steps-timeline{display:flex;flex-direction:column;gap:0}
.step-row{display:flex;gap:20px;position:relative}
.step-row:not(:last-child)::before{content:'';position:absolute;left:19px;top:42px;bottom:-1px;width:2px;background:var(--border)}
.step-num{width:40px;height:40px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0;margin-top:2px;z-index:1;position:relative}
.step-content{padding:0 0 32px}
.step-title{font-size:15px;font-weight:600;color:var(--dark);margin-bottom:4px}
.step-body{font-size:13px;color:var(--text2)}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.testi-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:22px}
.testi-quote{font-size:13px;color:var(--text2);line-height:1.7;margin-bottom:16px;font-style:italic}
.testi-author{display:flex;align-items:center;gap:10px}
.testi-avatar{width:36px;height:36px;border-radius:50%;background:var(--blue-light);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.testi-name{font-size:13px;font-weight:600;color:var(--dark)}
.testi-meta{font-size:11px;color:var(--text3)}
.faq-item{background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:6px}
.faq-q{padding:16px 20px;font-size:14px;font-weight:500;cursor:pointer;display:flex;justify-content:space-between;align-items:center;list-style:none}
.faq-q:hover{background:var(--grey)}
.faq-chevron{font-size:18px;color:var(--text3);transition:transform .2s}
.faq-a{display:none;padding:0 20px 16px;font-size:13px;color:var(--text2);line-height:1.7}
.faq-a.open{display:block}
.cta-block{background:var(--dark);border-radius:20px;padding:48px;text-align:center;margin:48px 0}
.cta-block h2{color:#fff;font-size:28px;margin-bottom:12px}
.cta-block p{color:rgba(255,255,255,.7);margin-bottom:28px;font-size:15px}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.cta-micro{color:rgba(255,255,255,.45);font-size:12px;margin-top:16px}
.form-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:24px;max-width:420px;margin:0 auto 48px}
.form-card h3{font-size:16px;font-weight:600;margin-bottom:16px}
.form-field{margin-bottom:12px}
.form-field label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:5px}
.form-field input,.form-field select{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:7px;font-size:13px;outline:none;font-family:'Inter',sans-serif}
.form-submit{width:100%;background:var(--blue);color:#fff;padding:11px;border-radius:8px;font-size:14px;font-weight:600;border:none;cursor:pointer;margin-top:4px}
.cutoff-table{width:100%;border-collapse:collapse}
.cutoff-table th{background:var(--blue);color:#fff;padding:10px 16px;font-size:12px;font-weight:600;text-align:left}
.cutoff-table td{padding:11px 16px;font-size:13px;border-bottom:1px solid var(--border)}
.cutoff-table tr:nth-child(even) td{background:var(--grey)}
.range-pill{display:inline-block;padding:2px 10px;border-radius:20px;font-size:12px;font-weight:600;background:var(--blue-light);color:var(--blue)}
.callout-box{background:var(--amber-light);border:1px solid #FFCD70;border-radius:12px;padding:20px;margin:20px 0;display:flex;gap:14px;align-items:flex-start}
.callout-icon{font-size:22px}
.callout-body p{font-size:13px;color:var(--text2);line-height:1.6}
.fee-table{width:100%;border-collapse:collapse}
.fee-table th{background:var(--grey2);padding:10px 16px;font-size:12px;font-weight:600;text-align:left}
.fee-table td{padding:11px 16px;font-size:13px;border-bottom:1px solid var(--border)}
.fee-table tr:last-child td{font-weight:700;background:var(--blue-light);color:var(--blue)}
.checklist{list-style:none;display:flex;flex-direction:column;gap:8px}
.checklist li{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--text2);padding:10px 14px;background:var(--white);border:1px solid var(--border);border-radius:8px}
.check-icon{width:20px;height:20px;border-radius:50%;background:#DCFCE7;color:var(--green);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.timeline-visual{display:flex;border:1px solid var(--border);border-radius:12px;overflow:hidden;margin:32px 0}
.tl-step{flex:1;padding:16px 12px;text-align:center;background:var(--white);border-right:1px solid var(--border)}
.tl-step:last-child{border-right:none}
.tl-month{font-size:10px;font-weight:700;color:var(--blue);text-transform:uppercase;margin-bottom:4px}
.tl-event{font-size:12px;font-weight:500;color:var(--dark)}
.page-hero{padding:56px 0 40px}
.page-hero h1{font-size:36px;line-height:1.2;margin-bottom:12px}
.page-hero .sub{font-size:15px;color:var(--text2);max-width:640px;line-height:1.7}
.divider{height:1px;background:var(--border)}
.recruiter-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.recruiter-pill{background:var(--white);border:1px solid var(--border);border-radius:8px;padding:10px 14px;font-size:12px;font-weight:500;color:var(--text2);text-align:center}
.sector-label{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:0.08em;margin:16px 0 8px}
footer{background:var(--dark);padding:40px 2rem;margin-top:80px}
.pre-footer{background:var(--dark);padding:48px 2rem 32px;margin-top:80px;border-bottom:1px solid rgba(255,255,255,.08)}
.pre-footer + footer{margin-top:0}
.pre-footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.1fr .7fr 1fr;gap:40px;align-items:start}
.pf-brand{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.pf-logo{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-mid));display:flex;align-items:center;justify-content:center;font-size:22px;border:2px solid var(--amber);flex-shrink:0}
.pf-name{font-size:15px;font-weight:700;color:#fff}
.pf-meta{font-size:11.5px;color:rgba(255,255,255,.5);margin-top:3px}
.pf-contact-row{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;font-size:13px;color:rgba(255,255,255,.75);line-height:1.6}
.pf-icon{width:30px;height:30px;border-radius:8px;border:1px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.pf-links-title{font-size:13px;font-weight:700;color:#fff;margin-bottom:16px}
.pf-links-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 28px}
.pf-links-grid a{font-size:13px;color:rgba(255,255,255,.7);text-decoration:none;cursor:pointer}
.pf-links-grid a:hover{color:var(--amber)}
.pf-map{position:relative;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.12)}
.pf-map-frame{width:100%;height:180px;border:0;display:block}
.pf-map-open{position:absolute;top:10px;left:10px;background:#fff;color:var(--blue);font-size:12px;font-weight:600;padding:6px 12px;border-radius:6px;text-decoration:none;z-index:2;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.pf-social{max-width:1280px;margin:32px auto 0;display:flex;justify-content:center;gap:32px;flex-wrap:wrap}
.pf-social a{font-size:13px;color:rgba(255,255,255,.75);text-decoration:none;cursor:pointer}
.pf-social a:hover{color:var(--amber)}
@media(max-width:900px){
  .pre-footer-inner{grid-template-columns:1fr;gap:32px}
  .pf-map-frame{height:200px}
}
.footer-inner{max-width:1100px;margin:0 auto;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:24px}
.footer-brand .fb1{font-size:14px;font-weight:600;color:#fff}
.footer-brand .fb2{font-size:12px;color:rgba(255,255,255,.5);margin-top:4px}
.footer-brand .fb3{font-size:12px;color:rgba(255,255,255,.4);margin-top:12px;line-height:1.6;max-width:240px}
.footer-links{display:flex;flex-direction:column;gap:6px}
.footer-links a{font-size:13px;color:rgba(255,255,255,.6);text-decoration:none;cursor:pointer}
.footer-col-title{font-size:11px;font-weight:700;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:10px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:32px;padding-top:20px;text-align:center;font-size:12px;color:rgba(255,255,255,.3)}
/* ── Campus Image Hero ── */
.campus-hero{
  position:relative;width:100%;overflow:hidden;
  background:var(--dark);
  max-height:680px;
  border-radius:0 0 32px 32px;
  margin-bottom:0;
}
.campus-hero img{
  width:100%;height:auto;display:block;
  object-fit:cover;
}
.campus-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom, rgba(11,20,38,0.1) 0%, rgba(11,20,38,0.55) 70%, rgba(11,20,38,0.85) 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:flex-end;
  padding:0 2rem 0;text-align:center;
}
.campus-hero-bottom{
  width:100%;display:flex;justify-content:center;
  padding:28px 2rem 32px;
}
.campus-hero-label{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,0.18);
  color:rgba(255,255,255,0.92);
  padding:10px 22px;border-radius:40px;
  font-size:12px;font-weight:500;letter-spacing:0.06em;
  text-transform:uppercase;
  box-shadow:0 4px 24px rgba(0,0,0,0.18);
}
.label-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--amber);
  box-shadow:0 0 8px var(--amber);
  flex-shrink:0;
}
.campus-hero-cta-wrap{
  background:var(--white);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:20px 2rem 18px;
  border-bottom:1px solid var(--border);
  box-shadow:0 4px 20px rgba(0,0,0,0.05);
}
.campus-hero-cta{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--dark);
  border:none;
  color:#fff;
  padding:12px 28px 12px 32px;
  border-radius:50px;
  font-size:13px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;
  cursor:pointer;transition:all 0.25s;
  font-family:'Inter',sans-serif;
  box-shadow:0 4px 20px rgba(11,20,38,0.25);
}
.campus-hero-cta:hover{
  background:var(--blue);
  box-shadow:0 6px 28px rgba(30,79,216,0.35);
  transform:translateY(-2px);
}
.campus-hero-cta-arrow{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;
  background:rgba(255,255,255,0.12);
  color:var(--amber);
  animation:bounce 2s infinite;
  flex-shrink:0;
}
.campus-hero-cta-tagline{
  font-size:11px;color:var(--text3);font-weight:500;
  letter-spacing:0.04em;
}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

@media(max-width:768px){
.campus-hero{max-height:none}
.campus-hero-title{font-size:22px}
.campus-hero-sub{display:none}
}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none;z-index:200}
.hamburger span{display:block;width:22px;height:2px;background:var(--dark);border-radius:2px;transition:all .25s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--white);z-index:150;padding:80px 24px 32px;flex-direction:column;overflow-y:auto}
.mobile-menu.open{display:flex}
.mobile-menu-link{padding:16px 0;font-size:16px;font-weight:600;color:var(--dark);border-bottom:1px solid var(--border);cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.mobile-menu-link:hover{color:var(--blue)}
.mobile-menu-actions{display:flex;flex-direction:column;gap:10px;margin-top:24px}
.mobile-menu-actions .m-btn-wa{background:#25D366;color:#fff;padding:14px;border-radius:10px;font-size:14px;font-weight:600;border:none;cursor:pointer;text-align:center}
.mobile-menu-actions .m-btn-apply{background:var(--dark);color:#fff;padding:14px;border-radius:10px;font-size:14px;font-weight:700;border:none;cursor:pointer;text-align:center}

/* Switch nav to hamburger mode for tablets + small laptops too — the
   full nav-links row + WhatsApp button only fit comfortably from ~1380px up */
@media(max-width:1380px){
.nav-links{display:none}
.nav-wa{display:none}
.hamburger{display:flex}
}

@media(max-width:768px){
.about-grid{grid-template-columns:1fr !important}
.about-facts-strip{grid-template-columns:repeat(2,1fr) !important}
.about-facts-strip > div:nth-child(2n){border-right:none !important}
.about-facts-strip > div{border-bottom:1px solid var(--border)}
main{padding:0 16px}
body{font-size:14px}
.ann-bar{display:none}
nav{padding:0 16px}
.nav-inner{height:60px;gap:8px}
.nav-cta{padding:9px 16px;font-size:12px}
.nav-brand .b1{font-size:15px}
.nav-brand .b2{font-size:9px}
.nav-logo{width:38px;height:38px;font-size:18px}
.campus-hero{max-height:none;min-height:220px}
.campus-hero img{height:220px;object-fit:cover;object-position:center}
.campus-hero-cta-wrap{padding:14px 16px}
.campus-hero-cta{font-size:12px;padding:10px 20px}
.hero{grid-template-columns:minmax(0,1fr);gap:24px;padding:32px 0 24px}
.hero h1{font-size:26px;line-height:1.2}
.hero-sub{font-size:14px;margin-bottom:20px}
.btns{flex-direction:column;gap:10px}
.btn-primary,.btn-wa,.btn-outline{width:100%;text-align:center;padding:13px 18px}
.trust-chips{gap:6px}
.hero-card{padding:16px}
.stat-n{font-size:18px}
.trust-bar-inner{flex-direction:column;gap:10px;align-items:flex-start}
.section{padding:36px 0}
.section h2{font-size:22px}
.section-sub{font-size:13px;margin-bottom:24px}
.bento{grid-template-columns:1fr;gap:12px}
.programs-grid{grid-template-columns:1fr;gap:12px}
.testimonials-grid{grid-template-columns:1fr;gap:12px}
.stats-highlight{grid-template-columns:repeat(2,1fr);gap:16px;padding:24px 16px;margin:24px 0}
.sh-num{font-size:24px}
.recruiter-grid{grid-template-columns:repeat(2,1fr);gap:8px}
.gallery-grid{grid-template-columns:repeat(2,1fr);gap:12px}
.blog-grid{grid-template-columns:1fr;gap:14px}
.gallery-tabs{gap:6px}
.gallery-tab{padding:7px 14px;font-size:12px}
.timeline-visual{flex-direction:column}
.tl-step{border-right:none;border-bottom:1px solid var(--border)}
.comp-table{font-size:11px;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
.comp-table th,.comp-table td{padding:8px 10px;white-space:nowrap}
.cutoff-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
.cutoff-table th,.cutoff-table td{padding:8px 10px;white-space:nowrap}
.fee-table th,.fee-table td{padding:8px 10px;font-size:12px}
.cta-block{padding:28px 20px;border-radius:14px;margin:28px 0}
.cta-block h2{font-size:20px}
.cta-block p{font-size:13px;margin-bottom:18px}
.cta-btns{flex-direction:column;gap:10px}
.cta-btns button{width:100%;padding:13px}
.form-card{padding:18px;margin-bottom:28px}
.callout-box{flex-direction:column;gap:8px}
.page-hero{padding:32px 0 24px}
.page-hero h1{font-size:24px}
.page-hero .sub{font-size:13px}
footer{padding:28px 16px;margin-top:40px}
.footer-inner{flex-direction:column;gap:20px}
.step-content{padding:0 0 20px}
.bento-card{padding:18px}
.bento-num{font-size:38px}
.prog-card{padding:18px}
.prog-fee{font-size:18px}
/* Pro hero card mobile fixes */
.pro-trust-row{gap:5px;margin-top:6px}
.pro-trust-item{font-size:10px;padding:4px 10px 4px 7px;gap:4px}
.pro-trust-item svg,.pro-trust-item span[style]{width:14px;height:14px;font-size:12px}
.pro-stats-grid{padding:12px 10px}
.pro-stat-n{font-size:16px}
.pro-stat-l{font-size:9px}
.pro-stat-divider{height:26px}
.pro-cta-row{gap:8px;margin-bottom:14px}
.pro-btn-primary{font-size:12px;padding:11px 16px}
.pro-btn-wa{font-size:12px;padding:11px 16px}
.pro-student-wrap{height:200px}
.pro-hero-card{border-radius:14px}
}

/* ══════════════════════════════════════
   PRO HERO CARD
══════════════════════════════════════ */
.pro-hero-card {
  background: #fff;
  border-radius: 20px;
  box-shadow: 0 8px 40px rgba(11,20,38,0.13), 0 1.5px 6px rgba(30,79,216,0.07);
  overflow: hidden;
  border: 1px solid rgba(30,79,216,0.10);
}

.pro-student-wrap {
  position: relative;
  background: linear-gradient(160deg, #EBF0FF 0%, #f7f8fc 100%);
  padding: 0;
  text-align: center;
  overflow: hidden;
  height: 260px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}

.pro-student-img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: top center;
  border-radius: 0;
}

.pro-student-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--blue);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 0 0 10px 10px;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}

.pro-stats-grid {
  display: flex;
  align-items: center;
  padding: 20px 20px 16px;
  background: var(--dark);
  gap: 0;
}

.pro-stat {
  flex: 1;
  text-align: center;
}

.pro-stat-n {
  font-size: 22px;
  font-weight: 800;
  color: var(--amber);
  font-family: 'Playfair Display', serif;
  line-height: 1.1;
}

.pro-stat-l {
  font-size: 10px;
  color: rgba(255,255,255,0.6);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-top: 3px;
}

.pro-stat-divider {
  width: 1px;
  height: 36px;
  background: rgba(255,255,255,0.12);
  flex-shrink: 0;
}

.pro-cuet-box {
  padding: 16px 18px 18px;
  background: #f7f8fc;
  border-top: 1px solid var(--border);
}

.pro-cuet-label {
  font-size: 12px;
  font-weight: 700;
  color: var(--blue);
  margin-bottom: 10px;
  letter-spacing: 0.02em;
}

.pro-cuet-row {
  display: flex;
  gap: 8px;
}

.pro-cuet-input {
  flex: 1;
  min-width: 0;
  padding: 10px 14px;
  border: 1.5px solid var(--border);
  border-radius: 10px;
  font-size: 13px;
  font-family: 'Inter', sans-serif;
  outline: none;
  background: #fff;
  transition: border .15s;
}

.pro-cuet-input:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(30,79,216,0.08);
}

.pro-cuet-btn {
  background: var(--blue);
  color: #fff;
  padding: 10px 18px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  transition: all .2s;
  letter-spacing: 0.02em;
}

.pro-cuet-btn:hover {
  background: #1743b8;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(30,79,216,0.3);
}

/* ══════════════════════════════════════
   PRO CTA BUTTONS
══════════════════════════════════════ */
.pro-cta-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.pro-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, #1E4FD8 0%, #3B6FF5 100%);
  color: #fff;
  padding: 14px 26px;
  border-radius: 50px;
  font-size: 14px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  letter-spacing: 0.02em;
  box-shadow: 0 4px 20px rgba(30,79,216,0.35);
  transition: all .2s;
  font-family: 'Inter', sans-serif;
}

.pro-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(30,79,216,0.45);
}

.pro-btn-primary span { font-weight: 700; }

.pro-btn-wa {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, #20C45A 0%, #16A34A 100%);
  color: #fff;
  padding: 14px 22px;
  border-radius: 50px;
  font-size: 14px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  box-shadow: 0 4px 18px rgba(22,163,74,0.3);
  transition: all .2s;
  font-family: 'Inter', sans-serif;
}

.pro-btn-wa:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(22,163,74,0.4);
}

/* ══════════════════════════════════════
   PRO TRUST CHIPS
══════════════════════════════════════ */
.pro-trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}

.pro-trust-item {
  display: flex;
  align-items: center;
  gap: 6px;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 50px;
  padding: 6px 14px 6px 10px;
  font-size: 12px;
  font-weight: 600;
  color: var(--dark);
  box-shadow: 0 1px 4px rgba(0,0,0,0.06);
  transition: all .2s;
}

.pro-trust-item:hover {
  border-color: var(--blue);
  color: var(--blue);
  box-shadow: 0 2px 10px rgba(30,79,216,0.12);
}

.pro-trust-icon {
  font-size: 14px;
  line-height: 1;
}

@media(max-width:768px){
  .pro-hero-card { margin-top: 28px; }
  .pro-student-img { max-height: 220px; }
  .pro-btn-primary, .pro-btn-wa { font-size: 13px; padding: 12px 18px; }
  .director-card { grid-template-columns: 1fr !important; text-align: center; padding: 20px !important; }
  .director-card > div:first-child > div:first-child { width: 110px !important; height: 110px !important; font-size: 40px !important; }
  .pre-footer { padding: 36px 16px 24px; }
  .pf-links-grid { grid-template-columns: 1fr; gap: 10px; }
  .pf-social { gap: 20px; font-size: 12px; }
  .blog-post-h1 { font-size: 22px; }
}

