/* =====================================================
   FASHION DESIGNING COURSE PAGE
====================================================== */

.course-page{
  background:#fff;
}

/* HERO */
/* =====================================================
   COURSE HERO - FULL WIDTH PREMIUM WITHOUT SIDE IMAGE
====================================================== */

/* =====================================================
   COURSE COMPACT HERO / BREADCRUMB STYLE
====================================================== */

.course-hero-compact{
  position: relative !important;
  padding: 145px 0 72px !important;
  color: #fff !important;
  overflow: hidden !important;
  background:
    linear-gradient(90deg, rgba(8,8,9,.96) 0%, rgba(18,18,20,.82) 52%, rgba(75,5,9,.62) 100%),
    url('../courses/fashion-bg.jpg') !important;
  background-size: cover !important;
  background-position: center right !important;
}

.course-hero-compact::before{
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background:
    radial-gradient(circle at 84% 18%, rgba(215,25,32,.24), transparent 36%),
    repeating-linear-gradient(115deg, transparent 0 92px, rgba(255,255,255,.065) 92px 93px) !important;
  pointer-events: none !important;
}

.course-hero-compact::after{
  content: "Fashion" !important;
  position: absolute !important;
  right: 5% !important;
  bottom: -28px !important;
  font-family: var(--serif) !important;
  font-size: clamp(90px, 11vw, 170px) !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  color: rgba(255,255,255,.035) !important;
  pointer-events: none !important;
}

.course-hero-compact .wrap{
  position: relative !important;
  z-index: 2 !important;
}

/* Breadcrumb */
.course-breadcrumb{
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 32px !important;
  color: rgba(255,255,255,.72) !important;
  font-size: 12px !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  font-weight: 800 !important;
}

.course-breadcrumb a{
  color: rgba(255,255,255,.72) !important;
  text-decoration: none !important;
  transition: .25s ease !important;
}

.course-breadcrumb a:hover{
  color: #fff !important;
}

.course-breadcrumb span{
  color: rgba(255,255,255,.35) !important;
}

.course-breadcrumb strong{
  color: #ff3340 !important;
  font-weight: 900 !important;
}

/* Main content */
.course-compact-content{
  display: grid !important;
  grid-template-columns: 1fr 430px !important;
  gap: 52px !important;
  align-items: end !important;
}

.course-compact-left h1{
  font-family: var(--serif) !important;
  font-size: clamp(52px, 6.4vw, 96px) !important;
  line-height: .92 !important;
  letter-spacing: -2.5px !important;
  color: #fff !important;
  margin: 18px 0 22px !important;
}

.course-compact-left h1 em{
  color: #ff3340 !important;
  font-style: italic !important;
}

.course-compact-left p{
  max-width: 820px !important;
  color: rgba(255,255,255,.78) !important;
  font-size: 16px !important;
  line-height: 1.75 !important;
  margin: 0 !important;
}

/* Right mini cards */
.course-compact-right{
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 14px !important;
}

.course-compact-card{
  min-height: 118px !important;
  padding: 22px 20px !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  background: rgba(255,255,255,.075) !important;
  backdrop-filter: blur(14px) !important;
  box-shadow: 0 18px 45px rgba(0,0,0,.12) !important;
}

.course-compact-card strong{
  display: block !important;
  font-family: var(--serif) !important;
  font-size: 36px !important;
  line-height: 1 !important;
  color: #fff !important;
  margin-bottom: 9px !important;
}

.course-compact-card span{
  display: block !important;
  color: rgba(255,255,255,.70) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  line-height: 1.35 !important;
}

.course-compact-actions{
  grid-column: 1 / -1 !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 14px !important;
}

.course-compact-actions .btn{
  height: 56px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  letter-spacing: .14em !important;
}

.btn-glass{
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.32) !important;
  background: rgba(255,255,255,.075) !important;
  backdrop-filter: blur(12px) !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  transition: .3s ease !important;
}

.btn-glass:hover{
  background: #fff !important;
  color: #111 !important;
  border-color: #fff !important;
}

/* Tags */
.course-compact-tags{
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  margin-top: 38px !important;
}

.course-compact-tags span{
  border: 1px solid rgba(255,255,255,.18) !important;
  background: rgba(255,255,255,.065) !important;
  backdrop-filter: blur(10px) !important;
  padding: 11px 14px !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,.82) !important;
}

/* Tablet */
@media(max-width: 1050px){
  .course-compact-content{
    grid-template-columns: 1fr !important;
    gap: 36px !important;
  }

  .course-compact-right{
    max-width: 520px !important;
  }
}

/* Mobile */
@media(max-width: 575px){
  .course-hero-compact{
    padding: 120px 0 58px !important;
    background-position: center !important;
  }

  .course-hero-compact::after{
    display: none !important;
  }

  .course-breadcrumb{
    margin-bottom: 24px !important;
    font-size: 10px !important;
    gap: 8px !important;
  }

  .course-compact-left h1{
    font-size: 44px !important;
    line-height: .98 !important;
    letter-spacing: -1px !important;
  }

  .course-compact-left p{
    font-size: 14.5px !important;
    line-height: 1.72 !important;
  }

  .course-compact-right,
  .course-compact-actions{
    grid-template-columns: 1fr !important;
  }

  .course-compact-card{
    min-height: auto !important;
    padding: 18px !important;
  }

  .course-compact-tags{
    margin-top: 28px !important;
  }

  .course-compact-tags span{
    width: 100% !important;
  }

  .course-compact-actions .btn{
    width: 100% !important;
  }
}

/* COMMON HEADINGS */
.course-overview-left h2,
.course-section-head h2,
.course-practical-content h2,
.course-enquiry-content h2{
  font-family:var(--serif);
  font-size:clamp(44px,5vw,78px);
  line-height:.98;
  letter-spacing:-2px;
  color:#111;
  margin:18px 0 0;
}

.course-overview-left h2 em,
.course-section-head h2 em,
.course-practical-content h2 em,
.course-enquiry-content h2 em{
  color:var(--red);
  font-style:italic;
}

/* OVERVIEW */
.course-overview{
  background:#fbfaf8;
  padding:95px 0;
}

.course-overview-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:54px;
  align-items:start;
}

.course-overview-left p{
  color:#606060;
  font-size:16px;
  line-height:1.9;
  margin:22px 0 0;
}

.course-overview-points{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}

.course-overview-points div{
  background:#fff;
  border:1px solid #eadfd7;
  border-radius:22px;
  padding:28px 24px;
  box-shadow:0 16px 45px rgba(0,0,0,.04);
}

.course-overview-points strong{
  color:var(--red);
  font-family:var(--serif);
  font-size:30px;
}

.course-overview-points h3{
  font-family:var(--serif);
  font-size:29px;
  margin:12px 0 10px;
  color:#111;
}

.course-overview-points p{
  color:#666;
  font-size:14px;
  line-height:1.7;
  margin:0;
}

/* LEARN */
.course-learn{
  background:#fff;
  padding:95px 0;
}

.course-section-head{
  display:grid;
  grid-template-columns:1fr .75fr;
  gap:54px;
  align-items:end;
  margin-bottom:46px;
}

.course-section-head p{
  color:#606060;
  font-size:16px;
  line-height:1.85;
  margin:0;
}

.course-learn-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.learn-card{
  background:#fbfaf8;
  border:1px solid #eadfd7;
  border-radius:22px;
  padding:30px 26px;
  min-height:245px;
  transition:.35s ease;
}

.learn-card:hover{
  transform:translateY(-6px);
  box-shadow:0 24px 70px rgba(0,0,0,.08);
  border-color:rgba(215,25,32,.25);
}

.learn-card span{
  width:52px;
  height:52px;
  border-radius:50%;
  background:var(--red);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--serif);
  font-size:22px;
  font-style:italic;
  margin-bottom:24px;
}

.learn-card h3{
  font-family:var(--serif);
  font-size:30px;
  color:#111;
  line-height:1.08;
  margin:0 0 10px;
}

.learn-card p{
  color:#666;
  font-size:14px;
  line-height:1.7;
  margin:0;
}

/* PRACTICAL */
.course-practical{
  background:#fbfaf8;
  padding:95px 0;
}

.course-practical-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:54px;
  align-items:center;
}

.course-practical-gallery{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}

.course-practical-gallery img{
  width:100%;
  height:300px;
  object-fit:cover;
  border-radius:18px;
  box-shadow:0 18px 50px rgba(0,0,0,.08);
}

.course-practical-gallery img:first-child{
  grid-row:span 2;
  height:616px;
}

.course-practical-content p{
  color:#606060;
  font-size:16px;
  line-height:1.9;
  margin:24px 0 28px;
}

.course-practical-content ul{
  list-style:none;
  margin:0;
  padding:0;
}

