/* 
Theme Name: Savvy3DX
Theme URI: https://savvy3dx.com
Author: Savvy3DX
Description: Dual theme with mega-menu, sun/moon toggle, CPTs, templates, and registered block patterns (1.5.0).
Version: 1.5.0
License: GPL-2.0-or-later
Text Domain: savvy3dx
*/
:root{--bg:#0E0E0E;--bg-2:#121212;--panel:#1C1C1C;--panel-2:#222;--ink:#fff;--muted:#B3B3B3;--brand:#C49A6C;--accent:#2D3BFF;--cta:#C49A6C;--cta-ink:#0E0E0E;--radius:16px;--max:1200px;--ease:cubic-bezier(.22,.61,.36,1)}
html[data-theme="light"]{--bg:#fff;--bg-2:#F7FAFF;--panel:#fff;--panel-2:#F7FAFF;--ink:#222;--muted:#4B5563;--brand:#4A90E2;--accent:#57CC99;--cta:#FF6B6B;--cta-ink:#fff}

*{box-sizing:border-box}
body{margin:0;background:linear-gradient(180deg,var(--bg),var(--bg-2));color:var(--ink);font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.6}
a{color:inherit;text-decoration:none}
.container{max-width:var(--max);margin-inline:auto;padding:0 20px}
.section{padding:36px 0}
h1{font-size:clamp(32px,4vw,48px);line-height:1.1;margin:0 0 .5em}
h2{font-size:clamp(24px,3vw,34px);line-height:1.15;margin:0 0 .6em}
h3{font-size:clamp(18px,2vw,22px);line-height:1.2;margin:0 0 .4em}
p{margin:.6em 0}

/* Buttons & Cards */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.1rem;border-radius:12px;font-weight:700;background:var(--cta);color:var(--cta-ink);border:1px solid rgba(0,0,0,.06);transition:transform .35s var(--ease), filter .25s var(--ease)}
.btn:hover{filter:brightness(.98);transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--ink);border:1px solid rgba(255,255,255,.18)}
html[data-theme="light"] .btn--ghost{border-color:rgba(0,0,0,.12)}
.card{background:var(--panel);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:20px}
html[data-theme="light"] .card{background:#fff;border-color:rgba(0,0,0,.08)}

/* Header / Nav */
.nav{position:sticky;top:0;z-index:80;backdrop-filter:saturate(180%) blur(12px);background:rgba(18,18,18,.70);border-bottom:1px solid rgba(255,255,255,.06);transition:background .35s var(--ease)}
.nav.scrolled{background:rgba(18,18,18,.92)}
html[data-theme="light"] .nav{background:rgba(255,255,255,.75);border-color:rgba(0,0,0,.06)}
html[data-theme="light"] .nav.scrolled{background:rgba(255,255,255,.95)}
.nav__row{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.nav__menu{display:flex;gap:1.2rem;align-items:center}
.nav__item{position:relative}
.nav__menu a{position:relative}
.nav__menu a::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:linear-gradient(90deg,transparent,var(--brand),transparent);transform:scaleX(0);transform-origin:center;transition:transform .35s var(--ease)}
.nav__menu a:hover::after{transform:scaleX(1)}

/* Theme toggle (sun/moon) */
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:transparent;cursor:pointer;color:var(--ink)}
.theme-toggle svg{width:18px;height:18px;fill:currentColor}
.icon-sun{display:block}.icon-moon{display:none}
html[data-theme="light"] .icon-sun{display:none}
html[data-theme="light"] .icon-moon{display:block}
html[data-theme="light"] .theme-toggle{border-color:rgba(0,0,0,.12)}

