/*
Theme Name: LOFA 2026
Theme URI: https://lofa.store
Description: Tema propio de LOFA Collections — joyería moderna, sin Elementor. Moderno audaz: Fraunces + Jost, charcoal/marfil/oro.
Author: LOFA + Claude
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 8.0
Text Domain: lofa2026
WC requires at least: 8.0
*/

:root{
  --ink:#15120d;--ink-soft:#2a251c;--bone:#f4eee2;--cream:#fbf8f1;
  --gold:#b1873f;--gold-deep:#8a6526;--line:#e0d7c5;
  --display:"Fraunces",Georgia,serif;--sans:"Jost",system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
.wrap{max-width:1280px;margin:0 auto;padding:0 32px}
.btn{display:inline-flex;align-items:center;gap:10px;font-size:13px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;padding:16px 30px;border-radius:2px;transition:all .28s ease;cursor:pointer;border:1.5px solid transparent;font-family:var(--sans)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:var(--ink);color:#fff}
.btn-dark{background:var(--ink);color:var(--bone)}
.btn-dark:hover{background:var(--gold);color:#fff}
.btn-ghost{border-color:rgba(244,238,226,.45);color:var(--bone)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}

/* announce */
.announce{background:var(--ink);color:var(--bone);overflow:hidden;font-size:12px;letter-spacing:.18em;text-transform:uppercase;padding:9px 0}
.announce .track{display:flex;gap:48px;white-space:nowrap;width:max-content;animation:scroll 28s linear infinite}
.announce span{display:inline-flex;align-items:center;gap:48px}
.announce b{color:var(--gold);font-weight:500}

/* header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,248,241,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:86px}
.brand{font-family:var(--display);font-weight:600;font-size:28px;letter-spacing:.32em;padding-left:.32em;color:var(--ink)}
.brand small{display:block;font-family:var(--sans);font-size:9px;letter-spacing:.42em;font-weight:400;color:var(--gold-deep);text-align:center;margin-top:-2px;padding-left:0}
.menu{display:flex;gap:30px;font-size:13px;letter-spacing:.13em;text-transform:uppercase;font-weight:500;list-style:none}
.menu a{position:relative;padding:6px 0;color:var(--ink-soft);transition:color .25s}
.menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--gold);transition:width .3s}
.menu a:hover{color:var(--ink)}.menu a:hover::after{width:100%}
.menu li.sale a,.menu .menu-item.sale a{color:var(--gold-deep)}
.hicons{display:flex;gap:18px;font-size:19px;align-items:center}
.hicons a{cursor:pointer;transition:color .2s;color:var(--ink)}
.hicons a:hover{color:var(--gold)}
.cart-link{position:relative}
.cart-link .cc{position:absolute;top:-7px;right:-9px;background:var(--gold);color:#fff;font-size:10px;width:16px;height:16px;border-radius:50%;display:grid;place-items:center;font-family:var(--sans)}
.burger{display:none;font-size:24px;cursor:pointer;background:none;border:none;color:var(--ink)}

/* hero */
.hero{position:relative;min-height:90vh;display:flex;align-items:center;overflow:hidden;background:var(--ink)}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center right;background-repeat:no-repeat;opacity:0;animation:fade 1.8s .2s forwards}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(95deg,rgba(15,12,9,.92) 12%,rgba(15,12,9,.55) 45%,rgba(15,12,9,.08) 70%)}
.hero .wrap{position:relative;z-index:2;color:var(--bone);width:100%;padding:40px 32px}
.hero .inner{max-width:600px}
.hero .eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:26px;opacity:0;animation:rise .9s .5s forwards}
.hero .eyebrow::before{content:"";width:38px;height:1px;background:var(--gold)}
.hero h1{font-family:var(--display);font-weight:400;font-size:clamp(50px,6.8vw,108px);line-height:.95;letter-spacing:-.015em}
.hero h1 .it{font-style:italic;font-weight:300;color:var(--gold)}
.hero h1 span{display:block;opacity:0;animation:rise 1s forwards}
.hero h1 span:nth-child(1){animation-delay:.6s}
.hero h1 span:nth-child(2){animation-delay:.74s}
.hero h1 span:nth-child(3){animation-delay:.88s}
.hero p{margin:32px 0 38px;max-width:440px;font-size:16.5px;line-height:1.75;color:#d7cebd;font-weight:300;opacity:0;animation:rise 1s 1s forwards}
.hero .cta-row{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:rise 1s 1.16s forwards}
.hero-scroll{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:2;color:var(--bone);font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.7;display:flex;flex-direction:column;align-items:center;gap:8px}
.hero-scroll i{font-size:18px;font-style:normal;animation:bob 1.8s ease-in-out infinite}

/* ticker */
.ticker{background:var(--gold);color:var(--ink);overflow:hidden;padding:14px 0;font-family:var(--display);font-style:italic;font-size:22px}
.ticker .track{display:flex;gap:40px;white-space:nowrap;width:max-content;animation:scroll 30s linear infinite}
.ticker span{display:inline-flex;align-items:center;gap:40px}
.ticker .star{font-style:normal;font-size:14px}

/* sections */
.sec{padding:96px 0}
.sec-head{text-align:center;margin-bottom:54px}
.sec-head .kicker{font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:16px}
.sec-head h2{font-family:var(--display);font-weight:400;font-size:clamp(34px,4.4vw,56px);line-height:1.02;letter-spacing:-.01em}
.sec-head h2 em{font-style:italic;color:var(--gold)}

/* categories */
.cats{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,196px);gap:18px}
.cat{position:relative;border-radius:6px;overflow:hidden;cursor:pointer}
.cat:nth-child(1){grid-row:span 2}
.cat img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.8,.2,1)}
.cat::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(21,18,13,.72),rgba(21,18,13,.05) 60%)}
.cat:hover img{transform:scale(1.08)}
.cat .label{position:absolute;left:24px;bottom:24px;z-index:2;color:var(--bone)}
.cat .label h3{font-family:var(--display);font-weight:400;font-size:27px;line-height:1}
.cat .label p{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-top:8px}

