/*
Theme Name: Photos by Jairo Editorial
Theme URI: https://photosbyjairo.com
Author: Jairo R. Leiva
Description: Minimal editorial WordPress theme optimized for photography portfolios and print sales. White canvas with Deep Sky Blue accents.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: photosbyjairo
Tags: block-styles, one-column, custom-logo, editor-style, photography, portfolio, e-commerce
*/

/* ========== Design Tokens ========== */
:root{
  --pbj-bg: #ffffff;
  --pbj-text: #0f0f0f;
  --pbj-body: #333333;
  --pbj-muted: #7a7a7a;
  --pbj-line: #e6e6e6;
  --pbj-soft: #f6f7f8;
  --pbj-accent: #00bfff; /* Deep Sky Blue */
  --pbj-radius: 20px;
  --pbj-max: 1400px;
  --pbj-wide: 1600px;
  --pbj-pad: clamp(18px, 3vw, 44px);
  --pbj-section: clamp(72px, 9vw, 140px);
  --pbj-font-body: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  --pbj-font-display: "Playfair Display", Georgia, "Times New Roman", serif;
}

html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--pbj-bg);
  color:var(--pbj-body);
  font-family:var(--pbj-font-body);
  font-size:19px;
  line-height:1.7;
}
a{ color:var(--pbj-text); text-decoration: none; }
a:hover{ color:var(--pbj-accent); }

.site{
  min-height:100dvh;
  display:flex;
  flex-direction:column;
}
.site-content{ flex:1; }

.container{
  width: min(100% - (var(--pbj-pad) * 2), var(--pbj-max));
  margin-inline:auto;
}
.container--wide{
  width: min(100% - (var(--pbj-pad) * 2), var(--pbj-wide));
  margin-inline:auto;
}

.section{
  padding-block: var(--pbj-section);
}

hr, .rule{
  border:0;
  border-top:1px solid var(--pbj-line);
  margin: 0;
}

/* ========== Header ========== */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(230,230,230,.6);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px var(--pbj-pad);
  gap: 18px;
}
.brand{
  display:flex;
  align-items:baseline;
  gap: 10px;
  min-width: 180px;
}
.brand a{
  font-family:var(--pbj-font-display);
  font-size: 22px;
  letter-spacing: .3px;
  color:var(--pbj-text);
}
.brand small{
  font-size: 12px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--pbj-muted);
}

.nav-toggle{
  display:none;
  border:1px solid var(--pbj-line);
  background:transparent;
  border-radius:999px;
  padding:10px 12px;
}
.primary-nav ul{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  align-items:center;
  gap: 18px;
  flex-wrap:wrap;
}
.primary-nav a{
  font-size: 14px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--pbj-text);
  padding: 10px 8px;
}
.primary-nav a:hover,
.primary-nav .current-menu-item > a,
.primary-nav .current_page_item > a{
  color: var(--pbj-accent);
}

.header-cta{
  display:flex;
  align-items:center;
  gap: 12px;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 12px 16px;
  border-radius: 999px;
  border: 1px solid var(--pbj-accent);
  background: transparent;
  color: var(--pbj-text);
  font-size: 13px;
  letter-spacing: .16em;
  text-transform: uppercase;
  transition: all .25s ease;
}
.btn:hover{
  background: var(--pbj-accent);
  color: #fff;
}
.btn--ghost{
  border-color: transparent;
  text-decoration: underline;
  text-underline-offset: 6px;
  text-decoration-thickness: 1px;
}
.btn--ghost:hover{
  background: transparent;
  color: var(--pbj-accent);
}