.course-practical-content li{
  position:relative;
  padding:14px 0 14px 28px;
  border-bottom:1px solid #eadfd7;
  color:#555;
  font-size:15px;
}

.course-practical-content li::before{
  content:"";
  position:absolute;
  left:0;
  top:22px;
  width:8px;
  height:8px;
  background:var(--red);
  border-radius:50%;
}

/* CAREER */
.course-career{
  background:#fff;
  padding:95px 0;
}

.course-career-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}

.course-career-grid div{
  background:#fbfaf8;
  border:1px solid #eadfd7;
  border-radius:18px;
  padding:22px 24px;
  position:relative;
  overflow:hidden;
}

.course-career-grid div::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:4px;
  height:100%;
  background:var(--red);
}

.course-career-grid span{
  font-family:var(--serif);
  font-size:25px;
  color:#111;
  font-weight:700;
}

/* ENQUIRY */
.course-enquiry{
  background:linear-gradient(135deg,#111,#2b0508);
  padding:85px 0;
  color:#fff;
}

.course-enquiry-grid{
  display:grid;
  grid-template-columns:.82fr 1.18fr;
  gap:54px;
  align-items:center;
}

.course-enquiry-content h2{
  color:#fff;
}

.course-enquiry-content p{
  color:rgba(255,255,255,.74);
  font-size:16px;
  line-height:1.85;
  margin:22px 0 0;
}

.course-form{
  background:#fff;
  border-radius:26px;
  padding:36px;
}

.course-form .form-row{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}

.course-form input,
.course-form select,
.course-form textarea{
  width:100%;
  border:1px solid #eadfd7;
  border-radius:14px;
  background:#fbfaf8;
  padding:0 16px;
  font-size:15px;
  margin-bottom:16px;
  outline:none;
}

.course-form input,
.course-form select{
  height:56px;
}

.course-form textarea{
  min-height:120px;
  padding-top:15px;
  resize:vertical;
}

.course-form .btn{
  width:100%;
  height:58px;
  border-radius:14px;
}

/* RESPONSIVE */
@media(max-width:1200px){
  .course-learn-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .course-career-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media(max-width:1024px){
  .course-hero-grid,
  .course-overview-grid,
  .course-section-head,
  .course-practical-grid,
  .course-enquiry-grid{
    grid-template-columns:1fr;
  }

  .course-hero-visual{
    order:-1;
    min-height:460px;
  }
}

@media(max-width:768px){
  .course-hero{
    min-height:auto;
    padding:120px 0 70px;
  }

  .course-hero h1{
    font-size:52px;
    letter-spacing:-1px;
  }

  .course-overview,
  .course-learn,
  .course-practical,
  .course-career{
    padding:75px 0;
  }

  .course-overview-points,
  .course-learn-grid,
  .course-career-grid{
    grid-template-columns:1fr;
  }

  .course-practical-gallery img,
  .course-practical-gallery img:first-child{
    height:320px;
    grid-row:auto;
  }

  .course-form .form-row{
    grid-template-columns:1fr;
    gap:0;
  }
}

@media(max-width:480px){
  .course-hero h1{
    font-size:44px;
  }

  .course-hero-tags span{
    width:100%;
  }

  .course-hero-visual{
    min-height:380px;
  }

  .course-main-img{
    width:88%;
    height:260px;
  }

  .course-info-box{
    width:240px;
    padding:22px;
  }

  .course-form{
    padding:24px 18px;
  }
}

/* show case */

/* =====================================================
   FRESH STUDENT SHOWCASE - COURSE PAGE
====================================================== */

.course-showcase-fresh{
  background:#fbfaf8;
  padding:95px 0;
  overflow:hidden;
}

.fresh-showcase-grid{
  display:grid;
  grid-template-columns:1fr 1.05fr;
  gap:24px;
  align-items:stretch;
}

/* Left Big Video */
.fresh-showcase-main{
  position:relative;
  min-height:620px;
  border-radius:28px;
  overflow:hidden;
  background:#111;
  box-shadow:0 22px 70px rgba(0,0,0,.10);
}

.fresh-showcase-main video,
.fresh-showcase-main img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  display:block;
  opacity:.9;
}

.fresh-showcase-main::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.05) 25%, rgba(0,0,0,.82) 100%);
  pointer-events:none;
}

.fresh-main-content{
  position:absolute;
  left:34px;
  right:34px;
  bottom:34px;
  z-index:2;
  color:#fff;
}

.fresh-main-content span{
  display:inline-block;
  color:#ff4b52;
  font-size:12px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-bottom:14px;
}

.fresh-main-content h3{
  font-family:var(--serif);
  font-size:clamp(38px,4vw,62px);
  line-height:1;
  color:#fff;
  margin:0 0 14px;
}

.fresh-main-content p{
  color:rgba(255,255,255,.76);
  font-size:15px;
  line-height:1.75;
  max-width:560px;
  margin:0;
}

/* Right Cards */
.fresh-showcase-cards{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:20px;
}

.fresh-showcase-card{
  position:relative;
  min-height:300px;
  border-radius:24px;
  overflow:hidden;
  background:#111;
  box-shadow:0 18px 55px rgba(0,0,0,.08);
}

.fresh-showcase-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  display:block;
  opacity:.9;
  transition:.5s ease;
}

.fresh-showcase-card:hover img{
  transform:scale(1.07);
  opacity:.75;
}

.fresh-showcase-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.03) 35%, rgba(0,0,0,.78) 100%);
  pointer-events:none;
}

.fresh-showcase-card div{
  position:absolute;
  left:24px;
  right:24px;
  bottom:24px;
  z-index:2;
  color:#fff;
}

.fresh-showcase-card span{
  display:inline-block;
  color:#ff4b52;
  font-size:11px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:10px;
}

.fresh-showcase-card h3{
  font-family:var(--serif);
  font-size:32px;
  line-height:1.05;
  color:#fff;
  margin:0;
}

