/*
Theme Name: Woldezzy
Theme URI: https://woldezzy.xyz
Author: Wole Oduwole
Author URI: https://woldezzy.xyz
Description: Editorial personal theme for 'Wole Oduwole. Marketing Executive and TechPreneur. SEO-first, mobile-first, Core Web Vitals optimized. Warm paper palette, Fraunces serif, JetBrains Mono accents. Classic PHP theme with full Customizer.
Version: 1.1.1
Requires at least: 6.0
Tested up to: 6.8
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: woldezzy
Tags: blog, portfolio, personal, editorial, minimal, one-column, custom-logo, custom-menu, featured-images, translation-ready
*/

:root{
  --ink:          #12110F;
  --ink-2:        #2A2926;
  --ink-3:        #6B6A64;
  --ink-4:        #A9A69C;
  --paper:        #F4F1EA;
  --paper-2:      #EAE6DC;
  --paper-3:      #DED9CB;
  --accent:       #E8412A;
  --accent-2:     #1F4E3F;
  --rule:         rgba(18,17,15,.14);
  --rule-strong:  rgba(18,17,15,.22);

  --display: "Fraunces", "Times New Roman", Georgia, serif;
  --body:    "Inter Tight", "Helvetica Neue", system-ui, -apple-system, sans-serif;
  --mono:    "JetBrains Mono", "SFMono-Regular", Consolas, monospace;

  --maxw: 1400px;
  --gutter: 22px;

  --ease: cubic-bezier(.2,.7,.2,1);
}

@media (min-width: 768px){  :root{ --gutter: 32px; }  }
@media (min-width: 1100px){ :root{ --gutter: 40px; }  }

*,*::before,*::after{ box-sizing:border-box }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; text-rendering:optimizeLegibility }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:16px;
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  width:100%;
}
body::before{
  content:"";
  position:fixed; inset:0;
  background-image:radial-gradient(rgba(18,17,15,.025) 1px, transparent 1px);
  background-size:3px 3px;
  pointer-events:none; z-index:1;
  mix-blend-mode:multiply;
}
img, picture, svg, video{ max-width:100%; height:auto; display:block }
a{ color:inherit; text-decoration:none }
button{ font:inherit; background:none; border:0; cursor:pointer; color:inherit }
::selection{ background:var(--ink); color:var(--paper) }

h1,h2,h3,h4,h5,h6{
  font-family:var(--display);
  font-weight:400;
  letter-spacing:-.02em;
  line-height:1.1;
  margin:0;
}
p{ margin:0 0 1em }

.container{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 var(--gutter);
  position:relative;
  z-index:2;
  width:100%;
}

