/*
Theme Name: Titan Kennels Breeder Theme
Theme URI: https://titankennels.net
Author: Titan Kennels
Author URI: https://titankennels.net
Description: A purpose-built WordPress theme for professional dog breeders. Features custom post types for Dogs, Litters, and a full pedigree database system with auto-generated kennel IDs, recursive pedigree charts, and breeder-focused layouts.
Version: 2.0.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: titan-kennels
Tags: dark, breeder, kennel, pedigree, dogs, glassmorphism
*/

/* ============================================
   CORE RESET & VARIABLES
   ============================================ */
:root {
    --gold: #D4AF37;
    --gold-light: #e8c84a;
    --gold-dim: rgba(212,175,55,0.15);
    --gold-glow: rgba(212,175,55,0.3);
    --black: #060606;
    --dark: #0c0c0c;
    --dark-card: #0f0f0f;
    --surface: #141414;
    --border: rgba(255,255,255,0.06);
    --border-gold: rgba(212,175,55,0.2);
    --text: #b0b0b0;
    --text-light: #d4d4d4;
    --white: #ffffff;
    --glass-bg: rgba(15,15,15,0.6);
    --glass-border: rgba(255,255,255,0.08);
    --glass-blur: 20px;

    /* Legacy aliases */
    --brand-gold: #D4AF37;
    --brand-gold-hover: #e8c84a;
    --brand-black: #060606;
    --brand-dark: #0c0c0c;
    --brand-gray: rgba(255,255,255,0.06);
    --text-main: #b0b0b0;
    --text-muted: #777777;
    --text-white: #ffffff;
    --border-color: rgba(255,255,255,0.06);
    --transition: 0.3s cubic-bezier(0.4,0,0.2,1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
    font-family: 'Barlow', sans-serif;
    background: var(--black);
    color: var(--text);
    line-height: 1.7;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

a { text-decoration: none; color: inherit; transition: all var(--transition); }
ul { list-style: none; }
img { max-width: 100%; height: auto; display: block; }

/* ── AMBIENT BACKGROUND ── */
body::before {
    content: '';
    position: fixed;
    top: -50%; left: -50%;
    width: 200%; height: 200%;
    background:
        radial-gradient(ellipse at 20% 20%, rgba(212,175,55,0.04) 0%, transparent 50%),
        radial-gradient(ellipse at 80% 80%, rgba(212,175,55,0.03) 0%, transparent 50%),
        radial-gradient(ellipse at 50% 50%, rgba(20,20,20,1) 0%, var(--black) 100%);
    z-index: -1;
    animation: ambientDrift 30s ease-in-out infinite alternate;
}
@keyframes ambientDrift {
    0% { transform: translate(0,0) rotate(0deg); }
    100% { transform: translate(-2%,-1%) rotate(1deg); }
}

/* ── NOISE OVERLAY ── */
body::after {
    content: '';
    position: fixed; inset: 0;
    opacity: 0.025;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    pointer-events: none;
    z-index: 9999;
}

/* ── GLASS UTILITIES ── */
.glass {
    background: var(--glass-bg);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--glass-border);
    border-radius: 16px;
}
.glass-gold {
    background: linear-gradient(135deg, rgba(212,175,55,0.06) 0%, rgba(15,15,15,0.7) 100%);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--border-gold);
    border-radius: 16px;
}

/* ============================================
   LAYOUT
   ============================================ */
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.site-content { padding: 60px 0; flex: 1; position: relative; z-index: 10; }
.home .site-content, .page-template-front-page .site-content { padding: 0; }
.align-center { text-align: center; }

/* ============================================
   TOP BAR
   ============================================ */
.top-bar { position: relative; z-index: 100; padding: 12px 0; border-bottom: 1px solid var(--border); }
.top-bar-inner { display: flex; justify-content: space-between; align-items: center; font-size: 0.85rem; color: #666; }
.top-bar .phone { display: flex; align-items: center; gap: 8px; font-weight: 500; color: var(--text); }
.top-bar .phone i { color: var(--gold); font-size: 0.75rem; }

.social-links { display: flex; gap: 6px; }
.social-links a {
    display: flex; align-items: center; justify-content: center;
    width: 34px; height: 34px; border-radius: 8px;
    border: 1px solid var(--border); color: #666; font-size: 0.85rem; margin-left: 0;
}
.social-links a:hover { border-color: var(--border-gold); color: var(--gold); background: var(--gold-dim); }

/* ============================================
   BRANDING
   ============================================ */
.branding { text-align: center; padding: 48px 0 32px; position: relative; z-index: 10; }
.brand-mark { display: inline-block; position: relative; }
.brand-mark::before, .brand-mark::after {
    content: ''; position: absolute; top: 50%; width: 80px; height: 1px;
    background: linear-gradient(90deg, transparent, var(--gold), transparent); opacity: 0.4;
}
.brand-mark::before { right: calc(100% + 24px); }
.brand-mark::after { left: calc(100% + 24px); }

.site-title, .site-title a {
    font-family: 'Bebas Neue', sans-serif;
    font-size: clamp(2.8rem, 6vw, 4.5rem);
    letter-spacing: 8px; color: var(--white); line-height: 1;
    text-shadow: 0 0 60px rgba(212,175,55,0.15); font-weight: 400;
}
.site-title a:hover { color: var(--gold); }

.site-description, .tagline {
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 0.9rem; font-weight: 600; letter-spacing: 6px;
    color: var(--gold); text-transform: uppercase; margin-top: 8px;
}

/* ============================================
   NAVIGATION
   ============================================ */
.nav-wrap {
    position: sticky; top: 0; z-index: 1000; padding: 8px 0;
    background: rgba(6,6,6,0.7);
    backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
    border-bottom: 1px solid var(--border);
}
.nav-menu { display: flex; justify-content: center; gap: 4px; flex-wrap: wrap; }
.nav-menu li { list-style: none; }
.nav-menu li a, .nav-menu a {
    display: block; padding: 10px 20px;
    font-family: 'Barlow Condensed', sans-serif; font-weight: 600;
    font-size: 0.95rem; letter-spacing: 1.5px; text-transform: uppercase;
    color: #777; border-radius: 8px; position: relative; background: transparent; border: none;
}
.nav-menu li a:hover, .nav-menu li.current-menu-item a, .nav-menu li.current_page_item a,
.nav-menu a:hover, .nav-menu a.active {
    color: var(--gold); background: var(--gold-dim);
}
.nav-menu li.current-menu-item a::after, .nav-menu li.current_page_item a::after, .nav-menu a.active::after {
    content: ''; position: absolute; bottom: 4px; left: 50%; transform: translateX(-50%);
    width: 20px; height: 2px; background: var(--gold); border-radius: 1px;
}

.menu-toggle {
    display: none; background: none; border: 1px solid var(--border);
    color: var(--gold); font-family: 'Barlow Condensed', sans-serif;
    font-weight: 600; font-size: 1rem; padding: 12px 25px; cursor: pointer;
    text-transform: uppercase; letter-spacing: 2px; width: 100%; border-radius: 8px;
}
.menu-toggle:hover { background: var(--gold-dim); }

/* ============================================
   HERO
   ============================================ */
.hero-section {
    position: relative; width: 100%; min-height: 300px;
    overflow: hidden; background-color: #000; margin-bottom: -60px;
}
.hero-section img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero-section::after {
    content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 50%;
    background: linear-gradient(to top, var(--black) 0%, transparent 100%); pointer-events: none;
}

/* ============================================
   PAGE HEADERS
   ============================================ */
.page-header { text-align: center; margin-bottom: 40px; }
.page-title {
    font-family: 'Bebas Neue', sans-serif; font-size: 2.5rem;
    color: var(--gold); text-transform: uppercase; margin-bottom: 20px; letter-spacing: 3px;
}
.disclaimer-box {
    border: 1px solid var(--border-gold); background: var(--glass-bg);
    backdrop-filter: blur(var(--glass-blur)); -webkit-backdrop-filter: blur(var(--glass-blur));
    padding: 24px; margin: 0 auto 50px; max-width: 800px;
    text-align: center; font-style: italic; color: #999; border-radius: 14px;
}

/* ============================================
   DOG CARDS
   ============================================ */
.dog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; padding: 20px 0; }
@media (max-width: 900px) { .dog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .dog-grid { grid-template-columns: 1fr; } }
.dog-card {
    background: var(--glass-bg);
    backdrop-filter: blur(var(--glass-blur)); -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--border); border-radius: 14px; padding: 24px; text-align: center;
    transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}
