/*
Theme Name: Zest
Theme URI: https://example.com/zest
Author: Zest Team
Author URI: https://example.com
Description: Zest is a refined, magazine-style WordPress theme engineered for recipe blogs that demand exceptional article readability. It pairs elegant Cormorant serif headings with crisp Manrope body text, a deep forest green and saffron accent palette, edge-to-edge featured images on mobile, a smooth reading progress bar, drop cap on articles, floating back-to-top, AdSense-safe ad slots, category-driven header navigation, and a pages-based footer with copyright.
Version: 1.0.0
Requires at least: 5.6
Tested up to: 6.5
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: zest
Tags: food-and-drink, blog, magazine, two-columns, right-sidebar, custom-menu, custom-logo, featured-images, threaded-comments, translation-ready, responsive-layout
*/

/* =========================================================
   1. DESIGN TOKENS
========================================================= */
:root{
    --c-bg: #FBFAF6;
    --c-surface: #FFFFFF;
    --c-text: #0F1A14;
    --c-text-soft: #3F4A43;
    --c-muted: #6B7569;
    --c-border: #E5E2D9;
    --c-line: #ECE9DF;
    --c-primary: #1F4332;
    --c-primary-dark: #143025;
    --c-primary-soft: #E8EFE9;
    --c-accent: #D4A24C;
    --c-accent-dark: #B0832F;
    --c-shadow-sm: 0 1px 2px rgba(15,26,20,.04), 0 1px 3px rgba(15,26,20,.06);
    --c-shadow-md: 0 4px 12px rgba(15,26,20,.06), 0 2px 4px rgba(15,26,20,.04);
    --c-shadow-lg: 0 18px 40px rgba(15,26,20,.08), 0 6px 16px rgba(15,26,20,.04);
    --r-sm: 4px;
    --r-md: 10px;
    --r-lg: 18px;
    --r-xl: 28px;
    --f-display: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
    --f-body: 'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --f-mono: ui-monospace, SFMono-Regular, Menlo, monospace;
    --container: 1180px;
    --container-narrow: 720px;
    --t-fast: .18s cubic-bezier(.4,0,.2,1);
    --t-base: .28s cubic-bezier(.4,0,.2,1);
}

/* =========================================================
   2. RESET & BASE
========================================================= */
*,*::before,*::after{box-sizing:border-box}
html{
    scroll-behavior:smooth;
    -webkit-text-size-adjust:100%;
    overflow-x:hidden;
}
body{
    margin:0;
    font-family:var(--f-body);
    font-size:17px;
    line-height:1.7;
    color:var(--c-text);
    background:var(--c-bg);
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
    overflow-x:hidden;
    font-feature-settings:"kern" 1,"liga" 1;
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--c-primary);text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--c-accent-dark)}
h1,h2,h3,h4,h5,h6{
    font-family:var(--f-display);
    font-weight:600;
    color:var(--c-text);
    line-height:1.15;
    margin:0 0 .5em;
    letter-spacing:-.005em;
}
h1{font-size:clamp(2rem,5vw,3.4rem);font-weight:700}
h2{font-size:clamp(1.65rem,3.5vw,2.4rem)}
h3{font-size:1.5rem}
h4{font-size:1.25rem}
p{margin:0 0 1.2em}
blockquote{
    border-left:3px solid var(--c-accent);
    padding:.4em 1.4em;
    margin:1.8em 0;
    font-family:var(--f-display);
    font-style:italic;
    font-size:1.4em;
    line-height:1.4;
    color:var(--c-primary);
}
blockquote p{margin:.4em 0}
hr{border:0;border-top:1px solid var(--c-line);margin:2.4em 0}
code{
    font-family:var(--f-mono);
    background:var(--c-primary-soft);
    padding:2px 6px;border-radius:4px;
    font-size:.9em;
}
::selection{background:var(--c-primary);color:var(--c-bg)}

/* =========================================================
   3. READING PROGRESS BAR
========================================================= */
.reading-progress{
    position:fixed;top:0;left:0;
    width:0%;height:3px;
    background:linear-gradient(90deg,var(--c-primary) 0%,var(--c-accent) 100%);
    z-index:200;
    transition:width .08s linear;
    will-change:width;
}

