:root {
      --page: #eef2f5;
      --bg: #ffffff;
      --bg-soft: #f6f8fa;
      --card: #ffffff;
      --text: #202b36;
      --muted: #211c1b;
      --light: #cccccc;
      --accent: #56c3d7;
      --accent-deep: #2f98ad;
      --gold: #cfb26d;
      --green: #5bb46c;
      --red: #ff6260;
      --cyan: #56c3d7;
      --orange: #ecaf69;
      --purple: #8075c6;
      --pink: #dd7bd0;
      --line: #e3e7eb;
      --shadow: 0 16px 48px rgba(32,43,54,0.11);
      --soft-shadow: 0 10px 30px rgba(32,43,54,0.08);
      --radius: 18px;
      --max: 1120px;
    }

    * { box-sizing: border-box; }
    html { scroll-behavior: smooth; font-size: 18px; line-height: 27px; }
    body {
      margin: 0;
      color: var(--muted);
      background: var(--page);
      font-family: 'Lato', 'Helvetica Neue', Helvetica, Arial, sans-serif;
      font-weight: 400;
      line-height: 1.75;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      overflow-x: hidden;
    }

    a { color: inherit; text-decoration: none; }
    img { max-width: 100%; display: block; }

    .container {
      width: min(var(--max), calc(100% - 40px));
      margin: 0 auto;
    }

    .nav {
      position: fixed;
      top: 0;
      left: 0;
      width: 100%;
      z-index: 50;
      background: transparent;
      border-bottom: 1px solid transparent;
      backdrop-filter: none;
      box-shadow: none;
      transition: background 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease, backdrop-filter 0.28s ease;
    }

    .nav.scrolled {
      background: rgba(255,255,255,0.92);
      border-bottom-color: var(--line);
      backdrop-filter: blur(12px);
      box-shadow: 0 8px 26px rgba(32,43,54,0.08);
    }

    .nav-inner {
      height: 76px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
    }

    .brand {
      display: flex;
      align-items: center;
      gap: 12px;
      font-family: 'Inter Tight', 'Helvetica Neue', Helvetica, Arial, sans-serif;
      font-weight: 400;
      letter-spacing: -0.015em;
      font-size: 1.18rem;
      color: var(--text);
    }

    .brand-mark {
      width: 38px;
      height: 38px;
      border-radius: 10px;
      background: var(--cyan);
      display: grid;
      place-items: center;
      color: #ffffff;
      font-weight: 500;
      box-shadow: 0 10px 24px rgba(86,195,215,0.28);
    }

    .nav-links {
      display: flex;
      align-items: center;
      gap: 20px;
      color: var(--muted);
      font-weight: 400;
      font-size: 0.88rem;
      letter-spacing: 0.01em;
    }
	  .nav-links a{
    display:flex;
    align-items:center;
    justify-content:center;

    text-align:center;
    line-height:1.15;
}
	  .nav-links a span{
    display:inline-block;
		  text-align:center;
}

    .nav-links a:not(.nav-cta) {
      position: relative;
      padding: 12px 2px;
      transition: color .25s ease, transform .25s ease;
    }

    .nav-links a:not(.nav-cta)::before {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      bottom: 5px;
      height: 1px;
      background: var(--cyan);
      transform: scaleX(0);
      transform-origin: right;
      transition: transform .28s ease;
    }

    .nav-links a:not(.nav-cta)::after {
      content: "";
      position: absolute;
      left: 50%;
      bottom: -3px;
      width: 5px;
      height: 5px;
      border-radius: 50%;
      background: var(--red);
      opacity: 0;
      transform: translateX(-50%) translateY(6px);
      transition: opacity .25s ease, transform .25s ease;
    }

    .nav-links a:not(.nav-cta):hover,
    .nav-links a:not(.nav-cta).active-section {
      color: var(--text);
      transform: translateY(-1px);
    }

    .nav-links a:not(.nav-cta):hover::before,
    .nav-links a:not(.nav-cta).active-section::before {
      transform: scaleX(1);
      transform-origin: left;
    }

    .nav-links a:not(.nav-cta):hover::after,
    .nav-links a:not(.nav-cta).active-section::after {
      opacity: 1;
      transform: translateX(-50%) translateY(0);
    }

    .nav-cta {
      padding: 11px 18px;
      border-radius: 4px;
      background: var(--cyan);
      color: #ffffff !important;
      font-weight: 400;
      box-shadow: 0 8px 22px rgba(86,195,215,0.22);
    }

    .mobile-toggle { display: none; }

    .hero {
      position: relative;
      z-index: 2;
      padding: 150px 0 110px;
      overflow: hidden;
      background-image: url('../images/background.png');
      background-repeat: repeat-x;
      background-size: auto 100%;
      background-position: center top;
      background-color: #ffffff;
    }

    .hero-bg-shape { display: none; }

    .hero::before {
      content: "";
      position: absolute;
      width: 720px;
      height: 420px;
      right: 146px;
      top: -140px;
      background: rgba(255,255,255,0.25);
      border-radius: 48% 52% 44% 56%;
      transform: rotate(-10deg);
    }

    .hero::after {
      content: "";
      position: absolute;
      width: 420px;
      height: 260px;
      left: -160px;
      bottom: -90px;
      background: rgba(207,178,109,0.10);
      border-radius: 45% 55% 40% 60%;
      transform: rotate(12deg);
    }

    .hero-grid {
      position: relative;
      z-index: 2;
      display: grid;
      grid-template-columns: 1.05fr 0.95fr;
      gap: 58px;
      align-items: center;
    }

    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      padding: 8px 12px;
      border: 1px solid var(--line);
      border-radius: 4px;
      background: rgba(255,255,255,0.78);
      color: var(--text);
      font-size: 0.74rem;
      font-weight: 400;
      letter-spacing: 0.08em;
      margin-bottom: 28px;
      text-transform: uppercase;
    }

    .pulse {
      width: 8px;
      height: 8px;
      border-radius: 50%;
      background: var(--red);
      box-shadow: 0 0 0 6px rgba(255,98,96,0.14);
    }

   h1, h2, h3, .brand {
    font-family: 'Outfit', 'Helvetica Neue', Helvetica, Arial, sans-serif;
    font-weight: 200;
}

  h1 {
    margin: 0;
    font-size: clamp(3.8rem, 7vw, 7rem);
    line-height: 0.92;
    letter-spacing: -0.055em;
    font-weight: 200;
    color: var(--text);
}

    .hero h1 span {
      display: block;
      color: #6f6f6f;
    }

    .lead {
      margin: 30px 0 0;
      max-width: 660px;
      color: var(--muted);
      font-size: 1.08rem;
      line-height: 1.85;
      font-weight: 400;
    }

    .hero-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
      margin-top: 42px;
    }

    .btn {
      position: relative;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      min-height: 50px;
      padding: 0 22px;
      border-radius: 4px;
      font-weight: 400;
      letter-spacing: 0.02em;
      border: 1px solid transparent;
      overflow: hidden;
      isolation: isolate;
      transition: transform 0.22s ease, box-shadow 0.22s ease, color 0.22s ease, border-color 0.22s ease;
    }

    .btn::before {
      content: "";
      position: absolute;
      inset: 0;
      transform: scaleX(0);
      transform-origin: left;
      background: var(--cyan);
      z-index: -1;
      transition: transform 0.28s ease;
    }

    .btn:hover {
      transform: translateY(-2px);
      box-shadow: var(--soft-shadow);
    }

    .btn-primary {
      background: var(--cyan);
      border-color: var(--cyan);
      color: #ffffff;
    }

    .btn-primary::before { background: var(--red); }
    .btn-primary:hover { border-color: var(--red); color: #ffffff; }
    .btn-primary:hover::before { transform: scaleX(1); }

    .btn-secondary {
      background: transparent;
      border-color: var(--cyan);
      color: var(--text);
    }

    .btn-secondary::before { background: var(--cyan); }
    .btn-secondary:hover { color: #ffffff; }
    .btn-secondary:hover::before { transform: scaleX(1); }

    .btn-light {
      background: rgba(255,255,255,0.82);
      border-color: var(--line);
      color: var(--text);
    }

    .hero-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-top: 34px;
      color: var(--muted);
      font-size: 0.86rem;
      font-weight: 400;
      letter-spacing: 0.01em;
    }

    .meta-pill {
      padding: 8px 11px;
      border-radius: 4px;
      background: rgba(255,255,255,0.78);
      border: 1px solid var(--line);
    }

.hero-panel {
    backdrop-filter: blur(6px);
    position: relative;
    min-height: 520px;
    border-radius: 12px;
    padding: 24px;
    /* background: rgba(255, 255, 255, 0.76); */
    /* border: 1px solid rgba(227, 231, 235, 0.85); */
    /* box-shadow: var(--shadow); */
    overflow: hidden;
}

    .hero-panel::before {
      content: "";
      position: absolute;
      width: 420px;
      height: 300px;
      right: -120px;
      top: -80px;
      background: var(--bg-soft);
      border-radius: 50%;
      pointer-events: none;
    }

.mock-card {
    position: relative;
    /* background: rgba(255, 255, 255, 0.78); */
    /* border: 1px solid rgba(227, 231, 235, 0.85); */
    /* border-radius: 10px; */
    padding: 22px;
    margin-bottom: 16px;
    /* box-shadow: 0 8px 22px rgba(32, 43, 54, 0.06); */
}

    .mock-card.featured {
      margin-top: 28px;
      border-left: 4px solid var(--cyan);
      background: rgba(255,255,255,0.84);
    }

    .tag {
      display: inline-flex;
      padding: 6px 10px;
      border-radius: 4px;
      background: rgba(255,98,96,0.10);
      color: var(--red);
      font-size: 0.72rem;
      font-weight: 400;
      margin-bottom: 12px;
      letter-spacing: 0.06em;
      text-transform: uppercase;
    }

    .mock-card h3 {
      margin: 0 0 8px;
      color: var(--text);
      font-size: 1.35rem;
      line-height: 1.22;
      letter-spacing: -0.025em;
      font-weight: 400;
    }

    .mock-card p { margin: 0; color: var(--muted); line-height: 1.75; font-weight: 400; }
    .mini-flow {
      position: relative;
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
      margin-top: 26px;
      counter-reset: flowStep;
      border-top: 1px solid rgba(32,43,54,0.12);
      border-bottom: 1px solid rgba(32,43,54,0.12);
    }

    .mini-flow::before {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      top: 50%;
      height: 1px;
      background: linear-gradient(90deg, transparent, rgba(86,195,215,0.42), rgba(255,98,96,0.30), transparent);
      pointer-events: none;
    }

.mini-flow div {
    position: relative;
    min-height: 112px;
    padding: 24px 12px 18px 0;

    color: var(--text);

    font-family: 'Outfit', 'Helvetica Neue', Helvetica, Arial, sans-serif;
    font-weight: 300;

    font-size: clamp(.92rem, 1.1vw, 1.08rem);

    letter-spacing: -0.035em;
    line-height: 1.1;

    display: flex;
    align-items: flex-end;

    background: transparent;
    border: 0;
    overflow: hidden;

    word-break: keep-all;
}

    .mini-flow div:not(:last-child) {
      border-right: 1px solid rgba(32,43,54,0.10);
    }
.mini-flow .flow-text{
    display:block;
    transform:translateY(10px);
}

    .mini-flow div::before {
      counter-increment: flowStep;
      content: "0" counter(flowStep);
      position: absolute;
      top: 14px;
      left: 0;
      font-family: 'Lato', sans-serif;
      font-size: 0.62rem;
      letter-spacing: 0.18em;
      color: rgba(32,43,54,0.42);
    }

    .mini-flow div::after {
      content: "";
      position: absolute;
      top: calc(50% - 6px);
      left: 0;
      width: 12px;
      height: 12px;
      border-radius: 50%;
      background: var(--cyan);
      box-shadow: 0 0 0 8px rgba(86,195,215,0.10);
      transition: transform .25s ease, background .25s ease, box-shadow .25s ease;
    }

    .mini-flow div:nth-child(2)::after { background: var(--red); box-shadow: 0 0 0 8px rgba(255,98,96,0.10); }
    .mini-flow div:nth-child(3)::after { background: var(--green); box-shadow: 0 0 0 8px rgba(91,180,108,0.10); }
    .mini-flow div:nth-child(4)::after { background: var(--orange); box-shadow: 0 0 0 8px rgba(236,175,105,0.12); }

    .mini-flow div:hover::after {
      transform: scale(1.35);
      background: var(--purple);
      box-shadow: 0 0 0 12px rgba(128,117,198,0.12);
    }


main{
    position:relative;
    z-index:2;
    background:var(--page);
    margin-bottom:420px;
}
main::after{
    content:"";
    position:absolute;
    left:0;
    bottom:-50px;
    width:100%;
    height:110px;
    pointer-events:none;
    background:linear-gradient(to bottom, rgba(0,0,0,0.22), transparent);
    filter:blur(20px);
    opacity:0.85;
    z-index:-1;
}


    section { padding: 108px 0; position: relative; overflow: hidden; }

    section:nth-of-type(even) {
      background: rgba(255,255,255,0.58);
      backdrop-filter: blur(2px);
    }

    .section-head {
      max-width: 820px;
      margin-bottom: 56px;
    }

    .section-kicker {
      color: var(--accent-deep);
      font-weight: 400;
      text-transform: uppercase;
      letter-spacing: 0.18em;
      font-size: 0.68rem;
      margin-bottom: 18px;
    }

    h2 {
      margin: 0;
      font-size: clamp(2.5rem, 4vw, 5rem);
      line-height: 1;
      letter-spacing: -0.045em;
      /*font-weight: 300;*/
      color: var(--text);
    }

    .section-head p {
      margin: 24px 0 0;
      color: var(--muted);
      font-size: 1.02rem;
      line-height: 1.85;
      font-weight: 400;
    }

   .cards-3{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:0;
    margin-top:60px;
    background:transparent;
}

    .step-card, .adult-card, .contact-card {
      backdrop-filter: blur(6px);
      background: rgba(255,255,255,0.78);
      border: 1px solid rgba(227,231,235,0.88);
      border-radius: 10px;
      padding: 28px;
      box-shadow: 0 8px 22px rgba(32,43,54,0.06);
      transition: transform .2s ease, box-shadow .2s ease;
    }
	  
.service-card{
    background:transparent;
    border:0;
    border-right:1px solid rgba(32,43,54,0.10);
    border-radius:0;
    padding:10px 34px 10px 10px;
    box-shadow:none;
    transition:transform .2s ease;
}

    .subject-card {
      background: transparent;
      border: 0;
      border-left: 3px solid var(--cyan);
      border-radius: 0;
      padding: 8px 18px 8px 18px;
      min-height: auto;
      box-shadow: none;
      transition: transform .2s ease, border-color .2s ease;
    }

    .service-card:hover, .adult-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 14px 34px rgba(32,43,54,0.10);
    }
	  .cards-3 .service-card:last-child{
    border-right:0;
}

    .subject-card:hover {
      transform: translateX(4px);
      border-left-color: var(--red);
    }