.dog-card:hover { transform: translateY(-6px); border-color: var(--border-gold); box-shadow: 0 12px 40px rgba(0,0,0,0.4); }
.dog-card-image { margin-bottom: 15px; display: flex; justify-content: center; }
.dog-card-image img {
    border: 1px solid var(--border); border-radius: 10px;
    width: 200px; height: 200px; object-fit: cover;
    filter: brightness(0.9); transition: all 0.4s;
}
.dog-card:hover .dog-card-image img { border-color: var(--border-gold); filter: brightness(1); }
.dog-card-title {
    font-family: 'Bebas Neue', sans-serif; font-size: 1.2rem;
    color: var(--gold); text-transform: uppercase; margin-bottom: 8px; display: block; letter-spacing: 1px;
}
.dog-card-title:hover { color: var(--gold-light); }
.dog-card-meta { font-size: 0.85rem; color: var(--text-muted); }
.dog-card-meta span { display: block; margin-bottom: 3px; }
.dog-card-id { font-size: 0.75rem; color: #555; margin-top: 8px; letter-spacing: 1px; }

/* ============================================
   SINGLE DOG PROFILE
   ============================================ */
.dog-profile { max-width: 1000px; margin: 0 auto; }
.dog-profile-header { display: grid; grid-template-columns: 350px 1fr; gap: 40px; margin-bottom: 40px; align-items: start; }
.dog-profile-photo img { border: 2px solid var(--border); border-radius: 14px; width: 100%; }
.dog-profile-info h1 {
    font-family: 'Bebas Neue', sans-serif; font-size: 2.4rem;
    color: var(--gold); text-transform: uppercase; margin-bottom: 5px; letter-spacing: 2px;
}
.dog-profile-kennel-id { font-size: 0.85rem; color: #555; letter-spacing: 2px; margin-bottom: 20px; }
.dog-details-table { width: 100%; border-collapse: collapse; margin-top: 15px; }
.dog-details-table tr { border-bottom: 1px solid var(--border); }
.dog-details-table th { text-align: left; padding: 10px 15px 10px 0; color: var(--text-muted); font-weight: 400; width: 140px; font-size: 0.9rem; text-transform: uppercase; letter-spacing: 1px; }
.dog-details-table td { padding: 10px 0; color: var(--white); }
.dog-details-table td a { color: var(--gold); }
.dog-details-table td a:hover { color: var(--gold-light); }

/* ============================================
   PEDIGREE TABLE
   ============================================ */
.pedigree-section {
    margin-top: 0;
    padding: 50px 24px;
    width: 100%;
    position: relative;
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    background: rgba(10,10,10,0.5);
}
.pedigree-section h2 {
    font-family: 'Bebas Neue', sans-serif; font-size: 1.8rem;
    color: var(--gold); text-transform: uppercase; margin-bottom: 25px; text-align: center; letter-spacing: 3px;
}
.pedigree-panel { max-width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.pedigree-table { width: 100%; border-collapse: collapse; font-size: 0.8rem; table-layout: auto; }
.pedigree-table td { border: 1px solid var(--border); padding: 6px 10px; vertical-align: middle; background: var(--dark-card); color: var(--text); white-space: nowrap; }
.pedigree-table td a { color: var(--gold); }
.pedigree-table td a:hover { color: var(--gold-light); }

/* Scale font for higher generations to fit viewport */
.pedigree-panel[data-gen="5"] .pedigree-table { font-size: 0.72rem; }
.pedigree-panel[data-gen="5"] .pedigree-table td { padding: 5px 8px; }
.pedigree-panel[data-gen="6"] .pedigree-table { font-size: 0.62rem; }
.pedigree-panel[data-gen="6"] .pedigree-table td { padding: 4px 6px; }
.pedigree-panel[data-gen="7"] .pedigree-table { font-size: 0.55rem; }
.pedigree-panel[data-gen="7"] .pedigree-table td { padding: 3px 5px; }

.pedigree-tabs { display: flex; justify-content: center; gap: 6px; margin-bottom: 20px; }
.pedigree-tabs button {
    padding: 8px 20px; background: transparent; border: 1px solid var(--border); border-radius: 8px;
    color: #777; font-family: 'Barlow Condensed', sans-serif; font-weight: 600; font-size: 0.9rem;
    letter-spacing: 1px; text-transform: uppercase; cursor: pointer; transition: all var(--transition);
}
.pedigree-tabs button:hover, .pedigree-tabs button.active { color: var(--gold); background: var(--gold-dim); border-color: var(--border-gold); }

/* ============================================
   LITTER LAYOUTS
   ============================================ */
.litter-parents { display: grid; grid-template-columns: 1fr auto 1fr; gap: 20px; align-items: center; margin-bottom: 30px; }
.litter-parent-card { text-align: center; }
.litter-parent-card img { width: 200px; height: 180px; object-fit: cover; border: 1px solid var(--border); border-radius: 10px; margin: 0 auto 15px; }
.litter-parent-card h3 { font-family: 'Bebas Neue', sans-serif; text-transform: uppercase; margin-bottom: 5px; letter-spacing: 1px; }
.litter-parent-card h3 a { color: var(--gold); }
.litter-parent-label { font-size: 0.8rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 2px; margin-bottom: 10px; }
.litter-x { font-family: 'Bebas Neue', sans-serif; font-size: 2rem; color: var(--gold); }
.litter-details {
    background: var(--glass-bg); backdrop-filter: blur(var(--glass-blur)); -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--border); border-radius: 14px; padding: 25px; margin-bottom: 40px;
}
.litter-details h2 { font-family: 'Bebas Neue', sans-serif; color: var(--gold); text-transform: uppercase; margin-bottom: 15px; font-size: 1.4rem; letter-spacing: 2px; }
.litter-pups-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 20px; margin-top: 20px; }

/* ============================================
   HOMEPAGE COMPONENTS
   ============================================ */
.promo-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 64px; }
.promo-card {
    position: relative; border-radius: 14px; overflow: hidden;
    border: 1px solid var(--border); aspect-ratio: 1; cursor: pointer;
}
.promo-card img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform 0.5s cubic-bezier(0.4,0,0.2,1), filter 0.5s;
    filter: brightness(0.85) saturate(0.9);
}
.promo-card::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.6) 0%, transparent 50%);
    opacity: 0; transition: opacity 0.4s; pointer-events: none;
}
.promo-card:hover img { transform: scale(1.08); filter: brightness(1) saturate(1.1); }
.promo-card:hover { border-color: var(--border-gold); }
.promo-card:hover::after { opacity: 1; }

.quick-links { padding: 40px 32px; margin-bottom: 56px; }
.quick-links-title { text-align: center; font-family: 'Bebas Neue', sans-serif; font-size: 1.4rem; letter-spacing: 4px; color: var(--gold); margin-bottom: 28px; opacity: 0.7; }
.links-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; }
.link-item {
    display: flex; align-items: center; gap: 14px; padding: 16px 20px;
    border-radius: 10px; border: 1px solid var(--border); background: rgba(255,255,255,0.02);
    color: var(--text-light); font-family: 'Barlow Condensed', sans-serif;
    font-weight: 600; font-size: 0.95rem; letter-spacing: 1px; text-transform: uppercase;
}
.link-item i { color: var(--gold); opacity: 0.6; font-size: 0.75rem; transition: all 0.3s; }
.link-item:hover { border-color: var(--border-gold); background: var(--gold-dim); color: var(--gold); }
.link-item:hover i { opacity: 1; transform: translateX(3px); }

.banner-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 20px; margin-bottom: 64px; }
.banner-card { border-radius: 14px; overflow: hidden; border: 1px solid var(--border); box-shadow: 0 8px 32px rgba(0,0,0,0.3); transition: border-color 0.3s, transform 0.3s; }
.banner-card:hover { border-color: var(--border-gold); transform: translateY(-4px); }
.banner-card img { width: 100%; display: block; }

