/*
Theme Name: Boutique Cypherpunk
Theme URI: https://github.com/hairetikos/wp
Description: A cypherpunk / early-2000s child theme for Storefront (compatible alongside Boutique). Horizontal product-category nav at the top, mobile-first search, responsive header image, zero external CDNs, near-zero JavaScript, optional self-hosted emoji.
Author: hairetikos
Version: 1.0.0
Template: storefront
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: boutique-cypherpunk
Tags: woocommerce, dark, custom-colors, responsive-layout, two-columns, custom-menu
*/

/* =========================================================================
   0. DESIGN TOKENS
   ------------------------------------------------------------------------- */
:root {
    --cp-bg:        #07090b;
    --cp-bg-alt:    #0d1117;
    --cp-panel:     #11161d;
    --cp-ink:       #c8ffd8;
    --cp-ink-dim:   #7aa890;
    --cp-accent:    #39ff14;   /* matrix green */
    --cp-accent-2:  #ff2bd6;   /* magenta */
    --cp-accent-3:  #00e5ff;   /* cyan */
    --cp-warn:      #ffb000;
    --cp-rule:      #1f2a36;
    --cp-glow:      0 0 6px rgba(57,255,20,.55), 0 0 14px rgba(57,255,20,.25);
    --cp-glow-pink: 0 0 6px rgba(255,43,214,.55), 0 0 14px rgba(255,43,214,.25);
    --cp-mono:      ui-monospace, "Cascadia Mono", "JetBrains Mono", Consolas, "Courier New", monospace;
    --cp-radius:    2px;
}

/* =========================================================================
   1. GLOBAL RESET / TYPOGRAPHY
   ------------------------------------------------------------------------- */
html, body {
    background: var(--cp-bg);
    color: var(--cp-ink);
    font-family: var(--cp-mono);
    font-size: 16px;
    line-height: 1.55;
}

/* Subtle CRT scanlines + vignette — pure CSS, no images, no JS. */
body::before {
    content: "";
    position: fixed; inset: 0;
    pointer-events: none;
    z-index: 9999;
    background:
        repeating-linear-gradient(
            to bottom,
            rgba(255,255,255,0.018) 0px,
            rgba(255,255,255,0.018) 1px,
            transparent 1px,
            transparent 3px
        ),
        radial-gradient(ellipse at center, transparent 55%, rgba(0,0,0,.45) 100%);
    mix-blend-mode: screen;
}

a, a:visited {
    color: var(--cp-accent);
    text-decoration: none;
    border-bottom: 1px dashed rgba(57,255,20,.35);
    transition: color .12s, text-shadow .12s, border-color .12s;
}
a:hover, a:focus {
    color: var(--cp-accent-2);
    text-shadow: var(--cp-glow-pink);
    border-bottom-color: var(--cp-accent-2);
    outline: none;
}

h1, h2, h3, h4, h5, h6,
.page-title, .entry-title, .widget-title, .product_title {
    font-family: var(--cp-mono);
    color: var(--cp-accent);
    text-shadow: var(--cp-glow);
    letter-spacing: .02em;
    text-transform: uppercase;
}
h1 { font-size: 1.9rem; }
h2 { font-size: 1.4rem; }
h3 { font-size: 1.15rem; }

::selection { background: var(--cp-accent); color: #000; }

hr, .widget-title::after {
    border: 0;
    height: 1px;
    background: repeating-linear-gradient(to right, var(--cp-rule) 0 6px, transparent 6px 12px);
    margin: 1.25rem 0;
}

/* =========================================================================
   2. LAYOUT — site frame
   ------------------------------------------------------------------------- */
#page.hfeed.site {
    background: var(--cp-bg);
}

.col-full {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1rem;
}

/* =========================================================================
   3. TOP UTILITY BAR (search + cart) — always visible on mobile
   ------------------------------------------------------------------------- */
