/*
Theme Name:   Mihaela Toma
Theme URI:    https://mihaelatomamakenbach.com/
Author:       Mihaela Toma
Author URI:   https://mihaelatomamakenbach.com/
Description:  Editorial portfolio theme for a writer & advisor. Zero-bloat, no page-builder. Designed for use with the companion "Mihaela Toma — Clips CPT" plugin. Lightweight, SEO-ready, JSON-LD schema built in.
Version:      1.1.0
Requires at least: 6.2
Requires PHP: 7.4
License:      GPL v2 or later
License URI:  https://www.gnu.org/licenses/gpl-2.0.html
Text Domain:  mt
Tags:         portfolio, one-column, custom-colors, custom-menu, editor-style, threaded-comments
*/

/* =========================================================
   RESET
   ========================================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{min-height:100vh;line-height:1.5}
img,picture,svg{display:block;max-width:100%;height:auto}
button,input,textarea,select{font:inherit;color:inherit}
a{color:inherit}
ul,ol{list-style:none}

/* =========================================================
   TOKENS
   ========================================================= */
:root{
  --paper: #F2EDE4;
  --paper-deep: #E8E0D1;
  --paper-edge: #DDD3BF;
  --ink: #1C1917;
  --ink-soft: #3A3631;
  --ink-muted: #6B6560;
  --accent: #7A2424;
  --accent-hover: #5C1818;
  --rule: rgba(28,25,23,0.14);
  --rule-soft: rgba(28,25,23,0.08);

  --display: "Fraunces", "Iowan Old Style", Georgia, serif;
  --sans: "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Helvetica Neue", sans-serif;
  --mono: "IBM Plex Mono", "SF Mono", Menlo, monospace;

  --gutter: clamp(1.25rem, 3vw, 2.5rem);
  --page-max: 78rem;
}

/* =========================================================
   BASE
   ========================================================= */
body{
  font-family:var(--sans);font-size:1rem;color:var(--ink);background:var(--paper);
  background-image:radial-gradient(rgba(28,25,23,0.025) 1px, transparent 1px);
  background-size:3px 3px;
}
h1,h2,h3,h4{font-family:var(--display);font-weight:500;letter-spacing:-0.01em;line-height:1.05;color:var(--ink)}
h1{font-size:clamp(2.4rem, 5.6vw, 4.8rem);font-variation-settings:"opsz" 144, "SOFT" 30}
h2{font-size:clamp(1.6rem, 3vw, 2.4rem);font-variation-settings:"opsz" 96}
h3{font-size:clamp(1.2rem, 2vw, 1.5rem);font-variation-settings:"opsz" 48}
p{font-size:1.0625rem;line-height:1.6;color:var(--ink-soft)}
a{text-decoration:none;transition:color 150ms ease}
a:hover{color:var(--accent)}
::selection{background:var(--accent);color:var(--paper)}

.meta,.kicker,.eyebrow{font-family:var(--mono);font-size:0.75rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-muted)}

.screen-reader-text{clip:rect(1px,1px,1px,1px);position:absolute !important;height:1px;width:1px;overflow:hidden;word-wrap:normal}

/* =========================================================
   MASTHEAD
   ========================================================= */
.masthead{border-bottom:1px solid var(--rule);padding-block:1.25rem;position:sticky;top:0;z-index:40;backdrop-filter:blur(6px);background-color:rgba(242,237,228,0.92)}
.masthead__inner{display:flex;align-items:baseline;justify-content:space-between;gap:2rem;max-width:var(--page-max);margin-inline:auto;padding-inline:var(--gutter)}
.masthead__mark{font-family:var(--display);font-size:1.125rem;font-weight:600;letter-spacing:-0.01em}
.masthead__mark em{font-style:italic;color:var(--accent);font-weight:400}
.masthead__nav{display:flex;gap:2rem;align-items:baseline;font-family:var(--mono);font-size:0.8125rem;letter-spacing:0.04em}
.masthead__nav a{color:var(--ink-soft);position:relative}
.masthead__nav a.current-menu-item, .masthead__nav a[aria-current="page"]{color:var(--accent)}
.masthead__nav a.current-menu-item::after, .masthead__nav a[aria-current="page"]::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:var(--accent)}
.masthead__nav .menu{display:flex;gap:2rem}
@media (max-width:720px){.masthead__nav{gap:1.25rem;font-size:0.75rem} .masthead__nav .menu{gap:1.25rem}}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{display:inline-flex;align-items:center;gap:0.5rem;padding:0.75rem 1.25rem;font-family:var(--sans);font-size:0.9375rem;font-weight:500;border:1px solid var(--ink);background:var(--ink);color:var(--paper);cursor:pointer;transition:all 180ms ease}
.btn:hover{background:var(--accent);border-color:var(--accent);color:var(--paper)}
.btn--ghost{background:transparent;color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--paper)}
.btn__arrow{display:inline-block;transition:transform 180ms ease}
.btn:hover .btn__arrow{transform:translateX(3px)}

