/*
Theme Name: Song Finder by Lyrics
Theme URI: https://songfinderbylyrics.com
Description: Custom theme for Song Finder by Lyrics
Version: 2.0
*/

/* ─────────────────────────────────────────────────────────────────────
   1. RESET & BASE
───────────────────────────────────────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:Arial,sans-serif;background:linear-gradient(135deg,#084d98,#ff0000);color:#fff;line-height:1.6}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* ─────────────────────────────────────────────────────────────────────
   2. HEADER & NAVIGATION
───────────────────────────────────────────────────────────────────── */
header{position:relative;top:0;left:0;width:100%;height:83px;background:linear-gradient(180deg,#14144a 0%,#006cc3 100%);z-index:1002;box-shadow:0 2px 8px rgba(0,0,0,.11)}
.header-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:1200px;margin:0 auto;padding:0 1rem;height:83px}
.logo{font-size:1.2rem;font-weight:bold;position:relative;z-index:1}
.icon-btn{background:none;border:none;padding:.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center}
.icon-btn svg{width:1.5rem;height:1.5rem;fill:#fff}
.header-buttons{display:flex;gap:.5rem}
.desktop-nav{display:none}

.desktop-menu li{position:relative}
.desktop-menu .sub-menu{display:none;position:absolute;top:100%;left:0;background:#0f0d3f;padding:.5rem 0;list-style:none;box-shadow:0 2px 8px rgba(0,0,0,.15);z-index:999;min-width:180px}
.desktop-menu li:hover>.sub-menu{display:block}
.desktop-menu .sub-menu li a{display:block;padding:.5rem 1rem;font-size:.95rem;color:#fff;white-space:nowrap}
.desktop-menu .sub-menu li a:hover{background:#14144a}

/* Mobile nav overlay */
.nav-overlay{position:fixed;top:60px;left:0;width:100vw;height:calc(100vh - 60px);background:#fff;transform:translateX(-100%);transition:transform .3s ease;padding:2rem 1rem 1rem;z-index:1001;display:flex;flex-direction:column;align-items:center}
.nav-overlay.open{transform:translateX(0)}
.nav-overlay ul{display:flex;flex-direction:column;width:100%;padding:0}
.nav-overlay li+li{margin-top:.5rem}
.nav-overlay a{font-size:1.2rem;color:#14144a;padding:.75rem 0;border-bottom:1px solid #eee}
.nav-overlay a:hover{color:#f43}
#navClose{background:#fff;color:#14144a;border:1px solid #eee;width:40px;height:40px;border-radius:50%;box-shadow:0 2px 8px rgba(0,0,0,.1);margin:.75rem auto 0;display:flex;align-items:center;justify-content:center}
#navClose svg{fill:none;stroke:#14144a;stroke-width:2.5}

/* ─────────────────────────────────────────────────────────────────────
   3. HERO & SEARCH
───────────────────────────────────────────────────────────────────── */
.hero{text-align:center;padding:2.5rem 1rem 0}
.hero h1{font-size:clamp(1.8rem,5vw,2.8rem);margin:0 auto .75rem;font-weight:800}
.hero p{font-size:1rem;text-align:justify;max-width:800px;margin:0 auto 1.8rem;line-height:1.7}

.search-container{position:relative;width:100%;max-width:700px;margin:8px auto;display:flex;align-items:center;background:#fff;border-radius:999px;box-shadow:0 12px 30px rgba(20,20,43,.12);border:1px solid rgba(91,140,255,.4);transition:all .3s cubic-bezier(.68,-.55,.27,1.55);transform-origin:center;overflow:hidden;padding:0}
.search-container:hover,
.search-container:focus-within{transform:translateY(-4px) scale(1.02);box-shadow:0 15px 40px rgba(0,0,0,.25);border-color:#5b8cff}
.search-container:focus-within{box-shadow:0 15px 40px rgba(0,0,0,.25),0 0 0 3px rgba(91,140,255,.3)}
.search-container input{width:100%;padding:1.3rem 5rem 1.3rem 1.8rem;border:none;background:transparent;color:#14144a;font-size:1.1rem;font-weight:400;letter-spacing:.3px}
.search-container input::placeholder{color:rgba(20,20,74,.4);transition:color .3s}
.search-container:hover input::placeholder,
.search-container:focus-within input::placeholder{color:rgba(20,20,74,.6)}
.search-container input:focus{outline:none}
.search-container .arrow-icon{position:absolute;left:1.2rem;top:50%;transform:translateY(-50%);color:rgba(91,140,255,.6);font-size:1.2rem}
.search-container button{position:absolute;right:.4rem;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:999px;border:none;background:linear-gradient(135deg,#5b8cff,#14144a);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.68,-.55,.27,1.55);box-shadow:0 5px 15px rgba(91,140,255,.35);overflow:hidden}
.search-container button::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,.2);border-radius:999px;transform:translate(-50%,-50%);transition:width .3s,height .3s}
.search-container button:hover::before{width:200%;height:200%}
.search-container button:hover{transform:translateY(-50%) scale(1.1) rotate(5deg);box-shadow:0 8px 25px rgba(91,140,255,.5)}
.search-container button svg{width:1.2rem;height:1.2rem;fill:#fff;position:relative;z-index:1;filter:drop-shadow(0 2px 3px rgba(0,0,0,.2))}

/* Search overlay (mobile header search) */
.search-overlay{display:none;position:absolute;top:0;left:0;width:100vw;height:11vh;background:#fff;z-index:2000;align-items:flex-start;justify-content:center;animation:fadeIn .18s}
.search-overlay.open{display:flex}
.search-overlay-content{background:#fff;border-radius:12px;box-shadow:0 4px 28px rgba(100,110,130,.13);width:100%;max-width:400px;padding:1.3rem 1.2rem;position:relative;display:flex;align-items:center}
.search-overlay input[type="text"]{flex:1;font-size:1.4rem;border:none;outline:none;background:transparent;color:#333;padding:.3rem .5rem .3rem 0}
.search-overlay input::placeholder{color:#888;font-weight:400}
.search-overlay .search-icon{margin-right:.7rem;color:#aaa;width:1.3rem;height:1.3rem;flex-shrink:0}
.search-overlay .close-btn{position:absolute;right:1.1rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;width:2.2rem;height:2.2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s}
.search-overlay .close-btn:hover{background:#f5f5f5}
.search-overlay .close-btn svg{width:1.6rem;height:1.6rem;stroke:#222;fill:none;stroke-width:3}

@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ─────────────────────────────────────────────────────────────────────
   4. PAGE CONTENT
───────────────────────────────────────────────────────────────────── */
.page-content{max-width:1200px;margin:0 auto;padding:1.5rem;background:#fff;color:#333;border-radius:8px 8px 0 0;box-shadow:0 4px 16px rgba(0,0,0,.08)}
.page-content h1,
.page-content h2,
.page-content h3{color:#14144a;margin:0 0 1rem;text-align:center}
.page-content h2{font-size:28px;line-height:30px;margin:10px 0 31px}
.page-content p{margin-bottom:1rem;line-height:1.6}
.page-content a{color:#f43;text-decoration:underline}
.page-content ul{list-style:disc inside;margin:1.5rem 0;padding-left:0;color:#333}
.page-content li{margin-bottom:.75rem;line-height:1.6}
.page-content ul+p,
.page-content h2+ul{margin-top:1rem}
.page-content + .ad-container,
.page-content + section.faq{margin-top:0}

/* ─────────────────────────────────────────────────────────────────────
   5. FAQ
───────────────────────────────────────────────────────────────────── */
.faq{background:#14144a;padding:0 1rem 2rem;margin-top:0;position:relative}
.faq::before{content:'';display:block;height:80px;background:linear-gradient(180deg,#fff 0%,#14144a 100%);margin-bottom:1.5rem}
.faq h2{color:#fff;text-align:center;font-size:1.5rem}
.faq-container{width:100%;max-width:900px;margin:1.5rem auto;padding:1rem;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,.08)}
.faq-item:not(:last-child){border-bottom:1px solid #eee}
.faq-item .question{width:100%;padding:1.3rem 1.25rem;display:flex;align-items:center;justify-content:space-between;font-size:1rem;color:#14144a;cursor:pointer;background:none;border:none;text-align:left}
.faq-item .question::after{content:"\25B6";font-size:1.1rem;transition:transform .3s ease;color:#666}
.faq-item.open .question::after{content:"\25BC"}
.faq-item .answer{width:100%;max-height:0;overflow:hidden;transition:max-height .3s ease;background:#fff}
.faq-item.open .answer{max-height:300px}
.faq-item .answer p{margin:0;padding:.9rem;color:#333;line-height:1.6}

/* ─────────────────────────────────────────────────────────────────────
   6. ADS
───────────────────────────────────────────────────────────────────── */
.ad-container{width:100%;min-height:250px;margin:0;position:relative;z-index:10;isolation:isolate}
.sfbl-ad-random{margin:0;padding:0;min-height:90px;position:relative;z-index:10}

/* ─────────────────────────────────────────────────────────────────────
   7. GOOGLE CSE (Search Results)
───────────────────────────────────────────────────────────────────── */
#search-results{position:relative;z-index:1;width:100%;max-width:1200px;margin:0 auto;padding:0;isolation:isolate}
#search-results .gsc-results-wrapper-nooverlay,
#search-results .gsc-results-wrapper-overlay{position:static !important;width:100% !important;max-width:100% !important}
#search-results .gsc-wrapper,
#search-results .gsc-resultsbox-visible,
#search-results .gsc-resultsRoot,
#search-results .gsc-results,
#search-results .gsc-webResult,
#search-results .gsc-table-cell-snippet-close,
#search-results table.gsc-table-result{width:100% !important;max-width:100% !important}
.gsc-control-cse{text-align:left !important;background:transparent !important;border-color:transparent !important;box-shadow:none !important;width:100% !important}
.gsc-control-cse:has(.gsc-result){background:#fff !important;border-color:#e5e7eb !important;max-width:100% !important;width:100% !important;margin:0 auto}
.gsc-adBlock{border:1px solid #f0e6d2;border-left:4px solid #e8c878;border-radius:8px;padding:16px 20px;margin-bottom:16px;background:linear-gradient(330deg,#fffcf5,#ff4d10)}
.gs-webResult.gs-result a.gs-title:link,
.gs-webResult.gs-result a.gs-title:link b,
.gs-imageResult a.gs-title:link,
.gs-imageResult a.gs-title:link b{text-decoration:underline}

/* ─────────────────────────────────────────────────────────────────────
   8. SHARE DOCK (left rail desktop / bottom bar mobile)
───────────────────────────────────────────────────────────────────── */
.share-dock{z-index:9999}
.share-btn::after{content:none !important}
.share-btn svg{display:block;fill:#fff}
.sb-facebook{background:#1877f2}
.sb-x{background:#000}
.sb-linkedin{background:#0A66C2}
.sb-whatsapp{background:#25D366}
.share-item .share-flyout{display:none !important}

/* ─────────────────────────────────────────────────────────────────────
   9. REPORT MODAL
───────────────────────────────────────────────────────────────────── */
.report-fab{align-items:center;background:var(--accent-color,#5b8cff);backdrop-filter:saturate(140%) blur(6px);border:2px solid rgba(255,255,255,.9);border-radius:999px;box-shadow:0 10px 26px rgba(0,0,0,.25);color:#fff;cursor:pointer;display:inline-flex;font:700 14px/1 system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;gap:.5rem;padding:.75rem 1rem;position:fixed;right:16px;bottom:calc(16px + env(safe-area-inset-bottom));transition:transform .15s ease,box-shadow .15s ease,filter .15s ease;z-index:999999}
.report-fab:hover{box-shadow:0 14px 30px rgba(0,0,0,.3);transform:translateY(-6px)}
.report-fab:active{transform:translateY(0) scale(.98)}
.report-fab svg{fill:none;height:18px;stroke:currentColor;width:18px}
.report-fab:focus-visible{outline:3px solid #fff;outline-offset:2px}

.report-modal[hidden]{display:none}
.report-modal{animation:report-fade .18s ease-out;backdrop-filter:blur(2px);background:rgba(0,0,0,.45);display:grid;inset:0;padding:1rem;place-items:center;position:fixed;z-index:10000}
.report-dialog{animation:report-pop .18s ease-out;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:14px;box-shadow:0 10px 30px rgba(0,0,0,.25);color:#111;max-height:80vh;overflow:auto;padding:1rem;width:min(560px,calc(100% - 2rem))}
.report-h{margin:0 0 .5rem}
.report-row{margin:.6rem 0}
.report-row label{display:block;font-weight:600;margin-bottom:.3rem}
.report-row textarea,
.report-row input{background:inherit;border:1px solid rgba(0,0,0,.15);border-radius:10px;color:inherit;padding:.6rem .7rem;width:100%}
.report-row textarea:focus,
.report-row input:focus{box-shadow:0 0 0 3px color-mix(in oklab,var(--accent-color,#5b8cff) 25%,transparent);outline:2px solid var(--accent-color,#5b8cff)}
.report-foot{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}

.btn-primary,
.btn-secondary{border:1px solid transparent;border-radius:999px;cursor:pointer;padding:.55rem 1rem;transition:transform .12s ease,background-color .12s ease,border-color .12s ease,color .12s ease}
.btn-primary{background:var(--accent-color,#5b8cff);color:#fff}
.btn-primary:hover{filter:brightness(1.05)}
.btn-primary:active{transform:scale(.98)}
.btn-secondary{background:transparent;border-color:currentColor;color:inherit}
.btn-secondary:hover{background:rgba(0,0,0,.06)}
.btn-secondary:active{transform:scale(.98)}

@keyframes report-fade{from{opacity:0}to{opacity:1}}
@keyframes report-pop{from{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
@supports (height:100dvh){.report-dialog{max-height:80dvh}}

/* ─────────────────────────────────────────────────────────────────────
   10. FX LAYER (decorative falling/rising elements)
───────────────────────────────────────────────────────────────────── */
.fx-layer{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:5000}
.fx-item{position:absolute;top:-10vh;animation:fx-fall var(--dur,5s) linear var(--delay,0s) forwards;will-change:transform}
.fx-item.up{top:auto;bottom:-10vh;animation:fx-rise var(--dur,5s) linear var(--delay,0s) forwards}
.fx-inner{display:inline-block;transform-origin:center;animation:fx-sway 2.4s ease-in-out infinite alternate;filter:drop-shadow(0 6px 16px rgba(0,0,0,.35));color:rgba(255,255,255,.96)}
@keyframes fx-fall{to{transform:translateY(115vh)}}
@keyframes fx-rise{to{transform:translateY(-115vh)}}
@keyframes fx-sway{from{transform:translateX(-18px) rotate(-14deg)}to{transform:translateX(18px) rotate(14deg)}}

/* ─────────────────────────────────────────────────────────────────────
   11. FOOTER
───────────────────────────────────────────────────────────────────── */
.site-footer{background:linear-gradient(135deg,#5d3364,#3F51B5);padding:2.5rem 1rem 2rem;border-top:2px solid rgba(91,140,255,.15);position:relative;text-align:center;font-size:.85rem;color:#fff}
.site-footer::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:200px;height:2px;background:linear-gradient(90deg,transparent,#5b8cff,transparent)}
.site-footer .footer-inner{max-width:900px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1.25rem}
.site-footer .footer-brand{font-size:1.1rem;font-weight:700;color:#fff;letter-spacing:.5px;display:flex;align-items:center;gap:.5rem}
.site-footer .footer-brand svg{width:20px;height:20px;fill:#5b8cff}
.site-footer .footer-links{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center}
.site-footer .footer-link{color:rgba(255,255,255,.55);text-decoration:none;font-size:.85rem;font-weight:500;letter-spacing:.3px;transition:color .2s}
.site-footer .footer-link:hover{color:#5b8cff}
.site-footer .footer-divider{width:60px;height:1px;background:linear-gradient(90deg,transparent,rgba(91,140,255,.25),transparent)}
.site-footer .footer-copy{color:rgba(255,255,255,.3);font-size:.75rem;letter-spacing:.2px}

/* ─────────────────────────────────────────────────────────────────────
   12. CONTACT FORM
───────────────────────────────────────────────────────────────────── */
.wpcf7-submit{background-color:#5b8cff !important;border-radius:6px !important;transition:background-color .2s !important}
.wpcf7-submit:hover{background-color:#4070dd !important}

/* ─────────────────────────────────────────────────────────────────────
   13. RESPONSIVE - DESKTOP (≥768px)
───────────────────────────────────────────────────────────────────── */
@media (min-width:768px){
  #menuToggle,
  #searchToggle{display:none}
  .desktop-nav{display:flex;margin-left:auto}
  .desktop-menu{display:flex;gap:2rem}
  .desktop-menu a{font-size:1.1rem;font-weight:500}
  .header-inner{max-width:none;padding:0 2rem}
  .faq-container{padding:.9rem !important}
  .faq-item .question,
  .faq-item .answer{padding:1.1rem 2rem !important}
}

/* ─────────────────────────────────────────────────────────────────────
   14. RESPONSIVE - TABLET / MOBILE (≤1023.98px)
───────────────────────────────────────────────────────────────────── */
@media (max-width:1023.98px){
  .share-dock{--h:58px;position:fixed;left:0;right:0;bottom:env(safe-area-inset-bottom);width:100%;transform:none;display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:0 12px;z-index:9999}
  .share-item{position:static}
  .share-btn{height:var(--h);border-radius:14px;display:grid;place-items:center}
  .share-btn svg{width:24px;height:24px}
  body{padding-bottom:0}
  .report-fab{right:3px !important;bottom:calc(60px + env(safe-area-inset-bottom)) !important}
}

/* ─────────────────────────────────────────────────────────────────────
   15. RESPONSIVE - DESKTOP SHARE DOCK (≥1024px)
───────────────────────────────────────────────────────────────────── */
@media (min-width:1024px){
  .share-dock{--s:60px;--gap:1.1rem;position:fixed;left:20px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:var(--gap)}
  .share-item{position:relative}
  .share-btn{width:var(--s);height:var(--s);border-radius:14px;display:inline-flex;align-items:center;justify-content:center;padding:0 14px;overflow:hidden;font-size:0;box-shadow:0 10px 24px rgba(0,0,0,.32),inset 0 0 0 1px rgba(255,255,255,.12);transition:width .22s,transform .2s,filter .2s,box-shadow .2s}
  .share-btn svg{width:28px;height:28px;flex:0 0 auto}
  .share-btn::before{content:'Share';color:#fff;font:700 15px/1 system-ui;opacity:0;max-width:0;margin-left:10px;white-space:nowrap;transform:translateX(8px);transition:max-width .22s,opacity .2s,transform .2s}
  .share-item:hover>.share-btn{width:calc(var(--s) + 96px);transform:translateX(6px);justify-content:flex-start;gap:12px}
  .share-item:hover>.share-btn::before{opacity:1;max-width:96px;transform:none}
}

/* ─────────────────────────────────────────────────────────────────────
   16. RESPONSIVE - MOBILE (≤767px)
───────────────────────────────────────────────────────────────────── */
@media (max-width:767px){
  .hero{background:#14144a;padding:1rem .75rem 0 !important}
  .hero h1{font-size:1.5rem !important;margin:0 auto 6px}
  .header-inner{padding:0 1rem;height:60px;position:relative}
  header{top:0}
  #menuToggle{position:absolute;top:50%;left:1rem;transform:translateY(-50%)}
  #searchToggle{position:absolute;top:50%;right:1rem;transform:translateY(-50%)}
  .logo{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
  .logo img{max-width:170px;max-height:50px;width:auto;height:auto;vertical-align:middle}
  .search-container{width:calc(100% - 1rem) !important;margin:0 auto;border-radius:999px !important;box-shadow:0 8px 20px rgba(0,0,0,.1) !important;background:#fff !important}
  .search-container input{padding:1rem 4rem 1rem 1.2rem !important;font-size:1rem !important;border:none}
  .search-container .arrow-icon{display:none}
  .faq-container{padding:1rem !important}
  .faq-item .question,
  .faq-item .answer{padding:1rem 1.25rem !important}
  .ad-container{margin-bottom:0 !important;padding-bottom:0 !important;width:100% !important;max-width:100vw !important;overflow:hidden !important}
  .ad-container ins,
  .ad-container iframe,
  .ad-container > div{max-width:100% !important}
  ins.adsbygoogle{display:block !important;width:100% !important;max-width:100% !important}
}

/* ─────────────────────────────────────────────────────────────────────
   17. RESPONSIVE - SMALL MOBILE (≤480px)
───────────────────────────────────────────────────────────────────── */
@media (max-width:480px){
  .report-fab{padding:.8rem}
  .report-fab span{display:none}
  .report-row input,
  .report-row textarea{font-size:16px !important}
  .site-footer{padding:2rem 1rem 1.5rem}
  .site-footer .footer-links{gap:1.25rem}
}

/* ─────────────────────────────────────────────────────────────────────
   18. ACCESSIBILITY
───────────────────────────────────────────────────────────────────── */
@media (prefers-reduced-motion:reduce){
  .fx-item,
  .fx-inner{animation:none !important}
  .report-fab,
  .btn-primary,
  .btn-secondary,
  .report-modal,
  .report-dialog{animation:none;transition:none}
}

@media print{
  .share-dock{display:none}
}