/* Bottom Card */
.fresh-showcase-bottom{
  margin-top:24px;
  background:linear-gradient(135deg,#111,#2b0508);
  border-radius:28px;
  padding:36px 40px;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:34px;
}

.fresh-showcase-bottom span{
  display:inline-block;
  color:#ff4b52;
  font-size:12px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-bottom:12px;
}

.fresh-showcase-bottom h3{
  font-family:var(--serif);
  font-size:42px;
  line-height:1.05;
  color:#fff;
  margin:0 0 10px;
}

.fresh-showcase-bottom p{
  color:rgba(255,255,255,.72);
  font-size:15px;
  line-height:1.75;
  max-width:760px;
  margin:0;
}

.fresh-showcase-bottom .btn{
  flex-shrink:0;
}

/* Large Screen */
@media(min-width:1600px){
  .fresh-showcase-main{
    min-height:700px;
  }

  .fresh-showcase-card{
    min-height:340px;
  }
}

/* Tablet */
@media(max-width:1050px){
  .fresh-showcase-grid{
    grid-template-columns:1fr;
  }

  .fresh-showcase-main{
    min-height:520px;
  }

  .fresh-showcase-bottom{
    flex-direction:column;
    align-items:flex-start;
  }
}

/* Mobile */
@media(max-width:575px){
  .course-showcase-fresh{
    padding:75px 0;
  }

  .fresh-showcase-main{
    min-height:430px;
    border-radius:22px;
  }

  .fresh-main-content{
    left:22px;
    right:22px;
    bottom:22px;
  }

  .fresh-main-content h3{
    font-size:34px;
  }

  .fresh-showcase-cards{
    grid-template-columns:1fr;
    gap:16px;
  }

  .fresh-showcase-card{
    min-height:320px;
    border-radius:20px;
  }

  .fresh-showcase-card h3{
    font-size:29px;
  }

  .fresh-showcase-bottom{
    padding:28px 22px;
    border-radius:22px;
  }

  .fresh-showcase-bottom h3{
    font-size:31px;
  }

  .fresh-showcase-bottom .btn{
    width:100%;
  }
}


/* interior page  */
/* =====================================================
   INTERIOR DESIGNING COURSE PAGE
====================================================== */

.interior-hero{
  background:
    linear-gradient(90deg, rgba(8,8,9,.96) 0%, rgba(18,18,20,.80) 52%, rgba(92,54,22,.55) 100%),
    url('../courses/Interior-bg.webp') !important;
  background-size: cover !important;
  background-position: center right !important;
}

.interior-hero::before{
  background:
    radial-gradient(circle at 84% 18%, rgba(185,120,62,.28), transparent 36%),
    repeating-linear-gradient(115deg, transparent 0 92px, rgba(255,255,255,.065) 92px 93px) !important;
}

.interior-hero::after{
  content: "Interior" !important;
}

/* Interior page warm accent on selected showcase areas */
.interior-course-page .fresh-showcase-bottom{
  background: linear-gradient(135deg, #111, #3a1f0f) !important;
}

.interior-course-page .course-enquiry{
  background: linear-gradient(135deg, #111, #3a1f0f) !important;
}


/* =====================================================
   APPAREL MERCHANDISING COURSE PAGE
====================================================== */

.apparel-hero{
  background:
    linear-gradient(90deg, rgba(8,8,9,.96) 0%, rgba(18,18,20,.82) 52%, rgba(102,22,12,.58) 100%),
    url('../courses/apparel-bg.jpg') !important;
  background-size: cover !important;
  background-position: center right !important;
}

.apparel-hero::before{
  background:
    radial-gradient(circle at 84% 18%, rgba(215,90,35,.28), transparent 36%),
    repeating-linear-gradient(115deg, transparent 0 92px, rgba(255,255,255,.065) 92px 93px) !important;
}

.apparel-hero::after{
  content: "Apparel" !important;
}

.apparel-course-page .fresh-showcase-bottom{
  background: linear-gradient(135deg, #111, #3a120b) !important;
}

.apparel-course-page .course-enquiry{
  background: linear-gradient(135deg, #111, #3a120b) !important;
}

/* =====================================================
   TEXTILE DESIGN COURSE PAGE
====================================================== */

.textile-hero{
  background:
    linear-gradient(90deg, rgba(8,8,9,.96) 0%, rgba(18,18,20,.82) 52%, rgba(35,76,55,.58) 100%),
    url('../courses/textile.jpg') !important;
  background-size: cover !important;
  background-position: center right !important;
}

.textile-hero::before{
  background:
    radial-gradient(circle at 84% 18%, rgba(46,130,88,.30), transparent 36%),
    repeating-linear-gradient(115deg, transparent 0 92px, rgba(255,255,255,.065) 92px 93px) !important;
}

.textile-hero::after{
  content: "Textile" !important;
}

.textile-course-page .fresh-showcase-bottom{
  background: linear-gradient(135deg, #111, #123020) !important;
}

.textile-course-page .course-enquiry{
  background: linear-gradient(135deg, #111, #123020) !important;
}

/* =====================================================
   FINE ART COURSE PAGE
====================================================== */

.fineart-hero{
  background:
    linear-gradient(90deg, rgba(8,8,9,.96) 0%, rgba(18,18,20,.82) 52%, rgba(106,58,20,.58) 100%),
    url('https://images.unsplash.com/photo-1513364776144-60967b0f800f?q=80&w=1600&auto=format&fit=crop') !important;
  background-size: cover !important;
  background-position: center right !important;
}

.fineart-hero::before{
  background:
    radial-gradient(circle at 84% 18%, rgba(230,128,45,.30), transparent 36%),
    repeating-linear-gradient(115deg, transparent 0 92px, rgba(255,255,255,.065) 92px 93px) !important;
}

.fineart-hero::after{
  content: "Fine Art" !important;
}

.fineart-course-page .fresh-showcase-bottom{
  background: linear-gradient(135deg, #111, #3a1f0a) !important;
}

.fineart-course-page .course-enquiry{
  background: linear-gradient(135deg, #111, #3a1f0a) !important;
}

/* =====================================================
   BOUTIQUE MANAGEMENT COURSE PAGE
====================================================== */

.boutique-hero{
  background:
    linear-gradient(90deg, rgba(8,8,9,.96) 0%, rgba(18,18,20,.82) 52%, rgba(86,20,40,.60) 100%),
    url('https://images.unsplash.com/photo-1441986300917-64674bd600d8?q=80&w=1600&auto=format&fit=crop') !important;
  background-size: cover !important;
  background-position: center right !important;
}

.boutique-hero::before{
  background:
    radial-gradient(circle at 84% 18%, rgba(215,25,98,.26), transparent 36%),
    repeating-linear-gradient(115deg, transparent 0 92px, rgba(255,255,255,.065) 92px 93px) !important;
}

.boutique-hero::after{
  content: "Boutique" !important;
}


/* INTRO SECTION */
.boutique-intro{
  background:#fbfaf8;
  padding:95px 0;
  overflow:hidden;
}

.boutique-intro-grid{
  display:grid;
  grid-template-columns:.9fr 1fr;
  gap:60px;
  align-items:center;
}

.boutique-intro-image{
  position:relative;
  min-height:620px;
  border-radius:34px;
  overflow:hidden;
  background:#111;
  box-shadow:0 28px 80px rgba(0,0,0,.12);
}

.boutique-intro-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}

.boutique-floating-box{
  position:absolute;
  left:28px;
  right:28px;
  bottom:28px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
  padding:24px 26px;
  border-left:5px solid var(--red);
}

.boutique-floating-box strong{
  display:block;
  font-family:var(--serif);
  font-size:42px;
  line-height:1;
  color:#111;
  margin-bottom:7px;
}

.boutique-floating-box span{
  color:#555;
  font-size:12px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.boutique-intro-content h2{
  font-family:var(--serif);
  font-size:clamp(42px,5vw,76px);
  line-height:.98;
  letter-spacing:-2px;
  color:#111;
  margin:18px 0 24px;
}

.boutique-intro-content h2 em{
  color:var(--red);
  font-style:italic;
}

.boutique-intro-content p{
  color:#595959;
  font-size:16px;
  line-height:1.85;
  margin:0 0 18px;
}

.boutique-intro-points{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:34px;
}

.boutique-intro-points div{
  background:#fff;
  border:1px solid #eadfd7;
  padding:28px 26px;
  box-shadow:0 18px 45px rgba(0,0,0,.05);
}

.boutique-intro-points span{
  display:block;
  color:var(--red);
  font-size:13px;
  font-weight:900;
  letter-spacing:.16em;
  margin-bottom:18px;
}

.boutique-intro-points h3{
  font-family:var(--serif);
  font-size:30px;
  color:#111;
  margin:0 0 10px;
}

.boutique-intro-points p{
  font-size:14px;
  line-height:1.7;
  margin:0;
}


/* BUSINESS STRIP */
.boutique-business-strip{
  background:#111;
  padding:90px 0;
  color:#fff;
  overflow:hidden;
}

.boutique-strip-head{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:40px;
  margin-bottom:42px;
}

.boutique-strip-head h2{
  font-family:var(--serif);
  font-size:clamp(40px,5vw,72px);
  line-height:.98;
  letter-spacing:-2px;
  color:#fff;
  margin:16px 0 0;
  max-width:850px;
}

.boutique-strip-head h2 em{
  color:#ff3340;
  font-style:italic;
}

.boutique-business-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

.boutique-business-card{
  min-height:285px;
  padding:34px 28px;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.12);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  transition:.35s ease;
}

.boutique-business-card:hover{
  transform:translateY(-6px);
  background:linear-gradient(180deg,rgba(215,25,32,.28),rgba(255,255,255,.05));
}

.boutique-business-card span{
  color:#ff3340;
  font-size:13px;
  font-weight:900;
  letter-spacing:.16em;
  margin-bottom:auto;
}

.boutique-business-card h3{
  font-family:var(--serif);
  font-size:34px;
  line-height:1.02;
  color:#fff;
  margin:0 0 12px;
}

.boutique-business-card p{
  color:rgba(255,255,255,.68);
  font-size:14px;
  line-height:1.7;
  margin:0;
}


/* SHOWCASE DIFFERENT LAYOUT */
.boutique-showcase{
  background:#fbfaf8;
  padding:100px 0;
  overflow:hidden;
}

.boutique-showcase-head{
  display:grid;
  grid-template-columns:1fr .75fr;
  gap:60px;
  align-items:end;
  margin-bottom:48px;
}

.boutique-showcase-head h2{
  font-family:var(--serif);
  font-size:clamp(42px,5vw,76px);
  line-height:.98;
  letter-spacing:-2px;
  color:#111;
  margin:16px 0 0;
}

.boutique-showcase-head h2 em{
  color:var(--red);
  font-style:italic;
}

.boutique-showcase-head p{
  color:#606060;
  font-size:16px;
  line-height:1.8;
  margin:0;
}

.boutique-showcase-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
}

.boutique-showcase-left,
.boutique-mini-card{
  position:relative;
  overflow:hidden;
  background:#111;
  border-radius:28px;
  box-shadow:0 20px 60px rgba(0,0,0,.08);
}

.boutique-showcase-left{
  min-height:640px;
}

.boutique-showcase-left img,
.boutique-mini-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  opacity:.9;
  transition:.55s ease;
}

.boutique-showcase-left:hover img,
.boutique-mini-card:hover img{
  transform:scale(1.07);
  opacity:.75;
}

.boutique-showcase-left::after,
.boutique-mini-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.03) 35%,rgba(0,0,0,.78) 100%);
  pointer-events:none;
}

.boutique-showcase-left > div,
.boutique-mini-card > div{
  position:absolute;
  left:28px;
  right:28px;
  bottom:28px;
  z-index:2;
  color:#fff;
}

.boutique-showcase-left span,
.boutique-mini-card span{
  display:inline-block;
  color:#ff4b52;
  font-size:12px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:12px;
}

.boutique-showcase-left h3{
  font-family:var(--serif);
  font-size:clamp(38px,4vw,62px);
  line-height:1;
  color:#fff;
  margin:0;
}

.boutique-showcase-right{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
}

.boutique-mini-card{
  min-height:309px;
}

.boutique-mini-card.wide{
  grid-column:1 / -1;
}

.boutique-mini-card h3{
  font-family:var(--serif);
  font-size:32px;
  line-height:1.05;
  color:#fff;
  margin:0;
}


/* PAGE ACCENTS */
.boutique-course-page .boutique-enquiry{
  background:linear-gradient(135deg,#111,#3c0c20) !important;
}

.boutique-course-page .boutique-career{
  background:#fff;
}


/* RESPONSIVE */
@media(max-width:1050px){
  .boutique-intro-grid,
  .boutique-showcase-head,
  .boutique-showcase-layout{
    grid-template-columns:1fr;
  }

  .boutique-intro-image{
    min-height:520px;
  }

  .boutique-business-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .boutique-showcase-left{
    min-height:520px;
  }
}

@media(max-width:575px){
  .boutique-intro,
  .boutique-business-strip,
  .boutique-showcase{
    padding:75px 0;
  }

  .boutique-intro-image{
    min-height:430px;
    border-radius:22px;
  }

  .boutique-floating-box{
    left:18px;
    right:18px;
    bottom:18px;
    padding:20px;
  }

  .boutique-floating-box strong{
    font-size:34px;
  }

  .boutique-intro-points,
  .boutique-business-grid,
  .boutique-showcase-right{
    grid-template-columns:1fr;
  }

  .boutique-business-card{
    min-height:230px;
  }

  .boutique-showcase-left,
  .boutique-mini-card{
    min-height:360px;
    border-radius:22px;
  }

  .boutique-showcase-left h3{
    font-size:34px;
  }

  .boutique-mini-card h3{
    font-size:28px;
  }
}

/* BUSINESS STRIP FIXED - NO LEFT EMPTY SPACE */
.boutique-business-strip{
  background:#0d0d0d !important;
  padding:85px 0 !important;
  color:#fff !important;
  overflow:hidden !important;
}

.boutique-business-layout{
  display:grid !important;
  grid-template-columns:360px 1fr !important;
  gap:42px !important;
  align-items:stretch !important;
}

.boutique-strip-head{
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  gap:0 !important;
  margin:0 !important;
  padding:38px 34px !important;
  background:linear-gradient(180deg, rgba(215,25,32,.18), rgba(255,255,255,.04)) !important;
  border:1px solid rgba(255,255,255,.12) !important;
}

.boutique-strip-head .eyebrow{
  margin-bottom:22px !important;
}

.boutique-strip-head h2{
  font-family:var(--serif) !important;
  font-size:clamp(42px,4.2vw,68px) !important;
  line-height:.98 !important;
  letter-spacing:-2px !important;
  color:#fff !important;
  margin:0 0 20px !important;
  max-width:100% !important;
}

.boutique-strip-head h2 em{
  color:#ff3340 !important;
  font-style:italic !important;
}

.boutique-strip-head p{
  color:rgba(255,255,255,.70) !important;
  font-size:15px !important;
  line-height:1.75 !important;
  margin:0 !important;
}

.boutique-business-grid{
  display:grid !important;
  grid-template-columns:repeat(2,1fr) !important;
  gap:18px !important;
}

.boutique-business-card{
  min-height:260px !important;
  padding:32px 30px !important;
  background:linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.035)) !important;
  border:1px solid rgba(255,255,255,.12) !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:flex-end !important;
  transition:.35s ease !important;
}

.boutique-business-card:hover{
  transform:translateY(-6px) !important;
  background:linear-gradient(180deg,rgba(215,25,32,.28),rgba(255,255,255,.05)) !important;
}

.boutique-business-card span{
  color:#ff3340 !important;
  font-size:13px !important;
  font-weight:900 !important;
  letter-spacing:.16em !important;
  margin-bottom:auto !important;
}

.boutique-business-card h3{
  font-family:var(--serif) !important;
  font-size:36px !important;
  line-height:1.02 !important;
  color:#fff !important;
  margin:0 0 12px !important;
}

.boutique-business-card p{
  color:rgba(255,255,255,.68) !important;
  font-size:14px !important;
  line-height:1.7 !important;
  margin:0 !important;
}

/* Tablet */
@media(max-width:1050px){
  .boutique-business-layout{
    grid-template-columns:1fr !important;
  }

  .boutique-strip-head{
    padding:34px 28px !important;
  }

  .boutique-business-grid{
    grid-template-columns:repeat(2,1fr) !important;
  }
}

/* Mobile */
@media(max-width:575px){
  .boutique-business-strip{
    padding:70px 0 !important;
  }

  .boutique-business-layout{
    gap:22px !important;
  }

  .boutique-strip-head{
    padding:28px 22px !important;
  }

  .boutique-strip-head h2{
    font-size:36px !important;
    letter-spacing:-1px !important;
  }

  .boutique-business-grid{
    grid-template-columns:1fr !important;
  }

  .boutique-business-card{
    min-height:220px !important;
    padding:28px 24px !important;
  }

  .boutique-business-card h3{
    font-size:30px !important;
  }
} 

/* =====================================================
   MAKEUP & MODELLING COURSE PAGE
====================================================== */

.makeup-hero{
  background:
    linear-gradient(90deg, rgba(8,8,9,.96) 0%, rgba(18,18,20,.82) 52%, rgba(92,18,48,.60) 100%),
    url('https://images.unsplash.com/photo-1522335789203-aabd1fc54bc9?q=80&w=1600&auto=format&fit=crop') !important;
  background-size: cover !important;
  background-position: center right !important;
}

.makeup-hero::before{
  background:
    radial-gradient(circle at 84% 18%, rgba(215,25,110,.28), transparent 36%),
    repeating-linear-gradient(115deg, transparent 0 92px, rgba(255,255,255,.065) 92px 93px) !important;
}

.makeup-hero::after{
  content:"Makeup" !important;
}


/* INTRO */
.makeup-intro{
  background:#fbfaf8;
  padding:95px 0;
  overflow:hidden;
}

.makeup-intro-grid{
  display:grid;
  grid-template-columns:1fr .9fr;
  gap:60px;
  align-items:center;
}

.makeup-intro-content h2{
  font-family:var(--serif);
  font-size:clamp(42px,5vw,76px);
  line-height:.98;
  letter-spacing:-2px;
  color:#111;
  margin:18px 0 24px;
}

.makeup-intro-content h2 em{
  color:var(--red);
  font-style:italic;
}

.makeup-intro-content p{
  color:#595959;
  font-size:16px;
  line-height:1.85;
  margin:0 0 18px;
}

.makeup-intro-points{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:34px;
}

.makeup-intro-points div{
  background:#fff;
  border:1px solid #eadfd7;
  padding:28px 26px;
  box-shadow:0 18px 45px rgba(0,0,0,.05);
}

.makeup-intro-points span{
  display:block;
  color:var(--red);
  font-size:13px;
  font-weight:900;
  letter-spacing:.16em;
  margin-bottom:18px;
}

.makeup-intro-points h3{
  font-family:var(--serif);
  font-size:30px;
  color:#111;
  margin:0 0 10px;
}

.makeup-intro-points p{
  font-size:14px;
  line-height:1.7;
  margin:0;
}

.makeup-intro-image{
  position:relative;
  min-height:610px;
  border-radius:34px;
  overflow:hidden;
  background:#111;
  box-shadow:0 28px 80px rgba(0,0,0,.12);
}

.makeup-intro-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}

.makeup-floating-card{
  position:absolute;
  left:28px;
  right:28px;
  bottom:28px;
  padding:24px 26px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
  border-left:5px solid var(--red);
}

.makeup-floating-card strong{
  display:block;
  font-family:var(--serif);
  font-size:42px;
  line-height:1;
  color:#111;
  margin-bottom:7px;
}

.makeup-floating-card span{
  color:#555;
  font-size:12px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
}


/* SKILLS STRIP */
.makeup-skills-strip{
  background:#111;
  padding:90px 0;
  color:#fff;
  overflow:hidden;
}

.makeup-strip-head{
  display:grid;
  grid-template-columns:1fr .72fr;
  gap:60px;
  align-items:end;
  margin-bottom:44px;
}

.makeup-strip-head h2{
  font-family:var(--serif);
  font-size:clamp(40px,5vw,72px);
  line-height:.98;
  letter-spacing:-2px;
  color:#fff;
  margin:16px 0 0;
}

.makeup-strip-head h2 em{
  color:#ff3340;
  font-style:italic;
}

.makeup-strip-head p{
  color:rgba(255,255,255,.70);
  font-size:16px;
  line-height:1.8;
  margin:0;
}

.makeup-skill-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

.makeup-skill-card{
  min-height:285px;
  padding:34px 28px;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.12);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  transition:.35s ease;
}