/* =========================================================
   FOOTER / COLOPHON
   ========================================================= */
.colophon{border-top:1px solid var(--rule);margin-top:6rem;padding-block:2.5rem 3rem}
.colophon__grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2rem;max-width:var(--page-max);margin-inline:auto;padding-inline:var(--gutter);align-items:end}
.colophon__brand h3{font-size:1.25rem;margin-bottom:0.25rem}
.colophon__brand p{font-size:0.875rem;color:var(--ink-muted);max-width:32ch}
.colophon dt{font-family:var(--mono);font-size:0.6875rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:0.25rem}
.colophon dd{font-size:0.9375rem;margin-bottom:0.75rem}
.colophon dd a:hover{color:var(--accent)}
@media (max-width:720px){.colophon__grid{grid-template-columns:1fr;gap:1.5rem}}

/* =========================================================
   HOME (One Scroll)
   ========================================================= */
.home main{min-height:calc(100vh - 80px);display:flex;flex-direction:column}
.hero-wrap{flex:1;display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(2rem,6vw,5rem);max-width:var(--page-max);margin-inline:auto;padding:clamp(2.5rem,6vw,5rem) var(--gutter) 2rem;width:100%;align-items:start}
.hero__lede .eyebrow{display:inline-flex;align-items:center;gap:0.5rem;margin-bottom:1.75rem}
.hero__lede .eyebrow::before{content:"";display:inline-block;width:28px;height:1px;background:var(--accent)}
.hero__headline{font-weight:400;margin-bottom:1.5rem}
.hero__headline em{font-style:italic;color:var(--accent);font-variation-settings:"opsz" 144, "SOFT" 100}
.hero__dek{font-size:clamp(1.0625rem,1.5vw,1.25rem);line-height:1.5;color:var(--ink-soft);max-width:46ch;margin-bottom:2rem}
.hero__actions{display:flex;gap:0.75rem;flex-wrap:wrap;margin-bottom:2.5rem}
.bylines{border-top:1px solid var(--rule);padding-top:1.25rem}
.bylines__label{font-family:var(--mono);font-size:0.6875rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:0.875rem}
.bylines__list{display:flex;flex-wrap:wrap;gap:1.25rem 2rem;font-family:var(--display);font-style:italic;font-size:1rem;color:var(--ink-soft)}
.bylines__list li{opacity:0.85}

.rail{border-left:1px solid var(--rule);padding-left:clamp(1.25rem,3vw,2.25rem)}
.rail__title{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--mono);font-size:0.6875rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:1.5rem;padding-bottom:0.875rem;border-bottom:1px solid var(--rule-soft)}
.rail__list{counter-reset:rail}
.rail__item{counter-increment:rail;padding:1.25rem 0;border-bottom:1px solid var(--rule-soft);display:grid;grid-template-columns:2rem 1fr;gap:0.75rem;transition:padding-inline-start 200ms ease}
.rail__item:hover{padding-inline-start:0.5rem}
.rail__item:last-child{border-bottom:0}
.rail__item::before{content:counter(rail,decimal-leading-zero);font-family:var(--mono);font-size:0.75rem;color:var(--accent);font-weight:500;padding-top:0.15rem}

/* When item has a thumbnail — switch to stacked layout with image on top */
.rail__item.has-thumb{grid-template-columns:2rem 1fr;grid-template-rows:auto auto;gap:0.875rem 0.75rem;padding:1.5rem 0}
.rail__item.has-thumb::before{grid-row:2;padding-top:0.1rem}
.rail__item.has-thumb .rail__thumb{grid-column:1 / -1;grid-row:1;margin-bottom:0}
.rail__item.has-thumb .rail__body{grid-column:2;grid-row:2}

.rail__thumb{display:block;overflow:hidden;aspect-ratio:16/9;background:var(--paper-deep);border:1px solid var(--rule-soft);margin-bottom:0.25rem}
.rail__thumb img{width:100%;height:100%;object-fit:cover;transition:transform 400ms ease,filter 400ms ease;filter:saturate(0.92)}
.rail__item:hover .rail__thumb img{transform:scale(1.03);filter:saturate(1)}

.rail__body{min-width:0}
.rail__meta{font-family:var(--mono);font-size:0.6875rem;letter-spacing:0.04em;color:var(--ink-muted);margin-bottom:0.25rem;text-transform:uppercase}
.rail__meta .pub{color:var(--ink)}
.rail__title-link{font-family:var(--display);font-size:1.0625rem;line-height:1.25;color:var(--ink);font-weight:500;display:block}
.rail__title-link:hover{color:var(--accent)}
.rail__footer{margin-top:1.5rem;display:flex;justify-content:flex-end}
.rail__more{font-family:var(--mono);font-size:0.75rem;letter-spacing:0.04em;color:var(--ink);text-transform:uppercase;border-bottom:1px solid var(--accent);padding-bottom:2px}
.rail__more:hover{color:var(--accent)}

