/*
Theme Name: AnimeUz 3D
Theme URI: https://animeuz.com/
Author: AnimeUz Agency
Author URI: https://animeuz.com/
Description: Immersive 3D anime, gaming, manga & entertainment news theme for AnimeUz. A WebGL hero powers the homepage while article and archive pages stay fast and SEO-clean. Built to work with Rank Math SEO.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: animeuz-3d
Tags: news, blog, three-columns, custom-menu, featured-images, threaded-comments, anime
*/

/* ============ Tokens ============ */
:root{
  --magenta:#ff2d95; --cyan:#23e7ff; --purple:#9d4edd;
  --bg:#05030d; --bg2:#0d0820; --surface:#120c28; --surface2:#1a1238;
  --ink:#f5f2ff; --muted:#a99fce; --line:rgba(255,255,255,.08);
  --radius:16px; --maxw:1200px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Segoe UI',system-ui,-apple-system,Roboto,Arial,sans-serif;
  background:radial-gradient(1200px 800px at 70% -10%,#160c33 0%,var(--bg2) 45%,var(--bg) 100%);
  background-attachment:fixed; color:var(--ink); line-height:1.6; overflow-x:hidden;
}
a{color:var(--cyan);text-decoration:none}
a:hover{color:#fff}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* ============ Header / Nav ============ */
.site-header{
  position:sticky;top:0;z-index:50;
  background:linear-gradient(180deg,rgba(5,3,13,.92),rgba(5,3,13,.6));
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;
  height:68px;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:22px;letter-spacing:.02em}
.brand .dot{width:11px;height:11px;border-radius:50%;background:var(--magenta);
  box-shadow:0 0 16px var(--magenta),0 0 30px var(--magenta)}
.brand a{background:linear-gradient(90deg,var(--magenta),var(--cyan));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.main-nav ul{list-style:none;display:flex;gap:24px;align-items:center}
.main-nav a{color:var(--muted);font-weight:600;font-size:14px;position:relative;padding:6px 0;transition:color .25s}
.main-nav a:hover{color:#fff}
.main-nav a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:linear-gradient(90deg,var(--magenta),var(--cyan));transition:width .25s}
.main-nav a:hover::after{width:100%}
.main-nav .current-menu-item>a{color:#fff}
.menu-toggle{display:none;background:none;border:1px solid var(--line);color:var(--ink);
  border-radius:10px;padding:8px 12px;font-size:18px;cursor:pointer}

/* ============ Buttons ============ */
.btn{display:inline-block;padding:10px 20px;border-radius:30px;font-weight:700;color:#fff !important;
  background:linear-gradient(90deg,var(--magenta),var(--purple));
  box-shadow:0 6px 24px rgba(255,45,149,.35);transition:transform .2s,box-shadow .2s}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(255,45,149,.5)}

/* ============ Section heads ============ */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;
  gap:14px;flex-wrap:wrap;margin:54px 0 26px}
.sec-head h2{font-size:clamp(24px,4vw,38px);font-weight:800}
.sec-head h2 span{background:linear-gradient(90deg,var(--magenta),var(--cyan));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.sec-head .more{color:var(--muted);font-weight:600;font-size:14px}

/* ============ Post grid / cards ============ */
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:24px}
.post-card{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--surface);
  border:1px solid var(--line);transition:transform .15s ease, box-shadow .3s ease;transform-style:preserve-3d}
.post-card:hover{box-shadow:0 26px 60px rgba(157,78,221,.35),0 0 0 1px rgba(35,231,255,.4)}
.post-card .thumb{display:block;height:188px;background:#1a1238 center/cover no-repeat;position:relative}
.post-card .thumb::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(5,3,13,0) 40%,rgba(18,12,40,.92))}
.post-card .cat{position:absolute;top:12px;left:12px;z-index:2;font-size:11px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:20px;color:#fff;
  background:linear-gradient(90deg,var(--magenta),var(--purple));box-shadow:0 4px 14px rgba(255,45,149,.4)}