.icon{
    width:44px;
    height:44px;
    border-radius:0;
    display:grid;
    place-items:center;
    background:transparent;
    color:var(--cyan);
    font-size:1.4rem;
    margin-bottom:22px;
}

    .service-card h3, .step-card h3, .subject-card h3, .adult-card h3, .contact-card h3 {
      margin: 0 0 12px;
      color: #211c1b;
      font-size: 1.32rem;
      line-height: 1.25;
      letter-spacing: -0.025em;
      font-weight: 400;
    }

    .service-card p, .step-card p, .subject-card p, .adult-card p, .contact-card p {
      margin: 0;
      color: var(--muted);
      line-height: 1.8;
      font-size: 0.98rem;
      font-weight: 400;
    }

    .emergency-strip {
      border-radius: 12px;
      border: 1px solid rgba(227,231,235,0.85);
      background: rgba(255,255,255,0.76);
      padding: 38px;
      display: grid;
      grid-template-columns: 1.2fr 0.8fr;
      gap: 30px;
      align-items: center;
      box-shadow: var(--shadow);
      position: relative;
      backdrop-filter: blur(4px);
    }

    .emergency-strip::before {
      content: "";
      position: absolute;
      width: 260px;
      height: 260px;
      right: -110px;
      top: -110px;
      background: rgba(86,195,215,0.10);
      border-radius: 50%;
    }

    .emergency-strip > * { position: relative; z-index: 2; }
    .emergency-strip h2 { font-size: clamp(2.2rem, 4.2vw, 4.3rem); }

    .booking-box {
      background: transparent;
      border: 0;
      border-left: 3px solid var(--cyan);
      border-radius: 0;
      padding: 8px 0 8px 22px;
    }

    .booking-row {
      display: flex;
      align-items: center;
      gap: 14px;
      padding: 16px 0;
      border-bottom: 1px solid rgba(227,231,235,0.9);
      color: var(--text);
      font-weight: 400;
      font-size: 0.95rem;
    }

    .booking-row:last-child { border-bottom: 0; }

    .num {
      width: 30px;
      height: 30px;
      border-radius: 50%;
      display: grid;
      place-items: center;
      background: var(--cyan);
      color: #ffffff;
      font-weight: 400;
      flex: 0 0 auto;
      font-size: 0.82rem;
    }

    .subjects-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 28px 18px;
      padding: 28px;
      background: rgba(255,255,255,0.62);
      border: 1px solid rgba(227,231,235,0.70);
      border-radius: 12px;
    }

