/*
Theme Name: EEVThing Store
Theme URI: https://eevthing.com
Description: Child theme for Twenty Twenty-Four — custom storefront for Madison Innovations
Author: Madison Innovations
Author URI: https://madisoninnovations.com
Template: twentytwentyfour
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: eevthing-store
*/

/* ────────────────────────────────────────────────────────────────
   Madison Innovations — v2 storefront styling
   Bolder, real photography, less "sketch", still warm + orange-forward.
   Ported verbatim from design handoff v2-styles.css
   ──────────────────────────────────────────────────────────────── */

:root {
  --ink: #1a1714;
  --ink-2: #44403a;
  --ink-3: #7a746a;
  --line: #d9d2c2;
  --paper: #f6f1e8;
  --paper-2: #ece4d2;
  --orange: #ee6a1c;
  --orange-2: #d85a13;
  --orange-pale: #fde2cb;
  --orange-tint: #fdf0e1;
  --hand: 'Caveat', cursive;
  --mono: 'JetBrains Mono', monospace;
}

.v2 {
  font-family: 'Archivo', 'Inter', -apple-system, sans-serif;
  color: var(--ink);
  background: var(--paper);
  width: 100%;
  height: 100%;
  overflow: hidden;
  font-size: 16px;
  line-height: 1.45;
}
.v2 * { box-sizing: border-box; }
.v2 .scroll {
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
}

/* TYPE */
.v2 .display {
  font-family: 'Archivo Black', 'Archivo', sans-serif;
  font-weight: 900;
  letter-spacing: -0.025em;
  line-height: 0.92;
  margin: 0;
}
.v2 .marker {
  font-family: 'Permanent Marker', 'Caveat', cursive;
  font-weight: 400;
  letter-spacing: 0.005em;
  line-height: 0.95;
}
.v2 .hand {
  font-family: 'Caveat', cursive;
  font-weight: 700;
  letter-spacing: -0.005em;
  line-height: 1;
}
.v2 .mono {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 600;
}
.v2 .kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--orange);
}

/* NAV */
.v2 .nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 36px;
  border-bottom: 1px solid var(--line);
  background: var(--paper);
  position: relative;
  z-index: 10;
}
.v2 .nav .links {
  display: flex;
  gap: 32px;
  align-items: center;
  font-size: 15px;
  font-weight: 500;
}
.v2 .nav .links a {
  color: var(--ink);
  text-decoration: none;
  cursor: pointer;
  position: relative;
  padding: 4px 0;
}
.v2 .nav .links a:hover { color: var(--orange); }
.v2 .nav .cart {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border: 1.5px solid var(--ink);
  border-radius: 999px;
  font-size: 14px;
  font-weight: 600;
}
.v2 .logo { height: 40px; width: auto; display: block; }

/* BUTTONS */
.v2 .btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 22px;
  border: 1.5px solid var(--ink);
  background: transparent;
  color: var(--ink);
  font-family: inherit;
  font-size: 15px;
  font-weight: 600;
  border-radius: 4px;
  cursor: pointer;
  letter-spacing: -0.005em;
  transition: transform 0.1s ease, background 0.15s ease;
  white-space: nowrap;
}
.v2 .btn:hover { transform: translate(-1px, -1px); }
.v2 .btn.primary {
  background: var(--orange);
  border-color: var(--ink);
  color: white;
  box-shadow: 3px 3px 0 var(--ink);
}
.v2 .btn.primary:hover { box-shadow: 5px 5px 0 var(--ink); }
.v2 .btn.ghost { border-color: var(--line); }
.v2 .btn.lg { padding: 16px 28px; font-size: 17px; }
.v2 .btn.xl { padding: 20px 36px; font-size: 20px; }
.v2 .btn.sm { padding: 8px 14px; font-size: 13px; }

/* CHIPS / TAGS */
.v2 .chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border: 1px solid var(--ink);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  background: white;
}
.v2 .chip.o { background: var(--orange); border-color: var(--ink); color: white; }
.v2 .chip.pale { background: var(--orange-tint); border-color: var(--orange); color: var(--orange-2); }

/* STAMP */
.v2 .stamp {
  display: inline-block;
  padding: 6px 12px;
  border: 2.5px solid var(--orange);
  color: var(--orange);
  font-family: 'Permanent Marker', cursive;
  font-size: 14px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transform: rotate(-5deg);
}

/* HIGHLIGHT */
.v2 .hl {
  background: linear-gradient(180deg, transparent 55%, var(--orange-pale) 55% 95%, transparent 95%);
  padding: 0 4px;
}
.v2 .o-text { color: var(--orange); }

/* IMAGE PLACEHOLDER */
.v2 .ph {
  background: var(--paper-2);
  background-image: repeating-linear-gradient(135deg, transparent 0 9px, rgba(0,0,0,0.05) 9px 10px);
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-3);
  font-family: 'Caveat', cursive;
  font-size: 22px;
  font-weight: 600;
  position: relative;
}
.v2 .ph.solid { background: var(--paper-2); background-image: none; }