.makeup-skill-card:hover{
  transform:translateY(-6px);
  background:linear-gradient(180deg,rgba(215,25,90,.28),rgba(255,255,255,.05));
}

.makeup-skill-card span{
  color:#ff3340;
  font-size:13px;
  font-weight:900;
  letter-spacing:.16em;
  margin-bottom:auto;
}

.makeup-skill-card h3{
  font-family:var(--serif);
  font-size:34px;
  line-height:1.02;
  color:#fff;
  margin:0 0 12px;
}

.makeup-skill-card p{
  color:rgba(255,255,255,.68);
  font-size:14px;
  line-height:1.7;
  margin:0;
}


/* SHOWCASE */
.makeup-showcase{
  background:#fbfaf8;
  padding:100px 0;
  overflow:hidden;
}

.makeup-showcase-head{
  display:grid;
  grid-template-columns:1fr .75fr;
  gap:60px;
  align-items:end;
  margin-bottom:48px;
}

.makeup-showcase-head h2{
  font-family:var(--serif);
  font-size:clamp(42px,5vw,76px);
  line-height:.98;
  letter-spacing:-2px;
  color:#111;
  margin:16px 0 0;
}

.makeup-showcase-head h2 em{
  color:var(--red);
  font-style:italic;
}

.makeup-showcase-head p{
  color:#606060;
  font-size:16px;
  line-height:1.8;
  margin:0;
}