.subject-card strong {
    display: block;
    color: #211c1b;
    margin-bottom: 8px;
    /* font-size: 1.1rem; */
    font-family: 'Inter Tight', 'Helvetica Neue', Helvetica, Arial, sans-serif;
    /* font-weight: 400; */
}

    .subject-card span { color: var(--muted); font-size: 1.0rem; line-height: 1.6; font-weight: 400; }

    .split {
      display: grid;
      grid-template-columns: 0.9fr 1.1fr;
      gap: 42px;
      align-items: center;
    }

    .feature-list {
      display: grid;
      gap: 14px;
      margin-top: 28px;
    }

    .feature-item {
      display: flex;
      gap: 14px;
      align-items: flex-start;
      padding: 8px 0 18px;
      border: 0;
      border-bottom: 1px solid var(--line);
      border-radius: 0;
      background: transparent;
      box-shadow: none;
    }

    .check {
      width: 24px;
      height: 24px;
      border-radius: 50%;
      display: grid;
      place-items: center;
      background: rgba(91,180,108,0.14);
      color: var(--green);
      font-weight: 400;
      flex: 0 0 auto;
      font-size: 0.8rem;
    }

    .feature-item strong {
      color: #211c1b;
      display: block;
      margin-bottom: 4px;
      font-family: 'Inter Tight', sans-serif;
      /*font-weight: 500;*/
    }
    .feature-item span { color: var(--muted); line-height: 1.7; font-weight: 400; }

    .visual-panel {
      border-radius: 12px;
      background: rgba(255,255,255,0.76);
      border: 1px solid var(--line);
      min-height: 500px;
      padding: 28px;
      position: relative;
      overflow: hidden;
      box-shadow: var(--shadow);
    }

    .visual-panel::after {
      content: "";
    position: absolute;
    width: 276px;
    height: 358px;
    /* border-radius: 50%; */
    background: var(--bg-soft);
    right: 28px;
    top: 28px;
    opacity: 0.7;
    }

    .floating-note {
      position: relative;
      z-index: 2;
      width: 78%;
      background: rgba(255,255,255,0.78);
      border: 0;
      border-left: 4px solid var(--cyan);
      border-radius: 0 10px 10px 0;
      padding: 22px;
      margin-bottom: 18px;
      box-shadow: 0 8px 22px rgba(32,43,54,0.07);
    }

    .floating-note:nth-child(2) { margin-left: auto; }
    .floating-note:nth-child(3) {     width: 78%;
    margin-left: 57px; }

    .adult-section {
      background: #ffffff !important;
    }

    .adult-section::before {
      content: "";
      position: absolute;
      left: -180px;
      bottom: -130px;
      width: 520px;
      height: 320px;
      border-radius: 50%;
      background: var(--bg-soft);
    }

    .adult-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 20px;
      margin-top: 30px;
      position: relative;
      z-index: 2;
    }

