/*
Theme Name: Luis Cabello — Fotografo
Theme URI: https://www.luiscabello.com
Author: Luis Cabello
Author URI: https://www.luiscabello.com
Description: Tema de fotografia de autor con estetica neoplasticista (Piet Mondrian / De Stijl): reticula asimetrica, lineas negras, colores primarios, tipografia Poppins, logo de diafragma y monograma LC. Inspirado en sitios inmersivos de fotografia.
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: luiscabello
*/


:root{
  --red:#D11421; --blue:#1356A2; --yellow:#F4C400; --ink:#16130F; --paper:#F7F3E7;
  --b:6px; --maxw:1320px; --nav-h:84px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Poppins',system-ui,sans-serif;background:var(--paper);color:var(--ink);
  line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:100%;object-fit:cover;-webkit-user-drag:none;user-select:none;-webkit-user-select:none}
::selection{background:var(--yellow);color:var(--ink)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.bar3{display:flex;height:14px}
.bar3 i{flex:1}.bar3 i:nth-child(1){background:var(--red)}.bar3 i:nth-child(2){background:var(--yellow)}.bar3 i:nth-child(3){background:var(--blue)}

/* ---------- HEADER ---------- */
header.nav{position:sticky;top:0;z-index:50;background:var(--paper);border-bottom:var(--b) solid var(--ink)}
.nav .row{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h)}
.brand{display:flex;align-items:center;gap:14px}
.brand .dia{width:52px;height:46px;transition:transform .6s cubic-bezier(.2,.8,.2,1)}
.brand:hover .dia{transform:rotate(120deg)}
.brand b{font-weight:800;font-size:1.25rem;letter-spacing:.02em;line-height:1;text-transform:uppercase;color:var(--ink)}
.brand span{display:block;font-size:.6rem;letter-spacing:.42em;color:#7a766c;font-weight:600}
nav.menu{display:flex;gap:6px}
nav.menu a{position:relative;font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;
  padding:10px 16px}
nav.menu a::after{content:"";position:absolute;left:16px;right:16px;bottom:6px;height:4px;background:var(--ink);
  transform:scaleX(0);transform-origin:left;transition:transform .28s}
nav.menu a:hover::after,nav.menu a.active::after{transform:scaleX(1)}
nav.menu a:nth-child(1):hover::after{background:var(--red)}
nav.menu a:nth-child(2):hover::after{background:var(--yellow)}
nav.menu a:nth-child(3):hover::after{background:var(--blue)}
nav.menu a:nth-child(4):hover::after{background:var(--red)}
.burger{display:none;width:46px;height:40px;border:var(--b) solid var(--ink);background:var(--paper);cursor:pointer;
  flex-direction:column;justify-content:center;gap:5px;align-items:center}
.burger i{width:22px;height:3px;background:var(--ink);transition:.3s}
.cta-mini{background:var(--ink);color:var(--paper)!important;padding:12px 18px!important}
.cta-mini::after{display:none}

/* ---------- HERO (horizontal) ---------- */
.hero{background:var(--ink);padding:var(--b);display:grid;gap:var(--b);
  grid-template-columns:repeat(12,1fr);grid-template-rows:auto minmax(46vh,1fr);min-height:calc(100vh - var(--nav-h))}
.hero>div{overflow:hidden;position:relative;background:var(--paper)}
.h-title{grid-column:1/8;grid-row:1;display:flex;flex-direction:column;justify-content:center;padding:46px 5%}
.h-title .kick{font-weight:600;letter-spacing:.4em;font-size:.8rem;color:#7a766c;text-transform:uppercase;margin-bottom:10px}
.h-title h1{font-weight:800;line-height:.9;text-transform:uppercase;font-size:clamp(2.1rem,5vw,4.4rem);letter-spacing:-.01em}
.h-title h1 em{font-style:normal;color:var(--red)}
.hero>.h-side{grid-column:8/13;grid-row:1;display:flex;flex-direction:column}
.h-side .mono-wrap{flex:1;display:grid;place-items:center;padding:22px}
.h-side .mono{width:min(170px,58%);height:auto}
.h-side .sbar{display:flex;height:16px}
.h-side .sbar i{flex:1}.h-side .sbar i:nth-child(1){background:var(--red)}.h-side .sbar i:nth-child(2){background:var(--yellow)}.h-side .sbar i:nth-child(3){background:var(--blue)}
.h-photo{grid-column:1/13;grid-row:2}
.h-photo img{transition:transform 1.2s ease}.h-photo:hover img{transform:scale(1.05)}
.h-tag{position:absolute;bottom:16px;left:16px;background:var(--paper);border:var(--b) solid var(--ink);
  padding:6px 12px;font-weight:700;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase}

/* ---------- SECTIONS ---------- */
section{border-bottom:var(--b) solid var(--ink)}
.pad{padding:84px 0}
.sec-head{display:flex;align-items:flex-end;gap:18px;margin-bottom:42px;flex-wrap:wrap}
.sec-head .no{font-weight:800;font-size:1rem;background:var(--ink);color:var(--paper);width:42px;height:42px;
  display:grid;place-items:center}
.sec-head h2{font-weight:800;text-transform:uppercase;font-size:clamp(1.8rem,4vw,3.2rem);line-height:.9;letter-spacing:-.01em}
.sec-head p{color:#5a564e;max-width:42ch;margin-left:auto;font-size:.98rem}
.tick{display:inline-flex;gap:5px;vertical-align:middle;margin-left:6px}
.tick i{width:16px;height:16px;display:inline-block}
.tick i:nth-child(1){background:var(--red)}.tick i:nth-child(2){background:var(--yellow)}.tick i:nth-child(3){background:var(--blue)}

/* about */
.about{display:grid;grid-template-columns:1.1fr .9fr;gap:var(--b);background:var(--ink);border:var(--b) solid var(--ink)}
.about>*{background:var(--paper)}
.about .txt{padding:48px}
.about .txt h3{font-size:clamp(1.5rem,3vw,2.3rem);font-weight:800;line-height:1;text-transform:uppercase;margin-bottom:18px}
.about .txt p{color:#4a463f;margin-bottom:16px}
.about .pic{min-height:420px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--b);margin-top:28px;background:var(--ink);border:var(--b) solid var(--ink)}
.stats div{background:var(--paper);padding:18px;text-align:center}
.stats b{display:block;font-size:1.8rem;font-weight:800}
.stats span{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:#7a766c}

/* mosaic portfolio (horizontal) */
.mosaic{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:185px;gap:var(--b);
  background:var(--ink);padding:var(--b);border:var(--b) solid var(--ink)}
.mosaic .cell{overflow:hidden;position:relative}
.mosaic img{transition:transform .9s ease}
.mosaic .cell:hover img{transform:scale(1.08)}
.mosaic .cell .ov{position:absolute;inset:0;display:flex;align-items:flex-end;padding:16px;opacity:0;
  background:linear-gradient(0deg,rgba(22,19,15,.82),transparent 60%);color:var(--paper);transition:opacity .3s;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.8rem}
.mosaic .cell:hover .ov{opacity:1}
.mosaic .block{display:grid;place-items:center;color:var(--paper);text-align:center;padding:18px}
.block.red{background:var(--red)}.block.blue{background:var(--blue)}.block.yellow{background:var(--yellow);color:var(--ink)}
.block .dia,.block .mono{width:96px;height:auto}
.m1{grid-column:1/7;grid-row:span 2}.m2{grid-column:7/13;grid-row:span 2}
.m3{grid-column:1/4;grid-row:span 2}.m4{grid-column:4/9;grid-row:span 2}.m5{grid-column:9/13;grid-row:span 2}
.m6{grid-column:1/9;grid-row:span 2}.m7{grid-column:9/13;grid-row:span 2}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  font-size:.82rem;padding:16px 26px;border:var(--b) solid var(--ink);background:var(--ink);color:var(--paper);
  cursor:pointer;transition:.25s;position:relative}
.btn:hover{background:var(--paper);color:var(--ink)}
.btn.y{background:var(--yellow);color:var(--ink)}.btn.y:hover{background:var(--ink);color:var(--yellow)}
.btn-row{display:flex;gap:16px;flex-wrap:wrap;margin-top:8px}

/* services */
.serv{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--b);background:var(--ink);border:var(--b) solid var(--ink)}
.serv article{background:var(--paper);padding:38px 30px;transition:.3s}
.serv article:hover{background:var(--ink);color:var(--paper)}
.serv .n{font-weight:800;font-size:2.4rem;line-height:1}
.serv .n.red{color:var(--red)}.serv .n.blue{color:var(--blue)}.serv .n.yellow{color:#d6ab00}
.serv h4{font-size:1.25rem;font-weight:800;text-transform:uppercase;margin:14px 0 10px}
.serv p{font-size:.92rem;color:#5a564e}.serv article:hover p{color:#cfc9bd}

/* CTA band */
.cta{background:var(--red);color:var(--paper);text-align:center;padding:80px 0}
.cta h2{font-size:clamp(2rem,5vw,4rem);font-weight:800;text-transform:uppercase;line-height:.9;margin-bottom:24px}
.cta .btn{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.cta .btn:hover{background:transparent;color:var(--paper)}

/* page hero (interior) */
.phero{background:var(--ink);color:var(--paper);padding:70px 0 60px}
.phero .kick{letter-spacing:.4em;font-size:.78rem;color:var(--yellow);font-weight:600;text-transform:uppercase}
.phero h1{font-size:clamp(2.4rem,7vw,5rem);font-weight:800;text-transform:uppercase;line-height:.86;margin-top:10px}
.phero p{max-width:60ch;margin-top:18px;color:#cfc9bd}

/* filters */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin:30px 0}
.filters button{font-family:inherit;font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;
  padding:10px 18px;border:3px solid var(--ink);background:var(--paper);cursor:pointer;transition:.2s}
.filters button[aria-pressed="true"]{background:var(--ink);color:var(--paper)}
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--b)}
.gal figure{position:relative;margin:0;border:var(--b) solid var(--ink);overflow:hidden;cursor:zoom-in;aspect-ratio:3/2}
.gal figure img{transition:transform .8s}.gal figure:hover img{transform:scale(1.07)}
.gal figcaption{position:absolute;left:0;bottom:0;background:var(--ink);color:var(--paper);font-size:.7rem;
  font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 12px}
.gal .pill{position:absolute;top:10px;right:10px;width:18px;height:18px}

/* blog cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--b);background:var(--ink);border:var(--b) solid var(--ink)}
.card{background:var(--paper);display:flex;flex-direction:column;transition:.3s}
.card .ph{aspect-ratio:4/3;overflow:hidden;border-bottom:var(--b) solid var(--ink)}
.card .ph img{transition:transform .8s}.card:hover .ph img{transform:scale(1.06)}
.card .body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.cat{align-self:flex-start;font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:4px 10px;color:var(--paper)}
.cat.red{background:var(--red)}.cat.blue{background:var(--blue)}.cat.yellow{background:var(--yellow);color:var(--ink)}
.card h3{font-size:1.25rem;font-weight:800;text-transform:uppercase;line-height:1.05}
.card .meta{font-size:.74rem;color:#8a857b;letter-spacing:.06em;text-transform:uppercase}
.card p{font-size:.9rem;color:#5a564e}
.card .more{margin-top:auto;font-weight:700;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;
  display:inline-flex;gap:8px;align-items:center}
.card .more::after{content:"→";transition:transform .25s}.card:hover .more::after{transform:translateX(6px)}

/* single post */
.post{max-width:760px;margin:0 auto;padding:60px 28px}
.post .ptop{font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:#8a857b;display:flex;gap:14px;align-items:center;margin-bottom:18px}
.post h1{font-size:clamp(2rem,5vw,3.4rem);font-weight:800;text-transform:uppercase;line-height:.92;margin-bottom:24px}
.post .lead{font-size:1.2rem;color:#3a362f;margin-bottom:30px;font-weight:500}
.post .phero-img{border:var(--b) solid var(--ink);margin:0 -28px 36px;aspect-ratio:16/9;overflow:hidden}
.post p{margin-bottom:20px;color:#2d2a25}
.post h2{font-size:1.6rem;font-weight:800;text-transform:uppercase;margin:34px 0 14px}
.post blockquote{border-left:var(--b) solid var(--red);background:#fff;padding:22px 26px;margin:30px 0;
  font-size:1.3rem;font-weight:600;font-style:italic}
.post .two{display:grid;grid-template-columns:1fr 1fr;gap:var(--b);margin:30px 0}
.post .two .ph{aspect-ratio:3/2;border:var(--b) solid var(--ink);overflow:hidden}
.tags{display:flex;gap:8px;flex-wrap:wrap;margin:34px 0}
.tags span{font-size:.72rem;border:3px solid var(--ink);padding:6px 12px;text-transform:uppercase;letter-spacing:.08em}
.pnav{display:flex;justify-content:space-between;border-top:var(--b) solid var(--ink);padding-top:24px;margin-top:30px;font-weight:700;text-transform:uppercase;font-size:.8rem;letter-spacing:.08em}
.author{display:flex;gap:16px;align-items:center;border:var(--b) solid var(--ink);padding:20px;margin-top:36px;background:#fff}
.author .mono{width:64px;height:64px;flex:none}
.author b{text-transform:uppercase}

/* contact */
.contact{display:grid;grid-template-columns:1.2fr .8fr;gap:var(--b);background:var(--ink);border:var(--b) solid var(--ink)}
.contact>div{background:var(--paper)}
.form{padding:46px}
.form .field{margin-bottom:20px}
.form label{display:block;font-weight:700;text-transform:uppercase;font-size:.74rem;letter-spacing:.1em;margin-bottom:8px}
.form input,.form select,.form textarea{width:100%;font-family:inherit;font-size:1rem;padding:14px;
  border:3px solid var(--ink);background:#fff;color:var(--ink)}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--blue);box-shadow:inset 0 0 0 1px var(--blue)}
.form textarea{min-height:140px;resize:vertical}
.info{padding:46px;display:flex;flex-direction:column;gap:22px}
.info .blk{border-left:var(--b) solid var(--red);padding-left:16px}
.info .blk:nth-child(2){border-color:var(--yellow)}.info .blk:nth-child(3){border-color:var(--blue)}
.info h4{text-transform:uppercase;font-size:.8rem;letter-spacing:.1em;color:#7a766c;margin-bottom:4px}
.info b{font-size:1.05rem}
.formok{background:var(--yellow);border:var(--b) solid var(--ink);padding:14px;font-weight:700;margin-top:10px;display:none}

/* socials */
.socials{display:flex;gap:8px;flex-wrap:wrap}
.socials a{border:3px solid var(--ink);padding:8px 14px;font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;transition:.2s}
.socials a:hover{background:var(--ink);color:var(--paper)}

/* ---------- FOOTER ---------- */
footer.ft{background:var(--ink);color:var(--paper)}
.ft .grid{display:grid;grid-template-columns:1.1fr 1fr 1fr;gap:40px;padding:64px 0}
.ft .card-logo{background:var(--paper);color:var(--ink);padding:24px;display:flex;align-items:center;gap:16px;align-self:start}
.ft .card-logo .dia{width:64px;height:58px;flex:none}
.ft .card-logo b{font-weight:800;text-transform:uppercase;line-height:1;font-size:1.15rem;color:var(--ink)}
.ft .card-logo span{font-size:.58rem;letter-spacing:.36em;color:#7a766c;font-weight:600}
.ft h5{text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;color:var(--yellow);margin-bottom:16px}
.ft a.fl,.ft p.fl{display:block;color:#d8d3c8;margin-bottom:8px;font-size:.95rem;transition:.2s}
.ft a.fl:hover{color:var(--paper)}
.ft .sign b{color:var(--paper);text-transform:uppercase}
.ft .bottom{border-top:3px solid #3a352e;padding:18px 0;display:flex;justify-content:space-between;
  font-size:.74rem;color:#8a857b;text-transform:uppercase;letter-spacing:.08em;flex-wrap:wrap;gap:10px}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}

/* ---------- RESPONSIVE ---------- */
@media(max-width:900px){
  :root{--nav-h:72px}
  .burger{display:flex}
  nav.menu{position:fixed;inset:var(--nav-h) 0 auto 0;background:var(--paper);flex-direction:column;gap:0;
    border-bottom:var(--b) solid var(--ink);transform:translateY(-130%);transition:transform .35s;z-index:40}
  nav.menu.open{transform:none}
  nav.menu a{padding:16px 28px;border-top:3px solid var(--ink)}
  nav.menu a::after{display:none}
  .hero{grid-template-columns:repeat(6,1fr);grid-template-rows:auto auto auto;min-height:auto}
  .h-title{grid-column:1/7;grid-row:1;padding:30px 22px}
  .hero>.h-side{grid-column:1/7;grid-row:2;min-height:230px}
  .h-photo{grid-column:1/7;grid-row:3;min-height:52vh}
  .about{grid-template-columns:1fr}
  .serv,.cards,.stats{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .mosaic{grid-template-columns:repeat(6,1fr);grid-auto-rows:160px}
  .m1,.m2,.m3,.m4,.m5,.m6,.m7{grid-column:1/7;grid-row:span 1}
  .gal{grid-template-columns:repeat(2,1fr)}
  .post .two{grid-template-columns:1fr}
  .ft .grid{grid-template-columns:1fr;gap:30px}
}
@media(max-width:540px){.gal{grid-template-columns:1fr}.wrap{padding:0 18px}}
#lightbox{position:fixed;inset:0;background:rgba(22,19,15,.93);display:none;place-items:center;z-index:100;padding:30px}#lightbox.on{display:grid}#lightbox img{max-width:90vw;max-height:88vh;width:auto;height:auto;border:var(--b) solid var(--paper)}#lightbox .lb-prev,#lightbox .lb-next{position:absolute;top:50%;transform:translateY(-50%);background:var(--paper);color:var(--ink);border:var(--b) solid var(--ink);font-size:1.7rem;font-weight:800;width:56px;height:56px;cursor:pointer;line-height:1;align-items:center;justify-content:center}#lightbox .lb-prev{left:24px}#lightbox .lb-next{right:24px}#lightbox .lb-count{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);background:var(--ink);color:var(--paper);padding:6px 14px;font-weight:700;font-size:.78rem;letter-spacing:.1em}
/* --- menú WordPress --- */
nav.menu>ul{display:flex;gap:6px;list-style:none;margin:0;padding:0;align-items:center}
nav.menu>ul li a{display:block}
nav.menu>ul li:nth-child(1) a:hover::after{background:var(--red)}
nav.menu>ul li:nth-child(2) a:hover::after{background:var(--yellow)}
nav.menu>ul li:nth-child(3) a:hover::after{background:var(--blue)}
nav.menu>ul li:nth-child(4) a:hover::after{background:var(--red)}
nav.menu>ul li.current-menu-item a::after,nav.menu>ul li.current_page_item a::after,
nav.menu>ul li.current-menu-parent a::after{transform:scaleX(1)}
.page-simple{max-width:820px;margin:0 auto;padding:60px 28px}
.page-simple h1{font-size:clamp(2rem,5vw,3.2rem);font-weight:800;text-transform:uppercase;line-height:.95;margin-bottom:24px}
.page-simple p{margin-bottom:18px;color:#2d2a25}
.pagination{display:flex;gap:10px;justify-content:center;padding:40px 0}
.pagination .page-numbers{border:3px solid var(--ink);padding:10px 16px;font-weight:700}
.pagination .current{background:var(--ink);color:var(--paper)}
@media(max-width:900px){nav.menu>ul{flex-direction:column;width:100%}
 nav.menu>ul li a{padding:16px 28px;border-top:3px solid var(--ink)}}