/* HEADER */
.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  background:rgba(244,241,234,.82);
  border-bottom:1px solid var(--rule);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0; gap:16px;
}
.site-logo{ display:flex; align-items:center; gap:10px; flex-shrink:0; min-width:0 }
.site-logo img,
.site-logo .custom-logo,
.site-logo .custom-logo-link img{
  height:50px !important;
  width:50px !important;
  max-width:none !important;
  object-fit:contain;
  display:block;
  flex-shrink:0;
}
.site-logo .custom-logo-link{ display:inline-flex; align-items:center; line-height:0 }
.site-logo .logo-text{
  font-family:var(--display); font-weight:500; font-size:16px; letter-spacing:-.01em;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.site-logo .logo-text em{ font-style:italic; color:var(--ink-3); font-weight:400 }

.primary-nav ul{
  list-style:none; margin:0; padding:0;
  display:flex; gap:32px; align-items:center;
}
.primary-nav a{
  font-size:14px; font-weight:500; color:var(--ink-2);
  position:relative; transition:color .2s var(--ease);
}
.primary-nav a:hover,
.primary-nav .current-menu-item>a{ color:var(--accent) }
.primary-nav a::after{
  content:""; position:absolute; left:0; bottom:-4px;
  width:0; height:1px; background:var(--accent);
  transition:width .3s var(--ease);
}
.primary-nav a:hover::after{ width:100% }

.nav-cta{
  font-family:var(--mono); font-size:12px;
  padding:10px 18px; border:1px solid var(--ink);
  border-radius:999px; background:var(--ink); color:var(--paper);
  text-transform:uppercase; letter-spacing:.08em;
  transition:all .25s var(--ease);
  white-space:nowrap; flex-shrink:0;
}
.nav-cta:hover{ background:var(--accent); border-color:var(--accent) }

.menu-toggle{
  display:none; width:40px; height:40px; border-radius:999px;
  border:1px solid var(--rule-strong);
  position:relative; flex-shrink:0;
}
.menu-toggle span{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:16px; height:1px; background:var(--ink);
}
.menu-toggle span::before,
.menu-toggle span::after{
  content:""; position:absolute; left:0; width:16px; height:1px; background:var(--ink);
  transition:transform .25s var(--ease);
}
.menu-toggle span::before{ top:-5px }
.menu-toggle span::after{  top: 5px }
.menu-toggle[aria-expanded="true"] span{ background:transparent }
.menu-toggle[aria-expanded="true"] span::before{ transform:rotate(45deg) translate(3px,4px) }
.menu-toggle[aria-expanded="true"] span::after{  transform:rotate(-45deg) translate(3px,-4px) }

@media (max-width: 860px){
  .site-logo .logo-text em{ display:none }

  .site-header .primary-nav{
    position:fixed !important;
    top:0 !important;
    right:0 !important;
    bottom:0 !important;
    left:0 !important;
    width:100% !important;
    height:100% !important;
    background:var(--paper) !important;
    transform:translateX(100%);
    transition:transform .35s var(--ease);
    padding:84px 24px 40px !important;
    margin:0 !important;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    z-index:55 !important;
  }
  .site-header .primary-nav.open{ transform:translateX(0) }

  .site-header .primary-nav ul,
  .site-header .primary-nav .menu,
  .site-header .primary-nav div ul{
    display:flex !important;
    flex-direction:column !important;
    gap:0 !important;
    align-items:stretch !important;
    list-style:none !important;
    margin:0 !important;
    padding:0 !important;
    width:100% !important;
  }

  .site-header .primary-nav li,
  .site-header .primary-nav .menu-item{
    width:100% !important;
    border-bottom:1px solid var(--rule) !important;
    margin:0 !important;
    padding:0 !important;
    list-style:none !important;
  }
  .site-header .primary-nav li:last-child,
  .site-header .primary-nav .menu-item:last-child{ border-bottom:0 !important }

  .site-header .primary-nav a,
  .site-header .primary-nav li a,
  .site-header .primary-nav .menu-item a{
    display:block !important;
    font-family:var(--body) !important;
    font-size:16px !important;
    font-weight:500 !important;
    line-height:1.4 !important;
    letter-spacing:0 !important;
    color:var(--ink) !important;
    padding:16px 0 !important;
    width:100% !important;
    text-transform:none !important;
    text-decoration:none !important;
  }
  .site-header .primary-nav a:hover,
  .site-header .primary-nav .current-menu-item>a{
    color:var(--accent) !important;
  }
  .site-header .primary-nav a::after{ display:none !important }

  .menu-toggle{ display:block; z-index:70; position:relative }
  .nav-cta{ display:none }
  .site-header{ z-index:60 }
}

/* HERO */
.hero{ padding:48px 0 72px; position:relative }
@media (min-width: 768px){ .hero{ padding:72px 0 100px } }
@media (min-width: 1100px){ .hero{ padding:80px 0 120px } }

.hero-meta{
  display:flex; flex-wrap:wrap; gap:16px 24px; align-items:center;
  font-family:var(--mono); font-size:10px;
  text-transform:uppercase; letter-spacing:.14em;
  color:var(--ink-3); margin-bottom:40px;
}
@media (min-width: 768px){ .hero-meta{ font-size:11px; margin-bottom:56px } }
.hero-meta .dot{
  width:6px; height:6px; border-radius:50%;
  background:var(--accent); display:inline-block; margin-right:8px;
  animation:pulse 2.5s infinite;
}
@keyframes pulse{ 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.3)} }

.hero-title{
  font-size:clamp(40px, 11vw, 132px);
  font-weight:300; line-height:.96;
  letter-spacing:-.035em; margin-bottom:32px;
  word-wrap:break-word;
}
.hero-title em{ font-style:italic; font-weight:400; color:var(--accent) }
.hero-title .soft{ color:var(--ink-3); font-weight:300; display:inline-block }

.hero-bottom{
  display:grid; grid-template-columns:1fr; gap:40px;
  margin-top:48px; padding-top:32px;
  border-top:1px solid var(--rule);
}
@media (min-width: 900px){
  .hero-bottom{ grid-template-columns:1.2fr 1fr; gap:60px; align-items:end; margin-top:56px }
}
.hero-lead{
  font-family:var(--display); font-size:18px;
  line-height:1.45; font-weight:300; color:var(--ink-2); max-width:560px;
  margin:0;
}
@media (min-width: 768px){ .hero-lead{ font-size:21px } }
.hero-lead em{ font-style:italic; color:var(--ink) }

.hero-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px }
@media (min-width: 768px){ .hero-stats{ gap:24px } }
.stat .num{
  font-family:var(--display);
  font-size:clamp(28px, 6vw, 44px);
  font-weight:400; letter-spacing:-.02em; line-height:1;
}
.stat .lbl{
  font-family:var(--mono); font-size:9px; text-transform:uppercase;
  letter-spacing:.12em; color:var(--ink-3); margin-top:6px;
}
@media (min-width: 768px){ .stat .lbl{ font-size:10px; margin-top:8px } }

