*{box-sizing:border-box;margin:0;padding:0}
    .site{font-family:'Helvetica Neue',Arial,sans-serif;background:#FDFCF8;color:#374151}
    
/* NAV */
.nav{
  background:#0F2D52;
  display:flex;
  align-items:center;
  padding:0 48px;
}

/* make anchors behave like your old divs */
.nav-link{
  display:block;
  font-size:13px;
  color:rgba(255,255,255,.7);
  padding:20px 15px;
  cursor:pointer;
  white-space:nowrap;
  text-decoration:none;
  line-height:1;
}

.nav-link:visited{
  color:rgba(255,255,255,.7);
}

.nav-link:hover,
.nav-link:focus{
  color:#fff;
  text-decoration:none;
}

.sub-nav{
  background:#fff;
  border-bottom:1px solid #E5E2D9;
  padding:0 48px;
  display:flex;
  align-items:center;
  gap:0;
  position:sticky;
  top:57px;
  z-index:90;
}

.sub-nav-label{
  font-size:11px;
  font-weight:500;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#6B7280;
  padding:14px 20px 14px 0;
  border-right:0.5px solid #E5E2D9;
  margin-right:4px;
  white-space:nowrap;
}

/* anchors styled like old divs */
.sub-nav-link{
  display:block;
  font-size:13px;
  color:#6B7280;
  padding:14px 18px;
  cursor:pointer;
  white-space:nowrap;
  border-bottom:2px solid transparent;
  transition:all .15s;
  text-decoration:none;
  line-height:1;
}

.sub-nav-link:visited{
  color:#6B7280;
}

.sub-nav-link:hover,
.sub-nav-link:focus{
  color:#0F2D52;
  text-decoration:none;
}

.sub-nav-link.active{
  color:#0F2D52;
  border-bottom-color:#B8860B;
  font-weight:500;
}

.sub-nav-link.active:visited{
  color:#0F2D52;
}

.sub-nav-cta{
  margin-left:auto;
  display:inline-block;
  background:#0F2D52;
  color:#fff;
  font-size:12px;
  font-weight:500;
  padding:8px 18px;
  border-radius:3px;
  cursor:pointer;
  font-family:inherit;
  white-space:nowrap;
  text-decoration:none;
  line-height:1;
}

.sub-nav-cta:visited{
  color:#fff;
}
    
    /* HERO */
    .hero{position:relative;min-height:540px;display:flex;align-items:center;overflow:hidden}
    .hero-video-bg{position:absolute;inset:0;background:#0B1E35}
    .hero-video-bg video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
    .hero-video-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:1;padding:24px}
    .hero-video-placeholder-box{border:1px dashed rgba(255,255,255,.35);border-radius:6px;padding:18px 20px;background:rgba(255,255,255,.04);max-width:420px;text-align:center}
    .hero-video-placeholder-box strong{display:block;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#fff;margin-bottom:8px}
    .hero-video-placeholder-box span{display:block;font-size:12px;line-height:1.65;color:rgba(255,255,255,.72)}
    .hero-video-overlay{position:absolute;inset:0;background:rgba(10,22,40,.62);z-index:1}
    .video-label{position:absolute;bottom:16px;right:20px;font-size:11px;color:rgba(255,255,255,.22);letter-spacing:.06em;z-index:2}
    .video-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:56px;height:56px;border-radius:50%;border:1.5px solid rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;z-index:2}
    .video-play-tri{width:0;height:0;border-top:9px solid transparent;border-bottom:9px solid transparent;border-left:16px solid rgba(255,255,255,.35);margin-left:4px}
    .hero-content{position:relative;z-index:2;padding:80px 48px 88px;max-width:680px}
    .hero-eyebrow{font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:#B8860B;margin-bottom:20px}
    .hero-h1{font-family:Georgia,serif;font-size:46px;color:#fff;line-height:1.12;letter-spacing:-.5px;margin-bottom:24px}
    .hero-h1 em{font-style:italic;color:rgba(255,255,255,.72)}
    .hero-sub{font-size:17px;color:rgba(255,255,255,.65);line-height:1.68;margin-bottom:40px;max-width:520px}
    .hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:24px}
    
    .btn-gold{
      background:#B8860B;
      color:#fff;
      padding:15px 36px;
      font-size:15px;
      font-weight:500;
      border:1px solid #B8860B;
      border-radius:3px 18px 18px 3px;
      cursor:pointer;
      font-family:inherit;
    }
    
    .btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4);padding:14px 34px;font-size:15px;font-weight:500;border-radius:3px;cursor:pointer;font-family:inherit}
    .hero-footnote{font-size:12px;color:rgba(255,255,255,.35);line-height:1.7}
    .hero-footnote strong{color:rgba(255,255,255,.5);font-weight:500}
    
    
    
    /* SECTION */
    .sec{padding:72px 48px}
    .sec.alt{background:#fff}
    .sec.dark{background:#0F2D52}
    
    .eyebrow{
      display:inline-flex;
      align-items:center;
      gap:10px;
    
      font-size:11px;
      font-weight:500;
      letter-spacing:.12em;
      text-transform:uppercase;
    
      color:#B8860B;
      margin-bottom:12px;
      line-height:1;
    }
    
    /* decorative dash */
    .eyebrow::before{
      content:"";
      width:42px;
      height:1px;
      flex-shrink:0;
    
      background:linear-gradient(
        90deg,
        #D4A017 0%,
        #B8860B 45%,
        rgba(184,134,11,0) 100%
      );
    }
    
    /* optional version for light sections */
    .eyebrow.light-eyebrow{
      color:#0F2D52;
    }
    
    .eyebrow.light-eyebrow::before{
      background:linear-gradient(
        90deg,
        #1E4C84 0%,
        #0F2D52 45%,
        rgba(15,45,82,0) 100%
      );
    }
    
    .sec-h2{font-family:Georgia,serif;font-size:30px;color:#0F2D52;margin-bottom:14px;line-height:1.25}
    .sec-h2.light{color:#fff}
    .sec-lead{font-size:16px;color:#374151;line-height:1.7;max-width:600px;margin-bottom:44px}
    .sec-lead.light{color:rgba(255,255,255,.65)}
    
    /* PROGRAMME */
    .prog-wrap{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start;margin-bottom:72px}
    .prog-bsc{background:#F8F7F4;border:0.5px solid #E5E2D9;border-radius:6px;padding:32px;position:relative;overflow:hidden}
    .prog-bsc-num{font-family:Georgia,serif;font-size:80px;color:#E5E2D9;position:absolute;bottom:-12px;right:16px;line-height:1;user-select:none}
    .prog-bsc-badge{display:inline-block;font-size:10px;font-weight:500;letter-spacing:.07em;text-transform:uppercase;background:#E8F0FE;color:#185EA5;padding:4px 10px;border-radius:3px;margin-bottom:14px}
    .prog-bsc-title{font-family:Georgia,serif;font-size:19px;color:#0F2D52;margin-bottom:10px;line-height:1.3}
    .prog-bsc-ects{font-size:13px;color:#6B7280;margin-bottom:16px}
    .prog-bsc-list{list-style:none;padding:0}
    .prog-bsc-list li{font-size:13px;color:#374151;padding:7px 0;border-bottom:0.5px solid #E5E2D9;display:flex;gap:10px;align-items:flex-start;line-height:1.5}
    .prog-bsc-list li:last-child{border-bottom:none}
    .prog-bsc-list li::before{content:"";width:5px;height:5px;border-radius:50%;background:#185EA5;margin-top:6px;flex-shrink:0}
    .prog-master{background:#0F2D52;border-radius:6px;padding:36px;position:relative;overflow:hidden}
    .prog-master-accent{position:absolute;top:0;left:0;right:0;height:3px;background:#B8860B}
    .prog-master-num{font-family:Georgia,serif;font-size:100px;color:rgba(255,255,255,.05);position:absolute;bottom:-18px;right:12px;line-height:1;user-select:none}
    .prog-master-badge{display:inline-block;font-size:10px;font-weight:500;letter-spacing:.07em;text-transform:uppercase;background:rgba(184,134,11,.2);color:#D4A017;padding:4px 10px;border-radius:3px;margin-bottom:14px}
    .prog-master-title{font-family:Georgia,serif;font-size:21px;color:#fff;margin-bottom:10px;line-height:1.3}
    .prog-master-ects{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:20px}
    .prog-master-list{list-style:none;padding:0;margin-bottom:24px}
    .prog-master-list li{font-size:13px;color:rgba(255,255,255,.8);padding:8px 0;border-bottom:0.5px solid rgba(255,255,255,.1);display:flex;gap:10px;align-items:flex-start;line-height:1.5}
    .prog-master-list li:last-child{border-bottom:none}
    .prog-master-list li::before{content:"";width:5px;height:5px;border-radius:50%;background:#B8860B;margin-top:6px;flex-shrink:0}
    .prog-master-hl{background:rgba(184,134,11,.12);border:0.5px solid rgba(184,134,11,.3);border-radius:4px;padding:14px 16px;margin-top:20px}
    .prog-master-hl p{font-size:12px;color:rgba(255,255,255,.65);line-height:1.6}
    .prog-master-hl strong{color:#D4A017;font-weight:500}
    
    /* SECTION INTRO BAND */
    .dept-intro-band{
      margin:0 0 34px;
    }
    
    .quote-band{
      
      padding:48px;
    }
    
    .quote-inner{
      max-width:760px;
      margin:0 auto;
      text-align:center;
    }
    
    .quote-text{
      font-family:Georgia,serif;
      font-size:20px;
      color:#0F2D52;
      line-height:1.55;
      font-style:italic;
      margin-bottom:16px;
    }
    
    .quote-source{
      font-size:13px;
      color:#6B7280;
      letter-spacing:.03em;
    }
    
    
    
    /* ── DEPARTMENT ROWS — full width, content always right ── */
    .dept-section-label{
      font-size:11px;
      font-weight:500;
      letter-spacing:.1em;
      text-transform:uppercase;
      color:#6B7280;
      margin-bottom:18px;
    }
    
    .dept-row{
      display:grid;
      grid-template-columns:5fr 3fr 4fr;
      gap:12px;
      align-items:stretch;
      padding:18px 0;
      overflow:visible;
    }
    
    
    
    /* large media — left */
    .dept-img-main{
      position:relative;
      overflow:hidden;
      min-height:340px;
      border-radius:8px;
      background:#B8B4A8;
    }
    
    .dept-img-main-bg{
      position:absolute;
      inset:0;
    }
    
    .dept-img-main-bg img,
    .dept-img-main-bg video{
      width:100%;
      height:100%;
      object-fit:cover;
      display:block;
    }
    
    .dept-img-main-overlay{
      position:absolute;
      inset:0;
      background:rgba(15,45,82,.20);
      z-index:1;
    }
    
    .dept-img-main-label{
      position:absolute;
      bottom:14px;
      left:14px;
      font-size:10px;
      font-weight:500;
      letter-spacing:.08em;
      text-transform:uppercase;
      color:rgba(255,255,255,.88);
      background:rgba(0,0,0,.3);
      padding:4px 9px;
      border-radius:3px;
      z-index:2;
    }
    
    /* stacked media — middle */
    .dept-imgs-stack{
      display:grid;
      grid-template-rows:1fr 1fr;
      gap:12px;
    }
    
    .dept-img-sm{
      position:relative;
      overflow:hidden;
      min-height:164px;
      border-radius:8px;
      background:#C8C4B8;
    }
    
    .dept-img-sm-bg{
      position:absolute;
      inset:0;
    }
    
    .dept-img-sm-bg img{
      width:100%;
      height:100%;
      object-fit:cover;
      display:block;
    }
    
    .dept-img-sm-overlay{
      position:absolute;
      inset:0;
      background:rgba(15,45,82,.12);
      z-index:1;
    }
    
    .dept-img-sm-label{
      position:absolute;
      bottom:10px;
      left:10px;
      font-size:10px;
      color:rgba(255,255,255,.82);
      background:rgba(0,0,0,.3);
      padding:3px 7px;
      border-radius:3px;
      z-index:2;
    }
    
    /* content — right */
    .dept-content{
      padding:28px 24px;
      border:0.5px solid #E5E2D9;
      border-radius:8px;
      background:#fff;
      display:flex;
      flex-direction:column;
      justify-content:space-between;
    }
    
    
    
    .dept-name{
      font-family:Georgia,serif;
      font-size:20px;
      color:#0F2D52;
      margin-bottom:10px;
      line-height:1.3;
    }
    
    .dept-desc{
      font-size:13px;
      color:#374151;
      line-height:1.65;
      margin-bottom:20px;
    }
    
    .dept-stats{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:10px;
      margin-bottom:24px;
    }
    
    .dept-stat{
      background:#F8F7F4;
      border:0.5px solid #E5E2D9;
      border-radius:6px;
      padding:10px 12px;
    }
    
    .dept-stat-n{
      font-family:Georgia,serif;
      font-size:20px;
      color:#0F2D52;
      line-height:1;
    }
    
    .dept-stat-l{
      font-size:11px;
      color:#6B7280;
      margin-top:3px;
      line-height:1.35;
    }
    
    .dept-cta{
      display:inline-flex;
      align-items:center;
      gap:8px;
      font-size:13px;
      font-weight:500;
      color:#0F2D52;
      border:1px solid #0F2D52;
      padding:10px 18px;
      border-radius:3px;
      cursor:pointer;
      background:transparent;
      font-family:inherit;
      align-self:flex-start;
    }
    
    /* FACULTY */
    .fac-grid{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:16px;
    }
    
    .fac-card{
      background:rgba(255,255,255,.06);
      border:0.5px solid rgba(255,255,255,.1);
      border-radius:6px;
      overflow:hidden;
    }
    
    /* image area */
    .fac-img{
      position:relative;
      aspect-ratio:1.74 / 1;
      background:rgba(255,255,255,.08);
      overflow:hidden;
    }
    
    .fac-img img{
      width:100%;
      height:100%;
      object-fit:cover;
      display:block;
    }
    
    .fac-dept-bar{
      position:absolute;
      bottom:0;
      left:0;
      right:0;
      background:rgba(184,134,11,.85);
      padding:6px 12px;
      font-size:10px;
      font-weight:500;
      letter-spacing:.06em;
      text-transform:uppercase;
      color:#fff;
      z-index:2;
    }
    
    .fac-body{
      padding:18px 20px;
    }
    
    .fac-name{
      font-family:Georgia,serif;
      font-size:15px;
      color:#fff;
      margin-bottom:4px;
    }
    
    .fac-area{
      font-size:12px;
      color:rgba(255,255,255,.5);
      line-height:1.55;
      margin-bottom:12px;
    }
    
    .fac-rank{
      display:inline-block;
      font-size:10px;
      font-weight:500;
      background:rgba(184,134,11,.18);
      color:#D4A017;
      padding:3px 8px;
      border-radius:3px;
    }
    
    .fac-note{
      margin-top:32px;
      border-top:0.5px solid rgba(255,255,255,.1);
      padding-top:28px;
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:16px;
    }
    
    .fac-note-item{
      background:rgba(255,255,255,.05);
      border-radius:6px;
      padding:18px 20px;
    }
    
    .fac-note-n{
      font-family:Georgia,serif;
      font-size:28px;
      color:#fff;
    }
    
    .fac-note-l{
      font-size:12px;
      color:rgba(255,255,255,.45);
      margin-top:4px;
      line-height:1.4;
    }
    
    /* FACULTY CONTEXT STRIP — credibility signals below faculty grid */
.fac-context {
  margin-top: 28px;
  padding-top: 28px;
  border-top: 0.5px solid rgba(255, 255, 255, .12);
}

.fac-context-label {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #B8860B;
  margin-bottom: 16px;
}

.fac-context-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.fac-context-card {
  background: rgba(255, 255, 255, .04);
  border: 0.5px solid rgba(255, 255, 255, .09);
  border-radius: 6px;
  padding: 22px 24px 24px;
  display: flex;
  flex-direction: column;
}

/* HEADER: source label only now (logo moved out) */
.fac-context-header {
  margin-bottom: 16px;
}

/* LOGO: rectangular, 80% width, centred, sits between .fac-context-line and .fac-context-caption */
.fac-context-logo {
  width: 80%;
  aspect-ratio: 4 / 1;
  margin: 14px auto 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, .04);
  border: 0.5px solid rgba(255, 255, 255, .12);
  border-radius: 4px;
  padding: 10px 14px;
  overflow: hidden;
}

.fac-context-logo img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
  filter: grayscale(0.3) brightness(1.05) opacity(0.9);
  transition: filter 0.25s ease;
}

.fac-context-card:hover .fac-context-logo img {
  filter: grayscale(0) brightness(1) opacity(1);
}

/* CAPTION: padding-top adjustment since logo now sits above instead of taking full vertical space below */
.fac-context-caption {
  font-size: 11px;
  color: rgba(255, 255, 255, .45);
  line-height: 1.55;
  margin-top: auto;
  padding-top: 0;
}

/* UPDATED: source now sits inside the header row, no bottom margin */
.fac-context-source {
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #B8860B;
  line-height: 1.4;
}

.fac-context-stat {
  font-family: Georgia, serif;
  font-size: 38px;
  color: #fff;
  line-height: 1;
  letter-spacing: -0.5px;
  margin-bottom: 6px;
}

.fac-context-line {
  font-family: Georgia, serif;
  font-size: 14px;
  color: rgba(255, 255, 255, .85);
  line-height: 1.3;
  margin-bottom: 10px;
}

.fac-context-caption {
  font-size: 11px;
  color: rgba(255, 255, 255, .45);
  line-height: 1.55;
  margin-top: auto;
  padding-top: 8px;
}

    /* TUITION */
    .cost-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
    .cost-card{border-radius:6px;padding:22px;border:0.5px solid #E5E2D9;background:#F8F7F4}
    .cost-card.hl{background:#0F2D52;border-color:#0F2D52}
    .cost-region{font-size:11px;color:#6B7280;margin-bottom:6px}
    .cost-region.lt{color:rgba(255,255,255,.45)}
    .cost-inst{font-size:13px;font-weight:500;color:#374151;margin-bottom:14px}
    .cost-inst.lt{color:#fff}
    .cost-price{font-family:Georgia,serif;font-size:26px;color:#374151}
    .cost-price.gold{color:#B8860B}
    .cost-per{font-size:11px;color:#6B7280;margin-top:3px}
    .cost-per.lt{color:rgba(255,255,255,.35)}
    .cost-bar-bg{margin-top:14px;height:4px;background:#E5E2D9;border-radius:2px}
    .cost-bar-fg{height:4px;border-radius:2px;background:#D1CDBE}
    .cost-bar-fg.gold{background:#B8860B}
    
    /* THESSALONIKI */
    .city-intro{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:48px;
      align-items:end;
      margin-bottom:36px;
    }
    
    .mosaic{
      display:grid;
      grid-template-columns:5fr 6fr;
      grid-template-rows:220px 190px;
      gap:10px;
    }
    
    /* LARGE LEFT IMAGE */
    .mos-left{
      grid-row:span 2;
      border-radius:6px;
      overflow:hidden;
      position:relative;
      background:#B8B4A8;
    }
    
    .mos-left img{
      width:100%;
      height:100%;
      object-fit:cover;
      display:block;
    }
    
    /* RIGHT GRID */
    .mos-right-grid{
      display:grid;
      grid-template-columns:1fr 1fr;
      grid-template-rows:220px 190px;
      gap:10px;
    }
    
    .mos-cell{
      border-radius:6px;
      overflow:hidden;
      position:relative;
      background:#C8C4B8;
    }
    
    .mos-cell img{
      width:100%;
      height:100%;
      object-fit:cover;
      display:block;
    }
    
    .mos-overlay{
      position:absolute;
      inset:0;
      background:rgba(15,45,82,.22);
      z-index:1;
    }
    
    .mos-label{
      position:absolute;
      bottom:12px;
      left:12px;
      font-size:10px;
      color:rgba(255,255,255,.85);
      background:rgba(0,0,0,.32);
      padding:4px 8px;
      border-radius:3px;
      z-index:2;
    }
    
    /* FACT STRIP */
    .city-facts-strip{
      display:grid;
      grid-template-columns:repeat(4,1fr);
      gap:12px;
      margin-top:28px;
    }
    
    .city-fact{
      background:#F8F7F4;
      border:0.5px solid #E5E2D9;
      border-radius:6px;
      padding:16px 18px;
    }
    
    .city-fact-val{
      font-family:Georgia,serif;
      font-size:20px;
      color:#0F2D52;
    }
    
    .city-fact-label{
      font-size:11px;
      color:#6B7280;
      margin-top:4px;
    }
    

    
    /* CTA */
    .cta-sec{background:#F8F7F4;border-top:1px solid #E5E2D9;padding:72px 48px;text-align:center}
    .cta-eyebrow{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:#B8860B;margin-bottom:14px}
    .cta-h2{font-family:Georgia,serif;font-size:34px;color:#0F2D52;margin-bottom:12px;line-height:1.25}
    .cta-sub{font-size:15px;color:#6B7280;margin-bottom:34px;max-width:440px;margin-left:auto;margin-right:auto;line-height:1.65}
    .cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

    /* CTA — Premium Motion Layer */
.cta-sec{
  position:relative;
  overflow:hidden;
}

.cta-sec::before{
  content:"";
  position:absolute;
  top:-120px;
  left:50%;
  width:520px;
  height:520px;
  transform:translateX(-50%);
  background:radial-gradient(circle, rgba(184,134,11,.13), rgba(184,134,11,0) 68%);
  pointer-events:none;
}

.cta-inner{
  position:relative;
  z-index:1;
  max-width:720px;
  margin:0 auto;
}

.cta-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
}

.cta-eyebrow::before,
.cta-eyebrow::after{
  content:"";
  width:34px;
  height:1px;
  background:linear-gradient(
    90deg,
    rgba(184,134,11,0),
    rgba(184,134,11,.75),
    rgba(184,134,11,0)
  );
}

.cta-h2{
  text-wrap:balance;
}

.cta-row{
  position:relative;
}

.cta-row a,
.cta-row button{
  will-change:transform;
}

/* Slightly more premium CTA button hover */
.cta-sec .btn-navy:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 38px rgba(15,45,82,.22);
}

.cta-sec .btn-outline:hover{
  transform:translateY(-4px);
  background:#0F2D52;
  color:#fff;
  box-shadow:0 18px 38px rgba(15,45,82,.14);
}

/* Subtle breathing glow after CTA appears */
.motion-ready .cta-sec .cta-inner.is-visible::before{
  opacity:1;
}

@media (prefers-reduced-motion: no-preference){
  .cta-sec::before{
    animation:ctaGlowDrift 7s ease-in-out infinite alternate;
  }
}

@keyframes ctaGlowDrift{
  from{
    transform:translateX(-50%) translateY(0) scale(1);
    opacity:.75;
  }
  to{
    transform:translateX(-50%) translateY(18px) scale(1.08);
    opacity:1;
  }
}
    
    .btn-navy{
      background:#0F2D52;
      color:#fff;
      border:1px solid #0F2D52;
      padding:15px 36px;
      font-size:15px;
      font-weight:500;
      border-radius:3px 18px 18px 3px;
      cursor:pointer;
      font-family:inherit;
    }
    
    .btn-outline{background:transparent;color:#0F2D52;border:1.5px solid #0F2D52;padding:14px 34px;font-size:15px;font-weight:500;border-radius:3px;cursor:pointer;font-family:inherit}
    

 





/* =========================================================
   3. DEPARTMENT ROWS
   ========================================================= */

.dept-img-main,
.dept-img-sm,
.dept-content,
.dept-stat{
  transition:
    opacity var(--motion-med) var(--motion-ease),
    transform var(--motion-med) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease);
}

.dept-img-main-bg img,
.dept-img-main-bg video,
.dept-img-sm-bg img{
  transition:transform 1000ms var(--motion-ease);
}

.dept-img-main:hover .dept-img-main-bg img,
.dept-img-main:hover .dept-img-main-bg video,
.dept-img-sm:hover .dept-img-sm-bg img{
  transform:scale(1.045);
}

.dept-content:hover{
  box-shadow:0 18px 44px rgba(15,45,82,.08);
}

.dept-cta{
  transition:
    background var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease);
}

.dept-cta:hover{
  background:#0F2D52;
  color:#fff;
  transform:translateY(-2px);
  box-shadow:0 12px 26px rgba(15,45,82,.16);
}


/* =========================================================
   4. BUTTON REFINEMENT FOR HERO / CTA STYLE BUTTONS
   ========================================================= */

.btn-gold,
.btn-ghost,
.btn-navy,
.btn-outline{
  transition:
    transform var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    background var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease);
}

.btn-gold:hover,
.btn-navy:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 34px rgba(0,0,0,.18);
}

.btn-ghost:hover{
  transform:translateY(-3px);
  border-color:rgba(255,255,255,.72);
  background:rgba(255,255,255,.08);
}

.btn-outline:hover{
  transform:translateY(-3px);
  background:#0F2D52;
  color:#fff;
  box-shadow:0 14px 30px rgba(15,45,82,.14);
}


/* =========================================================
   ACCESSIBILITY
   ========================================================= */

@media (prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
    transition-duration:.01ms !important;
  }

  .motion-ready [data-reveal],
  .motion-ready [data-reveal].is-visible{
    opacity:1;
    transform:none;
  }
}