/* =============================================================
   MAGMIX THEME — theme.css
   All values controlled via CSS custom properties injected
   by functions.php from the WordPress Customizer.
   ============================================================= */

/* ---------- variables (defaults – overridden by PHP) ---------- */
:root {
  /* accent */
  --mm-accent:        #e8192c;
  --mm-accent-hover:  #ff2d42;

  /* backgrounds */
  --mm-bg:            #0d0d0d;
  --mm-bg-card:       #161616;
  --mm-bg-header:     #0a0a0a;
  --mm-bg-nav:        #111111;

  /* text */
  --mm-text:          #e0e0e0;
  --mm-text-muted:    #777777;
  --mm-text-heading:  #ffffff;

  /* borders */
  --mm-border:        #252525;
  --mm-border-card:   #1e1e1e;

  /* layout */
  --mm-header-h:      64px;
  --mm-nav-h:         48px;
  --mm-container:     1380px;
  --mm-card-radius:   10px;
  --mm-gap:           18px;
  --mm-cols:          4;

  /* badge */
  --mm-badge-size:    11px;
  --mm-badge-radius:  5px;

  /* fonts */
  --mm-font-head:     'Bebas Neue', 'Noto Sans Thai', sans-serif;
  --mm-font-body:     'DM Sans', 'Noto Sans Thai', sans-serif;

  /* transitions */
  --mm-ease:          0.22s cubic-bezier(.4,0,.2,1);

  /* category badge colors */
  --mm-cat-lora:        #e8192c;
  --mm-cat-checkpoint:  #7c3aed;
  --mm-cat-zprompt:     #0ea5e9;
  --mm-cat-nsfw:        #f97316;
  --mm-cat-news:        #10b981;
  --mm-cat-hairstyle:   #ec4899;
  --mm-cat-pose:        #f59e0b;
  --mm-cat-comfyui:     #3b82f6;
  --mm-cat-prolora:     #8b5cf6;
  --mm-cat-googlecolab: #34d399;
  --mm-cat-drawthings:  #fb923c;
}

/* ===================== RESET ===================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--mm-font-body);
  background:var(--mm-bg);
  color:var(--mm-text);
  line-height:1.6;
  font-size:15px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;transition:color var(--mm-ease)}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}
input,select,textarea{font:inherit}

/* ===================== LAYOUT ===================== */
.mm-container{
  max-width:var(--mm-container);
  margin:0 auto;
  padding:0 22px;
}
.screen-reader-text{
  position:absolute;width:1px;height:1px;
  clip:rect(0,0,0,0);overflow:hidden;white-space:nowrap;
}

/* ===================== HEADER ===================== */
#masthead{
  position:sticky;top:0;z-index:1000;
  background:var(--mm-bg-header);
  border-bottom:1px solid var(--mm-border);
  height:var(--mm-header-h);
}
.mm-header-inner{
  display:flex;align-items:center;height:100%;gap:16px;
}

/* logo */
.site-branding{flex-shrink:0}
.site-title{
  font-family:var(--mm-font-head);
  font-size:26px;font-weight:400;
  letter-spacing:1px;
  color:var(--mm-text-heading);
  line-height:1;
}
.site-title a{color:inherit}
.site-title a:hover{color:var(--mm-accent)}

/* header widget / search / buttons */
.mm-header-right{
  margin-left:auto;
  display:flex;align-items:center;gap:12px;
}
.mm-search-form{
  display:flex;align-items:center;
  background:rgba(255,255,255,.05);
  border:1px solid var(--mm-border);
  border-radius:7px;overflow:hidden;
  transition:border-color var(--mm-ease);
}
.mm-search-form:focus-within{border-color:var(--mm-accent)}
.mm-search-form input[type=search]{
  background:transparent;border:none;outline:none;
  color:var(--mm-text);padding:7px 13px;width:200px;font-size:14px;
}
.mm-search-form input::placeholder{color:var(--mm-text-muted)}
.mm-search-form button{
  padding:7px 12px;color:var(--mm-text-muted);
  transition:color var(--mm-ease);
}
.mm-search-form button:hover{color:var(--mm-accent)}

.mm-btn-login{
  font-size:13px;font-weight:500;
  color:var(--mm-text);
  padding:6px 16px;border-radius:6px;
  border:1px solid var(--mm-border);
  transition:all var(--mm-ease);
  white-space:nowrap;
}
.mm-btn-login:hover{border-color:var(--mm-accent);color:var(--mm-accent)}