.cp-topbar {
    background: linear-gradient(90deg, #000 0%, var(--cp-bg-alt) 50%, #000 100%);
    border-bottom: 1px solid var(--cp-rule);
    padding: .35rem 0;
    font-size: .85rem;
}
.cp-topbar__inner {
    display: flex; flex-wrap: wrap;
    gap: .5rem;
    align-items: center;
    justify-content: space-between;
}
.cp-topbar__brand {
    color: var(--cp-accent);
    font-weight: 700;
    text-shadow: var(--cp-glow);
    letter-spacing: .15em;
    text-transform: uppercase;
    border: none;
}
.cp-topbar__brand::before { content: "> "; color: var(--cp-accent-2); }
.cp-topbar__brand .cp-caret {
    display: inline-block; width: .55em; height: 1em;
    background: var(--cp-accent);
    vertical-align: -2px;
    margin-left: .15em;
    animation: cp-blink 1.05s steps(2,end) infinite;
}
@keyframes cp-blink { 50% { opacity: 0; } }

.cp-topbar__search {
    flex: 1 1 240px;
    min-width: 200px;
}
.cp-topbar__search form,
.cp-search-form {
    display: flex; gap: .25rem;
    margin: 0;
}
.cp-topbar__search input[type="search"],
.cp-topbar__search input[type="text"],
.cp-search-form input[type="search"],
.cp-search-form input[type="text"] {
    flex: 1;
    background: #000;
    color: var(--cp-ink);
    border: 1px solid var(--cp-rule);
    border-left: 3px solid var(--cp-accent);
    padding: .35rem .5rem;
    font-family: var(--cp-mono);
    font-size: .9rem;
    border-radius: var(--cp-radius);
}
.cp-topbar__search input:focus,
.cp-search-form input:focus {
    outline: none;
    border-color: var(--cp-accent);
    box-shadow: var(--cp-glow);
}
.cp-topbar__search button,
.cp-search-form button,
.cp-search-form input[type="submit"] {
    background: var(--cp-accent);
    color: #000;
    border: 0;
    padding: .35rem .75rem;
    font-family: var(--cp-mono);
    font-weight: 700;
    cursor: pointer;
    letter-spacing: .1em;
    text-transform: uppercase;
    border-radius: var(--cp-radius);
}
.cp-topbar__search button:hover,
.cp-search-form button:hover {
    background: var(--cp-accent-2);
    color: #000;
    box-shadow: var(--cp-glow-pink);
}

.cp-topbar__cart a {
    border: 1px solid var(--cp-rule);
    padding: .25rem .55rem;
    border-radius: var(--cp-radius);
    background: #000;
}
.cp-topbar__cart a:hover { border-color: var(--cp-accent-2); }

/* =========================================================================
   4. HEADER — banner + responsive image
   ------------------------------------------------------------------------- */
.site-header {
    background-color: var(--cp-bg-alt) !important;
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    border-bottom: 1px solid var(--cp-rule);
    padding: 1.2rem 0 1rem;
    position: relative;
    overflow: hidden;
}
.site-header::after {
    /* phosphor glow line under header */
    content: "";
    position: absolute; left: 0; right: 0; bottom: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--cp-accent) 50%, transparent);
    box-shadow: var(--cp-glow);
}
.site-header .col-full {
    display: flex; flex-wrap: wrap;
    gap: 1rem; align-items: center; justify-content: space-between;
}
.site-branding { max-width: 100%; }

/* ---- SITE TITLE: terminal-console glow + interlace + blinking cursor ---- */
.site-title {
    position: relative;
    display: inline-block;
    margin: 0;
    font-family: var(--cp-mono);
    font-size: clamp(1.4rem, 4.5vw, 2.4rem);
    letter-spacing: .04em;
    line-height: 1.15;
    color: var(--cp-accent) !important;
    /* Multi-layer phosphor glow */
    text-shadow:
        0 0 2px  rgba(57,255,20,.95),
        0 0 6px  rgba(57,255,20,.75),
        0 0 14px rgba(57,255,20,.45),
        0 0 28px rgba(57,255,20,.30);
    /* Subtle CRT colour bleed */
    animation: cp-title-bleed 3.6s ease-in-out infinite alternate;
}
.site-title a,
.site-title a:visited {
    color: inherit !important;
    border: none !important;
    text-decoration: none;
    text-shadow: inherit;
}
.site-title a:hover {
    color: var(--cp-accent-2) !important;
    text-shadow:
        0 0 2px  rgba(255,43,214,.95),
        0 0 6px  rgba(255,43,214,.75),
        0 0 14px rgba(255,43,214,.45);
}

/* Blinking terminal cursor right after the title text. */
.site-title::after {
    content: "_";
    display: inline-block;
    margin-left: .15em;
    color: var(--cp-accent);
    text-shadow: var(--cp-glow);
    animation: cp-blink 1.05s steps(2, end) infinite;
}
.site-title a:hover + .site-title::after,
.site-title:hover::after { color: var(--cp-accent-2); }

/* Scanline / interlace overlay clipped to the title box only. */
.site-title::before {
    content: "";
    position: absolute;
    inset: -.1em -.2em;
    pointer-events: none;
    background: repeating-linear-gradient(
        to bottom,
        rgba(0,0,0,0)    0,
        rgba(0,0,0,0)    2px,
        rgba(0,0,0,.55)  2px,
        rgba(0,0,0,.55)  3px
    );
    mix-blend-mode: multiply;
    opacity: .65;
}

