/* MIXED CSS PACK */
/* Template: egaobras.com.ar/index.html */
/* Template mtime: 2026-04-17 20:47:52 */

/* external link (no embedded): https://fonts.googleapis.com/css2?family=Outfit:wght@700;800&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap */
/* external link (no embedded): https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/css/bootstrap.min.css */

/* ===== INLINE <style> BLOCK #1 ===== */
/* ─── TOKENS ─────────────────────────────────────────── */
    :root{
      --accent:#aa1b17;
      --accent-dark:#871512;
      --accent-glow:rgba(170,27,23,.15);
      --text:#141414;
      --muted:#5e5e5e;
      --line:#e9e9e9;
      --soft:#f7f7f7;
      --radius:22px;
      --shadow:0 24px 60px rgba(0,0,0,.09);
      --shadow-sm:0 8px 24px rgba(0,0,0,.06);
    }

    /* ─── RESET & BASE ────────────────────────────────────── */
    *{box-sizing:border-box;margin:0;padding:0}
    html{scroll-behavior:smooth}
    body{
      font-family:'DM Sans',system-ui,sans-serif;
      color:var(--text);
      background:#fff;
      overflow-x:hidden;
      -webkit-font-smoothing:antialiased;
    }
    img{max-width:100%;display:block}
    a{text-decoration:none}
    .section{padding:100px 0}
    .section-soft{background:var(--soft)}

    /* ─── TYPOGRAPHY ──────────────────────────────────────── */
    h1,h2,h3,.syne{font-family:'Outfit',sans-serif}

    .eyebrow{
      display:inline-flex;
      align-items:center;
      gap:8px;
      padding:6px 16px 6px 8px;
      border-radius:999px;
      border:1px solid rgba(170,27,23,.2);
      color:var(--accent);
      background:rgba(170,27,23,.05);
      font-size:.78rem;
      font-weight:600;
      letter-spacing:.12em;
      text-transform:uppercase;
      margin-bottom:20px;
    }
    .eyebrow::before{
      content:"";
      width:6px;height:6px;
      border-radius:50%;
      background:var(--accent);
      flex:0 0 auto;
    }

    .section-title{
      font-family:'Outfit',sans-serif;
      font-size:clamp(1.9rem,3.5vw,3.1rem);
      line-height:1.06;
      font-weight:800;
      margin:0 0 16px;
      letter-spacing:-.025em;
    }
    .section-subtitle{
      max-width:680px;
      color:var(--muted);
      font-size:1.05rem;
      line-height:1.78;
    }

    /* ─── NAVBAR ──────────────────────────────────────────── */
    .topbar{
      background:rgba(255,255,255,.88);
      backdrop-filter:saturate(180%) blur(14px);
      -webkit-backdrop-filter:saturate(180%) blur(14px);
      border-bottom:1px solid rgba(20,20,20,.07);
      transition:box-shadow .3s;
    }
    .topbar.scrolled{box-shadow:0 8px 30px rgba(0,0,0,.07)}
    .navbar{padding:.85rem 0}
    .navbar-brand{display:flex;align-items:center;gap:12px;min-width:0}
    .navbar-brand img{height:38px;width:auto;object-fit:contain;flex:0 0 auto}
    .brand-text{
      font-family:'Outfit',sans-serif;
      font-size:.94rem;
      font-weight:800;
      color:var(--text);
      line-height:1.1;
      letter-spacing:-.01em;
    }
    .navbar-nav{--bs-nav-link-padding-x:.95rem;gap:.1rem}
    .nav-link{
      color:#353535;
      font-weight:500;
      font-size:.95rem;
      position:relative;
      transition:color .2s;
    }
    .nav-link::after{
      content:"";
      position:absolute;
      bottom:-2px;left:50%;right:50%;
      height:2px;
      background:var(--accent);
      border-radius:999px;
      transition:left .25s,right .25s;
    }
    .nav-link:hover::after,.nav-link.active::after{left:.95rem;right:.95rem}
    .nav-link:hover,.nav-link.active{color:var(--accent)}
    .navbar-toggler{
      border:1px solid rgba(20,20,20,.1);
      padding:.45rem .7rem;
      border-radius:12px;
      box-shadow:none!important;
      transition:background .2s;
    }
    .navbar-toggler:hover{background:var(--soft)}

    /* Mobile menu */
    @media(max-width:991.98px){
      .navbar-collapse{
        background:#fff;
        margin-top:10px;
        border:1px solid rgba(20,20,20,.07);
        border-radius:20px;
        padding:16px;
        box-shadow:0 20px 40px rgba(0,0,0,.1);
      }
    }

    /* ─── HERO ────────────────────────────────────────────── */
    .hero{
      padding:160px 0 100px;
      position:relative;
      overflow:hidden;
      background:#fff;
    }

    /* Geometric accent shape */
    .hero-bg-shape{
      position:absolute;
      top:-80px;right:-120px;
      width:580px;height:580px;
      background:conic-gradient(from 200deg at 60% 40%, rgba(170,27,23,.07) 0deg, transparent 80deg, rgba(170,27,23,.04) 160deg, transparent 220deg);
      border-radius:50%;
      pointer-events:none;
      animation:rotateShape 30s linear infinite;
    }
    @keyframes rotateShape{to{transform:rotate(360deg)}}

    .hero-bg-grid{
      position:absolute;
      inset:0;
      background-image:
        linear-gradient(rgba(170,27,23,.04) 1px,transparent 1px),
        linear-gradient(90deg,rgba(170,27,23,.04) 1px,transparent 1px);
      background-size:60px 60px;
      mask-image:radial-gradient(ellipse 70% 60% at 80% 10%,black 0%,transparent 100%);
      pointer-events:none;
    }

    .hero .container{position:relative;z-index:2}
    .hero-grid{align-items:center;row-gap:48px}

    .hero-title{
      font-family:'Outfit',sans-serif;
      font-size:clamp(2.8rem,5.5vw,5.5rem);
      line-height:.96;
      font-weight:800;
      letter-spacing:-.03em;
      margin:0 0 22px;
    }
    .hero-title em{
      font-style:normal;
      color:var(--accent);
      position:relative;
    }
    /* Underline decoration on accent word */
    .hero-title em::after{
      content:"";
      position:absolute;
      left:0;right:0;bottom:-4px;
      height:4px;
      background:var(--accent);
      border-radius:2px;
      transform:scaleX(0);
      transform-origin:left;
      animation:underlineGrow .8s .6s cubic-bezier(.22,1,.36,1) forwards;
    }
    @keyframes underlineGrow{to{transform:scaleX(1)}}

    .hero-text{
      font-size:1.06rem;
      color:var(--muted);
      line-height:1.85;
      max-width:600px;
      margin:0 0 30px;
    }

    /* CTA row */
    .hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:36px}

    .btn-main{
      min-height:54px;padding:0 28px;
      border-radius:14px;
      font-weight:600;font-size:.97rem;
      display:inline-flex;align-items:center;justify-content:center;gap:8px;
      background:var(--accent);color:#fff;
      box-shadow:0 12px 28px rgba(170,27,23,.28);
      transition:transform .25s,box-shadow .25s,background .2s;
      position:relative;overflow:hidden;
    }
    .btn-main::before{
      content:"";
      position:absolute;inset:0;
      background:linear-gradient(135deg,rgba(255,255,255,.12),transparent);
      pointer-events:none;
    }
    .btn-main:hover{
      background:var(--accent-dark);color:#fff;
      transform:translateY(-3px);
      box-shadow:0 18px 36px rgba(170,27,23,.32);
    }
    .btn-alt{
      min-height:54px;padding:0 26px;
      border-radius:14px;
      font-weight:600;font-size:.97rem;
      display:inline-flex;align-items:center;justify-content:center;gap:8px;
      color:var(--text);
      border:1.5px solid rgba(20,20,20,.14);
      background:#fff;
      transition:transform .25s,border-color .2s,color .2s,box-shadow .2s;
    }
    .btn-alt:hover{
      border-color:rgba(170,27,23,.3);
      color:var(--accent);
      transform:translateY(-3px);
      box-shadow:var(--shadow-sm);
    }

    /* Hero pills */
    .hero-points{
      display:flex;flex-wrap:wrap;
      gap:10px;
    }
    .hero-point{
      display:inline-flex;align-items:center;gap:8px;
      padding:10px 16px;
      background:#fff;
      border:1px solid var(--line);
      border-radius:12px;
      font-size:.9rem;
      font-weight:500;
      color:#2a2a2a;
      box-shadow:0 4px 14px rgba(0,0,0,.05);
      transition:border-color .2s,box-shadow .2s;
    }
    .hero-point::before{
      content:"";
      width:7px;height:7px;
      border-radius:50%;
      background:var(--accent);
      flex:0 0 auto;
    }
    .hero-point:hover{border-color:rgba(170,27,23,.25);box-shadow:0 6px 18px rgba(0,0,0,.08)}

    /* Hero media card */
    .hero-media{position:relative}
    .hero-card{
      position:relative;
      background:#fff;
      border:1px solid rgba(20,20,20,.06);
      border-radius:28px;
      padding:16px;
      box-shadow:var(--shadow);
      overflow:hidden;
    }
    /* Decorative corner accent */
    .hero-card::before{
      content:"";
      position:absolute;
      top:-1px;right:-1px;
      width:80px;height:80px;
      background:var(--accent);
      clip-path:polygon(100% 0,0 0,100% 100%);
      border-radius:0 28px 0 0;
      opacity:.08;
    }
    .hero-card::after{
      content:"";
      position:absolute;
      bottom:-60px;right:-60px;
      width:200px;height:200px;
      background:radial-gradient(circle,rgba(170,27,23,.15),transparent 70%);
      pointer-events:none;
    }
    .hero-image{
      width:100%;
      aspect-ratio:1/1;
      object-fit:contain;
      border-radius:18px;
      background:#fafafa;
    }
    .hero-note{
      position:absolute;
      left:16px;right:16px;bottom:16px;
      display:flex;align-items:center;gap:14px;
      background:rgba(255,255,255,.92);
      backdrop-filter:blur(14px);
      border:1px solid rgba(20,20,20,.07);
      border-radius:16px;
      padding:14px 18px;
      box-shadow:0 16px 32px rgba(0,0,0,.1);
    }
    .hero-note-mark{
      width:44px;height:44px;
      border-radius:12px;
      background:var(--accent);
      display:grid;place-items:center;
      color:#fff;font-weight:800;
      font-family:'Outfit',sans-serif;
      font-size:1.1rem;
      flex:0 0 auto;
      box-shadow:0 8px 16px rgba(170,27,23,.3);
    }
    .hero-note strong{
      display:block;
      font-size:.94rem;
      font-family:'Outfit',sans-serif;
      font-weight:700;
      line-height:1.2;
    }
    .hero-note span{display:block;font-size:.84rem;color:var(--muted);margin-top:3px}

    /* Floating badge */
    .hero-badge{
      position:absolute;
      top:24px;left:-18px;
      background:#fff;
      border:1px solid var(--line);
      border-radius:14px;
      padding:12px 16px;
      box-shadow:var(--shadow);
      display:flex;align-items:center;gap:10px;
      animation:floatBadge 4s ease-in-out infinite;
      z-index:3;
    }
    @keyframes floatBadge{
      0%,100%{transform:translateY(0)}
      50%{transform:translateY(-8px)}
    }
    .hero-badge-dot{
      width:10px;height:10px;border-radius:50%;
      background:#22c55e;
      box-shadow:0 0 0 3px rgba(34,197,94,.2);
      animation:pulse 2s infinite;
    }
    @keyframes pulse{
      0%,100%{box-shadow:0 0 0 3px rgba(34,197,94,.2)}
      50%{box-shadow:0 0 0 6px rgba(34,197,94,.1)}
    }
    .hero-badge span{font-size:.84rem;font-weight:600;color:var(--text)}

    /* ─── QUIENES SOMOS ───────────────────────────────────── */
    .about-wrap{position:relative}

    /* Vertical rule on left */
    .about-left-accent{
      position:absolute;
      top:0;left:-2px;
      width:3px;height:100%;
      background:linear-gradient(to bottom,var(--accent),rgba(170,27,23,0));
      border-radius:4px;
    }

    .about-box{
      background:#fff;
      border:1px solid rgba(20,20,20,.07);
      border-radius:26px;
      box-shadow:var(--shadow);
      padding:40px;
      position:relative;
      overflow:hidden;
    }
    .about-box::before{
      content:"";
      position:absolute;
      top:0;left:0;right:0;
      height:3px;
      background:linear-gradient(90deg,var(--accent),transparent);
    }
    .about-text{color:var(--muted);font-size:1.06rem;line-height:1.88}
    .about-highlight{
      margin-top:28px;
      padding:20px 24px;
      background:rgba(170,27,23,.04);
      border:1px solid rgba(170,27,23,.14);
      border-left:4px solid var(--accent);
      color:var(--text);
      border-radius:0 16px 16px 0;
      font-weight:600;
      font-size:1rem;
      line-height:1.6;
    }

    /* Stats row inside about */
    .about-stats{
      display:flex;
      flex-wrap:wrap;
      gap:16px;
      margin-top:28px;
    }
    .about-stat{
      flex:1;min-width:110px;
      background:var(--soft);
      border:1px solid var(--line);
      border-radius:16px;
      padding:18px 20px;
      text-align:center;
    }
    .about-stat-num{
      font-family:'Outfit',sans-serif;
      font-size:1.9rem;
      font-weight:800;
      color:var(--accent);
      line-height:1;
      display:block;
    }
    .about-stat-label{
      font-size:.8rem;
      font-weight:500;
      color:var(--muted);
      display:block;
      margin-top:6px;
      letter-spacing:.04em;
      text-transform:uppercase;
    }

    /* ─── SERVICES ────────────────────────────────────────── */
    .services-grid{row-gap:24px}

    .service-card{
      background:#fff;
      border:1px solid rgba(20,20,20,.07);
      border-radius:24px;
      box-shadow:var(--shadow-sm);
      height:100%;
      padding:30px;
      position:relative;
      overflow:hidden;
      transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s,border-color .3s;
    }
    .service-card::after{
      content:"";
      position:absolute;
      bottom:0;left:0;right:0;
      height:3px;
      background:var(--accent);
      transform:scaleX(0);
      transform-origin:left;
      transition:transform .35s cubic-bezier(.22,1,.36,1);
      border-radius:0 0 24px 24px;
    }
    .service-card:hover{
      transform:translateY(-8px);
      border-color:rgba(170,27,23,.14);
      box-shadow:0 28px 56px rgba(0,0,0,.12);
    }
    .service-card:hover::after{transform:scaleX(1)}

    .card-icon{
      width:56px;height:56px;
      border-radius:16px;
      display:grid;place-items:center;
      background:rgba(170,27,23,.07);
      color:var(--accent);
      margin-bottom:20px;
      transition:background .3s,transform .3s;
    }
    .service-card:hover .card-icon{
      background:rgba(170,27,23,.12);
      transform:scale(1.08);
    }
    .card-icon svg{width:26px;height:26px}
    .card-title{
      font-family:'Outfit',sans-serif;
      font-size:1.18rem;
      font-weight:800;
      line-height:1.18;
      margin:0 0 14px;
      letter-spacing:-.02em;
    }
    .card-text,.card-list{
      color:var(--muted);
      font-size:.97rem;
      line-height:1.82;
    }
    .card-list{padding-left:18px}
    .card-list li+li{margin-top:7px}

    /* ─── POR QUÉ ELEGIRNOS ───────────────────────────────── */
    .values-grid{row-gap:24px}

    .value-card{
      background:#fff;
      border:1px solid rgba(20,20,20,.07);
      border-radius:24px;
      box-shadow:var(--shadow-sm);
      height:100%;
      padding:30px;
      transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s,border-color .3s;
      position:relative;overflow:hidden;
    }
    .value-card::before{
      content:"";
      position:absolute;
      top:0;right:0;
      width:100px;height:100px;
      background:radial-gradient(circle at top right,rgba(170,27,23,.06),transparent 70%);
    }
    .value-card:hover{
      transform:translateY(-6px);
      border-color:rgba(170,27,23,.16);
      box-shadow:0 24px 48px rgba(0,0,0,.11);
    }

    /* ─── GALLERY — untouched section (kept exact) ─────────── */
    .gal-gallery .carousel{max-width:1080px;margin-inline:auto;position:relative}
    .gal-frame{
      height:clamp(280px,55vw,500px);
      background:#fff;
      border:1px solid rgba(20,20,20,.07);
      border-radius:28px;
      overflow:hidden;
      box-shadow:var(--shadow);
      display:flex;align-items:center;justify-content:center;
      padding:16px;
    }
    .gal-img{
      width:auto!important;max-width:100%;
      height:auto!important;max-height:100%;
      object-fit:contain!important;object-position:center;
      cursor:zoom-in;border-radius:18px;
    }
    .gal-gallery .carousel-control-prev,
    .gal-gallery .carousel-control-next{
      z-index:20;width:54px;height:54px;
      top:50%;transform:translateY(-50%);
      opacity:1;
      background:rgba(20,20,20,.72);
      border-radius:999px;margin:0 12px;
    }
    .gal-gallery .carousel-control-prev{left:0}
    .gal-gallery .carousel-control-next{right:0}
    .gal-gallery .gal-ctrl-icon{width:2.7rem;height:2.7rem;background-size:58% 58%}
    .gal-gallery .carousel-indicators{z-index:10;bottom:-58px;margin-bottom:0}
    .gal-gallery .carousel-indicators button{
      width:11px;height:11px;border-radius:50%;
      background:rgba(20,20,20,.35);border:none;margin:0 6px;
    }
    .gal-gallery .carousel-indicators button.active{background:var(--accent)}
    .gal-gallery{padding-bottom:96px}
    .gal-gallery .gallery-cta{margin-top:84px;position:relative;z-index:2}
    #galLightbox .modal-content{background:#000;border:0}
    #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:30px;line-height:46px;text-align:center;z-index:5;cursor:pointer;
    }
    .gal-lightbox-nav:hover{background:rgba(255,255,255,.28)}
    .gal-lightbox-nav.gal-prev{left:14px}
    .gal-lightbox-nav.gal-next{right:14px}

    /* ─── FAQs ────────────────────────────────────────────── */
    .faq-wrap{
      max-width:820px;
      margin-inline:auto;
    }
    .accordion-item{
      border:1px solid rgba(20,20,20,.08)!important;
      border-radius:18px!important;
      overflow:hidden;
      background:#fff;
      transition:border-color .2s,box-shadow .2s;
    }
    .accordion-item+.accordion-item{margin-top:12px}
    .accordion-item:has(.accordion-button:not(.collapsed)){
      border-color:rgba(170,27,23,.2)!important;
      box-shadow:0 8px 24px rgba(170,27,23,.06);
    }
    .accordion-button{
      font-family:'Outfit',sans-serif;
      font-weight:700;
      font-size:1rem;
      color:#1d1d1d;
      padding:20px 24px;
      box-shadow:none!important;
      background:#fff;
      border-radius:18px!important;
      gap:12px;
    }
    .accordion-button:not(.collapsed){
      color:var(--accent);
      background:rgba(170,27,23,.04);
      border-radius:18px 18px 0 0!important;
    }
    .accordion-button::after{
      background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235e5e5e' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
      background-size:20px;
      flex-shrink:0;
    }
    .accordion-button:not(.collapsed)::after{
      background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23aa1b17' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    }
    .accordion-body{
      color:var(--muted);
      line-height:1.8;
      padding:0 24px 22px;
      font-size:.98rem;
    }

    /* ─── CONTACT ─────────────────────────────────────────── */
    .contact-wrap{row-gap:28px}

    .contact-card{
      background:#fff;
      border:1px solid rgba(20,20,20,.07);
      border-radius:26px;
      box-shadow:var(--shadow);
      padding:40px;
      height:100%;
      position:relative;
      overflow:hidden;
    }
    .contact-card::before{
      content:"";
      position:absolute;
      top:0;left:0;right:0;
      height:3px;
      background:linear-gradient(90deg,var(--accent),rgba(170,27,23,.3));
    }

    .contact-list{display:grid;gap:14px;margin-top:28px}
    .contact-item{
      display:flex;gap:14px;align-items:flex-start;
      padding:16px 18px;
      border-radius:16px;
      background:var(--soft);
      border:1px solid var(--line);
      transition:border-color .2s,box-shadow .2s;
    }
    .contact-item:hover{
      border-color:rgba(170,27,23,.2);
      box-shadow:0 6px 18px rgba(0,0,0,.06);
    }
    .contact-item-mark{
      width:40px;height:40px;
      border-radius:12px;
      background:rgba(170,27,23,.08);
      display:grid;place-items:center;
      color:var(--accent);flex:0 0 auto;
    }
    .contact-item-mark svg{width:18px;height:18px}
    .contact-item strong{display:block;font-size:.93rem;font-weight:600;line-height:1.2;margin-bottom:4px}
    .contact-item span,.contact-item a{color:var(--muted);font-size:.94rem;line-height:1.55;word-break:break-word}
    .contact-item a:hover{color:var(--accent)}

    /* Contact form */
    .contact-form{
      background:#fff;
      border:1px solid rgba(20,20,20,.07);
      border-radius:26px;
      box-shadow:var(--shadow);
      padding:40px;
      height:100%;
    }
    .form-label{font-weight:600;font-size:.9rem;color:#1f1f1f;margin-bottom:.5rem;letter-spacing:.01em}
    .form-control,.form-select{
      min-height:52px;
      border-radius:14px;
      border:1.5px solid rgba(20,20,20,.11);
      padding:.8rem 1rem;
      box-shadow:none!important;
      font-size:.97rem;
      transition:border-color .2s,box-shadow .2s;
      background:#fff;
    }
    textarea.form-control{min-height:140px;resize:vertical}
    .form-control:focus,.form-select:focus{
      border-color:rgba(170,27,23,.45);
      box-shadow:0 0 0 4px rgba(170,27,23,.08)!important;
    }
    .form-control::placeholder{color:#b4b4b4}

    /* ─── FOOTER ──────────────────────────────────────────── */
    .footer{
      background:var(--accent);
      color:#fff;
      padding:80px 0 32px;
      position:relative;
      overflow:hidden;
    }
    /* Geometric decoration */
    .footer::before{
      content:"";
      position:absolute;
      bottom:-80px;right:-80px;
      width:360px;height:360px;
      border:60px solid rgba(255,255,255,.06);
      border-radius:50%;
    }
    .footer::after{
      content:"";
      position:absolute;
      top:-40px;left:30%;
      width:200px;height:200px;
      border:30px solid rgba(255,255,255,.04);
      border-radius:50%;
    }
    .footer .container{position:relative;z-index:1}

    .footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:20px}
    .footer-logo{height:40px;width:auto;object-fit:contain;flex:0 0 auto}
    .footer-brand-text{
      font-family:'Outfit',sans-serif;
      font-size:.95rem;font-weight:800;color:#fff;line-height:1.1;letter-spacing:-.01em;
    }
    .footer p,.footer a,.footer li{color:rgba(255,255,255,.82)}
    .footer-title{
      font-family:'Outfit',sans-serif;
      font-size:1rem;font-weight:800;
      margin:0 0 18px;letter-spacing:.01em;color:#fff;
    }
    .footer-text{margin:0;line-height:1.78;max-width:320px;font-size:.96rem}
    .footer-nav,.footer-contact{
      list-style:none;padding:0;margin:0;
      display:grid;gap:11px;
    }
    .footer a{transition:color .2s}
    .footer a:hover{color:#fff}

    .footer-divider{
      margin-top:52px;
      padding-top:24px;
      border-top:1px solid rgba(255,255,255,.16);
    }
    .footer-divider p{margin:0;font-size:.92rem;color:rgba(255,255,255,.72)}
    .footer-divider a{font-weight:700;color:#fff}

    /* ─── SCROLL ANIMATIONS ───────────────────────────────── */
    .reveal{
      opacity:0;
      transform:translateY(28px);
      transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1);
    }
    .reveal.visible{opacity:1;transform:none}
    .reveal-delay-1{transition-delay:.1s}
    .reveal-delay-2{transition-delay:.2s}
    .reveal-delay-3{transition-delay:.3s}
    .reveal-delay-4{transition-delay:.4s}

    .hero-media-mobile{display:none}

    /* ─── RESPONSIVE ──────────────────────────────────────── */
    @media(max-width:991.98px){
      .hero{padding:138px 0 80px}
      .hero-title{max-width:none}
      .hero-card{max-width:680px;margin-inline:auto}
      .hero-media{order:-1}
      .hero-badge{display:none}
    }
    @media(max-width:575.98px){
      .section{padding:80px 0}
      .hero{padding:120px 0 70px}
      .hero-grid{row-gap:24px}
      .hero-actions{flex-direction:column;align-items:stretch}
      .btn-main,.btn-alt{width:100%}
      .hero-side-media{display:none}
      .hero-media-mobile{display:block;margin:22px 0 18px}
      .hero-media-mobile .hero-card{max-width:360px;margin-inline:auto;padding:14px}
      .hero-media-mobile .hero-image{aspect-ratio:auto;max-height:320px}
      .hero-note{position:static;margin-top:14px}
      .about-box,.contact-card,.contact-form{padding:28px}
      .gal-frame{height:clamp(230px,42vh,360px);padding:12px}
      .gal-gallery .carousel-control-prev,
      .gal-gallery .carousel-control-next{width:46px;height:46px;margin:0 8px}
      .footer{padding-top:64px}
      .about-stats{flex-direction:column}
    }

/* ===== INLINE <style> BLOCK #2 ===== */
.wa-float{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:2147483647;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  font-family:'DM Sans',system-ui,sans-serif;
}

.wa-btn{
  width:60px;
  height:60px;
  border-radius:50%;
  border:none;
  background:linear-gradient(135deg,#25D366,#128C7E);
  color:#fff;
  display:grid;
  place-items:center;
  cursor:pointer;
  box-shadow:0 10px 30px rgba(37,211,102,.45);
  transition:transform .25s, box-shadow .25s;
}
.wa-btn:hover{
  transform:translateY(-3px) scale(1.05);
  box-shadow:0 14px 36px rgba(37,211,102,.55);
}

.wa-card{
  position:absolute;
  right:0;
  bottom:74px;
  width:min(360px,92vw);
  background:#fff;
  border-radius:18px;
  border:1px solid #e3e6ea;
  box-shadow:0 18px 60px rgba(0,0,0,.25);
  overflow:hidden;
  transform:translateY(10px);
  opacity:0;
  transition:.25s ease;
}
.wa-card[aria-modal="true"]{
  transform:none;
  opacity:1;
}

.wa-head{
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px;
  background:linear-gradient(135deg,#aa1b17,#871512);
  color:#fff;
}

.wa-avatar{
  width:40px;
  height:40px;
  background:#fff;
  border-radius:10px;
  display:grid;
  place-items:center;
  overflow:hidden;
}
.wa-avatar img{
  width:26px;
  height:26px;
  object-fit:contain;
}

.wa-title{
  font-weight:800;
  line-height:1.1;
}
.wa-status{
  font-size:.85rem;
  opacity:.9;
}

.wa-close{
  margin-left:auto;
  border:none;
  background:transparent;
  color:#fff;
  font-size:24px;
  cursor:pointer;
  width:32px;
  height:32px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:.9;
}
.wa-close:hover{
  opacity:1;
  background:rgba(255,255,255,.14);
}

.wa-body{
  padding:14px;
  max-height:40vh;
  overflow:auto;
  background:#f8f9fa;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.wa-bubble{
  max-width:88%;
  padding:10px 12px;
  border-radius:14px;
  font-size:.95rem;
  box-shadow:0 4px 10px rgba(0,0,0,.08);
}

.wa-bot{
  background:#fff;
  border:1px solid #e3e6ea;
  align-self:flex-start;
}

.wa-user{
  background:#fff3f2;
  border:1px solid rgba(170,27,23,.18);
  align-self:flex-end;
}

.wa-compose{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  padding:10px;
  border-top:1px solid #e3e6ea;
  background:#fff;
}

.wa-compose textarea{
  resize:none;
  border-radius:12px;
  padding:10px;
  border:1px solid #e3e6ea;
  font-family:inherit;
  outline:none;
}
.wa-compose textarea:focus{
  border-color:rgba(170,27,23,.35);
  box-shadow:0 0 0 3px rgba(170,27,23,.08);
}

.wa-send{
  background:#aa1b17;
  color:#fff;
  border:none;
  border-radius:12px;
  padding:0 16px;
  cursor:pointer;
  transition:background .2s ease;
}
.wa-send:hover{
  background:#871512;
}

@media(max-width:480px){
  .wa-float{
    right:12px;
    bottom:12px;
  }
  .wa-card{
    width:calc(100vw - 24px);
  }
}

