/*
Theme Name:   DIY Joy Child
Theme URI:    https://diyjoy.com
Description:  A GeneratePress child theme styled after DIY Joy — crafts, recipes, home decor & gifts.
Author:       DIY Joy
Author URI:   https://diyjoy.com
Template:     generatepress
Version:      2.0.0
Text Domain:  diyjoy-child
*/

@import url("../generatepress/style.css");
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap');

/* === VARIABLES === */
:root {
  --diy-red:#e8534a; --diy-red-dark:#c03d35; --diy-red-light:#fdf3f2;
  --diy-red-border:#f7d0cc; --diy-text:#1a1a1a; --diy-muted:#6b6b6b;
  --diy-border:#e8e8e4; --diy-bg:#fafaf8; --diy-white:#ffffff;
  --diy-surface:#f5f4f0; --diy-radius:10px; --diy-radius-lg:16px;
  --font-display:'Playfair Display',Georgia,serif;
  --font-body:'DM Sans',sans-serif;
}

/* === BASE === */
*,*::before,*::after{box-sizing:border-box}
body{font-family:var(--font-body)!important;font-size:16px;line-height:1.75;color:var(--diy-text);background:var(--diy-bg)!important;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display)!important;font-weight:500!important;line-height:1.3!important;color:var(--diy-text)!important}
a{color:var(--diy-red);text-decoration:none}
a:hover{color:var(--diy-red-dark)}
img{max-width:100%;height:auto;display:block}

/* === FORCE FULL WIDTH CONTAINER (fixes narrow content bug) === */
.grid-container,.grid-container.grid-parent,.site-content .inside-site-content{max-width:1120px!important;width:100%!important;padding-left:24px!important;padding-right:24px!important}
.site-main{width:100%!important}
.inside-article,.entry-header,.entry-content{padding:0!important;max-width:100%!important}
.entry-content>*{max-width:100%!important}
.site-content{padding-top:32px!important;padding-bottom:60px!important}

/* === CONTENT + SIDEBAR LAYOUT === */
.content-sidebar-wrap{display:flex!important;gap:32px!important;align-items:flex-start!important}
.content-area{flex:1!important;min-width:0!important;width:auto!important}
.widget-area{width:300px!important;flex-shrink:0!important}
@media(min-width:769px){
  .right-sidebar .content-area{width:auto!important}
  .right-sidebar .widget-area{width:300px!important}
}
.blog .content-area,.archive .content-area,.search .content-area,.home .content-area{width:100%!important;max-width:100%!important}