.cta-final {
    text-align: center;
    padding: 76px 28px;
    border-radius: 12px;
    /* background: rgba(255, 255, 255, 0.78); */
    border: 1px solid rgba(227, 231, 235, 0.85);
    /* box-shadow: var(--shadow); */
    backdrop-filter: blur(4px);
}

    .cta-final h2 { max-width: 900px; margin: 0 auto; }
    .cta-final p {
      max-width: 700px;
      margin: 24px auto 0;
      color: var(--muted);
      line-height: 1.85;
      font-size: 1.02rem;
      font-weight: 400;
    }
    .cta-final .hero-actions { justify-content: center; }

    .contact-grid {
      display: grid;
      grid-template-columns: 0.9fr 1.1fr;
      gap: 24px;
      align-items: start;
    }

  .contact-form{
    background: transparent;
    border: 0;
    border-radius: 0;
    padding: 10px 0 0 40px;
    box-shadow: none;
    position: relative;
}

    .form-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 14px;
    }

    .field { display: grid; gap: 8px; }
    .field.full { grid-column: 1 / -1; }
    label { color: var(--text); font-weight: 400; font-size: 0.86rem; }
input, select, textarea {
    width: 100%;
    border: 1px solid rgba(32, 43, 54, 0.10);
    border-radius: 9px;
    background: #ccc;
    color: #768697;
    padding: 13px 20px;
    font: inherit;
    font-weight: 300;
    outline: none;
    box-shadow: inset 0 1px 1px rgb(255 255 255 / 0%), inset 0 -1px 2px rgb(83 28 28 / 4%), 0 1px 2px rgb(89 89 89 / 76%);
    transition: background .25s ease, border-color .25s ease, transform .2s ease;
}
  input:focus,
select:focus,
textarea:focus{
    background:#ffffff;

    border-color:rgba(86,195,215,0.45);

    box-shadow:
        0 0 0 4px rgba(86,195,215,0.10),
        inset 0 1px 1px rgba(255,255,255,0.9);

    transform:translateY(-1px);
}
	  select{
    height:62px;
    appearance:none;
    -webkit-appearance:none;
    -moz-appearance:none;

    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' fill='none' stroke='%23202b36' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");

    background-repeat:no-repeat;
    background-position:right 18px center;

    padding-right:48px;
}
    textarea { min-height: 118px; resize: vertical; }
	  .field{
    display:grid;
    gap:10px;
    margin-bottom:8px;
}

label {
    color: #221d1c;
    /* font-weight: 500; */
    font-size: 0.7rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    margin-bottom: 8px;
    font-weight: bold;
}
	  .contact-grid{
    align-items:start;
    gap:90px;
}
    input::placeholder,
textarea::placeholder{
    color:#768697;
    opacity:1;
}

