/* globalassets.css — global styles for www.dannny0117.com */
/* CSS custom properties are injected inline from theme.json via index.php */

/* ============================================================
   BASE RESET
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-primary,'Inter',sans-serif);
  background:var(--bg,#0a0a0a);
  color:var(--text,#e8e8e8);
  line-height:1.65;
  min-height:100vh;
  overflow-x:hidden;
}
img,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul,ol{list-style:none}
input,textarea,select{font-family:inherit;font-size:inherit}

/* ============================================================
   SCROLLBAR
   ============================================================ */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--accent);border-radius:3px}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1,h2,h3,h4,h5,h6{font-family:var(--font-display,'Inter',sans-serif);line-height:1.2;font-weight:700;letter-spacing:-0.02em}
h1{font-size:clamp(2.2rem,5vw,4rem)}
h2{font-size:clamp(1.8rem,3.5vw,2.8rem)}
h3{font-size:clamp(1.3rem,2.5vw,1.8rem)}
h4{font-size:1.1rem}
p{max-width:70ch}

/* ============================================================
   LAYOUT
   ============================================================ */
.container{width:100%;max-width:1280px;margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0}
.section-dark{background:rgba(0,0,0,.35)}
.section-header{text-align:center;margin-bottom:3rem}
.section-tag{
  display:inline-block;
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:.75rem;
  padding:.25rem .75rem;
  border:1px solid var(--accent);
  border-radius:99px;
}
.section-title{margin:.5rem 0 1rem}
.section-subtitle{color:var(--text-muted,#999);font-size:1.1rem;margin:0 auto}
.section-cta{text-align:center;margin-top:3rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ============================================================
   GLASS / CARD SYSTEM
   ============================================================ */
.glass-card{
  background:var(--surface,rgba(255,255,255,.06));
  border:1px solid var(--glass-border,rgba(255,255,255,.12));
  border-radius:var(--radius,16px);
  backdrop-filter:blur(var(--blur,20px));
  -webkit-backdrop-filter:blur(var(--blur,20px));
  transition:border-color .25s,box-shadow .25s,transform .25s;
}
.glass-card:hover{
  border-color:rgba(255,255,255,.22);
  box-shadow:var(--shadow-glow,0 8px 40px rgba(255,107,0,.15));
  transform:translateY(-3px);
}
.glass-card-accent{border-color:var(--accent);box-shadow:0 0 30px rgba(255,107,0,.12)}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.7rem 1.6rem;
  border-radius:var(--radius);
  font-weight:600;font-size:.9rem;
  cursor:pointer;transition:all .25s;
  white-space:nowrap;
  border:1px solid transparent;
}
.btn-large{padding:1rem 2.4rem;font-size:1.05rem}
.btn-sm{padding:.45rem 1rem;font-size:.8rem}
.btn-block{width:100%;justify-content:center}

.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{filter:brightness(1.15);box-shadow:0 4px 20px rgba(255,107,0,.45)}

.btn-glass{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18);color:var(--text)}
.btn-glass:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.28)}

.btn-glow{box-shadow:0 0 20px rgba(255,107,0,.35)}
.btn-glow:hover{box-shadow:0 0 35px rgba(255,107,0,.6)}