@keyframes cp-title-bleed {
    0%   { filter: hue-rotate(0deg)   drop-shadow(1px 0 0 rgba(255,43,214,.35))
                                       drop-shadow(-1px 0 0 rgba(0,229,255,.35)); }
    100% { filter: hue-rotate(-8deg)  drop-shadow(2px 0 0 rgba(255,43,214,.45))
                                       drop-shadow(-2px 0 0 rgba(0,229,255,.45)); }
}

.site-description {
    color: var(--cp-ink-dim);
    font-size: .85rem;
    margin-top: .2rem;
    font-style: italic;
}
.site-description::before { content: "// "; color: var(--cp-accent-3); }

/* Custom logo + header image: ALWAYS scale */
.custom-logo,
.site-header img,
.site-header-image img,
.wp-custom-header img {
    max-width: 100% !important;
    height: auto !important;
    display: block;
}
.wp-custom-header {
    width: 100%;
    max-height: 50vh;
    overflow: hidden;
}
.wp-custom-header img {
    width: 100%;
    object-fit: cover;
}

/* =========================================================================
   5. CATEGORY NAV BAR — horizontal, scrollable on mobile
   ------------------------------------------------------------------------- */
.cp-catnav {
    background: var(--cp-bg-alt);
    border-top: 1px solid var(--cp-rule);
    border-bottom: 1px solid var(--cp-rule);
    position: relative;
}
.cp-catnav::before, .cp-catnav::after {
    content: "";
    position: absolute; top: 0; bottom: 0; width: 24px;
    pointer-events: none;
    z-index: 2;
}
.cp-catnav::before { left: 0;  background: linear-gradient(90deg, var(--cp-bg-alt), transparent); }
.cp-catnav::after  { right: 0; background: linear-gradient(-90deg, var(--cp-bg-alt), transparent); }

.cp-catnav__list {
    display: flex;
    gap: 0;
    margin: 0; padding: 0;
    list-style: none;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: thin;
    scrollbar-color: var(--cp-accent) var(--cp-bg-alt);
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
}
.cp-catnav__list::-webkit-scrollbar { height: 6px; }
.cp-catnav__list::-webkit-scrollbar-thumb { background: var(--cp-accent); }

.cp-catnav__item { flex: 0 0 auto; }
.cp-catnav__link {
    display: inline-block;
    padding: .7rem 1rem;
    color: var(--cp-ink);
    border: none;
    border-right: 1px dashed var(--cp-rule);
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: .85rem;
    background: transparent;
    transition: background .12s, color .12s, text-shadow .12s;
}
.cp-catnav__link:hover,
.cp-catnav__link:focus,
.cp-catnav__item.current-cat .cp-catnav__link {
    background: #000;
    color: var(--cp-accent);
    text-shadow: var(--cp-glow);
}
.cp-catnav__link::before {
    content: "[ ";
    color: var(--cp-accent-2);
    opacity: 0;
    transition: opacity .12s;
}
.cp-catnav__link::after {
    content: " ]";
    color: var(--cp-accent-2);
    opacity: 0;
    transition: opacity .12s;
}
.cp-catnav__link:hover::before,
.cp-catnav__link:hover::after { opacity: 1; }

/* Secondary nav (pages / WP menu) shown beneath cat-nav on a thinner bar */
.cp-pagesnav {
    background: #000;
    border-bottom: 1px solid var(--cp-rule);
}
.cp-pagesnav ul {
    display: flex; flex-wrap: wrap;
    gap: 0; margin: 0; padding: 0;
    list-style: none;
}
.cp-pagesnav li a {
    display: block;
    padding: .45rem .8rem;
    font-size: .75rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--cp-ink-dim);
    border: none;
}
.cp-pagesnav li a:hover { color: var(--cp-accent-3); text-shadow: 0 0 6px rgba(0,229,255,.6); }

/* =========================================================================
   6. CONTENT, CARDS, PRODUCTS
   ------------------------------------------------------------------------- */
.site-content { padding: 1.5rem 0 2rem; }