.about-section { max-width: 800px; margin: 0 auto 80px; padding: 48px 40px; text-align: center; }
.about-section .section-label { font-family: 'Barlow Condensed', sans-serif; font-weight: 600; font-size: 0.8rem; letter-spacing: 4px; text-transform: uppercase; color: var(--gold); opacity: 0.7; margin-bottom: 12px; }
.about-section h2 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(1.6rem, 3vw, 2.2rem); letter-spacing: 3px; color: var(--white); margin-bottom: 28px; line-height: 1.2; }
.about-section p { color: #999; font-size: 0.95rem; line-height: 1.9; margin-bottom: 18px; }
.about-section p:last-child { margin-bottom: 0; }
.about-section a.inline-link { color: var(--gold); font-weight: 600; border-bottom: 1px solid var(--border-gold); padding-bottom: 1px; }
.about-section a.inline-link:hover { border-bottom-color: var(--gold); }

.featured-image { margin: 0 auto 56px; max-width: 900px; border-radius: 16px; overflow: hidden; border: 1px solid var(--border); box-shadow: 0 20px 60px rgba(0,0,0,0.5); }
.featured-image img { width: 100%; display: block; transition: transform 0.6s cubic-bezier(0.4,0,0.2,1); }
.featured-image:hover img { transform: scale(1.02); }

.cta-section { text-align: center; margin-bottom: 48px; }

.text-block { max-width: 800px; margin: 40px auto; text-align: center; color: #bbb; }
.text-block h2 { font-family: 'Bebas Neue', sans-serif; color: var(--gold); margin-bottom: 25px; font-size: 1.8rem; letter-spacing: 2px; }
.text-block p { margin-bottom: 20px; }
.text-block a { color: var(--gold); font-weight: bold; }

.link-list { text-align: center; margin: 40px 0; }
.link-list h3 { margin-bottom: 15px; font-family: 'Bebas Neue', sans-serif; text-transform: uppercase; font-size: 1.5rem; letter-spacing: 2px; }
.link-list a { color: var(--white); font-weight: bold; border-bottom: 2px solid transparent; }
.link-list a:hover { color: var(--gold); border-bottom: 2px solid var(--gold); }

/* ============================================
   PEDIGREE SEARCH
   ============================================ */
.pedigree-search-form { max-width: 600px; margin: 0 auto 40px; display: flex; gap: 10px; }
.pedigree-search-form input[type="text"] {
    flex: 1; padding: 12px 18px; background: var(--glass-bg);
    border: 1px solid var(--border); border-radius: 10px;
    color: var(--white); font-family: 'Barlow', sans-serif; font-size: 1rem;
}
.pedigree-search-form input[type="text"]::placeholder { color: #555; }
.pedigree-search-form input[type="text"]:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 20px rgba(212,175,55,0.1); }
.pedigree-search-form button {
    padding: 12px 25px; background: linear-gradient(135deg, var(--gold), var(--gold-light));
    color: #000; border: none; border-radius: 10px;
    font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 1rem;
    text-transform: uppercase; letter-spacing: 1px; cursor: pointer;
    transition: var(--transition); box-shadow: 0 4px 16px rgba(212,175,55,0.2);
}
.pedigree-search-form button:hover { background: var(--white); }

/* Pedigree Database Disclaimer */
.pedigree-disclaimer {
    max-width: 800px;
    margin: 0 auto 36px;
    display: flex;
    gap: 14px;
    align-items: flex-start;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    border-left: 3px solid var(--gold);
    border-radius: 10px;
    padding: 18px 22px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
.pedigree-disclaimer i {
    color: var(--gold);
    font-size: 18px;
    margin-top: 2px;
    flex-shrink: 0;
}
.pedigree-disclaimer p {
    font-size: 13px;
    line-height: 1.7;
    color: #888;
    margin: 0;
}
.pedigree-disclaimer a {
    color: var(--gold);
    font-weight: 600;
    border-bottom: 1px solid transparent;
    transition: 0.2s;
}
.pedigree-disclaimer a:hover {
    border-bottom-color: var(--gold);
}

.pedigree-results-table { width: 100%; border-collapse: collapse; }
.pedigree-results-table th { background: var(--dark-card); color: var(--gold); font-family: 'Barlow Condensed', sans-serif; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; padding: 12px 15px; text-align: left; border-bottom: 2px solid var(--gold); font-size: 0.9rem; }
.pedigree-results-table td { padding: 10px 15px; border-bottom: 1px solid var(--border); color: var(--text); }
.pedigree-results-table tr:hover td { background: var(--dark-card); }
.pedigree-results-table td a { color: var(--gold); }

/* ============================================
   BUTTONS
   ============================================ */
.btn, .btn-gold {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 14px 36px; font-family: 'Barlow Condensed', sans-serif;
    font-weight: 700; font-size: 1rem; letter-spacing: 2px; text-transform: uppercase;
    color: var(--black); background: linear-gradient(135deg, var(--gold), var(--gold-light));
    border-radius: 10px; border: none; cursor: pointer;
    box-shadow: 0 4px 24px rgba(212,175,55,0.25), inset 0 1px 0 rgba(255,255,255,0.2);
    position: relative; overflow: hidden; transition: all var(--transition); margin-top: 10px;
}
.btn::before, .btn-gold::before {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(135deg, transparent 0%, rgba(255,255,255,0.2) 50%, transparent 100%);
    transform: translateX(-100%); transition: transform 0.6s cubic-bezier(0.4,0,0.2,1);
}
.btn:hover::before, .btn-gold:hover::before { transform: translateX(100%); }
.btn:hover, .btn-gold:hover { box-shadow: 0 8px 40px rgba(212,175,55,0.4); transform: translateY(-2px); color: var(--black); }
.btn-outline { background: transparent; border: 1px solid var(--gold); color: var(--gold); box-shadow: none; }
.btn-outline::before { display: none; }
.btn-outline:hover { background: var(--gold-dim); color: var(--gold); box-shadow: 0 4px 24px rgba(212,175,55,0.2); }

/* ============================================
   PAGINATION
   ============================================ */
.pagination { text-align: center; margin-top: 40px; }
.pagination a, .pagination span { display: inline-block; padding: 8px 16px; margin: 0 3px; background: var(--glass-bg); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-family: 'Barlow Condensed', sans-serif; font-weight: 600; transition: all var(--transition); }
.pagination .current { background: var(--gold); color: #000; border-color: var(--gold); }
.pagination a:hover { border-color: var(--border-gold); color: var(--gold); background: var(--gold-dim); }

/* ============================================
   FOOTER
   ============================================ */
.site-footer { border-top: 1px solid var(--border); padding-top: 64px; background: linear-gradient(to bottom, var(--black), #080808); color: #777; }
.footer-widgets { padding-bottom: 40px; text-align: center; }
.footer-title, .gallery-title { font-family: 'Bebas Neue', sans-serif; font-size: 1.5rem; letter-spacing: 5px; color: var(--gold); margin-bottom: 24px; opacity: 0.8; }
.footer-gallery, .stud-gallery { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; }
.footer-gallery img, .stud-thumb img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(30%) brightness(0.8); transition: all 0.4s; }
.footer-gallery a, .stud-thumb { width: 120px; height: 120px; border-radius: 12px; overflow: hidden; border: 2px solid rgba(255,255,255,0.05); transition: all 0.3s cubic-bezier(0.4,0,0.2,1); display: block; }
.footer-gallery a:hover, .stud-thumb:hover { border-color: var(--gold); transform: translateY(-6px); box-shadow: 0 12px 32px rgba(212,175,55,0.15); }
.footer-gallery a:hover img, .stud-thumb:hover img { filter: grayscale(0%) brightness(1); }
.footer-bottom { border-top: 1px solid var(--border); padding: 20px 0; margin-top: 32px; }
.footer-bottom-inner { display: flex; justify-content: space-between; align-items: center; font-size: 0.8rem; color: #555; }
.footer-menu, .footer-nav { display: flex; gap: 20px; }
.footer-menu a, .footer-nav a { color: #555; letter-spacing: 1px; font-size: 0.8rem; text-transform: uppercase; }
.footer-menu a:hover, .footer-nav a:hover { color: var(--gold); }

/* ============================================
   SCROLL ANIMATIONS
   ============================================ */
.fade-up { opacity: 0; transform: translateY(30px); transition: opacity 0.7s cubic-bezier(0.4,0,0.2,1), transform 0.7s cubic-bezier(0.4,0,0.2,1); }
.fade-up.visible { opacity: 1; transform: translateY(0); }
.stagger-1 { transition-delay: 0.05s; }
.stagger-2 { transition-delay: 0.1s; }
.stagger-3 { transition-delay: 0.15s; }

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 768px) {
    .menu-toggle { display: block; }
    .nav-menu { display: none; flex-direction: column; text-align: center; gap: 2px; }
    .nav-menu.active { display: flex; }
    .nav-menu li a, .nav-menu a { border-bottom: 1px solid var(--border); border-radius: 0; }
    .site-title, .site-title a { font-size: 2.5rem; letter-spacing: 4px; }
    .page-title { font-size: 1.8rem; }
    .promo-grid { grid-template-columns: 1fr; max-width: 400px; margin-left: auto; margin-right: auto; }
    .links-grid { grid-template-columns: 1fr; }
    .banner-row { grid-template-columns: 1fr; }
    .dog-profile-header { grid-template-columns: 1fr; text-align: center; }
    .dog-profile-photo img { max-width: 350px; margin: 0 auto; }
    .litter-parents { grid-template-columns: 1fr; }
    .footer-bottom-inner { flex-direction: column; gap: 12px; text-align: center; }
    .footer-menu, .footer-nav { flex-wrap: wrap; justify-content: center; }
    .pedigree-search-form { flex-direction: column; }
    .pedigree-table { font-size: 0.7rem; }
    .pedigree-table td { padding: 4px 6px; }
    .brand-mark::before, .brand-mark::after { width: 40px; }
    .about-section { padding: 32px 24px; }
    .footer-gallery a, .stud-thumb { width: 90px; height: 90px; }
}
@media (max-width: 480px) {
    .nav-menu { flex-wrap: wrap; justify-content: center; }
    .nav-menu li a, .nav-menu a { padding: 7px 10px; font-size: 0.78rem; }
}

/* ============================================
   HOMEPAGE V2: HERO OVERLAY
   ============================================ */
.hero-section { margin-bottom: 0; min-height: 70vh; position: relative; }
.home .hero-section::after { display: none; }
.hero-overlay {
    position: absolute; inset: 0; display: flex; align-items: center;
    background: linear-gradient(to right, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.4) 60%, transparent 100%);
    z-index: 2;
}
.hero-content { max-width: 600px; }
.hero-title {
    font-family: 'Bebas Neue', sans-serif; font-size: clamp(3rem, 7vw, 5.5rem);
    color: var(--white); letter-spacing: 6px; line-height: 1;
    text-shadow: 0 4px 40px rgba(0,0,0,0.5);
    margin-bottom: 16px;
}
.hero-subtitle {
    font-family: 'Barlow Condensed', sans-serif; font-size: 1.1rem;
    font-weight: 400; letter-spacing: 2px; color: var(--gold);
    text-transform: uppercase; margin-bottom: 32px; line-height: 1.6;
}
.hero-actions { display: flex; gap: 16px; flex-wrap: wrap; }
.btn-outline-hero {
    background: transparent !important; border: 1px solid rgba(255,255,255,0.3) !important;
    color: var(--white) !important; box-shadow: none !important;
}
.btn-outline-hero:hover {
    border-color: var(--gold) !important; color: var(--gold) !important;
    background: rgba(212,175,55,0.1) !important;
}

/* ============================================
   HOMEPAGE EXTRAS (glassmorphism treatment)
   ============================================ */
.homepage-extras {
    padding: 60px 0 30px;
    background: var(--black);
}

/* Glass frame — wraps all images and the link list */
.extras-glass-frame {
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 16px;
    padding: 12px;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 8px 32px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.05);
    transition: border-color 0.3s, box-shadow 0.3s;
    overflow: hidden;
}
.extras-glass-frame:hover {
    border-color: rgba(212,175,55,0.2);
    box-shadow: 0 8px 32px rgba(0,0,0,0.5), 0 0 20px rgba(212,175,55,0.06), inset 0 1px 0 rgba(255,255,255,0.06);
}
.extras-glass-frame img {
    width: 100%;
    display: block;
    border-radius: 10px;
}

/* BFKC button row */
.extras-bfkc-row {
    margin-bottom: 36px;
}
.btn-glow {
    box-shadow: 0 0 20px rgba(212,175,55,0.2);
    transition: box-shadow 0.3s, background 0.3s, transform 0.2s;
}
.btn-glow:hover {
    box-shadow: 0 0 30px rgba(212,175,55,0.35);
    transform: translateY(-2px);
}
.btn-glow i {
    margin-right: 8px;
}

/* Featured banner */
.featured-banner-wrap {
    margin-bottom: 36px;
}

/* 3-column promo grid */
.promo-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 24px;
    margin: 0 0 36px;
}
.promo-grid-item {
    transition: transform 0.3s ease;
}
.promo-grid-item:hover {
    transform: translateY(-6px);
}
.promo-grid-item a { display: block; }

/* Text link list (inside glass frame) */
.homepage-link-list {
    text-align: center;
    margin: 0 0 36px;
    padding: 28px 20px;
}
.homepage-link-list h3 {
    margin-bottom: 14px;
    font-family: 'Oswald', 'Bebas Neue', sans-serif;
    text-transform: uppercase;
    font-size: 1.3rem;
    letter-spacing: 1.5px;
}
.homepage-link-list h3:last-child {
    margin-bottom: 0;
}
.homepage-link-list a {
    color: var(--text-light, #d4d4d4);
    font-weight: 600;
    border-bottom: 2px solid transparent;
    padding-bottom: 2px;
    transition: 0.3s;
}
.homepage-link-list a:hover {
    color: var(--gold);
    border-bottom-color: var(--gold);
}

/* Stacked banners */
.banners-stack {
    display: flex;
    flex-direction: column;
    gap: 24px;
    margin-bottom: 36px;
}
.standalone-banner img {
    border-radius: 10px;
}

@media (max-width: 768px) {
    .promo-grid { grid-template-columns: 1fr; }
    .homepage-extras { padding: 40px 0 20px; }
}

/* ============================================
   HOMEPAGE V2: STAT COUNTERS
   ============================================ */
.stats-bar { padding: 48px 0; border-bottom: 1px solid var(--border); }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; text-align: center; }
.stat-item { padding: 16px; }
.stat-number {
    display: block; font-family: 'Bebas Neue', sans-serif;
    font-size: 3rem; color: var(--gold); letter-spacing: 2px; line-height: 1;
}
.stat-label {
    display: block; font-size: 0.8rem; font-weight: 600;
    letter-spacing: 2px; text-transform: uppercase; color: #666; margin-top: 8px;
}

/* ============================================
   HOMEPAGE V2: SECTION HEADERS
   ============================================ */
.section-header { text-align: center; margin-bottom: 48px; }
.section-tag {
    display: inline-block; font-family: 'Barlow Condensed', sans-serif;
    font-weight: 600; font-size: 0.8rem; letter-spacing: 4px;
    text-transform: uppercase; color: var(--gold); opacity: 0.8;
    margin-bottom: 12px;
}
.section-title {
    font-family: 'Bebas Neue', sans-serif; font-size: clamp(2rem, 4vw, 3rem);
    color: var(--white); letter-spacing: 4px; line-height: 1.1;
}

/* ============================================
   HOMEPAGE V2: PILLARS (3 columns)
   ============================================ */
.pillars-section { padding: 80px 0; }
.pillars-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.pillar-card {
    padding: 40px 32px; text-align: center;
    transition: border-color 0.3s, transform 0.3s;
}
.pillar-card:hover { border-color: var(--border-gold); transform: translateY(-4px); }
.pillar-icon {
    width: 64px; height: 64px; border-radius: 14px;
    background: var(--gold-dim); display: flex; align-items: center; justify-content: center;
    margin: 0 auto 24px; font-size: 1.4rem; color: var(--gold);
    border: 1px solid var(--border-gold);
}
.pillar-card h3 {
    font-family: 'Bebas Neue', sans-serif; font-size: 1.5rem;
    color: var(--white); letter-spacing: 2px; margin-bottom: 12px;
}
.pillar-card p { font-size: 0.9rem; color: #888; line-height: 1.8; }

/* ============================================
   HOMEPAGE V2: STUDS SHOWCASE
   ============================================ */
.studs-showcase { padding: 80px 0; border-top: 1px solid var(--border); }
.studs-scroll-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 20px;
}
.stud-showcase-card {
    display: flex; flex-direction: column; border-radius: 14px; overflow: hidden;
    border: 1px solid var(--border); background: var(--dark-card);
    transition: all 0.4s cubic-bezier(0.4,0,0.2,1); position: relative;
}
.stud-showcase-card:hover {
    border-color: var(--border-gold); transform: translateY(-6px);
    box-shadow: 0 16px 48px rgba(0,0,0,0.5);
}
.stud-showcase-image { aspect-ratio: 1; overflow: hidden; }
.stud-showcase-image img {
    width: 100%; height: 100%; object-fit: cover;
    filter: brightness(0.85); transition: all 0.5s;
}
.stud-showcase-card:hover .stud-showcase-image img { filter: brightness(1); transform: scale(1.05); }
.stud-showcase-info {
    padding: 20px; flex: 1;
}
.stud-showcase-info h3 {
    font-family: 'Bebas Neue', sans-serif; font-size: 1.3rem;
    color: var(--gold); letter-spacing: 1.5px; margin-bottom: 4px;
}
.stud-id { font-size: 0.75rem; color: #555; letter-spacing: 1px; }
.stud-view-link {
    display: block; padding: 14px 20px; border-top: 1px solid var(--border);
    font-family: 'Barlow Condensed', sans-serif; font-weight: 600;
    font-size: 0.85rem; letter-spacing: 1.5px; text-transform: uppercase;
    color: #555; transition: all 0.3s;
}
.stud-view-link i { margin-left: 6px; transition: transform 0.3s; font-size: 0.75rem; }
.stud-showcase-card:hover .stud-view-link { color: var(--gold); }
.stud-showcase-card:hover .stud-view-link i { transform: translateX(4px); }

/* ============================================
   HOMEPAGE V2: INTERSTITIAL
   ============================================ */
.interstitial {
    padding: 100px 0; text-align: center;
    border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
    background: linear-gradient(135deg, rgba(212,175,55,0.03) 0%, transparent 50%, rgba(212,175,55,0.02) 100%);
}
.interstitial-inner { max-width: 700px; margin: 0 auto; }
.interstitial-tag {
    font-family: 'Barlow Condensed', sans-serif; font-weight: 600;
    font-size: 0.8rem; letter-spacing: 4px; text-transform: uppercase;
    color: var(--gold); opacity: 0.6; margin-bottom: 20px; display: block;
}
.interstitial h2 {
    font-family: 'Bebas Neue', sans-serif; font-size: clamp(2.5rem, 5vw, 4rem);
    color: var(--white); letter-spacing: 4px; line-height: 1.15; margin-bottom: 20px;
}
.interstitial p { font-size: 1rem; color: #777; line-height: 1.8; max-width: 500px; margin: 0 auto; }

/* ============================================
   HOMEPAGE V2: PUPS SECTION
   ============================================ */
.pups-section { padding: 80px 0; }

/* ============================================
   HOMEPAGE V2: INCLUDED SECTION
   ============================================ */
.included-section { padding: 80px 0; border-top: 1px solid var(--border); }
.included-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.included-item {
    padding: 28px 24px; text-align: center;
    transition: border-color 0.3s, transform 0.3s;
}
.included-item:hover { border-color: var(--border-gold); transform: translateY(-3px); }
.included-item i {
    font-size: 1.3rem; color: var(--gold); margin-bottom: 16px; display: block; opacity: 0.8;
}
.included-item h4 {
    font-family: 'Barlow Condensed', sans-serif; font-weight: 700;
    font-size: 1rem; letter-spacing: 1.5px; text-transform: uppercase;
    color: var(--white); margin-bottom: 8px;
}
.included-item p { font-size: 0.85rem; color: #666; }

/* ============================================
   HOMEPAGE V2: ABOUT BLOCK
   ============================================ */
.about-block { padding: 80px 0; border-top: 1px solid var(--border); }
.about-split { max-width: 800px; margin: 0 auto; }
.about-text-side .section-tag { display: block; margin-bottom: 12px; }
.about-text-side h2 {
    font-family: 'Bebas Neue', sans-serif; font-size: clamp(1.8rem, 3vw, 2.4rem);
    color: var(--white); letter-spacing: 2px; line-height: 1.2; margin-bottom: 24px;
}
.about-text-side p { color: #888; font-size: 0.95rem; line-height: 1.9; margin-bottom: 16px; }
.about-text-side a { color: var(--gold); font-weight: 600; }

/* ============================================
   HOMEPAGE V2: RESOURCES
   ============================================ */
.resources-section { padding: 0 0 80px; }

/* ============================================
   HOMEPAGE V2: CTA BANNER
   ============================================ */
.cta-banner { padding: 0 0 80px; }
.cta-banner-inner {
    padding: 56px 48px; text-align: center;
}
.cta-banner-inner h2 {
    font-family: 'Bebas Neue', sans-serif; font-size: clamp(1.8rem, 3vw, 2.4rem);
    color: var(--white); letter-spacing: 3px; margin-bottom: 12px;
}
.cta-banner-inner p { color: #888; font-size: 0.95rem; margin-bottom: 28px; }
.cta-banner-actions { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* ============================================
   HOMEPAGE V2: RESPONSIVE OVERRIDES
   ============================================ */
@media (max-width: 768px) {
    .hero-section { min-height: 50vh; }
    .hero-overlay { align-items: flex-end; padding-bottom: 40px;
        background: linear-gradient(to top, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.5) 50%, transparent 100%);
    }
    .hero-content { max-width: 100%; text-align: center; }
    .hero-actions { justify-content: center; }
    .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
    .pillars-grid { grid-template-columns: 1fr; max-width: 500px; margin: 0 auto; }
    .studs-scroll-grid { grid-template-columns: repeat(2, 1fr); }
    .included-grid { grid-template-columns: 1fr 1fr; }
    .cta-banner-inner { padding: 40px 24px; }
}
@media (max-width: 480px) {
    .studs-scroll-grid { grid-template-columns: 1fr; max-width: 340px; margin: 0 auto; }
    .included-grid { grid-template-columns: 1fr; }
    .stats-grid { grid-template-columns: 1fr 1fr; }
}

/* ============================================
   PEDIGREE: SHARE BUTTONS
   ============================================ */
.pedigree-share {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    margin-top: 28px;
    flex-wrap: wrap;
}
.pedigree-share-label {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 600;
    font-size: 0.8rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #555;
    margin-right: 4px;
}
.share-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 20px;
    border-radius: 8px;
    border: 1px solid var(--border);
    background: var(--glass-bg);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    color: #888;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 600;
    font-size: 0.85rem;
    letter-spacing: 1px;
    text-transform: uppercase;
    cursor: pointer;
    transition: all var(--transition);
    text-decoration: none;
}
.share-btn:hover { border-color: var(--border-gold); color: var(--gold); background: var(--gold-dim); }
.share-btn i { font-size: 0.9rem; }
.share-btn.share-facebook:hover { border-color: #1877f2; color: #1877f2; background: rgba(24,119,242,0.1); }
.share-btn.share-twitter:hover { border-color: #1da1f2; color: #1da1f2; background: rgba(29,161,242,0.1); }
.share-btn.share-copy.copied { border-color: #4caf50; color: #4caf50; background: rgba(76,175,80,0.1); }

/* ============================================
   PEDIGREE STATS — Analytics Dashboard
   ============================================ */
.ped-stats-section {
    padding: 60px 24px 80px;
    border-top: 1px solid var(--border);
    background: linear-gradient(180deg, rgba(212,175,55,0.02) 0%, transparent 40%);
}
.ped-stats-header { text-align: center; margin-bottom: 48px; }
.ped-stats-subtitle {
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 0.85rem; color: #555; letter-spacing: 1.5px;
    text-transform: uppercase; margin-top: 8px;
}

/* Rows */
.ped-stats-row { display: grid; gap: 20px; margin-bottom: 20px; }
.ped-stats-row-hero { grid-template-columns: 1fr 1fr; }
.ped-stats-row-metrics { grid-template-columns: repeat(4, 1fr); }
.ped-stats-row-charts { grid-template-columns: 1fr 1fr; }

/* Cards */
.ped-stat-card { padding: 28px; position: relative; }
.ped-stat-full { grid-column: 1 / -1; }
.ped-stat-card-title {
    font-family: 'Barlow Condensed', sans-serif; font-weight: 700;
    font-size: 0.85rem; letter-spacing: 2px; text-transform: uppercase;
    color: var(--gold); margin-bottom: 20px; opacity: 0.8;
}

/* COI Gauge */
.ped-stat-coi-gauge { display: flex; flex-direction: column; align-items: center; }
.coi-gauge-wrap { position: relative; width: 280px; height: 180px; margin: 0 auto; }
.coi-gauge-value {
    position: absolute; bottom: 12px; left: 50%; transform: translateX(-50%);
    text-align: center;
}
.coi-number { display: block; font-family: 'Bebas Neue', sans-serif; font-size: 2.8rem; letter-spacing: 2px; line-height: 1; }
.coi-tier { display: block; font-family: 'Barlow Condensed', sans-serif; font-size: 0.85rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; margin-top: 4px; }

/* No data state */
.ped-stat-no-data {
    display: flex; align-items: center; gap: 12px; padding: 20px;
    color: #555; font-size: 0.9rem; margin-top: 20px;
}
.ped-stat-no-data i { color: #ff9800; font-size: 1.2rem; }

/* COI Reference table */
.coi-ref-table { width: 100%; border-collapse: collapse; font-size: 0.85rem; }
.coi-ref-table tr { border-bottom: 1px solid var(--border); }
.coi-ref-table td { padding: 10px 8px; vertical-align: middle; color: #888; }
.coi-ref-table td:nth-child(2) { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; color: var(--white); white-space: nowrap; width: 60px; }
.coi-ref-bar { width: 80px; }
.coi-bar { height: 6px; border-radius: 3px; min-width: 4px; }
.coi-ref-note {
    margin-top: 16px; padding-top: 12px; border-top: 1px solid var(--border);
    font-size: 0.78rem; color: #555; line-height: 1.7;
}

/* Metric cards */
.ped-stat-metric { text-align: center; padding: 24px 16px; transition: border-color 0.3s, transform 0.3s; }
.ped-stat-metric:hover { border-color: var(--border-gold); transform: translateY(-3px); }
.ped-metric-icon { font-size: 1.2rem; color: var(--gold); opacity: 0.6; margin-bottom: 12px; }
.ped-metric-value {
    font-family: 'Bebas Neue', sans-serif; font-size: 2rem; color: var(--white);
    letter-spacing: 1px; line-height: 1;
}
.ped-metric-value small { font-size: 0.6em; color: #555; }
.ped-metric-label {
    font-family: 'Barlow Condensed', sans-serif; font-weight: 600;
    font-size: 0.75rem; letter-spacing: 1.5px; text-transform: uppercase;
    color: #555; margin-top: 8px;
}

/* Chart containers */
.ped-chart-wrap { position: relative; height: 220px; }
.ped-chart-wrap.ped-chart-tall { height: 300px; }

/* Ancestor detail table */
.ped-ancestor-table { width: 100%; border-collapse: collapse; font-size: 0.85rem; }
.ped-ancestor-table thead th {
    font-family: 'Barlow Condensed', sans-serif; font-weight: 700;
    text-transform: uppercase; letter-spacing: 1.5px; font-size: 0.78rem;
    color: var(--gold); padding: 10px 12px; text-align: left;
    border-bottom: 1px solid var(--border-gold);
}
.ped-ancestor-table tbody td {
    padding: 10px 12px; border-bottom: 1px solid var(--border); color: #888;
}
.ped-ancestor-table tbody td a { color: var(--gold); }
.ped-ancestor-table tbody td a:hover { color: var(--gold-light); }
.ped-ancestor-table .center { text-align: center; }
.ped-ancestor-table tbody tr:hover td { background: rgba(212,175,55,0.03); }

/* Impact bar */
.ped-impact-bar-bg { width: 100%; height: 6px; background: rgba(255,255,255,0.04); border-radius: 3px; overflow: hidden; }
.ped-impact-bar { height: 100%; background: var(--gold); border-radius: 3px; transition: width 0.6s cubic-bezier(0.4,0,0.2,1); }

/* Responsive */
@media (max-width: 768px) {
    .ped-stats-row-hero { grid-template-columns: 1fr; }
    .ped-stats-row-metrics { grid-template-columns: 1fr 1fr; }
    .ped-stats-row-charts { grid-template-columns: 1fr; }
    .ped-chart-wrap { height: 200px; }
    .ped-chart-wrap.ped-chart-tall { height: 260px; }
}
@media (max-width: 480px) {
    .ped-stats-row-metrics { grid-template-columns: 1fr; }
    .coi-gauge-wrap { width: 220px; height: 150px; }
    .coi-number { font-size: 2.2rem; }
}

/* ============================================
   SINGLE POST — Blog Articles
   ============================================ */
.tk-post-single { max-width: 800px; margin: 0 auto; padding: 40px 0 60px; }
.tk-post-header { margin-bottom: 32px; text-align: center; }
.tk-post-title {
    font-family: 'Bebas Neue', sans-serif; font-size: 2.6rem;
    letter-spacing: 2px; color: var(--white); line-height: 1.1; margin: 0 0 12px;
}
.tk-post-meta {
    font-family: 'Barlow Condensed', sans-serif; font-size: 0.85rem;
    color: #555; letter-spacing: 1px; text-transform: uppercase;
}
.tk-post-meta a { color: var(--gold); }
.tk-post-sep { margin: 0 8px; }
.tk-post-featured { margin-bottom: 32px; border-radius: 12px; overflow: hidden; }
.tk-post-featured img { width: 100%; height: auto; display: block; }
.tk-post-content { font-size: 1rem; line-height: 1.85; color: #bbb; }
.tk-post-content p { margin-bottom: 1.2em; }
.tk-post-content h2, .tk-post-content h3 {
    font-family: 'Bebas Neue', sans-serif; color: var(--white);
    letter-spacing: 1px; margin: 1.8em 0 0.6em;
}
.tk-post-content h2 { font-size: 1.6rem; }
.tk-post-content h3 { font-size: 1.3rem; }
.tk-post-content a { color: var(--gold); }
.tk-post-content img { max-width: 100%; height: auto; border-radius: 8px; }
.tk-post-content blockquote {
    border-left: 3px solid var(--gold); margin: 1.5em 0; padding: 12px 20px;
    color: #888; font-style: italic; background: rgba(255,255,255,0.02);
}
.tk-post-content ul, .tk-post-content ol { padding-left: 24px; margin-bottom: 1.2em; }
.tk-post-content li { margin-bottom: 6px; }
.tk-post-footer { margin-top: 40px; padding-top: 20px; border-top: 1px solid var(--border); }
.tk-post-tags { font-size: 0.85rem; color: #555; }
.tk-post-tags a { color: var(--gold); }
.tk-post-nav {
    display: flex; justify-content: space-between; margin-top: 32px;
    padding-top: 20px; border-top: 1px solid var(--border); font-size: 0.9rem;
}
.tk-post-nav a { color: var(--gold); }
.tk-post-nav a:hover { color: var(--gold-light); }

/* ============================================
   POST SHARE BUTTONS
   ============================================ */
.tk-post-share {
    margin-top: 40px; padding: 28px 0; text-align: center;
    border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
}
.tk-post-share-label {
    display: block; font-family: 'Barlow Condensed', sans-serif; font-weight: 700;
    font-size: 0.8rem; letter-spacing: 2px; text-transform: uppercase;
    color: #555; margin-bottom: 16px;
}
.tk-post-share-buttons { display: flex; justify-content: center; flex-wrap: wrap; gap: 10px; }
.tk-share-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 9px 16px; border-radius: 6px; font-size: 0.82rem;
    font-family: 'Barlow Condensed', sans-serif; font-weight: 600;
    letter-spacing: 0.5px; text-decoration: none; cursor: pointer;
    background: var(--glass-bg, rgba(15,15,15,0.6));
    border: 1px solid var(--border, rgba(255,255,255,0.06));
    color: #888; transition: all 0.25s;
    -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
}
.tk-share-btn:hover { color: #fff; transform: translateY(-2px); }
.tk-share-btn i { font-size: 0.9rem; }
.tk-share-facebook:hover  { background: #1877f2; border-color: #1877f2; }
.tk-share-twitter:hover   { background: #1da1f2; border-color: #1da1f2; }
.tk-share-whatsapp:hover  { background: #25d366; border-color: #25d366; }
.tk-share-linkedin:hover  { background: #0a66c2; border-color: #0a66c2; }
.tk-share-email:hover     { background: var(--gold, #D4AF37); border-color: var(--gold); color: #000; }
.tk-share-copy:hover      { background: #4caf50; border-color: #4caf50; }
.tk-share-copy.copied     { background: #4caf50; border-color: #4caf50; color: #fff; }
@media (max-width: 480px) {
    .tk-post-share-buttons { gap: 8px; }
    .tk-share-btn { padding: 8px 12px; font-size: 0.78rem; }
}

/* ============================================
   RELATED AVAILABLE PUPS — Single Dog Page
   ============================================ */
.tk-related-pups-section {
    margin-top: 60px; padding-top: 50px;
    border-top: 1px solid var(--border-gold, rgba(212,175,55,0.15));
}
.tk-related-pups-title {
    font-family: 'Bebas Neue', sans-serif; font-size: 2rem;
    color: var(--white); text-align: center; letter-spacing: 3px;
    text-transform: uppercase; margin: 8px 0 10px;
}
.tk-related-pups-sub {
    text-align: center; font-family: 'Barlow Condensed', sans-serif;
    font-size: 0.9rem; color: #555; letter-spacing: 0.5px; margin-bottom: 32px;
}
.tk-related-pups-section .dog-grid { margin-bottom: 0; }

/* ============================================
   PUP CARDS & ARCHIVE
   ============================================ */

/* Grid */
.pup-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 24px; margin-bottom: 40px;
}
.pup-grid-sold { opacity: 0.6; }

/* Section headers */
.pup-section-header {
    text-align: center; margin: 40px 0 24px;
    padding-bottom: 12px; border-bottom: 1px solid var(--border);
}
.pup-section-header:first-of-type { margin-top: 0; }
.pup-section-header h2 {
    font-family: 'Bebas Neue', sans-serif; font-size: 1.6rem;
    letter-spacing: 3px; text-transform: uppercase; color: var(--white);
}
.pup-count {
    background: var(--gold); color: #000; padding: 2px 10px;
    border-radius: 4px; font-size: 0.85em; margin-right: 6px;
}
.pup-section-reserved h2 { color: #ff9800; }
.pup-section-sold h2 { color: #555; }

/* Card */
.pup-card {
    background: var(--glass-bg, rgba(15,15,15,0.6));
    border: 1px solid var(--border, rgba(255,255,255,0.06));
    border-radius: 12px; overflow: hidden;
    transition: transform 0.3s, border-color 0.3s;
    -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
}
.pup-card:hover { transform: translateY(-6px); border-color: var(--border-gold, rgba(212,175,55,0.2)); }
.pup-status-sold { opacity: 0.55; }
.pup-status-sold:hover { opacity: 0.75; }

/* Card image */
.pup-card-image { position: relative; overflow: hidden; aspect-ratio: 1; }
.pup-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s; }
.pup-card:hover .pup-card-image img { transform: scale(1.05); }

/* Status badge */
.pup-status-badge {
    position: absolute; top: 12px; right: 12px;
    font-family: 'Barlow Condensed', sans-serif; font-weight: 700;
    font-size: 0.7rem; letter-spacing: 1.5px; text-transform: uppercase;
    padding: 4px 12px; border-radius: 4px;
}
.pup-badge-available { background: var(--gold); color: #000; }
.pup-badge-reserved  { background: #ff9800; color: #000; }
.pup-badge-sold      { background: #555; color: #ddd; }
.pup-badge-keeper    { background: #2196f3; color: #fff; }
.pup-badge-large     { font-size: 0.8rem; padding: 6px 16px; top: 16px; right: 16px; }

/* Card body */
.pup-card-body { padding: 16px 18px 20px; }
.pup-card-title {
    display: block; font-family: 'Bebas Neue', sans-serif;
    font-size: 1.2rem; letter-spacing: 1.5px; color: var(--white);
    text-transform: uppercase; margin-bottom: 4px;
}
.pup-card-title:hover { color: var(--gold); }
.pup-card-callname {
    font-family: 'Barlow', sans-serif; font-style: italic;
    font-size: 0.85rem; color: var(--gold); margin-bottom: 10px; opacity: 0.7;
}

/* Details */
.pup-card-details { display: flex; flex-wrap: wrap; gap: 8px 14px; margin-bottom: 10px; }
.pup-detail {
    font-family: 'Barlow Condensed', sans-serif; font-size: 0.8rem;
    color: #666; display: flex; align-items: center; gap: 4px;
}
.pup-detail i { color: var(--gold); font-size: 0.7rem; opacity: 0.6; }

/* Parents */
.pup-card-parents {
    font-size: 0.78rem; color: #555; margin-bottom: 10px; line-height: 1.6;
    padding-top: 8px; border-top: 1px solid var(--border);
}
.pup-card-parents span { display: block; }
.pup-card-parents a { color: var(--gold); }

/* Price */
.pup-card-price {
    font-family: 'Bebas Neue', sans-serif; font-size: 1.3rem;
    color: var(--gold); letter-spacing: 1px; margin: 10px 0;
}

/* CTA button */
.pup-card-btn {
    display: block; text-align: center; font-size: 0.78rem;
    padding: 8px 16px; margin-top: 6px;
}

/* ============================================
   SINGLE PUP PAGE
   ============================================ */
.pup-single { max-width: 1000px; margin: 0 auto; padding: 20px 0 60px; }
.pup-single-top { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: start; }

.pup-single-photo {
    position: relative; border-radius: 12px; overflow: hidden;
    border: 1px solid var(--border);
}
.pup-single-photo img { width: 100%; height: auto; display: block; }

.pup-single-title {
    font-family: 'Bebas Neue', sans-serif; font-size: 2.2rem;
    color: var(--white); letter-spacing: 2px; text-transform: uppercase;
    margin: 0 0 4px; line-height: 1.1;
}
.pup-single-callname {
    font-family: 'Barlow', sans-serif; font-style: italic;
    font-size: 1rem; color: var(--gold); margin-bottom: 20px; opacity: 0.7;
}

/* Info table */
.pup-single-details { padding: 20px; margin-bottom: 20px; }
.pup-info-row {
    display: flex; justify-content: space-between; padding: 8px 0;
    border-bottom: 1px solid var(--border); font-size: 0.9rem;
}
.pup-info-row:last-child { border-bottom: none; }
.pup-info-label { color: #555; font-family: 'Barlow Condensed', sans-serif; text-transform: uppercase; letter-spacing: 1px; font-size: 0.8rem; }
.pup-info-value { color: var(--white); }

/* Parents */
.pup-single-parents { padding: 20px; margin-bottom: 20px; }
.pup-parent-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: 10px 0; border-bottom: 1px solid var(--border);
}
.pup-parent-row:last-child { border-bottom: none; }
.pup-parent-label { color: #555; font-size: 0.85rem; }
.pup-parent-label i { color: var(--gold); margin-right: 4px; }
.pup-parent-link { color: var(--gold); font-weight: 600; }
.pup-parent-link:hover { color: var(--gold-light); }

/* Price */
.pup-single-price {
    font-family: 'Bebas Neue', sans-serif; font-size: 2rem;
    color: var(--gold); letter-spacing: 2px; margin-top: 16px;
}

/* Content area */
.pup-single-content { margin-top: 40px; font-size: 1rem; line-height: 1.8; color: #bbb; }
.pup-single-content p { margin-bottom: 1.2em; }
.pup-single-content h2, .pup-single-content h3 { font-family: 'Bebas Neue', sans-serif; color: var(--white); margin: 1.5em 0 0.6em; }

@media (max-width: 768px) {
    .pup-single-top { grid-template-columns: 1fr; }
    .pup-single-title { font-size: 1.8rem; }
    .pup-grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px; }
}

/* ============================================
   BLINKING AVAILABLE PUPS BUTTON
   ============================================ */
.tk-blink-btn {
    display: inline-block;
    padding: 16px 40px;
    background: var(--gold, #D4AF37);
    color: #000;
    font-family: 'Bebas Neue', 'Oswald', sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    text-decoration: none;
    border: 2px solid var(--gold, #D4AF37);
    border-radius: 6px;
    cursor: pointer;
    animation: tkBtnPulse 1.8s ease-in-out infinite;
    transition: transform 0.2s, box-shadow 0.2s;
}
.tk-blink-btn:hover {
    transform: scale(1.04);
    box-shadow: 0 0 30px rgba(212, 175, 55, 0.5);
    animation: none;
    color: #000;
}

@keyframes tkBtnPulse {
    0%   { box-shadow: 0 0 8px rgba(212,175,55,0.3); opacity: 1; }
    50%  { box-shadow: 0 0 25px rgba(212,175,55,0.7); opacity: 0.85; }
    100% { box-shadow: 0 0 8px rgba(212,175,55,0.3); opacity: 1; }
}

@media (max-width: 768px) {
    .tk-blink-btn { font-size: 0.85rem; padding: 14px 24px; letter-spacing: 1px; }
}

/* ============================================
   BFKC VERIFIED BADGE
   ============================================ */
.tk-bfkc-badge {
    position: relative; display: inline-block; cursor: pointer;
    margin-left: 3px; line-height: 1;
}
.tk-bfkc-badge::after {
    content: attr(title);
    position: absolute; bottom: 100%; left: 50%; transform: translateX(-50%);
    background: #111; color: #D4AF37; font-family: 'Barlow Condensed', sans-serif;
    font-size: 0.7rem; font-weight: 600; letter-spacing: 0.5px;
    padding: 5px 10px; border-radius: 4px; white-space: nowrap;
    border: 1px solid rgba(212,175,55,0.3);
    opacity: 0; pointer-events: none; transition: opacity 0.2s;
    margin-bottom: 6px; z-index: 100;
}
.tk-bfkc-badge:hover::after { opacity: 1; }
.tk-bfkc-badge-lg { margin-left: 6px; }

/* Pedigree table badge sizing adjustments for dense generations */
.pedigree-5gen .tk-bfkc-badge svg { width: 12px; height: 12px; }
.pedigree-6gen .tk-bfkc-badge svg { width: 10px; height: 10px; }
.pedigree-7gen .tk-bfkc-badge svg { width: 9px; height: 9px; }

/* ============================================
   BLOG GRID & CARDS
   ============================================ */
.blog-grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}

.blog-card {
    background: var(--glass-bg, rgba(15,15,15,0.6));
    border: 1px solid var(--border, rgba(255,255,255,0.06));
    border-radius: 12px; overflow: hidden;
    transition: transform 0.3s, border-color 0.3s;
    -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
    display: flex; flex-direction: column;
}
.blog-card:hover {
    transform: translateY(-6px);
    border-color: var(--border-gold, rgba(212,175,55,0.2));
}

.blog-card-image { display: block; overflow: hidden; aspect-ratio: 16/9; }
.blog-card-image img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform 0.4s;
}
.blog-card:hover .blog-card-image img { transform: scale(1.05); }

.blog-card-body { padding: 20px 22px 24px; flex: 1; display: flex; flex-direction: column; }

.blog-card-meta {
    font-family: 'Barlow Condensed', sans-serif; font-size: 0.78rem;
    color: #555; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px;
}
.blog-card-meta a { color: var(--gold, #D4AF37); }
.blog-card-sep { margin: 0 6px; }

.blog-card-title {
    font-family: 'Bebas Neue', sans-serif; font-size: 1.3rem;
    letter-spacing: 1.5px; line-height: 1.2; margin-bottom: 10px;
}
.blog-card-title a { color: var(--white, #fff); text-transform: uppercase; }
.blog-card-title a:hover { color: var(--gold, #D4AF37); }

.blog-card-excerpt {
    font-size: 0.88rem; color: #777; line-height: 1.6;
    margin-bottom: 16px; flex: 1;
}

.blog-card-read {
    font-family: 'Barlow Condensed', sans-serif; font-weight: 600;
    font-size: 0.82rem; letter-spacing: 1px; text-transform: uppercase;
    color: var(--gold, #D4AF37);
}
.blog-card-read:hover { color: var(--gold-light, #e6c84a); }

@media (max-width: 900px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .blog-grid { grid-template-columns: 1fr; } }

/* ============================================
   FEATURED DOGS — PEDIGREE DATABASE
   ============================================ */
.tk-featured-dogs {
    margin-bottom: 40px; padding: 30px 0;
    border-top: 1px solid var(--border, rgba(255,255,255,0.06));
    border-bottom: 1px solid var(--border, rgba(255,255,255,0.06));
}

.tk-featured-header {
    text-align: center; margin-bottom: 24px;
    display: flex; align-items: center; justify-content: center; gap: 12px;
}
.tk-featured-star { color: var(--gold, #D4AF37); font-size: 1.1rem; }
.tk-featured-label {
    font-family: 'Bebas Neue', sans-serif; font-size: 1.4rem;
    color: var(--gold, #D4AF37); letter-spacing: 3px; text-transform: uppercase;
}

.tk-featured-grid, .dog-grid-5col {
    grid-template-columns: repeat(5, 1fr); gap: 16px;
}
.dog-grid-5col .dog-card { padding: 16px; }
.dog-grid-5col .dog-card-image img { width: 130px; height: 130px; }
.dog-grid-5col .dog-card-title { font-size: 0.9rem; letter-spacing: 0.5px; }
.dog-grid-5col .dog-card-meta { font-size: 0.75rem; }
.dog-grid-5col .dog-card-id { font-size: 0.65rem; }

@media (max-width: 900px) {
    .dog-grid-5col { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 560px) {
    .dog-grid-5col { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .dog-grid-5col .dog-card-image img { width: 100px; height: 100px; }
}

/* ============================================
   HERO SLIDER
   ============================================ */
.tk-slider {
    position: relative; width: 100%; overflow: hidden;
    background: #000;
}
.tk-slider-track { position: relative; width: 100%; }

.tk-slide {
    position: absolute; top: 0; left: 0; width: 100%; 
    opacity: 0; transition: opacity 0.8s ease-in-out;
    z-index: 1;
}
.tk-slide.active { position: relative; opacity: 1; z-index: 2; }

.tk-slide img {
    width: 100%; height: auto; display: block;
    max-height: 500px; object-fit: cover;
}

.tk-slide-overlay {
    position: absolute; bottom: 0; left: 0; right: 0;
    background: linear-gradient(transparent, rgba(0,0,0,0.75));
    padding: 60px 0 40px; z-index: 3;
}
.tk-slide-heading {
    font-family: 'Bebas Neue', sans-serif; font-size: 3rem;
    color: #fff; letter-spacing: 4px; text-transform: uppercase;
    text-shadow: 0 2px 8px rgba(0,0,0,0.6); margin-bottom: 6px;
}
.tk-slide-text {
    font-family: 'Barlow Condensed', sans-serif; font-size: 1.1rem;
    color: var(--gold, #D4AF37); letter-spacing: 2px; text-transform: uppercase;
}

/* Arrows */
.tk-slider-arrow {
    position: absolute; top: 50%; transform: translateY(-50%);
    z-index: 10; background: rgba(0,0,0,0.5); color: #fff;
    border: none; font-size: 1.4rem; padding: 14px 16px;
    cursor: pointer; transition: background 0.3s;
}
.tk-slider-arrow:hover { background: var(--gold, #D4AF37); color: #000; }
.tk-slider-prev { left: 0; border-radius: 0 4px 4px 0; }
.tk-slider-next { right: 0; border-radius: 4px 0 0 4px; }

/* Dots */
.tk-slider-dots {
    position: absolute; bottom: 16px; left: 50%; transform: translateX(-50%);
    z-index: 10; display: flex; gap: 8px;
}
.tk-slider-dot {
    width: 10px; height: 10px; border-radius: 50%; border: 2px solid rgba(255,255,255,0.5);
    background: transparent; cursor: pointer; transition: all 0.3s; padding: 0;
}
.tk-slider-dot.active, .tk-slider-dot:hover {
    background: var(--gold, #D4AF37); border-color: var(--gold, #D4AF37);
}

@media (max-width: 768px) {
    .tk-slide img { max-height: 300px; }
    .tk-slide-heading { font-size: 1.8rem; letter-spacing: 2px; }
    .tk-slide-text { font-size: 0.85rem; }
    .tk-slider-arrow { padding: 10px 12px; font-size: 1rem; }
}
@media (max-width: 480px) {
    .tk-slide img { max-height: 200px; }
    .tk-slide-overlay { padding: 30px 0 20px; }
    .tk-slide-heading { font-size: 1.3rem; }
}
/* ============================================
   SINGLE DOG PROFILE — DARK THEME KILL SWITCH
   Neutralizes ALL dark-theme rules inside
   .dog-profile-wrap so dog-profile.css wins.
   ============================================ */

/* Nuclear reset: kill dark backgrounds, glass, borders */
.dog-profile-wrap,
.dog-profile-wrap .pedigree-section,
.dog-profile-wrap .ped-stats-section,
.dog-profile-wrap .pedigree-share,
.dog-profile-wrap .pedigree-panel,
.dog-profile-wrap .pedigree-tabs button,
.dog-profile-wrap .tk-related-pups-section,
.dog-profile-wrap .tk-blink-btn,
.dog-profile-wrap .tk-featured-dogs,
.dog-profile-wrap .tk-featured-header,
.dog-profile-wrap .glass,
.dog-profile-wrap .glass-gold,
.dog-profile-wrap .disclaimer-box {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  text-shadow: none !important;
}

/* These need explicit light backgrounds, NOT transparent */
.dog-profile-wrap .glass-card,
.dog-profile-wrap .dog-card,
.dog-profile-wrap .pup-card,
.dog-profile-wrap .litter-card,
.dog-profile-wrap .share-btn,
.dog-profile-wrap .pedigree-table td,
.dog-profile-wrap .btn,
.dog-profile-wrap .btn-gold {
  background: #f1f1f1 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  text-shadow: none !important;
}

/* Grids use black background for 1px gap borders */
.dog-profile-wrap .dog-grid,
.dog-profile-wrap .pup-grid {
  background: #000 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-radius: 0 !important;
}

/* Kill dark body pseudo-elements bleeding in */
.dog-profile-wrap::before,
.dog-profile-wrap::after {
  display: none !important;
}

/* Constrain ALL SVGs inside dog profile */
.dog-profile-wrap svg {
  max-width: 1em !important;
  max-height: 1em !important;
}
.dog-profile-wrap .view-count svg {
  width: 14px !important;
  height: 14px !important;
}
.dog-profile-wrap .bfkc-badge {
  width: 18px !important;
  height: 18px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  background: #666 !important;
  flex-shrink: 0 !important;
}
.dog-profile-wrap .bfkc-badge svg {
  width: 12px !important;
  height: 12px !important;
  fill: #fff !important;
}

/* Inbreeding card - force light backgrounds */
.dog-profile-wrap .inbreeding-card {
  display: flex !important;
  background: #f1f1f1 !important;
}
.dog-profile-wrap .inbreeding-stat {
  flex: 1 !important;
  background: #f1f1f1 !important;
  padding: 12px !important;
  text-align: center !important;
}
.dog-profile-wrap .info-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 14px !important;
  height: 14px !important;
  background: #1565C0 !important;
  color: #fff !important;
  border-radius: 50% !important;
  font-size: 9px !important;
}

/* Reset pedigree-section dark theme */
.dog-profile-wrap .pedigree-section {
  background: transparent !important;
  border-top: none !important;
  border-bottom: none !important;
  padding: 0 !important;
  margin: 6px 0 !important;
}
.dog-profile-wrap .pedigree-section h2 {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 11px !important;
  color: #fff !important;
  background: #666 !important;
  padding: 5px 10px !important;
  letter-spacing: 0 !important;
  text-align: left !important;
  margin: 0 !important;
}

/* Reset pedigree table */
.dog-profile-wrap .pedigree-table {
  border-collapse: separate !important;
  border-spacing: 1px !important;
  background: #000 !important;
  font-size: 10px !important;
}
.dog-profile-wrap .pedigree-table td {
  background: #f1f1f1 !important;
  border: none !important;
  color: #1A6742 !important;
  padding: 5px 8px !important;
  white-space: normal !important;
}
.dog-profile-wrap .pedigree-table td:hover {
  background: #e8e8e8 !important;
}
.dog-profile-wrap .pedigree-table td a {
  color: #1A6742 !important;
}
.dog-profile-wrap .pedigree-table td a:hover {
  color: #000 !important;
}

/* Scale fonts for higher generations */
.dog-profile-wrap .pedigree-panel[data-gen="5"] .pedigree-table { font-size: 9px !important; }
.dog-profile-wrap .pedigree-panel[data-gen="6"] .pedigree-table { font-size: 8px !important; }
.dog-profile-wrap .pedigree-panel[data-gen="7"] .pedigree-table { font-size: 7px !important; }
.dog-profile-wrap .pedigree-panel[data-gen="8"] .pedigree-table { font-size: 6.5px !important; }

/* Reset pedigree tabs */
.dog-profile-wrap .pedigree-tabs button {
  background: none !important;
  border: none !important;
  border-right: 1px solid #ccc !important;
  color: #666 !important;
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 11px !important;
  font-weight: bold !important;
  border-radius: 0 !important;
  letter-spacing: 0 !important;
  padding: 4px 10px !important;
}
.dog-profile-wrap .pedigree-tabs button:hover,
.dog-profile-wrap .pedigree-tabs button.active {
  color: #fff !important;
  background: #666 !important;
}

/* Reset share buttons */
.dog-profile-wrap .pedigree-share {
  background: #f1f1f1 !important;
  border: 1px solid #000 !important;
  margin: 6px 0 !important;
  padding: 8px !important;
  gap: 4px !important;
}
.dog-profile-wrap .pedigree-share-label {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 11px !important;
  color: #666 !important;
  letter-spacing: 0 !important;
}
.dog-profile-wrap .share-btn {
  background: #666 !important;
  color: #fff !important;
  border: 1px solid #333 !important;
  border-radius: 0 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  padding: 4px 12px !important;
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 10px !important;
  font-weight: bold !important;
  letter-spacing: 0 !important;
}
.dog-profile-wrap .share-btn:hover {
  background: #555 !important;
  color: #fff !important;
  border-color: #333 !important;
  transform: none !important;
}
.dog-profile-wrap .share-btn.share-facebook:hover { background: #1877f2 !important; border-color: #1877f2 !important; }
.dog-profile-wrap .share-btn.share-twitter:hover { background: #1da1f2 !important; border-color: #1da1f2 !important; }
.dog-profile-wrap .share-btn.share-whatsapp:hover { background: #25d366 !important; border-color: #25d366 !important; }
.dog-profile-wrap .share-btn.share-copy.copied { background: #4caf50 !important; border-color: #4caf50 !important; }

/* Reset pedigree stats dashboard */
.dog-profile-wrap .ped-stats-section {
  background: transparent !important;
  border-top: none !important;
  padding: 0 !important;
}
.dog-profile-wrap .ped-stats-header {
  background: #666 !important;
  padding: 5px 10px !important;
  margin-bottom: 0 !important;
  text-align: left !important;
}
.dog-profile-wrap .ped-stats-section .section-tag,
.dog-profile-wrap .ped-stats-section .page-title,
.dog-profile-wrap .ped-stats-header .page-title {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 11px !important;
  color: #fff !important;
  letter-spacing: 0 !important;
  -webkit-text-fill-color: #fff !important;
}
.dog-profile-wrap .ped-stats-subtitle {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 10px !important;
  color: #666 !important;
  letter-spacing: 0 !important;
}
.dog-profile-wrap .ped-stat-card {
  background: #f1f1f1 !important;
  border: 1px solid #000 !important;
  border-radius: 0 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  padding: 10px !important;
}
.dog-profile-wrap .ped-stat-card:hover {
  transform: none !important;
  border-color: #000 !important;
}
.dog-profile-wrap .ped-stat-card-title {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 11px !important;
  font-weight: bold !important;
  color: #666 !important;
  letter-spacing: 0 !important;
  opacity: 1 !important;
}
.dog-profile-wrap .coi-number {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 32px !important;
  color: #1A6742 !important;
  letter-spacing: 0 !important;
}
.dog-profile-wrap .coi-tier {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 11px !important;
  font-weight: bold !important;
  color: #666 !important;
  letter-spacing: 0 !important;
}
.dog-profile-wrap .coi-ref-table tr {
  border-bottom: 1px solid #ddd !important;
}
.dog-profile-wrap .coi-ref-table td {
  color: #333 !important;
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 10px !important;
  padding: 6px 8px !important;
}
.dog-profile-wrap .coi-ref-table td:nth-child(2) {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  color: #1A6742 !important;
  font-weight: bold !important;
}
.dog-profile-wrap .coi-ref-note {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 9px !important;
  color: #666 !important;
  border-top: 1px solid #ddd !important;
}
.dog-profile-wrap .ped-stat-metric {
  background: #f1f1f1 !important;
  border: 1px solid #000 !important;
  border-radius: 0 !important;
}
.dog-profile-wrap .ped-stat-metric:hover {
  transform: none !important;
  border-color: #000 !important;
}
.dog-profile-wrap .ped-metric-icon {
  color: #666 !important;
  opacity: 1 !important;
}
.dog-profile-wrap .ped-metric-value {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 20px !important;
  color: #1A6742 !important;
  letter-spacing: 0 !important;
}
.dog-profile-wrap .ped-metric-value small {
  color: #666 !important;
}
.dog-profile-wrap .ped-metric-label {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 10px !important;
  color: #666 !important;
  letter-spacing: 0 !important;
}
.dog-profile-wrap .ped-stats-row {
  gap: 1px !important;
  background: #000 !important;
  margin-bottom: 1px !important;
}
.dog-profile-wrap .ped-ancestor-table { font-size: 10px !important; }
.dog-profile-wrap .ped-ancestor-table thead th {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 10px !important;
  color: #fff !important;
  background: #666 !important;
  letter-spacing: 0 !important;
  border-bottom: none !important;
  padding: 5px 8px !important;
}
.dog-profile-wrap .ped-ancestor-table tbody td {
  background: #f1f1f1 !important;
  border-bottom: none !important;
  color: #1A6742 !important;
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 10px !important;
  padding: 5px 8px !important;
}
.dog-profile-wrap .ped-ancestor-table tbody td a { color: #1A6742 !important; }
.dog-profile-wrap .ped-ancestor-table tbody td a:hover { color: #000 !important; }
.dog-profile-wrap .ped-ancestor-table tbody tr:hover td { background: #e8e8e8 !important; }
.dog-profile-wrap .ped-impact-bar-bg { background: #ddd !important; }
.dog-profile-wrap .ped-impact-bar { background: #1A6742 !important; }
.dog-profile-wrap .ped-stat-no-data { color: #666 !important; }
.dog-profile-wrap .ped-stat-no-data i { color: #B8860B !important; }

/* Reset blink button */
.dog-profile-wrap .tk-blink-btn {
  background: #2E7D32 !important;
  color: #fff !important;
  border: 1px solid #1b5e20 !important;
  border-radius: 0 !important;
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 11px !important;
  font-weight: bold !important;
  letter-spacing: 0 !important;
  padding: 8px 20px !important;
  animation: none !important;
  box-shadow: none !important;
}
.dog-profile-wrap .tk-blink-btn:hover {
  background: #1b5e20 !important;
  transform: none !important;
  box-shadow: none !important;
}

/* Reset related pups section */
.dog-profile-wrap .tk-related-pups-section {
  margin-top: 0 !important;
  padding-top: 0 !important;
  border-top: none !important;
}
.dog-profile-wrap .tk-related-pups-title {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 14px !important;
  color: #1A6742 !important;
  letter-spacing: 0 !important;
  -webkit-text-fill-color: #1A6742 !important;
}
.dog-profile-wrap .tk-related-pups-sub {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 11px !important;
  color: #666 !important;
  letter-spacing: 0 !important;
}

/* Reset dog-card / pup-card inside dog profile */
.dog-profile-wrap .dog-card {
  background: #f1f1f1 !important;
  border: none !important;
  border-radius: 0 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  padding: 8px !important;
  text-align: center !important;
}
.dog-profile-wrap .dog-card:hover {
  transform: none !important;
  box-shadow: none !important;
  border-color: transparent !important;
  background: #e8e8e8 !important;
}
.dog-profile-wrap .dog-card-image img {
  border: 1px solid #999 !important;
  border-radius: 0 !important;
  filter: none !important;
}
.dog-profile-wrap .dog-card-title {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 11px !important;
  color: #1A6742 !important;
  letter-spacing: 0 !important;
  -webkit-text-fill-color: #1A6742 !important;
}
.dog-profile-wrap .dog-card-title:hover { color: #000 !important; -webkit-text-fill-color: #000 !important; }
.dog-profile-wrap .dog-card-meta { color: #666 !important; font-family: Verdana, Arial, Helvetica, sans-serif !important; font-size: 10px !important; }
.dog-profile-wrap .dog-card-id { color: #999 !important; font-size: 9px !important; }

.dog-profile-wrap .pup-card {
  background: #f1f1f1 !important;
  border: none !important;
  border-radius: 0 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.dog-profile-wrap .pup-card:hover {
  transform: none !important;
  border-color: transparent !important;
  background: #e8e8e8 !important;
}
.dog-profile-wrap .pup-card-title {
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 11px !important;
  color: #1A6742 !important;
  letter-spacing: 0 !important;
  -webkit-text-fill-color: #1A6742 !important;
}
.dog-profile-wrap .pup-card-body { padding: 8px !important; }
.dog-profile-wrap .pup-detail { color: #666 !important; font-family: Verdana, Arial, Helvetica, sans-serif !important; font-size: 10px !important; }
.dog-profile-wrap .pup-detail i { color: #666 !important; }
.dog-profile-wrap .pup-card-parents { color: #666 !important; border-top: 1px solid #ddd !important; font-family: Verdana, Arial, Helvetica, sans-serif !important; }
.dog-profile-wrap .pup-card-parents a { color: #1A6742 !important; }
.dog-profile-wrap .pup-card-price { color: #1A6742 !important; font-family: Verdana, Arial, Helvetica, sans-serif !important; font-size: 14px !important; }
.dog-profile-wrap .pup-badge-available { background: #2E7D32 !important; color: #fff !important; }
.dog-profile-wrap .pup-badge-reserved { background: #B8860B !important; }
.dog-profile-wrap .pup-badge-sold { background: #666 !important; }

/* Reset BFKC badge inside dog profile */
.dog-profile-wrap .tk-bfkc-badge::after {
  background: #f1f1f1 !important;
  color: #1A6742 !important;
  border: 1px solid #ccc !important;
  border-radius: 0 !important;
}

/* Reset litter-card inside dog profile */
.dog-profile-wrap .litter-card,
.dog-profile-wrap .litter-details {
  background: #f1f1f1 !important;
  border: none !important;
  border-radius: 0 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.dog-profile-wrap .litter-card:hover {
  transform: none !important;
  box-shadow: none !important;
}

/* Reset grids inside dog profile */
.dog-profile-wrap .dog-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)) !important;
  gap: 1px !important;
  background: #000 !important;
  padding: 1px !important;
}
.dog-profile-wrap .pup-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)) !important;
  gap: 1px !important;
  background: #000 !important;
  padding: 1px !important;
}

/* Reset .btn inside dog profile */
.dog-profile-wrap .btn,
.dog-profile-wrap .btn-gold {
  background: #2E7D32 !important;
  color: #fff !important;
  border-radius: 0 !important;
  border: 1px solid #1b5e20 !important;
  box-shadow: none !important;
  font-family: Verdana, Arial, Helvetica, sans-serif !important;
  font-size: 11px !important;
  font-weight: bold !important;
  letter-spacing: 0 !important;
  padding: 6px 16px !important;
}
.dog-profile-wrap .btn:hover,
.dog-profile-wrap .btn-gold:hover {
  background: #1b5e20 !important;
  transform: none !important;
  box-shadow: none !important;
  color: #fff !important;
}
.dog-profile-wrap .btn::before,
.dog-profile-wrap .btn-gold::before { display: none !important; }

/* Chart.js canvas containers */
.dog-profile-wrap .ped-chart-wrap {
  background: #f1f1f1 !important;
}

/* ============================================
   PEDIGREE DATABASE PAGE — OnlinePedigrees Palette
   Replace existing pedigree-search-form and
   pedigree-results-table styles in style.css
   ============================================ */

/* Page background override for pedigree template */
.page-template-page-pedigree-database .site-content {
  background: #E0F8E2;
}
.page-template-page-pedigree-database .page-header {
  background: #666;
  padding: 8px 16px;
  margin-bottom: 10px;
  border: 1px solid #000;
}
.page-template-page-pedigree-database .page-title {
  font-family: Verdana, Arial, Helvetica, sans-serif;
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0;
}

/* Search Form */
.pedigree-search-form {
  display: flex;
  gap: 3px;
  margin-bottom: 16px;
  background: #000;
  padding: 1px;
}
.pedigree-search-form input[type="text"] {
  flex: 1;
  padding: 8px 12px;
  font-family: Verdana, Arial, Helvetica, sans-serif;
  font-size: 11px;
  border: none;
  background: #f1f1f1;
  color: #1A6742;
  border-radius: 0;
  outline: none;
}
.pedigree-search-form input[type="text"]::placeholder { color: #999; }
.pedigree-search-form button {
  padding: 8px 18px;
  background: #666;
  color: #fff;
  border: none;
  border-radius: 0;
  font-family: Verdana, Arial, Helvetica, sans-serif;
  font-weight: bold;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0;
  cursor: pointer;
  box-shadow: none;
}
.pedigree-search-form button:hover { background: #555; }

/* Results count */
.page-template-page-pedigree-database .site-content p {
  color: #666;
  font-family: Verdana, Arial, Helvetica, sans-serif;
  font-size: 11px;
}

/* Results Table */
.pedigree-results-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 1px;
  background: #000;
}
.pedigree-results-table th {
  background: #666;
  color: #fff;
  font-family: Verdana, Arial, Helvetica, sans-serif;
  font-weight: bold;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0;
  padding: 6px 10px;
  text-align: left;
  border-bottom: none;
}
.pedigree-results-table td {
  padding: 5px 10px;
  background: #f1f1f1;
  border-bottom: none;
  color: #1A6742;
  font-family: Verdana, Arial, Helvetica, sans-serif;
  font-size: 11px;
}
.pedigree-results-table tr:hover td { background: #e8e8e8; }
.pedigree-results-table td a { color: #1A6742; font-weight: bold; }
.pedigree-results-table td a:hover { color: #000; text-decoration: underline; }

/* Featured Dogs section */
.tk-featured-dogs {
  margin-bottom: 16px;
  background: #000;
  padding: 1px;
}
.tk-featured-header {
  background: #666;
  color: #fff;
  text-align: center;
  padding: 5px 10px;
  font-family: Verdana, Arial, Helvetica, sans-serif;
  font-size: 11px;
  font-weight: bold;
}
.tk-featured-star { color: #B8860B; }

/* Disclaimer card override */
.page-template-page-pedigree-database .pedigree-disclaimer {
  background: #f1f1f1;
  border: 1px solid #000;
  border-left: 3px solid #B8860B;
  border-radius: 0;
  backdrop-filter: none;
  padding: 10px 14px;
}
.page-template-page-pedigree-database .pedigree-disclaimer p {
  font-size: 10px;
  color: #666;
}
.page-template-page-pedigree-database .pedigree-disclaimer a {
  color: #1A6742;
  font-weight: bold;
}

/* Pagination */
.page-template-page-pedigree-database .pagination {
  margin-top: 10px;
  text-align: center;
}
.page-template-page-pedigree-database .pagination a,
.page-template-page-pedigree-database .pagination span {
  display: inline-block;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: bold;
  background: #f1f1f1;
  color: #1A6742;
  border: 1px solid #ccc;
  text-decoration: none;
  font-family: Verdana, Arial, Helvetica, sans-serif;
}
.page-template-page-pedigree-database .pagination a:hover {
  background: #e8e8e8;
}
.page-template-page-pedigree-database .pagination .current {
  background: #666;
  color: #fff;
  border-color: #000;
}

/* Dog cards inside pedigree database */
.page-template-page-pedigree-database .dog-card {
  background: #f1f1f1;
  border: none;
  border-radius: 0;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  padding: 8px;
}
.page-template-page-pedigree-database .dog-card:hover {
  transform: none;
  box-shadow: none;
  background: #e8e8e8;
  border-color: transparent;
}
.page-template-page-pedigree-database .dog-card-image img {
  border: 1px solid #999;
  border-radius: 0;
  filter: none;
}
.page-template-page-pedigree-database .dog-card-title {
  font-family: Verdana, Arial, Helvetica, sans-serif;
  font-size: 11px;
  color: #1A6742;
  letter-spacing: 0;
}
.page-template-page-pedigree-database .dog-card-title:hover { color: #000; }
.page-template-page-pedigree-database .dog-card-meta {
  color: #666;
  font-family: Verdana, Arial, Helvetica, sans-serif;
  font-size: 10px;
}
.page-template-page-pedigree-database .dog-card-id { color: #999; font-size: 9px; }
.page-template-page-pedigree-database .dog-grid {
  gap: 1px;
  background: #000;
  padding: 1px;
}
.page-template-page-pedigree-database .dog-grid-5col {
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: #000;
  padding: 1px;
}
@media (max-width: 900px) {
  .page-template-page-pedigree-database .dog-grid-5col { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 560px) {
  .page-template-page-pedigree-database .dog-grid-5col { grid-template-columns: repeat(2, 1fr); }
}