/*
Theme Name: Dog Blog
Theme URI: https://example.com/dog-blog-theme
Author: Dog Toy Haven
Author URI: https://example.com
Description: A clean, responsive dog blog theme that’s AdSense-ready. Hamburger nav with dropdown submenus, grid posts, and sidebar widgets.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: dog-blog
Tags: blog, two-columns, responsive-layout, accessibility-ready, custom-menu, custom-logo
*/

:root {
  --bg: #0b0c0f;
  --card: #12141a;
  --muted: #717784;
  --text: #e8ecf2;
  --accent: #ffb703;
  --accent-2: #8ecae6;
  --ring: rgba(255, 183, 3, .35);
  --maxw: 1350px;
  --radius: 16px;
}

@media (prefers-color-scheme: light) {
  :root { --bg:#f7fafc; --card:#ffffff; --text:#1b2430; --muted:#6b7280; }
}

* { box-sizing: border-box; }
html, body { height:100%; }
body {
  margin:0; font-family: system-ui,-apple-system,Segoe UI, Roboto, Inter, Ubuntu, Cantarell, Noto Sans, Arial, "Apple Color Emoji","Segoe UI Emoji";
  background:var(--bg); color:var(--text); line-height:1.6;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; border-radius: calc(var(--radius) - 6px); }

.container { width: min(100%, var(--maxw)); margin-inline: auto; padding: 18px; }

/* Header / Nav */
header.site-header {
  position: sticky; top: 0; z-index: 50; backdrop-filter: saturate(140%) blur(8px);
  background: color-mix(in oklab, var(--bg) 88%, #0000);
  border-bottom: 1px solid color-mix(in oklab, var(--text) 12%, transparent);
  overflow: visible; /* ensure dropdowns aren’t clipped */
}
.nav { display:flex; align-items:center; justify-content:space-between; gap:14px; overflow:visible; }
.brand { display:flex; align-items:center; gap:10px; font-weight:800; letter-spacing:.2px; }
.brand .logo { display:grid; place-items:center; width:38px; height:38px; border-radius:10px; background:linear-gradient(135deg, var(--accent), var(--accent-2)); box-shadow:0 8px 24px -6px var(--ring); }
.brand span { font-size: clamp(1rem, 2.2vw, 1.25rem); }

.primary-nav { display:flex; align-items:center; gap: 14px; margin-left:auto; overflow:visible; }
.primary-nav .menu { list-style:none; display:flex; gap:18px; align-items:center; margin:0; padding:0; }
.primary-nav .menu > li { position: relative; }
.primary-nav .menu a, .primary-nav .submenu-toggle { opacity:.95; font-weight:700; background:none; border:none; color:inherit; cursor:pointer; padding:8px 6px; border-radius:10px; }
.primary-nav .menu a:hover, .primary-nav .submenu-toggle:hover { opacity:1; text-decoration: underline; text-underline-offset:4px; }

/* ===== Desktop Submenu (no flicker) ===== */
.menu > li { position: relative; }

/* Hover bridge so pointer can cross the gap to dropdown */
.menu > li.menu-item-has-children::after,
.menu > li.has-submenu::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  top: 100%;
  height: 10px; /* increase if you still feel a gap */
}

/* Base dropdown panel */
.submenu, .sub-menu {
  list-style:none; position:absolute; left:0; top:100%;
  margin-top: 8px; /* visual gap; bridge covers it */
  min-width:220px; background:var(--card);
  border:1px solid color-mix(in oklab, var(--text) 12%, transparent);
  border-radius:12px; padding:8px;
  box-shadow:0 20px 50px -20px rgb(0 0 0 / .45);
  z-index: 9999;

  /* keep in flow to avoid hover loss; hide via visibility */
  display:block;
  opacity:0; visibility:hidden; transform: translateY(6px);
  transition: opacity .15s ease, transform .15s ease, visibility 0s linear .15s;
}
.submenu li, .sub-menu li { margin:0; }
.submenu a, .sub-menu a { display:block; padding:10px 12px; border-radius:10px; color:var(--text); white-space:nowrap; }
.submenu a:hover, .sub-menu a:hover { background: color-mix(in oklab, var(--text) 8%, transparent); text-decoration:none; }

@media (min-width: 841px) {
  .has-submenu:hover > .submenu,
  .has-submenu:focus-within > .submenu,
  .menu > li:hover > .sub-menu,
  .menu > li:focus-within > .sub-menu,
  .menu > li.open > .sub-menu { /* optional JS click-to-open support */
    opacity:1; visibility:visible; transform: translateY(0);
    transition-delay: 0s, 0s, 0s;
  }
}

/* Mobile nav */
.mobile-toggle { display:none; align-items:center; justify-content:center; background:var(--card); border:1px solid color-mix(in oklab, var(--text) 12%, transparent); padding:8px 10px; border-radius:10px; cursor:pointer; }
.hamburger { display:inline-grid; gap:4px; }
.hamburger span { width:22px; height:2px; background: currentColor; border-radius: 2px; transition: transform .2s ease, opacity .2s ease; }
.mobile-toggle.active .hamburger span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.mobile-toggle.active .hamburger span:nth-child(2) { opacity:0; }
.mobile-toggle.active .hamburger span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

@media (max-width: 840px) {
  .mobile-toggle { display:inline-flex; }
  .primary-nav { margin-left:0; }
  .primary-nav .menu {
    display:none; position:absolute; top:64px; left:0; right:0; background:var(--card);
    border-bottom:1px solid color-mix(in oklab, var(--text) 12%, transparent);
    padding:12px 18px 16px; flex-direction:column; gap:8px;
  }
  .primary-nav .menu.open { display:flex; }
  .primary-nav .menu > li { width:100%; }
  .primary-nav .menu a, .primary-nav .submenu-toggle {
    width:100%; text-align:left; padding:12px 10px;
    border:1px solid color-mix(in oklab, var(--text) 12%, transparent); border-radius:12px; background:transparent;
  }
  /* Mobile accordion for submenus */
  .has-submenu .submenu, .menu .sub-menu {
    position:static; margin-top:8px; padding:0;
    border:none; box-shadow:none; overflow:hidden;
    max-height:0; transition:max-height .25s ease;
    opacity:1; visibility:visible; transform:none; /* always visible in flow; height controls display */
  }
  .has-submenu.open-submenu .submenu, .menu .open-submenu > .sub-menu { max-height: 500px; }
  .submenu a, .sub-menu a { padding:10px 12px; border:1px solid color-mix(in oklab, var(--text) 10%, transparent); margin-top:8px; border-radius:12px; }
}

/* Layout */
.hero { margin: 28px 0 18px; display:grid; grid-template-columns: 1.2fr .8fr; gap: 22px; align-items: stretch; }
.hero-card { background: var(--card); border:1px solid color-mix(in oklab, var(--text) 12%, transparent); border-radius: var(--radius); overflow: clip; display:grid; grid-template-rows: auto 1fr; }
.hero-content { padding: 18px; }
.badge { display:inline-flex; align-items:center; gap:8px; background: color-mix(in oklab, var(--accent) 15%, var(--card)); border:1px solid color-mix(in oklab, var(--accent) 35%, transparent); color: #2a2a2a; font-weight: 700; padding:6px 10px; border-radius: 999px; font-size:.8rem; }
.badge .dot { width:8px; height:8px; border-radius:999px; background: var(--accent); box-shadow:0 0 0 8px color-mix(in oklab, var(--ring) 30%, transparent) inset; }
.hero-title { font-size: clamp(1.3rem, 4vw, 2rem); margin: 10px 0 8px; }
.hero p { color: var(--muted); margin: 0 0 12px; }
.hero-actions { display:flex; flex-wrap:wrap; gap: 10px; }
.btn { display:inline-flex; align-items:center; gap:10px; padding:10px 14px; border-radius: 12px; font-weight: 700; border:1px solid transparent; cursor:pointer; }
.btn.primary { background: linear-gradient(135deg, var(--accent), #ffd166); color:#1b1b1b; box-shadow:0 10px 30px -12px var(--ring); }
.btn.ghost { background:transparent; border-color: color-mix(in oklab, var(--text) 14%, transparent); color: var(--text); }

@media (max-width: 920px) { .hero { grid-template-columns: 1fr; } }

.layout { display:grid; grid-template-columns: 1fr 320px; gap: 22px; }
@media (max-width: 1100px) { .layout { grid-template-columns: 1fr 300px; } }
@media (max-width: 900px) { .layout { grid-template-columns: 1fr; } }

.grid { display:grid; grid-template-columns: repeat(12, 1fr); gap: 18px; }
.post-card { grid-column: span 6; background: var(--card); border:1px solid color-mix(in oklab, var(--text) 12%, transparent); border-radius: var(--radius); overflow: clip; display:grid; grid-template-rows: auto 1fr; transition: transform .18s ease, box-shadow .18s ease; }
.post-card:hover { transform: translateY(-2px); box-shadow: 0 16px 40px -24px black; }
.post-card .content { padding: 14px 16px 18px; }
.post-card .meta { display:flex; gap:12px; align-items:center; font-size: .85rem; color: var(--muted); }
.post-card h3 { margin: 8px 0 6px; font-size: 1.05rem; }
.post-card p { margin: 0; color: var(--muted); }
.chip { display:inline-flex; align-items:center; gap:8px; font-size:.75rem; padding:6px 10px; border-radius:999px; background: color-mix(in oklab, var(--accent-2) 14%, var(--card)); border:1px solid color-mix(in oklab, var(--accent-2) 38%, transparent); color:#0b1a22; font-weight:700; }
@media (max-width: 740px) { .post-card { grid-column: span 12; } }

/* Sidebar */
.sidebar .widget, .sidebar .card { background:var(--card); border:1px solid color-mix(in oklab, var(--text) 12%, transparent); border-radius: var(--radius); padding: 16px; margin-bottom: 16px; }
.newsletter input { width:100%; padding:12px 14px; border-radius: 12px; border:1px solid color-mix(in oklab, var(--text) 14%, transparent); background: transparent; color: var(--text); }
.newsletter button { margin-top:10px; }

/* Footer */
footer.site-footer { margin-top: 32px; border-top:1px solid color-mix(in oklab, var(--text) 12%, transparent); }
.foot { display:flex; flex-wrap:wrap; gap:14px; align-items:center; justify-content:space-between; padding: 18px 0; color: var(--muted); font-size:.95rem; }

.sr-only { position: absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* Basic WP content styles */
.entry-content p { color: var(--muted); }
.entry-title a { text-decoration: none; }
.wp-post-image { width: 100%; height: auto; display:block; border-radius: calc(var(--radius) - 6px); }

/* Ad wrappers (optional, for spacing & placeholders) */
.ad-frame {
  background: var(--card);
  border: 1px dashed rgba(255,255,255,.18);
  border-radius: 12px;
  padding: 10px;
}
.ad-placeholder {
  text-align: center;
  color: var(--muted);
  font-size: .95rem;
  padding: 16px;
}

/* Contact page inputs reuse comment styles */
.contact-card .contact-input {
  width: 100%;
  background: transparent;
  color: var(--text);
  border: 1px solid color-mix(in oklab, var(--text) 16%, transparent);
  border-radius: 12px;
  padding: 12px 14px;
  outline: none;
  transition: box-shadow .18s ease, border-color .18s ease;
}
.contact-card .contact-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--accent) 30%, transparent);
}