.makeup-showcase-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr .9fr;
  grid-auto-rows:310px;
  gap:20px;
}

.makeup-showcase-main,
.makeup-showcase-card{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  background:#111;
  box-shadow:0 20px 60px rgba(0,0,0,.08);
}

.makeup-showcase-main{
  grid-row:span 2;
}

.makeup-showcase-card.wide{
  grid-column:span 2;
}

.makeup-showcase-main img,
.makeup-showcase-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  opacity:.9;
  transition:.55s ease;
}

.makeup-showcase-main:hover img,
.makeup-showcase-card:hover img{
  transform:scale(1.07);
  opacity:.75;
}

.makeup-showcase-main::after,
.makeup-showcase-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.03) 35%,rgba(0,0,0,.78) 100%);
  pointer-events:none;
}

.makeup-showcase-main > div,
.makeup-showcase-card > div{
  position:absolute;
  left:28px;
  right:28px;
  bottom:28px;
  z-index:2;
  color:#fff;
}

.makeup-showcase-main span,
.makeup-showcase-card span{
  display:inline-block;
  color:#ff4b52;
  font-size:12px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:12px;
}

.makeup-showcase-main h3{
  font-family:var(--serif);
  font-size:clamp(38px,4vw,62px);
  line-height:1;
  color:#fff;
  margin:0;
}

.makeup-showcase-card h3{
  font-family:var(--serif);
  font-size:32px;
  line-height:1.05;
  color:#fff;
  margin:0;
}


/* PAGE ACCENTS */
.makeup-course-page .makeup-enquiry{
  background:linear-gradient(135deg,#111,#3c0c24) !important;
}

.makeup-course-page .makeup-career{
  background:#fff;
}


/* RESPONSIVE */
@media(max-width:1050px){
  .makeup-intro-grid,
  .makeup-strip-head,
  .makeup-showcase-head{
    grid-template-columns:1fr;
  }

  .makeup-intro-image{
    min-height:520px;
  }

  .makeup-skill-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .makeup-showcase-grid{
    grid-template-columns:repeat(2,1fr);
    grid-auto-rows:300px;
  }

  .makeup-showcase-main{
    grid-row:span 1;
  }
}

@media(max-width:575px){
  .makeup-intro,
  .makeup-skills-strip,
  .makeup-showcase{
    padding:75px 0;
  }

  .makeup-intro-image{
    min-height:430px;
    border-radius:22px;
  }

  .makeup-floating-card{
    left:18px;
    right:18px;
    bottom:18px;
    padding:20px;
  }

  .makeup-floating-card strong{
    font-size:34px;
  }

  .makeup-intro-points,
  .makeup-skill-grid,
  .makeup-showcase-grid{
    grid-template-columns:1fr;
  }

  .makeup-skill-card{
    min-height:230px;
  }

  .makeup-showcase-main,
  .makeup-showcase-card,
  .makeup-showcase-card.wide{
    grid-column:span 1;
    grid-row:span 1;
    min-height:360px;
    border-radius:22px;
  }

  .makeup-showcase-main h3{
    font-size:34px;
  }

  .makeup-showcase-card h3{
    font-size:28px;
  }
}

/* =====================================================
   VISUAL MERCHANDISING COURSE PAGE
====================================================== */

.visual-hero{
  background:
    linear-gradient(90deg, rgba(8,8,9,.96) 0%, rgba(18,18,20,.82) 52%, rgba(72,38,16,.60) 100%),
    url('https://images.unsplash.com/photo-1481437156560-3205f6a55735?q=80&w=1600&auto=format&fit=crop') !important;
  background-size: cover !important;
  background-position: center right !important;
}

.visual-hero::before{
  background:
    radial-gradient(circle at 84% 18%, rgba(205,112,45,.28), transparent 36%),
    repeating-linear-gradient(115deg, transparent 0 92px, rgba(255,255,255,.065) 92px 93px) !important;
}

.visual-hero::after{
  content:"Visual" !important;
}


/* OVERVIEW */
.visual-overview{
  background:#fbfaf8;
  padding:95px 0;
  overflow:hidden;
}

.visual-overview-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}

.visual-overview-content h2{
  font-family:var(--serif);
  font-size:clamp(42px,5vw,76px);
  line-height:.98;
  letter-spacing:-2px;
  color:#111;
  margin:18px 0 24px;
}

.visual-overview-content h2 em{
  color:var(--red);
  font-style:italic;
}

.visual-overview-content p{
  color:#595959;
  font-size:16px;
  line-height:1.85;
  margin:0 0 18px;
}

.visual-overview-features{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:34px;
}

.visual-overview-features div{
  background:#fff;
  border:1px solid #eadfd7;
  padding:28px 26px;
  box-shadow:0 18px 45px rgba(0,0,0,.05);
}

.visual-overview-features span{
  display:block;
  color:var(--red);
  font-size:13px;
  font-weight:900;
  letter-spacing:.16em;
  margin-bottom:18px;
}

.visual-overview-features h3{
  font-family:var(--serif);
  font-size:30px;
  color:#111;
  margin:0 0 10px;
}

.visual-overview-features p{
  font-size:14px;
  line-height:1.7;
  margin:0;
}

.visual-overview-showcase{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
}

.visual-main-display{
  position:relative;
  min-height:430px;
  border-radius:30px;
  overflow:hidden;
  background:#111;
  box-shadow:0 26px 80px rgba(0,0,0,.12);
}

.visual-main-display img,
.visual-small-displays img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}

.visual-main-display::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.04) 35%,rgba(0,0,0,.76) 100%);
}

.visual-main-display div{
  position:absolute;
  left:28px;
  right:28px;
  bottom:28px;
  z-index:2;
  color:#fff;
}

.visual-main-display span{
  display:inline-block;
  color:#ff4b52;
  font-size:12px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:12px;
}

.visual-main-display h3{
  font-family:var(--serif);
  font-size:44px;
  line-height:1;
  color:#fff;
  margin:0;
}

.visual-small-displays{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}

.visual-small-displays img{
  height:210px;
  border-radius:24px;
  box-shadow:0 18px 50px rgba(0,0,0,.08);
}


/* SKILLS SECTION */
.visual-skills-section{
  background:#111;
  color:#fff;
  padding:90px 0;
  overflow:hidden;
}

.visual-skills-head{
  display:grid;
  grid-template-columns:1fr .72fr;
  gap:60px;
  align-items:end;
  margin-bottom:44px;
}

.visual-skills-head h2{
  font-family:var(--serif);
  font-size:clamp(40px,5vw,72px);
  line-height:.98;
  letter-spacing:-2px;
  color:#fff;
  margin:16px 0 0;
}

.visual-skills-head h2 em{
  color:#ff3340;
  font-style:italic;
}

