/* ============================================================
   MURATAKA GLOBAL STYLESHEET
   Link in every page: <link rel="stylesheet" href="murataka-global.css">
   For WordPress: enqueue via functions.php or upload to theme folder
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Bebas+Neue&family=Rajdhani:wght@300;400;600;700&family=Noto+Sans+JP:wght@300;700&display=swap');

/* ── VARIABLES ── */
:root {
  --red: #cc0022;
  --red-bright: #ff0033;
  --red-dim: #660011;
  --black: #060406;
  --dark: #0c0008;
  --darker: #080508;
  --card: #100010;
  --text: #c8b8c8;
  --text-dim: #664455;
  --white: #ffffff;
  --mono: 'Share Tech Mono', monospace;
  --display: 'Bebas Neue', sans-serif;
  --body: 'Rajdhani', sans-serif;
  --jp: 'Noto Sans JP', sans-serif;

  /* ── UNIVERSAL TEXT SIZES ── */
  --text-xs: 11px;      /* tiny labels, eyebrows, legal fine print */
  --text-sm: 13px;      /* tags, mono labels, table cells */
  --text-base: 16px;    /* body paragraphs */
  --text-md: 18px;      /* card descriptions, form inputs */
  --text-lg: 22px;      /* card names, sub-headings */
  --text-xl: 32px;      /* section titles */
  --text-2xl: clamp(36px, 5vw, 56px);  /* section names */
  --text-3xl: clamp(48px, 7vw, 80px);  /* page titles */
  --text-4xl: clamp(64px, 10vw, 120px); /* hero titles */

  /* ── SPACING ── */
  --page-pad: 48px;
  --section-pad: 80px 48px;
  --card-pad: 16px;
}

/* ── RESET ── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--black);
  color: var(--text);
  font-family: var(--body);
  font-size: var(--text-base);
  line-height: 1.6;
  overflow-x: hidden;
  cursor: crosshair;
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: var(--black); }
::-webkit-scrollbar-thumb { background: var(--red-dim); }
* { scrollbar-width: thin; scrollbar-color: var(--red-dim) transparent; }

/* ── TYPOGRAPHY ── */
h1, h2, h3, h4, h5, h6 { font-family: var(--display); color: var(--white); letter-spacing: 2px; line-height: 1; }

p, li { font-size: var(--text-base); line-height: 1.8; color: #333333; font-weight: 400; }

a { color: var(--red); text-decoration: none; transition: color 0.2s; }
a:hover { color: var(--red-bright); }

/* ── NAV ── */
.mrt-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; justify-content: space-between; align-items: center;
  padding: 0 var(--page-pad); height: 64px;
  background: rgba(6,4,6,0.95);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid #cc002218;
}
.mrt-nav::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--red), transparent);
}
.mrt-nav-logo { display: flex; align-items: center; gap: 14px; text-decoration: none; }
.mrt-nav-seal {
  width: 36px; height: 36px; border: 1px solid #cc002244;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-family: var(--jp); font-size: 13px; color: var(--red);
  transition: all 0.3s;
}
.mrt-nav-logo:hover .mrt-nav-seal { border-color: var(--red); box-shadow: 0 0 10px #cc002433; }
.mrt-nav-brand-main { font-family: var(--display); font-size: 20px; letter-spacing: 4px; color: var(--white); line-height: 1; }
.mrt-nav-brand-sub { font-family: var(--jp); font-size: 9px; color: var(--red); letter-spacing: 6px; opacity: 0.7; }
.mrt-nav-links { display: flex; gap: 36px; list-style: none; }
.mrt-nav-links a {
  text-decoration: none; color: var(--text-dim);
  font-family: var(--mono); font-size: var(--text-xs); letter-spacing: 3px;
  transition: color 0.2s; position: relative;
}
.mrt-nav-links a::after { content: ''; position: absolute; bottom: -4px; left: 0; width: 0; height: 1px; background: var(--red); transition: width 0.3s; }
.mrt-nav-links a:hover { color: var(--white); }
.mrt-nav-links a:hover::after { width: 100%; }
.mrt-nav-cta {
  background: var(--red); color: var(--white) !important;
  padding: 8px 20px; font-family: var(--mono) !important;
  font-size: 10px !important; letter-spacing: 3px !important;
  transition: background 0.2s !important;
}
.mrt-nav-cta:hover { background: var(--red-bright) !important; }
.mrt-nav-cta::after { display: none !important; }

/* ── PAGE HEADER ── */
.mrt-page-header {
  padding: 120px var(--page-pad) 60px;
  position: relative; overflow: hidden;
  border-bottom: 1px solid #cc002218;
}
.mrt-page-header::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 20% 50%, #1a000a 0%, transparent 60%);
}
.mrt-page-header-content { position: relative; z-index: 2; }
.mrt-page-eyebrow {
  font-family: var(--mono); font-size: var(--text-xs);
  letter-spacing: 6px; color: var(--red); margin-bottom: 16px;
  display: flex; align-items: center; gap: 12px;
}
.mrt-page-eyebrow::before { content: ''; width: 30px; height: 1px; background: var(--red); }
.mrt-page-title {
  font-family: var(--display); font-size: var(--text-3xl);
  color: var(--white); letter-spacing: 2px; line-height: 1; margin-bottom: 16px;
}
.mrt-page-title span { color: var(--red); }
.mrt-page-sub {
  font-family: var(--mono); font-size: var(--text-sm);
  color: var(--text-dim); letter-spacing: 3px;
}

