    @font-face {
      font-family: 'Blackjack';
      src: url('../fonts/BLACKJAR.TTF') format('truetype');
      font-display: swap;
    }
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    :root {
      --cream: #F8F4EC; --cream-dark: #EEE8D8; --cream-mid: #E2D9C5;
      --blue: #1b5876; --blue-dark: #123d54; --orange: #c8820b;
      --text: #1a2e3a; --text-soft: #3a5568;
    }
    html { scroll-behavior: smooth; }
    body { font-family: 'Nunito','Avenir','Century Gothic',sans-serif; background-color: var(--cream); color: var(--text); font-weight: 300; letter-spacing: 0.01em; }


    nav { position:fixed; top:0; left:0; right:0; z-index:100; display:flex; align-items:center; justify-content:space-between; padding:28px 64px; transition:background .4s,padding .4s,box-shadow .4s; }
    nav.scrolled { background:rgba(248,244,236,.95); backdrop-filter:blur(14px); padding:16px 64px; box-shadow:0 1px 0 var(--cream-mid); }
    .nav-logo { font-family:'Blackjack',cursive; font-size:1.5rem; color:var(--blue); text-decoration:none; }
    .nav-links { display:flex; gap:40px; list-style:none; }
    .nav-links a { font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--text); text-decoration:none; position:relative; padding-bottom:4px; font-weight:400; }
    .nav-links a::after { content:''; position:absolute; bottom:0; left:0; width:0; height:1.5px; background:var(--orange); transition:width .35s; }
    .nav-links a:hover::after { width:100%; }
    .nav-cta { background:var(--blue)!important; color:var(--cream)!important; padding:10px 26px; font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; text-decoration:none; transition:background .3s,transform .2s; font-weight:400; }
    .nav-cta:hover { background:var(--blue-dark)!important; transform:translateY(-1px); }
    .nav-cta::after { display:none!important; }

    .hero { min-height:100vh; display:grid; grid-template-columns:55% 45%; overflow:hidden; position:relative; }
    .hero-left { display:flex; flex-direction:column; justify-content:center; padding:130px 70px 90px 64px; position:relative; z-index:2; }
    .hero-eyebrow { font-size:.68rem; letter-spacing:.3em; text-transform:uppercase; color:var(--orange); margin-bottom:24px; opacity:0; animation:fadeUp 1s .3s forwards; font-weight:400; }
    .hero-title { font-family:'Blackjack',cursive; font-size:clamp(2.8rem,5vw,5.5rem); line-height:1.15; color:var(--blue); margin-bottom:30px; opacity:0; animation:fadeUp 1s .5s forwards; }
    .hero-title .accent { color:var(--orange); }
    .hero-desc { max-width:440px; font-size:1rem; line-height:1.95; color:var(--text-soft); margin-bottom:52px; opacity:0; animation:fadeUp 1s .7s forwards; font-weight:300; }
    .hero-buttons { display:flex; gap:20px; align-items:center; opacity:0; animation:fadeUp 1s .9s forwards; }
    .btn-primary { background:var(--blue); color:var(--cream); padding:16px 40px; font-family:'Nunito',sans-serif; font-size:.72rem; font-weight:400; letter-spacing:.2em; text-transform:uppercase; text-decoration:none; border:none; cursor:pointer; transition:background .3s,transform .2s; }
    .btn-primary:hover { background:var(--blue-dark); transform:translateY(-2px); }
    .btn-secondary { font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--text-soft); text-decoration:none; display:flex; align-items:center; gap:12px; font-weight:400; background:none; border:none; cursor:pointer; }
    .btn-secondary span { width:40px; height:1px; background:var(--cream-mid); transition:width .3s,background .3s; display:block; }
    .btn-secondary:hover span { width:60px; background:var(--orange); }
    .hero-right { position:relative; overflow:hidden; max-height:70vh; align-self:center; }
    .hero-right img { width:100%; height:100%; object-fit:cover; object-position:center; transform:scale(1.06); animation:zoomOut 2.2s .2s ease forwards; }
    .hero-right::before { content:''; position:absolute; inset:0; z-index:1; background:linear-gradient(to right,var(--cream) 0%,transparent 28%); }
    .hero-right::after { content:''; position:absolute; top:0; left:0; width:4px; height:100%; background:var(--orange); z-index:2; }
    .hero-scroll { position:absolute; bottom:40px; left:64px; display:flex; align-items:center; gap:14px; opacity:0; animation:fadeUp 1s 1.3s forwards; }
    .hero-scroll-line { width:1px; height:52px; background:var(--cream-mid); animation:grow 1.5s 1.5s ease forwards; transform-origin:top; transform:scaleY(0); }
    .hero-scroll span { font-size:.62rem; letter-spacing:.28em; text-transform:uppercase; color:var(--text-soft); writing-mode:vertical-rl; }

    section { padding:120px 64px; }
    .section-tag { display:inline-flex; align-items:center; gap:10px; font-size:.68rem; letter-spacing:.3em; text-transform:uppercase; color:var(--orange); margin-bottom:18px; font-weight:400; }
    .section-tag::before { content:''; width:28px; height:1.5px; background:var(--orange); display:block; }
    .section-title { font-family:'Blackjack',cursive; font-size:clamp(2.2rem,3.5vw,4rem); line-height:1.2; color:var(--blue); }
    .section-title .accent { color:var(--orange); }

    .about { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; background:var(--cream-dark); }
    .about-images { display:flex; flex-direction:column; gap:14px; position:relative; }
    .about-images::before { content:''; position:absolute; top:-12px; left:-12px; width:60px; height:60px; border-top:3px solid var(--blue); border-left:3px solid var(--blue); z-index:1; }
    .about-images::after { content:''; position:absolute; bottom:-12px; right:-12px; width:60px; height:60px; border-bottom:3px solid var(--orange); border-right:3px solid var(--orange); z-index:1; }
    .about-photos { display:flex; flex-direction:row; gap:14px; }
    .about-photos img { width:calc(50% - 7px); aspect-ratio:1/1; object-fit:cover; display:block; }
    .about-carousel { position:relative; width:100%; overflow:hidden; }
    .about-carousel-track { display:flex; flex-direction:row; flex-wrap:nowrap; transition:transform .4s ease; }
    .about-carousel-slide { width:100%; min-width:100%; flex-shrink:0; display:flex; flex-direction:row; }
    .about-carousel-img { width:50%; flex-shrink:0; }
    .about-carousel-img img { width:100%; height:100%; object-fit:cover; display:block; }
    .about-carousel-info { width:50%; flex-shrink:0; background:var(--blue); padding:20px 24px; display:flex; flex-direction:column; justify-content:center; gap:10px; overflow-y:auto; }
    .about-carousel-title { font-family:'Nunito',sans-serif; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; font-weight:400; color:var(--orange); margin:0 0 4px; }
    .about-carousel-section { border-top:1px solid rgba(248,244,236,.15); padding-top:8px; }
    .about-carousel-label { font-size:.62rem; letter-spacing:.22em; text-transform:uppercase; color:var(--orange); font-weight:600; margin:0 0 4px; }
    .about-carousel-text { font-size:.78rem; color:rgba(248,244,236,.85); line-height:1.7; font-weight:300; margin:0; }
    .about-carousel-nav { position:absolute; top:50%; left:0; right:0; display:flex; justify-content:space-between; transform:translateY(-50%); padding:0 10px; pointer-events:none; z-index:2; }
    .about-carousel-btn { pointer-events:all; background:rgba(255,255,255,.85); border:none; width:34px; height:34px; border-radius:50%; font-size:1.2rem; cursor:pointer; color:var(--blue); display:flex; align-items:center; justify-content:center; transition:background .3s; }
    .about-carousel-btn:hover { background:white; }
    .about-text p { font-size:1rem; line-height:2; color:var(--text-soft); margin-bottom:18px; font-weight:300; }
    .about-text .signature { font-family:'Blackjack',cursive; font-size:2.4rem; color:var(--orange); margin-top:28px; }
    .btn-outline { display:inline-block; margin-top:36px; border:1.5px solid var(--blue); color:var(--blue); padding:13px 36px; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; text-decoration:none; transition:all .3s; font-weight:400; }
    .btn-outline:hover { background:var(--blue); color:var(--cream); }

    .services { background:var(--cream); }
    .services-header { text-align:center; margin-bottom:72px; }
    .services-header .section-tag { justify-content:center; }
    .services-header .section-tag::before { display:none; }
    .services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
    .service-card { background:var(--cream-dark); padding:56px 44px; position:relative; overflow:hidden; cursor:pointer; transition:background .4s; }
    .service-card:hover { background:var(--blue); }
    .service-card:hover .service-title,.service-card:hover .service-desc,.service-card:hover .service-num { color:var(--cream); }
    .service-card:hover .service-link { color:var(--orange); }
    .service-card::after { content:''; position:absolute; bottom:0; left:0; width:100%; height:3px; background:var(--orange); transform:scaleX(0); transform-origin:left; transition:transform .4s; }
    .service-card:hover::after { transform:scaleX(1); }
    .service-num { font-family:'Blackjack',cursive; font-size:3.5rem; color:var(--cream-mid); line-height:1; margin-bottom:20px; transition:color .4s; }
    .service-title { font-family:'Blackjack',cursive; font-size:2rem; color:var(--blue); margin-bottom:14px; transition:color .4s; }
    .service-desc { font-size:.88rem; line-height:1.9; color:var(--text-soft); margin-bottom:28px; transition:color .4s; font-weight:300; }
    .service-features { list-style:none; margin-bottom:32px; }
    .service-features li { font-size:.8rem; color:var(--text-soft); padding:8px 0; border-bottom:1px solid rgba(27,88,118,.12); display:flex; gap:10px; align-items:center; transition:color .4s; font-weight:300; }
    .service-card:hover .service-features li { color:rgba(248,244,236,.75); border-color:rgba(248,244,236,.15); }
    .service-features li::before { content:'✓'; color:var(--orange); font-size:.72rem; }
    .service-link { font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:var(--blue); text-decoration:none; display:flex; align-items:center; gap:10px; transition:color .4s; font-weight:400; }
    .service-link::after { content:'→'; transition:transform .3s; }
    .service-card:hover .service-link::after { transform:translateX(6px); }

    .testimonials { background:var(--blue); color:var(--cream); padding:120px 64px; }
    .testimonials-header { text-align:center; margin-bottom:72px; }
    .testimonials-header .section-tag { color:var(--orange); justify-content:center; }
    .testimonials-header .section-tag::before { background:var(--orange); }
    .testimonials-header .section-title { color:var(--cream); }
    .testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:40px; }
    .testimonial-card { border-top:2px solid rgba(200,130,11,.45); padding-top:32px; }
    .testimonial-type { font-size:.85rem; letter-spacing:.28em; text-transform:uppercase; color:var(--orange); margin-bottom:18px; font-weight:400; }
    .testimonial-quote { font-size:.95rem; font-style:italic; font-weight:300; line-height:1.9; color:rgba(248,244,236,.88); margin-bottom:24px; }
    .testimonial-quote::before { content:'\201C'; font-family:'Blackjack',cursive; font-size:1.3rem; color:var(--orange); line-height:0; vertical-align:-0.3em; margin-right:4px; }
    .testimonial-quote::after { content:'\201D'; font-family:'Blackjack',cursive; font-size:1.3rem; color:var(--orange); line-height:0; vertical-align:-0.3em; margin-left:4px; }
    .testimonial-author { font-size:.88rem; letter-spacing:.08em; color:rgba(248,244,236,.88); line-height:1.6; }
    .testimonial-modality { font-size:.75rem; font-style:italic; font-weight:300; color:var(--orange); line-height:1.7; margin-bottom:20px; padding-top:14px; border-top:1px solid rgba(248,244,236,.1); }
    .testimonial-modality strong { font-style:normal; font-weight:600; color:var(--orange); letter-spacing:.08em; }

    .workshops { background:var(--cream); }
    .workshops-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:56px; }
    .workshops-list { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
    .workshop-item { display:flex; flex-direction:row; background:var(--cream-dark); overflow:hidden; transition:transform .3s, box-shadow .3s; cursor:pointer; border-radius:6px; }
    .workshop-item:hover { transform:translateY(-4px); box-shadow:0 8px 24px rgba(0,0,0,.08); }
    .workshop-img { width:45%; flex-shrink:0; min-height:180px; background-size:cover; background-position:center; }
    .workshop-item .workshop-info { width:55%; padding:24px 28px; display:flex; flex-direction:column; justify-content:center; }
    .workshop-date { font-family:'Blackjack',cursive; font-size:2rem; color:var(--blue); line-height:1.1; }
    .workshop-date span { display:block; font-family:'Nunito',sans-serif; font-size:.62rem; letter-spacing:.22em; text-transform:uppercase; color:var(--orange); margin-top:2px; font-weight:400; }
    .workshop-info h3 { font-family:'Nunito',sans-serif; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--orange); margin-bottom:5px; font-weight:600; }
    .workshop-info p { font-size:.82rem; color:var(--text-soft); font-weight:300; margin:0; line-height:1.7; }
    .workshop-book { background:var(--blue); color:var(--cream); padding:12px 28px; font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; text-decoration:none; transition:background .3s; font-weight:400; border:none; cursor:pointer; }
    .workshop-book:hover { background:var(--orange); }

    .cta-section { background:var(--orange); padding:100px 64px; display:flex; flex-direction:column; align-items:center; text-align:center; position:relative; overflow:hidden; }
    .cta-section::before { content:''; position:absolute; top:-80px; right:-80px; width:280px; height:280px; border-radius:50%; background:rgba(255,255,255,.07); }
    .cta-section::after { content:''; position:absolute; bottom:-60px; left:-60px; width:200px; height:200px; border-radius:50%; background:rgba(255,255,255,.07); }
    .cta-section .section-tag { color:rgba(255,255,255,.8); }
    .cta-section .section-tag::before { background:rgba(255,255,255,.6); }
    .cta-section .section-title { color:white; margin:10px 0 24px; }
    .cta-section > p { font-size:1rem; color:rgba(255,255,255,.88); max-width:480px; line-height:1.95; margin-bottom:48px; font-weight:300; }
    .cta-buttons { display:flex; gap:20px; flex-wrap:wrap; justify-content:center; position:relative; z-index:1; }
    .btn-white { background:white; color:var(--orange); padding:18px 52px; font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; border:none; cursor:pointer; transition:transform .2s,box-shadow .3s; font-weight:600; }
    .btn-white:hover { transform:translateY(-3px); box-shadow:0 18px 40px rgba(0,0,0,.18); }
    .btn-ghost { background:transparent; color:white; border:2px solid white; padding:16px 52px; font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; text-decoration:none; transition:background .3s,transform .2s; font-weight:600; }
    .btn-ghost:hover { background:rgba(255,255,255,.15); transform:translateY(-3px); }

    footer { background:var(--blue-dark); color:rgba(248,244,236,.6); padding:80px 64px 40px; }
    .footer-top { display:grid; grid-template-columns:2fr 1fr 1fr; gap:80px; margin-bottom:60px; }
    .footer-brand .nav-logo { color:var(--cream); font-size:1.6rem; }
    .footer-brand p { font-size:.85rem; line-height:1.95; margin-top:20px; max-width:280px; font-weight:300; }
    .footer-col h4 { font-size:.65rem; letter-spacing:.28em; text-transform:uppercase; color:var(--cream); margin-bottom:24px; font-weight:400; }
    .footer-col ul { list-style:none; }
    .footer-col ul li { margin-bottom:12px; }
    .footer-col ul a { font-size:.85rem; color:rgba(248,244,236,.5); text-decoration:none; transition:color .2s; font-weight:300; }
    .footer-col ul a:hover { color:var(--orange); }
    .footer-bottom { border-top:1px solid rgba(248,244,236,.1); padding-top:30px; display:flex; justify-content:space-between; align-items:center; }
    .footer-bottom span { font-size:.76rem; font-weight:300; }
    .social-links { display:flex; gap:24px; }
    .social-links a { font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(248,244,236,.45); text-decoration:none; transition:color .2s; font-weight:400; }
    .social-links a:hover { color:var(--orange); }

    /* MODAL */
    .modal-overlay { position:fixed; inset:0; z-index:1000; background:rgba(27,88,118,.55); backdrop-filter:blur(6px); display:flex; align-items:center; justify-content:center; padding:24px; opacity:0; pointer-events:none; transition:opacity .3s; }
    .modal-overlay.active { opacity:1; pointer-events:all; }
    .modal-box { background:var(--cream); max-width:620px; width:100%; max-height:90vh; overflow-y:auto; padding:52px 48px 48px; position:relative; transform:translateY(24px); transition:transform .35s; }
    .modal-overlay.active .modal-box { transform:translateY(0); }
    .modal-close { position:absolute; top:20px; right:24px; background:none; border:none; cursor:pointer; font-size:1rem; color:var(--text-soft); width:32px; height:32px; display:flex; align-items:center; justify-content:center; transition:color .2s; }
    .modal-close:hover { color:var(--orange); }
    .modal-header { margin-bottom:32px; }
    .modal-title { font-family:'Blackjack',cursive; font-size:2.2rem; color:var(--blue); margin-bottom:8px; }
    .modal-title .accent { color:var(--orange); }
    .modal-subtitle { font-size:.88rem; color:var(--text-soft); font-weight:300; }
    .form-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px 24px; margin-bottom:32px; }
    .form-group { display:flex; flex-direction:column; gap:8px; }
    .form-group.span-2 { grid-column:1/-1; }
    .form-group label { font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color:var(--blue); font-weight:400; }
    .form-group input, .form-group textarea { border:1.5px solid var(--cream-mid); background:white; padding:12px 16px; font-family:'Nunito',sans-serif; font-size:.9rem; font-weight:300; color:var(--text); outline:none; transition:border-color .2s; border-radius:0; }
    .form-group input:focus, .form-group textarea:focus { border-color:var(--blue); }
    .form-group textarea { resize:vertical; min-height:80px; }
    .radio-group, .checkbox-group { display:flex; flex-wrap:wrap; gap:10px; }
    .radio-label, .check-label { display:flex; align-items:center; gap:8px; font-size:.82rem; font-weight:300; color:var(--text-soft); cursor:pointer; padding:8px 16px; border:1.5px solid var(--cream-mid); background:white; transition:all .2s; }
    .radio-label:hover, .check-label:hover { border-color:var(--blue); color:var(--blue); }
    .radio-label input, .check-label input { accent-color:var(--blue); }
    .radio-label:has(input:checked), .check-label:has(input:checked) { background:var(--blue); color:white; border-color:var(--blue); }
    .btn-submit { width:100%; background:var(--blue); color:var(--cream); padding:18px; font-family:'Nunito',sans-serif; font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; font-weight:600; border:none; cursor:pointer; transition:background .3s,transform .2s; }
    .btn-submit:hover { background:var(--blue-dark); transform:translateY(-2px); }
    .form-success { text-align:center; padding:40px 0; }
    .success-icon { width:64px; height:64px; background:var(--orange); border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 20px; color:white; font-size:1.5rem; }
    .form-success h4 { font-family:'Blackjack',cursive; font-size:1.8rem; color:var(--blue); margin-bottom:10px; }
    .form-success p { font-size:.95rem; color:var(--text-soft); font-weight:300; line-height:1.8; }

    @keyframes fadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }
    @keyframes zoomOut { from{transform:scale(1.06)} to{transform:scale(1)} }
    @keyframes grow { from{transform:scaleY(0)} to{transform:scaleY(1)} }
    .reveal { opacity:0; transform:translateY(36px); transition:opacity .85s ease,transform .85s ease; }
    .reveal.visible { opacity:1; transform:translateY(0); }

    @media (max-width:900px) {
      nav { padding:22px 28px; } nav.scrolled { padding:14px 28px; }
      .nav-links { display:none; }
      .hero { grid-template-columns:1fr; } .hero-right { display:none; }
      .hero-left { padding:110px 28px 60px; }
      section { padding:80px 28px; }
      .about { grid-template-columns:1fr; gap:48px; }
      .services-grid { grid-template-columns:1fr; }
      .testimonials-grid { grid-template-columns:1fr; }
      .workshops-header { flex-direction:column; gap:24px; align-items:flex-start; }
      .workshops-list { grid-template-columns:1fr; }
      .workshop-item { flex-direction:column; }
      .workshop-img { width:100%; min-height:160px; }
      .workshop-item .workshop-info { width:100%; }
      .footer-top { grid-template-columns:1fr; gap:44px; }
      .footer-bottom { flex-direction:column; gap:20px; text-align:center; }
      .cta-buttons { flex-direction:column; align-items:center; }
      .modal-box { padding:36px 24px; }
      .form-grid { grid-template-columns:1fr; }
    }