.hero-scenic{
  margin-top:56px;
  aspect-ratio: 16 / 10;
  border-radius:8px;
  overflow:hidden; position:relative;
  background:var(--paper-2);
}
@media (min-width: 900px){ .hero-scenic{ aspect-ratio: 21 / 9; margin-top:72px } }
.hero-scenic img{
  width:100%; height:100%;
  object-fit:cover; object-position:center;
  transition:transform 1.2s var(--ease);
}
.hero-scenic:hover img{ transform:scale(1.03) }
.hero-scenic .caption{
  position:absolute; bottom:16px; left:16px;
  font-family:var(--mono); font-size:10px; text-transform:uppercase;
  letter-spacing:.14em; color:var(--paper);
  background:rgba(18,17,15,.6); padding:6px 10px; border-radius:4px;
  backdrop-filter:blur(6px);
  max-width:calc(100% - 32px);
}

/* MARQUEE */
.marquee{
  border-top:1px solid var(--rule); border-bottom:1px solid var(--rule);
  padding:18px 0; overflow:hidden; white-space:nowrap;
  background:var(--paper-2);
}
.marquee-track{
  display:inline-flex; gap:48px;
  animation:slide 38s linear infinite;
  font-family:var(--display); font-style:italic;
  font-size:18px; color:var(--ink-2); font-weight:400;
}
@media (min-width: 768px){ .marquee-track{ font-size:22px; gap:60px } }
.marquee-track span{ display:inline-flex; align-items:center; gap:48px }
@media (min-width: 768px){ .marquee-track span{ gap:60px } }
.marquee-track .star{
  display:inline-block; width:8px; height:8px;
  background:var(--accent); border-radius:50%;
}
@keyframes slide{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* SECTIONS */
.section{ padding:72px 0; position:relative }
@media (min-width: 768px){ .section{ padding:100px 0 } }
@media (min-width: 1100px){ .section{ padding:120px 0 } }

.section-label{
  font-family:var(--mono); font-size:10px;
  text-transform:uppercase; letter-spacing:.16em;
  color:var(--accent);
  display:flex; align-items:center; gap:12px;
  margin-bottom:24px;
}
@media (min-width: 768px){ .section-label{ font-size:11px; margin-bottom:32px } }
.section-label::before{ content:""; width:20px; height:1px; background:var(--accent) }

.section-title{
  font-size:clamp(32px, 6.5vw, 68px);
  font-weight:300; line-height:1.05; letter-spacing:-.025em;
  max-width:900px;
}
.section-title em{ font-style:italic; color:var(--ink-3); font-weight:400 }

/* CAPABILITIES */
.caps{ margin-top:48px; border-top:1px solid var(--rule) }
@media (min-width: 900px){ .caps{ margin-top:72px } }

.cap{
  display:grid;
  grid-template-columns:40px 1fr;
  grid-template-areas:"num title" "num desc" "num arrow";
  column-gap:16px; row-gap:8px;
  padding:24px 0;
  border-bottom:1px solid var(--rule);
  transition:background .3s var(--ease), padding .3s var(--ease);
  cursor:pointer;
}
.cap-num   { grid-area:num;   font-family:var(--mono); font-size:11px; color:var(--ink-4); padding-top:6px }
.cap-title { grid-area:title; font-family:var(--display); font-size:26px; font-weight:400; line-height:1.1; letter-spacing:-.02em }
.cap-desc  { grid-area:desc;  color:var(--ink-3); font-size:14px; line-height:1.65 }
.cap-arrow {
  grid-area:arrow;
  font-family:var(--mono); font-size:10px;
  text-transform:uppercase; letter-spacing:.1em;
  color:var(--ink); display:inline-flex; align-items:center; gap:10px;
  margin-top:4px;
}
@media (min-width: 900px){
  .cap{
    grid-template-columns:80px 1fr 2fr 180px;
    grid-template-areas:"num title desc arrow";
    column-gap:40px; row-gap:0;
    padding:32px 0;
    align-items:start;
  }
  .cap:hover{ background:var(--paper-2); padding-left:20px; padding-right:20px }
  .cap-num{ padding-top:10px; font-size:12px }
  .cap-title{ font-size:30px }
  .cap-desc{ padding-top:10px; font-size:15px }
  .cap-arrow{ justify-self:end; padding-top:12px; font-size:11px; margin-top:0 }
}
.cap-arrow span{
  width:26px; height:26px; border:1px solid var(--ink);
  border-radius:50%; display:inline-flex; align-items:center; justify-content:center;
  transition:all .3s var(--ease);
}
.cap:hover .cap-arrow span{
  background:var(--accent); border-color:var(--accent);
  color:var(--paper); transform:rotate(-45deg);
}

/* ABOUT */
.about{
  background:var(--ink); color:var(--paper);
  margin:32px 0; border-radius:18px;
  padding:48px 28px; position:relative; overflow:hidden;
}
@media (min-width: 768px){ .about{ padding:72px 44px; border-radius:22px } }
@media (min-width: 1100px){ .about{ padding:100px 60px; border-radius:24px; margin:40px 0 } }

.about::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(circle at 20% 80%, rgba(232,65,42,.12), transparent 50%);
  pointer-events:none;
}
.about-grid{
  display:grid; grid-template-columns:1fr; gap:32px;
  align-items:center; position:relative;
}
@media (min-width: 900px){ .about-grid{ grid-template-columns:1fr 1.4fr; gap:60px } }
@media (min-width: 1100px){ .about-grid{ gap:80px } }