/* === TOP BAR === */
.diy-topbar{background:var(--diy-red);color:#fff;text-align:center;font-family:var(--font-body)!important;font-size:12px;font-weight:500;letter-spacing:.04em;padding:8px 20px;width:100%}
.diy-topbar a{color:#fff;text-decoration:underline}

/* === HEADER === */
.site-header{background:var(--diy-white)!important;border-bottom:1px solid var(--diy-border)!important;box-shadow:0 1px 0 rgba(0,0,0,.04)!important;padding:0!important}
.site-header .inside-header{max-width:1120px!important;margin:0 auto!important;padding:0 24px!important;display:flex!important;align-items:center!important;min-height:64px!important}
.site-branding .site-title,.site-title{font-family:var(--font-display)!important;font-size:26px!important;font-weight:600!important;letter-spacing:-.5px!important;margin:0!important;line-height:1!important}
.site-title a,.site-title a:hover{color:var(--diy-text)!important}
.site-title a span{color:var(--diy-red)!important}
.site-description{display:none!important}
.main-navigation .menu-item a,.main-navigation ul li a{font-family:var(--font-body)!important;font-size:13.5px!important;font-weight:500!important;color:var(--diy-muted)!important;padding:6px 10px!important;border-radius:6px!important;transition:color .15s,background .15s!important}
.main-navigation .menu-item a:hover,.main-navigation ul li a:hover,.main-navigation .current-menu-item>a,.main-navigation .current_page_item>a{color:var(--diy-red)!important;background:var(--diy-red-light)!important}
.main-navigation .sub-menu,.main-navigation ul ul{background:var(--diy-white)!important;border:1px solid var(--diy-border)!important;border-radius:var(--diy-radius)!important;box-shadow:0 8px 24px rgba(0,0,0,.08)!important;padding:6px!important}

/* === SECTION HEADERS === */
.diy-section-header{display:flex;align-items:baseline;justify-content:space-between;margin:36px 0 18px;padding-bottom:12px;border-bottom:2px solid var(--diy-border)}
.diy-section-header h2{font-size:22px!important;font-weight:500!important;margin:0!important}
.diy-section-header .see-all{font-family:var(--font-body)!important;font-size:12px;font-weight:600;color:var(--diy-red);text-transform:uppercase;letter-spacing:.06em}

/* === POST CARDS === */
.diy-post-grid{display:grid;gap:18px;width:100%}
.diy-post-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.diy-post-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.diy-post-grid.cols-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:1024px){.diy-post-grid.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.diy-post-grid.cols-4,.diy-post-grid.cols-3{grid-template-columns:1fr}}

.diy-post-card{background:var(--diy-white);border-radius:var(--diy-radius-lg);border:1px solid var(--diy-border);overflow:hidden;transition:box-shadow .2s,transform .2s}
.diy-post-card:hover{box-shadow:0 8px 28px rgba(0,0,0,.08);transform:translateY(-2px)}
.diy-post-card .card-thumb{aspect-ratio:3/2;overflow:hidden;display:block}
.diy-post-card .card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.diy-post-card:hover .card-thumb img{transform:scale(1.04)}
.diy-post-card .card-body{padding:12px 14px 14px}
.diy-post-card .card-tag{font-size:10px!important;font-weight:600!important;color:var(--diy-red)!important;text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px;display:block}
.diy-post-card .card-tag a{color:var(--diy-red)!important}
.diy-post-card .card-title{font-family:var(--font-display)!important;font-size:14px!important;font-weight:500!important;line-height:1.4!important;color:var(--diy-text)!important}
.diy-post-card .card-title a{color:var(--diy-text)!important}
.diy-post-card .card-title a:hover{color:var(--diy-red)!important}
.diy-post-card .card-excerpt{font-size:12px;color:var(--diy-muted);line-height:1.6;margin-top:5px}

/* === HERO GRID === */
.diy-hero-grid{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-bottom:4px}
@media(max-width:768px){.diy-hero-grid{grid-template-columns:1fr}}
.diy-hero-card{background:var(--diy-white);border-radius:var(--diy-radius-lg);border:1px solid var(--diy-border);overflow:hidden;transition:box-shadow .2s}
.diy-hero-card:hover{box-shadow:0 10px 32px rgba(0,0,0,.09)}
.diy-hero-card .card-thumb{aspect-ratio:16/9;overflow:hidden;display:block}
.diy-hero-card .card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.diy-hero-card:hover .card-thumb img{transform:scale(1.03)}
.diy-hero-card .card-body{padding:18px 20px 20px}
.diy-hero-card .card-tag{font-size:10px!important;font-weight:600!important;color:var(--diy-red)!important;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;display:block}
.diy-hero-card .card-tag a{color:var(--diy-red)!important}
.diy-hero-card .card-title{font-family:var(--font-display)!important;font-size:20px!important;font-weight:500!important;line-height:1.3!important;color:var(--diy-text)!important;margin-bottom:8px}
.diy-hero-card .card-title a{color:var(--diy-text)!important}
.diy-hero-card .card-excerpt{font-size:13.5px;color:var(--diy-muted);line-height:1.65}
.diy-side-stack{display:flex;flex-direction:column;gap:14px}
.diy-side-card{background:var(--diy-white);border-radius:var(--diy-radius);border:1px solid var(--diy-border);overflow:hidden;display:flex;transition:box-shadow .2s}
.diy-side-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.07)}
.diy-side-card .card-thumb{width:96px;flex-shrink:0;display:block}
.diy-side-card .card-thumb img{width:100%;height:100%;object-fit:cover}
.diy-side-card .card-body{padding:10px 12px;display:flex;flex-direction:column;justify-content:center}
.diy-side-card .card-tag{font-size:9px!important;font-weight:600!important;color:var(--diy-red)!important;text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}
.diy-side-card .card-title{font-family:var(--font-display)!important;font-size:12.5px!important;line-height:1.4!important;color:var(--diy-text)!important}
.diy-side-card .card-title a{color:var(--diy-text)!important}