.mm-btn-register{
  font-size:13px;font-weight:600;
  color:#fff;padding:6px 16px;border-radius:6px;
  background:var(--mm-accent);
  border:1px solid var(--mm-accent);
  transition:all var(--mm-ease);
  white-space:nowrap;
}
.mm-btn-register:hover{
  background:var(--mm-accent-hover);
  border-color:var(--mm-accent-hover);
}

/* ===================== CATEGORY NAV ===================== */
#mm-cat-nav{
  background:var(--mm-bg-nav);
  border-bottom:1px solid var(--mm-border);
  position:sticky;top:var(--mm-header-h);z-index:990;
  height:var(--mm-nav-h);
}
.mm-cat-nav-inner{
  display:flex;align-items:center;height:100%;
  overflow-x:auto;scrollbar-width:none;
  gap:2px;padding:0 2px;
}
.mm-cat-nav-inner::-webkit-scrollbar{display:none}

.mm-cat-link{
  position:relative;flex-shrink:0;
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;border-radius:7px;
  font-size:13.5px;font-weight:500;
  color:var(--mm-text-muted);
  white-space:nowrap;
  transition:all var(--mm-ease);
}
.mm-cat-link:hover{
  color:var(--mm-text-heading);
  background:rgba(255,255,255,.06);
}
.mm-cat-link.is-active{
  color:var(--mm-text-heading);
  background:rgba(255,255,255,.08);
}
/* active underline */
.mm-cat-link.is-active::after{
  content:'';
  position:absolute;bottom:-1px;left:10px;right:10px;
  height:2px;border-radius:2px 2px 0 0;
  background:var(--mm-accent);
}
.mm-cat-dot{
  width:6px;height:6px;border-radius:50%;
  background:currentColor;opacity:.5;flex-shrink:0;
}
.mm-cat-link.is-active .mm-cat-dot{
  background:var(--mm-accent);opacity:1;
  box-shadow:0 0 5px var(--mm-accent);
}
.mm-cat-count{
  font-size:10.5px;font-weight:700;
  padding:1px 5px;border-radius:20px;
  background:rgba(255,255,255,.07);
  color:var(--mm-text-muted);line-height:1.5;
}
.mm-cat-link.is-active .mm-cat-count{
  background:var(--mm-accent);color:#fff;
}

/* ===================== MAIN ===================== */
#mm-primary{padding:28px 0 64px}

/* ===================== POSTS GRID ===================== */
.mm-posts-grid{
  display:grid;
  grid-template-columns:repeat(var(--mm-cols),1fr);
  gap:var(--mm-gap);
}

/* ===================== POST CARD ===================== */
@keyframes mmFadeUp{
  from{opacity:0;transform:translateY(16px)}
  to  {opacity:1;transform:translateY(0)}
}

.mm-card{
  position:relative;
  background:var(--mm-bg-card);
  border:1px solid var(--mm-border-card);
  border-radius:var(--mm-card-radius);
  overflow:hidden;
  transition:transform var(--mm-ease),box-shadow var(--mm-ease),border-color var(--mm-ease);
  animation:mmFadeUp .35s ease both;
}
.mm-card:nth-child(1){animation-delay:.04s}
.mm-card:nth-child(2){animation-delay:.08s}
.mm-card:nth-child(3){animation-delay:.12s}
.mm-card:nth-child(4){animation-delay:.16s}
.mm-card:nth-child(5){animation-delay:.20s}
.mm-card:nth-child(6){animation-delay:.24s}
.mm-card:nth-child(7){animation-delay:.28s}
.mm-card:nth-child(8){animation-delay:.32s}

.mm-card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,255,255,.13);
  box-shadow:0 14px 40px rgba(0,0,0,.55);
}

/* thumbnail */
.mm-card-thumb{
  position:relative;aspect-ratio:3/4;overflow:hidden;
  background:#1a1a1a;
}
.mm-card-thumb img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .4s ease;
}
.mm-card:hover .mm-card-thumb img{transform:scale(1.05)}

/* thumbnail gradient overlay */
.mm-card-thumb::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 45%,rgba(0,0,0,.65) 100%);
  pointer-events:none;
}

/* no thumbnail placeholder */
.mm-no-thumb{
  width:100%;height:100%;display:flex;align-items:center;
  justify-content:center;opacity:.15;
}