.about-portrait{
  aspect-ratio:4/5;
  border-radius:8px; position:relative; overflow:hidden;
  background:var(--paper-2);
  max-width:400px; width:100%;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.06);
}
@media (min-width: 900px){ .about-portrait{ max-width:none } }
.about-portrait img{
  width:100%; height:100%;
  object-fit:contain; object-position:center;
  background:var(--paper-2);
}
.about-portrait .tag{
  position:absolute; bottom:14px; left:14px;
  font-family:var(--mono); font-size:10px;
  text-transform:uppercase; letter-spacing:.14em;
  color:var(--ink-2); background:var(--paper);
  padding:5px 10px; border-radius:4px;
}
.about-label{
  font-family:var(--mono); font-size:10px;
  text-transform:uppercase; letter-spacing:.16em;
  color:var(--accent); margin-bottom:20px;
  display:flex; gap:12px; align-items:center;
}
@media (min-width: 768px){ .about-label{ font-size:11px; margin-bottom:28px } }
.about-label::before{ content:""; width:20px; height:1px; background:var(--accent) }
.about-text{
  font-family:var(--display);
  font-size:clamp(20px, 4vw, 36px);
  line-height:1.35; font-weight:300; letter-spacing:-.01em;
  margin:0;
}
.about-text em{ font-style:italic; color:var(--accent) }
.about-sig{
  margin-top:28px; display:flex; align-items:center; gap:16px;
  font-family:var(--mono); font-size:11px; color:var(--ink-4);
  text-transform:uppercase; letter-spacing:.12em;
  flex-wrap:wrap;
}
@media (min-width: 768px){ .about-sig{ margin-top:36px; font-size:12px } }
.about-sig .line{ width:32px; height:1px; background:var(--ink-4); flex-shrink:0 }

/* WORK GRID */
.work-grid{
  margin-top:48px;
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:1px; background:var(--rule); border:1px solid var(--rule);
}
@media (min-width: 768px){ .work-grid{ grid-template-columns:repeat(3,1fr); margin-top:60px } }
@media (min-width: 1100px){ .work-grid{ grid-template-columns:repeat(4,1fr); margin-top:80px } }

.work-item{
  background:var(--paper); padding:28px 16px; text-align:center;
  font-family:var(--display);
  font-size:clamp(17px, 3vw, 22px);
  font-weight:400; letter-spacing:-.01em; color:var(--ink-2);
  transition:all .3s var(--ease);
}
@media (min-width: 768px){ .work-item{ padding:36px 20px } }
@media (min-width: 1100px){ .work-item{ padding:40px 24px } }
.work-item:hover{ background:var(--ink); color:var(--paper) }
.work-item .yr{
  display:block; font-family:var(--mono); font-size:9px;
  color:var(--ink-4); margin-top:6px; letter-spacing:.1em; text-transform:uppercase;
}
@media (min-width: 768px){ .work-item .yr{ font-size:10px; margin-top:8px } }
.work-item:hover .yr{ color:var(--accent) }

/* JOURNAL */
.journal{
  margin-top:48px;
  display:grid; grid-template-columns:1fr; gap:32px;
}
@media (min-width: 900px){ .journal{ grid-template-columns:2fr 1fr 1fr; gap:32px; margin-top:72px } }