footer{
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    width:100%;
    height:420px;
    z-index:0;
    background:
      radial-gradient(circle at 82% 22%, rgba(86,195,215,0.16), transparent 34%),
      linear-gradient(135deg, #08372f 0%, #0d3f35 48%, #12351e 100%);
    color:#eef7ed;
    display:flex;
    align-items:stretch;
    overflow:hidden;
}

footer::before{
    content:"";
    position:absolute;
    inset:0;
    background:
      linear-gradient(to bottom, rgba(255,255,255,0.04), transparent 32%),
      radial-gradient(circle at 105% 70%, rgba(255,255,255,0.09), transparent 35%);
    pointer-events:none;
}

.footer-shell{
    position:relative;
    z-index:2;
    width:min(var(--max), calc(100% - 40px));
    margin:0 auto;
    padding:58px 0 34px;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
}

.footer-top{
    display:grid;
    grid-template-columns:1fr 0.9fr;
    gap:80px;
    align-items:start;
}

.footer-brand{
    font-family:'Outfit', 'Helvetica Neue', Arial, sans-serif;
    font-size:2.15rem;
    line-height:1;
    letter-spacing:-0.055em;
    color:#ffffff;
    margin-bottom:34px;
}

.footer-nav{
    display:flex;
    flex-wrap:wrap;
    gap:26px;
    color:rgba(255,255,255,0.72);
    font-size:0.92rem;
}

.footer-nav a:hover{
    color:#ffffff;
}

.footer-news h3{
    margin:0 0 18px;
    font-size:1rem;
    font-weight:400;
    letter-spacing:-0.01em;
    color:#ffffff;
}

.footer-form{
    display:flex;
    max-width:420px;
    border:1px solid rgba(255,255,255,0.24);
}

.footer-form input{
    flex:1;
    height:54px;
    border:0;
    border-radius:0;
    background:rgba(255,255,255,0.04);
    color:#ffffff;
    padding:0 18px;
    box-shadow:none;
}

.footer-form input::placeholder{
    color:rgba(255,255,255,0.55);
}

.footer-form button{
    width:142px;
    border:0;
    border-left:1px solid rgba(255,255,255,0.24);
    background:rgba(255,255,255,0.08);
    color:#ffffff;
    font:inherit;
    cursor:pointer;
}

.footer-form button:hover{
    background:var(--cyan);
}

.footer-bottom{
    border-top:1px solid rgba(255,255,255,0.18);
    padding-top:24px;
    display:flex;
    justify-content:space-between;
    gap:24px;
    flex-wrap:wrap;
    color:rgba(255,255,255,0.62);
    font-size:0.82rem;
}

.footer-legal{
    display:flex;
    flex-wrap:wrap;
    gap:18px;
}

.footer-social{
    display:flex;
    gap:12px;
}

.footer-social span{
    width:24px;
    height:24px;
    border-radius:50%;
    border:1px solid rgba(255,255,255,0.28);
    display:grid;
    place-items:center;
    font-size:0.68rem;
    color:rgba(255,255,255,0.72);
}

.footer-ghost{
    position:absolute;
    right:-40px;
    bottom:-60px;
    font-family:'Outfit', sans-serif;
    font-size:9rem;
    line-height:1;
    letter-spacing:-0.08em;
    color:rgba(255,255,255,0.08);
    pointer-events:none;
}

@media (max-width: 780px){
  main{ margin-bottom:560px; }
  footer{ height:560px; }
  .footer-top{ grid-template-columns:1fr; gap:34px; }
  .footer-form{ max-width:none; }
  .footer-ghost{ font-size:5rem; }
}


   .side-dots {
      position: fixed;
      right: 18px;
      top: 50%;
      transform: translateY(-50%);
      z-index: 40;
      display: grid;
      gap: 10px;
    }

    .side-dots a {
      width: 9px;
      height: 9px;
      border-radius: 50%;
      background: rgba(86,195,215,0.45);
      border: 1px solid rgba(86,195,215,0.55);
    }

    .side-dots a:hover { background: var(--red); }

    .appear {
      opacity: 0;
      transform: translateY(18px);
      transition: opacity .65s ease, transform .65s ease;
    }

    .appear.visible {
      opacity: 1;
      transform: translateY(0);
    }


/* CorePath promise ribbon: more color, less boxed UI */
.promise-ribbon{
  position:relative;
  background:#fff;
  padding:0;
  overflow:visible;
}

.promise-track{
  display:grid;
  grid-template-columns:1.1fr 1fr 1fr;
  min-height:250px;
  border-top:1px solid rgba(32,43,54,0.08);
  border-bottom:1px solid rgba(32,43,54,0.08);
}

.promise-item{
  position:relative;
  padding:52px 42px;
  overflow:hidden;
  color:#202b36;
}

.promise-item:not(:last-child){
  border-right:1px solid rgba(32,43,54,0.08);
}

.promise-item::before{
  content:"";
  position:absolute;
  inset:auto -30px -80px auto;
  width:210px;
  height:210px;
  border-radius:50%;
  opacity:.18;
  transition:transform .35s ease, opacity .35s ease;
}

.promise-item:hover::before{
  transform:scale(1.18) translate(-10px,-10px);
  opacity:.26;
}

.promise-item.mock::before{ background:var(--cyan); }
.promise-item.hour::before{ background:var(--orange); }
.promise-item.human::before{ background:var(--green); }

.promise-number{
  display:block;
  font-family:'Outfit',sans-serif;
  font-size:.74rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(32,43,54,0.45);
  margin-bottom:28px;
}

.promise-item h3{
  margin:0;
  font-size:clamp(2rem,3.4vw,3.9rem);
  line-height:.98;
  letter-spacing:-.055em;
  font-weight:200;
  color:#211c1b;
}

.promise-item p{
  margin:22px 0 0;
  max-width:360px;
  line-height:1.75;
  color:#211c1b;
}

.promise-accent{
  display:inline-block;
  margin-top:28px;
  width:42px;
  height:4px;
  border-radius:999px;
  background:var(--cyan);
}
.promise-item.hour .promise-accent{ background:var(--orange); }
.promise-item.human .promise-accent{ background:var(--green); }

.color-wash{
  position:absolute;
  pointer-events:none;
  border-radius:999px;
  filter:blur(34px);
  opacity:.18;
}
.color-wash.one{ width:260px; height:260px; background:var(--cyan); right:8%; top:14%; }
.color-wash.two{ width:220px; height:220px; background:var(--orange); left:4%; bottom:8%; }

.subject-cloud button.featured-service{
  border-color:rgba(255,98,96,.35);
  background:rgba(255,98,96,.09);
  color:#211c1b;
}

.subject-cloud button.featured-service:hover{
  background:var(--red);
  border-color:var(--red);
  color:#fff;
}

.feature-item.human-first .check{
  background:rgba(255,98,96,.14);
  color:var(--red);
}

@media (max-width: 980px){
  .promise-track{ grid-template-columns:1fr; }
  .promise-item:not(:last-child){ border-right:0; border-bottom:1px solid rgba(32,43,54,0.08); }
}


    /* Paper-style service lines */
    .support-lines{
      align-items:stretch;
      border-top:1px solid rgba(32,43,54,0.10);
      border-bottom:1px solid rgba(32,43,54,0.10);
      padding:34px 0;
    }

    .support-mark{
      width:42px;
      height:42px;
      position:relative;
      margin-bottom:28px;
    }

    .support-mark::before,
    .support-mark::after{
      content:"";
      position:absolute;
      width:30px;
      height:30px;
      border-radius:3px;
      background:rgba(86,195,215,0.72);
      transform:rotate(-8deg);
    }

    .support-mark::after{
      left:12px;
      top:8px;
      background:rgba(47,152,173,0.78);
      transform:rotate(8deg);
    }

    .support-mark span{
      position:absolute;
      z-index:2;
      left:7px;
      top:5px;
      font-family:'Outfit',sans-serif;
      font-size:.72rem;
      color:#fff;
      letter-spacing:.04em;
    }

    .service-card{
      position:relative;
    }

    .service-card::after{
      content:"";
      position:absolute;
      top:34px;
      right:0;
      height:70%;
      width:1px;
      background:rgba(32,43,54,0.12);
    }

    .cards-3 .service-card:last-child::after{
      display:none;
    }

    /* Interactive subject studio */
    .subject-studio-section{
      background:#ffffff;
    }

    .subject-studio{
      position:relative;
      padding:20px 0;
    }

    .subject-studio::before{
      content:"";
      position:absolute;
      right:-12%;
      top:0;
      width:420px;
      height:420px;
      border-radius:50%;
      background:rgba(86,195,215,0.08);
      pointer-events:none;
    }

    .subject-intro{
      max-width:850px;
      position:relative;
      z-index:2;
    }

    .subject-tabs{
      position:relative;
      z-index:3;
      display:flex;
      flex-wrap:wrap;
      gap:34px;
      margin:54px 0 42px;
      border-bottom:1px solid rgba(32,43,54,0.12);
    }

    .subject-tab{
      appearance:none;
      border:0;
      background:transparent;
      padding:0 0 18px;
      font-family:'Outfit',sans-serif;
      font-size:clamp(1.5rem,2.4vw,2.4rem);
      line-height:1;
      font-weight:200;
      letter-spacing:-.04em;
      color:rgba(32,43,54,0.42);
      cursor:pointer;
      position:relative;
      transition:color .25s ease, transform .25s ease;
    }

    .subject-tab::after{
      content:"";
      position:absolute;
      left:0;
      bottom:-1px;
      width:100%;
      height:2px;
      background:var(--cyan);
      transform:scaleX(0);
      transform-origin:left;
      transition:transform .25s ease;
    }

    .subject-tab:hover{
      color:var(--text);
      transform:translateY(-2px);
    }

    .subject-tab.active{
      color:var(--text);
    }

    .subject-tab.active::after{
      transform:scaleX(1);
    }

    .subject-panel{
      display:none;
      position:relative;
      z-index:2;
      min-height:240px;
    }

    .subject-panel.active{
      display:block;
      animation:softFade .35s ease both;
    }

    @keyframes softFade{
      from{opacity:0; transform:translateY(12px);}
      to{opacity:1; transform:translateY(0);}
    }

    .subject-cloud{
      display:flex;
      flex-wrap:wrap;
      gap:14px;
      max-width:980px;
    }

    .subject-cloud button{
      border:1px solid rgba(32,43,54,0.12);
      background:rgba(255,255,255,0.42);
      color:#211c1b;
      border-radius:999px;
      padding:14px 20px;
      font:inherit;
      font-weight:400;
      cursor:pointer;
      transition:background .25s ease, color .25s ease, transform .25s ease, border-color .25s ease;
    }

    .subject-cloud button:hover{
      transform:translateY(-3px);
      border-color:var(--cyan);
      background:var(--cyan);
      color:#fff;
    }

    .exam-cloud button:nth-child(2n):hover{
      background:var(--red);
      border-color:var(--red);
    }

    .subject-caption{
      max-width:680px;
      margin:34px 0 0;
      line-height:1.85;
      color:var(--muted);
    }

    .adviser-layout{
      display:grid;
      grid-template-columns:.95fr 1.05fr;
      gap:54px;
      align-items:start;
      max-width:1000px;
    }

    .adviser-layout h3{
      font-size:clamp(2.2rem,4vw,4rem);
      line-height:1;
      letter-spacing:-.045em;
      margin:0 0 22px;
      color:var(--text);
    }

    .adviser-layout p{
      line-height:1.85;
      margin:0;
    }

    .adviser-layout ul{
      margin:0;
      padding:0;
      list-style:none;
      border-top:1px solid rgba(32,43,54,0.12);
    }

    .adviser-layout li{
      --item-color: var(--cyan);
      position:relative;
      padding:18px 18px 18px 54px;
      border-bottom:1px solid rgba(32,43,54,0.10);
      color:#211c1b;
      overflow:hidden;
      transition:transform .25s ease, color .25s ease, background .25s ease;
    }

    .adviser-layout li::before{
      content:"";
      position:absolute;
      left:0;
      top:50%;
      width:28px;
      height:28px;
      border-radius:50%;
      background:color-mix(in srgb, var(--item-color) 18%, transparent);
      border:1px solid color-mix(in srgb, var(--item-color) 45%, transparent);
      transform:translateY(-50%);
      transition:transform .25s ease, background .25s ease;
    }

    .adviser-layout li::after{
      content:"→";
      position:absolute;
      left:8px;
      top:50%;
      transform:translateY(-52%);
      color:var(--item-color);
      font-size:.85rem;
      transition:transform .25s ease;
    }

    .adviser-layout li:nth-child(1){ --item-color: var(--cyan); }
    .adviser-layout li:nth-child(2){ --item-color: var(--red); }
    .adviser-layout li:nth-child(3){ --item-color: var(--green); }
    .adviser-layout li:nth-child(4){ --item-color: var(--purple); }
    .adviser-layout li:nth-child(5){ --item-color: var(--orange); }

    .adviser-layout li:hover{
      transform:translateX(8px);
      background:color-mix(in srgb, var(--item-color) 9%, transparent);
    }

    .adviser-layout li:hover::before{
      transform:translateY(-50%) scale(1.12);
      background:color-mix(in srgb, var(--item-color) 25%, transparent);
    }

    .adviser-layout li:hover::after{
      transform:translateY(-52%) translateX(3px);
    }

    .visual-break{
      background:#f8fafb;
    }

    .visual-break-grid{
      display:grid;
      grid-template-columns:.9fr 1.1fr;
      gap:80px;
      align-items:center;
    }

    .visual-copy h2{
      font-size:clamp(3rem,4vw,5.6rem);
    }

    .visual-copy p{
      max-width:560px;
      line-height:1.85;
      margin:28px 0 0;
    }

    .visual-photo{
      position:relative;
    }

    .visual-photo::before{
      content:"";
      position:absolute;
      inset:-24px 24px 24px -24px;
      border:1px solid rgba(32,43,54,0.08);
      z-index:0;
    }

    .visual-photo img{
      position:relative;
      z-index:1;
      width:100%;
      border-radius:0;
      box-shadow:0 24px 60px rgba(32,43,54,0.12);
    }

    .text-link{
      display:inline-flex;
      align-items:center;
      gap:24px;
      margin-top:36px;
      padding-bottom:8px;
      border-bottom:1px solid currentColor;
      color:var(--text);
    }

    .text-link span{
      transition:transform .25s ease;
    }

    .text-link:hover span{
      transform:translateX(8px);
    }



/* Adult/Newcomer section: diagonal background + interactive service rows */
.adult-section{
  position:relative;
  background:#ffffff !important;
  overflow:hidden;
}

.adult-section::before{
    content: "";
    position: absolute;
    right: -8vw;
    /* top: 0; */
    /* width: 62vw; */
    height: 24%;
    /* border-radius: 0;*/

}

.adult-section::after{
    content:"";

    position:absolute;

    top:0;
    right:0;

    width:56%;
    height:100%;

     background:linear-gradient(135deg, rgba(86,195,215,0.28), rgba(91,180,108,0.16));
  clip-path:polygon(34% 0, 100% 0, 100% 100%, 0 100%);
  z-index:0;

    clip-path:polygon(34% 0,100% 0,100% 100%,0 100%);

    pointer-events:none;
}

.adult-section .container{
  position:relative;
  z-index:2;
}

.adult-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  margin-top:42px;
  border-top:1px solid rgba(32,43,54,0.12);
  border-bottom:1px solid rgba(32,43,54,0.12);
  background:rgba(255,255,255,0.58);
  backdrop-filter:blur(4px);
}

