/* MIXED CSS PACK */
/* Template: institutogranadino.com/index.html */
/* Template mtime: 2026-05-05 19:27:04 */

/* external link (no embedded): https://fonts.googleapis.com/css2?family=Domine:wght@400;600;700&family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap */
/* external link (no embedded): https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/css/bootstrap.min.css */
/* external link (no embedded): https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.3/font/bootstrap-icons.css */

/* ===== INLINE <style> BLOCK #1 ===== */
/* ─── VARIABLES ─────────────────────────────────────────────── */
    :root{
      --brand:#111111;
      --brand-2:#2b2b2b;
      --accent:#cfbc79;
      --accent-dark:#9f8946;
      --accent-light:#f4ecd2;
      --paper:#faf8f1;
      --soft:#f7f3e6;
      --ink:#111111;
      --muted:#6d665c;
      --line:#e8dfc7;
      --white:#ffffff;
      --shadow:0 14px 34px rgba(17,17,17,.08);
      --shadow-lg:0 24px 54px rgba(17,17,17,.12);
      --radius:18px;
      --radius-lg:28px;
      --nav-h:72px;
      --t:all .35s cubic-bezier(.4,0,.2,1);
    }

    /* ─── RESET / BASE ──────────────────────────────────────────── */
    *{box-sizing:border-box;margin:0;padding:0}
    html{scroll-behavior:smooth;scroll-padding-top:90px}
    html,body{max-width:100%;overflow-x:hidden}
    body{font-family:'Plus Jakarta Sans',system-ui,sans-serif;background:#fff;color:var(--ink);line-height:1.72;-webkit-font-smoothing:antialiased}
    img,video{max-width:100%;height:auto;display:block}
    a{color:inherit;text-decoration:none}
    h1,h2,h3,h4,h5{font-family:'Domine',Georgia,serif;color:var(--brand);letter-spacing:-.025em;line-height:1.1}
    .text-muted{color:var(--muted)!important}

    /* ─── BUTTONS ───────────────────────────────────────────────── */
    .btn{font-weight:700;letter-spacing:.01em;border:0;border-radius:999px;padding:.7rem 1.6rem;font-size:.97rem;transition:var(--t);display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-family:inherit}
    .btn-brand{background:var(--brand);color:#fff;box-shadow:0 8px 24px rgba(17,17,17,.18)}
    .btn-brand:hover{background:#000;color:#fff;transform:translateY(-2px);box-shadow:0 14px 32px rgba(17,17,17,.22)}
    .btn-accent{background:var(--accent);color:#111;box-shadow:0 8px 24px rgba(207,188,121,.35)}
    .btn-accent:hover{background:var(--accent-dark);color:#fff;transform:translateY(-2px);box-shadow:0 14px 32px rgba(159,137,70,.38)}
    .btn-ghost{background:transparent;color:var(--brand);border:2px solid var(--line);padding:.65rem 1.5rem}
    .btn-ghost:hover{border-color:var(--accent);background:var(--accent-light);color:var(--brand);transform:translateY(-2px)}
    .btn-outline-wa{background:transparent;color:#25d366;border:2px solid #25d366;padding:.65rem 1.5rem}
    .btn-outline-wa:hover{background:#25d366;color:#fff;transform:translateY(-2px)}

    /* ─── NAVBAR ────────────────────────────────────────────────── */
    .navbar{
      position:sticky;top:0;z-index:1030;
      min-height:var(--nav-h);
      padding:.7rem 0;
      background:rgba(255,255,255,.92);
      backdrop-filter:saturate(200%) blur(20px);
      -webkit-backdrop-filter:saturate(200%) blur(20px);
      border-bottom:1px solid rgba(232,223,199,.6);
      box-shadow:0 2px 20px rgba(17,17,17,.04);
      transition:var(--t)
    }
    .navbar.scrolled{
      background:rgba(255,255,255,.98);
      box-shadow:0 4px 30px rgba(17,17,17,.09);
      border-bottom-color:rgba(232,223,199,.9)
    }
    .navbar .container{flex-wrap:nowrap}
    .navbar-brand{
      display:flex;align-items:center;gap:.75rem;
      color:var(--brand);font-family:'Domine',Georgia,serif;
      font-weight:700;font-size:1.1rem;letter-spacing:-.01em
    }
    .navbar-brand img{height:44px;width:auto;object-fit:contain;flex:0 0 auto}
    .navbar-brand span{white-space:nowrap}
    /* Separator dot */
    .navbar-brand::after{content:'';display:none}
    .nav-link{
      color:var(--brand);font-weight:600;font-size:.9rem;
      padding:.45rem .75rem!important;border-radius:10px;
      position:relative;transition:var(--t);letter-spacing:.01em
    }
    .nav-link::after{
      content:'';position:absolute;left:50%;bottom:4px;
      width:0;height:2px;background:var(--accent);
      transform:translateX(-50%);transition:var(--t);border-radius:2px
    }
    .nav-link:hover,.nav-link.active{color:var(--accent-dark)}
    .nav-link:hover::after,.nav-link.active::after{width:55%}
    .navbar-toggler{border:0;box-shadow:none!important;padding:.4rem}
    .navbar-toggler:focus{box-shadow:none!important}
    /* Custom hamburger */
    .toggler-bar{
      display:block;width:22px;height:2px;background:var(--ink);
      border-radius:2px;transition:var(--t);margin:5px 0
    }
    .nav-cta{
      background:var(--brand);color:#fff!important;
      border-radius:999px;padding:.5rem 1.1rem!important;
      margin-left:.5rem;font-weight:700;font-size:.88rem;
      box-shadow:0 6px 18px rgba(17,17,17,.16);
      transition:var(--t);letter-spacing:.01em
    }
    .nav-cta:hover{background:var(--accent);color:#111!important;transform:translateY(-2px)}
    .nav-cta::after{display:none!important}

    /* ─── HERO ──────────────────────────────────────────────────── */
    .hero{
      position:relative;
      height:clamp(380px,58svh,560px);
      min-height:380px;
      overflow:hidden;
      background:var(--paper);
    }
    .hero-img{
      position:absolute;inset:0;
      width:100%;height:100%;
      object-fit:cover;object-position:50% 45%;
      transform:scale(1.04);
      animation:heroZoom 12s ease-out forwards;
      will-change:transform;
    }
    @keyframes heroZoom{to{transform:scale(1)}}
    /* Dark gradient overlay at bottom for text readability */
    .hero::after{
      content:'';position:absolute;inset:0;pointer-events:none;
      background:linear-gradient(180deg,
        rgba(17,17,17,.0) 0%,
        rgba(17,17,17,.05) 60%,
        rgba(17,17,17,.18) 100%);
    }
    @supports not (height:1svh){.hero{height:clamp(380px,58vh,560px)}}
    @media(max-width:991.98px){
      .hero{height:clamp(330px,50svh,470px);min-height:330px}
      .hero-img{object-position:50% 38%}
    }
    @media(max-width:767px){
      .hero{height:clamp(260px,42svh,360px)!important;min-height:260px!important}
      .hero-img{object-position:50% 30%!important}
    }

    /* ─── INTRO (below hero) ────────────────────────────────────── */
    .intro-section{
      background:#fff;
      padding:88px 0 80px;
      position:relative;
      overflow:hidden;
    }
    /* subtle decorative circle */
    .intro-section::before{
      content:'';position:absolute;top:-180px;right:-180px;
      width:560px;height:560px;border-radius:50%;
      background:radial-gradient(circle,rgba(207,188,121,.12) 0%,transparent 70%);
      pointer-events:none
    }
    .intro-eyebrow{
      display:flex;align-items:center;justify-content:center;gap:.5rem;
      width:fit-content;max-width:100%;
      font-weight:700;letter-spacing:.1em;text-transform:uppercase;
      font-size:.76rem;padding:.42rem 1rem;border-radius:999px;
      background:var(--accent-light);color:var(--accent-dark);
      margin:0 auto 1.2rem;
      clear:both;
    }
    .intro-eyebrow i{font-size:.9rem}
    .intro-title{
      font-size:clamp(2.4rem,5vw,4.4rem);
      line-height:1.04;
      max-width:900px;
      margin:0 auto 1.3rem;
      letter-spacing:-.03em;
    }
    .intro-title em{
      font-style:normal;
      color:var(--accent-dark);
      position:relative;display:inline-block;
    }
    .intro-title em::after{
      content:'';position:absolute;
      left:0;bottom:-4px;right:0;height:3px;
      background:linear-gradient(90deg,var(--accent-dark),var(--accent));
      border-radius:3px;opacity:.6;
    }
    .intro-lead{
      font-size:clamp(1rem,1.3vw,1.14rem);
      color:var(--muted);max-width:800px;margin:0 auto 2.2rem;
      font-weight:400;line-height:1.78
    }
    .intro-actions{
      display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;
    }
    /* Stats strip */
    .intro-stats{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:1.2rem;
      max-width:780px;
      margin:3rem auto 0;
    }
    .intro-stat{
      background:var(--paper);
      border:1px solid var(--line);
      border-radius:20px;
      padding:1.4rem 1.2rem;
      text-align:center;
      position:relative;
      overflow:hidden;
      transition:var(--t);
    }
    .intro-stat::before{
      content:'';position:absolute;inset-x:0;top:0;height:3px;
      background:linear-gradient(90deg,var(--accent-dark),var(--accent));
      border-radius:3px 3px 0 0;
    }
    .intro-stat:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
    .intro-stat-num{
      font-family:'Domine',Georgia,serif;
      font-size:2rem;font-weight:700;
      color:var(--brand);letter-spacing:-.03em;
      display:block;line-height:1
    }
    .intro-stat-label{
      font-size:.82rem;font-weight:600;
      color:var(--muted);margin-top:.4rem;
      display:block;letter-spacing:.03em;text-transform:uppercase
    }
    @media(max-width:600px){
      .intro-stats{grid-template-columns:1fr}
      .intro-actions .btn{width:100%;justify-content:center}
    }

    /* ─── SECTIONS SHARED ───────────────────────────────────────── */
    .section{padding:96px 0;position:relative}
    .section-paper{background:var(--paper)}
    .section-white{background:#fff}

    .section-after-ticker{padding-top:58px}
    @media(max-width:767.98px){.section-after-ticker{padding-top:46px}}

    .eyebrow{
      display:flex;align-items:center;justify-content:center;gap:.45rem;
      width:fit-content;max-width:100%;
      font-weight:700;letter-spacing:.1em;text-transform:uppercase;
      font-size:.76rem;padding:.42rem 1rem;border-radius:999px;
      background:var(--accent-light);color:var(--accent-dark);
      margin:0 0 1.1rem;
      clear:both;
    }
    .section-heading{
      font-size:clamp(1.8rem,3.5vw,2.8rem);
      margin:0 0 1rem;letter-spacing:-.025em;
    }
    .section-heading mark{
      background:linear-gradient(transparent 55%,rgba(207,188,121,.32) 0);
      padding:0 .2em;border-radius:6px;
      color:inherit;
    }
    /* Gold underline decoration */
    .heading-line{
      display:block;width:52px;height:3px;margin:1rem 0 1.3rem;
      background:linear-gradient(90deg,var(--accent-dark),var(--accent));
      border-radius:3px;
    }
    .text-center .heading-line{margin-left:auto;margin-right:auto}
    .section-sub{
      font-size:1.05rem;color:var(--muted);max-width:780px;
      line-height:1.78;
    }

    /* Eyebrow siempre arriba del título */
    .eyebrow + .section-heading,
    .intro-eyebrow + .intro-title{
      display:block;
      width:100%;
      clear:both;
    }
    .text-center .eyebrow,
    .text-center .intro-eyebrow{
      margin-left:auto;
      margin-right:auto;
    }
    .section-heading{
      display:block;
      width:100%;
    }

    /* ─── QUIÉNES SOMOS ─────────────────────────────────────────── */
    .about-card{
      background:#fff;
      border:1px solid var(--line);
      border-radius:var(--radius-lg);
      padding:2.2rem 2rem;
      box-shadow:var(--shadow);
      position:relative;overflow:hidden;
    }
    .about-card::before{
      content:'';position:absolute;top:0;left:0;right:0;height:4px;
      background:linear-gradient(90deg,var(--accent-dark),var(--accent),var(--accent-light));
    }
    .about-card p{color:var(--muted);line-height:1.8;margin-bottom:1rem}
    .about-card p:last-child{margin-bottom:0}
    .about-card strong{color:var(--brand)}
    .check-list{list-style:none;padding:0;margin:1.6rem 0 0;display:grid;gap:.8rem}
    .check-list li{
      display:flex;gap:.85rem;align-items:flex-start;
      font-size:.97rem;color:var(--muted);
    }
    .check-list li .icon-check{
      flex:0 0 auto;width:22px;height:22px;border-radius:50%;
      background:var(--accent-light);color:var(--accent-dark);
      display:grid;place-items:center;font-size:.8rem;margin-top:.1rem
    }
    .media-frame{
      border-radius:var(--radius-lg);overflow:hidden;
      border:1px solid var(--line);box-shadow:var(--shadow-lg);
      background:#fff;min-height:420px;
      display:flex;align-items:center;justify-content:center;padding:12px;
    }
    .media-frame img{
      width:100%;height:100%;max-height:520px;
      object-fit:contain;display:block;background:#fff;border-radius:18px;
    }

    /* ─── SERVICIOS ─────────────────────────────────────────────── */
    .service-card{
      height:100%;background:#fff;
      border:1px solid var(--line);
      border-radius:var(--radius);
      padding:1.75rem 1.6rem;
      box-shadow:0 4px 20px rgba(17,17,17,.05);
      transition:var(--t);
      position:relative;overflow:hidden;
    }
    .service-card::after{
      content:'';position:absolute;
      inset-x:0;bottom:0;height:0;
      background:linear-gradient(0deg,rgba(207,188,121,.08),transparent);
      transition:height .4s ease;
    }
    .service-card:hover{
      transform:translateY(-6px);
      box-shadow:0 20px 50px rgba(17,17,17,.11);
      border-color:rgba(207,188,121,.55);
    }
    .service-card:hover::after{height:100%}
    .service-icon{
      width:56px;height:56px;border-radius:16px;
      background:var(--accent-light);color:var(--accent-dark);
      display:grid;place-items:center;font-size:1.4rem;
      margin-bottom:1.15rem;
      transition:var(--t);
    }
    .service-card:hover .service-icon{
      background:var(--brand);color:var(--accent);
    }
    .service-card h3{font-size:1.06rem;margin-bottom:.6rem}
    .service-card p{color:var(--muted);margin:0;font-size:.93rem;line-height:1.7}


    /* ─── IMAGE TICKER ─────────────────────────────────────────── */
    .image-ticker-section{
      background:#fff;
      padding:72px 0 70px;
      overflow:hidden;
      border-top:1px solid rgba(232,223,199,.72);
      border-bottom:1px solid rgba(232,223,199,.72);
    }
    .image-ticker{
      position:relative;
      width:100%;
      overflow:hidden;
    }
    .image-ticker-track{
      display:flex;
      align-items:center;
      gap:42px;
      width:max-content;
      animation:imageTickerMove 72s linear infinite;
      will-change:transform;
    }
    .image-ticker:hover .image-ticker-track{animation-play-state:paused}
    .image-ticker-item{
      flex:0 0 auto;
      width:auto;
      height:clamp(420px,34vw,560px);
      margin:0;
      border-radius:28px;
      overflow:visible;
      background:transparent;
      border:0;
      box-shadow:none;
    }
    .image-ticker-item img{
      height:100%;
      width:auto;
      max-width:none;
      object-fit:contain;
      object-position:center;
      display:block;
      border-radius:28px;
      background:#fff;
      border:1px solid var(--line);
      box-shadow:0 18px 44px rgba(17,17,17,.14);
    }
    @keyframes imageTickerMove{
      from{transform:translateX(0)}
      to{transform:translateX(-50%)}
    }
    @media(max-width:991.98px){
      .image-ticker-section{padding:56px 0 54px}
      .image-ticker-track{gap:30px;animation-duration:62s}
      .image-ticker-item{height:clamp(330px,48vw,430px);border-radius:24px}
      .image-ticker-item img{border-radius:24px}
    }
    @media(max-width:575.98px){
      .image-ticker-section{padding:42px 0 40px}
      .image-ticker-track{gap:22px;animation-duration:50s}
      .image-ticker-item{height:clamp(260px,72vw,340px);border-radius:20px}
      .image-ticker-item img{border-radius:20px}
    }

    /* ─── POR QUÉ ELEGIRNOS ─────────────────────────────────────── */
    .why-card{
      height:100%;
      padding:1.8rem 1.6rem;
      border-radius:var(--radius);
      border:1px solid var(--line);
      background:#fff;
      box-shadow:0 4px 20px rgba(17,17,17,.05);
      transition:var(--t);
      position:relative;overflow:hidden;
    }
    .why-card::before{
      content:'';position:absolute;
      left:0;top:0;bottom:0;width:3px;
      background:linear-gradient(180deg,var(--accent-dark),var(--accent));
      border-radius:0 3px 3px 0;
      transform:scaleY(0);transform-origin:bottom;
      transition:transform .4s ease;
    }
    .why-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:rgba(207,188,121,.4)}
    .why-card:hover::before{transform:scaleY(1)}
    .why-icon{
      width:52px;height:52px;border-radius:14px;
      display:grid;place-items:center;
      background:var(--brand);color:var(--accent);
      font-size:1.3rem;margin-bottom:1.1rem;
      transition:var(--t);
    }
    .why-card:hover .why-icon{background:var(--accent);color:var(--brand)}
    .why-card h3{font-size:1.02rem;margin-bottom:.5rem;font-weight:700}
    .why-card p{color:var(--muted);margin:0;font-size:.93rem;line-height:1.7}

    /* ─── GALLERY (unchanged functionally, subtle polish) ────────── */
    .gal-gallery .carousel{max-width:980px;margin-inline:auto;position:relative}
    .gal-frame{
      height:clamp(260px,52vh,500px);background:#fff;
      border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);
      display:flex;align-items:center;justify-content:center;
      padding:10px;border:1px solid var(--line)
    }
    .gal-img{
      width:auto!important;max-width:100%;height:auto!important;
      max-height:100%;object-fit:contain!important;object-position:center;
      display:block;cursor:zoom-in
    }
    .gal-gallery .carousel-control-prev,.gal-gallery .carousel-control-next{
      z-index:20;width:52px;height:52px;top:50%;transform:translateY(-50%);
      opacity:1;background:rgba(17,17,17,.66);border-radius:50%;
      margin:0 12px;transition:var(--t)
    }
    .gal-gallery .carousel-control-prev:hover,.gal-gallery .carousel-control-next:hover{background:#111}
    .gal-gallery .carousel-control-prev{left:0}
    .gal-gallery .carousel-control-next{right:0}
    .gal-gallery .gal-ctrl-icon{width:2.6rem;height:2.6rem;background-size:60% 60%}
    .gal-gallery .carousel-indicators{z-index:10;bottom:-52px}
    .gal-gallery .carousel-indicators button{
      width:10px;height:10px;border-radius:50%;
      background:rgba(17,17,17,.35);border:none
    }
    .gal-gallery .carousel-indicators button.active{background:#111}
    .gal-gallery{padding-bottom:60px}
    #galLightbox .modal-content{background:#000;border:0;border-radius:20px;overflow:hidden}
    #galLightboxImg{max-height:86vh;width:100%;height:auto;object-fit:contain;background:#000}
    .gal-lightbox-nav{
      position:absolute;top:50%;transform:translateY(-50%);
      border:0;width:46px;height:46px;border-radius:999px;
      background:rgba(255,255,255,.18);color:#fff;font-size:32px;
      line-height:44px;text-align:center;z-index:5;cursor:pointer;transition:var(--t)
    }
    .gal-lightbox-nav:hover{background:rgba(255,255,255,.3)}
    .gal-lightbox-nav.gal-prev{left:12px}
    .gal-lightbox-nav.gal-next{right:12px}

    /* ─── FAQs ──────────────────────────────────────────────────── */
    .faq-wrap .accordion-item{
      border:1px solid var(--line)!important;
      border-radius:16px!important;overflow:hidden;
      margin-bottom:.9rem;background:#fff;
      box-shadow:0 4px 16px rgba(17,17,17,.04);
      transition:var(--t);
    }
    .faq-wrap .accordion-item:hover{box-shadow:var(--shadow)}
    .faq-wrap .accordion-button{
      font-weight:700;color:var(--brand);
      background:#fff;padding:1.2rem 1.4rem;
      font-family:'Plus Jakarta Sans',sans-serif;
      font-size:.97rem;gap:.75rem;
    }
    .faq-wrap .accordion-button::before{
      content:'';flex:0 0 20px;height:20px;border-radius:50%;
      background:var(--accent-light);
      background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%239f8946' d='M8 4a.5.5 0 0 1 .5.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3A.5.5 0 0 1 8 4z'/%3E%3C/svg%3E");
      background-size:100%;background-repeat:no-repeat;
      transition:var(--t);
    }
    .faq-wrap .accordion-button:not(.collapsed)::before{
      background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%239f8946' d='M4 8a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7A.5.5 0 0 1 4 8z'/%3E%3C/svg%3E");
      background:var(--accent-light);
    }
    .faq-wrap .accordion-button:not(.collapsed){
      background:var(--paper);color:var(--brand);box-shadow:none;
    }
    .faq-wrap .accordion-button:focus{
      box-shadow:0 0 0 .2rem rgba(207,188,121,.22);
    }
    .faq-wrap .accordion-button::after{display:none}
    .faq-wrap .accordion-body{
      color:var(--muted);padding:0 1.4rem 1.2rem 3.3rem;
      font-size:.96rem;line-height:1.78;
    }

    /* ─── CONTACT ───────────────────────────────────────────────── */
    .contact-info-card{
      height:100%;
      background:var(--brand);
      border-radius:var(--radius-lg);
      padding:2.4rem 2rem;
      color:#fff;
      position:relative;overflow:hidden;
    }
    .contact-info-card::before{
      content:'';position:absolute;
      right:-80px;top:-80px;
      width:300px;height:300px;border-radius:50%;
      background:rgba(207,188,121,.08);pointer-events:none
    }
    .contact-info-card::after{
      content:'';position:absolute;
      left:-60px;bottom:-60px;
      width:220px;height:220px;border-radius:50%;
      background:rgba(207,188,121,.06);pointer-events:none
    }
    .contact-info-card h3{color:#fff;margin-bottom:1.5rem;font-size:1.3rem}
    .ci-item{
      display:flex;gap:1rem;align-items:flex-start;
      margin-bottom:1.4rem;color:rgba(255,255,255,.82)
    }
    .ci-item:last-child{margin-bottom:0}
    .ci-icon{
      flex:0 0 42px;height:42px;border-radius:12px;
      background:rgba(207,188,121,.18);color:var(--accent);
      display:grid;place-items:center;font-size:1.1rem;
    }
    .ci-label{font-weight:700;color:#fff;display:block;margin-bottom:.2rem;font-size:.9rem}
    .ci-value{font-size:.93rem;line-height:1.5}
    .ci-value a{color:rgba(255,255,255,.82);transition:color .2s}
    .ci-value a:hover{color:var(--accent)}

    .contact-form-card{
      height:100%;
      background:#fff;
      border:1px solid var(--line);
      border-radius:var(--radius-lg);
      padding:2.4rem 2rem;
      box-shadow:var(--shadow);
    }
    .form-label{font-weight:700;color:var(--brand);margin-bottom:.45rem;font-size:.9rem}
    .form-control,.form-select{
      padding:.85rem 1.1rem;
      border-radius:12px;
      border:1.5px solid var(--line);
      transition:var(--t);background:#fff;
      font-family:inherit;font-size:.96rem;
      color:var(--ink)
    }
    .form-control:focus,.form-select:focus{
      border-color:var(--accent-dark);
      box-shadow:0 0 0 .2rem rgba(207,188,121,.18);
      outline:none;
    }
    .form-control::placeholder{color:#aaa}

    /* ─── FOOTER ────────────────────────────────────────────────── */
    footer{
      background:var(--brand);color:#fff;
      padding:60px 0 28px;
      position:relative;overflow:hidden;
    }
    footer::before{
      content:'';position:absolute;
      right:-200px;top:-200px;
      width:600px;height:600px;border-radius:50%;
      background:radial-gradient(circle,rgba(207,188,121,.07) 0%,transparent 70%);
      pointer-events:none
    }
    .footer-brand{display:flex;align-items:center;gap:.8rem;margin-bottom:1rem}
    .footer-brand img{height:42px;width:auto;object-fit:contain;flex:0 0 auto}
    .footer-brand-name{
      font-family:'Domine',Georgia,serif;
      font-weight:700;font-size:1.05rem;color:#fff
    }
    .footer-desc{max-width:440px;color:rgba(255,255,255,.6);font-size:.92rem;line-height:1.72}
    .footer-divider{
      width:40px;height:2px;
      background:linear-gradient(90deg,var(--accent-dark),var(--accent));
      border-radius:2px;margin:1.2rem 0;
    }
    .footer-heading{
      font-size:.78rem;font-weight:800;
      text-transform:uppercase;letter-spacing:.1em;
      color:var(--accent);margin-bottom:1rem
    }
    .footer-links{display:grid;gap:.55rem}
    .footer-links a{
      font-size:.9rem;font-weight:500;
      color:rgba(255,255,255,.65);transition:color .2s;
    }
    .footer-links a:hover{color:#fff}
    .footer-bottom{
      border-top:1px solid rgba(255,255,255,.08);
      margin-top:40px;padding-top:22px;
      display:flex;flex-wrap:wrap;gap:1rem;
      justify-content:space-between;align-items:center;
      font-size:.86rem;color:rgba(255,255,255,.5)
    }
    .netfan-link{font-weight:700;color:rgba(255,255,255,.75);text-decoration:underline;text-underline-offset:3px}
    .netfan-link:hover{color:#fff}

    /* ─── WHATSAPP FLOAT ────────────────────────────────────────── */
    .wa-float{position:fixed;right:22px;bottom:22px;z-index:10050}
    .wa-btn{
      background:#25d366;color:#fff;border:0;
      width:62px;height:62px;border-radius:50%;
      display:grid;place-items:center;
      box-shadow:0 8px 30px rgba(37,211,102,.38);
      cursor:pointer;transition:var(--t);font-size:1.6rem;
    }
    .wa-btn:hover{transform:translateY(-3px) scale(1.06)}
    .wa-card{
      position:absolute;right:0;bottom:78px;
      width:min(360px,92vw);background:#111;color:#fff;
      border-radius:22px;overflow:hidden;
      box-shadow:0 20px 60px rgba(0,0,0,.45);
      border:1px solid rgba(255,255,255,.08);
      transform:translateY(12px);opacity:0;
      transition:transform .32s cubic-bezier(.4,0,.2,1),opacity .32s ease;
    }
    .wa-card[aria-modal="true"]{transform:translateY(0);opacity:1}
    .wa-head{
      display:flex;align-items:center;gap:12px;
      padding:14px 16px;background:#161616;
      border-bottom:1px solid rgba(255,255,255,.07)
    }
    .wa-avatar{
      width:40px;height:40px;border-radius:12px;
      background:var(--accent);color:#111;
      display:grid;place-items:center;font-weight:900;font-size:1rem
    }
    .wa-title{font-weight:800;font-size:1.02rem}
    .wa-status{
      font-size:.82rem;color:rgba(255,255,255,.65);
      display:flex;align-items:center;gap:6px
    }
    .wa-status::before{
      content:'';width:7px;height:7px;border-radius:50%;background:#25d366
    }
    .wa-close{
      margin-left:auto;background:transparent;color:#fff;border:0;
      font-size:22px;cursor:pointer;opacity:.7;
      width:30px;height:30px;border-radius:50%;transition:var(--t)
    }
    .wa-close:hover{opacity:1;background:rgba(255,255,255,.1)}
    .wa-body{
      padding:14px 16px;max-height:40vh;overflow:auto;
      background:#111;display:flex;flex-direction:column;gap:10px
    }
    .wa-bubble{
      max-width:88%;padding:10px 14px;border-radius:14px;
      line-height:1.4;box-shadow:0 4px 12px rgba(0,0,0,.2);font-size:.93rem
    }
    .wa-bot{
      background:#202020;border:1px solid rgba(255,255,255,.06);
      align-self:flex-start;border-bottom-left-radius:4px
    }
    .wa-user{background:#128c7e;align-self:flex-end;border-bottom-right-radius:4px}
    .wa-compose{
      display:grid;grid-template-columns:1fr auto;gap:8px;
      padding:10px 12px;background:#111;
      border-top:1px solid rgba(255,255,255,.07)
    }
    .wa-compose textarea{
      resize:none;border-radius:12px;padding:10px 14px;
      border:1px solid rgba(255,255,255,.13);
      background:#1c1c1c;color:#fff;outline:0;
      min-height:44px;font-family:inherit;font-size:.93rem
    }
    .wa-send{
      background:#25d366;color:#111;border:0;
      border-radius:12px;padding:0 18px;
      font-weight:900;cursor:pointer;font-size:.95rem;
      transition:var(--t)
    }
    .wa-send:hover{background:#1fba5a}

    /* ─── REVEAL ANIMATION ──────────────────────────────────────── */
    .reveal{opacity:0;transform:translateY(26px);transition:opacity .75s ease,transform .75s ease}
    .reveal.active{opacity:1;transform:translateY(0)}

    /* ─── RESPONSIVE ────────────────────────────────────────────── */
    @media(max-width:991.98px){
      :root{--nav-h:66px}
      .navbar{padding:.6rem 0}
      .navbar-collapse{
        position:absolute;left:12px;right:12px;
        top:calc(100% + 8px);background:#fff;
        border:1px solid var(--line);border-radius:22px;
        padding:16px;box-shadow:var(--shadow-lg);
      }
      .nav-cta{display:inline-flex;margin-top:.5rem;margin-left:0}
      .media-frame{min-height:340px}
    }
    @media(max-width:767.98px){
      .section{padding:66px 0}
      .contact-info-card,.contact-form-card{padding:1.8rem 1.5rem}
      .wa-float{right:14px;bottom:14px}
      .wa-card{width:calc(100vw - 28px)}
      .intro-stats{grid-template-columns:1fr 1fr}
    }
    @media(max-width:480px){
      .intro-stats{grid-template-columns:1fr}
    }