.j-card{
  border-top:1px solid var(--ink); padding:24px 0;
  display:flex; flex-direction:column; gap:14px;
}
.j-card.has-image{ padding-top:0; border-top:none }
.j-thumb{
  aspect-ratio:4/3; overflow:hidden; border-radius:6px; background:var(--paper-2);
  display:block;
  box-shadow: inset 0 0 0 1px var(--rule);
}
.j-thumb img{
  width:100%; height:100%;
  object-fit:contain; object-position:center;
  background:var(--paper-2);
  transition:transform .8s var(--ease);
}
.j-card:hover .j-thumb img{ transform:scale(1.04) }
.j-card.has-image::before{
  content:""; height:1px; background:var(--ink); display:block; margin-bottom:20px;
}
.j-meta{
  display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap;
  font-family:var(--mono); font-size:10px;
  text-transform:uppercase; letter-spacing:.12em; color:var(--ink-3);
}
.j-card h3{
  font-size:22px; font-weight:400; line-height:1.2;
  letter-spacing:-.015em; color:var(--ink);
  transition:color .25s var(--ease);
  margin:0;
}
@media (min-width: 768px){ .j-card h3{ font-size:26px } }
.j-card.large h3{ font-size:28px }
@media (min-width: 768px){ .j-card.large h3{ font-size:36px } }
.j-card:hover h3{ color:var(--accent) }
.j-excerpt{ color:var(--ink-3); font-size:14px; line-height:1.6; margin:0 }
.j-card .read{
  font-family:var(--mono); font-size:10px;
  text-transform:uppercase; letter-spacing:.12em; color:var(--ink); margin-top:auto;
}
.j-card .read::after{ content:" \2192"; transition:margin-left .25s var(--ease); display:inline-block }
.j-card:hover .read::after{ margin-left:6px }

/* CTA */
.cta{
  padding:80px 0 96px; text-align:center; position:relative;
  overflow:hidden;
}
@media (min-width: 768px){ .cta{ padding:120px 0 } }
@media (min-width: 1100px){ .cta{ padding:140px 0 } }

.cta-decor{
  position:absolute; inset:0; z-index:0;
  opacity:.07; pointer-events:none;
}
.cta-decor img{ width:100%; height:100%; object-fit:cover; filter:grayscale(1) }
.cta > .container{ position:relative; z-index:2 }

.cta h2{
  font-size:clamp(40px, 9vw, 112px);
  font-weight:300; line-height:1; letter-spacing:-.035em;
  max-width:none; margin:0 auto;
}
.cta h2 em{ font-style:italic; color:var(--accent); font-weight:400 }
.cta-sub{
  font-family:var(--mono); font-size:11px; text-transform:uppercase;
  letter-spacing:.16em; color:var(--ink-3); margin-top:24px;
}
@media (min-width: 768px){ .cta-sub{ font-size:12px; margin-top:32px } }

.cta-btn{
  display:inline-flex; align-items:center; gap:12px;
  margin-top:36px; padding:16px 28px;
  background:var(--ink); color:var(--paper); border-radius:999px;
  font-family:var(--mono); font-size:11px;
  text-transform:uppercase; letter-spacing:.12em;
  transition:all .3s var(--ease);
}
@media (min-width: 768px){ .cta-btn{ padding:20px 36px; font-size:12px; margin-top:48px; gap:14px } }
.cta-btn:hover{ background:var(--accent); transform:translateY(-2px) }
.cta-btn .arrow{
  width:28px; height:28px; border-radius:50%;
  background:var(--paper); color:var(--ink);
  display:inline-flex; align-items:center; justify-content:center;
  font-size:13px; transition:transform .3s var(--ease);
}
@media (min-width: 768px){ .cta-btn .arrow{ width:32px; height:32px; font-size:14px } }
.cta-btn:hover .arrow{ transform:rotate(-45deg) }

/* FOOTER */
.site-footer{
  background:var(--ink); color:var(--paper-3);
  padding:56px 0 32px; font-size:14px; position:relative; z-index:2;
}
@media (min-width: 768px){ .site-footer{ padding:80px 0 40px } }

.foot-grid{
  display:grid; grid-template-columns:1fr; gap:40px;
  padding-bottom:40px;
  border-bottom:1px solid rgba(244,241,234,.12);
}
@media (min-width: 600px){ .foot-grid{ grid-template-columns:1fr 1fr; gap:40px } }
@media (min-width: 900px){ .foot-grid{ grid-template-columns:2fr 1fr 1fr 1fr; gap:56px; padding-bottom:56px } }

.foot-logo{
  font-family:var(--display); font-size:28px; font-weight:400;
  color:var(--paper); letter-spacing:-.02em; margin-bottom:14px;
}
@media (min-width: 768px){ .foot-logo{ font-size:32px; margin-bottom:16px } }
.foot-logo em{ font-style:italic; color:var(--accent) }
.foot-desc{ color:var(--ink-4); max-width:360px; line-height:1.6; margin:0 }
.foot-col h4{
  font-family:var(--mono); font-size:11px; text-transform:uppercase;
  letter-spacing:.14em; color:var(--paper); margin:0 0 16px; font-weight:500;
}
.foot-col a{
  display:block; color:var(--ink-4); padding:6px 0;
  transition:color .2s var(--ease);
}
.foot-col a:hover{ color:var(--accent) }
.foot-col ul{ list-style:none; margin:0; padding:0 }
.foot-bottom{
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  padding-top:24px; font-family:var(--mono); font-size:10px;
  text-transform:uppercase; letter-spacing:.12em; color:var(--ink-4);
}
@media (min-width: 768px){ .foot-bottom{ padding-top:32px; font-size:11px } }

