    :root{
      --blue:#263b88;
      --blue2:#1b2d73;
      --cyan:#2fb7c8;
      --cyan2:#6de7ef;
      --orange:#ff8a1d;
      --orange2:#ff6422;
      --yellow:#ffd84d;
      --green:#33c481;
      --pink:#f85b8f;
      --purple:#8639c7;
      --soft:#f7fbff;
      --dark:#1d2440;
      --muted:#63708a;
      --radius:28px;
    }

    *{box-sizing:border-box;margin:0;padding:0}
    html{scroll-behavior:smooth}
    body{
      font-family:'Nunito',sans-serif;
      color:var(--dark);
      background:#fff;
      line-height:1.6;
      overflow-x:hidden;
    }

    a{text-decoration:none;color:inherit}
    img{max-width:100%;display:block}
    .container{width:min(1120px,92%);margin:auto}

    h1,h2,h3{
      font-family:'Baloo 2',cursive;
      line-height:1.08;
    }

    h1{
      font-size:clamp(42px,6.5vw,78px);
      font-weight:800;
      color:#fff;
      text-shadow:0 6px 0 rgba(15,45,130,.55),0 14px 28px rgba(0,0,0,.25);
    }

    h2{
      font-size:clamp(30px,4vw,50px);
      color:var(--blue);
    }

    h3{
      font-size:26px;
      color:var(--blue);
    }

    p{font-size:17px}

    .btn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:10px;
      border-radius:999px;
      padding:14px 24px;
      font-weight:900;
      box-shadow:0 12px 24px rgba(0,0,0,.14);
      transition:.25s ease;
      border:none;
      cursor:pointer;
    }

    .btn:hover{transform:translateY(-3px)}
    .btn-primary{background:linear-gradient(135deg,var(--orange),var(--orange2));color:#fff}
    .btn-whatsapp{background:#20c467;color:#fff}
    .btn-light{background:#fff;color:var(--blue)}
    .btn-blue{background:linear-gradient(135deg,#2b78d6,#263b88);color:#fff}

    .section{padding:76px 0}
    .section-title{text-align:center;margin-bottom:38px}

    .eyebrow{
      display:inline-block;
      background:#eef5ff;
      color:var(--blue);
      border-radius:999px;
      padding:8px 16px;
      font-size:14px;
      font-weight:900;
      margin-bottom:10px;
    }

    header{
      position:sticky;
      top:0;
      z-index:1000;
      background:rgba(255,255,255,.95);
      backdrop-filter:blur(14px);
      box-shadow:0 8px 24px rgba(23,38,84,.08);
    }

    .nav{
      height:105px;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:20px;
    }

    .brand{
      display:flex;
      align-items:center;
      gap:12px;
      font-weight:900;
      color:var(--blue);
    }

    .brand-logo{
      width:118px;
      height:auto;
    }

    .brand-title{
      font-family:'Baloo 2',cursive;
      font-weight:800;
      line-height:.95;
      color:var(--blue);
      font-size:22px;
    }

    .brand-title span{
      color:var(--orange);
    }

    .menu{
      display:flex;
      align-items:center;
      gap:20px;
      font-weight:900;
      color:#3b4668;
      font-size:15px;
    }

    .menu a:hover{color:var(--orange)}
    .menu-toggle{display:none;font-size:26px;color:var(--blue);cursor:pointer}

    .hero{
      position:relative;
      min-height:760px;
      display:flex;
      align-items:center;
      background:
        radial-gradient(circle at 88% 9%,rgba(255,216,77,.55),transparent 22%),
        radial-gradient(circle at 12% 20%,rgba(109,231,239,.45),transparent 24%),
        linear-gradient(135deg,#43c9d4 0%,#a8edf2 45%,#f0fbff 100%);
      overflow:hidden;
      color:#fff;
    }

    .hero::before{
      content:"";
      position:absolute;
      inset:0;
      background-image:radial-gradient(rgba(255,255,255,.36) 2px, transparent 2px);
      background-size:34px 34px;
      opacity:.45;
    }

    .hero::after{
      content:"";
      position:absolute;
      bottom:-90px;
      left:-8%;
      width:116%;
      height:185px;
      background:#fff;
      border-radius:50% 50% 0 0/100% 100% 0 0;
    }

    .hero-grid{
      position:relative;
      z-index:2;
      display:grid;
      grid-template-columns:1fr .92fr;
      align-items:center;
      gap:34px;
      padding:72px 0 112px;
    }

    .hero .tag{
      display:inline-flex;
      align-items:center;
      gap:8px;
      background:#fff;
      border:3px solid rgba(38,59,136,.15);
      color:var(--blue);
      border-radius:999px;
      padding:10px 17px;
      font-weight:900;
      margin-bottom:18px;
      box-shadow:0 10px 20px rgba(38,59,136,.12);
    }

    .hero-copy p{
      font-size:21px;
      max-width:620px;
      margin:18px 0 26px;
      color:#17306d;
      font-weight:800;
    }

    .hero-actions{
      display:flex;
      flex-wrap:wrap;
      gap:14px;
    }

    .hero-card{
      position:relative;
      background:#fff;
      border-radius:42px;
      padding:15px;
      box-shadow:0 28px 65px rgba(38,59,136,.25);
      transform:rotate(1.3deg);
      border:7px solid rgba(255,255,255,.75);
    }

    .hero-card img{
      border-radius:30px;
      width:100%;
      height:560px;
      object-fit:cover;
      object-position:center top;
    }

    .float-badge{
      position:absolute;
      background:#fff;
      color:var(--blue);
      border-radius:22px;
      padding:14px 16px;
      font-weight:900;
      box-shadow:0 14px 30px rgba(0,0,0,.16);
      border:3px solid #eef5ff;
    }

    .float-badge.one{left:-26px;top:44px}
    .float-badge.two{right:-20px;bottom:78px}
    .float-badge i{color:var(--orange);margin-right:6px}

    .event-bar{
      background:#fff;
      position:relative;
      z-index:3;
      margin-top:-72px;
    }

    .event-box{
      background:#fff;
      border-radius:34px;
      padding:24px;
      display:grid;
      grid-template-columns:repeat(4,1fr);
      gap:16px;
      box-shadow:0 22px 55px rgba(38,59,136,.14);
      border:1px solid #eef2ff;
    }

    .event-item{
      display:flex;
      align-items:flex-start;
      gap:13px;
      padding:16px;
      border-radius:24px;
      background:linear-gradient(180deg,#fff,#f7fbff);
    }

    .event-item i{
      width:42px;
      height:42px;
      border-radius:50%;
      display:grid;
      place-items:center;
      color:#fff;
      background:linear-gradient(135deg,var(--orange),var(--pink));
      flex:0 0 42px;
    }

    .event-item strong{
      display:block;
      color:var(--blue);
      font-weight:900;
      line-height:1.2;
    }

    .event-item span{
      display:block;
      color:var(--muted);
      font-size:14px;
      font-weight:800;
      margin-top:3px;
    }

    .intro{
      background:#fff;
    }

    .intro-grid{
      display:grid;
      grid-template-columns:.95fr 1.05fr;
      gap:34px;
      align-items:center;
    }

    .poster-card{
      border-radius:34px;
      padding:14px;
      background:linear-gradient(135deg,#fff,#e9fbff);
      box-shadow:0 18px 45px rgba(38,59,136,.13);
      border:1px solid #eef2ff;
    }

    .poster-card img{
      border-radius:24px;
      width:100%;
      object-fit:cover;
    }

    .check-list{
      display:grid;
      gap:14px;
      margin-top:24px;
    }

    .check-item{
      display:flex;
      gap:13px;
      align-items:flex-start;
      background:#fff;
      border:1px solid #edf2fb;
      border-radius:18px;
      padding:16px;
      box-shadow:0 8px 24px rgba(23,38,84,.06);
    }

    .check-item i{
      color:#fff;
      background:var(--orange);
      border-radius:50%;
      width:26px;
      height:26px;
      display:grid;
      place-items:center;
      flex:0 0 26px;
      margin-top:2px;
    }

    .activities{
      background:linear-gradient(135deg,#fff7e9,#eefaff);
      position:relative;
      overflow:hidden;
    }

    .activity-grid{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:20px;
    }

    .activity-card{
      background:#fff;
      border-radius:28px;
      overflow:hidden;
      box-shadow:0 16px 40px rgba(38,59,136,.11);
      transition:.25s;
      border:1px solid #edf2fb;
    }

    .activity-card:hover{transform:translateY(-6px)}
    .activity-card img{
      height:210px;
      width:100%;
      object-fit:cover;
    }

    .activity-content{
      padding:22px;
    }

    .activity-content h3{
      color:var(--blue);
      margin-bottom:8px;
    }

    .activity-content p{
      color:var(--muted);
      font-size:15px;
    }

    .promo{
      background:var(--blue);
      color:#fff;
      position:relative;
      overflow:hidden;
    }

    .promo::before{
      content:"";
      position:absolute;
      inset:0;
      background-image:radial-gradient(rgba(255,255,255,.14) 2px, transparent 2px);
      background-size:36px 36px;
      opacity:.35;
    }

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

    .promo h2{
      color:#fff;
    }

    .promo-grid{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:20px;
      margin-top:34px;
    }

    .promo-card{
      background:#fff;
      color:var(--dark);
      border-radius:30px;
      padding:28px;
      text-align:center;
      box-shadow:0 20px 45px rgba(0,0,0,.16);
      border-bottom:8px solid var(--yellow);
    }

    .promo-icon{
      width:78px;
      height:78px;
      border-radius:24px;
      display:grid;
      place-items:center;
      margin:0 auto 16px;
      color:#fff;
      background:linear-gradient(135deg,var(--orange),var(--pink));
      font-size:34px;
    }

    .promo-card:nth-child(2) .promo-icon{
      background:linear-gradient(135deg,var(--cyan),var(--blue));
    }

    .promo-card:nth-child(3) .promo-icon{
      background:linear-gradient(135deg,var(--green),var(--cyan));
    }

    .promo-card h3{
      margin-bottom:8px;
    }

    .promo-card p{
      color:var(--muted);
      font-size:15px;
    }

    .register{
      background:#f6f9ff;
    }

    .reg-grid{
      display:grid;
      grid-template-columns:.9fr 1.1fr;
      gap:26px;
      align-items:start;
    }

    .reg-card{
      background:linear-gradient(135deg,#243477,#172457);
      color:#fff;
      border-radius:32px;
      padding:30px;
      position:sticky;
      top:130px;
      box-shadow:0 20px 50px rgba(38,59,136,.18);
    }

    .reg-card h2{
      color:#fff;
    }

    .reg-card .eyebrow{
      background:rgba(255,255,255,.14);
      color:#fff;
    }

    .reg-card p{
      margin:16px 0;
      color:#eef4ff;
    }

    .reg-info{
      display:grid;
      gap:12px;
      margin:22px 0;
    }

    .reg-info div{
      display:flex;
      gap:12px;
      align-items:flex-start;
      font-weight:800;
    }

    .reg-info i{
      color:var(--yellow);
      width:22px;
      margin-top:4px;
    }

    .form-embed{
      background:#fff;
      border-radius:30px;
      padding:12px;
      min-height:680px;
      box-shadow:0 18px 45px rgba(38,59,136,.12);
      border:1px solid #e8eef9;
    }

    .form-embed iframe{
      width:100%;
      height:680px;
      border:0;
      border-radius:22px;
    }

    .form-placeholder{
      min-height:680px;
      border:2px dashed #cbd6ee;
      border-radius:22px;
      display:grid;
      place-items:center;
      text-align:center;
      color:#63708a;
      padding:24px;
    }

    .location{
      background:#fff;
    }

    .contact-grid{
      display:grid;
      grid-template-columns:.9fr 1.1fr;
      gap:24px;
    }

    .contact-card{
      background:linear-gradient(180deg,#fff,#f7fbff);
      border-radius:28px;
      padding:28px;
      border:1px solid #edf2fb;
      box-shadow:0 14px 34px rgba(38,59,136,.08);
    }

    .contact-row{
      display:flex;
      gap:12px;
      margin:16px 0;
    }

    .contact-row i{
      color:#fff;
      background:var(--blue);
      width:36px;
      height:36px;
      border-radius:50%;
      display:grid;
      place-items:center;
      flex:0 0 36px;
    }

    .map{
      border-radius:28px;
      overflow:hidden;
      min-height:360px;
      background:#eef5ff;
      box-shadow:0 14px 34px rgba(38,59,136,.08);
    }

    .map iframe{
      width:100%;
      height:360px;
      border:0;
    }

    footer{
      background:#172457;
      color:#fff;
      padding:34px 0;
      text-align:center;
    }

    .footer-logo{
      width:150px;
      margin:0 auto 14px;
    }

    .social{
      display:flex;
      justify-content:center;
      gap:12px;
      margin:18px 0;
    }

    .social a{
      width:42px;
      height:42px;
      border-radius:50%;
      background:rgba(255,255,255,.12);
      display:grid;
      place-items:center;
    }

    .wa-float{
      position:fixed;
      right:18px;
      bottom:18px;
      z-index:1001;
      width:58px;
      height:58px;
      border-radius:50%;
      background:#22c55e;
      color:#fff;
      display:grid;
      place-items:center;
      font-size:30px;
      box-shadow:0 14px 28px rgba(0,0,0,.22);
      animation:pulse 1.8s infinite;
    }

    @keyframes pulse{
      0%{transform:scale(1)}
      50%{transform:scale(1.06)}
      100%{transform:scale(1)}
    }

    @media(max-width:960px){
      .menu{
        display:none;
        position:absolute;
        top:88px;
        left:0;
        right:0;
        background:#fff;
        flex-direction:column;
        align-items:flex-start;
        padding:22px 6%;
        box-shadow:0 18px 30px rgba(23,38,84,.12);
      }

      .menu.show{display:flex}
      .menu-toggle{display:block}

      .hero-grid,
      .intro-grid,
      .reg-grid,
      .contact-grid{
        grid-template-columns:1fr;
      }

      .hero{
        min-height:auto;
      }

      .hero-grid{
        padding:42px 0 92px;
      }

      .hero-card{
        transform:none;
      }

      .hero-card img{
        height:auto;
      }

      .event-box{
        grid-template-columns:repeat(2,1fr);
      }

      .activity-grid,
      .promo-grid{
        grid-template-columns:1fr;
      }

      .reg-card{
        position:relative;
        top:auto;
      }
    }

    @media(max-width:560px){
      .brand-logo{width:76px}
      .brand-title{font-size:18px}
      .nav{height:82px}
      .menu{top:82px}

      .section{padding:54px 0}

      h1{
        font-size:44px;
      }

      .hero-copy p{
        font-size:18px;
      }

      .hero-actions{
        flex-direction:column;
      }

      .btn{
        width:100%;
      }

      .float-badge{
        display:none;
      }

      .event-box{
        grid-template-columns:1fr;
        padding:16px;
      }

      .form-embed,
      .form-placeholder,
      .form-embed iframe{
        height:540px;
        min-height:540px;
      }
    }
  