/* =========================================================
   4. CONTAINERS / LAYOUT
========================================================= */
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.container-narrow{max-width:var(--container-narrow);margin:0 auto;padding:0 24px}
.site{display:flex;flex-direction:column;min-height:100vh}
.site-main{flex:1;padding:48px 0 64px}
.content-wrap{display:grid;grid-template-columns:1fr 300px;gap:56px;align-items:start}

/* =========================================================
   5. HEADER
========================================================= */
.site-header{
    background:rgba(251,250,246,.85);
    backdrop-filter:saturate(180%) blur(10px);
    -webkit-backdrop-filter:saturate(180%) blur(10px);
    border-bottom:1px solid var(--c-line);
    position:sticky;top:0;z-index:100;
    transition:box-shadow var(--t-base);
}
.site-header.is-scrolled{box-shadow:0 2px 16px rgba(15,26,20,.04)}
.header-top{
    display:flex;align-items:center;justify-content:space-between;
    padding:18px 0;gap:24px;
}

/* Text logo */
.site-branding{display:flex;align-items:baseline;gap:14px;min-width:0}
.site-title{
    margin:0;
    font-family:var(--f-display);
    font-weight:700;
    font-size:clamp(1.5rem,3vw,1.9rem);
    letter-spacing:-.02em;
    line-height:1;
}
.site-title a{
    color:var(--c-text);
    display:inline-flex;align-items:baseline;
    position:relative;
}
.site-title a::after{
    content:".";
    color:var(--c-accent);
    font-weight:700;
    margin-left:1px;
}
.site-description{
    font-size:.78rem;
    color:var(--c-muted);
    letter-spacing:.06em;
    text-transform:uppercase;
    margin:0;
    padding-left:14px;
    border-left:1px solid var(--c-border);
}

/* Nav */
.main-navigation{display:flex;align-items:center;gap:8px}
.main-navigation ul{
    list-style:none;margin:0;padding:0;
    display:flex;align-items:center;gap:2px;
}
.main-navigation a{
    color:var(--c-text-soft);
    font-weight:500;
    font-size:.92rem;
    padding:10px 14px;
    border-radius:var(--r-sm);
    transition:all var(--t-fast);
    position:relative;
    letter-spacing:.01em;
}
.main-navigation a:hover{color:var(--c-primary)}
.main-navigation .current-menu-item > a,
.main-navigation .current-cat > a{
    color:var(--c-primary);
}
.main-navigation .current-menu-item > a::after,
.main-navigation .current-cat > a::after{
    content:"";
    position:absolute;
    bottom:4px;left:14px;right:14px;
    height:2px;background:var(--c-accent);
    border-radius:2px;
}
.main-navigation li{position:relative}
.main-navigation .sub-menu,
.main-navigation .children{
    position:absolute;top:100%;left:0;
    background:var(--c-surface);
    border:1px solid var(--c-line);
    border-radius:var(--r-md);
    box-shadow:var(--c-shadow-lg);
    min-width:200px;padding:8px;
    opacity:0;visibility:hidden;
    transform:translateY(8px);
    transition:all var(--t-base);
    list-style:none;margin:0;
}
.main-navigation li:hover > .sub-menu,
.main-navigation li:hover > .children{
    opacity:1;visibility:visible;transform:translateY(0);
}
.main-navigation .sub-menu a,
.main-navigation .children a{display:block;padding:10px 14px;font-size:.9rem}

/* Search icon button in header */
.header-search-toggle{
    background:none;border:0;cursor:pointer;
    width:40px;height:40px;border-radius:50%;
    display:inline-flex;align-items:center;justify-content:center;
    color:var(--c-text-soft);
    transition:all var(--t-fast);
}
.header-search-toggle:hover{background:var(--c-primary-soft);color:var(--c-primary)}

/* Mobile toggle */
.menu-toggle{
    display:none;
    background:none;border:1px solid var(--c-border);
    width:44px;height:44px;border-radius:var(--r-md);
    cursor:pointer;align-items:center;justify-content:center;
    padding:0;flex-shrink:0;
    transition:all var(--t-fast);
}
.menu-toggle:hover{border-color:var(--c-primary)}
.menu-toggle span,
.menu-toggle span::before,
.menu-toggle span::after{
    display:block;width:20px;height:2px;
    background:var(--c-text);
    border-radius:2px;position:relative;
    transition:transform var(--t-fast);
}
.menu-toggle span::before,
.menu-toggle span::after{
    content:"";position:absolute;left:0;
}
.menu-toggle span::before{top:-6px}
.menu-toggle span::after{top:6px}
.menu-toggle[aria-expanded="true"] span{background:transparent}
.menu-toggle[aria-expanded="true"] span::before{transform:rotate(45deg);top:0}
.menu-toggle[aria-expanded="true"] span::after{transform:rotate(-45deg);top:0}