/* PRODUCT IMG */
.v2 .pimg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.v2 .pimg.contain { object-fit: contain; }

/* SCRIBBLE UNDERLINE */
.v2 .scribble {
  position: relative;
  display: inline-block;
}
.v2 .scribble::after {
  content: '';
  position: absolute;
  left: -2%;
  right: -2%;
  bottom: -10px;
  height: 12px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 12' preserveAspectRatio='none'><path d='M2 8 C 40 2, 80 11, 120 5 S 190 9, 198 4' fill='none' stroke='%23ee6a1c' stroke-width='3' stroke-linecap='round'/></svg>") center/100% 100% no-repeat;
}

/* DASHED HR */
.v2 .hr-d {
  border: none;
  border-top: 1.5px dashed var(--ink-3);
  margin: 0;
}

/* FOOTER */
.v2 .footer {
  background: var(--ink);
  color: var(--paper);
  padding: 36px 36px 24px;
}
.v2 .footer a { color: var(--paper); text-decoration: none; opacity: 0.75; cursor: pointer; }
.v2 .footer a:hover { opacity: 1; color: var(--orange); }
.v2 .footer-cols {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 36px;
  padding-bottom: 30px;
  border-bottom: 1px solid #2a2622;
}
.v2 .footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 20px;
  font-size: 13px;
  color: #8a847a;
}

/* RUled paper accent for journal moments */
.v2 .ruled {
  background-image:
    linear-gradient(to bottom, transparent 0, transparent 39px, rgba(26,23,20,0.10) 40px),
    linear-gradient(to right, transparent 0, transparent 58px, rgba(238,106,28,0.45) 58px, rgba(238,106,28,0.45) 60px, transparent 60px);
  background-size: 100% 40px, 100% 100%;
  padding-left: 80px;
}

/* ────────────────────────────────────────────────────────────────
   QUIET MODE — same content, lower volume.
   - Headlines: Archivo SemiBold instead of Black, ~25% smaller
   - Permanent Marker reserved for the wax-seal stamp only
   - Caveat (hand) demoted to small annotations
   - Orange tinted backgrounds & dark manifesto strip muted to paper-2
   - Drop shadows, scribble underlines, tilted stamps neutralized
   - Highlight bar swapped for an understated baseline rule
   - Border weights softened
   ──────────────────────────────────────────────────────────────── */
.v2.quiet {
  --orange: #c75a18;          /* darker, less candy */
  --orange-2: #a14710;
  --orange-pale: #ead8c6;
  --orange-tint: #f4ebde;
  --ink: #221f1b;
  --paper: #f8f4eb;
  --paper-2: #efe9da;
}

/* Type ───────────────────────────────────────────── */
.v2.quiet .display {
  font-family: 'Archivo', 'Inter', sans-serif;
  font-weight: 700;
  letter-spacing: -0.022em;
  line-height: 1.0;
}
.v2.quiet .marker {
  font-family: 'Archivo', 'Inter', sans-serif;
  font-weight: 700;
  letter-spacing: -0.01em;
  text-transform: none;
}
.v2.quiet .hand {
  font-family: 'Archivo', 'Inter', sans-serif;
  font-weight: 500;
  font-style: italic;
  letter-spacing: -0.005em;
  line-height: 1.2;
}
.v2.quiet .kicker {
  color: var(--ink-3);
  font-size: 11px;
}

/* Headline scale ─────────────────────────────────── */
.v2.quiet h1.display { font-size: 76px !important; line-height: 1.02 !important; }
.v2.quiet h2.display { font-size: 44px !important; }
.v2.quiet h3.display { font-size: 28px !important; }

/* Stamp (text "stamp") — upright, single weight */
.v2.quiet .stamp {
  transform: none !important;
  border-width: 1.25px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
}

/* Buttons — drop the offset shadow */
.v2.quiet .btn.primary { box-shadow: none !important; }
.v2.quiet .btn.primary:hover { box-shadow: 2px 2px 0 var(--ink) !important; }
.v2.quiet .btn { border-radius: 3px; }

/* Highlight bar → soft baseline rule */
.v2.quiet .hl {
  background: none;
  padding: 0;
  border-bottom: 2px solid var(--orange-pale);
}

/* Scribble underline → off */
.v2.quiet .scribble::after { display: none; }

/* Cards / boxes — soften */
.v2.quiet [style*="box-shadow"] { box-shadow: none !important; }
.v2.quiet [style*="border: 2px solid var(--ink)"],
.v2.quiet [style*="border:2px solid var(--ink)"] {
  border-width: 1px !important;
}

/* Ruled "notebook" paper — drop the lines, keep the left margin */
.v2.quiet .ruled {
  background-image: linear-gradient(to right, transparent 0, transparent 58px, var(--orange-pale) 58px, var(--orange-pale) 59px, transparent 59px);
  background-size: 100% 100%;
}