.visual-skills-head p{
  color:rgba(255,255,255,.70);
  font-size:16px;
  line-height:1.8;
  margin:0;
}

.visual-skills-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

.visual-skill-card{
  min-height:285px;
  padding:34px 28px;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.12);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  transition:.35s ease;
}

.visual-skill-card:hover{
  transform:translateY(-6px);
  background:linear-gradient(180deg,rgba(215,25,32,.28),rgba(255,255,255,.05));
}

.visual-skill-card span{
  color:#ff3340;
  font-size:13px;
  font-weight:900;
  letter-spacing:.16em;
  margin-bottom:auto;
}

.visual-skill-card h3{
  font-family:var(--serif);
  font-size:34px;
  line-height:1.02;
  color:#fff;
  margin:0 0 12px;
}

.visual-skill-card p{
  color:rgba(255,255,255,.68);
  font-size:14px;
  line-height:1.7;
  margin:0;
}


/* PRACTICAL */
.visual-practical{
  background:#fff;
  padding:95px 0;
  overflow:hidden;
}

.visual-practical-grid{
  display:grid;
  grid-template-columns:.82fr 1fr;
  gap:60px;
  align-items:center;
}

.visual-practical-left h2{
  font-family:var(--serif);
  font-size:clamp(42px,5vw,76px);
  line-height:.98;
  letter-spacing:-2px;
  color:#111;
  margin:18px 0 24px;
}

.visual-practical-left h2 em{
  color:var(--red);
  font-style:italic;
}

.visual-practical-left p{
  color:#595959;
  font-size:16px;
  line-height:1.85;
  margin:0 0 24px;
}

.visual-practical-left ul{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:14px;
}

.visual-practical-left li{
  position:relative;
  padding-left:28px;
  color:#333;
  font-size:15px;
  line-height:1.5;
  font-weight:700;
}

.visual-practical-left li::before{
  content:"";
  position:absolute;
  left:0;
  top:9px;
  width:10px;
  height:10px;
  background:var(--red);
}

.visual-practical-images{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}

.vp-img{
  height:290px;
  overflow:hidden;
  border-radius:24px;
  background:#111;
  box-shadow:0 18px 55px rgba(0,0,0,.08);
}

.vp-img.vp-large{
  grid-column:1 / -1;
  height:360px;
}

.vp-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}


/* SHOWCASE */
.visual-showcase{
  background:#fbfaf8;
  padding:100px 0;
  overflow:hidden;
}

.visual-showcase-head{
  display:grid;
  grid-template-columns:1fr .75fr;
  gap:60px;
  align-items:end;
  margin-bottom:48px;
}

.visual-showcase-head h2{
  font-family:var(--serif);
  font-size:clamp(42px,5vw,76px);
  line-height:.98;
  letter-spacing:-2px;
  color:#111;
  margin:16px 0 0;
}

.visual-showcase-head h2 em{
  color:var(--red);
  font-style:italic;
}

.visual-showcase-head p{
  color:#606060;
  font-size:16px;
  line-height:1.8;
  margin:0;
}

.visual-showcase-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  grid-auto-rows:310px;
  gap:20px;
}

.visual-showcase-card{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  background:#111;
  box-shadow:0 20px 60px rgba(0,0,0,.08);
}

.visual-showcase-card.tall{
  grid-row:span 2;
}

.visual-showcase-card.wide{
  grid-column:span 2;
}

.visual-showcase-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  opacity:.9;
  transition:.55s ease;
}

.visual-showcase-card:hover img{
  transform:scale(1.07);
  opacity:.75;
}

.visual-showcase-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.03) 35%,rgba(0,0,0,.78) 100%);
  pointer-events:none;
}

.visual-showcase-card > div{
  position:absolute;
  left:28px;
  right:28px;
  bottom:28px;
  z-index:2;
  color:#fff;
}

.visual-showcase-card span{
  display:inline-block;
  color:#ff4b52;
  font-size:12px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:12px;
}

.visual-showcase-card h3{
  font-family:var(--serif);
  font-size:34px;
  line-height:1.05;
  color:#fff;
  margin:0;
}

.visual-showcase-card.tall h3,
.visual-showcase-card.wide h3{
  font-size:clamp(36px,4vw,56px);
  line-height:1;
}


/* PAGE ACCENTS */
.visual-course-page .visual-enquiry{
  background:linear-gradient(135deg,#111,#3a1e0c) !important;
}

.visual-course-page .visual-career{
  background:#fff;
}


/* RESPONSIVE */
@media(max-width:1050px){
  .visual-overview-grid,
  .visual-skills-head,
  .visual-practical-grid,
  .visual-showcase-head{
    grid-template-columns:1fr;
  }

  .visual-skills-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .visual-showcase-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .visual-showcase-card.tall{
    grid-row:span 1;
  }
}

@media(max-width:575px){
  .visual-overview,
  .visual-skills-section,
  .visual-practical,
  .visual-showcase{
    padding:75px 0;
  }

  .visual-overview-features,
  .visual-small-displays,
  .visual-skills-grid,
  .visual-practical-images,
  .visual-showcase-grid{
    grid-template-columns:1fr;
  }

  .visual-main-display{
    min-height:360px;
    border-radius:22px;
  }

  .visual-main-display h3{
    font-size:32px;
  }

  .visual-small-displays img,
  .vp-img,
  .vp-img.vp-large{
    height:310px;
  }

  .visual-skill-card{
    min-height:230px;
  }

  .visual-showcase-card,
  .visual-showcase-card.tall,
  .visual-showcase-card.wide{
    grid-column:span 1;
    grid-row:span 1;
    min-height:340px;
    border-radius:22px;
  }

  .visual-showcase-card h3,
  .visual-showcase-card.tall h3,
  .visual-showcase-card.wide h3{
    font-size:30px;
  }
}

/* =====================================================
   CAD TECHNOLOGY COURSE PAGE
====================================================== */

.cad-hero{
  background:
    linear-gradient(90deg, rgba(8,8,9,.96) 0%, rgba(18,18,20,.82) 52%, rgba(18,48,92,.60) 100%),
    url('https://images.unsplash.com/photo-1516321318423-f06f85e504b3?q=80&w=1600&auto=format&fit=crop') !important;
  background-size: cover !important;
  background-position: center right !important;
}

.cad-hero::before{
  background:
    radial-gradient(circle at 84% 18%, rgba(38,110,210,.28), transparent 36%),
    repeating-linear-gradient(115deg, transparent 0 92px, rgba(255,255,255,.065) 92px 93px) !important;
}

.cad-hero::after{
  content:"CAD" !important;
}


/* OVERVIEW */
.cad-overview{
  background:#fbfaf8;
  padding:95px 0;
  overflow:hidden;
}

.cad-overview-grid{
  display:grid;
  grid-template-columns:.95fr 1fr;
  gap:60px;
  align-items:center;
}

.cad-overview-visual{
  position:relative;
}

.cad-main-screen{
  position:relative;
  min-height:560px;
  border-radius:34px;
  overflow:hidden;
  background:#111;
  box-shadow:0 28px 80px rgba(0,0,0,.12);
}

.cad-main-screen img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}

.cad-main-screen::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.04) 35%,rgba(0,0,0,.78) 100%);
}

.cad-screen-label{
  position:absolute;
  left:30px;
  right:30px;
  bottom:30px;
  z-index:2;
  color:#fff;
}

.cad-screen-label span{
  display:block;
  color:#ff4b52;
  font-size:12px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:10px;
}

.cad-screen-label strong{
  font-family:var(--serif);
  font-size:54px;
  line-height:1;
  color:#fff;
}

.cad-floating-panel{
  position:absolute;
  right:-26px;
  top:44px;
  width:210px;
  background:#fff;
  border:1px solid #eadfd7;
  box-shadow:0 24px 70px rgba(0,0,0,.16);
  padding:18px;
  display:grid;
  gap:12px;
  z-index:3;
}

.cad-floating-panel div{
  padding:18px;
  background:#fbfaf8;
  border-left:4px solid var(--red);
}

.cad-floating-panel strong{
  display:block;
  font-family:var(--serif);
  font-size:34px;
  line-height:1;
  color:#111;
  margin-bottom:6px;
}