/* =========================================================
   6. AD ZONES (Google AdSense friendly)
========================================================= */
.ad-zone{
    margin:28px 0;
    text-align:center;
    min-height:90px;
    display:flex;flex-direction:column;
    align-items:center;justify-content:center;
    background:var(--c-surface);
    border:1px dashed var(--c-border);
    border-radius:var(--r-md);
    color:var(--c-muted);
    overflow:hidden;
    position:relative;
}
.ad-zone::before{
    content:"Advertisement";
    position:absolute;top:6px;left:50%;
    transform:translateX(-50%);
    font-size:.62rem;letter-spacing:.16em;
    text-transform:uppercase;color:var(--c-muted);opacity:.55;
}
.ad-zone .ad-content{width:100%}
.ad-zone .ad-content:empty{
    min-height:60px;
    display:flex;align-items:center;justify-content:center;
}
.ad-zone .ad-content:empty::after{
    content:"Ad space (paste AdSense in widget)";
    font-size:.82rem;letter-spacing:.04em;
    color:var(--c-muted);
}
.ad-zone.ad-sidebar{min-height:260px}
.ad-zone.ad-incontent{margin:36px 0}

/* =========================================================
   7. HOMEPAGE — HERO POST
========================================================= */
.hero-section{
    margin-bottom:48px;
    padding-bottom:48px;
    border-bottom:1px solid var(--c-line);
}
.hero-post{
    display:grid;
    grid-template-columns:1.2fr 1fr;
    gap:40px;
    align-items:center;
}
.hero-post-image{
    aspect-ratio:4/3;
    border-radius:var(--r-lg);
    overflow:hidden;
    background:var(--c-primary-soft);
    box-shadow:var(--c-shadow-md);
}
.hero-post-image img{
    width:100%;height:100%;object-fit:cover;
    transition:transform .8s cubic-bezier(.4,0,.2,1);
}
.hero-post:hover .hero-post-image img{transform:scale(1.04)}
.hero-post-body{padding:20px 0}
.hero-post-tag{
    display:inline-block;
    font-size:.7rem;
    letter-spacing:.16em;text-transform:uppercase;
    color:var(--c-accent-dark);
    font-weight:700;
    margin-bottom:18px;
    position:relative;padding-left:24px;
}
.hero-post-tag::before{
    content:"";position:absolute;
    left:0;top:50%;transform:translateY(-50%);
    width:16px;height:2px;background:var(--c-accent);
}
.hero-post-title{
    font-size:clamp(1.8rem,4.5vw,3rem);
    line-height:1.1;
    margin-bottom:18px;
}
.hero-post-title a{color:var(--c-text)}
.hero-post-title a:hover{color:var(--c-primary)}
.hero-post-excerpt{
    color:var(--c-text-soft);
    font-size:1.05rem;
    line-height:1.65;
    margin-bottom:20px;
}
.hero-post-meta{
    font-size:.85rem;color:var(--c-muted);
    display:flex;gap:14px;align-items:center;
}
.hero-post-meta a{color:var(--c-text)}

/* Section header */
.section-header{
    display:flex;align-items:baseline;
    justify-content:space-between;
    margin-bottom:28px;
    padding-bottom:14px;
    border-bottom:1px solid var(--c-line);
}
.section-title{
    margin:0;font-size:1.4rem;font-weight:700;
    letter-spacing:-.01em;
}
.section-link{
    font-size:.82rem;font-weight:600;
    color:var(--c-primary);
    letter-spacing:.04em;
}