/* === CATEGORY CIRCLES === */
.diy-cat-circles{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin:24px 0}
@media(max-width:768px){.diy-cat-circles{grid-template-columns:repeat(3,1fr)}}
.diy-cat-item{text-align:center}
.diy-cat-item a{display:block;color:var(--diy-text);text-decoration:none}
.diy-cat-item a:hover .diy-cat-thumb{transform:scale(1.05);border-color:var(--diy-red)}
.diy-cat-thumb{width:100%;aspect-ratio:1;border-radius:50%;overflow:hidden;border:2px solid var(--diy-border);margin:0 auto 8px;transition:transform .2s,border-color .2s;background:var(--diy-surface)}
.diy-cat-thumb img{width:100%;height:100%;object-fit:cover}
.diy-cat-item span{font-size:12px!important;font-weight:500!important;color:var(--diy-muted)}

/* === NEWSLETTER === */
.diy-newsletter{background:var(--diy-red-light);border:1px solid var(--diy-red-border);border-radius:var(--diy-radius-lg);padding:36px 32px;text-align:center;margin:36px 0}
.diy-newsletter .nl-icon{font-size:32px;margin-bottom:10px}
.diy-newsletter h3{font-size:20px!important;font-weight:500!important;margin-bottom:6px!important}
.diy-newsletter p{font-size:13.5px;color:var(--diy-muted);margin-bottom:18px}
.diy-newsletter .nl-form{display:flex;gap:8px;max-width:400px;margin:0 auto}
.diy-newsletter .nl-form input[type="email"]{flex:1;padding:10px 14px;border:1px solid var(--diy-red-border);border-radius:8px;font-family:var(--font-body)!important;font-size:13px;background:var(--diy-white);color:var(--diy-text);outline:none}
.diy-newsletter .nl-form input[type="email"]:focus{border-color:var(--diy-red)}
.diy-newsletter .nl-form button{padding:10px 20px;background:var(--diy-red);color:#fff;border:none;border-radius:8px;font-family:var(--font-body)!important;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap}
.diy-newsletter .nl-form button:hover{background:var(--diy-red-dark)}
@media(max-width:480px){.diy-newsletter .nl-form{flex-direction:column}}

/* === SINGLE POST === */
.diy-breadcrumb{font-size:11.5px;color:var(--diy-muted);margin-bottom:14px;font-family:var(--font-body)!important}
.diy-breadcrumb a{color:var(--diy-red)!important}
.diy-breadcrumb .sep{margin:0 5px;opacity:.5}

.single .entry-title,.single h1.entry-title{font-family:var(--font-display)!important;font-size:32px!important;font-weight:500!important;line-height:1.25!important;margin-bottom:14px!important;color:var(--diy-text)!important}

.diy-post-meta{display:flex;align-items:center;gap:12px;padding:12px 0 16px;border-bottom:1px solid var(--diy-border);margin-bottom:20px;flex-wrap:wrap}
.diy-author-avatar{width:38px;height:38px;border-radius:50%;overflow:hidden;flex-shrink:0}
.diy-author-avatar img{width:100%;height:100%;object-fit:cover}
.diy-post-meta-text{font-size:13px!important;color:var(--diy-muted)}
.diy-post-meta-text strong{color:var(--diy-text);font-weight:500}
.diy-post-meta-text a{color:var(--diy-text)!important}
.diy-post-tag{margin-left:auto;background:var(--diy-red-light);color:var(--diy-red-dark)!important;font-size:10px!important;font-weight:600!important;padding:4px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.06em}

.single .post-thumbnail,.single .featured-image{border-radius:var(--diy-radius-lg);overflow:hidden;margin-bottom:22px}
.single .post-thumbnail img{width:100%;height:auto}

.diy-save-box{background:var(--diy-surface);border-radius:var(--diy-radius);padding:14px 16px;display:flex;align-items:center;gap:12px;margin-bottom:22px;flex-wrap:wrap}
.diy-save-box .save-icon{width:36px;height:36px;background:var(--diy-red);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-size:16px}
.diy-save-box p{font-size:13px!important;color:var(--diy-muted);flex:1;margin:0!important}
.diy-save-box .nl-form{display:flex;gap:6px}
.diy-save-box input[type="email"]{padding:7px 12px;border:1px solid var(--diy-border);border-radius:7px;font-size:12px;font-family:var(--font-body)!important;width:180px;background:var(--diy-white)}
.diy-save-box button{padding:7px 14px;background:var(--diy-red);color:#fff;border:none;border-radius:7px;font-size:12px;font-family:var(--font-body)!important;font-weight:600;cursor:pointer}

.entry-content{font-size:15px!important;line-height:1.8!important;color:var(--diy-text)!important}
.entry-content h2{font-size:22px!important;margin:32px 0 14px!important;padding-bottom:10px;border-bottom:1px solid var(--diy-border)}
.entry-content h3{font-size:17px!important;margin:22px 0 8px!important}
.entry-content p{margin-bottom:14px!important}
.entry-content ul,.entry-content ol{padding-left:22px;margin-bottom:14px}
.entry-content li{margin-bottom:6px}
.entry-content a{color:var(--diy-red)!important}
.entry-content figure{margin:20px 0;border-radius:var(--diy-radius);overflow:hidden}
.entry-content figure img{border-radius:var(--diy-radius);width:100%}
.entry-content figcaption{font-size:12px;color:var(--diy-muted);text-align:center;margin-top:6px}

.diy-toc{border:1px solid var(--diy-border);border-radius:var(--diy-radius-lg);padding:18px 20px;margin:24px 0;background:var(--diy-white)}
.diy-toc h4{font-size:14px!important;font-weight:500!important;margin-bottom:12px!important}
.diy-toc ol{padding-left:18px;margin:0}
.diy-toc li{font-size:13px;margin-bottom:6px}
.diy-toc li a{color:var(--diy-red)!important}

.diy-supplies{background:var(--diy-surface);border-radius:var(--diy-radius-lg);padding:18px 20px;margin:24px 0}
.diy-supplies h4{font-size:14px!important;font-weight:500!important;margin-bottom:12px!important}
.diy-supplies-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 24px}
.diy-supply-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--diy-muted)}
.diy-supply-item::before{content:'';width:7px;height:7px;background:var(--diy-red);border-radius:50%;flex-shrink:0}