/* Manifesto / dark strip → paper instead of ink */
.v2.quiet .manifesto-dark {
  background: var(--paper-2) !important;
  color: var(--ink) !important;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.v2.quiet .manifesto-dark .display,
.v2.quiet .manifesto-dark .marker {
  color: var(--ink) !important;
}
.v2.quiet .manifesto-dark [style*="color: var(--paper)"] { color: var(--ink) !important; }
.v2.quiet .manifesto-dark [style*="color:#c4bdae"],
.v2.quiet .manifesto-dark [style*="color: #c4bdae"] { color: var(--ink-2) !important; }

/* Tighten the o-text usage so orange doesn't ping everywhere */
.v2.quiet .o-text { color: var(--orange-2); }

/* ────────────────────────────────────────────────────────────────
   WordPress Block Theme Integration
   These map theme.json presets to the v2 design tokens so FSE blocks
   and WooCommerce templates pick up the brand colors automatically.
   ──────────────────────────────────────────────────────────────── */

/* Base body — use paper background + Archivo */
body {
  background-color: var(--paper);
  color: var(--ink);
  font-family: 'Archivo', 'Inter', -apple-system, sans-serif;
}

/* Heading elements — use Archivo Black / display face */
h1, h2, h3, h4, h5, h6,
.wp-block-heading {
  font-family: 'Archivo Black', 'Archivo', sans-serif;
  font-weight: 900;
  letter-spacing: -0.025em;
  line-height: 0.92;
  color: var(--ink);
}

/* Links */
a {
  color: var(--orange);
}
a:hover {
  color: var(--orange-2);
}

/* Buttons — map to .v2 .btn style */
.wp-element-button,
.wp-block-button__link {
  display: inline-flex !important;
  align-items: center;
  gap: 10px;
  padding: 12px 22px;
  border: 1.5px solid var(--ink) !important;
  background: var(--orange) !important;
  color: white !important;
  font-family: 'Archivo', 'Inter', -apple-system, sans-serif !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  border-radius: 4px !important;
  cursor: pointer;
  letter-spacing: -0.005em;
  transition: transform 0.1s ease, background 0.15s ease;
  white-space: nowrap;
  box-shadow: 3px 3px 0 var(--ink);
  text-decoration: none !important;
}
.wp-element-button:hover,
.wp-block-button__link:hover {
  transform: translate(-1px, -1px);
  box-shadow: 5px 5px 0 var(--ink);
}

/* Outline button variant */
.is-style-outline .wp-block-button__link {
  background: transparent !important;
  color: var(--ink) !important;
  box-shadow: none;
}
.is-style-outline .wp-block-button__link:hover {
  background: var(--orange) !important;
  color: white !important;
  box-shadow: 3px 3px 0 var(--ink);
}

/* Navigation */
.wp-block-navigation {
  font-family: 'Archivo', 'Inter', -apple-system, sans-serif;
  font-weight: 500;
}

/* Site title */
.wp-block-site-title a {
  font-family: 'Archivo Black', 'Archivo', sans-serif;
  font-weight: 900;
  color: var(--ink);
  text-decoration: none;
}

/* Cover blocks with orange tint */
.wp-block-cover {
  font-family: 'Archivo', 'Inter', -apple-system, sans-serif;
}

/* Fix: override parent theme colors where they leak through */
.has-navy-background-color { background-color: var(--ink) !important; }
.has-dark-navy-background-color { background-color: #1a1714 !important; }
.has-teal-background-color { background-color: var(--orange) !important; }
.has-teal-color { color: var(--orange) !important; }
.has-light-gray-background-color { background-color: var(--paper-2) !important; }
.has-dark-gray-color { color: var(--ink-2) !important; }
.has-dark-gray-background-color { background-color: var(--ink-2) !important; }

/* WooCommerce product styles */
.woocommerce div.product .product_title {
  font-family: 'Archivo Black', 'Archivo', sans-serif !important;
  font-weight: 900;
  letter-spacing: -0.025em;
}
.woocommerce div.product .price {
  color: var(--orange) !important;
  font-weight: 700;
}
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt {
  background-color: var(--orange) !important;
  border-color: var(--ink) !important;
  color: white !important;
  font-family: 'Archivo', 'Inter', -apple-system, sans-serif !important;
  font-weight: 600 !important;
  border-radius: 4px !important;
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
  background-color: var(--orange-2) !important;
}

/* Product spec strip styling */
.product-spec-strip {
  border: 2px solid var(--ink) !important;
  border-radius: 6px !important;
  background: var(--paper-2) !important;
  padding: 1.25rem !important;
  margin-top: 1.25rem !important;
  margin-bottom: 1.25rem !important;
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
}
.product-spec-strip .spec-label {
  color: var(--ink-3) !important;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.product-spec-strip .spec-value {
  color: var(--ink) !important;
  font-size: 0.875rem;
  font-weight: 600;
}