.post-card .body{padding:16px 18px 20px}
.post-card .body h3{font-size:16px;line-height:1.34;font-weight:700}
.post-card .body h3 a{color:var(--ink)}
.post-card .body h3 a:hover{color:var(--cyan)}
.post-card .excerpt{color:var(--muted);font-size:13.5px;margin-top:8px}
.post-card .meta{margin-top:12px;display:flex;gap:8px;align-items:center;color:var(--muted);font-size:12px}
.post-card .meta .who{color:var(--cyan)}

/* ============ Category strip ============ */
.cats{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-top:8px}
.cat-card{padding:22px;border-radius:var(--radius);border:1px solid var(--line);
  background:rgba(255,255,255,.03);transition:transform .25s,border-color .25s,background .25s}
.cat-card:hover{transform:translateY(-6px);border-color:rgba(35,231,255,.5);background:rgba(35,231,255,.06)}
.cat-card h4{margin-top:8px;font-size:18px;font-weight:800;color:var(--ink)}
.cat-card small{color:var(--muted)}

/* ============ Layout with sidebar ============ */
.content-wrap{display:grid;grid-template-columns:1fr 320px;gap:38px;margin:40px 0}
@media(max-width:960px){.content-wrap{grid-template-columns:1fr}}
.widget{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;margin-bottom:24px}
.widget-title{font-size:15px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;
  margin-bottom:14px;color:var(--ink)}
.widget ul{list-style:none}
.widget li{padding:8px 0;border-bottom:1px solid var(--line)}
.widget li:last-child{border-bottom:none}
.widget a{color:var(--muted)}.widget a:hover{color:var(--cyan)}