/* card body */
.mm-card-body{padding:12px 14px 14px}
.mm-card-title{
  font-size:14.5px;font-weight:600;
  color:var(--mm-text-heading);line-height:1.4;
  margin-bottom:9px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.mm-card-title a:hover{color:var(--mm-accent)}

/* ===================== BADGE SYSTEM ===================== */
/* position variants (set via body class) */
.mm-badge-pos-thumb .mm-badge-wrap--thumb{display:flex}
.mm-badge-pos-thumb .mm-badge-wrap--body{display:none}
.mm-badge-pos-body  .mm-badge-wrap--thumb{display:none}
.mm-badge-pos-body  .mm-badge-wrap--body{display:flex}
.mm-badge-pos-both  .mm-badge-wrap--thumb{display:flex}
.mm-badge-pos-both  .mm-badge-wrap--body{display:flex}

/* default show thumb badges */
body:not(.mm-badge-pos-body):not(.mm-badge-pos-both) .mm-badge-wrap--body{display:none}

.mm-badge-wrap--thumb{
  position:absolute;bottom:10px;left:10px;z-index:2;
  display:flex;flex-wrap:wrap;gap:5px;
}
.mm-badge-wrap--body{
  display:flex;flex-wrap:wrap;gap:5px;margin-top:2px;
}

/* badge base */
.mm-badge{
  display:inline-flex;align-items:center;
  font-size:var(--mm-badge-size);font-weight:700;
  padding:2px 9px;
  border-radius:var(--mm-badge-radius);
  letter-spacing:.03em;text-transform:uppercase;
  line-height:1.65;
  backdrop-filter:blur(4px);
  background:var(--mm-badge-bg, var(--mm-accent));
  color:var(--mm-badge-text, #fff);
  border:1px solid rgba(255,255,255,.12);
  transition:transform var(--mm-ease);
  text-decoration:none;
}
.mm-badge:hover{transform:scale(1.06)}

/* style variants */
body.mm-badge-style-pill .mm-badge{border-radius:999px;padding:2px 11px}
body.mm-badge-style-square .mm-badge{border-radius:2px}
body.mm-badge-style-outline .mm-badge{
  background:transparent !important;
  border:1px solid var(--mm-badge-bg, var(--mm-accent));
  color:var(--mm-badge-bg, var(--mm-accent)) !important;
}
body.mm-badge-style-ghost .mm-badge{
  background:rgba(0,0,0,.55) !important;
  color:#fff !important;
  border:none;
}

/* per-category colors */
.mm-badge.mm-cat-lora        {--mm-badge-bg:var(--mm-cat-lora)}
.mm-badge.mm-cat-checkpoint  {--mm-badge-bg:var(--mm-cat-checkpoint)}
.mm-badge.mm-cat-zprompt     {--mm-badge-bg:var(--mm-cat-zprompt)}
.mm-badge.mm-cat-nsfw        {--mm-badge-bg:var(--mm-cat-nsfw)}
.mm-badge.mm-cat-news        {--mm-badge-bg:var(--mm-cat-news)}
.mm-badge.mm-cat-hairstyle   {--mm-badge-bg:var(--mm-cat-hairstyle)}
.mm-badge.mm-cat-pose        {--mm-badge-bg:var(--mm-cat-pose)}
.mm-badge.mm-cat-comfyui     {--mm-badge-bg:var(--mm-cat-comfyui)}
.mm-badge.mm-cat-prolora     {--mm-badge-bg:var(--mm-cat-prolora)}
.mm-badge.mm-cat-googlecolab {--mm-badge-bg:var(--mm-cat-googlecolab);--mm-badge-text:#000}
.mm-badge.mm-cat-drawthings  {--mm-badge-bg:var(--mm-cat-drawthings)}

/* ===================== PAGINATION ===================== */
.mm-pagination{
  margin-top:44px;display:flex;justify-content:center;
  align-items:center;gap:6px;flex-wrap:wrap;
}
.mm-pagination .page-numbers{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:38px;height:38px;padding:0 10px;
  border-radius:7px;font-size:13px;font-weight:500;
  border:1px solid var(--mm-border);color:var(--mm-text-muted);
  transition:all var(--mm-ease);
}
.mm-pagination .page-numbers:hover,
.mm-pagination .page-numbers.current{
  background:var(--mm-accent);border-color:var(--mm-accent);color:#fff;
}
.mm-pagination .page-numbers.dots{border:none;background:none}

/* ===================== NO POSTS ===================== */
.mm-no-posts{
  grid-column:1/-1;text-align:center;padding:80px 20px;
  color:var(--mm-text-muted);
}
.mm-no-posts h2{font-size:18px;color:var(--mm-text);margin:16px 0 6px}

/* ===================== SINGLE POST ===================== */
.mm-single-wrap{max-width:700px;margin:0 auto;padding:36px 22px 80px}

.mm-single-cats{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px}
.mm-single-title{
  font-size:clamp(22px,4vw,34px);font-weight:700;
  color:var(--mm-text-heading);line-height:1.3;margin-bottom:10px;
}
.mm-single-meta{
  font-size:13px;color:var(--mm-text-muted);
  display:flex;align-items:center;gap:14px;margin-bottom:28px;
}
.mm-single-meta a:hover{color:var(--mm-accent)}

.mm-single-thumb{
  width:100%;border-radius:var(--mm-card-radius);overflow:hidden;
  margin-bottom:32px;max-height:580px;
}
.mm-single-thumb img{width:100%;height:100%;object-fit:cover}

/* entry content */
.entry-content{font-size:15px;line-height:1.8;color:var(--mm-text)}
.entry-content h2{
  font-size:20px;font-weight:700;color:var(--mm-text-heading);
  margin:32px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--mm-border);
}
.entry-content h3{font-size:17px;font-weight:600;color:var(--mm-text-heading);margin:24px 0 8px}
.entry-content p{margin-bottom:16px}
.entry-content a{color:var(--mm-accent);text-decoration:underline;text-underline-offset:3px}
.entry-content a:hover{color:var(--mm-accent-hover)}
.entry-content ul{list-style:disc;margin:12px 0 18px 20px}
.entry-content ol{list-style:decimal;margin:12px 0 18px 20px}
.entry-content li{margin-bottom:5px}
.entry-content img{border-radius:8px;margin:20px 0}
.entry-content blockquote{
  border-left:3px solid var(--mm-accent);padding:10px 18px;margin:20px 0;
  background:rgba(255,255,255,.03);border-radius:0 7px 7px 0;
  font-style:italic;color:var(--mm-text-muted);
}
.entry-content code{
  font-family:'JetBrains Mono',monospace;font-size:12.5px;
  background:rgba(255,255,255,.06);padding:2px 6px;border-radius:4px;color:#e879f9;
}
.entry-content pre{
  background:rgba(255,255,255,.04);border:1px solid var(--mm-border);
  border-radius:9px;padding:18px;overflow-x:auto;margin:20px 0;
}
.entry-content pre code{background:none;padding:0;color:var(--mm-text)}

/* post nav */
.mm-post-nav{
  margin-top:44px;padding-top:28px;border-top:1px solid var(--mm-border);
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
}
.mm-post-nav .nav-previous,.mm-post-nav .nav-next{display:flex;flex-direction:column;gap:3px}
.mm-post-nav .nav-next{text-align:right}
.mm-post-nav .nav-subtitle{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--mm-text-muted)}
.mm-post-nav .nav-title{font-size:13.5px;font-weight:600;color:var(--mm-text-heading)}
.mm-post-nav a:hover .nav-title{color:var(--mm-accent)}

/* ===================== FOOTER ===================== */
#colophon{
  background:var(--mm-bg-header);border-top:1px solid var(--mm-border);
  padding:28px 0;text-align:center;font-size:13px;color:var(--mm-text-muted);
}
#colophon a{color:var(--mm-accent)}
#colophon a:hover{color:var(--mm-accent-hover)}