.adult-card{
  position:relative;
  background:transparent !important;
  border:0 !important;
  border-right:1px solid rgba(32,43,54,0.12) !important;
  border-radius:0 !important;
  box-shadow:none !important;
  padding:42px 36px !important;
  overflow:hidden;
  cursor:pointer;
  transition:transform .25s ease, background .25s ease;
}

.adult-card:last-child{ border-right:0 !important; }

.adult-card::before{
  content:"";
  position:absolute;
  width:150px;
  height:150px;
  right:-70px;
  bottom:-80px;
  border-radius:50%;
  background:var(--cyan);
  opacity:.11;
  transform:scale(.8);
  transition:transform .35s ease, opacity .35s ease;
}

.adult-card:nth-child(2)::before{ background:var(--purple); }
.adult-card:nth-child(3)::before{ background:var(--orange); }

.adult-card:hover{
  
  background:rgba(255,255,255,0.72) !important;
}

.adult-card:hover::before{
  transform:scale(1.35);
  opacity:.22;
}

.adult-card .icon{
  width:auto;
  height:auto;
  display:inline-flex;
  background:transparent;
  margin-bottom:30px;
  color:var(--cyan);
  font-size:1.55rem;
  transition:transform .25s ease;
}

.adult-card:hover .icon{ transform:translateY(-4px) rotate(-5deg); }

.adult-card h3{
  font-size:clamp(1.65rem,2.3vw,2.25rem) !important;
  font-weight:300 !important;
  letter-spacing:-.045em !important;
  margin-bottom:18px !important;
}

.adult-card p{
  max-width:320px;
  line-height:1.85 !important;
}

.adult-section .hero-actions .btn-secondary{
  background:#ffffff;
  border-color:var(--cyan);
}

/* Sonnet-inspired left side dots */
.side-dots{
  position:fixed;
  left:42px;
  right:auto;
  top:50%;
  transform:translateY(-50%);
  z-index:45;
  display:grid;
  gap:18px;
}

.side-dots::before{
  content:"";
  position:absolute;
  left:5px;
  top:8px;
  bottom:8px;
  width:1px;
  background:linear-gradient(to bottom, transparent, rgba(128,117,198,0.24), transparent);
}

.side-dots a{
  position:relative;
  width:11px;
  height:11px;
  border-radius:50%;
  background:rgba(128,117,198,0.24);
  border:1px solid rgba(128,117,198,0.26);
  display:block;
  transition:transform .22s ease, background .22s ease, border-color .22s ease;
}

