/*
Theme Name: Quiet Luxury Shop
Theme URI: https://example.com/
Author: ChatGPT
Author URI: https://example.com/
Description: Minimalistyczny, „quiet luxury” szablon WordPress z wsparciem WooCommerce, inspirowany UX premium (czysta typografia, dużo whitespace, prosta nawigacja).
Version: 1.0.0
Requires at least: 6.2
Tested up to: 6.6
Requires PHP: 8.0
Text Domain: quiet-luxury
Tags: e-commerce, woocommerce, block-styles, wide-blocks, custom-logo, editor-style

License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
*/

/* =========================
   Design tokens
========================= */
:root{
  --bg:#ffffff;
  --text:#111111;
  --muted:#6b6b6b;
  --border:#e8e8e8;
  --surface:#fafafa;

  --container: 1200px;
  --gutter: 24px;
  --radius: 14px;

  --font-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Noto Sans", "Liberation Sans", sans-serif;
  --font-serif: ui-serif, "Iowan Old Style", "Palatino Linotype", Palatino, Garamond, serif;

  --h1: clamp(28px, 3vw, 44px);
  --h2: clamp(22px, 2.2vw, 32px);
  --h3: 18px;
  --base: 16px;
  --small: 13px;

  --lh: 1.55;
  --shadow: 0 12px 36px rgba(0,0,0,.06);
}

/* =========================
   Base
========================= */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-sans);
  font-size:var(--base);
  line-height:var(--lh);
}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto}
hr{border:none;border-top:1px solid var(--border);margin:24px 0}
small{font-size:var(--small);color:var(--muted)}

/* Accessibility */
:focus-visible{outline:2px solid #111;outline-offset:3px}

/* =========================
   Layout helpers
========================= */
.container{
  width:min(var(--container), calc(100% - (var(--gutter) * 2)));
  margin-inline:auto;
}
.stack>*+*{margin-top:16px}
.stack-lg>*+*{margin-top:28px}
.muted{color:var(--muted)}

/* =========================
   Header
========================= */
.site-topbar{
  border-bottom:1px solid var(--border);
  font-size:13px;
  color:var(--muted);
  background:var(--bg);
}
.site-topbar .row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:10px 0;
}
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--border);
}
.site-header .row{
  display:flex; align-items:center; justify-content:space-between;
  gap:18px; padding:16px 0;
}
.brand{
  display:flex; align-items:center; gap:12px; min-width:140px;
}
.brand .site-title{
  font-family:var(--font-serif);
  letter-spacing:.02em;
  font-size:18px;
  text-transform:uppercase;
}
.nav{
  display:flex; align-items:center; gap:18px;
  font-size:14px;
}
.nav a{padding:6px 2px}
.header-actions{
  display:flex; align-items:center; gap:14px;
  font-size:14px;
}
.icon-link{
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 8px; border-radius:999px;
}
.icon-link:hover{background:var(--surface); text-decoration:none}
.hamburger{display:none}