/* ===================== WIDGETS ===================== */
.mm-widget{
  background:var(--mm-bg-card);border:1px solid var(--mm-border-card);
  border-radius:var(--mm-card-radius);padding:18px;margin-bottom:20px;
}
.mm-widget-title{
  font-size:13px;font-weight:700;text-transform:uppercase;
  letter-spacing:.07em;color:var(--mm-accent);
  margin-bottom:13px;padding-bottom:9px;border-bottom:1px solid var(--mm-border);
}

/* ===================== RESPONSIVE ===================== */
@media(max-width:1100px){:root{--mm-cols:3}}
@media(max-width:720px) {:root{--mm-cols:2;--mm-gap:12px}}
@media(max-width:460px) {:root{--mm-cols:1}}

@media(max-width:640px){
  :root{--mm-header-h:56px;--mm-nav-h:44px}
  .mm-search-form input[type=search]{width:140px}
  .mm-btn-login{display:none}
}
@media(max-width:400px){
  .mm-search-form{display:none}
  .site-title{font-size:20px}
}

/* ===================== WP CORE HELPERS ===================== */
.alignleft {float:left;margin-right:20px}
.alignright{float:right;margin-left:20px}
.aligncenter{display:block;margin:0 auto 20px}
.wp-caption-text{font-size:12px;color:var(--mm-text-muted);text-align:center;margin-top:6px}

/* sticky header scrolled state */
#masthead.mm-scrolled{
  box-shadow:0 2px 20px rgba(0,0,0,.5);
}