article, .hentry,
ul.products li.product,
.woocommerce ul.products li.product {
    background: var(--cp-panel);
    border: 1px solid var(--cp-rule);
    padding: 1rem;
    margin-bottom: 1rem;
    border-radius: var(--cp-radius);
    position: relative;
}
ul.products li.product::before {
    content: "";
    position: absolute; left: -1px; top: -1px; bottom: -1px;
    width: 3px;
    background: linear-gradient(var(--cp-accent), var(--cp-accent-2));
    opacity: .65;
}
ul.products li.product:hover {
    border-color: var(--cp-accent);
    box-shadow: var(--cp-glow);
}
ul.products li.product img {
    background: #000;
    border: 1px solid var(--cp-rule);
}
.price, .woocommerce-Price-amount {
    color: var(--cp-warn) !important;
    font-weight: 700;
    text-shadow: 0 0 4px rgba(255,176,0,.45);
}
.onsale, .wc-block-components-product-sale-badge {
    background: var(--cp-accent-2) !important;
    color: #000 !important;
    border-radius: 0 !important;
    font-family: var(--cp-mono);
    text-transform: uppercase;
    letter-spacing: .1em;
    box-shadow: var(--cp-glow-pink);
}

/* =========================================================================
   7. BUTTONS / FORMS
   ------------------------------------------------------------------------- */
button, input[type="submit"], .button,
.woocommerce a.button, .woocommerce button.button,
.woocommerce input.button, .woocommerce #respond input#submit {
    background: var(--cp-accent) !important;
    color: #000 !important;
    border: 0 !important;
    font-family: var(--cp-mono) !important;
    text-transform: uppercase;
    letter-spacing: .1em;
    border-radius: var(--cp-radius) !important;
    padding: .55rem 1rem !important;
    text-shadow: none !important;
    transition: background .12s, box-shadow .12s, transform .08s;
}
button:hover, input[type="submit"]:hover, .button:hover,
.woocommerce a.button:hover, .woocommerce button.button:hover,
.woocommerce input.button:hover {
    background: var(--cp-accent-2) !important;
    color: #000 !important;
    box-shadow: var(--cp-glow-pink);
}
button:active { transform: translateY(1px); }

input[type="text"], input[type="email"], input[type="url"],
input[type="password"], input[type="search"], input[type="number"],
input[type="tel"], input[type="date"], textarea, select {
    background: #000;
    color: var(--cp-ink);
    border: 1px solid var(--cp-rule);
    border-left: 3px solid var(--cp-accent);
    padding: .45rem .55rem;
    font-family: var(--cp-mono);
    border-radius: var(--cp-radius);
}
input:focus, textarea:focus, select:focus {
    outline: none;
    border-color: var(--cp-accent);
    box-shadow: var(--cp-glow);
}

/* =========================================================================
   8. SIDEBAR / WIDGETS
   ------------------------------------------------------------------------- */
.widget {
    background: var(--cp-panel);
    border: 1px solid var(--cp-rule);
    padding: 1rem;
    margin-bottom: 1rem;
}
.widget-title {
    margin-top: 0;
    border-bottom: 1px dashed var(--cp-accent);
    padding-bottom: .35rem;
}

/* =========================================================================
   9. FOOTER
   ------------------------------------------------------------------------- */
.site-footer {
    background: #000 !important;
    color: var(--cp-ink-dim) !important;
    border-top: 1px solid var(--cp-rule);
    padding: 1.5rem 0;
    font-size: .85rem;
}
.site-footer a { color: var(--cp-accent-3); }
.site-footer::before {
    content: "// EOF -- thanks for connecting //";
    display: block;
    text-align: center;
    color: var(--cp-accent);
    font-size: .75rem;
    letter-spacing: .25em;
    margin-bottom: .75rem;
    text-shadow: var(--cp-glow);
}

/* =========================================================================
   10. RESPONSIVE
   ------------------------------------------------------------------------- */
@media (max-width: 768px) {
    .col-full { padding: 0 .6rem; }
    h1 { font-size: 1.4rem; }
    .site-header { padding: .8rem 0; }
    .site-title { font-size: 1.2rem; }
    .cp-topbar__inner { gap: .35rem; }
    .cp-topbar__brand { font-size: .8rem; letter-spacing: .1em; }
    .cp-catnav__link { padding: .6rem .8rem; font-size: .8rem; }
    .wp-custom-header { max-height: 30vh; }
}
@media (max-width: 480px) {
    .cp-topbar__inner { flex-direction: column; align-items: stretch; }
    .cp-topbar__cart { text-align: right; }
}

/* =========================================================================
   11. ACCESSIBILITY
   ------------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation: none !important; transition: none !important; }
    body::before { display: none; }
}
:focus-visible {
    outline: 2px solid var(--cp-accent-3) !important;
    outline-offset: 2px;
}
.screen-reader-text {
    position: absolute !important;
    clip: rect(1px, 1px, 1px, 1px);
    width: 1px; height: 1px; overflow: hidden;
}

/* =========================================================================
   12. PRINT
   ------------------------------------------------------------------------- */
@media print {
    body::before { display: none; }
    body { background: #fff; color: #000; }
    a { color: #000; border: 0; text-shadow: none; }
}