/* ============ Single / Page article ============ */
.article{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden}
.article .hero-img{width:100%;max-height:440px;object-fit:cover}
.article .inner{padding:30px clamp(20px,4vw,46px)}
.article .cat-line{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.article .cat-line a{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:5px 11px;border-radius:20px;color:#fff;background:linear-gradient(90deg,var(--magenta),var(--purple))}
.article h1.entry-title{font-size:clamp(28px,5vw,46px);line-height:1.12;font-weight:900;letter-spacing:-.01em}
.article .byline{margin:16px 0 26px;color:var(--muted);font-size:14px}
.article .byline .who{color:var(--cyan);font-weight:700}
.entry-content{font-size:17px;color:#e9e4ff}
.entry-content p{margin:0 0 1.2em}
.entry-content h2{font-size:28px;margin:1.4em 0 .5em;font-weight:800}
.entry-content h3{font-size:22px;margin:1.2em 0 .5em;font-weight:700}
.entry-content a{color:var(--cyan);text-decoration:underline}
.entry-content img{border-radius:12px;margin:1.2em 0}
.entry-content blockquote{border-left:3px solid var(--magenta);padding:.4em 0 .4em 18px;
  margin:1.2em 0;color:var(--muted);font-style:italic}
.entry-content ul,.entry-content ol{margin:0 0 1.2em 1.4em}
.entry-content li{margin:.3em 0}
.entry-content code{background:#0b0820;padding:2px 6px;border-radius:6px;font-size:.9em}
.entry-content table{width:100%;border-collapse:collapse;margin:1.2em 0}
.entry-content th,.entry-content td{border:1px solid var(--line);padding:10px 12px;text-align:left}
.entry-content th{background:var(--surface2)}

/* page title (archives etc) */
.page-hero{padding:46px 0 8px}
.page-hero .eyebrow{color:var(--cyan);letter-spacing:.3em;text-transform:uppercase;font-size:12px}
.page-hero h1{font-size:clamp(30px,5vw,52px);font-weight:900;margin-top:8px}
.page-hero p{color:var(--muted);max-width:640px;margin-top:10px}

/* pagination */
.pagination{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:46px 0}
.pagination a,.pagination span{padding:10px 15px;border-radius:10px;border:1px solid var(--line);
  color:var(--muted);font-weight:600}
.pagination .current{background:linear-gradient(90deg,var(--magenta),var(--purple));color:#fff;border:none}
.pagination a:hover{border-color:var(--cyan);color:#fff}

/* comments */
.comments-area{margin-top:34px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:26px clamp(20px,4vw,40px)}
.comments-area h2{font-size:22px;margin-bottom:18px}
.comment-list{list-style:none}
.comment-body{border-bottom:1px solid var(--line);padding:16px 0}
.comment-form input,.comment-form textarea{width:100%;background:var(--bg2);border:1px solid var(--line);
  color:var(--ink);border-radius:10px;padding:12px;margin:6px 0;font-family:inherit}
.comment-form .submit{width:auto}

/* ============ Footer ============ */
.site-footer{margin-top:64px;border-top:1px solid var(--line);background:var(--bg);
  padding:46px 0 30px;color:var(--muted)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:34px}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr}}
.site-footer h5{color:var(--ink);font-size:14px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.site-footer ul{list-style:none}
.site-footer li{padding:5px 0}
.footer-bottom{text-align:center;margin-top:30px;padding-top:20px;border-top:1px solid var(--line);font-size:13px}
.footer-bottom b{color:var(--ink)}

/* ============ 404 / search empty ============ */
.notice-box{text-align:center;padding:80px 20px}
.notice-box h1{font-size:clamp(50px,12vw,120px);font-weight:900;
  background:linear-gradient(90deg,var(--magenta),var(--cyan));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.notice-box p{color:var(--muted);margin:10px 0 22px}

/* ============ Responsive nav ============ */
@media(max-width:820px){
  .menu-toggle{display:block}
  .main-nav{position:absolute;top:68px;left:0;right:0;background:var(--bg2);
    border-bottom:1px solid var(--line);display:none}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;gap:0;padding:8px 22px 18px}
  .main-nav li{padding:10px 0;border-bottom:1px solid var(--line)}
}

/* ============ 3D Hero ============ */
.hero-3d{position:relative;height:88vh;min-height:560px;width:100%;margin-bottom:10px}
#animeuz-scene{position:absolute;inset:0;z-index:1;display:block}
.hero-3d .hero-copy{position:absolute;z-index:10;left:0;right:0;text-align:center;
  pointer-events:none;padding:0 20px}
.hero-3d .hero-copy.top{top:9%}
.hero-3d .hero-copy.bottom{bottom:12%}
.hero-3d .eyebrow{font-size:13px;letter-spacing:.45em;color:var(--cyan);
  text-transform:uppercase;opacity:.9}
.hero-3d .hero-copy.bottom p{color:var(--muted);font-size:clamp(14px,2vw,18px);letter-spacing:.04em}
.hero-hint{position:absolute;z-index:10;bottom:24px;left:50%;transform:translateX(-50%);
  color:var(--muted);font-size:11px;letter-spacing:.25em;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:8px;animation:auz-bob 2s ease-in-out infinite}
.hero-hint .mouse{width:22px;height:34px;border:2px solid var(--muted);border-radius:12px;position:relative}
.hero-hint .mouse::after{content:"";position:absolute;left:50%;top:7px;transform:translateX(-50%);
  width:3px;height:7px;border-radius:2px;background:var(--cyan);animation:auz-wheel 1.6s ease-in-out infinite}
@keyframes auz-wheel{0%,100%{opacity:1;top:7px}50%{opacity:.3;top:15px}}
@keyframes auz-bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}
.hero-fallback{display:flex;align-items:center;justify-content:center;height:100%;
  flex-direction:column;text-align:center}
.hero-fallback h1{font-size:clamp(40px,9vw,96px);font-weight:900;
  background:linear-gradient(90deg,var(--magenta),var(--cyan));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