.home-strip{border-top:1px solid var(--ink);background:var(--paper-deep);padding-block:1rem;font-family:var(--mono);font-size:0.75rem;letter-spacing:0.04em;color:var(--ink-soft)}
.home-strip__row{display:flex;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;max-width:var(--page-max);margin-inline:auto;padding-inline:var(--gutter)}
.home-strip a:hover{color:var(--accent)}

@media (max-width:1080px){
  .hero-wrap{grid-template-columns:1fr;gap:3rem}
  .rail{border-left:0;border-top:1px solid var(--rule);padding-left:0;padding-top:2rem}
}

/* =========================================================
   CLIPS ARCHIVE
   ========================================================= */
.ledger{max-width:var(--page-max);margin-inline:auto;padding:3rem var(--gutter) 2rem}
.ledger__intro{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:end;padding-bottom:2rem;border-bottom:2px solid var(--ink);margin-bottom:2rem}
.ledger__intro h1{font-size:clamp(2rem,4.5vw,3.5rem)}
.ledger__intro p{max-width:46ch}
@media (max-width:720px){.ledger__intro{grid-template-columns:1fr;gap:1rem}}

.filters{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding-block:1.25rem;margin-bottom:0.5rem;border-bottom:1px solid var(--rule)}
.filters__niches{display:flex;flex-wrap:wrap;gap:0.5rem}
.filter-chip{display:inline-block;padding:0.375rem 0.875rem;font-family:var(--mono);font-size:0.75rem;letter-spacing:0.04em;border:1px solid var(--rule);border-radius:999px;color:var(--ink-soft);cursor:pointer;transition:all 150ms ease;background:transparent;text-decoration:none}
.filter-chip:hover{border-color:var(--ink);color:var(--ink)}
.filter-chip.is-active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.filters__sort{font-family:var(--mono);font-size:0.75rem;color:var(--ink-muted);text-transform:uppercase;letter-spacing:0.04em}

.entries{display:block}
.entry{display:grid;grid-template-columns:10rem 1fr 8rem;gap:2rem;align-items:baseline;padding:1.75rem 0;border-bottom:1px solid var(--rule);transition:all 180ms ease}
.entry:hover{background:linear-gradient(to right, var(--paper-deep), transparent);padding-inline:1rem;margin-inline:-1rem}
.entry__meta{font-family:var(--mono);font-size:0.75rem;letter-spacing:0.04em;color:var(--ink-muted);text-transform:uppercase}
.entry__meta .pub{display:block;color:var(--ink);font-weight:500;margin-bottom:0.125rem}
.entry__body h3{margin-bottom:0.5rem;font-size:1.375rem}
.entry__body h3 a{color:var(--ink)}
.entry__body h3 a:hover{color:var(--accent)}
.entry__body p{font-size:0.9375rem;color:var(--ink-soft);max-width:62ch}
.entry__tags{display:flex;flex-direction:column;gap:0.375rem;font-family:var(--mono);font-size:0.6875rem;letter-spacing:0.04em;text-transform:uppercase;color:var(--ink-muted);text-align:right}
.entry__format{display:inline-block;align-self:flex-end;padding:0.15rem 0.5rem;border:1px solid var(--rule);color:var(--ink-soft)}
@media (max-width:1080px){.entry{grid-template-columns:1fr;gap:0.75rem}.entry__tags{text-align:left;flex-direction:row;flex-wrap:wrap}}

