/*
Theme Name: Theo Howard Portfolio
Theme URI: https://theohoward.com
Author: Theo Howard
Author URI: https://theohoward.com
Description: A gallery-first WordPress portfolio theme for artist & technologist Theo Howard. Manage multiple art portfolios (fantasy & game art, bird & wildlife watercolor, rowing & sport) from one Artwork post type, write blog posts, run an events calendar, and capture contact inquiries that Hermes can read over the REST API. Includes a professional/technologist section that pitches Theo as an art director & designer for mobile game production. Built-in SEO, Open Graph, and Person/CreativeWork schema.
Version: 1.0.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: theohoward
Tags: portfolio, art, photography, blog, custom-menu, featured-images, two-columns, full-width-template, custom-colors, editor-style, translation-ready
*/

/* ============ 1. TOKENS — museum light ============ */
:root {
  --paper:   #f7f4ee;   /* warm gallery wall */
  --surface: #ffffff;
  --surface-2:#f1ece2;
  --ink:     #1b1a20;
  --ink-soft:#33313c;
  --muted:   #6c6a76;
  --faint:   #9b97a3;
  --line:    #e6e1d8;
  --line-2:  #d8d2c5;
  --accent:  #1f6f6b;   /* deep teal */
  --accent-d:#155350;
  --terra:   #c2632f;   /* warm terracotta */
  --gold:    #b08a3e;
  --shadow:  0 24px 60px -30px rgba(28,27,34,.45);
  --shadow-s:0 10px 30px -16px rgba(28,27,34,.35);
  --radius:  12px;
  --wrap:    1180px;
  --serif:   "Fraunces", Georgia, "Times New Roman", serif;
  --sans:    "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--paper); color: var(--ink-soft);
  font-family: var(--sans); line-height: 1.7; font-size: 17px;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--accent); text-decoration-thickness: 1px; text-underline-offset: 3px; }
h1,h2,h3,h4 { font-family: var(--serif); color: var(--ink); line-height: 1.12; font-weight: 600; letter-spacing: -.01em; }
.wrap { max-width: var(--wrap); margin: 0 auto; padding: 0 24px; }
.narrow { max-width: 760px; margin: 0 auto; }
.skip-link { position:absolute; left:-9999px; }
.skip-link:focus { left:12px; top:12px; z-index:999; background:var(--ink); color:#fff; padding:10px 16px; border-radius:8px; }
.screen-reader-text { position:absolute!important; clip:rect(1px,1px,1px,1px); width:1px; height:1px; overflow:hidden; }
.eyebrow { font: 600 .78rem/1 var(--sans); letter-spacing: .22em; text-transform: uppercase; color: var(--accent); display:inline-block; margin-bottom: 14px; }
.center { text-align: center; }
.lead { font-size: clamp(1.1rem, 2vw, 1.35rem); color: var(--ink-soft); }

/* ============ 2. HEADER / NAV ============ */
.site-header { position: sticky; top: 0; z-index: 100; background: rgba(247,244,238,.85); backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); }
.site-header .bar { display:flex; align-items:center; justify-content:space-between; gap:20px; padding:16px 24px; max-width:1320px; margin:0 auto; }
.site-logo { display:flex; align-items:center; gap:12px; text-decoration:none; }
.site-logo img { height:42px; width:auto; }
.site-logo .name { font-family: var(--serif); font-size:1.3rem; color:var(--ink); font-weight:600; letter-spacing:-.01em; }
.site-logo .name small { display:block; font-family:var(--sans); font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); font-weight:600; }
.main-nav ul { list-style:none; display:flex; gap:4px; align-items:center; }
.main-nav a { color:var(--ink-soft); text-decoration:none; font-size:.94rem; font-weight:500; padding:9px 14px; border-radius:8px; transition:.15s; }
.main-nav a:hover, .main-nav .current-menu-item>a { color:var(--accent); background:var(--surface-2); }
.header-cta { display:flex; align-items:center; gap:10px; }
.nav-toggle { display:none; background:none; border:1px solid var(--line-2); color:var(--ink); border-radius:8px; padding:8px 12px; font-size:1.1rem; cursor:pointer; }
@media (max-width:980px){
  .nav-toggle{display:block;}
  .main-nav{position:fixed; inset:70px 0 auto 0; background:var(--surface); border-bottom:1px solid var(--line); transform:translateY(-130%); transition:transform .25s; box-shadow:var(--shadow-s);}
  .main-nav.open{transform:translateY(0);}
  .main-nav ul{flex-direction:column; padding:14px; gap:2px;}
  .main-nav a{display:block; padding:12px 14px;}
  .header-cta .btn-ghost{display:none;}
}