/* =========================================================
   8. POST CARDS / GRID
========================================================= */
.posts-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
    gap:36px;
    margin:0 0 32px;
}
.post-card{
    display:flex;flex-direction:column;
    background:transparent;
    transition:transform var(--t-base);
}
.post-card:hover{transform:translateY(-3px)}
.post-card-image{
    aspect-ratio:4/3;
    border-radius:var(--r-md);
    overflow:hidden;
    background:var(--c-primary-soft);
    margin-bottom:18px;
    box-shadow:var(--c-shadow-sm);
}
.post-card-image img{
    width:100%;height:100%;object-fit:cover;
    transition:transform .6s cubic-bezier(.4,0,.2,1);
}
.post-card:hover .post-card-image img{transform:scale(1.06)}
.post-card-category{
    font-size:.68rem;letter-spacing:.14em;
    text-transform:uppercase;
    color:var(--c-accent-dark);
    font-weight:700;
    margin-bottom:8px;
    display:inline-block;
}
.post-card-title{
    font-size:1.4rem;
    line-height:1.2;
    margin:0 0 10px;
}
.post-card-title a{color:var(--c-text)}
.post-card-title a:hover{color:var(--c-primary)}
.post-card-excerpt{
    color:var(--c-text-soft);
    font-size:.95rem;
    line-height:1.6;
    margin:0 0 14px;
    display:-webkit-box;-webkit-line-clamp:2;
    -webkit-box-orient:vertical;overflow:hidden;
}
.post-card-meta{
    font-size:.78rem;color:var(--c-muted);
    display:flex;gap:10px;align-items:center;
    margin-top:auto;
}

/* Page header (archive / search) */
.page-header{
    text-align:center;
    padding:24px 0 36px;
    margin-bottom:36px;
    border-bottom:1px solid var(--c-line);
}
.page-title{
    font-size:clamp(2rem,4vw,2.8rem);
    margin-bottom:8px;
}
.archive-description{
    color:var(--c-muted);
    max-width:580px;margin:0 auto;
    font-size:1rem;
}

/* =========================================================
   9. SINGLE POST — ARTICLE VIEW (the star of the theme)
========================================================= */
.single-article{
    max-width:760px;
    margin:0 auto;
}
.entry-header{
    text-align:center;
    margin-bottom:36px;
    padding:8px 0 0;
}
.entry-category-badge{
    display:inline-block;
    font-size:.72rem;
    letter-spacing:.16em;
    text-transform:uppercase;
    color:var(--c-accent-dark);
    font-weight:700;
    margin-bottom:22px;
    position:relative;
}
.entry-category-badge::before,
.entry-category-badge::after{
    content:"";
    display:inline-block;
    width:24px;height:1px;
    background:var(--c-border);
    vertical-align:middle;
    margin:0 12px;
}
.entry-title{
    font-size:clamp(2.2rem,5.5vw,3.6rem);
    line-height:1.08;
    margin-bottom:22px;
    letter-spacing:-.015em;
    font-weight:700;
}
.entry-subtitle{
    font-family:var(--f-display);
    font-size:clamp(1.15rem,2.2vw,1.4rem);
    font-style:italic;
    color:var(--c-text-soft);
    line-height:1.5;
    margin:0 0 28px;
    font-weight:400;
}
.entry-meta-row{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:18px;
    font-size:.88rem;
    color:var(--c-muted);
    flex-wrap:wrap;
}
.entry-meta-row .author-avatar{
    width:36px;height:36px;border-radius:50%;
    overflow:hidden;background:var(--c-primary-soft);
    flex-shrink:0;
}
.entry-meta-row .author-avatar img{
    width:100%;height:100%;object-fit:cover;
}
.entry-meta-row .meta-author{
    display:flex;align-items:center;gap:10px;
    color:var(--c-text);
}
.entry-meta-row .meta-author strong{
    font-weight:600;color:var(--c-text);
}
.entry-meta-row .meta-divider{
    width:4px;height:4px;border-radius:50%;
    background:var(--c-border);
}

/* Featured image — edge-to-edge on mobile */
.entry-thumbnail{
    margin:36px -40px 40px;
    border-radius:var(--r-xl);
    overflow:hidden;
    box-shadow:var(--c-shadow-lg);
    background:var(--c-primary-soft);
}
.entry-thumbnail img{
    width:100%;
    aspect-ratio:16/9;
    object-fit:cover;
}