.cad-floating-panel span{
  color:#555;
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.cad-overview-content h2{
  font-family:var(--serif);
  font-size:clamp(42px,5vw,76px);
  line-height:.98;
  letter-spacing:-2px;
  color:#111;
  margin:18px 0 24px;
}

.cad-overview-content h2 em{
  color:var(--red);
  font-style:italic;
}

.cad-overview-content p{
  color:#595959;
  font-size:16px;
  line-height:1.85;
  margin:0 0 18px;
}

.cad-overview-points{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:34px;
}

.cad-overview-points div{
  background:#fff;
  border:1px solid #eadfd7;
  padding:28px 26px;
  box-shadow:0 18px 45px rgba(0,0,0,.05);
}

.cad-overview-points span{
  display:block;
  color:var(--red);
  font-size:13px;
  font-weight:900;
  letter-spacing:.16em;
  margin-bottom:18px;
}

.cad-overview-points h3{
  font-family:var(--serif);
  font-size:30px;
  color:#111;
  margin:0 0 10px;
}

.cad-overview-points p{
  font-size:14px;
  line-height:1.7;
  margin:0;
}


/* CAD MODULES */
.cad-modules{
  background:#111;
  color:#fff;
  padding:90px 0;
  overflow:hidden;
}

.cad-modules-head{
  display:grid;
  grid-template-columns:1fr .72fr;
  gap:60px;
  align-items:end;
  margin-bottom:44px;
}

.cad-modules-head h2{
  font-family:var(--serif);
  font-size:clamp(40px,5vw,72px);
  line-height:.98;
  letter-spacing:-2px;
  color:#fff;
  margin:16px 0 0;
}

.cad-modules-head h2 em{
  color:#ff3340;
  font-style:italic;
}

.cad-modules-head p{
  color:rgba(255,255,255,.70);
  font-size:16px;
  line-height:1.8;
  margin:0;
}

.cad-module-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

.cad-module-card{
  min-height:285px;
  padding:34px 28px;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.12);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  transition:.35s ease;
}

.cad-module-card:hover{
  transform:translateY(-6px);
  background:linear-gradient(180deg,rgba(35,110,215,.28),rgba(255,255,255,.05));
}

.cad-module-card span{
  color:#ff3340;
  font-size:13px;
  font-weight:900;
  letter-spacing:.16em;
  margin-bottom:auto;
}

.cad-module-card h3{
  font-family:var(--serif);
  font-size:34px;
  line-height:1.02;
  color:#fff;
  margin:0 0 12px;
}

.cad-module-card p{
  color:rgba(255,255,255,.68);
  font-size:14px;
  line-height:1.7;
  margin:0;
}


/* PRACTICAL */
.cad-practical{
  background:#fff;
  padding:95px 0;
  overflow:hidden;
}

.cad-practical-grid{
  display:grid;
  grid-template-columns:.82fr 1fr;
  gap:60px;
  align-items:center;
}

.cad-practical-content h2{
  font-family:var(--serif);
  font-size:clamp(42px,5vw,76px);
  line-height:.98;
  letter-spacing:-2px;
  color:#111;
  margin:18px 0 24px;
}

.cad-practical-content h2 em{
  color:var(--red);
  font-style:italic;
}

.cad-practical-content p{
  color:#595959;
  font-size:16px;
  line-height:1.85;
  margin:0 0 24px;
}

.cad-practical-content ul{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:14px;
}

.cad-practical-content li{
  position:relative;
  padding-left:28px;
  color:#333;
  font-size:15px;
  line-height:1.5;
  font-weight:700;
}

.cad-practical-content li::before{
  content:"";
  position:absolute;
  left:0;
  top:9px;
  width:10px;
  height:10px;
  background:var(--red);
}

.cad-practical-gallery{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}

.cad-img{
  height:290px;
  overflow:hidden;
  border-radius:24px;
  background:#111;
  box-shadow:0 18px 55px rgba(0,0,0,.08);
}

.cad-img.cad-large{
  grid-column:1 / -1;
  height:360px;
}

.cad-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}


/* SHOWCASE */
.cad-showcase{
  background:#fbfaf8;
  padding:100px 0;
  overflow:hidden;
}

.cad-showcase-head{
  display:grid;
  grid-template-columns:1fr .75fr;
  gap:60px;
  align-items:end;
  margin-bottom:48px;
}

.cad-showcase-head h2{
  font-family:var(--serif);
  font-size:clamp(42px,5vw,76px);
  line-height:.98;
  letter-spacing:-2px;
  color:#111;
  margin:16px 0 0;
}

.cad-showcase-head h2 em{
  color:var(--red);
  font-style:italic;
}

.cad-showcase-head p{
  color:#606060;
  font-size:16px;
  line-height:1.8;
  margin:0;
}

.cad-showcase-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr .9fr;
  grid-auto-rows:310px;
  gap:20px;
}

.cad-showcase-main,
.cad-showcase-card{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  background:#111;
  box-shadow:0 20px 60px rgba(0,0,0,.08);
}

.cad-showcase-main{
  grid-row:span 2;
}

.cad-showcase-card.wide{
  grid-column:span 2;
}

.cad-showcase-main img,
.cad-showcase-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  opacity:.9;
  transition:.55s ease;
}

.cad-showcase-main:hover img,
.cad-showcase-card:hover img{
  transform:scale(1.07);
  opacity:.75;
}

.cad-showcase-main::after,
.cad-showcase-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.03) 35%,rgba(0,0,0,.78) 100%);
  pointer-events:none;
}

.cad-showcase-main > div,
.cad-showcase-card > div{
  position:absolute;
  left:28px;
  right:28px;
  bottom:28px;
  z-index:2;
  color:#fff;
}

.cad-showcase-main span,
.cad-showcase-card span{
  display:inline-block;
  color:#ff4b52;
  font-size:12px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:12px;
}

.cad-showcase-main h3{
  font-family:var(--serif);
  font-size:clamp(38px,4vw,62px);
  line-height:1;
  color:#fff;
  margin:0;
}

.cad-showcase-card h3{
  font-family:var(--serif);
  font-size:32px;
  line-height:1.05;
  color:#fff;
  margin:0;
}


/* PAGE ACCENTS */
.cad-course-page .cad-enquiry{
  background:linear-gradient(135deg,#111,#0c203c) !important;
}

.cad-course-page .cad-career{
  background:#fff;
}


/* RESPONSIVE */
@media(max-width:1050px){
  .cad-overview-grid,
  .cad-modules-head,
  .cad-practical-grid,
  .cad-showcase-head{
    grid-template-columns:1fr;
  }

  .cad-main-screen{
    min-height:500px;
  }

  .cad-floating-panel{
    right:22px;
  }

  .cad-module-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .cad-showcase-grid{
    grid-template-columns:repeat(2,1fr);
    grid-auto-rows:300px;
  }

  .cad-showcase-main{
    grid-row:span 1;
  }
}

@media(max-width:575px){
  .cad-overview,
  .cad-modules,
  .cad-practical,
  .cad-showcase{
    padding:75px 0;
  }

  .cad-main-screen{
    min-height:390px;
    border-radius:22px;
  }

  .cad-screen-label strong{
    font-size:38px;
  }

  .cad-floating-panel{
    position:relative;
    right:auto;
    top:auto;
    width:100%;
    margin-top:16px;
  }

  .cad-overview-points,
  .cad-module-grid,
  .cad-practical-gallery,
  .cad-showcase-grid{
    grid-template-columns:1fr;
  }

  .cad-module-card{
    min-height:230px;
  }

  .cad-img,
  .cad-img.cad-large{
    height:310px;
  }

  .cad-showcase-main,
  .cad-showcase-card,
  .cad-showcase-card.wide{
    grid-column:span 1;
    grid-row:span 1;
    min-height:340px;
    border-radius:22px;
  }

  .cad-showcase-main h3{
    font-size:34px;
  }

  .cad-showcase-card h3{
    font-size:28px;
  }
}

/* =====================================================
   AI & ENTREPRENEURSHIP COURSE PAGE
====================================================== */

.ai-hero{
  background:
    linear-gradient(90deg, rgba(8,8,9,.96) 0%, rgba(18,18,20,.82) 52%, rgba(60,18,92,.60) 100%),
    url('https://images.unsplash.com/photo-1677442136019-21780ecad995?q=80&w=1600&auto=format&fit=crop') !important;
  background-size: cover !important;
  background-position: center right !important;
}

.ai-hero::before{
  background:
    radial-gradient(circle at 84% 18%, rgba(125,70,255,.30), transparent 36%),
    repeating-linear-gradient(115deg, transparent 0 92px, rgba(255,255,255,.065) 92px 93px) !important;
}

.ai-hero::after{
  content:"AI" !important;
}


/* OVERVIEW */
.ai-overview{
  background:#fbfaf8;
  padding:95px 0;
  overflow:hidden;
}

.ai-overview-grid{
  display:grid;
  grid-template-columns:1fr .95fr;
  gap:60px;
  align-items:center;
}

.ai-overview-content h2{
  font-family:var(--serif);
  font-size:clamp(42px,5vw,76px);
  line-height:.98;
  letter-spacing:-2px;
  color:#111;
  margin:18px 0 24px;
}

.ai-overview-content h2 em{
  color:var(--red);
  font-style:italic;
}

.ai-overview-content p{
  color:#595959;
  font-size:16px;
  line-height:1.85;
  margin:0 0 18px;
}

.ai-overview-points{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:34px;
}

.ai-overview-points div{
  background:#fff;
  border:1px solid #eadfd7;
  padding:28px 26px;
  box-shadow:0 18px 45px rgba(0,0,0,.05);
}

.ai-overview-points span{
  display:block;
  color:var(--red);
  font-size:13px;
  font-weight:900;
  letter-spacing:.16em;
  margin-bottom:18px;
}

.ai-overview-points h3{
  font-family:var(--serif);
  font-size:30px;
  color:#111;
  margin:0 0 10px;
}

.ai-overview-points p{
  font-size:14px;
  line-height:1.7;
  margin:0;
}

.ai-overview-visual{
  position:relative;
}

.ai-main-card{
  position:relative;
  min-height:560px;
  border-radius:34px;
  overflow:hidden;
  background:#111;
  box-shadow:0 28px 80px rgba(0,0,0,.12);
}

.ai-main-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}