.btn-discord{background:#5865F2;color:#fff;border-color:#5865F2}
.btn-discord:hover{background:#4752c4}
.btn-glow-discord{box-shadow:0 0 20px rgba(88,101,242,.4)}

.btn-xbox{background:#107C10;color:#fff;border-color:#107C10}
.btn-xbox:hover{background:#0e6b0e}
.btn-windows{background:#0078D4;color:#fff;border-color:#0078D4}
.btn-windows:hover{background:#006bbd}
.btn-snap{background:#FFFC00;color:#000;border-color:#FFFC00}
.btn-snap:hover{filter:brightness(.92)}

/* ============================================================
   NAVIGATION
   ============================================================ */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:.9rem 1.5rem;
  background:rgba(10,10,10,.7);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:background .3s,border-color .3s;
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;
}
.site-nav.scrolled{background:rgba(10,10,10,.92);border-bottom-color:rgba(255,255,255,.14)}
.nav-logo{font-size:1.4rem;font-weight:800;letter-spacing:-.03em}
.nav-logo span{color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:1.8rem;list-style:none}
.nav-links a{font-size:.88rem;font-weight:500;color:var(--text-muted,#aaa);transition:color .2s;white-space:nowrap}
.nav-links a:hover,.nav-links a.active{color:var(--text,#e8e8e8)}

.nav-live-badge{
  display:inline-flex;align-items:center;gap:.4rem;
  background:rgba(255,0,80,.2);border:1px solid rgba(255,0,80,.5);
  color:#ff3060;padding:.2rem .6rem;border-radius:99px;font-size:.75rem;font-weight:700;
  animation:livePulse 2s infinite;
}
.nav-live-badge .live-dot{width:7px;height:7px;border-radius:50%;background:#ff3060;animation:liveDot 1.4s infinite}
@keyframes livePulse{0%,100%{box-shadow:0 0 0 0 rgba(255,48,96,.5)}50%{box-shadow:0 0 0 5px transparent}}
@keyframes liveDot{0%,100%{opacity:1}50%{opacity:.3}}

.nav-right{display:flex;align-items:center;gap:.8rem}
.nav-search-btn{background:none;border:none;color:var(--text-muted,#aaa);font-size:1.1rem;padding:.5rem;transition:color .2s;cursor:pointer}
.nav-search-btn:hover{color:var(--text)}
.nav-lang-btn{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:var(--text);padding:.35rem .75rem;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}
.nav-lang-btn:hover{background:rgba(255,255,255,.16)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:.5rem;cursor:pointer}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s}

/* Mobile nav */
@media(max-width:900px){
  .nav-links{display:none;position:fixed;inset:0;flex-direction:column;justify-content:center;align-items:center;gap:2rem;background:rgba(10,10,10,.97);font-size:1.4rem;z-index:999}
  .nav-links.open{display:flex}
  .nav-hamburger{display:flex}
}

/* ============================================================
   SEARCH OVERLAY
   ============================================================ */
.search-overlay{
  position:fixed;inset:0;z-index:2000;
  background:rgba(0,0,0,.88);
  backdrop-filter:blur(12px);
  display:flex;flex-direction:column;align-items:center;padding-top:12vh;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.search-overlay.open{opacity:1;pointer-events:auto}
.search-overlay-inner{width:100%;max-width:640px;padding:0 1.5rem}
.search-overlay-bar{
  display:flex;align-items:center;gap:.75rem;
  background:rgba(255,255,255,.09);border:1.5px solid rgba(255,255,255,.2);
  border-radius:var(--radius);padding:.9rem 1.2rem;
}
.search-overlay-bar input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:1.15rem}
.search-overlay-bar input::placeholder{color:var(--text-muted,#888)}
.search-overlay-close{font-size:1.3rem;color:var(--text-muted);cursor:pointer;transition:color .2s}
.search-overlay-close:hover{color:var(--text)}
.search-overlay-results{margin-top:1.2rem;display:flex;flex-direction:column;gap:.75rem}
.search-result-quick{
  display:flex;align-items:center;gap:.9rem;padding:.75rem 1rem;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:12px;transition:background .2s;
}
.search-result-quick:hover{background:rgba(255,255,255,.12)}
.sr-quick-img{width:48px;height:48px;border-radius:8px;object-fit:cover;flex-shrink:0}
.sr-quick-info h4{font-size:.9rem;margin-bottom:.2rem}
.sr-quick-info span{font-size:.78rem;color:var(--text-muted)}
.search-view-all{text-align:center;margin-top:1rem}

/* ============================================================
   SCROLL PROGRESS
   ============================================================ */
.scroll-progress{
  position:fixed;bottom:2rem;right:2rem;z-index:900;
  width:44px;height:44px;cursor:pointer;
  transition:opacity .3s,transform .3s;
  opacity:0;transform:translateY(10px);
}
.scroll-progress.visible{opacity:1;transform:translateY(0)}
.scroll-progress svg{width:100%;height:100%;transform:rotate(-90deg)}
.scroll-progress-circle{
  stroke:var(--accent);stroke-width:3;fill:none;
  stroke-dasharray:126;stroke-dashoffset:126;
  transition:stroke-dashoffset .1s;
}
.scroll-progress-bg{stroke:rgba(255,255,255,.1);stroke-width:3;fill:rgba(10,10,10,.7)}
.scroll-progress-icon{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:.85rem;color:var(--accent);
}

/* ============================================================
   PRELOADER
   ============================================================ */
.preloader{
  position:fixed;inset:0;z-index:9999;
  background:var(--bg);display:flex;align-items:center;justify-content:center;
  transition:opacity .6s,visibility .6s;
}
.preloader.done{opacity:0;visibility:hidden;pointer-events:none}
.preloader-inner{text-align:center}
.preloader-logo{font-size:2.5rem;font-weight:900;letter-spacing:-.04em;margin-bottom:1.5rem}
.preloader-logo span{color:var(--accent)}
.preloader-bar{width:200px;height:3px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden;margin:0 auto}
.preloader-bar-fill{height:100%;background:var(--accent);border-radius:2px;animation:preloaderFill 1.8s ease forwards}
@keyframes preloaderFill{from{width:0}to{width:100%}}

/* ============================================================
   TICKER
   ============================================================ */
.ticker-section{overflow:hidden;padding:0}
.ticker-track-wrap{overflow:hidden;padding:.65rem 0}
.ticker-track{display:flex;width:max-content;will-change:transform}
.ticker-track.reverse{animation-direction:reverse}
.ticker-item{
  display:inline-flex;align-items:center;gap:.65rem;
  padding:.4rem 1.4rem;font-size:.88rem;font-weight:600;
  white-space:nowrap;
}
.ticker-item a{display:inline-flex;align-items:center;gap:.65rem;text-decoration:none;color:inherit;transition:opacity .2s}
.ticker-item a:hover{opacity:.75}
.ticker-sep{font-size:.55rem;opacity:.5}
@keyframes tickerScroll{from{transform:translateX(0)}to{transform:translateX(-33.333%)}}

/* ============================================================
   FORMS — global
   ============================================================ */
.form-group{margin-bottom:1.2rem}
.form-group label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.45rem;color:var(--text-muted,#aaa)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}

input[type=text],input[type=email],input[type=url],input[type=search],input[type=number],select,textarea{
  width:100%;
  background:rgba(255,255,255,.07);
  border:1.5px solid rgba(255,255,255,.14);
  border-radius:10px;
  color:var(--text);
  padding:.75rem 1rem;
  outline:none;
  transition:border-color .2s,box-shadow .2s;
  -webkit-appearance:none;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(255,107,0,.15);
}
select option{background:var(--bg,#0a0a0a);color:var(--text)}
textarea{resize:vertical;min-height:120px}
.checkbox-group,.radio-group{display:flex;flex-wrap:wrap;gap:.6rem}
.checkbox-label,.radio-label{display:flex;align-items:center;gap:.5rem;font-size:.88rem;cursor:pointer}
.checkbox-label input,.radio-label input{width:auto;accent-color:var(--accent)}

/* Star rating input */
.star-rating-input{display:flex;gap:.4rem}
.star-btn{font-size:1.3rem;color:rgba(255,255,255,.3);transition:color .15s}
.star-btn:hover,.star-btn.on{color:#FFD700}

/* Form status messages */
.contact-form-status,.hire-form-status,.music-form-status{margin-top:.9rem;font-size:.88rem}
.status-success{color:#4ade80}
.status-error{color:#f87171}

/* ============================================================
   SOCIAL CARDS
   ============================================================ */
.social-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:1rem;
  margin-top:2rem;
}
.social-platform-card{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:1.5rem 1rem;gap:.5rem;
  border-color:rgba(var(--platform-color,255,255,255),.15);
  transition:all .25s;
}
.social-platform-card:hover{
  border-color:var(--platform-color);
  box-shadow:0 0 20px color-mix(in srgb,var(--platform-color) 30%,transparent);
  transform:translateY(-4px);
}
.social-plat-icon{font-size:2rem;margin-bottom:.3rem}
.social-plat-name{font-weight:700;font-size:.95rem}
.social-plat-note{font-size:.78rem;color:var(--accent);font-weight:600}
.social-plat-cta{font-size:.78rem;color:var(--text-muted,#aaa);margin-top:.4rem}

/* ============================================================
   ANIMATIONS — text-anime
   ============================================================ */
.text-anime{
  background:linear-gradient(135deg,var(--text) 0%,var(--accent-second,#00C2FF) 50%,var(--accent) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  background-size:200%;
  animation:textShimmer 4s linear infinite;
}
@keyframes textShimmer{0%{background-position:0%}100%{background-position:200%}}

/* ============================================================
   PRODUCT CARDS (global, used in multiple sections)
   ============================================================ */
.mc-product-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:1.25rem;
}
.mc-product-card{overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit}
.mc-product-img-wrap{position:relative;aspect-ratio:16/9;overflow:hidden}
.mc-product-img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.mc-product-card:hover .mc-product-img{transform:scale(1.06)}
.mc-type-badge,.product-type-badge{
  position:absolute;top:.6rem;left:.6rem;
  background:var(--accent);color:#fff;
  font-size:.68rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  padding:.25rem .6rem;border-radius:6px;
}
.mc-product-info{padding:1rem;flex:1;display:flex;flex-direction:column;gap:.4rem}
.mc-product-title{font-size:1rem;font-weight:700;line-height:1.3}
.mc-product-desc{font-size:.82rem;color:var(--text-muted);flex:1}
.mc-product-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem}
.mc-product-price{font-weight:700;color:var(--accent);font-size:.9rem}
.mc-product-stars{color:#FFD700;font-size:.75rem}

/* ============================================================
   SECTION — BLOG / GUIDES CARDS
   ============================================================ */
.guide-card,.blog-card{overflow:hidden;display:flex;flex-direction:column}
.guide-card-img-wrap,.blog-card-img-wrap{position:relative;aspect-ratio:16/9;overflow:hidden}
.guide-card-img,.blog-card-img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.guide-card:hover .guide-card-img,.blog-card:hover .blog-card-img{transform:scale(1.06)}
.guide-cat-badge,.blog-cat-badge{
  position:absolute;bottom:.6rem;left:.6rem;
  background:rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.2);
  color:#fff;font-size:.7rem;font-weight:700;
  padding:.2rem .55rem;border-radius:6px;
  backdrop-filter:blur(8px);
}
.guide-card-body,.blog-card-body{padding:1.1rem;flex:1;display:flex;flex-direction:column;gap:.5rem}
.guide-date,.blog-date{font-size:.78rem;color:var(--text-muted)}

/* ============================================================
   WYSIWYG OUTPUT STYLES
   ============================================================ */
.wysiwyg-output h2,.wysiwyg-output h3,.wysiwyg-output h4{margin:1.5rem 0 .75rem}
.wysiwyg-output p{margin-bottom:1rem;max-width:none}
.wysiwyg-output ul,.wysiwyg-output ol{margin:1rem 0 1rem 1.5rem}
.wysiwyg-output li{margin-bottom:.4rem}
.wysiwyg-output a{color:var(--accent);text-decoration:underline}
.wysiwyg-output img{border-radius:12px;margin:1.5rem 0}
.wysiwyg-output blockquote{border-left:3px solid var(--accent);padding-left:1.2rem;color:var(--text-muted);font-style:italic;margin:1rem 0}
.wysiwyg-output code{background:rgba(255,255,255,.08);padding:.15rem .4rem;border-radius:4px;font-family:monospace;font-size:.88em}
.wysiwyg-output pre{background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.1);padding:1.2rem;border-radius:12px;overflow-x:auto;margin:1rem 0}
.wysiwyg-output pre code{background:none;padding:0}
.wysiwyg-output table{width:100%;border-collapse:collapse;margin:1rem 0}
.wysiwyg-output th,.wysiwyg-output td{padding:.6rem 1rem;border:1px solid rgba(255,255,255,.1);text-align:left}
.wysiwyg-output th{background:rgba(255,255,255,.06);font-weight:700}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  position:relative;padding:4rem 0 2rem;
  border-top:1px solid rgba(255,255,255,.1);
  background:rgba(0,0,0,.4);
}
.footer-glow-line{position:absolute;top:0;left:20%;right:20%;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}
.footer-top{display:grid;grid-template-columns:1.5fr 0.7fr 0.8fr;gap:3rem;margin-bottom:3rem}
.footer-wordmark{font-size:1.8rem;font-weight:900;letter-spacing:-.04em}
.footer-tagline{color:var(--text-muted,#aaa);font-size:.9rem;margin:.75rem 0 1rem;max-width:300px}
.footer-social-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.75rem}
.footer-social-icon{
  width:36px;height:36px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);
  font-size:.95rem;transition:all .2s;
}
.footer-social-icon:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.25)}
.footer-partner-logos{display:flex;flex-direction:column;gap:1rem;justify-content:flex-start}
.footer-partner-img{max-height:38px;width:auto;opacity:.8;transition:opacity .2s;filter:brightness(0) invert(1)}
.footer-partner-logo-link:hover .footer-partner-img{opacity:1}
.footer-nav-title{font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.9rem}
.footer-nav ul li{margin-bottom:.6rem}
.footer-nav ul li a{font-size:.88rem;color:var(--text-muted);transition:color .2s}
.footer-nav ul li a:hover{color:var(--text)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:1.5rem;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;
}
.footer-copyright{font-size:.82rem;color:var(--text-muted)}
.footer-copyright-link{color:var(--text);font-weight:600}
.footer-legal-nav{display:flex;gap:1.5rem}
.footer-legal-nav a{font-size:.82rem;color:var(--text-muted);transition:color .2s}
.footer-legal-nav a:hover{color:var(--text)}

/* SEO hidden layer */
.seo-layer{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;
  font-size:1px;color:transparent;pointer-events:none;user-select:none;
}

/* ============================================================
   LANG SWITCHER DROPDOWN
   ============================================================ */
.lang-dropdown{position:relative}
.lang-dropdown-menu{
  position:absolute;top:calc(100% + .5rem);right:0;
  background:rgba(20,20,20,.98);border:1px solid rgba(255,255,255,.14);
  border-radius:12px;padding:.5rem;min-width:130px;
  backdrop-filter:blur(16px);
  opacity:0;pointer-events:none;transform:translateY(-8px);
  transition:all .2s;z-index:1001;
}
.lang-dropdown.open .lang-dropdown-menu{opacity:1;pointer-events:auto;transform:translateY(0)}
.lang-dropdown-item{
  display:block;padding:.5rem .75rem;border-radius:8px;
  font-size:.85rem;color:var(--text-muted);transition:all .2s;cursor:pointer;
}
.lang-dropdown-item:hover,.lang-dropdown-item.active{background:rgba(255,255,255,.09);color:var(--text)}

/* ============================================================
   RESPONSIVE UTILITIES
   ============================================================ */
@media(max-width:1200px){.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:768px){
  .section{padding:3.5rem 0}
  .mc-product-grid{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .footer-legal-nav{flex-wrap:wrap;gap:1rem}
  .social-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
}
@media(max-width:480px){
  .mc-product-grid{grid-template-columns:1fr}
  .btn-large{padding:.85rem 1.8rem;font-size:.95rem}
}