/* Content typography */
.entry-content{
    font-size:1.13rem;
    line-height:1.85;
    color:var(--c-text);
}
.entry-content > p:first-of-type::first-letter{
    font-family:var(--f-display);
    font-weight:700;
    font-size:4em;
    float:left;
    line-height:.85;
    padding:8px 12px 0 0;
    color:var(--c-primary);
}
.entry-content p{margin-bottom:1.3em}
.entry-content h2{
    font-size:clamp(1.6rem,3vw,2.1rem);
    margin-top:2em;margin-bottom:.7em;
    position:relative;
}
.entry-content h3{
    font-size:clamp(1.3rem,2.4vw,1.6rem);
    margin-top:1.8em;margin-bottom:.6em;
}
.entry-content a{
    color:var(--c-primary);
    text-decoration:underline;
    text-decoration-color:var(--c-accent);
    text-decoration-thickness:2px;
    text-underline-offset:3px;
    transition:all var(--t-fast);
}
.entry-content a:hover{
    color:var(--c-accent-dark);
    text-decoration-color:var(--c-primary);
}
.entry-content img,
.entry-content figure{
    margin:2em 0;
    border-radius:var(--r-md);
    overflow:hidden;
    box-shadow:var(--c-shadow-md);
}
.entry-content figure img{margin:0;border-radius:0;box-shadow:none}
.entry-content figcaption,
.entry-content .wp-caption-text{
    font-family:var(--f-display);
    font-style:italic;
    font-size:.95em;
    text-align:center;
    color:var(--c-muted);
    margin-top:.7em;
    padding:0 1em;
}
.entry-content ul,
.entry-content ol{
    padding-left:1.4em;
    margin-bottom:1.4em;
}
.entry-content ul li::marker{color:var(--c-accent)}
.entry-content ol li::marker{color:var(--c-primary);font-weight:600}
.entry-content li{margin-bottom:.5em}
.entry-content li > ul,
.entry-content li > ol{margin-top:.5em;margin-bottom:.5em}

/* Recipe tables */
.entry-content table{
    width:100%;
    border-collapse:collapse;
    margin:1.8em 0;
    background:var(--c-surface);
    border-radius:var(--r-md);
    overflow:hidden;
    box-shadow:var(--c-shadow-sm);
    font-size:.96em;
}
.entry-content table th{
    background:var(--c-primary);
    color:var(--c-surface);
    text-align:left;
    padding:14px 16px;
    font-weight:600;
    letter-spacing:.02em;
}
.entry-content table td{
    padding:12px 16px;
    border-top:1px solid var(--c-line);
}
.entry-content table tr:nth-child(even) td{background:var(--c-bg)}

/* Pull quote variation */
.entry-content blockquote{
    margin:2em -20px;
    padding:1em 1.5em;
    background:var(--c-primary-soft);
    border-radius:var(--r-md);
    border-left:4px solid var(--c-accent);
}
.entry-content blockquote::before{
    content:"\201C";
    display:block;
    font-family:var(--f-display);
    font-size:3em;
    line-height:.5;
    color:var(--c-accent);
    margin-bottom:.2em;
}

/* Tags */
.entry-tags{
    margin-top:48px;
    padding-top:24px;
    border-top:1px solid var(--c-line);
    display:flex;flex-wrap:wrap;gap:8px;align-items:center;
}
.entry-tags-label{
    font-size:.78rem;
    letter-spacing:.1em;text-transform:uppercase;
    color:var(--c-muted);
    margin-right:8px;font-weight:600;
}
.entry-tags a{
    background:var(--c-surface);
    border:1px solid var(--c-border);
    padding:6px 14px;
    border-radius:999px;
    font-size:.82rem;
    color:var(--c-text);
    transition:all var(--t-fast);
}
.entry-tags a:hover{
    background:var(--c-primary);
    color:var(--c-surface);
    border-color:var(--c-primary);
}

/* Author bio card */
.author-bio{
    margin-top:48px;
    padding:28px;
    background:var(--c-surface);
    border-radius:var(--r-lg);
    box-shadow:var(--c-shadow-sm);
    display:flex;
    gap:20px;
    align-items:flex-start;
}
.author-bio-avatar{
    width:72px;height:72px;
    border-radius:50%;
    overflow:hidden;
    flex-shrink:0;
    background:var(--c-primary-soft);
}
.author-bio-avatar img{width:100%;height:100%;object-fit:cover}
.author-bio-body{flex:1;min-width:0}
.author-bio-name{
    font-size:.7rem;letter-spacing:.14em;
    text-transform:uppercase;color:var(--c-muted);
    margin:0 0 4px;font-weight:600;
    font-family:var(--f-body);
}
.author-bio-display{
    font-family:var(--f-display);
    font-size:1.4rem;font-weight:600;
    margin:0 0 10px;
}
.author-bio-text{
    color:var(--c-text-soft);
    font-size:.95rem;line-height:1.65;
    margin:0;
}