.ai-main-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.04) 35%, rgba(0,0,0,.80) 100%);
}

.ai-main-content{
  position:absolute;
  left:30px;
  right:30px;
  bottom:30px;
  z-index:2;
  color:#fff;
}

.ai-main-content span{
  display:block;
  color:#ff4b52;
  font-size:12px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:12px;
}

.ai-main-content h3{
  font-family:var(--serif);
  font-size:clamp(38px,4vw,58px);
  line-height:1;
  color:#fff;
  margin:0;
}

.ai-floating-stats{
  position:absolute;
  left:-28px;
  top:42px;
  width:220px;
  background:#fff;
  border:1px solid #eadfd7;
  box-shadow:0 24px 70px rgba(0,0,0,.16);
  padding:18px;
  display:grid;
  gap:12px;
  z-index:3;
}

.ai-floating-stats div{
  padding:18px;
  background:#fbfaf8;
  border-left:4px solid var(--red);
}

.ai-floating-stats strong{
  display:block;
  font-family:var(--serif);
  font-size:34px;
  line-height:1;
  color:#111;
  margin-bottom:6px;
}

.ai-floating-stats span{
  color:#555;
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}


/* MODULES */
.ai-modules{
  background:#111;
  color:#fff;
  padding:90px 0;
  overflow:hidden;
}

.ai-modules-head{
  display:grid;
  grid-template-columns:1fr .72fr;
  gap:60px;
  align-items:end;
  margin-bottom:44px;
}

.ai-modules-head h2{
  font-family:var(--serif);
  font-size:clamp(40px,5vw,72px);
  line-height:.98;
  letter-spacing:-2px;
  color:#fff;
  margin:16px 0 0;
}

.ai-modules-head h2 em{
  color:#ff3340;
  font-style:italic;
}

.ai-modules-head p{
  color:rgba(255,255,255,.70);
  font-size:16px;
  line-height:1.8;
  margin:0;
}

.ai-module-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

.ai-module-card{
  min-height:285px;
  padding:34px 28px;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.12);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  transition:.35s ease;
}

.ai-module-card:hover{
  transform:translateY(-6px);
  background:linear-gradient(180deg,rgba(125,70,255,.28),rgba(255,255,255,.05));
}

.ai-module-card span{
  color:#ff3340;
  font-size:13px;
  font-weight:900;
  letter-spacing:.16em;
  margin-bottom:auto;
}

.ai-module-card h3{
  font-family:var(--serif);
  font-size:34px;
  line-height:1.02;
  color:#fff;
  margin:0 0 12px;
}

.ai-module-card p{
  color:rgba(255,255,255,.68);
  font-size:14px;
  line-height:1.7;
  margin:0;
}


/* PRACTICAL */
.ai-practical{
  background:#fff;
  padding:95px 0;
  overflow:hidden;
}

.ai-practical-grid{
  display:grid;
  grid-template-columns:1fr .82fr;
  gap:60px;
  align-items:center;
}

.ai-practical-visual{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}

.ai-practical-img{
  height:290px;
  overflow:hidden;
  border-radius:24px;
  background:#111;
  box-shadow:0 18px 55px rgba(0,0,0,.08);
}

.ai-practical-img.large{
  grid-column:1 / -1;
  height:360px;
}

.ai-practical-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}

.ai-practical-content h2{
  font-family:var(--serif);
  font-size:clamp(42px,5vw,76px);
  line-height:.98;
  letter-spacing:-2px;
  color:#111;
  margin:18px 0 24px;
}

.ai-practical-content h2 em{
  color:var(--red);
  font-style:italic;
}

.ai-practical-content p{
  color:#595959;
  font-size:16px;
  line-height:1.85;
  margin:0 0 24px;
}

.ai-practical-content ul{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:14px;
}

.ai-practical-content li{
  position:relative;
  padding-left:28px;
  color:#333;
  font-size:15px;
  line-height:1.5;
  font-weight:700;
}

.ai-practical-content li::before{
  content:"";
  position:absolute;
  left:0;
  top:9px;
  width:10px;
  height:10px;
  background:var(--red);
}


/* SHOWCASE */
.ai-showcase{
  background:#fbfaf8;
  padding:100px 0;
  overflow:hidden;
}

.ai-showcase-head{
  display:grid;
  grid-template-columns:1fr .75fr;
  gap:60px;
  align-items:end;
  margin-bottom:48px;
}

.ai-showcase-head h2{
  font-family:var(--serif);
  font-size:clamp(42px,5vw,76px);
  line-height:.98;
  letter-spacing:-2px;
  color:#111;
  margin:16px 0 0;
}

.ai-showcase-head h2 em{
  color:var(--red);
  font-style:italic;
}

.ai-showcase-head p{
  color:#606060;
  font-size:16px;
  line-height:1.8;
  margin:0;
}

.ai-showcase-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  grid-auto-rows:310px;
  gap:20px;
}

.ai-showcase-card{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  background:#111;
  box-shadow:0 20px 60px rgba(0,0,0,.08);
}

.ai-showcase-card.tall{
  grid-row:span 2;
}

.ai-showcase-card.wide{
  grid-column:span 2;
}

.ai-showcase-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  opacity:.9;
  transition:.55s ease;
}

.ai-showcase-card:hover img{
  transform:scale(1.07);
  opacity:.75;
}

.ai-showcase-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.03) 35%,rgba(0,0,0,.78) 100%);
  pointer-events:none;
}

.ai-showcase-card > div{
  position:absolute;
  left:28px;
  right:28px;
  bottom:28px;
  z-index:2;
  color:#fff;
}

.ai-showcase-card span{
  display:inline-block;
  color:#ff4b52;
  font-size:12px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:12px;
}

.ai-showcase-card h3{
  font-family:var(--serif);
  font-size:34px;
  line-height:1.05;
  color:#fff;
  margin:0;
}

.ai-showcase-card.tall h3,
.ai-showcase-card.wide h3{
  font-size:clamp(36px,4vw,56px);
  line-height:1;
}


/* PAGE ACCENTS */
.ai-course-page .ai-enquiry{
  background:linear-gradient(135deg,#111,#27104a) !important;
}

.ai-course-page .ai-career{
  background:#fff;
}


/* RESPONSIVE */
@media(max-width:1050px){
  .ai-overview-grid,
  .ai-modules-head,
  .ai-practical-grid,
  .ai-showcase-head{
    grid-template-columns:1fr;
  }

  .ai-main-card{
    min-height:500px;
  }

  .ai-floating-stats{
    left:22px;
  }

  .ai-module-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .ai-showcase-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .ai-showcase-card.tall{
    grid-row:span 1;
  }
}

@media(max-width:575px){
  .ai-overview,
  .ai-modules,
  .ai-practical,
  .ai-showcase{
    padding:75px 0;
  }

  .ai-main-card{
    min-height:390px;
    border-radius:22px;
  }

  .ai-floating-stats{
    position:relative;
    left:auto;
    top:auto;
    width:100%;
    margin-top:16px;
  }

  .ai-overview-points,
  .ai-module-grid,
  .ai-practical-visual,
  .ai-showcase-grid{
    grid-template-columns:1fr;
  }

  .ai-module-card{
    min-height:230px;
  }

  .ai-practical-img,
  .ai-practical-img.large{
    height:310px;
  }

  .ai-showcase-card,
  .ai-showcase-card.tall,
  .ai-showcase-card.wide{
    grid-column:span 1;
    grid-row:span 1;
    min-height:340px;
    border-radius:22px;
  }

  .ai-showcase-card h3,
  .ai-showcase-card.tall h3,
  .ai-showcase-card.wide h3{
    font-size:30px;
  }
}