/* ── SECTION HEADERS ── */
.mrt-section-label {
  font-family: var(--mono); font-size: var(--text-sm);
  letter-spacing: 4px; color: var(--red); margin-bottom: 8px;
}
.mrt-section-title {
  font-family: var(--display); font-size: var(--text-2xl);
  color: var(--white); letter-spacing: 2px; line-height: 1;
}
.mrt-section-title span { color: var(--red); }
.mrt-section-sub {
  font-size: var(--text-base); color: var(--text-dim);
  font-weight: 300; max-width: 480px; line-height: 1.7;
}

/* ── DIVIDERS ── */
.mrt-divider { height: 1px; background: #cc002215; margin: 0 var(--page-pad); }
.mrt-red-line {
  height: 1px; background: var(--red); opacity: 0.3;
  margin: 0 var(--page-pad);
}

/* ── BUTTONS ── */
.mrt-btn-primary {
  background: var(--red); border: none;
  padding: 14px 32px;
  font-family: var(--mono); font-size: var(--text-xs); letter-spacing: 4px;
  color: var(--white); cursor: pointer; transition: all 0.2s;
  text-decoration: none; display: inline-block;
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
}
.mrt-btn-primary:hover { background: var(--red-bright); box-shadow: 0 0 20px #cc002244; color: var(--white); }

.mrt-btn-secondary {
  border: 1px solid var(--red-dim); padding: 14px 32px;
  font-family: var(--mono); font-size: var(--text-xs); letter-spacing: 4px;
  color: var(--text-dim); text-decoration: none; display: inline-block;
  transition: all 0.2s; background: transparent;
}
.mrt-btn-secondary:hover { border-color: var(--red); color: var(--white); }

.mrt-btn-ghost {
  border: 1px solid #cc002244; padding: 10px 20px;
  font-family: var(--mono); font-size: var(--text-xs); letter-spacing: 3px;
  color: var(--red); background: transparent; cursor: pointer;
  transition: all 0.2s;
}
.mrt-btn-ghost:hover { background: #cc000210; border-color: var(--red); }

/* ── TAGS ── */
.mrt-tag {
  font-family: var(--mono); font-size: var(--text-sm);
  letter-spacing: 2px; padding: 4px 10px;
  background: var(--red); color: var(--white);
  display: inline-block;
}
.mrt-tag-outline {
  font-family: var(--mono); font-size: var(--text-sm);
  letter-spacing: 2px; padding: 4px 10px;
  border: 1px solid #cc002244; color: var(--text-dim);
  display: inline-block; transition: all 0.2s;
}
.mrt-tag-outline:hover { border-color: var(--red); color: var(--red); }

/* ── CARDS ── */
.mrt-card {
  background: var(--card); border: 1px solid #cc002218;
  position: relative; overflow: hidden; transition: all 0.3s;
}
.mrt-card:hover { border-color: #cc002255; transform: translateY(-3px); }
.mrt-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 2px; background: var(--red);
  transform: scaleX(0); transition: transform 0.3s;
}
.mrt-card:hover::before { transform: scaleX(1); }

/* ── INFO BOXES ── */
.mrt-info-box {
  background: var(--dark); border: 1px solid #cc002222;
  border-left: 3px solid var(--red); padding: 20px 24px;
  font-family: var(--mono); font-size: var(--text-sm);
  line-height: 1.8; color: var(--text);
}
.mrt-info-box.warning { border-left-color: #cc8800; background: #0a0800; }
.mrt-info-box-label { font-size: 10px; letter-spacing: 4px; color: var(--red); margin-bottom: 8px; }
.mrt-info-box.warning .mrt-info-box-label { color: #cc8800; }

/* ── LISTS ── */
.mrt-list { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.mrt-list li {
  display: flex; gap: 12px; align-items: flex-start;
  font-size: var(--text-base); line-height: 1.7; color: #333333; font-weight: 400;
}
.mrt-list li::before { content: '◆'; color: var(--red); font-size: 10px; margin-top: 5px; flex-shrink: 0; }

/* ── FORMS ── */
.mrt-form { display: flex; flex-direction: column; gap: 20px; }
.mrt-form-field { display: flex; flex-direction: column; gap: 8px; }
.mrt-form-label { font-family: var(--mono); font-size: var(--text-sm); letter-spacing: 3px; color: var(--red); }
.mrt-form-field input,
.mrt-form-field textarea,
.mrt-form-field select {
  background: var(--dark); border: none;
  border-bottom: 1px solid #cc002266;
  padding: 14px 0;
  font-family: var(--mono); font-size: var(--text-md);
  color: var(--white); outline: none;
  transition: border-color 0.3s, background 0.3s;
  width: 100%; letter-spacing: 1px;
  resize: vertical;
}
.mrt-form-field input:focus,
.mrt-form-field textarea:focus,
.mrt-form-field select:focus { border-bottom-color: var(--red); background: #0c0008; }
.mrt-form-field input::placeholder,
.mrt-form-field textarea::placeholder { color: var(--text-dim); }
.mrt-form-field select option { background: var(--dark); }

.mrt-form-submit {
  background: var(--red); border: none; padding: 16px 40px;
  font-family: var(--mono); font-size: var(--text-xs); letter-spacing: 5px;
  color: var(--white); cursor: pointer; transition: all 0.2s; align-self: flex-start;
  clip-path: polygon(0 0, calc(100% - 12px) 0, 100% 12px, 100% 100%, 12px 100%, 0 calc(100% - 12px));
}
.mrt-form-submit:hover { background: var(--red-bright); box-shadow: 0 0 20px #cc002244; }

/* ── FOOTER ── */
.mrt-footer {
  background: var(--darker); border-top: 1px solid #cc002218;
  padding: 32px var(--page-pad);
  display: flex; justify-content: space-between; align-items: center;
}
.mrt-footer::before {
  display: none; /* top red line handled by border */
}
.mrt-footer-brand { font-family: var(--display); font-size: 18px; letter-spacing: 4px; color: var(--white); }
.mrt-footer-copy { font-family: var(--mono); font-size: 10px; color: var(--text-dim); letter-spacing: 2px; }
.mrt-footer-jp { font-family: var(--jp); font-size: 11px; color: var(--red); opacity: 0.5; letter-spacing: 4px; }

/* ── ANIMATIONS ── */
@keyframes mrt-pulse { 0%,100%{opacity:1} 50%{opacity:0.3} }
@keyframes mrt-fadeUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }
@keyframes mrt-scan { 0%{top:0} 100%{top:100vh} }
@keyframes mrt-glitch { 0%, 90%, 100% { transform: none; } 91% { transform: skew(-1deg); } 93% { transform: skew(1deg); } }

.mrt-animate-up { animation: mrt-fadeUp 0.8s ease both; }
.mrt-animate-up-delay { animation: mrt-fadeUp 0.8s ease 0.3s both; }

/* ── GRID OVERLAY ── */
.mrt-grid-overlay {
  position: absolute; inset: 0; pointer-events: none;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 60px, rgba(204,0,34,0.03) 60px, rgba(204,0,34,0.03) 61px),
    repeating-linear-gradient(90deg, transparent, transparent 60px, rgba(204,0,34,0.03) 60px, rgba(204,0,34,0.03) 61px);
}

/* ── BREADCRUMB ── */
.mrt-breadcrumb {
  padding: 24px var(--page-pad) 0;
  display: flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: var(--text-xs);
  letter-spacing: 2px; color: var(--text-dim);
}
.mrt-breadcrumb a { color: var(--text-dim); text-decoration: none; transition: color 0.2s; }
.mrt-breadcrumb a:hover { color: var(--red); }
.mrt-breadcrumb .sep { color: #440011; }
.mrt-breadcrumb .current { color: var(--text); }

/* ── TAB NAV (used on legal, shipping pages) ── */
.mrt-tab-nav {
  display: flex; border-bottom: 1px solid #cc002222;
  padding: 0 var(--page-pad); position: sticky;
  top: 64px; z-index: 50; background: var(--black);
}
.mrt-tab-btn {
  font-family: var(--mono); font-size: var(--text-sm);
  letter-spacing: 4px; color: var(--text-dim);
  padding: 20px 32px; cursor: pointer; border: none;
  background: transparent; border-bottom: 2px solid transparent;
  transition: all 0.2s; margin-bottom: -1px;
}
.mrt-tab-btn:hover { color: var(--white); }
.mrt-tab-btn.active { color: var(--red); border-bottom-color: var(--red); }

/* ── TABLE (shipping zones, specs) ── */
.mrt-table { width: 100%; border-collapse: collapse; }
.mrt-table th {
  background: var(--dark); font-family: var(--mono);
  font-size: var(--text-sm); letter-spacing: 3px; color: var(--red);
  padding: 12px 16px; text-align: left; border-bottom: 1px solid #cc002233;
}
.mrt-table td {
  padding: 12px 16px; font-family: var(--mono);
  font-size: var(--text-sm); color: var(--text);
  border-bottom: 1px solid #cc002215;
}
.mrt-table tr:last-child td { border-bottom: none; }
.mrt-table tr:nth-child(even) td { background: #0a0006; }
.mrt-table td:first-child { color: var(--white); }

/* ── WOOCOMMERCE OVERRIDES ── */
.woocommerce .price { font-family: var(--display) !important; color: var(--red) !important; }
.woocommerce .button {
  background: var(--red) !important; color: var(--white) !important;
  font-family: var(--mono) !important; letter-spacing: 3px !important;
  border-radius: 0 !important; border: none !important;
  transition: background 0.2s !important;
}
.woocommerce .button:hover { background: var(--red-bright) !important; }
.woocommerce .woocommerce-message { border-top-color: var(--red) !important; }
.woocommerce-store-notice { background: var(--red) !important; }

/* CF7 overrides */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form textarea {
  background: var(--dark) !important; border: none !important;
  border-bottom: 1px solid #cc002266 !important;
  font-family: var(--mono) !important; font-size: var(--text-md) !important;
  color: var(--white) !important; width: 100% !important;
  padding: 14px 0 !important; outline: none !important;
}
.wpcf7-form input[type="submit"] {
  background: var(--red) !important; border: none !important;
  font-family: var(--mono) !important; letter-spacing: 4px !important;
  color: var(--white) !important; padding: 14px 32px !important;
  cursor: pointer !important; transition: background 0.2s !important;
}
.wpcf7-not-valid-tip { font-family: var(--mono) !important; font-size: var(--text-xs) !important; color: var(--red) !important; }
.wpcf7-mail-sent-ok { border-color: #006622 !important; color: #00cc44 !important; font-family: var(--mono) !important; }

/* ── UTILITY CLASSES ── */
.mrt-red { color: var(--red); }
.mrt-white { color: var(--white); }
.mrt-dim { color: var(--text-dim); }
.mrt-mono { font-family: var(--mono); }
.mrt-display { font-family: var(--display); }
.mrt-jp { font-family: var(--jp); }
.mrt-border-red { border: 1px solid #cc002244; }
.mrt-border-left-red { border-left: 2px solid var(--red-dim); padding-left: 20px; }
.mrt-bg-dark { background: var(--dark); }
.mrt-bg-card { background: var(--card); }
.mrt-text-center { text-align: center; }
.mrt-text-right { text-align: right; }

/* ============================================================
   MURATAKA RESPONSIVE STYLES
   Breakpoints:
   -- Mobile S   : 320px
   -- Mobile     : up to 480px
   -- Mobile L   : up to 600px
   -- Tablet      : 601px – 900px
   -- Laptop      : 901px – 1200px
   -- Desktop     : 1201px – 1440px
   -- Wide        : 1441px – 1920px
   -- Ultra Wide  : 1921px+
   ============================================================ */

/* ── WIDE MONITORS (1441px – 1920px) ── */
@media (min-width: 1441px) {
  :root { --page-pad: 80px; }
  .mrt-nav { padding: 0 80px; }
  .mrt-footer { padding: 32px 80px; }
  .hero-content { max-width: 900px; }
  .products-grid { grid-template-columns: repeat(4, 1fr); }
  .related-grid { grid-template-columns: repeat(5, 1fr); }
}

/* ── ULTRA WIDE (1921px+) ── */
@media (min-width: 1921px) {
  :root { --page-pad: 120px; }
  body { max-width: 2400px; margin: 0 auto; }
  .mrt-nav { max-width: 2400px; left: 50%; transform: translateX(-50%); }
}

/* ── LAPTOP (901px – 1200px) ── */
@media (max-width: 1200px) {
  :root { --page-pad: 36px; }

  /* Nav */
  .mrt-nav { padding: 0 36px; }
  .mrt-nav-links { gap: 24px; }

  /* Homepage */
  .hero { padding: 100px 36px 60px; }
  .hero-logo-display { right: 36px; opacity: 0.5; }
  .hero-logo-display svg { width: 200px; height: 200px; }
  .products-grid { grid-template-columns: repeat(3, 1fr); }
  .about-strip { padding: 80px 36px; gap: 48px; }

  /* Products page */
  .section-header { padding: 40px 36px 28px; }
  .scroll-track-wrap { padding: 0 36px; }
  .custom-inner { padding: 36px; }
  .portfolio-grid { grid-template-columns: repeat(3, 1fr); }

  /* Product detail */
  .mrt-product { gap: 40px; padding: 32px 36px 60px; }

  /* About */
  .story-grid { gap: 48px; }
  .pillars-grid { grid-template-columns: repeat(3, 1fr); }
  .japan-inner { gap: 48px; }

  /* Legal / Shipping */
  .content-wrap { padding: 48px 36px 80px; }
}

/* ── TABLET (601px – 900px) ── */
@media (max-width: 900px) {
  :root {
    --page-pad: 24px;
    --text-base: 15px;
  }

  /* Nav — hide links, show hamburger */
  .mrt-nav { padding: 0 24px; height: 56px; }
  .mrt-nav-links { display: none; }
  .mrt-nav-hamburger {
    display: flex !important;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    background: none;
    border: none;
    padding: 8px;
  }
  .mrt-nav-hamburger span {
    display: block;
    width: 24px;
    height: 2px;
    background: #cc0022;
    transition: all 0.3s;
  }
  .mrt-nav-mobile {
    position: fixed;
    top: 56px; left: 0; right: 0;
    background: rgba(6,4,6,0.98);
    padding: 24px;
    display: none;
    flex-direction: column;
    gap: 0;
    z-index: 99;
    border-bottom: 1px solid #cc002233;
    backdrop-filter: blur(12px);
  }
  .mrt-nav-mobile.open { display: flex; }
  .mrt-nav-mobile a {
    font-family: 'Share Tech Mono', monospace;
    font-size: 14px;
    letter-spacing: 4px;
    color: #c8b8c8;
    text-decoration: none;
    padding: 16px 0;
    border-bottom: 1px solid #cc002215;
    display: block;
    transition: color 0.2s;
  }
  .mrt-nav-mobile a:hover { color: #cc0022; }
  .mrt-nav-mobile a:last-child { border-bottom: none; }

  /* Hero */
  .hero { padding: 90px 24px 60px; min-height: auto; }
  .hero-logo-display { display: none; }
  .hero-title { font-size: clamp(52px, 10vw, 80px); }
  .hero-lead { font-size: 16px; }
  .hero-btns { flex-direction: column; align-items: flex-start; }

  /* Stats strip */
  .stats-strip { grid-template-columns: repeat(2, 1fr); gap: 0; padding: 32px 24px; }
  .stat-item { padding: 16px; border-right: none; border-bottom: 1px solid #cc002218; }
  .stat-item:nth-child(odd) { border-right: 1px solid #cc002218; }
  .stat-item:nth-child(3),
  .stat-item:nth-child(4) { border-bottom: none; }
  .stat-num { font-size: 48px; }

  /* Homepage products */
  .products-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .section { padding: 60px 24px; }
  .section-head { flex-direction: column; gap: 12px; align-items: flex-start; }

  /* About strip */
  .about-strip { grid-template-columns: 1fr; padding: 60px 24px; gap: 40px; }
  .about-visual { height: 240px; }

  /* Marquee */
  .marquee-item { font-size: 11px; padding: 0 16px; }

  /* Products page */
  .page-header { padding: 90px 24px 40px; }
  .search-bar-wrap { padding: 0 24px 32px; }
  .section-header { padding: 32px 24px 24px; flex-direction: column; align-items: flex-start; gap: 8px; }
  .scroll-track-wrap { padding: 0 24px; }
  .product-card { flex: 0 0 240px; height: 380px; }
  .card-img { height: 180px; }
  .custom-inner { padding: 24px; }
  .portfolio-grid { grid-template-columns: repeat(2, 1fr); }
  .form-row { grid-template-columns: 1fr; }

  /* Product detail */
  .mrt-product { grid-template-columns: 1fr; gap: 32px; padding: 24px 24px 60px; }
  .mrt-gallery { position: static; }
  .mrt-gallery-main { aspect-ratio: 4/3; }
  .related-grid { grid-template-columns: repeat(2, 1fr); }
  .mrt-related { padding: 40px 24px 60px; }

  /* Contact */
  .page-wrap { grid-template-columns: 1fr; }
  .left-panel { padding: 90px 24px 40px; min-height: auto; }
  .left-bg-text { display: none; }
  .right-panel { padding: 40px 24px 60px; }
  .left-title { font-size: clamp(48px, 10vw, 72px); }

  /* About page */
  .story-section { padding: 60px 24px; }
  .story-grid { grid-template-columns: 1fr; gap: 48px; }
  .pillars-grid { grid-template-columns: 1fr; gap: 1px; }
  .japan-section { padding: 60px 24px; }
  .japan-inner { grid-template-columns: 1fr; gap: 32px; }
  .japan-visual { height: 200px; }
  .cta-section { padding: 60px 24px; }
  .cta-title { font-size: clamp(36px, 8vw, 60px); }
  .cta-btns { flex-direction: column; align-items: center; }

  /* Legal / Shipping */
  .content-wrap { grid-template-columns: 1fr; padding: 32px 24px 60px; }
  .toc { position: static; border-right: none; border-bottom: 1px solid #cc002218; padding-right: 0; padding-bottom: 24px; margin-bottom: 32px; }
  .legal-content { padding-left: 0; }
  .tab-nav { padding: 0 24px; overflow-x: auto; }
  .tab-btn { padding: 16px 20px; font-size: 11px; white-space: nowrap; }

  /* Footer */
  .mrt-footer { flex-direction: column; gap: 16px; text-align: center; padding: 32px 24px; }

  /* 404 */
  .bg-number { font-size: 50vw; }
  .err-main { padding: 80px 24px 0; }
  .nav-buttons { flex-direction: column; align-items: center; }
}

/* ── MOBILE L (up to 600px) ── */
@media (max-width: 600px) {
  :root { --text-base: 14px; }

  .hero-title { font-size: clamp(44px, 12vw, 64px); }
  .products-grid { grid-template-columns: 1fr; }
  .stats-strip { grid-template-columns: repeat(2, 1fr); }
  .product-card { flex: 0 0 220px; }
  .portfolio-grid { grid-template-columns: repeat(2, 1fr); }
  .request-form-wrap { padding: 24px 16px; }
  .related-grid { grid-template-columns: 1fr 1fr; }

  .mrt-product { padding: 16px 16px 48px; }
  .mrt-name { font-size: clamp(32px, 8vw, 48px); }
  .mrt-price-block .price { font-size: 40px !important; }
  .mrt-thumbs { grid-template-columns: repeat(3, 1fr); }

  .section-title { font-size: clamp(28px, 8vw, 44px); }
  .section-name { font-size: clamp(28px, 8vw, 44px); }
  .page-title { font-size: clamp(36px, 10vw, 60px); }

  .pillar-card { padding: 32px 24px; }
  .pillars-grid { gap: 0; }

  .section-block { margin-bottom: 40px; padding-bottom: 40px; }
  .section-title { font-size: 26px; }

  .zones-table { font-size: 11px; }
  .zones-table th, .zones-table td { padding: 8px 10px; }
}

/* ── MOBILE (up to 480px) ── */
@media (max-width: 480px) {
  .mrt-nav-brand-sub { display: none; }
  .hero-desc { font-size: 14px; }
  .hero-btns .mrt-btn-primary,
  .hero-btns .mrt-btn-secondary { width: 100%; text-align: center; }

  .product-card { flex: 0 0 200px; height: 360px; }
  .card-img { height: 160px; }
  .card-name { font-size: 18px; }

  .related-grid { grid-template-columns: 1fr; }
  .mrt-related-header { flex-direction: column; gap: 8px; align-items: flex-start; }

  .portfolio-grid { grid-template-columns: 1fr; }

  .japan-bg-text { font-size: 100px; }

  .stat-num { font-size: 40px; }
  .stat-label { font-size: 9px; }

  .mrt-footer { font-size: 11px; }
  .mrt-footer-brand { font-size: 14px; }
}

/* ── MOBILE S (320px) ── */
@media (max-width: 360px) {
  :root { --page-pad: 16px; }
  .mrt-nav { padding: 0 16px; }
  .hero { padding: 80px 16px 48px; }
  .product-card { flex: 0 0 180px; }
  .section-header, .custom-inner, .mrt-related { padding-left: 16px; padding-right: 16px; }
  .scroll-track-wrap { padding: 0 16px; }
  .search-bar-wrap { padding: 0 16px 24px; }
  .page-header { padding: 80px 16px 32px; }
}

/* ── HAMBURGER MENU — always hidden on desktop ── */
.mrt-nav-hamburger { display: none; }
.mrt-nav-mobile { display: none; }

/* ── TOUCH IMPROVEMENTS ── */
@media (hover: none) and (pointer: coarse) {
  .product-card:hover { transform: none; }
  .mrt-card:hover { transform: none; }
  .p-card:hover { transform: none; }
  .card-btn { padding: 10px 16px; }
  .mrt-btn-primary, .mrt-btn-secondary { padding: 16px 32px; }
  .tab-btn { padding: 18px 24px; }
  .mrt-gallery-arrow { padding: 16px 20px; }
  input, textarea, select { font-size: 16px !important; } /* prevents zoom on iOS */
}

/* ── PRINT ── */
@media print {
  .mrt-nav, .mrt-footer, .marquee-strip, .hero-logo-display { display: none; }
  body { background: #fff; color: #000; }
  a { color: #000; }
}

/* ============================================================
   CONTACT FORM 7 — FULL STYLE OVERRIDE
   Forces CF7 output to match original Murataka design
   ============================================================ */

/* Remove CF7 default wrapper styles */
.wpcf7 { margin: 0 !important; padding: 0 !important; }
.wpcf7-form { display: flex; flex-direction: column; gap: 20px; }

/* Each CF7 field block */
.wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}

/* Only hide CF7 auto-generated labels, not our custom ones */
.wpcf7 label:not(.mrt-cf7-label) {
  display: none !important;
}

/* All text inputs and email */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="number"],
.wpcf7-form input[type="url"] {
  background: #080508 !important;
  border: none !important;
  border: 1px solid #cc002233 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 12px 14px !important;
  font-family: 'Share Tech Mono', monospace !important;
  font-size: 14px !important;
  color: #ffffff !important;
  width: 100% !important;
  outline: none !important;
  transition: border-color 0.3s !important;
  letter-spacing: 1px !important;
}

.wpcf7-form input[type="text"]:focus,
.wpcf7-form input[type="email"]:focus,
.wpcf7-form input[type="tel"]:focus,
.wpcf7-form input[type="number"]:focus {
  border-bottom-color: #cc0022 !important;
  background: #0c0008 !important;
  outline: none !important;
  box-shadow: none !important;
}

.wpcf7-form input::placeholder { color: #664455 !important; }

/* Textarea */
.wpcf7-form textarea {
  background: #080508 !important;
  border: 1px solid #cc002233 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 12px 14px !important;
  font-family: 'Share Tech Mono', monospace !important;
  font-size: 14px !important;
  color: #ffffff !important;
  width: 100% !important;
  outline: none !important;
  resize: vertical !important;
  min-height: 120px !important;
  transition: border-color 0.3s !important;
}

.wpcf7-form textarea:focus {
  border-bottom-color: #cc0022 !important;
  background: #0c0008 !important;
  outline: none !important;
  box-shadow: none !important;
}

.wpcf7-form textarea::placeholder { color: #664455 !important; }

/* Select */
.wpcf7-form select {
  background: #080508 !important;
  border: 1px solid #cc002233 !important;
  border-radius: 0 !important;
  padding: 12px 14px !important;
  font-family: 'Share Tech Mono', monospace !important;
  font-size: 14px !important;
  color: #c8b8c8 !important;
  width: 100% !important;
  outline: none !important;
  appearance: none !important;
}

.wpcf7-form select option { background: #0c0008; color: #c8b8c8; }

/* Submit button */
.wpcf7-form input[type="submit"],
.wpcf7-submit {
  background: #cc0022 !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 16px 40px !important;
  font-family: 'Share Tech Mono', monospace !important;
  font-size: 12px !important;
  letter-spacing: 5px !important;
  color: #ffffff !important;
  cursor: pointer !important;
  transition: background 0.2s !important;
  text-transform: uppercase !important;
  box-shadow: none !important;
  clip-path: polygon(0 0, calc(100% - 12px) 0, 100% 12px, 100% 100%, 12px 100%, 0 calc(100% - 12px)) !important;
  align-self: flex-start !important;
  width: auto !important;
}

.wpcf7-form input[type="submit"]:hover,
.wpcf7-submit:hover {
  background: #ff0033 !important;
  box-shadow: 0 0 20px #cc002244 !important;
}

/* Validation error messages */
.wpcf7-not-valid-tip {
  font-family: 'Share Tech Mono', monospace !important;
  font-size: 11px !important;
  color: #cc0022 !important;
  letter-spacing: 2px !important;
  margin-top: 4px !important;
  display: block !important;
}

/* ============================================================
   CF7 & FORM STYLES — CLEAN SINGLE BLOCK
   ============================================================ */

/* Request form container — dark box */
.request-form-wrap {
  background: #0c0008;
  border: 1px solid #cc002222;
  padding: 36px;
  max-width: 700px;
}

/* Form title and sub */
.form-title { font-family: 'Bebas Neue', sans-serif; font-size: 28px; color: #1a0008; letter-spacing: 2px; margin-bottom: 8px; }
.form-sub { font-family: 'Share Tech Mono', monospace; font-size: 13px; color: #999; letter-spacing: 2px; margin-bottom: 28px; }

/* Reset wpcf7 form tag */
.request-form-wrap .wpcf7-form { display: block !important; }

/* Two column row */
.mrt-cf7-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-bottom: 20px;
}

/* Single field */
.mrt-cf7-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 20px;
  min-width: 0;
}

.mrt-cf7-field.full { grid-column: 1 / -1; }

/* Red label */
.mrt-cf7-label {
  font-family: 'Share Tech Mono', monospace;
  font-size: 12px;
  letter-spacing: 3px;
  color: #cc0022;
  display: block !important;
}

/* CF7 span wrapper */
.mrt-cf7-field .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
  min-width: 0;
}

/* All inputs */
.mrt-cf7-field input[type="text"],
.mrt-cf7-field input[type="email"],
.mrt-cf7-field input[type="number"],
.mrt-cf7-field input[type="tel"] {
  display: block;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  background: #080508;
  border: 1px solid #cc002233;
  padding: 12px 14px;
  font-family: 'Share Tech Mono', monospace;
  font-size: 14px;
  color: #ffffff;
  outline: none;
  transition: border-color 0.3s;
}

.mrt-cf7-field input:focus { border-bottom-color: #cc0022; }
.mrt-cf7-field input::placeholder { color: #bbb; }

/* Textarea */
.mrt-cf7-field textarea {
  display: block;
  width: 100%;
  box-sizing: border-box;
  background: #080508;
  border: 1px solid #cc002233;
  padding: 12px 14px;
  font-family: 'Share Tech Mono', monospace;
  font-size: 14px;
  color: #ffffff;
  outline: none;
  resize: vertical;
  min-height: 140px;
  transition: border-color 0.3s;
}

.mrt-cf7-field textarea:focus { border-bottom-color: #cc0022; }
.mrt-cf7-field textarea::placeholder { color: #bbb; }

/* Select */
.mrt-cf7-field select {
  display: block;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  background: #080508;
  border: 1px solid #cc002233;
  padding: 12px 14px;
  font-family: 'Share Tech Mono', monospace;
  font-size: 14px;
  color: #c8b8c8;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  transition: border-color 0.3s;
}

.mrt-cf7-field select:focus { border-bottom-color: #cc0022; }
.mrt-cf7-field select option { background: #0c0008; color: #c8b8c8; }

/* Submit button */
.request-form-wrap input[type="submit"],
.request-form-wrap .wpcf7-submit {
  background: #cc0022;
  border: none;
  padding: 16px 40px;
  font-family: 'Share Tech Mono', monospace;
  font-size: 12px;
  letter-spacing: 5px;
  color: #ffffff;
  cursor: pointer;
  transition: background 0.2s;
  text-transform: uppercase;
  clip-path: polygon(0 0, calc(100% - 12px) 0, 100% 12px, 100% 100%, 12px 100%, 0 calc(100% - 12px));
  display: inline-block;
  margin-top: 8px;
}

.request-form-wrap input[type="submit"]:hover,
.request-form-wrap .wpcf7-submit:hover { background: #ff0033; }

/* CF7 validation */
.wpcf7-not-valid-tip { font-family: 'Share Tech Mono', monospace; font-size: 11px; color: #cc0022; letter-spacing: 2px; margin-top: 4px; display: block; }
.wpcf7-mail-sent-ok { background: #001a0a; border-color: #006622 !important; color: #00cc44; font-family: 'Share Tech Mono', monospace; padding: 14px 16px; margin-top: 8px; }
.wpcf7-mail-sent-ng, .wpcf7-aborted { background: #1a0006; border-color: #cc0022 !important; color: #cc0022; font-family: 'Share Tech Mono', monospace; padding: 14px 16px; margin-top: 8px; }

/* Contact page CF7 labels */
.right-panel .wpcf7-form { display: flex; flex-direction: column; gap: 20px; }
.right-panel .wpcf7-form-control-wrap { display: block; width: 100%; }
.right-panel .wpcf7-form input[type="text"],
.right-panel .wpcf7-form input[type="email"],
.right-panel .wpcf7-form textarea {
  display: block; width: 100%; background: transparent;
  border: none; border-bottom: 1px solid #cc002266;
  padding: 14px 0; font-family: 'Share Tech Mono', monospace;
  font-size: 14px; color: #ffffff; outline: none; transition: border-color 0.3s;
}
.right-panel .wpcf7-form input:focus,
.right-panel .wpcf7-form textarea:focus { border-bottom-color: #cc0022; }
.right-panel .wpcf7-form input::placeholder,
.right-panel .wpcf7-form textarea::placeholder { color: #664455; }
.right-panel .wpcf7-form input[type="submit"] {
  background: #cc0022; border: none; padding: 16px 40px;
  font-family: 'Share Tech Mono', monospace; font-size: 12px;
  letter-spacing: 5px; color: #fff; cursor: pointer;
  clip-path: polygon(0 0, calc(100% - 12px) 0, 100% 12px, 100% 100%, 12px 100%, 0 calc(100% - 12px));
  transition: background 0.2s; margin-top: 8px;
}
.right-panel .wpcf7-form input[type="submit"]:hover { background: #ff0033; }

/* Mobile */
@media (max-width: 600px) {
  .mrt-cf7-row { grid-template-columns: 1fr; gap: 0; }
  .request-form-wrap { padding: 24px 16px; }
}