/* Post navigation */
.post-navigation{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:18px;
    margin:48px 0 0;
}
.post-navigation a{
    display:block;
    padding:22px 24px;
    background:var(--c-surface);
    border-radius:var(--r-md);
    box-shadow:var(--c-shadow-sm);
    color:var(--c-text);
    transition:all var(--t-base);
    border:1px solid transparent;
}
.post-navigation a:hover{
    transform:translateY(-2px);
    box-shadow:var(--c-shadow-md);
    border-color:var(--c-primary-soft);
}
.post-navigation .nav-label{
    font-size:.7rem;letter-spacing:.14em;
    text-transform:uppercase;color:var(--c-accent-dark);
    display:block;margin-bottom:6px;font-weight:700;
}
.post-navigation .nav-title{
    font-family:var(--f-display);
    font-size:1.05rem;
    font-weight:600;
    line-height:1.3;
}
.post-navigation .nav-next{text-align:right}

/* Related posts */
.related-posts{
    margin-top:64px;
    padding-top:48px;
    border-top:1px solid var(--c-line);
}
.related-posts-title{
    text-align:center;
    margin-bottom:32px;
    font-size:1.6rem;
}

/* =========================================================
   10. COMMENTS
========================================================= */
.comments-area{
    margin-top:56px;
    padding-top:32px;
    border-top:1px solid var(--c-line);
}
.comments-title{
    margin-bottom:24px;
    font-size:1.5rem;
}
.comment-list{list-style:none;padding:0;margin:0 0 32px}
.comment-list .children{list-style:none;padding-left:24px;margin-top:16px}
.comment-body{
    padding:22px;
    background:var(--c-surface);
    border-radius:var(--r-md);
    margin-bottom:16px;
    box-shadow:var(--c-shadow-sm);
}
.comment-author{display:flex;gap:12px;align-items:center;margin-bottom:10px}
.comment-author cite{
    font-style:normal;
    font-weight:600;
    color:var(--c-text);
}
.comment-author img{
    width:40px;height:40px;border-radius:50%;
}
.comment-meta{
    font-size:.78rem;
    color:var(--c-muted);
    margin-bottom:12px;
}
.comment-content{font-size:.95rem;line-height:1.65}
.reply{margin-top:8px}
.reply a{
    font-size:.8rem;font-weight:600;
    color:var(--c-primary);
}

.comment-form label{
    display:block;
    font-size:.82rem;
    font-weight:600;
    margin-bottom:6px;
    color:var(--c-text-soft);
    letter-spacing:.02em;
}
.comment-form input[type=text],
.comment-form input[type=email],
.comment-form input[type=url],
.comment-form textarea,
.search-field{
    width:100%;
    padding:12px 14px;
    border:1px solid var(--c-border);
    border-radius:var(--r-sm);
    background:var(--c-surface);
    font-family:inherit;
    font-size:.95rem;
    color:var(--c-text);
    margin-bottom:16px;
    transition:all var(--t-fast);
}
.comment-form input:focus,
.comment-form textarea:focus,
.search-field:focus{
    outline:none;
    border-color:var(--c-primary);
    box-shadow:0 0 0 3px var(--c-primary-soft);
}
.comment-form .submit,
.search-submit,
button[type=submit],
.button{
    background:var(--c-primary);
    color:var(--c-surface);
    border:0;
    padding:12px 24px;
    border-radius:var(--r-sm);
    font-weight:600;
    font-size:.92rem;
    cursor:pointer;
    font-family:inherit;
    letter-spacing:.02em;
    transition:all var(--t-fast);
}
.comment-form .submit:hover,
.search-submit:hover,
button[type=submit]:hover,
.button:hover{
    background:var(--c-primary-dark);
    transform:translateY(-1px);
}