/* ========== Footer ========== */
.site-footer{
  border-top: 1px solid var(--pbj-line);
  padding: 28px var(--pbj-pad);
}
.footer-inner{
  display:flex;
  justify-content:space-between;
  gap: 18px;
  flex-wrap:wrap;
  align-items:center;
}
.footer-links{
  display:flex;
  gap: 14px;
  flex-wrap:wrap;
  align-items:center;
}
.footer-links a{
  font-size: 13px;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.copyright{
  color: var(--pbj-muted);
  font-size: 13px;
}

/* ========== Content / Blocks ========== */
h1,h2,h3,h4{
  font-family: var(--pbj-font-display);
  color: var(--pbj-text);
  line-height: 1.18;
  margin: 0 0 14px 0;
}
h1{ font-size: clamp(46px, 5vw, 78px); }
h2{ font-size: clamp(30px, 3.2vw, 44px); }
h3{ font-size: clamp(22px, 2.2vw, 30px); }
p{ margin: 0 0 16px 0; }

.entry-content{
  padding: 0;
}
.entry-content > *{
  width: min(100% - (var(--pbj-pad) * 2), var(--pbj-max));
  margin-inline:auto;
}
.entry-content > .alignwide{
  width: min(100% - (var(--pbj-pad) * 2), var(--pbj-wide));
}
.entry-content > .alignfull{
  width: 100%;
  margin-inline: 0;
}

/* Cover block overlay polish */
.wp-block-cover .wp-block-cover__inner-container{
  padding: var(--pbj-pad);
  max-width: var(--pbj-wide);
  margin-inline:auto;
}
.wp-block-cover .wp-block-buttons{ margin-top: 18px; }
.wp-block-cover .wp-block-button__link{
  border-radius: 999px !important;
  border: 1px solid var(--pbj-accent);
  background: transparent;
  color: var(--pbj-text);
  font-size: 13px;
  letter-spacing: .16em;
  text-transform: uppercase;
  padding: 12px 16px;
  transition: all .25s ease;
}
.wp-block-cover .wp-block-button__link:hover{
  background: var(--pbj-accent);
  color:#fff;
}
.wp-block-button.is-style-outline .wp-block-button__link{
  border-color: transparent;
  text-decoration: underline;
  text-underline-offset: 6px;
}

/* Hide default page titles site-wide on PhotosByJairo */
.page .entry-title,
.page .wp-block-post-title {
  display: none !important;
}

/* Gallery / Images */
.wp-block-gallery{ gap: 14px; }
.wp-block-image img{ border-radius: 16px; }
.wp-block-gallery .wp-block-image img{ border-radius: 18px; }
figure{ margin: 0; }

/* Forms (Contact Form 7 / native inputs) */
input, textarea, select{
  width: 100%;
  border: 1px solid var(--pbj-line);
  border-radius: 14px;
  padding: 14px 14px;
  font-size: 16px;
  font-family: var(--pbj-font-body);
  background:#fff;
}
input:focus, textarea:focus, select:focus{
  outline: none;
  border-color: var(--pbj-accent);
  box-shadow: 0 0 0 3px rgba(0,191,255,.18);
}
button, input[type="submit"]{
  border-radius: 999px;
  border: 1px solid var(--pbj-accent);
  background: transparent;
  color: var(--pbj-text);
  padding: 12px 16px;
  font-size: 13px;
  letter-spacing: .16em;
  text-transform: uppercase;
  transition: all .25s ease;
  cursor:pointer;
}
button:hover, input[type="submit"]:hover{
  background: var(--pbj-accent);
  color:#fff;
}

/* WooCommerce */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button{
  border-radius: 999px !important;
  border: 1px solid var(--pbj-accent) !important;
  background: transparent !important;
  color: var(--pbj-text) !important;
  letter-spacing: .16em;
  text-transform: uppercase;
  font-size: 13px !important;
  padding: 12px 16px !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover{
  background: var(--pbj-accent) !important;
  color:#fff !important;
}
.woocommerce div.product .product_title{
  font-family: var(--pbj-font-display);
}

/* Responsive nav */
@media (max-width: 980px){
  .nav-toggle{ display:inline-flex; }
  .primary-nav{
    display:none;
    padding: 0 var(--pbj-pad) 14px var(--pbj-pad);
  }
  .primary-nav.is-open{ display:block; }
  .primary-nav ul{
    flex-direction:column;
    align-items:flex-start;
    gap: 6px;
  }
  .brand{ min-width: auto; }
}