/* SINGLE / PAGE */
.single-main, .page-main{ padding:48px 0 80px }
@media (min-width: 768px){ .single-main, .page-main{ padding:64px 0 100px } }
@media (min-width: 1100px){ .single-main, .page-main{ padding:80px 0 120px } }

.entry-header{
  max-width:820px; margin:0 auto 40px; text-align:center;
}
@media (min-width: 768px){ .entry-header{ margin-bottom:60px } }
.entry-meta{
  font-family:var(--mono); font-size:10px; text-transform:uppercase;
  letter-spacing:.14em; color:var(--accent); margin-bottom:16px;
}
@media (min-width: 768px){ .entry-meta{ font-size:11px; margin-bottom:20px } }
.entry-title{
  font-size:clamp(32px, 7vw, 72px);
  font-weight:300; letter-spacing:-.03em; line-height:1.05;
}
.entry-title em{ font-style:italic; color:var(--ink-3) }

.entry-featured{
  max-width:1200px; margin:0 auto 48px;
  aspect-ratio:16/9; overflow:hidden; border-radius:8px;
  background:var(--paper-2);
  box-shadow: inset 0 0 0 1px var(--rule);
}
@media (min-width: 768px){ .entry-featured{ margin-bottom:72px } }
.entry-featured img{
  width:100%; height:100%;
  object-fit:contain; object-position:center;
  background:var(--paper-2);
}

.entry-content{
  max-width:720px; margin:0 auto;
  font-size:17px; line-height:1.75; color:var(--ink-2);
}
@media (min-width: 768px){ .entry-content{ font-size:18px } }
.entry-content > *{ margin-bottom:1.4em }
.entry-content h2{ font-size:28px; font-weight:400; margin:1.8em 0 .5em; letter-spacing:-.02em }
@media (min-width: 768px){ .entry-content h2{ font-size:36px; margin:2em 0 .6em } }
.entry-content h3{ font-size:22px; font-weight:400; margin:1.5em 0 .4em }
@media (min-width: 768px){ .entry-content h3{ font-size:26px } }
.entry-content p{ margin:0 0 1.2em }
.entry-content a{ color:var(--accent); border-bottom:1px solid currentColor; transition:opacity .2s }
.entry-content a:hover{ opacity:.7 }
.entry-content blockquote{
  border-left:2px solid var(--accent); padding:8px 0 8px 20px; margin:1.8em 0;
  font-family:var(--display); font-style:italic;
  font-size:20px; line-height:1.4; color:var(--ink);
}
@media (min-width: 768px){
  .entry-content blockquote{ padding-left:24px; margin:2em 0; font-size:24px }
}
.entry-content code{
  font-family:var(--mono); font-size:.9em;
  background:var(--paper-2); padding:2px 6px; border-radius:3px;
}
.entry-content pre{
  font-family:var(--mono); background:var(--ink); color:var(--paper);
  padding:18px 20px; border-radius:8px; overflow-x:auto;
  font-size:13px; line-height:1.6;
}
.entry-content img{ border-radius:8px; margin:2em 0; width:100%; height:auto }
.entry-content ul, .entry-content ol{ padding-left:22px; margin:0 0 1.4em }
.entry-content li{ margin-bottom:.5em }

/* ARCHIVE */
.archive-header{ padding:56px 0 32px; text-align:center }
@media (min-width: 768px){ .archive-header{ padding:80px 0 40px } }
.archive-title{
  font-size:clamp(36px, 7vw, 80px); font-weight:300;
  letter-spacing:-.03em; line-height:1;
}
.archive-title em{ font-style:italic; color:var(--accent) }
.archive-list{
  padding:24px 0 80px;
  display:grid; grid-template-columns:1fr; gap:32px;
}
@media (min-width: 700px){ .archive-list{ grid-template-columns:repeat(2,1fr); gap:48px; padding:40px 0 120px } }