/* Mega Dropdown */
.dropdown{position:absolute;left:0;top:100%;margin-top:12px;background:var(--panel);border:1px solid rgba(255,255,255,.08);border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,.5);padding:14px;opacity:0;transform:translateY(8px);pointer-events:none;transition:opacity .2s var(--ease), transform .2s var(--ease);min-width:320px}
.dropdown.open{opacity:1;transform:translateY(0);pointer-events:auto}
.dropdown__grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.dropdown a{display:block;padding:10px 12px;border-radius:10px;color:var(--ink);border:1px solid transparent}
.dropdown a:hover{background:rgba(196,154,108,.12);border-color:rgba(196,154,108,.35)}
html[data-theme="light"] .dropdown a:hover{background:rgba(74,144,226,.12);border-color:rgba(74,144,226,.35);color:#0F172A}

/* Footer */
.footer{padding:48px 0;border-top:1px solid rgba(255,255,255,.08);color:var(--muted)}
html[data-theme="light"] .footer{border-top-color:rgba(0,0,0,.08)}
.social__btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:999px;border:1px solid rgba(255,255,255,.18);color:var(--ink);transition:transform .25s var(--ease),border-color .25s var(--ease),color .25s var(--ease)}
.social__btn:hover{transform:translateY(-2px);border-color:var(--brand);color:var(--brand)}

/* Grids */
.grid{display:grid;gap:20px}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
@media(max-width:960px){.grid--3,.grid--2{grid-template-columns:1fr}}

/* Gutenberg normalization */
.entry-content, .wp-block-group, .wp-site-blocks{max-width:var(--max);margin-left:auto;margin-right:auto;padding-left:20px;padding-right:20px}
.wp-block-image img{max-width:100%;height:auto;border-radius:12px}
.wp-block-group .container{max-width:none;padding:0}
.wp-block-columns{gap:20px}
.wp-block-button .wp-block-button__link{border-radius:12px;background:var(--cta);color:var(--cta-ink)}

/* Sliders & Before/After */
.slider{position:relative; overflow:hidden; border-radius:16px; border:1px solid rgba(255,255,255,.1); background:linear-gradient(135deg,var(--panel),var(--panel-2))}
html[data-theme="light"] .slider{background:#fff; border-color:rgba(0,0,0,.08)}
.slider__track{display:flex; width:200%; gap:12px; padding:12px; animation:sceneScroll 44s linear infinite}
.slider:hover .slider__track{animation-play-state:paused}
.slide{flex:0 0 auto; width:360px; height:240px; border-radius:12px; overflow:hidden; position:relative}
.slide img{width:100%; height:100%; object-fit:cover; display:block}
@keyframes sceneScroll{from{transform:translateX(0)} to{transform:translateX(-50%)}}
@media (max-width: 960px){ .slide{width:78vw; height:48vw} }

.comparison{position:relative; border-radius:16px; overflow:hidden; border:1px solid rgba(255,255,255,.1); background:var(--panel); aspect-ratio:16/9}
html[data-theme="light"] .comparison{background:#fff; border-color:rgba(0,0,0,.08)}
.comparison img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover}
.comparison .clip{position:absolute; inset:0; width:var(--pos,50%); overflow:hidden}
.ba input[type=range]{-webkit-appearance:none; width:100%; height:28px; background:transparent}
.ba input[type=range]::-webkit-slider-runnable-track{height:4px; background:linear-gradient(90deg,var(--brand), rgba(255,255,255,.25)); border-radius:999px}
.ba input[type=range]::-webkit-slider-thumb{-webkit-appearance:none; width:20px; height:20px; border-radius:50%; background:var(--brand); box-shadow:0 2px 10px rgba(0,0,0,.3); margin-top:-8px}

/* Helpers */
.breadcrumbs{font-size:.88rem;color:var(--muted);display:flex;gap:6px;align-items:center}
.breadcrumbs a{opacity:.9}
.breadcrumbs a:hover{color:var(--brand)}
.badge{display:inline-flex;gap:.5rem;align-items:center;padding:.35rem .7rem;border-radius:999px;font-size:.8rem;line-height:1;background:rgba(196,154,108,.12);color:var(--brand);border:1px solid rgba(196,154,108,.32)}
html[data-theme="light"] .badge{background:rgba(74,144,226,.12);border-color:rgba(74,144,226,.28);color:#1E3A8A}
.frame{aspect-ratio:16/10;width:100%;border-radius:16px;background:linear-gradient(135deg,var(--panel),var(--panel-2));border:1px solid rgba(255,255,255,.08);position:relative;overflow:hidden}
.frame img{width:100%;height:100%;object-fit:cover}
