/* ===== Two Tails Homepage ===== */
:root {
    --tt-pink: #FF69B4;
    --tt-pink-light: #FFB6D9;
    --tt-yellow: #E8E048;
    --tt-yellow-soft: #FFF7AE;
    --tt-teal: #40E0D0;
    --tt-teal-light: #B2F5EA;
    --tt-lavender: #CE93D8;
    --tt-lavender-light: #E8D5F5;
    --tt-orange: #FF7043;
    --tt-dark: #2D2D3F;
    --tt-white: #FFFDF7;
}
/* Fix mobile scroll blocked by theme */
body#index, body#index html { overflow-y: auto !important; height: auto !important; min-height: 100vh !important; }
body#index #wrapper { overflow: visible !important; }
/* Hide old theme promo banner (we have our own) */
body#index .header-banner { display: none !important; }
/* Break out of theme container */
.tt-homepage {
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    font-family: 'Nunito', sans-serif;
    color: var(--tt-dark);
    overflow-x: clip;
    background: var(--tt-white);
}
.tt-homepage * { box-sizing: border-box; }
.tt-homepage h1, .tt-homepage h2, .tt-homepage h3, .tt-homepage h4 { font-family: 'Lilita One', cursive; }
.tt-homepage a { text-decoration: none; }
.tt-homepage ul { list-style: none; padding: 0; margin: 0; }
/* HERO */
.tt-hero-slider { position: relative; min-height: 85vh; overflow: hidden; }
.tt-hero-track { position: relative; min-height: 85vh; }
.tt-hero-slide { position: absolute; inset: 0; display: flex; align-items: center; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.55s ease, visibility 0.55s ease; }
.tt-hero-slide.active { opacity: 1; visibility: visible; pointer-events: auto; z-index: 2; }
.tt-hero-slide::before { content: ''; position: absolute; inset: 0; background-image: radial-gradient(circle at 10% 20%, rgba(255,255,255,0.18) 2px, transparent 2px), radial-gradient(circle at 90% 80%, rgba(255,255,255,0.2) 3px, transparent 3px), radial-gradient(circle at 50% 10%, rgba(255,255,255,0.12) 2px, transparent 2px), radial-gradient(circle at 80% 30%, rgba(255,255,255,0.18) 4px, transparent 4px); background-size: 200px 200px; opacity: 0.55; }
.tt-slide-dogs { background: var(--tt-teal); }
.tt-slide-cats { background: linear-gradient(135deg, var(--tt-lavender) 0%, #b884d8 100%); }
.tt-slide-cats::before { background-image: radial-gradient(circle at 15% 22%, rgba(255,255,255,0.18) 3px, transparent 3px), radial-gradient(circle at 85% 78%, rgba(255,182,217,0.35) 4px, transparent 4px), radial-gradient(circle at 55% 12%, rgba(255,247,174,0.3) 3px, transparent 3px), radial-gradient(circle at 78% 34%, rgba(255,255,255,0.16) 5px, transparent 5px); }
.tt-hero-content { display: grid; grid-template-columns: 1fr 1fr; max-width: 1300px; width: 100%; min-height: 85vh; margin: 0 auto; padding: 40px; gap: 40px; align-items: center; position: relative; z-index: 2; }
.tt-hero-text h1 { font-size: 4.5rem; color: var(--tt-yellow); text-shadow: 3px 3px 0 var(--tt-dark); line-height: 1; margin-bottom: 16px; }
.tt-tagline { font-family: 'Lilita One', cursive; font-size: 1.6rem; color: var(--tt-dark); background: var(--tt-yellow); display: inline-block; padding: 6px 20px; border-radius: 50px; transform: rotate(-2deg); margin-bottom: 24px; }
.tt-hero-text p { color: white; font-size: 1.15rem; font-weight: 600; margin-bottom: 32px; max-width: 420px; }
.tt-hero-actions { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.tt-btn-primary { background: var(--tt-yellow); color: var(--tt-dark); font-family: 'Lilita One', cursive; font-size: 1.3rem; padding: 16px 40px; border: 3px solid var(--tt-dark); border-radius: 50px; cursor: pointer; display: inline-block; transition: all 0.3s; box-shadow: 4px 4px 0 var(--tt-dark); }
.tt-btn-primary:hover { transform: translate(-2px, -2px); box-shadow: 6px 6px 0 var(--tt-dark); color: var(--tt-dark); }
.tt-btn-secondary { background: white; color: var(--tt-dark); font-family: 'Lilita One', cursive; font-size: 1.1rem; padding: 14px 32px; border: 3px solid var(--tt-dark); border-radius: 50px; cursor: pointer; display: inline-block; transition: all 0.3s; margin-left: 12px; }
.tt-btn-secondary:hover { background: var(--tt-dark); color: white; }
.tt-hero-actions .tt-btn-secondary { margin-left: 0; }
.tt-hero-image { position: relative; }
.tt-hero-image img { width: 100%; max-width: 550px; border-radius: 30px; border: 5px solid white; box-shadow: 8px 8px 0 var(--tt-dark); transform: rotate(2deg); transition: transform 0.5s; }
.tt-hero-image img:hover { transform: rotate(-1deg) scale(1.02); }
.tt-hero-sticker { position: absolute; animation: tt-float 3s ease-in-out infinite; }
.tt-hero-sticker.s1 { top: -20px; right: 40px; font-size: 3rem; }
.tt-hero-sticker.s2 { bottom: 20px; left: -20px; font-size: 2.5rem; animation-delay: 0.5s; }
.tt-hero-sticker.s3 { top: 40%; right: -30px; animation-delay: 1s; }
.tt-sticker-badge { background: var(--tt-yellow); color: var(--tt-dark); font-family: 'Lilita One', cursive; padding: 12px 20px; border-radius: 50%; border: 3px solid var(--tt-dark); font-size: 0.9rem; transform: rotate(12deg); box-shadow: 3px 3px 0 var(--tt-dark); width: 100px; height: 100px; display: flex; align-items: center; justify-content: center; text-align: center; line-height: 1.1; }
@keyframes tt-float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
.tt-slide-cats .tt-hero-text h1 { color: var(--tt-white); text-shadow: 3px 3px 0 var(--tt-dark); }
.tt-slide-cats .tt-tagline { background: var(--tt-yellow-soft); }
.tt-slide-cats .tt-btn-primary { background: var(--tt-pink-light); }
.tt-slider-dots { position: absolute; left: 50%; bottom: 30px; z-index: 4; display: flex; gap: 12px; transform: translateX(-50%); }
.tt-dot { width: 14px; height: 14px; padding: 0; border-radius: 999px; border: 2px solid var(--tt-dark); background: rgba(255,255,255,0.55); cursor: pointer; transition: transform 0.2s ease, background 0.2s ease; }
.tt-dot.active { background: var(--tt-yellow); transform: scale(1.15); }
.tt-slider-arrow { position: absolute; top: 50%; z-index: 4; width: 54px; height: 54px; border: 3px solid var(--tt-dark); border-radius: 50%; background: rgba(255,255,255,0.9); color: var(--tt-dark); font-size: 2rem; line-height: 1; display: flex; align-items: center; justify-content: center; cursor: pointer; box-shadow: 4px 4px 0 var(--tt-dark); transform: translateY(-50%); transition: transform 0.2s ease, background 0.2s ease; }
.tt-slider-arrow:hover { background: var(--tt-yellow); transform: translateY(-50%) scale(1.04); }
.tt-arrow-prev { left: 24px; }
.tt-arrow-next { right: 24px; }
/* TRUST BAR */
.tt-trust-bar { background: var(--tt-yellow); padding: 20px 40px; display: flex; justify-content: center; gap: 60px; flex-wrap: wrap; border-top: 3px solid var(--tt-dark); border-bottom: 3px solid var(--tt-dark); }
.tt-trust-item { display: flex; align-items: center; gap: 10px; font-weight: 700; font-size: 0.95rem; color: var(--tt-dark); }
.tt-trust-item .tt-icon { font-size: 1.8rem; line-height: 1; }
.tt-trust-item strong { display: block; }
.tt-trust-item small { font-weight: 600; font-size: 0.8rem; opacity: 0.7; }
/* SECTION TITLES */
.tt-section-title { font-size: 3rem; color: var(--tt-teal); text-shadow: 2px 2px 0 var(--tt-teal-light); margin-bottom: 8px; }
.tt-section-subtitle { font-size: 1.1rem; color: #888; font-weight: 600; margin-bottom: 48px; }
/* CATEGORIES */
.tt-categories { padding: 80px 40px; max-width: 1300px; margin: 0 auto; text-align: center; }
.tt-cat-grid { display: grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: 24px !important; }
.tt-cat-card { background: white; border-radius: 24px; border: 3px solid var(--tt-dark); overflow: hidden; transition: all 0.3s; cursor: pointer; text-decoration: none !important; color: var(--tt-dark); box-shadow: 4px 4px 0 var(--tt-dark); display: block !important; }
.tt-cat-card:hover { transform: translate(-3px, -3px); box-shadow: 7px 7px 0 var(--tt-dark); color: var(--tt-dark); }
.tt-cat-card-img { height: 200px; position: relative; overflow: hidden; }
.tt-cat-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s; }
.tt-cat-card:hover .tt-cat-card-img img { transform: scale(1.08); }
.tt-cat-card-body { padding: 20px; text-align: left; }
.tt-cat-card-body h3 { font-size: 1.3rem; margin-bottom: 4px; }
.tt-cat-card-body p { font-size: 0.85rem; color: #999; font-weight: 600; }
.tt-badge-count { background: var(--tt-teal); color: white; padding: 3px 12px; border-radius: 50px; font-size: 0.75rem; font-weight: 800; display: inline-block; margin-top: 8px; }
/* DOUBLE FEATURE */
.tt-double-feature { padding: 0 40px 80px; max-width: 1300px; margin: 0 auto; display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 24px; }
.tt-feature-card { border-radius: 30px; padding: 48px; display: flex; align-items: center; gap: 32px; border: 3px solid var(--tt-dark); box-shadow: 5px 5px 0 var(--tt-dark); overflow: hidden; }
.tt-feature-card.dogs { background: var(--tt-teal-light); }
.tt-feature-card.cats { background: var(--tt-lavender-light); }
.tt-feature-card img { width: 220px; height: 220px; object-fit: cover; border-radius: 20px; border: 3px solid var(--tt-dark); flex-shrink: 0; }
.tt-feature-card h3 { font-size: 2rem; margin-bottom: 12px; }
.tt-feature-card p { font-weight: 600; margin-bottom: 20px; color: #555; }
/* GALLERY MARQUEE */
.tt-gallery-section { background: var(--tt-teal); padding: 60px 0; overflow: hidden; border-top: 3px solid var(--tt-dark); border-bottom: 3px solid var(--tt-dark); }
.tt-gallery-section .tt-section-title { color: var(--tt-yellow); text-shadow: 2px 2px 0 var(--tt-dark); }
.tt-gallery-section .tt-section-subtitle { color: rgba(255,255,255,0.8); }
.tt-marquee { display: flex; gap: 20px; animation: tt-marquee 30s linear infinite; width: max-content; }
.tt-marquee img { width: 280px; height: 380px; object-fit: cover; border-radius: 20px; border: 4px solid white; box-shadow: 4px 4px 0 var(--tt-dark); flex-shrink: 0; }
@keyframes tt-marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
/* ABOUT */
.tt-hp-about { padding: 80px 40px; max-width: 1300px; margin: 0 auto; display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 60px; align-items: center; }
.tt-about-image { position: relative; }
.tt-about-image img { width: 100%; border-radius: 30px; border: 4px solid var(--tt-dark); box-shadow: 6px 6px 0 var(--tt-dark); }
.tt-about-badge { position: absolute; top: -20px; right: -20px; background: var(--tt-yellow); color: var(--tt-dark); font-family: 'Lilita One', cursive; width: 110px; height: 110px; border-radius: 50%; display: flex; align-items: center; justify-content: center; text-align: center; font-size: 1rem; border: 3px solid var(--tt-dark); box-shadow: 3px 3px 0 var(--tt-dark); line-height: 1.1; transform: rotate(10deg); }
.tt-about-text h2 { font-size: 2.5rem; color: var(--tt-teal); margin-bottom: 8px; }
.tt-about-tag { background: var(--tt-lavender); color: white; font-family: 'Lilita One', cursive; padding: 4px 16px; border-radius: 50px; font-size: 0.85rem; display: inline-block; margin-bottom: 20px; }
.tt-about-text p { font-weight: 600; color: #555; line-height: 1.7; margin-bottom: 24px; }
.tt-about-perks { display: flex; flex-direction: column; gap: 12px; margin-bottom: 32px; }
.tt-about-perks li { font-weight: 700; display: flex; align-items: center; gap: 10px; }
.tt-about-perks li::before { content: '🐾'; font-size: 1.2rem; }
/* TESTIMONIALS */
.tt-hp-testimonials { background: #FFF7AE !important; padding: 80px 40px !important; text-align: center !important; border-top: 3px solid #2D2D3F !important; }
.tt-hp-testimonials .tt-section-title { color: var(--tt-dark); }
.tt-testi-grid { display: grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: 24px; max-width: 1100px; margin: 0 auto; }
.tt-testi-card { background: white; border-radius: 24px; padding: 32px; border: 3px solid var(--tt-dark); box-shadow: 4px 4px 0 var(--tt-dark); text-align: left; }
.tt-testi-card .tt-stars { color: var(--tt-yellow); font-size: 1.3rem; margin-bottom: 12px; letter-spacing: 2px; }
.tt-testi-card blockquote { font-weight: 600; font-style: italic; color: #555; margin-bottom: 16px; line-height: 1.6; padding: 0; border: none; }
.tt-testi-card .tt-author { display: flex; align-items: center; gap: 12px; }
.tt-testi-card .tt-author img { width: 44px; height: 44px; border-radius: 50%; border: 2px solid var(--tt-teal); }
.tt-testi-card .tt-author-info strong { font-size: 0.95rem; }
.tt-testi-card .tt-author-info small { color: #999; font-weight: 600; }
/* NEWSLETTER */
.tt-hp-newsletter { background: #40E0D0 !important; padding: 80px 40px !important; text-align: center !important; position: relative !important; overflow: hidden !important; border-top: 3px solid #2D2D3F !important; }
.tt-hp-newsletter::before { content: '' !important; position: absolute !important; top: 0; left: 0; right: 0; bottom: 0; background-image: radial-gradient(circle at 20% 30%, rgba(255,255,255,0.12) 3px, transparent 3px), radial-gradient(circle at 70% 60%, rgba(255,255,255,0.08) 4px, transparent 4px), radial-gradient(circle at 40% 80%, rgba(255,255,255,0.1) 2px, transparent 2px); background-size: 150px 150px; }
.tt-hp-newsletter-inner { position: relative; z-index: 2; max-width: 600px; margin: 0 auto; }
.tt-hp-newsletter h2 { font-size: 2.5rem; color: var(--tt-yellow); text-shadow: 2px 2px 0 var(--tt-dark); margin-bottom: 12px; }
.tt-hp-newsletter p { color: white; font-weight: 600; margin-bottom: 32px; font-size: 1.1rem; }
.tt-hp-newsletter-form { display: flex; gap: 0; max-width: 480px; margin: 0 auto; }
.tt-hp-newsletter-form input { flex: 1; padding: 16px 24px; border: 3px solid var(--tt-dark); border-right: none; border-radius: 50px 0 0 50px; font-family: 'Nunito', sans-serif; font-size: 1rem; font-weight: 600; outline: none; }
.tt-hp-newsletter-form button { background: var(--tt-yellow); color: var(--tt-dark); font-family: 'Lilita One', cursive; font-size: 1.1rem; padding: 16px 32px; border: 3px solid var(--tt-dark); border-radius: 0 50px 50px 0; cursor: pointer; transition: all 0.3s; }
.tt-hp-newsletter-form button:hover { background: var(--tt-dark); color: var(--tt-yellow); }
/* RESPONSIVE */
@media (max-width: 900px) {
    .tt-hero-content { grid-template-columns: 1fr !important; text-align: center; }
    .tt-hero-text h1 { font-size: 3rem; }
    .tt-hero-actions { justify-content: center; }
    .tt-hero-image { display: flex; justify-content: center; }
    .tt-hero-image img { max-width: 350px; }
    .tt-cat-grid { grid-template-columns: repeat(2, 1fr) !important; }
    .tt-double-feature { grid-template-columns: 1fr !important; }
    .tt-feature-card { flex-direction: column; text-align: center; padding: 32px 24px; gap: 24px; }
    .tt-feature-card > div { width: 100%; }
    .tt-feature-card img { width: min(100%, 260px); height: auto; }
    .tt-feature-card h3 { font-size: 1.8rem; }
    .tt-feature-card p { margin-bottom: 16px; }
    .tt-hp-about { grid-template-columns: 1fr !important; }
    .tt-testi-grid { grid-template-columns: 1fr !important; }
}
@media (max-width: 600px) {
    .tt-hero-text h1 { font-size: 2.4rem; }
    .tt-hero-actions { flex-direction: column; }
    .tt-hero-actions .tt-btn-primary, .tt-hero-actions .tt-btn-secondary { width: 100%; justify-content: center; margin-left: 0; text-align: center; }
    .tt-cat-grid { grid-template-columns: 1fr !important; }
    .tt-trust-bar { gap: 24px; }
    .tt-section-title { font-size: 2rem; }
    .tt-double-feature { padding: 0 20px 60px; gap: 18px; }
    .tt-feature-card { padding: 24px 18px; border-radius: 24px; }
    .tt-feature-card img { width: 100%; max-width: 240px; }
    .tt-feature-card h3 { font-size: 1.55rem; }
    .tt-feature-card p { font-size: 0.95rem; }
    .tt-feature-card .tt-btn-primary { font-size: 0.95rem !important; padding: 12px 22px !important; }
}
