/*
Theme Name: ZENJI
Theme URI: https://oreviaclothing.com/
Author: ZENJI Studio
Author URI: https://oreviaclothing.com/
Description: ZENJI — a premium white-theme, anime-inspired streetwear WordPress + WooCommerce theme. Clean editorial layouts, manga panel grids, dynamic animations, colour swatch product cards and a strong mobile experience. Built for original anime-inspired streetwear drops.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: zenji
Tags: e-commerce, custom-menu, featured-images, full-width-template, theme-options, translation-ready, custom-colors, custom-logo
WC requires at least: 6.0
WC tested up to: 9.0
*/

/* ============================================================
   ZENJI — Design Tokens
   ============================================================ */
:root{
  --white:#FFFFFF;
  --offwhite:#F6F3EE;
  --ink:#0D0D0D;
  --charcoal:#1A1A1A;
  --blood:#B30000;
  --eblue:#0066FF;
  --purple:#7A2CFF;
  --sakura:#FF6FAE;
  --teal:#00A896;
  --gold:#F5B700;
  --line:#E7E2DA;
  --muted:#6B6B6B;
  --radius:14px;
  --radius-sm:8px;
  --maxw:1280px;
  --ff-display:"Archivo","Helvetica Neue",Arial,sans-serif;
  --ff-body:"Inter","Helvetica Neue",Arial,sans-serif;
  --shadow:0 18px 50px rgba(13,13,13,.10);
  --shadow-sm:0 8px 24px rgba(13,13,13,.08);
  --ease:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--white);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .25s var(--ease)}