.diy-tips-box{border-left:4px solid var(--diy-red);background:var(--diy-red-light);border-radius:0 var(--diy-radius) var(--diy-radius) 0;padding:14px 18px;margin:22px 0}
.diy-tips-box h4{font-size:14px!important;font-weight:500!important;color:var(--diy-red-dark)!important;margin-bottom:8px!important}
.diy-tips-box ul{padding-left:18px;margin:0}
.diy-tips-box li{font-size:13px;color:var(--diy-muted);margin-bottom:4px}

.diy-share-bar{display:flex;align-items:center;gap:8px;padding:16px 0;border-top:1px solid var(--diy-border);border-bottom:1px solid var(--diy-border);margin:28px 0;flex-wrap:wrap}
.diy-share-bar .share-label{font-size:12px!important;font-weight:600!important;text-transform:uppercase;letter-spacing:.06em;color:var(--diy-muted);margin-right:4px}
.diy-share-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:7px;font-family:var(--font-body)!important;font-size:12px!important;font-weight:600!important;cursor:pointer;border:none;transition:opacity .15s;color:#fff!important;text-decoration:none!important}
.diy-share-btn:hover{opacity:.88;color:#fff!important}
.diy-share-btn.pin{background:#e60023}
.diy-share-btn.fb{background:#1877F2}
.diy-share-btn.tw{background:#1DA1F2}
.diy-share-btn.email{background:#6b6b6b}

.diy-author-box{background:var(--diy-surface);border-radius:var(--diy-radius-lg);padding:20px;display:flex;gap:16px;align-items:flex-start;margin:28px 0}
.diy-author-box .author-photo{width:60px;height:60px;border-radius:50%;overflow:hidden;flex-shrink:0}
.diy-author-box .author-photo img{width:100%;height:100%;object-fit:cover}
.diy-author-box h4{font-size:15px!important;font-weight:500!important;margin-bottom:4px!important}
.diy-author-box p{font-size:13px!important;color:var(--diy-muted);line-height:1.65;margin:0!important}
.diy-author-box .author-link{display:inline-block;margin-top:8px;font-size:12px!important;font-weight:600!important;color:var(--diy-red)!important}

.diy-related{margin:32px 0}
.diy-related h2{font-size:20px!important;margin-bottom:16px!important}

/* === SIDEBAR WIDGETS === */
.widget-area .widget{background:var(--diy-white);border:1px solid var(--diy-border);border-radius:var(--diy-radius-lg);padding:18px 20px;margin-bottom:20px}
.widget-area .widget-title{font-family:var(--font-display)!important;font-size:15px!important;font-weight:500!important;margin-bottom:14px!important;padding-bottom:10px;border-bottom:1px solid var(--diy-border);color:var(--diy-text)!important}
.widget_recent_entries ul{list-style:none;padding:0;margin:0}
.widget_recent_entries ul li{padding:8px 0;border-bottom:1px solid var(--diy-border);font-size:13px!important}
.widget_recent_entries ul li:last-child{border:none}
.widget_recent_entries ul li a{color:var(--diy-text)!important;font-weight:500;line-height:1.4}
.widget_recent_entries ul li a:hover{color:var(--diy-red)!important}
.post-date{font-size:11px!important;color:var(--diy-muted);display:block;margin-top:2px}
.widget_categories ul{list-style:none!important;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:6px}
.widget_categories ul li{list-style:none!important}
.widget_categories ul li a{display:inline-block;padding:5px 12px;background:var(--diy-surface);border:1px solid var(--diy-border);border-radius:20px;font-size:12px!important;font-weight:500!important;color:var(--diy-muted)!important;transition:background .15s,color .15s,border-color .15s}
.widget_categories ul li a:hover{background:var(--diy-red-light)!important;color:var(--diy-red)!important;border-color:var(--diy-red-border)!important}
.widget_search .search-form{display:flex;gap:6px}
.widget_search input[type="search"]{flex:1;padding:8px 12px;border:1px solid var(--diy-border);border-radius:7px;font-size:13px;font-family:var(--font-body)!important;background:var(--diy-bg);outline:none}
.widget_search input[type="search"]:focus{border-color:var(--diy-red)}
.widget_search input[type="submit"]{padding:8px 14px;background:var(--diy-red);color:#fff;border:none;border-radius:7px;font-size:13px;font-family:var(--font-body)!important;font-weight:600;cursor:pointer}
.widget.diy-nl-widget{background:var(--diy-red-light)!important;border-color:var(--diy-red-border)!important}
.widget.diy-nl-widget .widget-title{color:var(--diy-red-dark)!important;border-color:var(--diy-red-border)!important}
.widget.diy-nl-widget p{font-size:12px!important;color:var(--diy-muted);line-height:1.6;margin-bottom:10px!important}
.widget.diy-nl-widget input[type="email"]{width:100%;padding:8px 12px;border:1px solid var(--diy-red-border);border-radius:7px;font-family:var(--font-body)!important;font-size:13px;margin-bottom:8px;background:var(--diy-white);display:block}
.widget.diy-nl-widget button{width:100%;padding:9px;background:var(--diy-red);color:#fff;border:none;border-radius:7px;font-family:var(--font-body)!important;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}
.widget.diy-nl-widget button:hover{background:var(--diy-red-dark)}

/* === FOOTER === */
.site-footer{background:var(--diy-white)!important;border-top:1px solid var(--diy-border)!important;margin-top:40px;padding:32px 0 0!important}
.site-info{display:none!important}
.diy-footer-wrap{max-width:1120px;margin:0 auto;padding:0 24px 24px}
.diy-footer-top{display:flex;justify-content:space-between;align-items:flex-start;gap:32px;flex-wrap:wrap;padding-bottom:24px;border-bottom:1px solid var(--diy-border);margin-bottom:20px}
.diy-footer-logo{font-family:var(--font-display)!important;font-size:22px;font-weight:600;color:var(--diy-text)}
.diy-footer-logo span{color:var(--diy-red)}
.diy-footer-desc{font-size:13px!important;color:var(--diy-muted);margin-top:6px;max-width:260px;line-height:1.65}
.diy-footer-nav{display:flex;gap:20px;flex-wrap:wrap;align-items:center}
.diy-footer-nav a{font-size:13px!important;color:var(--diy-muted)!important}
.diy-footer-nav a:hover{color:var(--diy-red)!important}
.diy-footer-copy{font-size:12px!important;color:var(--diy-muted);text-align:center;padding-top:16px;border-top:1px solid var(--diy-border)}
.diy-footer-copy a{color:var(--diy-red)!important}

/* === PAGINATION === */
.pagination,.nav-links{display:flex;justify-content:center;gap:6px;margin:40px 0;flex-wrap:wrap}
.page-numbers{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--diy-border);border-radius:8px;font-size:13px!important;color:var(--diy-muted)!important;transition:background .15s,border-color .15s,color .15s;font-family:var(--font-body)!important}
.page-numbers:hover,.page-numbers.current{background:var(--diy-red)!important;border-color:var(--diy-red)!important;color:#fff!important}

/* === RESPONSIVE === */
@media(max-width:960px){.content-sidebar-wrap{flex-direction:column!important}.widget-area{width:100%!important}}
@media(max-width:768px){.site-content{padding:20px 16px 40px!important}.single .entry-title{font-size:24px!important}.diy-save-box{flex-direction:column}.grid-container{padding-left:16px!important;padding-right:16px!important}}