/* ============ 3. BUTTONS ============ */
.btn { display:inline-flex; align-items:center; gap:8px; font:600 .96rem/1 var(--sans); text-decoration:none; border:0; cursor:pointer; padding:13px 24px; border-radius:100px; transition:transform .15s, box-shadow .15s, background .15s, color .15s; }
.btn-primary { background:var(--ink); color:#fff; }
.btn-primary:hover { background:var(--accent); transform:translateY(-2px); }
.btn-accent { background:var(--accent); color:#fff; }
.btn-accent:hover { background:var(--accent-d); transform:translateY(-2px); }
.btn-ghost { background:transparent; color:var(--ink); box-shadow:inset 0 0 0 1.5px var(--line-2); }
.btn-ghost:hover { box-shadow:inset 0 0 0 1.5px var(--accent); color:var(--accent); }
.btn-row { display:flex; flex-wrap:wrap; gap:12px; margin-top:26px; }
.center .btn-row { justify-content:center; }

/* ============ 4. SECTIONS ============ */
section.th { padding: clamp(3.5rem, 8vw, 7rem) 0; }
.th-head { max-width:680px; margin:0 auto clamp(2.5rem,5vw,4rem); text-align:center; }
.th-head h2 { font-size: clamp(2rem, 4.5vw, 3.2rem); margin-bottom:14px; }
.th-head p { color:var(--muted); font-size:1.1rem; }
.alt { background: var(--surface); border-block: 1px solid var(--line); }

/* ============ 5. HERO ============ */
.hero { padding: clamp(3rem,7vw,6rem) 0 clamp(2rem,5vw,4rem); }
.hero-grid { display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem,5vw,4.5rem); align-items:center; }
.hero h1 { font-size: clamp(2.6rem, 6.5vw, 4.8rem); margin-bottom:20px; }
.hero h1 .accent { color:var(--accent); font-style:italic; }
.hero p { font-size: clamp(1.1rem,2vw,1.3rem); color:var(--ink-soft); max-width:520px; }
.hero-art { position:relative; }
.hero-art .frame { border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); aspect-ratio:5/6; background:var(--surface-2); }
.hero-art .frame img { width:100%; height:100%; object-fit:cover; }
.hero-art .pip { position:absolute; bottom:-18px; left:-18px; width:46%; border-radius:10px; overflow:hidden; box-shadow:var(--shadow-s); border:4px solid var(--paper); }
@media (max-width:860px){ .hero-grid{grid-template-columns:1fr;} .hero-art{max-width:440px; margin:0 auto;} .hero p{max-width:none;} }