/* COMMENTS */
.comments-area{
  max-width:720px; margin:56px auto 0;
  padding-top:32px; border-top:1px solid var(--rule);
}
@media (min-width: 768px){ .comments-area{ margin-top:80px; padding-top:40px } }
.comments-title{ font-size:22px; font-weight:400; margin-bottom:20px }
@media (min-width: 768px){ .comments-title{ font-size:24px; margin-bottom:24px } }
.comment-list{ list-style:none; margin:0; padding:0 }
.comment-body{ padding:18px 0; border-bottom:1px solid var(--rule) }
.comment-author{ font-weight:500; font-size:14px }
.comment-meta{
  font-family:var(--mono); font-size:10px; color:var(--ink-3);
  text-transform:uppercase; letter-spacing:.1em; margin-bottom:8px;
}
.comment-form input[type=text],
.comment-form input[type=email],
.comment-form input[type=url],
.comment-form textarea{
  width:100%; padding:12px 14px; border:1px solid var(--rule-strong);
  border-radius:6px; background:var(--paper); font:inherit;
  margin-bottom:14px; transition:border-color .2s var(--ease);
  font-size:15px;
}
.comment-form input:focus, .comment-form textarea:focus{
  outline:none; border-color:var(--ink);
}
.comment-form .submit{
  background:var(--ink); color:var(--paper);
  padding:14px 26px; border-radius:999px; border:0;
  font-family:var(--mono); font-size:11px;
  text-transform:uppercase; letter-spacing:.1em; cursor:pointer;
  transition:background .25s var(--ease);
}
.comment-form .submit:hover{ background:var(--accent) }

/* PAGINATION */
.pagination{
  display:flex; justify-content:center; gap:6px; flex-wrap:wrap;
  padding:32px 0 80px;
}
@media (min-width: 768px){ .pagination{ gap:8px; padding:40px 0 120px } }
.pagination .page-numbers{
  min-width:36px; height:36px; display:inline-flex;
  align-items:center; justify-content:center;
  border:1px solid var(--rule-strong); border-radius:999px;
  font-family:var(--mono); font-size:11px; padding:0 12px;
  transition:all .25s var(--ease);
}
@media (min-width: 768px){
  .pagination .page-numbers{ min-width:40px; height:40px; font-size:12px; padding:0 14px }
}
.pagination .page-numbers:hover,
.pagination .page-numbers.current{
  background:var(--ink); color:var(--paper); border-color:var(--ink);
}

/* 404 */
.error-404{ padding:96px 0 120px; text-align:center }
@media (min-width: 768px){ .error-404{ padding:160px 0 } }
.error-404 .big{
  font-size:clamp(100px, 20vw, 240px);
  font-weight:300; letter-spacing:-.05em;
  line-height:1; color:var(--accent); font-family:var(--display); font-style:italic;
}
.error-404 p{ max-width:480px; margin:24px auto; color:var(--ink-3) }

/* PAGE-SPECIFIC */
.page-intro{
  padding:56px 0 32px;
  display:grid; grid-template-columns:1fr; gap:40px; align-items:center;
}
@media (min-width: 900px){
  .page-intro{ padding:80px 0 48px; grid-template-columns:1.2fr 1fr; gap:64px }
}
.page-intro h1{
  font-size:clamp(36px, 7vw, 72px); font-weight:300;
  letter-spacing:-.03em; line-height:1.05;
}
.page-intro h1 em{ font-style:italic; color:var(--accent) }
.page-intro-lead{
  font-family:var(--display); font-size:18px; line-height:1.5;
  font-weight:300; color:var(--ink-2); margin-top:24px;
}
@media (min-width: 768px){ .page-intro-lead{ font-size:21px; margin-top:32px } }

.page-image{
  aspect-ratio:4/5; border-radius:10px; overflow:hidden;
  background:var(--paper-2); max-width:480px; width:100%; margin:0 auto;
  box-shadow: inset 0 0 0 1px var(--rule);
}
.page-image img{
  width:100%; height:100%;
  object-fit:contain; object-position:center;
  background:var(--paper-2);
}
.page-image.wide{ aspect-ratio:16/10; max-width:none }
.page-image.wide img{ object-fit:contain }

.img-pair{
  display:grid; grid-template-columns:1fr; gap:16px;
  margin:48px 0;
}
@media (min-width: 768px){ .img-pair{ grid-template-columns:1fr 1fr; gap:20px; margin:64px 0 } }
.img-pair .cell{
  aspect-ratio:4/5; border-radius:8px; overflow:hidden; background:var(--paper-2);
  box-shadow: inset 0 0 0 1px var(--rule);
}
.img-pair .cell.wide{ aspect-ratio:16/10 }
.img-pair img{
  width:100%; height:100%;
  object-fit:contain; object-position:center;
  background:var(--paper-2);
}