.pagination{display:flex;justify-content:center;gap:0.5rem;padding-block:2rem;font-family:var(--mono);font-size:0.8125rem}
.pagination a, .pagination span{padding:0.5rem 0.875rem;border:1px solid var(--rule);color:var(--ink-soft)}
.pagination .current{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.pagination a:hover{border-color:var(--accent);color:var(--accent)}

/* =========================================================
   SINGLE CLIP
   ========================================================= */
.folio{max-width:68rem;margin-inline:auto;padding:2.5rem var(--gutter) 2rem;display:grid;grid-template-columns:minmax(0,1fr) 16rem;gap:3rem;align-items:start}
@media (max-width:1080px){.folio{grid-template-columns:1fr;gap:2rem}}
.breadcrumb{font-family:var(--mono);font-size:0.75rem;letter-spacing:0.04em;color:var(--ink-muted);text-transform:uppercase;margin-bottom:2rem}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .sep{margin-inline:0.5rem;color:var(--accent)}

.clip{grid-column:1}
.clip__kicker{display:inline-block;padding:0.25rem 0.625rem;border:1px solid var(--accent);color:var(--accent);font-family:var(--mono);font-size:0.6875rem;letter-spacing:0.08em;text-transform:uppercase;margin-bottom:1.5rem}
.clip__title{font-size:clamp(2.25rem,5vw,3.75rem);line-height:1.05;letter-spacing:-0.015em;margin-bottom:1.75rem;font-weight:400}
.clip__rail{display:grid;grid-template-columns:repeat(4,auto);gap:1.5rem 2.5rem;padding:1.25rem 0;border-block:1px solid var(--rule);margin-bottom:2rem}
.clip__rail dt{font-family:var(--mono);font-size:0.6875rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:0.25rem}
.clip__rail dd{font-size:0.9375rem;font-weight:500}
@media (max-width:720px){.clip__rail{grid-template-columns:1fr 1fr}}

.clip__dek{font-family:var(--display);font-size:clamp(1.25rem,2.2vw,1.5rem);line-height:1.45;color:var(--ink-soft);font-weight:400;max-width:58ch;margin-bottom:2.5rem;border-left:3px solid var(--accent);padding-left:1.5rem}
.clip__dek em{font-style:italic}

.clip__cta-block{padding:2rem;background:var(--paper-deep);border:1px solid var(--rule);display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap;margin-bottom:2rem}
.clip__cta-block .label{font-family:var(--mono);font-size:0.75rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:0.25rem}
.clip__cta-block .target{font-family:var(--display);font-size:1.25rem;font-weight:500}

.clip__notes{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--rule)}
.clip__notes h2{font-size:1.5rem;margin-bottom:1rem}
.clip__notes .prose p{margin-bottom:1rem;max-width:62ch}
.clip__notes .prose a{border-bottom:1px solid currentColor}

.related{grid-column:2;position:sticky;top:6rem;padding-left:1.5rem;border-left:1px solid var(--rule)}
.related h2{font-family:var(--mono);font-size:0.75rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:1.25rem;font-weight:500}
.related__list li{padding:0.875rem 0;border-bottom:1px solid var(--rule-soft)}
.related__list li:last-child{border-bottom:0}
.related__list a{display:block;font-size:0.9375rem;line-height:1.35;color:var(--ink);font-family:var(--display);font-weight:500}
.related__list a:hover{color:var(--accent)}
.related__list .pub{display:block;font-family:var(--mono);font-size:0.6875rem;letter-spacing:0.04em;text-transform:uppercase;color:var(--ink-muted);margin-top:0.25rem}
@media (max-width:1080px){.related{grid-column:1;position:static;padding-left:0;border-left:0;border-top:1px solid var(--rule);padding-top:2rem}}

/* =========================================================
   PAGE (generic)
   ========================================================= */
.page-wrap{max-width:var(--page-max);margin-inline:auto;padding:3rem var(--gutter) 2rem}
.page-wrap .prose{max-width:62ch}
.page-wrap .prose p{margin-bottom:1.25rem;font-size:1.0625rem}
.page-wrap .prose h2{margin-top:2rem;margin-bottom:1rem}
.page-wrap .prose h3{margin-top:1.5rem;margin-bottom:0.5rem}
.page-wrap .prose ul, .page-wrap .prose ol{margin:1rem 0 1.25rem 1.5rem}
.page-wrap .prose li{margin-bottom:0.5rem;font-size:1.0625rem;color:var(--ink-soft);line-height:1.6}
.page-wrap .prose ul li{list-style:disc}
.page-wrap .prose ol li{list-style:decimal}
.page-wrap .prose a{border-bottom:1px solid currentColor}
.page-wrap .prose blockquote{border-left:3px solid var(--accent);padding-left:1.5rem;margin:1.5rem 0;font-family:var(--display);font-style:italic;font-size:1.25rem;color:var(--ink-soft)}

/* =========================================================
   ANIMATIONS
   ========================================================= */
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.rise{animation:rise 600ms ease-out both}
.rise-1{animation-delay:50ms}.rise-2{animation-delay:150ms}.rise-3{animation-delay:250ms}
.rise-4{animation-delay:350ms}.rise-5{animation-delay:450ms}.rise-6{animation-delay:550ms}

@media (prefers-reduced-motion:reduce){*{animation:none !important;transition:none !important}}

/* =========================================================
   WordPress core classes (required for theme review)
   ========================================================= */
.alignleft{float:left;margin-right:1.5rem}
.alignright{float:right;margin-left:1.5rem}
.aligncenter{display:block;margin-inline:auto}
.wp-caption{max-width:100%}
.wp-caption-text{font-family:var(--mono);font-size:0.75rem;color:var(--ink-muted);margin-top:0.5rem}
.gallery-caption{font-family:var(--mono);font-size:0.75rem;color:var(--ink-muted)}
.bypostauthor{display:block}
.sticky{display:block}
