/*
Theme Name: HolaHijo
Theme URI: https://holahijo.com
Author: HolaHijo
Description: Tema demo para la tienda HolaHijo. Arte, fe y papelería hecha a mano. Paleta blanco / gris gastado con acento ladrillo, tipografía estilo lettering a marcador. Preparado para WooCommerce.
Version: 0.1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: holahijo
Tags: e-commerce, custom-colors, one-column
*/

:root{
    --blanco:#ffffff;
    --papel:#faf9f6;
    --gris-oscuro:#454340;   /* gris gastado, apenas más claro que el original */
    --gris-medio:#6f6c66;
    --gris-claro:#e8e6e1;
    --ladrillo:#9e3b35;      /* rojo que ella usa en sus letterings */
    --display:'Caveat',cursive;
    --marker:'Rock Salt',cursive;
    --body:'Karla',sans-serif;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{font-family:var(--body);color:var(--gris-oscuro);background:var(--blanco);line-height:1.6;}
  img{max-width:100%;display:block}
  a{color:inherit;text-decoration:none}
  ::selection{background:var(--gris-oscuro);color:var(--blanco)}

  

  /* ---------- header ---------- */
  header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--gris-claro);}
  /* WordPress: que la barra de admin no tape el menú al scrollear */
  body.admin-bar header{top:32px}
  @media (max-width:782px){ body.admin-bar header{top:46px} }
  html{scroll-padding-top:90px}
  .nav{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.5rem;min-height:76px;transition:min-height .25s ease,padding .25s ease;}
  header.scrolled .nav{min-height:50px;padding-top:.35rem;padding-bottom:.35rem}
  header.scrolled{background:rgba(255,255,255,.97)}
  .logo{display:inline-block;line-height:0;transform:rotate(-2deg);transition:opacity .25s ease;}
  .foot .logo img{width:150px;height:auto}
  header.scrolled .logo{opacity:0;pointer-events:none}
  .logo img{height:56px;width:auto;transition:height .25s ease}
  header.scrolled .logo img{height:34px}
  .logo em{font-style:normal;color:var(--ladrillo)}
  .menu{display:flex;gap:2rem;font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500}
  .menu a{position:relative;padding:.2rem 0}
  .menu a::after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:3px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='4' viewBox='0 0 60 4'%3E%3Cpath d='M1 3 C 12 1, 25 4, 38 2 S 55 3, 59 1' stroke='%239e3b35' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") repeat-x;transition:right .25s ease;}
  .menu a:hover::after{right:0}
  .icons{display:flex;gap:1.1rem;align-items:center}
  .icons button{background:none;border:none;cursor:pointer;font-family:var(--body);font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gris-oscuro);display:flex;align-items:center;gap:.35rem}
  .cart-count{background:var(--ladrillo);color:#fff;border-radius:50%;width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700}
  .burger{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer}

  /* ---------- hero ---------- */
  .hero{background:var(--papel);position:relative;overflow:hidden;}
  .hero-inner{max-width:1200px;margin:0 auto;padding:5.5rem 1.5rem 6rem;text-align:center;position:relative}
  .eyebrow{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gris-medio);margin-bottom:1.4rem}
  .hero h1{font-family:var(--marker);font-size:clamp(1.7rem,5vw,3.4rem);line-height:1.45;text-transform:uppercase;max-width:18ch;margin:0 auto;}
  .hero h1 .sub{display:inline-block;background:var(--gris-oscuro);color:var(--papel);padding:.05em .35em;transform:rotate(-1.5deg);}
  .hero p{font-family:var(--display);font-size:1.5rem;color:var(--gris-medio);margin:1.6rem auto 2.4rem;max-width:34ch;transform:rotate(-.5deg)}
  .btn{display:inline-block;background:var(--gris-oscuro);color:#fff;padding:.95rem 2.4rem;font-size:.85rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;border:2px solid var(--gris-oscuro);transition:all .2s ease;cursor:pointer}
  .btn:hover{background:transparent;color:var(--gris-oscuro)}
  .btn.ghost{background:transparent;color:var(--gris-oscuro)}
  .btn.ghost:hover{background:var(--gris-oscuro);color:#fff}
  .scribble{position:absolute;font-family:var(--display);color:var(--ladrillo);font-size:1.2rem;opacity:.85}
  .scrib-1{top:22%;left:6%;transform:rotate(-12deg)}
  .scrib-2{bottom:18%;right:7%;transform:rotate(8deg)}
  .scribble svg{display:block;margin:0 auto .2rem}

  /* ---------- marquee ---------- */
  .marquee{background:var(--gris-oscuro);color:var(--papel);overflow:hidden;padding:.8rem 0;border-top:1px solid var(--gris-oscuro)}
  .marquee-track{display:flex;gap:3rem;white-space:nowrap;animation:scroll 18s linear infinite;font-family:var(--display);font-size:1.25rem}
  .marquee-track span::after{content:"✶";margin-left:3rem;color:var(--ladrillo)}
  @keyframes scroll{to{transform:translateX(-50%)}}

  /* ---------- secciones ---------- */
  section{padding:5rem 1.5rem}
  .wrap{max-width:1200px;margin:0 auto}
  .sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:2.8rem;flex-wrap:wrap}
  .sec-head h2{font-family:var(--display);font-weight:700;font-size:clamp(2.1rem,4vw,3rem);transform:rotate(-1deg)}
  .sec-head a{font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;border-bottom:2px solid var(--ladrillo);padding-bottom:2px;font-weight:700}

  /* ---------- categorías ---------- */
  .cats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
  .cat{position:relative;background:var(--papel);border:1px solid var(--gris-claro);aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;text-align:center;transition:transform .25s ease, box-shadow .25s ease;overflow:hidden}
  .cat:hover{transform:translateY(-5px) rotate(-.6deg);box-shadow:0 14px 30px rgba(46,46,46,.10)}
  .cat .inner{padding:1rem}
  .cat .name{font-family:var(--marker);font-size:1.05rem;text-transform:uppercase;line-height:1.5}
  .cat .qty{font-family:var(--display);color:var(--gris-medio);font-size:1.1rem;margin-top:.4rem}
  .tape{position:absolute;top:-10px;left:50%;transform:translateX(-50%) rotate(-3deg);width:84px;height:26px;background:rgba(210,205,190,.75);box-shadow:0 1px 2px rgba(0,0,0,.08)}

  /* ---------- productos ---------- */
  .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem 1.4rem}
  .card{cursor:pointer}
  .thumb{position:relative;background:var(--papel);border:1px solid var(--gris-claro);aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:transform .25s ease, box-shadow .25s ease}
  .card:hover .thumb{transform:translateY(-5px) rotate(.5deg);box-shadow:0 14px 30px rgba(46,46,46,.10)}
  .art{font-family:var(--marker);text-transform:uppercase;text-align:center;line-height:1.7;font-size:1rem;padding:1.4rem;max-width:90%}
  .art .red{color:var(--ladrillo)}
  .thumb.dark{background:var(--gris-oscuro)}
  .thumb.dark .art{color:var(--papel)}
  .thumb.red{background:var(--ladrillo)}
  .thumb.red .art{color:#fff}
  .badge{position:absolute;top:.8rem;left:.8rem;background:var(--ladrillo);color:#fff;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:.3rem .6rem;transform:rotate(-3deg)}
  .badge.gris{background:var(--gris-oscuro)}
  .quick{position:absolute;left:0;right:0;bottom:0;background:var(--gris-oscuro);color:#fff;text-align:center;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;padding:.7rem;transform:translateY(100%);transition:transform .25s ease}
  .card:hover .quick{transform:translateY(0)}
  .info{padding:.9rem .2rem 0}
  .pname{font-weight:700;font-size:.95rem}
  .ptype{font-size:.78rem;color:var(--gris-medio);text-transform:uppercase;letter-spacing:.1em;margin-top:.15rem}
  .price{font-family:var(--display);font-size:1.35rem;margin-top:.3rem}
  .price s{color:var(--gris-medio);font-size:1.05rem;margin-right:.4rem}

  /* ---------- banner frase ---------- */
  .quote{background:var(--papel);text-align:center;position:relative}
  .quote h3{font-family:var(--marker);font-size:clamp(1.3rem,3.4vw,2.2rem);text-transform:uppercase;line-height:1.7;max-width:24ch;margin:0 auto}
  .quote .firma{font-family:var(--display);font-size:1.4rem;color:var(--gris-medio);margin-top:1.4rem;transform:rotate(-1deg)}
  .quote .tape{top:-13px}

  /* ---------- nosotros / about ---------- */
  .about{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
  .about-img{background:var(--gris-oscuro);aspect-ratio:4/5;position:relative;display:flex;align-items:center;justify-content:center}
  .about-img .art{color:var(--papel);font-size:1.3rem}
  .polaroid{position:absolute;bottom:-22px;right:-22px;background:#fff;padding:.7rem .7rem 2.2rem;box-shadow:0 12px 28px rgba(46,46,46,.18);transform:rotate(5deg)}
  .polaroid .mini{width:120px;height:120px;background:var(--papel);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:1rem;color:var(--ladrillo);text-align:center;line-height:1.2}
  .about h2{font-family:var(--display);font-size:clamp(2.2rem,4vw,3.2rem);font-weight:700;line-height:1.15;margin-bottom:1.4rem;transform:rotate(-1deg)}
  .about p{color:var(--gris-medio);margin-bottom:1.1rem;max-width:48ch}
  .about .btn{margin-top:1rem}

  /* ---------- instagram ---------- */
  .ig-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.6rem}
  .ig{aspect-ratio:1;background:var(--papel);border:1px solid var(--gris-claro);display:flex;align-items:center;justify-content:center;font-family:var(--marker);font-size:.62rem;text-transform:uppercase;text-align:center;line-height:1.8;padding:.7rem;transition:opacity .2s}
  .ig:hover{opacity:.65}
  .ig.dark{background:var(--gris-oscuro);color:var(--papel)}
  .ig.red{background:var(--ladrillo);color:#fff}

  /* ---------- newsletter ---------- */
  .news{background:var(--gris-oscuro);color:var(--papel);text-align:center}
  .news h2{font-family:var(--display);font-size:clamp(2.2rem,4vw,3rem);font-weight:700;transform:rotate(-1deg)}
  .news p{color:#bdb9b2;max-width:42ch;margin:1rem auto 2rem}
  .news form{display:flex;gap:.7rem;max-width:480px;margin:0 auto;flex-wrap:wrap;justify-content:center}
  .news input{flex:1;min-width:230px;padding:.95rem 1.1rem;border:1px solid #6b6863;background:transparent;color:#fff;font-family:var(--body);font-size:.95rem}
  .news input::placeholder{color:#8d8a84}
  .news .btn{background:var(--papel);color:var(--gris-oscuro);border-color:var(--papel)}
  .news .btn:hover{background:transparent;color:var(--papel)}


  /* ---------- preguntas frecuentes ---------- */
  .faq{background:var(--papel)}
  .faq-list{max-width:760px;margin:0 auto}
  .faq-item{border-bottom:1px solid var(--gris-claro);background:transparent}
  .faq-item summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.3rem .2rem;font-weight:700;font-size:1rem}
  .faq-item summary::-webkit-details-marker{display:none}
  .faq-item summary::after{content:"+";font-family:var(--display);font-size:1.7rem;color:var(--ladrillo);transition:transform .2s;line-height:1}
  .faq-item[open] summary::after{transform:rotate(45deg)}
  .faq-item .resp{padding:0 .2rem 1.4rem;color:var(--gris-medio);max-width:60ch}
  .faq .sec-head{justify-content:center;text-align:center}

  /* ---------- whatsapp flotante ---------- */
  .wsp{position:fixed;right:1.4rem;bottom:1.4rem;z-index:90;width:58px;height:58px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(0,0,0,.22);transition:transform .2s ease}
  .wsp:hover{transform:scale(1.08) rotate(-4deg)}
  .wsp svg{width:30px;height:30px;fill:#fff}

  /* ---------- footer ---------- */
  footer{border-top:1px solid var(--gris-claro);padding:3.5rem 1.5rem 2rem;background:#fff}
  .foot{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem}
  .foot .logo{font-size:2.2rem;margin-bottom:.8rem}
  .foot p{color:var(--gris-medio);font-size:.9rem;max-width:30ch}
  .foot h4{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:1rem}
  .foot ul{list-style:none}
  .foot li{margin-bottom:.55rem;font-size:.9rem;color:var(--gris-medio)}
  .foot li a:hover{color:var(--gris-oscuro)}
  .legal{max-width:1200px;margin:2.5rem auto 0;padding-top:1.4rem;border-top:1px solid var(--gris-claro);display:flex;justify-content:space-between;font-size:.78rem;color:var(--gris-medio);flex-wrap:wrap;gap:.5rem}
  .legal span b{font-family:var(--display);font-size:1rem;color:var(--ladrillo);font-weight:700}

  /* ---------- responsive ---------- */
  @media (max-width:920px){
    .cats{grid-template-columns:repeat(2,1fr)}
    .grid{grid-template-columns:repeat(2,1fr)}
    .about{grid-template-columns:1fr;gap:3.5rem}
    .ig-grid{grid-template-columns:repeat(3,1fr)}
    .foot{grid-template-columns:1fr 1fr}
    .menu{display:none}
    .burger{display:block}
    .scribble{display:none}
  }
  @media (max-width:520px){
    .grid{grid-template-columns:1fr 1fr;gap:1rem .8rem}
    .art{font-size:.78rem;padding:.8rem}
    .icons button span.txt{display:none}
  }
  @media (prefers-reduced-motion:reduce){
    .marquee-track{animation:none}
    *{transition:none!important}
  }