/* ============ 6. PORTFOLIO SHOWCASE (3 bodies of work) ============ */
.portfolios { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media (max-width:880px){ .portfolios{grid-template-columns:1fr; max-width:460px; margin:0 auto;} }
.pf-card { position:relative; display:block; border-radius:var(--radius); overflow:hidden; text-decoration:none; box-shadow:var(--shadow-s); aspect-ratio:4/5; background:var(--ink); }
.pf-card img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease, opacity .3s; opacity:.92; }
.pf-card:hover img { transform:scale(1.06); opacity:.7; }
.pf-card .cap { position:absolute; inset:auto 0 0 0; padding:26px 22px 22px; background:linear-gradient(transparent, rgba(20,19,26,.88)); color:#fff; }
.pf-card .cap h3 { color:#fff; font-size:1.5rem; }
.pf-card .cap span { font-size:.86rem; color:rgba(255,255,255,.8); }
.pf-card .cap .go { margin-top:10px; font:600 .8rem/1 var(--sans); letter-spacing:.12em; text-transform:uppercase; color:#fff; opacity:0; transform:translateY(6px); transition:.25s; }
.pf-card:hover .cap .go { opacity:1; transform:none; }

/* ============ 7. GALLERY (masonry + lightbox) ============ */
.filters { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:36px; }
.chip { font:600 .85rem/1 var(--sans); letter-spacing:.03em; padding:9px 18px; border-radius:100px; cursor:pointer; color:var(--muted); background:transparent; border:1px solid var(--line-2); transition:.15s; }
.chip:hover { color:var(--ink); border-color:var(--accent); }
.chip.is-active { color:#fff; background:var(--accent); border-color:transparent; }
.gallery { columns: 4 250px; column-gap:18px; }
.gallery .tile { break-inside:avoid; margin-bottom:18px; position:relative; border-radius:10px; overflow:hidden; cursor:zoom-in; box-shadow:var(--shadow-s); }
.gallery .tile img { width:100%; transition:transform .5s ease; }
.gallery .tile:hover img { transform:scale(1.04); }
.gallery .tile .meta { position:absolute; inset:auto 0 0 0; padding:22px 14px 12px; background:linear-gradient(transparent, rgba(20,19,26,.82)); color:#fff; opacity:0; transition:.25s; }
.gallery .tile:hover .meta { opacity:1; }
.gallery .tile .meta b { display:block; font-family:var(--serif); font-size:1rem; }
.gallery .tile .meta span { font-size:.76rem; color:rgba(255,255,255,.78); }

/* lightbox */
.lightbox { position:fixed; inset:0; z-index:1000; background:rgba(18,17,22,.93); display:none; align-items:center; justify-content:center; padding:32px; }
.lightbox.open { display:flex; }
.lightbox img { max-width:92vw; max-height:82vh; border-radius:8px; box-shadow:0 30px 80px rgba(0,0,0,.6); }
.lightbox .lb-cap { position:absolute; bottom:24px; left:0; right:0; text-align:center; color:#fff; font-family:var(--serif); font-size:1.1rem; }
.lightbox .lb-close, .lightbox .lb-nav { position:absolute; background:rgba(255,255,255,.12); border:0; color:#fff; width:48px; height:48px; border-radius:50%; font-size:1.4rem; cursor:pointer; display:grid; place-items:center; }
.lightbox .lb-close { top:24px; right:24px; }
.lightbox .lb-nav.prev { left:24px; top:50%; transform:translateY(-50%); }
.lightbox .lb-nav.next { right:24px; top:50%; transform:translateY(-50%); }
.lightbox .lb-nav:hover, .lightbox .lb-close:hover { background:rgba(255,255,255,.25); }

/* ============ 8. SPLIT / ABOUT / SERVICES ============ */
.split { display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.split.flip > :first-child { order:2; }
@media (max-width:860px){ .split,.split.flip>*{grid-template-columns:1fr; order:0!important;} }
.split .art { border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); }
.cards-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.cards-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
@media (max-width:860px){ .cards-3,.cards-2{grid-template-columns:1fr;} }
.card { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:30px 28px; transition:.2s; }
.card:hover { transform:translateY(-4px); box-shadow:var(--shadow-s); border-color:var(--line-2); }
.card .ic { width:48px; height:48px; border-radius:12px; display:grid; place-items:center; font-size:1.4rem; background:rgba(31,111,107,.1); color:var(--accent); margin-bottom:18px; }
.card h3 { font-size:1.3rem; margin-bottom:8px; }
.card p { color:var(--muted); font-size:.98rem; }

/* hire / studio pitch band */
.hire { background:var(--ink); color:#fff; border-radius:20px; padding:clamp(2.5rem,5vw,4.5rem); }
.hire .eyebrow { color:#7fd6cf; }
.hire h2 { color:#fff; }
.hire p { color:rgba(255,255,255,.82); }
.hire .pill-row { display:flex; flex-wrap:wrap; gap:10px; margin-top:22px; }
.hire .pill { background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.18); color:#fff; font-size:.85rem; font-weight:500; padding:8px 16px; border-radius:100px; }

/* ============ 9. EXPERIENCE TIMELINE ============ */
.timeline { position:relative; padding-left:30px; max-width:760px; margin:0 auto; }
.timeline::before { content:""; position:absolute; left:6px; top:8px; bottom:8px; width:2px; background:linear-gradient(var(--accent), var(--terra)); }
.tl { position:relative; padding-bottom:30px; }
.tl::before { content:""; position:absolute; left:-30px; top:7px; width:14px; height:14px; border-radius:50%; background:var(--paper); border:2px solid var(--accent); }
.tl h3 { font-size:1.25rem; margin-bottom:2px; }
.tl .meta { color:var(--terra); font-weight:600; font-size:.9rem; margin-bottom:8px; }
.tl p { color:var(--muted); font-size:.98rem; }

/* stats */
.stats { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; text-align:center; }
@media (max-width:680px){ .stats{grid-template-columns:repeat(2,1fr);} }
.stat .n { font-family:var(--serif); font-size:clamp(2rem,5vw,3rem); color:var(--ink); line-height:1; }
.stat .l { color:var(--muted); font-size:.88rem; margin-top:8px; }

/* ============ 10. EVENTS ============ */
.events-list { display:grid; gap:16px; max-width:820px; margin:0 auto; }
.event-row { display:grid; grid-template-columns:auto 1fr auto; gap:22px; align-items:center; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:20px 24px; transition:.2s; }
.event-row:hover { border-color:var(--accent); box-shadow:var(--shadow-s); }
.event-date { text-align:center; min-width:64px; }
.event-date .mon { font:700 .72rem/1 var(--sans); letter-spacing:.12em; text-transform:uppercase; color:var(--terra); }
.event-date .day { font-family:var(--serif); font-size:2rem; color:var(--ink); line-height:1; }
.event-info h3 { font-size:1.2rem; margin-bottom:2px; }
.event-info .when { color:var(--muted); font-size:.9rem; }
.event-row .btn { padding:10px 18px; font-size:.85rem; }
@media (max-width:600px){ .event-row{grid-template-columns:auto 1fr;} .event-row .btn{grid-column:1/-1;} }
.event-past { opacity:.6; }

/* ============ 11. BLOG ============ */
.page-head { padding: clamp(3rem,6vw,5rem) 0 0; text-align:center; }
.page-head h1 { font-size:clamp(2.2rem,6vw,3.6rem); }
.page-head p { color:var(--muted); margin-top:10px; }
.layout { display:grid; grid-template-columns:1fr 300px; gap:50px; padding: clamp(2.5rem,5vw,4rem) 0; }
.layout.full { grid-template-columns:1fr; max-width:820px; }
@media (max-width:920px){ .layout{grid-template-columns:1fr;} }
.posts { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:30px; }
.post-card { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; transition:.2s; }
.post-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-s); }
.post-card .thumb { aspect-ratio:16/10; overflow:hidden; }
.post-card .thumb img { width:100%; height:100%; object-fit:cover; }
.post-card .pc { padding:22px 24px 26px; }
.post-card .metaline, .single-meta { color:var(--terra); font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; font-weight:600; }
.post-card h2, .post-card h3 { font-size:1.35rem; margin:8px 0; line-height:1.2; }
.post-card h2 a, .post-card h3 a { color:var(--ink); text-decoration:none; }
.post-card h2 a:hover { color:var(--accent); }
.post-card p { color:var(--muted); font-size:.95rem; }
.readmore { display:inline-block; margin-top:12px; font-weight:600; font-size:.88rem; text-decoration:none; }

.single-article { max-width:760px; margin:0 auto; }
.single-article h1 { font-size:clamp(2rem,5vw,3rem); margin:8px 0 18px; }
.single-article .featured { border-radius:var(--radius); overflow:hidden; margin:24px 0; box-shadow:var(--shadow-s); }
.entry { font-size:1.08rem; line-height:1.85; color:var(--ink-soft); }
.entry p, .entry ul, .entry ol { margin-bottom:1.3em; }
.entry h2 { font-size:1.7rem; margin:1.5em 0 .5em; }
.entry h3 { font-size:1.3rem; margin:1.3em 0 .4em; }
.entry img { border-radius:10px; margin:1em 0; }
.entry blockquote { border-left:3px solid var(--accent); padding:6px 22px; margin:1.4em 0; font-family:var(--serif); font-style:italic; font-size:1.2rem; color:var(--ink); }
.entry a { color:var(--accent); }

.sidebar .widget { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:24px; margin-bottom:24px; }
.sidebar .widget-title { font-family:var(--serif); font-size:1.15rem; margin-bottom:14px; }
.sidebar ul { list-style:none; }
.sidebar li { padding:7px 0; border-bottom:1px solid var(--line); }
.sidebar a { color:var(--muted); text-decoration:none; }
.sidebar a:hover { color:var(--accent); }
.tag-pill { display:inline-block; background:var(--surface-2); border:1px solid var(--line-2); color:var(--muted); font-size:.76rem; padding:4px 12px; border-radius:100px; margin:4px 4px 0 0; text-decoration:none; }
.share-row { display:flex; gap:10px; margin:26px 0; }
.share-row a { background:var(--surface); border:1px solid var(--line-2); color:var(--ink); width:40px; height:40px; border-radius:50%; display:grid; place-items:center; text-decoration:none; }
.share-row a:hover { border-color:var(--accent); color:var(--accent); }
.pagination { display:flex; gap:8px; justify-content:center; margin-top:44px; flex-wrap:wrap; }
.pagination .page-numbers { padding:10px 16px; border-radius:9px; border:1px solid var(--line-2); color:var(--muted); text-decoration:none; }
.pagination .current { background:var(--accent); color:#fff; border-color:var(--accent); }

/* ============ 12. CONTACT FORM ============ */
.contact-grid { display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(2rem,5vw,4rem); }
@media (max-width:860px){ .contact-grid{grid-template-columns:1fr;} }
.th-form { display:grid; gap:16px; }
.th-form label { display:grid; gap:6px; font-size:.88rem; color:var(--muted); font-weight:500; }
.th-form input, .th-form select, .th-form textarea { font:inherit; padding:13px 15px; border-radius:10px; border:1px solid var(--line-2); background:var(--surface); color:var(--ink); width:100%; }
.th-form input:focus, .th-form textarea:focus, .th-form select:focus { outline:2px solid var(--accent); border-color:transparent; }
.th-form .hp { position:absolute; left:-9999px; }
.form-note { font-size:.82rem; color:var(--faint); }
.form-msg { padding:14px 18px; border-radius:10px; margin-bottom:16px; }
.form-msg.ok { background:rgba(31,111,107,.12); color:var(--accent-d); }
.form-msg.err { background:rgba(194,99,47,.12); color:var(--terra); }

/* ============ 13. CTA / FOOTER ============ */
.cta-band { text-align:center; background:linear-gradient(135deg, rgba(31,111,107,.1), rgba(194,99,47,.08)); border:1px solid var(--line); border-radius:20px; padding:clamp(2.5rem,5vw,4.5rem); }
.site-footer { background:var(--ink); color:rgba(255,255,255,.72); padding:56px 0 40px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.4fr; gap:40px; margin-bottom:40px; }
@media (max-width:860px){ .footer-grid{grid-template-columns:1fr 1fr;} }
@media (max-width:520px){ .footer-grid{grid-template-columns:1fr;} }
.site-footer h4 { color:#fff; font-size:1.05rem; margin-bottom:14px; }
.site-footer ul { list-style:none; }
.site-footer li { padding:5px 0; }
.site-footer a { color:rgba(255,255,255,.72); text-decoration:none; font-size:.94rem; }
.site-footer a:hover { color:#fff; }
.footer-brand .name { font-family:var(--serif); font-size:1.4rem; color:#fff; display:block; margin-bottom:10px; }
.footer-social { display:flex; gap:10px; margin-top:16px; }
.footer-social a { width:40px; height:40px; border-radius:50%; border:1px solid rgba(255,255,255,.2); display:grid; place-items:center; color:#fff; text-decoration:none; }
.footer-social a:hover { background:rgba(255,255,255,.12); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.14); padding-top:24px; text-align:center; font-size:.85rem; color:rgba(255,255,255,.55); }

/* ============ 14. MOTION ============ */
.reveal { opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease; }
.reveal.on { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ *{animation:none!important; transition:none!important; scroll-behavior:auto!important;} .reveal{opacity:1; transform:none;} }

/* WP core */
.aligncenter{margin-inline:auto;} .alignleft{float:left; margin:0 1.5em 1em 0;} .alignright{float:right; margin:0 0 1em 1.5em;}
.wp-caption-text{color:var(--muted); font-size:.85rem; text-align:center;}
.sticky,.gallery-caption,.bypostauthor{}