/* product grid (shared: home + woo) */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px 22px}
ul.products{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:18px 22px;margin:0}
.card,ul.products li.product{cursor:pointer;position:relative;text-align:left}
.card .ph,ul.products li.product a img,ul.products li.product img{margin:0}
.card .ph{position:relative;background:#fff;border:1px solid var(--line);border-radius:6px;overflow:hidden;aspect-ratio:1;margin-bottom:16px}
.card .ph img{width:100%;height:100%;object-fit:contain;padding:10px;transition:transform .6s ease}
.card:hover .ph img{transform:scale(1.06)}
.card .tag{position:absolute;top:12px;left:12px;background:var(--ink);color:var(--bone);font-size:10px;letter-spacing:.14em;text-transform:uppercase;padding:5px 10px;border-radius:2px;z-index:2}
.card .tag.sale{background:var(--gold)}
.card .add{position:absolute;left:12px;right:12px;bottom:12px;background:var(--ink);color:var(--bone);text-align:center;font-size:12px;letter-spacing:.16em;text-transform:uppercase;padding:13px;border-radius:3px;opacity:0;transform:translateY(10px);transition:all .32s ease}
.card:hover .add{opacity:1;transform:translateY(0)}
.card .add:hover{background:var(--gold);color:#fff}
.card h3{font-family:var(--display);font-size:19px;font-weight:400;line-height:1.2}
.card .price{margin-top:5px;font-size:15px;color:var(--gold-deep);font-weight:500}
.card .stars{color:var(--gold);font-size:12px;margin-top:6px;letter-spacing:2px}
.center-cta{text-align:center;margin-top:56px}

/* values */
.values{background:var(--ink);color:var(--bone)}
.values .wrap{padding:84px 32px;display:grid;grid-template-columns:repeat(4,1fr);gap:40px}
.val{text-align:center}
.val .ic{width:54px;height:54px;margin:0 auto 20px;border:1.5px solid var(--gold);border-radius:50%;display:grid;place-items:center;color:var(--gold);font-size:24px}
.val h4{font-family:var(--display);font-size:21px;font-weight:400;margin-bottom:10px}
.val p{font-size:14px;line-height:1.65;color:#b9b0a0;font-weight:300}

/* instagram */
.insta{padding:96px 0;background:var(--bone)}
.insta .ig-head{text-align:center;margin-bottom:46px}
.insta .ig-head .kicker{font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:14px}
.insta .ig-head h2{font-family:var(--display);font-weight:400;font-size:clamp(30px,4vw,50px)}
.insta .ig-head a{display:inline-block;margin-top:14px;font-size:14px;letter-spacing:.14em;color:var(--ink);border-bottom:1.5px solid var(--gold)}
.ig-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.ig-grid .ig{position:relative;aspect-ratio:1;overflow:hidden;border-radius:6px;cursor:pointer}
.ig-grid .ig img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.ig-grid .ig:hover img{transform:scale(1.09)}

/* editorial + newsletter */
.edito{position:relative;background:var(--bone);overflow:hidden}
.edito .wrap{padding:110px 32px;text-align:center;position:relative;z-index:2}
.edito .kicker{font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:22px}
.edito h2{font-family:var(--display);font-weight:300;font-size:clamp(32px,5vw,62px);line-height:1.08;max-width:900px;margin:0 auto 30px;letter-spacing:-.01em}
.edito h2 em{font-style:italic;color:var(--gold)}
.edito .deco{position:absolute;font-family:var(--display);font-size:340px;color:rgba(177,135,63,.07);top:-60px;right:-20px;font-style:italic;z-index:1;line-height:1}
.news{background:var(--ink-soft);color:var(--bone)}
.news .wrap{padding:80px 32px;text-align:center}
.news h2{font-family:var(--display);font-weight:400;font-size:clamp(30px,4vw,46px);margin-bottom:14px}
.news p{color:#c4bba9;font-weight:300;margin-bottom:32px;font-size:15px}
.news form{display:flex;gap:12px;max-width:480px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.news input{flex:1;min-width:240px;background:transparent;border:1.5px solid rgba(244,238,226,.3);color:var(--bone);padding:15px 20px;border-radius:3px;font-family:var(--sans);font-size:14px;outline:none}
.news input::placeholder{color:#8d8473}.news input:focus{border-color:var(--gold)}

/* footer */
.site-footer{background:var(--ink);color:#b9b0a0;padding:72px 0 0}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:56px}
.fbrand .brand{color:var(--bone);font-size:26px}
.fbrand p{font-size:14px;line-height:1.7;font-weight:300;margin:22px 0;max-width:280px}
.fcol h5{color:var(--bone);font-size:12px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:20px;font-weight:500}
.fcol a{display:block;font-size:14px;font-weight:300;padding:7px 0;transition:color .2s}
.fcol a:hover{color:var(--gold)}
.fbot{border-top:1px solid rgba(244,238,226,.12);padding:24px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:12.5px;font-weight:300}
.pays{display:flex;gap:8px}
.pays b{background:rgba(244,238,226,.08);color:var(--bone);font-weight:500;font-size:11px;padding:5px 9px;border-radius:3px}

/* WooCommerce cohesion */
.woo-head{background:var(--ink);color:var(--bone);text-align:center;padding:64px 0 56px}
.woo-head h1{font-family:var(--display);font-weight:400;font-size:clamp(38px,5vw,64px);line-height:1}
.woo-head .crumb{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:#a99c84;margin-bottom:16px}
.woocommerce .wrap-woo{max-width:1280px;margin:0 auto;padding:54px 32px 90px}
.woocommerce ul.products,.woocommerce-page ul.products{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:20px 24px!important;margin:0!important}
.woocommerce ul.products::before,.woocommerce ul.products::after{display:none!important}
.woocommerce ul.products li.product,.woocommerce-page ul.products li.product{width:100%!important;float:none!important;margin:0 0 8px!important;clear:none!important}
.woocommerce ul.products li.product a img,.woocommerce ul.products li.product img{width:100%!important;height:auto!important;aspect-ratio:1;object-fit:contain!important;background:#fff;padding:14px;border:1px solid var(--line);border-radius:8px;margin:0 0 14px!important}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-family:var(--display)!important;font-size:19px!important;font-weight:400!important;padding:6px 0 2px!important;color:var(--ink)}
.woocommerce ul.products li.product .price{color:var(--gold-deep)!important;font-size:15px!important;font-weight:500!important;font-family:var(--sans)}
.woocommerce ul.products li.product .price del{color:#b3a892!important;font-weight:400}
.woocommerce ul.products li.product img{border:1px solid var(--line);border-radius:6px;background:#fff}
.woocommerce ul.products li.product .button,.woocommerce a.button,.woocommerce button.button,.woocommerce #respond input#submit,.woocommerce .button.alt{background:var(--ink)!important;color:var(--bone)!important;border-radius:3px!important;font-family:var(--sans)!important;letter-spacing:.14em;text-transform:uppercase;font-size:12px!important;font-weight:500!important;padding:13px 22px!important;transition:background .25s}
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce .button.alt:hover,.woocommerce ul.products li.product .button:hover{background:var(--gold)!important;color:#fff!important}
.woocommerce div.product .product_title{font-family:var(--display);font-weight:400;font-size:clamp(30px,3.5vw,46px);line-height:1.05}
.woocommerce div.product p.price,.woocommerce div.product span.price{color:var(--ink);font-size:26px;font-weight:500;font-family:var(--sans)}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active{border-bottom-color:var(--gold)}
.woocommerce .woocommerce-result-count{font-family:var(--sans);color:var(--ink-soft)}
.woocommerce .star-rating span{color:var(--gold)}
.woocommerce span.onsale{background:var(--gold);color:#fff;border-radius:2px;font-family:var(--sans);letter-spacing:.1em;text-transform:uppercase;font-size:11px}
.woocommerce-message,.woocommerce-info{border-top-color:var(--gold)}

@keyframes scroll{to{transform:translateX(-50%)}}
@keyframes rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fade{to{opacity:1}}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

@media(max-width:980px){
  .hero-scroll{display:none}
  .burger{display:block;order:-1}
  .hero .wrap{text-align:center}.hero .cta-row,.hero p{margin-left:auto;margin-right:auto}
  .cats{grid-template-columns:repeat(2,1fr);grid-template-rows:none}.cat:nth-child(1){grid-row:auto;height:300px}
  .prod-grid{grid-template-columns:repeat(2,1fr)}
  .woocommerce ul.products,.woocommerce-page ul.products{grid-template-columns:repeat(2,1fr)!important;gap:12px 14px!important}
  .values .wrap,.fgrid,.ig-grid{grid-template-columns:repeat(2,1fr)}
  /* mobile slide-in menu */
  .site-header .menu{position:fixed;top:0;right:0;bottom:0;width:82%;max-width:330px;background:var(--ink);flex-direction:column;justify-content:flex-start;align-items:flex-start;padding:92px 34px 34px;gap:4px;transform:translateX(105%);transition:transform .36s cubic-bezier(.4,0,.2,1);z-index:60;display:flex}
  body.nav-open .site-header .menu{transform:translateX(0)}
  .site-header .menu a{color:var(--bone);font-size:17px;letter-spacing:.06em;padding:16px 0;border-bottom:1px solid rgba(244,238,226,.12);width:100%}
  .site-header .menu a::after{display:none}
  .site-header .menu li.sale a,.site-header .menu .sale a{color:var(--gold)}
  body.nav-open .nav-overlay{opacity:1;pointer-events:auto}
  .nav-overlay{position:fixed;inset:0;background:rgba(10,8,5,.55);z-index:59;opacity:0;pointer-events:none;transition:opacity .3s}
  .nav-close{position:fixed;top:26px;right:26px;z-index:61;font-size:26px;line-height:1;color:var(--bone);background:none;border:none;cursor:pointer;display:none}
  body.nav-open .nav-close{display:block}
  body.nav-open{overflow:hidden}
}