/* =========================================================
   11. SIDEBAR & WIDGETS
========================================================= */
.sidebar{position:sticky;top:92px}
.widget{
    background:var(--c-surface);
    padding:24px;
    border-radius:var(--r-md);
    box-shadow:var(--c-shadow-sm);
    margin-bottom:24px;
}
.widget-title{
    font-size:.78rem;
    font-weight:700;
    letter-spacing:.14em;
    text-transform:uppercase;
    color:var(--c-text);
    margin:0 0 18px;
    padding-bottom:12px;
    border-bottom:2px solid var(--c-accent);
    display:inline-block;
    font-family:var(--f-body);
}
.widget ul{list-style:none;margin:0;padding:0}
.widget li{
    padding:10px 0;
    border-bottom:1px solid var(--c-line);
    font-size:.92rem;
    color:var(--c-text-soft);
}
.widget li:last-child{border-bottom:0}
.widget li a{color:var(--c-text-soft)}
.widget li a:hover{color:var(--c-primary)}

.widget_search .search-form{display:flex;gap:6px;align-items:stretch}
.widget_search .search-field{margin:0;flex:1}
.widget_search .search-submit{flex-shrink:0}

/* =========================================================
   12. PAGINATION
========================================================= */
.pagination{
    display:flex;
    justify-content:center;
    gap:8px;
    margin:48px 0 0;
    flex-wrap:wrap;
}
.pagination .page-numbers{
    display:inline-flex;align-items:center;justify-content:center;
    min-width:44px;height:44px;padding:0 14px;
    background:var(--c-surface);
    border:1px solid var(--c-border);
    border-radius:var(--r-sm);
    color:var(--c-text);
    font-weight:600;font-size:.9rem;
    transition:all var(--t-fast);
}
.pagination .page-numbers:hover,
.pagination .page-numbers.current{
    background:var(--c-primary);
    color:var(--c-surface);
    border-color:var(--c-primary);
}