.side-dots a::before{
  content:"";
  position:absolute;
  inset:3px;
  border-radius:50%;
  background:rgba(128,117,198,0.65);
  opacity:.55;
}

.side-dots a::after{
  content:attr(data-label);
  position:absolute;
  left:24px;
  top:50%;
  transform:translateY(-50%) translateX(-4px);
  white-space:nowrap;
  font-family:'Outfit', sans-serif;
  font-size:.72rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(32,43,54,0.50);
  opacity:0;
  pointer-events:none;
  transition:opacity .22s ease, transform .22s ease;
}

.side-dots a:hover,
.side-dots a.active-dot{
  transform:scale(1.35);
  background:rgba(86,195,215,0.32);
  border-color:rgba(86,195,215,0.65);
}

.side-dots a:hover::after,
.side-dots a.active-dot::after{
  opacity:1;
  transform:translateY(-50%) translateX(0);
}

/* Redesigned student pressure section */
.pressure-section{
  position:relative;
  background:
    linear-gradient(180deg, #ffffff 0%, #f7fbfc 100%);
  overflow:hidden;
}

.pressure-section::before{
  content:"";
  position:absolute;
  left:-14vw;
  top:12%;
  width:34vw;
  height:34vw;
  border-radius:50%;
  background:rgba(86,195,215,0.10);
  filter:blur(12px);
  pointer-events:none;
}

.pressure-orb{
  position:absolute;
  border-radius:999px;
  filter:blur(38px);
  opacity:.22;
  pointer-events:none;
}

.pressure-orb-one{
  width:260px;
  height:260px;
  right:10%;
  top:14%;
  background:var(--red);
}

.pressure-orb-two{
  width:220px;
  height:220px;
  right:30%;
  bottom:8%;
  background:var(--green);
}

.pressure-head{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:70px;
  align-items:end;
  margin-bottom:70px;
}

.pressure-head h2{
  max-width:760px;
}

.pressure-head p{
  max-width:520px;
  margin:0;
  line-height:1.9;
  color:#211c1b;
}

.pressure-stage{
  position:relative;
  z-index:2;
  border-top:1px solid rgba(32,43,54,.12);
  border-bottom:1px solid rgba(32,43,54,.12);
}

.pressure-item{
  position:relative;
}

.pressure-item:not(:last-child){
  border-bottom:1px solid rgba(32,43,54,.10);
}

.pressure-link{
  position:relative;
  display:grid;
  grid-template-columns:90px 1px 1fr 52px;
  gap:30px;
  align-items:center;
  min-height:168px;
  padding:34px 0;
  color:#211c1b;
  overflow:hidden;
}

.pressure-link::before{
  content:"";
  position:absolute;
  inset:14px -20px;
  background:color-mix(in srgb, var(--accent-color) 8%, transparent);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .35s ease;
  border-radius:999px;
}

.pressure-link:hover::before{
  transform:scaleX(1);
}

.pressure-number{
  position:relative;
  z-index:2;
  font-family:'Outfit', sans-serif;
  font-size:clamp(2.8rem, 5vw, 5.4rem);
  line-height:.9;
  letter-spacing:-.07em;
  font-weight:200;
  color:color-mix(in srgb, var(--accent-color) 72%, #202b36);
}

.pressure-line{
  position:relative;
  z-index:2;
  width:1px;
  height:78px;
  background:color-mix(in srgb, var(--accent-color) 60%, transparent);
}

.pressure-content{
  position:relative;
  z-index:2;
  display:grid;
  gap:10px;
  max-width:760px;
}

.pressure-label{
  width:max-content;
  font-size:.68rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:color-mix(in srgb, var(--accent-color) 70%, #202b36);
}

.pressure-content strong{
  font-family:'Outfit', sans-serif;
  font-size:clamp(1.65rem, 3vw, 3.1rem);
  line-height:1;
  letter-spacing:-.05em;
  font-weight:300;
  color:#202b36;
}

.pressure-content span:last-child{
  max-width:590px;
  line-height:1.75;
  color:#211c1b;
}

.pressure-arrow{
  position:relative;
  z-index:2;
  width:44px;
  height:44px;
  border-radius:50%;
  border:1px solid color-mix(in srgb, var(--accent-color) 50%, transparent);
  color:var(--accent-color);
  display:grid;
  place-items:center;
  transition:transform .25s ease, background .25s ease, color .25s ease;
}

.pressure-link:hover .pressure-arrow{
  transform:translateX(8px);
  background:var(--accent-color);
  color:#fff;
}

.pressure-note{
  position:relative;
  z-index:2;
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:34px;
}

.pressure-note span{
  padding:10px 14px;
  border:1px solid rgba(32,43,54,.10);
  background:rgba(255,255,255,.55);
  border-radius:999px;
  font-size:.82rem;
  color:#211c1b;
}

@media (max-width: 980px){
  .pressure-head{
    grid-template-columns:1fr;
    gap:28px;
    margin-bottom:42px;
  }

  .pressure-link{
    grid-template-columns:70px 1fr 42px;
    gap:18px;
  }

  .pressure-line{
    display:none;
  }
}

@media (max-width: 620px){
  .pressure-link{
    grid-template-columns:1fr;
    min-height:auto;
    padding:30px 0;
  }

  .pressure-arrow{
    width:38px;
    height:38px;
  }
}

    @media (max-width: 980px) {
      .nav-links {
        position: fixed;
        inset: 76px 16px auto 16px;
        padding: 18px;
        border-radius: 10px;
        background: rgba(255,255,255,0.98);
        border: 1px solid var(--line);
        flex-direction: column;
        align-items: stretch;
        display: none;
        box-shadow: var(--shadow);
      }
      .nav-links.open { display: flex; }
      .mobile-toggle {
        display: inline-flex;
        background: rgba(255,255,255,0.82);
        color: var(--text);
        border: 1px solid var(--line);
        border-radius: 6px;
        padding: 10px 12px;
        font-weight: 400;
      }
      .hero-grid, .split, .contact-grid, .emergency-strip, .visual-break-grid, .adviser-layout { grid-template-columns: 1fr; }
      .hero { padding-top: 118px; }
      .hero-panel { min-height: auto; }
      .cards-3, .adult-grid { grid-template-columns: 1fr; }
      .subjects-grid { grid-template-columns: repeat(2, 1fr); }
      .subject-tabs { gap:22px; }
      .service-card::after{ display:none; }
      .support-lines{ gap:32px; }
      .side-dots { display: none; }
    }

    @media (max-width: 620px) {
      .container { width: min(100% - 26px, var(--max)); }
      .nav-inner { height: 70px; }
      .hero { min-height: auto; }
      section { padding: 72px 0; }
      .subjects-grid, .form-grid, .mini-flow { grid-template-columns: 1fr; }
      .emergency-strip, .cta-final { padding: 24px; border-radius: 10px; }
      .subject-tab{ font-size:1.8rem; }
      .visual-break-grid{ gap:40px; }
      .hero-panel, .visual-panel { border-radius: 10px; padding: 18px; }
      h1 { font-size: clamp(2.8rem, 13vw, 4.4rem); }
      h2 { font-size: clamp(2.3rem, 12vw, 3.8rem); }
    }

/* Final Sonnet-style side navigation */
.side-dots{
  position:fixed;
  left:34px;
  top:50%;
  transform:translateY(-50%);
  z-index:45;

  display:flex;
  flex-direction:column;
  justify-content:center;

  gap:42px; /* taller spacing */
}

.side-dots::before{
  content:"";
  position:absolute;

  left:5px;
  top:-55px;
  bottom:-55px;

  width:1px;

  background:
    linear-gradient(
      to bottom,
      transparent,
      rgba(128,117,198,0.16),
      rgba(86,195,215,0.26),
      rgba(128,117,198,0.16),
      transparent
    );
}

.side-dots a{
  position:relative;

  width:11px;
  height:11px;

  transform:rotate(45deg);

  border-radius:2px;

  background:rgba(128,117,198,0.18);
  border:1px solid rgba(128,117,198,0.22);

  transition:
    transform .22s ease,
    background .22s ease,
    border-color .22s ease;
}

.side-dots a::before{
  content:"";
  position:absolute;
  inset:3px;

  border-radius:1px;
  background:rgba(128,117,198,0.65);

  transition:all .22s ease;
}

.side-dots a::after{
  content:attr(data-label);

  position:absolute;
  left:20px;
  top:50%;

  transform:
    translateY(-50%)
    rotate(-45deg);

  white-space:nowrap;

  font-family:'Outfit', sans-serif;
  font-size:.60rem;
  letter-spacing:.10em;
  text-transform:uppercase;

  color:rgba(32,43,54,0.52);

  opacity:0;

  pointer-events:none;

  transition:
    opacity .22s ease,
    left .22s ease;
}

.side-dots a:hover,
.side-dots a.active-dot{
  background:rgba(86,195,215,0.32);
  border-color:rgba(86,195,215,0.65);

  transform:rotate(45deg) scale(1.45);
}

.side-dots a:hover::before,
.side-dots a.active-dot::before{
  background:var(--cyan);
}

.side-dots a:hover::after,
.side-dots a.active-dot::after{
  opacity:1;
  left:20px;
}
@media (max-width: 980px){
  .mini-flow{ grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 620px){
  .mini-flow{ grid-template-columns: 1fr; }
  .mini-flow::before{ display:none; }
  .mini-flow div{ min-height:86px; border-right:0 !important; border-bottom:1px solid rgba(32,43,54,0.10); padding-left:2px; }
  .mini-flow div:last-child{ border-bottom:0; }
}


/* =========================================================
   Site-wide soft image atmosphere layers
   Put these image files inside /images/ on the server:
   g1.png, s1.png, s3.png, stu1.png, stu2.png, y1.png
   These are used as transparent background mood layers only.
   ========================================================= */

.hero::after{
    content:"";
    position:absolute;
    right:-4%;
    bottom:-5%;
    width:42vw;
    height:42vw;
    background:
      linear-gradient(to left, rgba(255,255,255,0.05), rgba(255,255,255,0.72)),
      url('../images/stu1.png');
    background-size:cover;
    background-position:center;
    opacity:.22;
    mix-blend-mode:multiply;
    filter:grayscale(8%) blur(.2px);
    border-radius:50%;
    pointer-events:none;
    z-index:0;
}

.pressure-section{
    position:relative;
    overflow:hidden;
}

.pressure-section::after{
    content:"";

    position:absolute;

    top:0;
    right:0;

    width:44%;
    height:100%;

    background:
      linear-gradient(
        to left,
        rgba(247,251,252,0.08),
        rgba(247,251,252,0.72)
      ),
      url('../images/y1.png');

    background-size:cover;
    background-position:center;

    opacity:.16;

    clip-path:polygon(32% 0,100% 0,100% 100%,0 100%);

    mix-blend-mode:multiply;

    pointer-events:none;
}

.subject-studio::before{
    content:"";
    position:absolute;
    right:-10%;
    top:-8%;
    width:42vw;
    height:42vw;
    background:
      linear-gradient(to left, rgba(255,255,255,0), rgba(255,255,255,.84)),
      url('../images/g1.png');
    background-size:cover;
    background-position:center;
    opacity:.10;
    filter:grayscale(10%);
    pointer-events:none;
    z-index:0;
}

#adviser{
    position:relative;
    overflow:hidden;
}

#adviser::after{
    content:"";
    position:absolute;
    left:-6%;
    bottom:-6%;

    width:32vw;
    
        height:26vw;
    bottom:-30%;

    background-image:
        linear-gradient(to right, rgba(255,255,255,.88), rgba(255,255,255,0)),
         url("../images/stu2.png");

        background-size:contain;
       background-position:70% 28%;
    background-repeat:no-repeat;

    opacity:.40;

    pointer-events:none;
    z-index:0;
}

#adviser .adviser-layout{
    position:relative;
    z-index:2;
}

.adult-section::before{
    content:"";
    position:absolute;
    left:-6%;
    bottom:-4%;
    width:36vw;
    height:36vw;
    background:
      linear-gradient(to right, rgba(255,255,255,.85), rgba(255,255,255,.15)),
      url('../images/s1.png');
    background-size:cover;
    background-position:center;
    opacity:.16;
    filter:grayscale(12%);
    border-radius:50%;
    pointer-events:none;
    z-index:0;
}

#contact{
    position:relative;
    overflow:hidden;
}