/* =========================
   Footer
========================= */
.site-footer{
  margin-top:64px;
  border-top:1px solid var(--border);
  background:var(--bg);
}
.site-footer .grid{
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr 1fr;
  gap:24px;
  padding:40px 0;
}
.site-footer h3{
  margin:0 0 12px;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li+li{margin-top:10px}
.site-footer .bottom{
  border-top:1px solid var(--border);
  padding:16px 0;
  color:var(--muted);
  font-size:13px;
  display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap;
}

/* =========================
   Content
========================= */
.page-hero{
  padding:44px 0 18px;
}
.page-hero h1{
  margin:0;
  font-size:var(--h1);
  font-family:var(--font-serif);
  letter-spacing:.02em;
}
.page-hero p{margin:12px 0 0; color:var(--muted); max-width:70ch}

.content{
  padding:24px 0 40px;
}
.prose{
  max-width: 78ch;
}
.prose h2{font-size:var(--h2); font-family:var(--font-serif)}
.prose h3{font-size:var(--h3)}
.prose p{margin:0 0 16px}
.prose ul, .prose ol{padding-left:18px}

/* =========================
   Buttons + forms
========================= */
.button, button, input[type="submit"]{
  appearance:none;
  border:1px solid #111;
  background:#111;
  color:#fff;
  border-radius:999px;
  padding:12px 16px;
  font-size:14px;
  line-height:1;
  cursor:pointer;
}
.button.secondary{
  background:transparent;
  color:#111;
}
.button:hover, button:hover, input[type="submit"]:hover{
  opacity:.92;
}
input[type="text"], input[type="search"], input[type="email"], input[type="password"], textarea, select{
  width:100%;
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px 12px;
  font-size:14px;
  background:#fff;
}
label{font-size:13px; color:var(--muted)}

/* =========================
   Cards + grids
========================= */
.grid{
  display:grid;
  gap:18px;
}
.grid.cols-3{grid-template-columns:repeat(3, minmax(0, 1fr))}
.grid.cols-4{grid-template-columns:repeat(4, minmax(0, 1fr))}
.card{
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:#fff;
  overflow:hidden;
}
.card .pad{padding:14px}
.badge{
  display:inline-flex;
  gap:8px;
  align-items:center;
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#111;
  border:1px solid var(--border);
  border-radius:999px;
  padding:6px 10px;
}

/* =========================
   WooCommerce (light touch)
========================= */
.woocommerce .woocommerce-breadcrumb{
  font-size:13px; color:var(--muted);
  margin:0 0 12px;
}
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering select{
  font-size:13px;
}
.woocommerce ul.products{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:18px;
  margin:0;
}
.woocommerce ul.products li.product{
  float:none;
  width:auto;
  margin:0;
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  padding:0;
}
.woocommerce ul.products li.product a{
  display:block;
}
.woocommerce ul.products li.product img{
  width:100%;
  margin:0;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title{
  font-family:var(--font-serif);
  font-size:16px;
  padding:12px 14px 0;
  margin:0;
}
.woocommerce ul.products li.product .price{
  padding:6px 14px 14px;
  color:#111;
  font-size:14px;
}
.woocommerce span.onsale{
  background:#111;
  border-radius:999px;
  padding:6px 10px;
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  top:12px; right:12px; left:auto;
  min-height:auto; min-width:auto;
}
.woocommerce div.product .product_title{
  font-family:var(--font-serif);
  font-size:var(--h2);
}
.woocommerce div.product form.cart .button{
  padding:14px 18px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs{
  padding:0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li{
  border:1px solid var(--border);
  border-radius:999px;
  background:transparent;
  margin:0 10px 10px 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{
  padding:10px 14px;
  font-size:13px;
}
.woocommerce-message, .woocommerce-info, .woocommerce-error{
  border-radius:12px;
}

/* =========================
   Responsive
========================= */
@media (max-width: 980px){
  .grid.cols-4{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .site-footer .grid{grid-template-columns:1fr 1fr}
  .nav{display:none}
  .hamburger{display:inline-flex}
  .woocommerce ul.products{grid-template-columns:repeat(2, minmax(0, 1fr))}
}
@media (max-width: 540px){
  .site-footer .grid{grid-template-columns:1fr}
}


/* =========================
   Overlays + Mobile drawer
========================= */
.overlay{
  position:fixed; inset:0; z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(14px);
  display:none;
}
.overlay.is-open{display:block}
.overlay .panel{
  width:min(860px, calc(100% - (var(--gutter) * 2)));
  margin:80px auto 0;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:#fff;
  box-shadow:var(--shadow);
  padding:18px;
}
.overlay .panel .row{
  display:flex; justify-content:space-between; align-items:center; gap:12px;
}
.overlay .close{
  background:transparent;
  color:#111;
  border:1px solid var(--border);
}
.overlay .hint{
  margin-top:12px;
  font-size:13px;
  color:var(--muted);
}

.mobile-drawer{
  position:fixed; inset:0; z-index:110;
  display:none;
}
.mobile-drawer.is-open{display:block}
.mobile-drawer .backdrop{
  position:absolute; inset:0; background:rgba(0,0,0,.22);
}
.mobile-drawer .sheet{
  position:absolute; top:0; bottom:0; left:0;
  width:min(380px, 92vw);
  background:#fff;
  border-right:1px solid var(--border);
  padding:18px;
  overflow:auto;
}
.mobile-drawer .sheet .top{
  display:flex; justify-content:space-between; align-items:center; gap:10px;
  padding-bottom:12px; border-bottom:1px solid var(--border);
}
.mobile-drawer .sheet .top .title{
  font-family:var(--font-serif);
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:14px;
}
.mobile-drawer .sheet .close{
  background:transparent;
  color:#111;
  border:1px solid var(--border);
}
.mobile-drawer nav ul{list-style:none; padding:14px 0 0; margin:0}
.mobile-drawer nav li{padding:10px 0; border-bottom:1px solid var(--border)}
.mobile-drawer nav a{display:block; font-size:14px}
.mobile-drawer nav .sub-menu{
  padding:10px 0 0 14px;
  border-left:1px solid var(--border);
}
.mobile-drawer nav .sub-menu li{border-bottom:none; padding:8px 0}

/* =========================
   Mega-menu (simple)
========================= */
.nav ul{list-style:none; margin:0; padding:0; display:flex; gap:18px; align-items:center}
.nav li{position:relative}
.nav > ul > li > a{
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:12px;
}
.nav .sub-menu{
  position:absolute; top:110%; left:0;
  min-width: 280px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:12px;
  display:none;
  box-shadow:var(--shadow);
}
.nav li:hover > .sub-menu,
.nav li:focus-within > .sub-menu{display:block}
.nav .sub-menu li{margin:0}
.nav .sub-menu a{
  display:block;
  padding:10px 10px;
  border-radius:12px;
  font-size:13px;
}
.nav .sub-menu a:hover{
  background:var(--surface);
  text-decoration:none;
}

/* Optional: turn second level into 2 columns if long */
.nav .sub-menu{
  column-count:2;
  column-gap:10px;
}
.nav .sub-menu li{break-inside:avoid}

/* Header actions tweaks */
.header-actions .icon-link{white-space:nowrap}