.body-prose{
  max-width:720px; margin:0 auto;
  font-size:17px; line-height:1.75; color:var(--ink-2);
}
@media (min-width: 768px){ .body-prose{ font-size:18px } }
.body-prose p{ margin:0 0 1.2em }
.body-prose h2{ font-size:28px; font-weight:400; margin:2em 0 .5em; color:var(--ink) }
@media (min-width: 768px){ .body-prose h2{ font-size:34px } }

/* Contact */
.contact-grid{
  display:grid; grid-template-columns:1fr; gap:48px;
  padding:40px 0 80px;
}
@media (min-width: 900px){ .contact-grid{ grid-template-columns:1fr 1.2fr; gap:80px; padding:60px 0 120px } }

.contact-channels{ display:flex; flex-direction:column; gap:4px }
.contact-channels a{
  display:flex; justify-content:space-between; align-items:center;
  padding:20px 0; border-bottom:1px solid var(--rule);
  font-family:var(--display); font-size:22px; font-weight:400;
  color:var(--ink); transition:color .2s var(--ease), padding .2s var(--ease);
}
.contact-channels a:hover{ color:var(--accent); padding-left:8px }
.contact-channels a span{
  font-family:var(--mono); font-size:10px;
  text-transform:uppercase; letter-spacing:.14em; color:var(--ink-3);
}
.contact-channels a:hover span{ color:var(--accent) }

/* WP core */
.alignleft{  float:none; margin:0 0 1em 0; display:block }
.alignright{ float:none; margin:0 0 1em 0; display:block }
@media (min-width: 700px){
  .alignleft{  float:left;  margin:0 1.5em 1em 0 }
  .alignright{ float:right; margin:0 0 1em 1.5em }
}
.aligncenter{ display:block; margin-left:auto; margin-right:auto }
.alignwide{ max-width:1100px; margin-left:auto; margin-right:auto }
.alignfull{ max-width:none }
.screen-reader-text{
  position:absolute !important; width:1px; height:1px;
  overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap;
}
.skip-link{
  position:absolute; top:-40px; left:0; padding:8px 16px;
  background:var(--ink); color:var(--paper); z-index:100;
}
.skip-link:focus{ top:0 }

/* reveal */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .8s var(--ease), transform .8s var(--ease) }
.reveal.in{ opacity:1; transform:none }

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.01ms !important; transition-duration:.01ms !important }
  .reveal{ opacity:1; transform:none }
}

/* ═══════════════════════════════════════════════
   FINAL MOBILE MENU ENFORCER
   Last-in-file rules; wins cascade vs any plugin.
   ═══════════════════════════════════════════════ */
@media (max-width: 860px){
  body .site-header .primary-nav,
  body header.site-header nav.primary-nav{
    position:fixed !important;
    inset:0 !important;
    top:0 !important; right:0 !important; bottom:0 !important; left:0 !important;
    width:100vw !important;
    max-width:100vw !important;
    height:100vh !important;
    max-height:100vh !important;
    background:#F4F1EA !important;
    transform:translateX(100%) !important;
    transition:transform .35s cubic-bezier(.2,.7,.2,1) !important;
    padding:80px 22px 40px !important;
    margin:0 !important;
    overflow-y:auto !important;
    z-index:55 !important;
    box-sizing:border-box !important;
  }
  body .site-header .primary-nav.open,
  body header.site-header nav.primary-nav.open{
    transform:translateX(0) !important;
  }

  body .site-header .primary-nav ul,
  body .site-header .primary-nav .menu,
  body .site-header .primary-nav ol,
  body header.site-header nav.primary-nav ul{
    display:block !important;
    flex-direction:column !important;
    width:100% !important;
    margin:0 !important;
    padding:0 !important;
    list-style:none !important;
    gap:0 !important;
  }

  body .site-header .primary-nav li,
  body .site-header .primary-nav .menu-item,
  body header.site-header nav.primary-nav li{
    display:block !important;
    width:100% !important;
    margin:0 !important;
    padding:0 !important;
    border-bottom:1px solid rgba(18,17,15,.14) !important;
    list-style:none !important;
  }

  body .site-header .primary-nav a,
  body .site-header .primary-nav li a,
  body .site-header .primary-nav ul li a,
  body .site-header .primary-nav .menu-item a,
  body header.site-header nav.primary-nav a{
    display:block !important;
    font-family:"Inter Tight","Helvetica Neue",system-ui,sans-serif !important;
    font-size:15px !important;
    font-weight:500 !important;
    line-height:1.4 !important;
    letter-spacing:0 !important;
    color:#12110F !important;
    padding:14px 0 !important;
    margin:0 !important;
    width:100% !important;
    text-transform:none !important;
    text-decoration:none !important;
    text-align:left !important;
    background:transparent !important;
  }

  body .site-header .primary-nav a::before,
  body .site-header .primary-nav a::after{
    display:none !important;
    content:none !important;
  }
}
