/*
Theme Name: Hostyle
Theme URI: https://hostyle.gr
Author: Dimitra M.
Author URI: https://typorg.com
Description: Custom minimal theme for Hostyle streetwear. Built for WooCommerce.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: Private
Text Domain: hostyle
Tags: woocommerce, minimal, custom
*/

/* ─── Reset ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; -webkit-text-size-adjust: 100%; }
body { font-family: 'Neue Haas Grotesk', 'Helvetica Neue', Helvetica, Arial, sans-serif; background: #fff; color: #111; line-height: 1.5; -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button, input, select, textarea { font-family: inherit; font-size: inherit; }
button { cursor: pointer; border: none; background: transparent; }

/* ─── Typography ─────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 { font-weight: 500; letter-spacing: -0.02em; line-height: 1.1; color: #111; }
h1 { font-size: clamp(2rem, 5vw, 3.5rem); }
h2 { font-size: clamp(1.5rem, 3vw, 2.25rem); }
h3 { font-size: clamp(1.1rem, 2vw, 1.5rem); }
p { font-size: 0.875rem; color: #888; line-height: 1.8; }

/* ─── CSS Variables ──────────────────────────────────────── */
:root {
  --black:       #111111;
  --white:       #ffffff;
  --off-white:   #f6f5f2;
  --warm-grey:   #f0efeb;
  --mid-grey:    #d8d7d3;
  --border:      #e4e4e4;
  --border-lt:   #f0f0f0;
  --text-primary:   #111;
  --text-secondary: #888;
  --text-muted:     #bbb;
  --text-faint:     #ccc;
  --spacing-xs: 8px;
  --spacing-sm: 16px;
  --spacing-md: 24px;
  --spacing-lg: 48px;
  --spacing-xl: 72px;
  --nav-height: 64px;
  --max-width: 1440px;
  --container: 1200px;
}

/* ─── Layout helpers ─────────────────────────────────────── */
.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 var(--spacing-lg); }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); }
.gap-1px { gap: 1px; background: var(--border); }
.gap-1px > * { background: #fff; }

/* ─── Buttons ────────────────────────────────────────────── */
.btn { display: inline-block; font-size: 0.6875rem; letter-spacing: 0.14em; padding: 14px 28px; cursor: pointer; transition: all 0.15s; text-align: center; }
.btn-primary { background: var(--black); color: var(--white); border: none; }
.btn-primary:hover { background: #333; }
.btn-secondary { background: transparent; color: var(--black); border: 0.5px solid var(--black); }
.btn-secondary:hover { background: var(--black); color: var(--white); }
.btn-ghost { background: transparent; color: rgba(255,255,255,0.7); border: 0.5px solid rgba(255,255,255,0.25); }
.btn-ghost:hover { border-color: rgba(255,255,255,0.7); color: #fff; }
.btn-full { width: 100%; display: block; }

/* ─── Links ──────────────────────────────────────────────── */
.link-underline { border-bottom: 1px solid currentColor; padding-bottom: 1px; display: inline-block; }
.link-muted { color: var(--text-muted); font-size: 0.75rem; letter-spacing: 0.08em; }
.link-muted:hover { color: var(--black); }

/* ─── Labels / Eyebrows ──────────────────────────────────── */
.label { font-size: 0.625rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-muted); }
.label-dark { color: #3a3a3a; }
.label-white { color: rgba(255,255,255,0.35); }

/* ─── Dividers ───────────────────────────────────────────── */
.divider { height: 0.5px; background: var(--border); }

/* ─── Section bar ────────────────────────────────────────── */
.section-bar { display: flex; justify-content: space-between; align-items: baseline; padding: var(--spacing-lg) var(--spacing-lg) var(--spacing-sm); border-bottom: 0.5px solid var(--border); }
.section-bar__title { font-size: 0.6875rem; letter-spacing: 0.2em; color: var(--black); }
.section-bar__link { font-size: 0.75rem; color: var(--text-muted); border-bottom: 1px solid var(--border); padding-bottom: 1px; }
.section-bar__link:hover { color: var(--black); border-color: var(--black); }

/* ─── Badges ─────────────────────────────────────────────── */
.badge { font-size: 0.5625rem; letter-spacing: 0.12em; padding: 4px 8px; }
.badge-new { background: var(--black); color: #fff; }
.badge-soldout { background: var(--border); color: var(--text-secondary); }

/* ─── Forms ──────────────────────────────────────────────── */
.field { display: flex; flex-direction: column; gap: 5px; }
.field label { font-size: 0.625rem; letter-spacing: 0.12em; color: var(--text-muted); text-transform: uppercase; }
.field input,
.field select,
.field textarea { border: 0.5px solid var(--border); padding: 11px 14px; font-size: 0.75rem; color: var(--black); outline: none; background: #fff; letter-spacing: 0.03em; width: 100%; transition: border-color 0.15s; }
.field input:focus,
.field select:focus,
.field textarea:focus { border-color: var(--black); }
.field input::placeholder,
.field textarea::placeholder { color: var(--text-faint); }

/* ─── WooCommerce base overrides ─────────────────────────── */
.woocommerce-notices-wrapper { padding: 0 var(--spacing-lg); }
.woocommerce-message,
.woocommerce-info,
.woocommerce-error { border-top: 2px solid var(--black); background: var(--off-white); padding: var(--spacing-sm) var(--spacing-md); font-size: 0.8125rem; color: var(--black); letter-spacing: 0.03em; list-style: none; margin: var(--spacing-sm) 0; }
.woocommerce-error { border-color: #c00; }

/* ─── Accessibility ──────────────────────────────────────── */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
:focus-visible { outline: 2px solid var(--black); outline-offset: 2px; }

/* ─── Responsive breakpoints ─────────────────────────────── */
@media (max-width: 1024px) {
  :root { --spacing-lg: 32px; }
  .grid-4 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  :root { --spacing-lg: 20px; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-2.stack-mobile { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr 1fr; }
  .grid-4.stack-mobile { grid-template-columns: 1fr 1fr; }
}