#contact::after{
    content:"";
    position:absolute;
    right:-10%;
    bottom:-10%;
    width:34vw;
    height:34vw;
    background:
      linear-gradient(to left, rgba(238,242,245,.08), rgba(238,242,245,.82)),
      url('../images/s3.png');
    background-size:cover;
    background-position:center;
    opacity:.08;
    border-radius:50%;
    pointer-events:none;
    z-index:0;
}

#contact .container{
    position:relative;
    z-index:2;
}

@media (max-width: 980px){
  .hero::after,
  .pressure-section::after,
  .subject-studio::before,
  #adviser::after,
  .adult-section::before,
  #contact::after{
    width:56vw;
    height:56vw;
    opacity:.10;
  }
}

@media (max-width: 620px){
  .hero::after,
  .pressure-section::after,
  .subject-studio::before,
  #adviser::after,
  .adult-section::before,
  #contact::after{
    width:78vw;
    height:78vw;
    opacity:.08;
  }
}
	  .subject-tabs{
  display:grid;
  grid-template-columns:repeat(4, max-content);
  align-items:end;
}

.subject-tab{
  white-space:nowrap;
  font-size:clamp(1.25rem, 1.85vw, 1.9rem);
}

@media (max-width:1100px){
  .subject-tabs{
    grid-template-columns:repeat(2, max-content);
    gap:22px 42px;
  }
}