/* =========================================================
   13. FOOTER
========================================================= */
.site-footer{
    background:var(--c-primary-dark);
    color:#c9d6cb;
    padding:56px 0 28px;
    margin-top:80px;
}
.footer-inner{
    display:grid;
    grid-template-columns:1.5fr 1fr 1fr 1fr;
    gap:48px;
    margin-bottom:40px;
}
.footer-branding .site-title a{color:#fff}
.footer-branding .site-title a::after{color:var(--c-accent)}
.footer-branding p{
    color:#a8baad;
    font-size:.92rem;
    margin-top:14px;
    max-width:340px;
    line-height:1.7;
}
.footer-widget h4{
    color:#fff;
    font-family:var(--f-body);
    font-size:.78rem;
    font-weight:700;
    letter-spacing:.14em;
    text-transform:uppercase;
    margin:0 0 18px;
    padding-bottom:12px;
    border-bottom:2px solid var(--c-accent);
    display:inline-block;
}
.footer-widget ul{list-style:none;margin:0;padding:0}
.footer-widget li{margin-bottom:10px}
.footer-widget a{
    color:#a8baad;
    font-size:.92rem;
    transition:color var(--t-fast);
}
.footer-widget a:hover{color:var(--c-accent)}
.site-info{
    text-align:center;
    padding-top:28px;
    border-top:1px solid rgba(255,255,255,.08);
    color:#85968a;
    font-size:.85rem;
}
.site-info a{color:#c9d6cb}
.site-info a:hover{color:var(--c-accent)}

/* =========================================================
   14. FLOATING BACK-TO-TOP
========================================================= */
.back-to-top{
    position:fixed;
    bottom:24px;right:24px;
    width:48px;height:48px;
    border-radius:50%;
    background:var(--c-primary);
    color:var(--c-surface);
    border:0;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    box-shadow:var(--c-shadow-lg);
    z-index:90;
    opacity:0;visibility:hidden;
    transform:translateY(20px);
    transition:all var(--t-base);
}
.back-to-top.is-visible{
    opacity:1;visibility:visible;transform:translateY(0);
}
.back-to-top:hover{
    background:var(--c-accent);
    transform:translateY(-3px);
}

/* =========================================================
   15. UTILITIES
========================================================= */
.screen-reader-text{
    border:0;clip:rect(1px,1px,1px,1px);
    clip-path:inset(50%);height:1px;width:1px;
    overflow:hidden;position:absolute!important;
    word-wrap:normal!important;
}
.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;clear:both}
.alignwide{margin-left:-60px;margin-right:-60px;max-width:none;width:auto}
.alignfull{
    margin-left:calc(-50vw + 50%);
    margin-right:calc(-50vw + 50%);
    max-width:100vw;width:100vw;
}

/* =========================================================
   16. ANIMATIONS
========================================================= */
@keyframes fadeUp{
    from{opacity:0;transform:translateY(16px)}
    to{opacity:1;transform:translateY(0)}
}
.post-card,.entry-header,.widget,.hero-post{
    animation:fadeUp .5s ease-out both;
}
.posts-grid .post-card:nth-child(1){animation-delay:.04s}
.posts-grid .post-card:nth-child(2){animation-delay:.08s}
.posts-grid .post-card:nth-child(3){animation-delay:.12s}
.posts-grid .post-card:nth-child(4){animation-delay:.16s}
.posts-grid .post-card:nth-child(5){animation-delay:.2s}
.posts-grid .post-card:nth-child(6){animation-delay:.24s}

/* =========================================================
   17. RESPONSIVE
========================================================= */
@media (max-width: 1024px){
    .content-wrap{grid-template-columns:1fr 280px;gap:40px}
    .footer-inner{grid-template-columns:1fr 1fr 1fr;gap:32px}
    .footer-branding{grid-column:1/-1}
}
@media (max-width: 880px){
    .content-wrap{grid-template-columns:1fr;gap:48px}
    .sidebar{position:static}
    .hero-post{grid-template-columns:1fr;gap:28px}
    .hero-post-body{padding:0}
}
@media (max-width: 768px){
    body{font-size:16px}
    .menu-toggle{display:inline-flex}
    .header-search-toggle{display:none}
    .main-navigation{
        position:fixed;
        top:0;left:0;right:0;bottom:0;
        background:var(--c-bg);
        padding:88px 24px 32px;
        z-index:99;
        transform:translateX(100%);
        transition:transform var(--t-base);
        overflow-y:auto;
        display:block;
    }
    .main-navigation.is-open{transform:translateX(0)}
    .main-navigation ul{
        flex-direction:column;
        align-items:stretch;
        gap:4px;
    }
    .main-navigation a{
        display:block;
        padding:14px 18px;
        font-size:1.05rem;
        border-bottom:1px solid var(--c-line);
        border-radius:0;
    }
    .main-navigation .current-menu-item > a::after,
    .main-navigation .current-cat > a::after{display:none}
    .main-navigation .sub-menu,
    .main-navigation .children{
        position:static;
        opacity:1;visibility:visible;
        transform:none;box-shadow:none;
        border:0;padding-left:18px;
        background:transparent;
    }
    .site-description{display:none}
    .footer-inner{
        grid-template-columns:1fr 1fr;
        gap:32px;
    }
    .footer-branding{grid-column:1/-1}
    .posts-grid{grid-template-columns:1fr;gap:32px}
    .post-card-image{margin-bottom:14px}
    .entry-thumbnail{
        margin:28px -24px 32px;
        border-radius:0;
    }
    .entry-content{font-size:1.06rem;line-height:1.8}
    .entry-content > p:first-of-type::first-letter{
        font-size:3.2em;padding:6px 10px 0 0;
    }
    .entry-content blockquote{
        margin:1.6em -8px;
        font-size:1.2em;
    }
    .author-bio{
        flex-direction:column;
        align-items:flex-start;
        padding:22px;
    }
    .post-navigation{grid-template-columns:1fr;gap:12px}
    .post-navigation .nav-next{text-align:left}
    .container{padding:0 20px}
    .site-main{padding:28px 0 48px}
    .hero-section{margin-bottom:36px;padding-bottom:36px}
    .back-to-top{
        width:44px;height:44px;
        bottom:18px;right:18px;
    }
}
@media (max-width: 480px){
    body{font-size:15.5px}
    .site-title{font-size:1.35rem}
    .entry-title{font-size:1.9rem}
    .entry-subtitle{font-size:1.05rem}
    .hero-post-title{font-size:1.7rem}
    .post-card-title{font-size:1.2rem}
    .entry-meta-row{gap:10px;font-size:.82rem}
    .entry-meta-row .meta-divider{display:none}
    .footer-inner{grid-template-columns:1fr}
    .widget{padding:20px}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
    *,*::before,*::after{
        animation-duration:.01ms!important;
        transition-duration:.01ms!important;
        scroll-behavior:auto!important;
    }
}
