:root{
    --bg: #f6f3ef;
    --paper: #ffffff;
    --text: #171717;
    --muted: #5f5f5f;
    --line: rgba(0,0,0,.10);
    --accent: #c7a57a;
    --accent2: #efe3d3;
  
    --shadow: 0 18px 55px rgba(0,0,0,.10);
    --shadow2: 0 10px 30px rgba(0,0,0,.08);
  
    --r: 18px;
    --r2: 26px;
  }
  
  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    margin:0;
    font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
    color:var(--text);
    background:
      radial-gradient(1200px 600px at 10% -10%, rgba(199,165,122,.18), transparent 60%),
      radial-gradient(900px 500px at 90% 0%, rgba(0,0,0,.05), transparent 60%),
      radial-gradient(700px 400px at 50% 100%, rgba(199,165,122,.10), transparent 70%),
      linear-gradient(180deg, #f6f3ef 0%, #f9f7f4 40%, #ffffff 100%);
  }
  
  a{color:inherit; text-decoration:none}
  .container{width:min(1120px, 92%); margin-inline:auto}
  
  /* ===== Topbar ===== */
  .topbar{
    position:sticky; top:0; z-index:50;
    background: rgba(246,243,239,.82);
    backdrop-filter: blur(10px);
    border-bottom:1px solid rgba(0,0,0,.08);
  }
  .topbar__inner{
    display:flex; align-items:center; justify-content:space-between;
    padding:12px 0;
    gap:14px;
  }
  .brand{display:flex; align-items:center; gap:12px; min-width:240px}
  .brand__logo{
    width:44px; height:44px; border-radius:14px; object-fit:cover;
    border:1px solid var(--line);
    box-shadow: 0 10px 24px rgba(0,0,0,.10);
  }
  .brand__text{display:flex; flex-direction:column; line-height:1.1}
  .brand__name{font-weight:950; letter-spacing:.2px}
  .brand__tag{font-size:.85rem; color:var(--muted)}
  
  .nav{display:flex; gap:10px; flex-wrap:wrap}
  .nav a{
    font-weight:900;
    font-size:.95rem;
    color:rgba(0,0,0,.78);
    padding:10px 12px;
    border-radius:999px;
  }
  .nav a:hover{background: rgba(199,165,122,.18)}
  
  .nav__toggle{
    display:none;
    width:44px; height:44px; border-radius:16px;
    border:1px solid var(--line);
    background: rgba(255,255,255,.75);
    cursor:pointer;
    box-shadow: 0 10px 24px rgba(0,0,0,.08);
  }
  .nav__toggle span{
    display:block; height:2px; width:18px; margin:5px auto;
    background: rgba(0,0,0,.70);
  }
  
  /* ===== Buttons ===== */
  .btn{
    display:inline-flex; align-items:center; justify-content:center;
    gap:10px;
    padding:12px 16px;
    border-radius:16px;
    border:1px solid var(--line);
    font-weight:950;
    letter-spacing:.2px;
    cursor:pointer;
    transition: transform .16s ease, box-shadow .16s ease, background .16s ease;
    user-select:none;
  }
  .btn:active{transform: translateY(1px)}
  .btn:hover{transform: translateY(-2px)}
  
  .btn--primary{
    background: linear-gradient(180deg, #111, #000);
    color:#fff;
    border-color: rgba(0,0,0,.85);
    box-shadow: 0 18px 40px rgba(0,0,0,.18);
  }
  .btn--primary:hover{
    background: linear-gradient(180deg, #1a1a1a, #050505);
    box-shadow: 0 24px 70px rgba(0,0,0,.22);
  }
  
  .btn--ghost{
    background: rgba(255,255,255,.88);
    color:#0f0f0f;
    border-color: rgba(0,0,0,.12);
    box-shadow: var(--shadow2);
  }
  .btn--ghost:hover{background: rgba(255,255,255,.96)}
  
  /* ===== Cards ===== */
  .card{
    background: rgba(255,255,255,.88);
    border:1px solid rgba(0,0,0,.10);
    border-radius: var(--r2);
    box-shadow: var(--shadow);
    overflow:hidden;
  }
  .card:hover{box-shadow: 0 26px 70px rgba(0,0,0,.12)}
  .glass{
    background: rgba(255,255,255,.74);
    backdrop-filter: blur(10px);
  }
  
  /* ===== HERO ===== */
  .hero{
    position:relative;
    padding:72px 0 38px;
    overflow:hidden;
  }
  .hero__bg{
    position:absolute; inset:0;
    background:
      linear-gradient(115deg, rgba(246,243,239,.92) 0%, rgba(246,243,239,.72) 45%, rgba(246,243,239,.92) 100%),
      url("assets/hero_utiles.jpg");
    background-size:cover;
    background-position:center;
    filter:saturate(1.08) contrast(1.02);
  }
  .hero__content{
    position:relative;
    display:grid;
    grid-template-columns: 1.05fr .95fr;
    gap:26px;
    align-items:start;
  }
  .hero h1{
    margin:0;
    font-size: clamp(2.15rem, 3.7vw, 3.45rem);
    line-height:1.05;
    letter-spacing:-.8px;
  }
  .accent{
    position:relative;
    padding-bottom:6px;
  }
  .accent::after{
    content:"";
    position:absolute; left:0; bottom:0;
    width:100%; height:2px;
    background: linear-gradient(90deg, var(--accent), transparent);
  }
  .hero p{
    margin:14px 0 0;
    color: rgba(0,0,0,.70);
    font-size:1.05rem;
    line-height:1.65;
    max-width:58ch;
  }
  .hero__cta{display:flex; gap:12px; margin-top:18px; flex-wrap:wrap}
  
  /* Badges */
  .hero__badges{display:flex; gap:10px; margin-top:18px; flex-wrap:wrap}
  .badge{
    border:1px solid rgba(0,0,0,.10);
    background: rgba(255,255,255,.78);
    border-radius:999px;
    padding:10px 12px;
    display:flex; gap:10px;
    box-shadow: 0 12px 26px rgba(0,0,0,.06);
  }
  .badge__title{color: rgba(0,0,0,.55); font-size:.85rem}
  .badge__value{font-weight:950; font-size:.9rem}
  
  /* Right Hero Card */
  .card__header{padding:18px 18px 10px}
  .card__header h2{margin:0; font-size:1.25rem}
  .card__header p{margin:8px 0 0; color: rgba(0,0,0,.62); font-size:.95rem}
  
  .quick{display:grid; gap:10px; padding:0 18px 18px}
  .quick__item{
    text-align:left;
    background: rgba(250,248,245,.92);
    border:1px solid rgba(0,0,0,.10);
    border-radius:18px;
    padding:12px 14px;
    color: var(--text);
    box-shadow: 0 10px 24px rgba(0,0,0,.06);
  }
  .quick__item:hover{background: rgba(239,227,211,.70)}
  .quick__item span{display:block; font-weight:950}
  .quick__item small{color: rgba(0,0,0,.58)}
  
  .card__footer{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap:12px;
    border-top:1px solid rgba(0,0,0,.10);
    padding:14px 18px;
    background: rgba(255,255,255,.65);
  }
  .mini__label{display:block; color: rgba(0,0,0,.55); font-size:.85rem}
  #tel-link{font-weight:950}
  
  /* Note */
  .note{
    margin-top:12px;
    display:flex; align-items:center; gap:10px;
    color: rgba(0,0,0,.65);
    font-size:.95rem;
  }
  .dot{
    width:10px; height:10px; border-radius:999px;
    background: var(--accent);
    box-shadow: 0 0 18px rgba(199,165,122,.55);
  }
  
  /* ===== SECTIONS ===== */
  .section{padding:70px 0}
  .section--alt{
    background:
      radial-gradient(900px 600px at 50% 0%, rgba(199,165,122,.16), transparent 55%),
      linear-gradient(to bottom, rgba(255,255,255,.60), rgba(255,255,255,.25));
    border-top:1px solid rgba(0,0,0,.08);
    border-bottom:1px solid rgba(0,0,0,.08);
  }
  .section__head{
    display:flex; align-items:flex-end; justify-content:space-between;
    gap:20px;
    margin-bottom:18px;
  }
  .section__head h2{margin:0; font-size:1.9rem; letter-spacing:-.35px}
  .section__head p{margin:0; color: rgba(0,0,0,.60)}
  
  /* grid base */
  .grid{display:grid; gap:14px}
  
  /* ===== SERVICIOS + ICONOS ===== */
  .services{grid-template-columns: repeat(4, 1fr)}
  .service{
    padding:18px;
    border-radius: var(--r);
    border:1px solid rgba(0,0,0,.10);
    background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(248,245,241,.85));
    box-shadow: 0 14px 34px rgba(0,0,0,.07);
    position:relative;
    overflow:hidden;
    transition: transform .18s ease, box-shadow .18s ease;
  }
  .service:hover{transform: translateY(-3px)}
  .service::before{
    content:"";
    position:absolute; inset:-2px;
    background:
      radial-gradient(420px 220px at 20% 0%, rgba(199,165,122,.28), transparent 55%),
      radial-gradient(420px 220px at 100% 30%, rgba(0,0,0,.06), transparent 55%);
    opacity:.85;
    pointer-events:none;
  }
  .service > *{position:relative}
  
  .service h3{
    margin:0 0 10px;
    font-size:1.15rem;
    display:flex;
    align-items:center;
    gap:10px;
  }
  .service h3::before{
    width:34px; height:34px;
    display:grid; place-items:center;
    border-radius:12px;
    border:1px solid rgba(0,0,0,.10);
    background: rgba(239,227,211,.70);
    font-size: 1.05rem;
  }
  .service:nth-child(1) h3::before{ content:"🖨️"; }
  .service:nth-child(2) h3::before{ content:"📄"; }
  .service:nth-child(3) h3::before{ content:"📚"; }
  .service:nth-child(4) h3::before{ content:"✏️"; }
  
  .service p{color: rgba(0,0,0,.62); margin:10px 0 12px}
  .service ul{margin:0; padding-left:18px; color: rgba(0,0,0,.72)}
  .service li{margin:6px 0}
  
  /* Callout */
  .callout{
    margin-top:16px;
    padding:18px;
    border-radius: var(--r2);
    border:1px solid rgba(0,0,0,.10);
    background: linear-gradient(115deg, rgba(255,255,255,.95), rgba(239,227,211,.70));
    display:flex; align-items:center; justify-content:space-between;
    gap:14px;
    box-shadow: 0 16px 38px rgba(0,0,0,.08);
  }
  
  /* ===== PROMOS ===== */
  .promos{grid-template-columns: repeat(3, 1fr)}
  .promo{
    padding:18px;
    border-radius: var(--r);
    border:1px solid rgba(0,0,0,.10);
    background: rgba(255,255,255,.88);
    box-shadow: 0 14px 34px rgba(0,0,0,.07);
    transition: transform .18s ease, box-shadow .18s ease;
  }
  .promo:hover{transform: translateY(-3px)}
  .promo h3{margin:0}
  .promo p{color: rgba(0,0,0,.62)}
  
  /* ===== UBICACIÓN ===== */
  .location{grid-template-columns: 1fr}
  .location__map iframe{
    width:100%;
    height: 420px;
    border:0;
    display:block;
    filter: contrast(1.05) saturate(1.05);
    transition: transform .7s ease, filter .7s ease;
  }
  .location__map:hover iframe{
    transform: scale(1.01);
    filter: contrast(1.08) saturate(1.10);
  }
  
  .location__chips{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-top: 14px;
  }
  .chip{
    display:flex;
    align-items:center;
    gap:8px;
    padding: 10px 12px;
    border-radius: 999px;
    background: rgba(255,255,255,.82);
    border:1px solid rgba(0,0,0,.10);
    box-shadow: 0 10px 24px rgba(0,0,0,.06);
    color: rgba(0,0,0,.78);
    font-weight: 800;
    font-size: .92rem;
  }
  .location__actions{
    display:flex;
    gap:10px;
    margin-top: 16px;
    flex-wrap:wrap;
  }
  
  /* ===== CONTACTO ===== */
  #contacto .contact{grid-template-columns: 1fr 1fr; gap:40px; margin-top: 18px}
  #contacto .card{padding:30px}
  #contacto h3{margin:0 0 10px}
  #contacto p{margin:0 0 14px; color: rgba(0,0,0,.62)}
  .muted{margin-top:10px; color: rgba(0,0,0,.60)}
  .muted b{font-size:1.05rem; letter-spacing:.3px}
  
  /* Reseñas */
  .reviews{
    margin-top: 22px;
    padding-top: 18px;
    border-top: 1px solid rgba(0,0,0,.08);
  }
  .reviews__title{
    font-weight: 950;
    margin-bottom: 14px;
    color: rgba(0,0,0,.75);
    font-size: .95rem;
    letter-spacing: .4px;
  }
  .review{
    background: rgba(255,255,255,.85);
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 16px;
    padding: 14px;
    margin-bottom: 12px;
    box-shadow: 0 10px 25px rgba(0,0,0,.05);
    transition: transform .2s ease, box-shadow .2s ease;
  }
  .review:hover{
    transform: translateY(-3px);
    box-shadow: 0 18px 45px rgba(0,0,0,.10);
  }
  .stars{
    color: #c7a57a;
    font-size: .85rem;
    margin-bottom: 6px;
    letter-spacing: 2px;
  }
  .review p{margin:0; font-size:.9rem; color: rgba(0,0,0,.65)}
  
  /* Form icon inputs */
  .form{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px 20px;
    margin-top: 16px;
  }
  .field{
    position:relative;
    border-radius: 18px;
    border: 1px solid rgba(0,0,0,.10);
    background: rgba(255,255,255,.88);
    box-shadow: 0 10px 24px rgba(0,0,0,.06);
    padding: 14px 14px 12px;
  }
  .field:hover{
    transform: translateY(-2px);
    box-shadow: 0 18px 40px rgba(0,0,0,.10);
  }
  .field--full{grid-column: 1 / -1;}
  .field__icon{
    position:absolute;
    left: 14px;
    top: 44px;
    width: 34px;
    height: 34px;
    display:grid;
    place-items:center;
    border-radius: 12px;
    background: rgba(239,227,211,.75);
    border: 1px solid rgba(0,0,0,.10);
    box-shadow: 0 10px 18px rgba(0,0,0,.06);
    user-select:none;
  }
  .field label{
    display:flex;
    flex-direction:column;
    gap: 8px;
    font-size: .9rem;
    font-weight: 950;
    color: rgba(0,0,0,.78);
  }
  .field input,
  .field select,
  .field textarea{
    width:100%;
    padding: 14px 14px 14px 56px;
    border-radius: 16px;
    border: 1px solid rgba(0,0,0,.12);
    background: rgba(255,255,255,.96);
    color: var(--text);
    font-size: .95rem;
    outline:none;
  }
  .field textarea{min-height: 120px; resize: vertical;}
  .field:focus-within{
    border-color: rgba(199,165,122,.55);
    box-shadow: 0 0 0 4px rgba(199,165,122,.18), 0 18px 45px rgba(0,0,0,.10);
    transform: translateY(-2px);
  }
  .field:focus-within .field__icon{
    background: rgba(199,165,122,.22);
    border-color: rgba(199,165,122,.55);
    transform: scale(1.03);
  }
  .btn--pulse{grid-column: 1 / -1; width:100%; padding: 15px; border-radius: 999px}
  
  /* ===== WhatsApp Float ===== */
  @keyframes glow{
    0%,100%{ box-shadow: 0 18px 55px rgba(0,0,0,.10); }
    50%{ box-shadow: 0 22px 70px rgba(199,165,122,.18); }
  }
  .wa-float{
    position:fixed;
    right:18px; bottom:18px;
    z-index:60;
    display:flex; align-items:center; gap:10px;
    padding:12px 14px;
    border-radius:999px;
    background: linear-gradient(180deg, #111, #000);
    color:#fff;
    border:1px solid rgba(0,0,0,.85);
    box-shadow: 0 22px 65px rgba(0,0,0,.20);
    font-weight:950;
    animation: glow 2.8s ease-in-out infinite;
  }
  .wa-float__icon{
    width:26px; height:26px;
    display:grid; place-items:center;
    border-radius:999px;
    background: rgba(199,165,122,.22);
  }
  
  /* ===== Footer ===== */
  .footer{
    border-top:1px solid rgba(0,0,0,.08);
    padding:22px 0;
    background: rgba(255,255,255,.60);
  }
  .footer__inner{display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap}
  .footer__brand{font-weight:950}
  .footer__muted{color: rgba(0,0,0,.60); margin-top:6px}
  .footer__links{display:flex; gap:16px; color: rgba(0,0,0,.70)}
  .footer__links a:hover{color:#000}
  
  /* ===== Reveal Animations (scroll) ===== */
  .reveal{
    opacity:0;
    transform: translateY(16px);
    filter: blur(2px);
    transition: opacity .55s ease, transform .55s ease, filter .55s ease;
  }
  .reveal.is-visible{
    opacity:1;
    transform: translateY(0);
    filter: blur(0);
  }
  .reveal-stagger > *{
    opacity:0;
    transform: translateY(14px);
    transition: opacity .55s ease, transform .55s ease;
  }
  .reveal-stagger.is-visible > *{
    opacity:1;
    transform: translateY(0);
  }
  .reveal-stagger.is-visible > *:nth-child(1){ transition-delay: .00s; }
  .reveal-stagger.is-visible > *:nth-child(2){ transition-delay: .06s; }
  .reveal-stagger.is-visible > *:nth-child(3){ transition-delay: .12s; }
  .reveal-stagger.is-visible > *:nth-child(4){ transition-delay: .18s; }
  .reveal-stagger.is-visible > *:nth-child(5){ transition-delay: .24s; }
  .reveal-stagger.is-visible > *:nth-child(6){ transition-delay: .30s; }
  
  /* Hero entrance */
  @keyframes fadeUp{
    from{ opacity:0; transform: translateY(14px); }
    to{ opacity:1; transform: translateY(0); }
  }
  .hero h1{ animation: fadeUp .55s ease both; }
  .hero p{ animation: fadeUp .65s ease .06s both; }
  .hero__cta{ animation: fadeUp .70s ease .12s both; }
  .hero__badges{ animation: fadeUp .75s ease .18s both; }
  .hero__right{ animation: fadeUp .75s ease .10s both; }
  
  /* ===== Responsive ===== */
  @media (max-width: 980px){
    .hero__content{grid-template-columns:1fr}
    .services{grid-template-columns: repeat(2, 1fr)}
    #contacto .contact{grid-template-columns:1fr; gap:25px}
  }
  @media (max-width: 640px){
    .nav{
      display:none;
      position:absolute;
      right:4%;
      top:62px;
      width:92%;
      flex-direction:column;
      padding:14px;
      border-radius:18px;
      border:1px solid rgba(0,0,0,.10);
      background: rgba(255,255,255,.96);
      backdrop-filter: blur(10px);
      box-shadow: 0 18px 55px rgba(0,0,0,.12);
    }
    .nav a{padding:10px 10px; border-radius:14px}
    .nav a:hover{background: rgba(199,165,122,.18)}
    .nav__toggle{display:block}
    .services{grid-template-columns:1fr}
    .promos{grid-template-columns:1fr}
    .location__map iframe{height:360px}
    .form{grid-template-columns:1fr}
    .field--full{grid-column: 1}
  }
  