a:hover{color:var(--blood)}
h1,h2,h3,h4,h5{font-family:var(--ff-display);font-weight:800;line-height:1.05;letter-spacing:-.02em;margin:0 0 .4em}
p{margin:0 0 1em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:90px 0}
.eyebrow{font-family:var(--ff-display);text-transform:uppercase;letter-spacing:.28em;font-size:12px;font-weight:700;color:var(--blood)}
.text-center{text-align:center}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 30px;font-family:var(--ff-display);font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:13px;border-radius:50px;border:2px solid var(--ink);cursor:pointer;transition:all .3s var(--ease);background:var(--ink);color:#fff}
.btn:hover{background:var(--blood);border-color:var(--blood);color:#fff;transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:#fff}
.btn--block{display:flex;width:100%;justify-content:center}

/* ============================================================
   Page load + scroll progress
   ============================================================ */
#zenji-loader{position:fixed;inset:0;background:var(--white);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .6s var(--ease),visibility .6s}
#zenji-loader.is-done{opacity:0;visibility:hidden}
#zenji-loader .loader-mark{font-family:var(--ff-display);font-weight:900;font-size:clamp(34px,8vw,80px);letter-spacing:.2em;color:var(--ink);position:relative;overflow:hidden}
#zenji-loader .loader-mark span{display:inline-block;animation:zj-rise .8s var(--ease) both}
@keyframes zj-rise{from{transform:translateY(110%)}to{transform:translateY(0)}}
#scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--blood),var(--purple),var(--eblue));z-index:1200;transition:width .1s linear}

/* ============================================================
   Header
   ============================================================ */
.site-header{position:fixed;top:0;left:0;width:100%;z-index:1000;transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);padding:18px 0}
.site-header.transparent{background:transparent}
.site-header.scrolled{background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(14px);box-shadow:0 1px 0 var(--line);padding:12px 0}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{font-family:var(--ff-display);font-weight:900;font-size:26px;letter-spacing:.32em;color:var(--ink);padding-left:.32em}
.brand .dot{color:var(--blood)}
.main-nav ul{display:flex;gap:30px;list-style:none;margin:0;padding:0}
.main-nav a{font-family:var(--ff-display);font-weight:700;text-transform:uppercase;font-size:13px;letter-spacing:.12em;position:relative;padding:4px 0}
.main-nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--blood);transition:width .3s var(--ease)}
.main-nav a:hover::after,.main-nav .current-menu-item>a::after{width:100%}
.header-actions{display:flex;align-items:center;gap:18px}
.icon-btn{background:none;border:none;cursor:pointer;color:var(--ink);display:flex;align-items:center;position:relative;padding:4px}
.cart-count{position:absolute;top:-6px;right:-8px;background:var(--blood);color:#fff;font-size:10px;font-weight:800;min-width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0 3px}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.hamburger span{width:26px;height:2px;background:var(--ink);transition:.3s var(--ease)}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile drawer */
.mobile-drawer{position:fixed;inset:0 0 0 auto;width:min(85vw,360px);background:var(--white);z-index:1100;transform:translateX(100%);transition:transform .45s var(--ease);box-shadow:var(--shadow);display:flex;flex-direction:column;padding:90px 30px 30px}
.mobile-drawer.open{transform:translateX(0)}
.mobile-drawer ul{list-style:none;margin:0;padding:0}
.mobile-drawer li{border-bottom:1px solid var(--line)}
.mobile-drawer a{display:block;padding:16px 0;font-family:var(--ff-display);font-weight:800;text-transform:uppercase;letter-spacing:.1em;font-size:18px}
.drawer-overlay{position:fixed;inset:0;background:rgba(13,13,13,.45);z-index:1090;opacity:0;visibility:hidden;transition:.4s}
.drawer-overlay.open{opacity:1;visibility:visible}

/* ============================================================
   Hero
   ============================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;background:var(--offwhite);overflow:hidden;padding-top:90px}
.hero::before{content:"";position:absolute;right:-8%;top:50%;transform:translateY(-50%);width:46vw;height:46vw;max-width:680px;max-height:680px;background:radial-gradient(circle at 30% 30%,rgba(122,44,255,.16),rgba(0,102,255,.10) 45%,transparent 70%);border-radius:50%;filter:blur(6px)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center;position:relative;z-index:2}
.hero-kanji{position:absolute;font-family:var(--ff-display);font-weight:900;font-size:clamp(120px,30vw,420px);color:rgba(13,13,13,.04);right:-2%;top:8%;z-index:1;pointer-events:none;letter-spacing:-.05em}
.hero h1{font-size:clamp(44px,7vw,104px);text-transform:uppercase}
.hero h1 .accent{color:var(--blood)}
.hero .lead{font-size:18px;max-width:460px;color:var(--charcoal)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.hero-visual{position:relative;aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;background:linear-gradient(160deg,#fff,#ece6dd);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center}
.hero-visual .ph-figure{width:100%;height:100%}
.hero-badge{position:absolute;left:18px;top:18px;background:var(--ink);color:#fff;font-family:var(--ff-display);font-weight:800;font-size:11px;letter-spacing:.16em;text-transform:uppercase;padding:8px 14px;border-radius:50px;z-index:3}

/* ============================================================
   Marquee
   ============================================================ */
.marquee{background:var(--ink);color:#fff;padding:14px 0;overflow:hidden;white-space:nowrap}
.marquee__track{display:inline-flex;gap:40px;animation:zj-marquee 22s linear infinite;font-family:var(--ff-display);font-weight:800;text-transform:uppercase;letter-spacing:.18em;font-size:14px;will-change:transform}
.marquee__track span{display:inline-flex;align-items:center;gap:40px}
.marquee__track .star{color:var(--blood)}
@keyframes zj-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   Section heading
   ============================================================ */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:46px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(30px,4.5vw,56px);text-transform:uppercase}
.sec-head p{color:var(--muted);max-width:480px;margin:0}

/* ============================================================
   Product grid + cards
   ============================================================ */
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.product-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease);position:relative}
.product-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.product-card__media{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--offwhite)}
.product-card__media .ph-figure{width:100%;height:100%;transition:transform .6s var(--ease)}
.product-card:hover .product-card__media .ph-figure{transform:scale(1.08)}
.product-card__badge{position:absolute;top:12px;left:12px;background:var(--blood);color:#fff;font-family:var(--ff-display);font-weight:800;font-size:10px;letter-spacing:.14em;text-transform:uppercase;padding:6px 11px;border-radius:50px;z-index:3}
.badge-new{background:var(--eblue);animation:zj-pulse 1.8s var(--ease) infinite}
@keyframes zj-pulse{0%,100%{box-shadow:0 0 0 0 rgba(0,102,255,.5)}50%{box-shadow:0 0 0 8px rgba(0,102,255,0)}}
.product-card__actions{position:absolute;left:12px;right:12px;bottom:12px;display:flex;gap:8px;transform:translateY(140%);opacity:0;transition:.4s var(--ease)}
.product-card:hover .product-card__actions{transform:translateY(0);opacity:1}
.product-card__actions .btn{flex:1;padding:12px 10px;font-size:11px}
.product-card__body{padding:16px 16px 20px}
.product-card__name{font-family:var(--ff-display);font-weight:800;font-size:16px;text-transform:uppercase;letter-spacing:.02em;margin:0 0 4px}
.product-card__colour{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:7px;margin-bottom:8px}
.swatch{width:14px;height:14px;border-radius:50%;border:1px solid rgba(13,13,13,.15);display:inline-block;transition:transform .25s var(--ease)}
.product-card:hover .swatch{transform:scale(1.25)}
.product-card__price{font-family:var(--ff-display);font-weight:800;font-size:16px}
.product-card__price .was{color:var(--muted);text-decoration:line-through;font-weight:500;margin-right:6px;font-size:13px}

/* Swatch row */
.swatch-row{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.swatch-row .swatch{width:18px;height:18px;cursor:pointer}
.swatch-row .swatch:hover{transform:scale(1.3);box-shadow:0 0 0 2px var(--white),0 0 0 3px var(--ink)}

/* ============================================================
   Character collection
   ============================================================ */
.char-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.char-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;background:var(--offwhite);border:1px solid var(--line)}
.char-card .ph-figure{width:100%;height:100%;transition:transform .6s var(--ease)}
.char-card:hover .ph-figure{transform:scale(1.06)}
.char-card__label{position:absolute;left:0;right:0;bottom:0;padding:14px;background:linear-gradient(transparent,rgba(13,13,13,.78));color:#fff;font-family:var(--ff-display);font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:14px}

/* ============================================================
   Drop section
   ============================================================ */
.drop{background:var(--ink);color:#fff;border-radius:24px;overflow:hidden;display:grid;grid-template-columns:1fr 1fr;align-items:center}
.drop__text{padding:70px 56px}
.drop__text .eyebrow{color:var(--gold)}
.drop__text h2{font-size:clamp(34px,5vw,64px);text-transform:uppercase;color:#fff}
.drop__text p{color:rgba(255,255,255,.72);max-width:420px}
.drop__visual{aspect-ratio:1/1;background:linear-gradient(160deg,#2a2a2a,#0d0d0d);position:relative;min-height:100%}
.drop .btn{background:#fff;color:var(--ink);border-color:#fff}
.drop .btn:hover{background:var(--blood);color:#fff;border-color:var(--blood)}

/* ============================================================
   Manga panel lookbook
   ============================================================ */
.manga-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:200px;gap:14px}
.manga-panel{position:relative;border:3px solid var(--ink);border-radius:6px;overflow:hidden;background:var(--offwhite)}
.manga-panel .ph-figure{width:100%;height:100%;transition:transform .6s var(--ease)}
.manga-panel:hover .ph-figure{transform:scale(1.1)}
.manga-panel__cap{position:absolute;left:10px;top:10px;background:var(--white);border:2px solid var(--ink);font-family:var(--ff-display);font-weight:800;text-transform:uppercase;font-size:11px;letter-spacing:.08em;padding:4px 9px;transform:rotate(-2deg)}
.manga-panel .hover-cap{position:absolute;inset:0;display:flex;align-items:flex-end;padding:16px;background:linear-gradient(transparent 40%,rgba(13,13,13,.7));color:#fff;opacity:0;transition:.4s var(--ease);font-family:var(--ff-display);font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.manga-panel:hover .hover-cap{opacity:1}
.m-a{grid-column:span 3;grid-row:span 2}
.m-b{grid-column:span 3;grid-row:span 1}
.m-c{grid-column:span 2;grid-row:span 1}
.m-d{grid-column:span 1;grid-row:span 1}
.m-e{grid-column:span 3;grid-row:span 1}
.m-f{grid-column:span 3;grid-row:span 1}

/* ============================================================
   Brand values
   ============================================================ */
.values-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.value{text-align:center;padding:30px 16px;border:1px solid var(--line);border-radius:var(--radius);transition:.35s var(--ease);background:var(--white)}
.value:hover{background:var(--ink);color:#fff;transform:translateY(-6px)}
.value:hover .value__icon{background:var(--blood);color:#fff}
.value__icon{width:54px;height:54px;border-radius:50%;background:var(--offwhite);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:24px;transition:.35s var(--ease)}
.value h4{text-transform:uppercase;letter-spacing:.06em;font-size:15px;margin:0}

/* ============================================================
   Materials
   ============================================================ */
.materials{background:var(--offwhite)}
.mat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.mat{background:var(--white);border-radius:var(--radius);padding:30px;border:1px solid var(--line);display:flex;gap:16px;align-items:flex-start}
.mat__num{font-family:var(--ff-display);font-weight:900;font-size:22px;color:var(--blood);line-height:1}
.mat h4{text-transform:uppercase;font-size:15px;letter-spacing:.04em;margin:0 0 4px}
.mat p{margin:0;color:var(--muted);font-size:14px}

/* ============================================================
   Newsletter
   ============================================================ */
.newsletter{background:var(--ink);color:#fff;border-radius:24px;padding:70px 40px;text-align:center;position:relative;overflow:hidden}
.newsletter::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(255,111,174,.18),transparent 40%),radial-gradient(circle at 80% 80%,rgba(0,102,255,.18),transparent 42%)}
.newsletter > *{position:relative;z-index:2}
.newsletter h2{font-size:clamp(30px,5vw,56px);text-transform:uppercase;color:#fff}
.newsletter p{color:rgba(255,255,255,.74);max-width:520px;margin:0 auto 26px}
.news-form{display:flex;gap:10px;max-width:460px;margin:0 auto;flex-wrap:wrap}
.news-form input{flex:1;min-width:200px;padding:15px 20px;border-radius:50px;border:2px solid rgba(255,255,255,.25);background:rgba(255,255,255,.06);color:#fff;font-size:14px;font-family:var(--ff-body)}
.news-form input::placeholder{color:rgba(255,255,255,.55)}
.news-form .btn{background:var(--blood);border-color:var(--blood)}
.news-form .btn:hover{background:#fff;color:var(--ink);border-color:#fff}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{background:var(--white);border-top:1px solid var(--line);padding:70px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:50px}
.footer-brand .brand{font-size:30px;display:inline-block;margin-bottom:14px}
.footer-brand p{color:var(--muted);max-width:280px;font-size:14px}
.footer-col h5{font-family:var(--ff-display);text-transform:uppercase;letter-spacing:.1em;font-size:13px;margin:0 0 16px}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin-bottom:10px}
.footer-col a{color:var(--muted);font-size:14px}
.footer-col a:hover{color:var(--ink)}
.social-row{display:flex;gap:12px;margin-top:16px}
.social-row a{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink);font-family:var(--ff-display);font-weight:800;font-size:13px}
.social-row a:hover{background:var(--ink);color:#fff;transform:translateY(-3px)}
.footer-bottom{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:var(--muted);font-size:13px}

/* ============================================================
   Quick view modal
   ============================================================ */
.qv-overlay{position:fixed;inset:0;background:rgba(13,13,13,.55);z-index:1300;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;transition:.35s var(--ease)}
.qv-overlay.open{opacity:1;visibility:visible}
.qv-modal{background:#fff;border-radius:var(--radius);max-width:840px;width:100%;display:grid;grid-template-columns:1fr 1fr;overflow:hidden;transform:translateY(20px) scale(.98);transition:.4s var(--ease);max-height:90vh;position:relative}
.qv-overlay.open .qv-modal{transform:none}
.qv-modal__media{background:var(--offwhite);aspect-ratio:1/1}
.qv-modal__body{padding:34px;overflow:auto}
.qv-modal__body h3{font-size:26px;text-transform:uppercase;margin-bottom:6px}
.qv-close{position:absolute;top:16px;right:16px;background:#fff;border:1px solid var(--line);width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:18px;z-index:2}

/* ============================================================
   Placeholder figures (anime-inspired tone art)
   ============================================================ */
.ph-figure{position:relative;display:block;background:
   radial-gradient(circle at 50% 32%,rgba(255,255,255,.85),transparent 55%),
   linear-gradient(160deg,var(--c1,#ece6dd),var(--c2,#d9d2c7));}
.ph-figure::before{content:"";position:absolute;inset:0;background-image:
   repeating-linear-gradient(45deg,rgba(13,13,13,.05) 0 2px,transparent 2px 14px);opacity:.6}
.ph-figure::after{content:attr(data-label);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:14px;font-family:var(--ff-display);font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:13px;color:rgba(13,13,13,.42)}

/* ============================================================
   Page content / generic
   ============================================================ */
.page-hero{padding:160px 0 60px;background:var(--offwhite);text-align:center}
.page-hero h1{font-size:clamp(36px,6vw,76px);text-transform:uppercase}
.page-hero .crumbs{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.14em}
.entry{max-width:820px;margin:0 auto;padding:60px 24px}
.entry h2{font-size:30px;margin-top:1.4em}
.entry h3{font-size:22px;margin-top:1.2em}
.entry img{border-radius:var(--radius);margin:1.4em 0}
.entry ul,.entry ol{padding-left:1.3em;margin-bottom:1.2em}
.entry li{margin-bottom:.5em}
.faq-item{border:1px solid var(--line);border-radius:var(--radius);margin-bottom:14px;overflow:hidden}
.faq-q{padding:20px 24px;font-family:var(--ff-display);font-weight:800;text-transform:uppercase;font-size:15px;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.faq-q .plus{transition:transform .3s var(--ease)}
.faq-item.open .faq-q .plus{transform:rotate(45deg)}
.faq-a{padding:0 24px;max-height:0;overflow:hidden;transition:max-height .4s var(--ease),padding .4s var(--ease);color:var(--muted)}
.faq-item.open .faq-a{padding:0 24px 22px;max-height:400px}
.size-table{width:100%;border-collapse:collapse;margin:20px 0}
.size-table th,.size-table td{border:1px solid var(--line);padding:12px 14px;text-align:center;font-size:14px}
.size-table th{background:var(--ink);color:#fff;font-family:var(--ff-display);text-transform:uppercase;letter-spacing:.06em}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;max-width:1000px;margin:0 auto;padding:60px 24px}
.contact-form input,.contact-form textarea{width:100%;padding:14px 18px;border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:14px;font-family:var(--ff-body);font-size:15px}
.contact-form textarea{min-height:140px;resize:vertical}

/* ============================================================
   Scroll reveal
   ============================================================ */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   WooCommerce
   ============================================================ */
.woocommerce-products-header{padding:150px 24px 20px;text-align:center;max-width:var(--maxw);margin:0 auto}
.woocommerce-products-header__title{font-size:clamp(34px,5vw,64px);text-transform:uppercase}
.woocommerce .products ul,.woocommerce ul.products{display:grid !important;grid-template-columns:repeat(4,1fr);gap:26px;margin:0;list-style:none}
.woocommerce ul.products li.product,.woocommerce-page ul.products li.product{width:auto !important;margin:0 !important;float:none !important;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;padding:0;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.woocommerce ul.products li.product:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.woocommerce ul.products li.product a img{margin:0;border-radius:0}
.woocommerce ul.products li.product .woocommerce-loop-product__title{padding:14px 16px 4px;font-family:var(--ff-display);font-weight:800;text-transform:uppercase;font-size:15px}
.woocommerce ul.products li.product .price{padding:0 16px;font-family:var(--ff-display);font-weight:800;color:var(--ink);display:block}
.woocommerce ul.products li.product .price del{color:var(--muted);font-weight:400}
.woocommerce ul.products li.product .button,.woocommerce ul.products li.product .added_to_cart{margin:12px 16px 18px;display:inline-block;background:var(--ink);color:#fff;border-radius:50px;padding:11px 20px;font-family:var(--ff-display);font-weight:800;text-transform:uppercase;font-size:12px;letter-spacing:.06em;border:2px solid var(--ink);transition:.3s var(--ease)}
.woocommerce ul.products li.product .button:hover{background:var(--blood);border-color:var(--blood)}
.woocommerce span.onsale{background:var(--blood);color:#fff;border-radius:50px;font-family:var(--ff-display);font-weight:800;text-transform:uppercase;font-size:11px;min-height:auto;min-width:auto;padding:6px 12px;top:12px;left:12px;right:auto;margin:0;position:absolute}
.woocommerce div.product .product_title{font-size:clamp(28px,4vw,48px);text-transform:uppercase}
.woocommerce div.product p.price,.woocommerce div.product span.price{color:var(--ink);font-family:var(--ff-display);font-weight:800;font-size:26px}
.woocommerce div.product .woocommerce-product-details__short-description{color:var(--charcoal)}
.woocommerce #respond input#submit,.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,.woocommerce div.product form.cart .button{background:var(--ink);color:#fff;border-radius:50px;font-family:var(--ff-display);font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:14px 28px;border:2px solid var(--ink);transition:.3s var(--ease)}
.woocommerce #respond input#submit:hover,.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover,.woocommerce div.product form.cart .button:hover{background:var(--blood);border-color:var(--blood);color:#fff}
.woocommerce .single_add_to_cart_button{width:auto}
.woocommerce-message,.woocommerce-info,.woocommerce-error{border-top-color:var(--blood)}
.woocommerce table.shop_table{border-radius:var(--radius);overflow:hidden}
.woocommerce .cart-collaterals .cart_totals,.woocommerce-checkout #payment{border-radius:var(--radius)}
/* Variation swatches (visual) */
.zenji-variation-swatches{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0 18px}
.zenji-variation-swatches .swatch{width:30px;height:30px;border-radius:50%;border:2px solid var(--line);cursor:pointer;transition:.25s var(--ease)}
.zenji-variation-swatches .swatch:hover,.zenji-variation-swatches .swatch.active{box-shadow:0 0 0 2px #fff,0 0 0 4px var(--ink);transform:scale(1.1)}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:1080px){
  .product-grid{grid-template-columns:repeat(3,1fr)}
  .char-grid{grid-template-columns:repeat(3,1fr)}
  .values-grid{grid-template-columns:repeat(3,1fr)}
  .woocommerce .products ul,.woocommerce ul.products{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:900px){
  .main-nav{display:none}
  .hamburger{display:flex}
  .hero-grid{grid-template-columns:1fr;gap:34px}
  .hero{min-height:auto;padding:130px 0 70px}
  .hero-visual{max-width:420px}
  .drop{grid-template-columns:1fr}
  .drop__text{padding:46px 30px}
  .manga-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .m-a,.m-b,.m-c,.m-d,.m-e,.m-f{grid-column:span 1;grid-row:span 1}
  .footer-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .qv-modal{grid-template-columns:1fr}
}
@media(max-width:680px){
  .section{padding:60px 0}
  .product-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .char-grid{grid-template-columns:repeat(2,1fr)}
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .mat-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .woocommerce .products ul,.woocommerce ul.products{grid-template-columns:repeat(2,1fr);gap:14px}
  .product-card__actions{position:static;transform:none;opacity:1;margin-top:10px}
}

/* ZENJI live CRO polish: product pages */
body.single-product .page-hero {
  display: none;
}
body.single-product div.product.type-product[id^="product-"] {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 122px 24px 72px;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, .82fr);
  gap: clamp(32px, 5vw, 68px);
  align-items: start;
}
body.single-product div.product.type-product[id^="product-"] div.images,
body.single-product div.product.type-product[id^="product-"] div.summary {
  float: none !important;
  width: auto !important;
}
body.single-product div.product.type-product[id^="product-"] div.images {
  margin: 0 !important;
}
body.single-product div.product.type-product[id^="product-"] div.images .woocommerce-product-gallery__wrapper {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: var(--offwhite);
}
body.single-product div.product.type-product[id^="product-"] div.images img {
  width: 100%;
  border-radius: 0;
}
body.single-product div.product.type-product[id^="product-"] div.summary {
  position: sticky;
  top: 96px;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(255,255,255,.94);
  box-shadow: var(--shadow-sm);
}
.zenji-trust-marks {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 20px 0;
}
.zenji-trust-marks span {
  min-height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--offwhite);
  font-family: var(--ff-display);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-align: center;
  text-transform: uppercase;
}
body.single-product table.variations {
  width: 100%;
  margin: 18px 0 10px;
}
body.single-product table.variations th,
body.single-product table.variations td {
  display: block;
  padding: 0 0 10px;
  text-align: left;
}
body.single-product table.variations label {
  font-family: var(--ff-display);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}
body.single-product table.variations select,
.woocommerce div.product form.cart .variations select,
.woocommerce .quantity .qty {
  width: 100%;
  min-height: 52px;
  border: 2px solid var(--ink);
  border-radius: 999px;
  background-color: #fff;
  color: var(--ink);
  font-weight: 700;
}
body.single-product .single_variation_wrap .woocommerce-variation-price {
  margin: 12px 0;
}
body.single-product .single_variation_wrap .woocommerce-variation-add-to-cart {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 10px;
  align-items: stretch;
}
body.single-product .single_variation_wrap .single_add_to_cart_button {
  width: 100%;
  min-height: 54px;
}
.woocommerce div.product .woocommerce-tabs {
  max-width: var(--maxw);
  margin: 0 auto 70px;
  padding: 0 24px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
  padding: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  border-radius: 999px;
  background: #fff;
  border-color: var(--line);
}
@media(max-width:900px) {
  body.single-product div.product.type-product[id^="product-"] {
    grid-template-columns: 1fr;
    padding: 100px 18px 56px;
  }
  body.single-product div.product.type-product[id^="product-"] div.summary {
    position: static;
    padding: 0;
    border: 0;
    border-radius: 0;
    box-shadow: none;
  }
}
@media(max-width:680px) {
  .zenji-trust-marks {
    grid-template-columns: 1fr 1fr;
  }
  body.single-product .single_variation_wrap .woocommerce-variation-add-to-cart {
    position: sticky;
    bottom: 0;
    z-index: 40;
    grid-template-columns: 82px 1fr;
    margin: 16px -12px -8px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 20px 20px 0 0;
    background: #fff;
    box-shadow: 0 -16px 36px rgba(13,13,13,.12);
  }
}
