/* ============================================================
   NÕIATAR THEME — main.css
   Design system, layout, components
   ============================================================ */

/* Fondid laetakse PHP kaudu wp_enqueue_style (functions.php) */

/* ── TOKENS ── */
:root {
  --obsidian:   #110D10;
  --deep-plum:  #1E1520;
  --velvet:     #2A1E28;
  --mauve:      #4A2F3E;
  --rose-dusk:  #7A5264;
  --champagne:  #C8AA82;
  --gold-soft:  #B89468;
  --pearl:      #E8DDD0;
  --ivory:      #F5F0EA;
  --smoke:      #9A8A90;

  --serif: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:  'DM Sans', system-ui, -apple-system, sans-serif;

  --radius-none: 0;
  --space-xs:  8px;
  --space-sm:  16px;
  --space-md:  24px;
  --space-lg:  48px;
  --space-xl:  80px;
  --space-2xl: 120px;

  --nav-height: 68px;
  --container:  1160px;
  --transition: 0.3s ease;
}

/* ── RESET & BASE ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  background: var(--obsidian);
  color: var(--pearl);
  font-family: var(--sans);
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font-family: var(--sans); }
input, select, textarea { font-family: var(--sans); }

/* ── TYPOGRAPHY ── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--serif);
  font-weight: 300;
  color: var(--ivory);
  line-height: 1.15;
}
h1 { font-size: clamp(40px, 5vw, 68px); }
h2 { font-size: clamp(30px, 3.5vw, 52px); }
h3 { font-size: clamp(22px, 2.5vw, 34px); }
h4 { font-size: clamp(18px, 2vw, 24px); }
p   { color: var(--smoke); font-size: 15px; line-height: 1.8; font-weight: 300; }

.serif  { font-family: var(--serif); }
.italic { font-style: italic; }
.champagne { color: var(--champagne); }
.ivory { color: var(--ivory); }

/* eyebrow */
.eyebrow {
  font-family: var(--sans);
  font-size: 10px; letter-spacing: 0.25em; text-transform: uppercase;
  color: var(--champagne); display: flex; align-items: center; gap: 14px;
  margin-bottom: var(--space-sm);
}
.eyebrow::before { content: ''; width: 24px; height: 1px; background: var(--champagne); flex-shrink: 0; }

/* ── LAYOUT ── */
.container { max-width: var(--container); margin: 0 auto; padding: 0 var(--space-lg); }
.section { padding: var(--space-2xl) var(--space-lg); }
.section--plum  { background: var(--deep-plum); }
.section--velvet { background: var(--velvet); }
.section--dark  { background: var(--obsidian); }

/* ── BUTTONS ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--sans); font-size: 11px; font-weight: 500;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 15px 32px; border: none; cursor: pointer;
  transition: background var(--transition), color var(--transition), transform var(--transition);
  text-decoration: none; white-space: nowrap;
}
.btn--primary   { background: var(--champagne); color: var(--obsidian); }
.btn--primary:hover { background: var(--pearl); transform: translateY(-1px); }
.btn--ghost     { background: transparent; color: var(--champagne); border: 1px solid var(--mauve); }
.btn--ghost:hover { border-color: var(--champagne); }
.btn--dark      { background: var(--obsidian); color: var(--champagne); border: 1px solid rgba(200,170,130,0.3); }
.btn--dark:hover { border-color: var(--champagne); }
.btn--full      { width: 100%; }
.btn--sm        { padding: 10px 20px; font-size: 10px; }

/* ── NAV ── */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  display: grid; grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 0 var(--space-lg);
  height: var(--nav-height);
  background: linear-gradient(to bottom, rgba(17,13,16,0.97) 0%, rgba(17,13,16,0) 100%);
  transition: background var(--transition), height var(--transition);
}
.site-header.scrolled {
  background: rgba(17,13,16,0.97);
  border-bottom: 1px solid rgba(200,170,130,0.08);
}
.site-logo {
  font-family: var(--serif); font-size: 20px; font-weight: 500;
  letter-spacing: 0.18em; color: var(--champagne); text-transform: uppercase;
  justify-self: start; line-height: 1;
}
.site-logo__sub {
  display: block; font-weight: 300; font-size: 11px;
  color: var(--smoke); letter-spacing: 0.1em; margin-top: -2px;
}
.nav-primary {
  display: flex; align-items: center; gap: 32px; list-style: none;
  justify-content: center;
}
.nav-primary a {
  font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--smoke); transition: color var(--transition);
}
.nav-primary a:hover,
.nav-primary .current-menu-item a { color: var(--champagne); }
.nav-right {
  display: flex; align-items: center; gap: 14px; justify-self: end;
}
.nav-cart-link {
  position: relative; color: var(--smoke); font-size: 17px;
  transition: color var(--transition); line-height: 1;
}
.nav-cart-link:hover { color: var(--champagne); }
.cart-count {
  position: absolute; top: -7px; right: -9px;
  background: var(--champagne); color: var(--obsidian);
  font-size: 9px; font-weight: 500; min-width: 16px; height: 16px;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
}

/* hamburger */
.nav-hamburger {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; cursor: pointer; padding: 6px;
}
.nav-hamburger span {
  display: block; width: 22px; height: 1.5px; background: var(--champagne);
  transition: transform var(--transition), opacity var(--transition);
}
.nav-hamburger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity: 0; }
.nav-hamburger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* mobile menu */
.mobile-nav {
  display: none; position: fixed; inset: 0; z-index: 190;
  background: var(--obsidian); padding: 88px 32px 48px;
  flex-direction: column; overflow-y: auto;
}
.mobile-nav.open { display: flex; }
.mobile-nav a {
  font-family: var(--serif); font-size: 34px; font-weight: 300;
  color: var(--pearl); padding: 14px 0;
  border-bottom: 1px solid rgba(200,170,130,0.08);
  letter-spacing: 0.04em; transition: color var(--transition);
}
.mobile-nav a:hover { color: var(--champagne); }
.mobile-nav__auth {
  display: flex; gap: 10px; margin-top: 32px; flex-wrap: wrap;
}
.mobile-nav__auth .btn { flex: 1; min-width: 140px; padding: 16px; }

/* ── HERO ── */
.hero {
  min-height: 100vh; display: grid;
  grid-template-columns: 1fr 1fr; overflow: hidden;
  margin-top: 0;
}
.hero__image {
  position: relative; overflow: hidden;
}
.hero__image img {
  width: 100%; height: 100%; object-fit: cover; object-position: center 15%;
  filter: brightness(0.82) saturate(0.9);
}
.hero__image-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(90deg,
    rgba(17,13,16,0) 0%,
    rgba(17,13,16,0.25) 60%,
    rgba(17,13,16,0.95) 100%);
}
.hero__content {
  background: var(--obsidian);
  display: flex; flex-direction: column; justify-content: center;
  padding: calc(var(--nav-height) + 60px) 72px 80px 56px;
}
.hero__eyebrow { margin-bottom: 28px; }
.hero__title { margin-bottom: 8px; }
.hero__title em { font-style: italic; color: var(--champagne); }
.hero__subtitle {
  font-size: 15px; max-width: 380px;
  margin-bottom: var(--space-lg); margin-top: 20px;
}
.hero__btn-row { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: var(--space-lg); }
.hero__trust { display: flex; flex-direction: column; gap: 10px; padding-top: var(--space-md); border-top: 1px solid rgba(200,170,130,0.15); }
.trust-item { display: flex; align-items: center; gap: 12px; font-size: 12px; color: var(--smoke); }
.trust-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--champagne); flex-shrink: 0; }

/* ── PROOF BAR ── */
.proof-bar {
  background: var(--velvet); padding: 32px var(--space-lg);
  display: flex; align-items: center; gap: 40px; flex-wrap: wrap;
}
.proof-stat { text-align: center; flex-shrink: 0; }
.proof-stat__num { font-family: var(--serif); font-size: 36px; font-weight: 300; color: var(--champagne); line-height: 1; }
.proof-stat__label { font-size: 11px; color: var(--smoke); letter-spacing: 0.08em; margin-top: 4px; }
.proof-divider { width: 1px; height: 48px; background: var(--mauve); flex-shrink: 0; }
.proof-quote { flex: 1; min-width: 240px; font-family: var(--serif); font-size: 17px; font-weight: 300; font-style: italic; color: var(--pearl); line-height: 1.5; }
.proof-quote__author { font-size: 11px; color: var(--smoke); margin-top: 8px; font-style: normal; font-family: var(--sans); letter-spacing: 0.1em; }

/* ── SERVICES ── */
.services-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-top: var(--space-lg); }
.service-card {
  background: var(--velvet); padding: 52px 44px; position: relative;
  transition: background var(--transition); text-decoration: none; display: block;
}
.service-card:hover { background: var(--mauve); }
.service-card--featured { border-top: 2px solid var(--champagne); }
.service-card__badge {
  position: absolute; top: -1px; left: 44px;
  background: var(--champagne); color: var(--obsidian);
  font-size: 9px; letter-spacing: 0.15em; padding: 5px 14px; font-weight: 500; text-transform: uppercase;
}
.service-card::after {
  content: ''; position: absolute; bottom: 0; left: 44px; right: 44px;
  height: 1px; background: var(--champagne);
  transform: scaleX(0); transform-origin: left; transition: transform 0.4s ease;
}
.service-card:hover::after { transform: scaleX(1); }
.service-card__num { font-family: var(--serif); font-size: 13px; color: var(--champagne); letter-spacing: 0.18em; margin-bottom: 20px; display: block; text-transform: uppercase; }
.service-card__name { font-family: var(--serif); font-size: 34px; font-weight: 300; color: var(--ivory); margin-bottom: 16px; line-height: 1.15; }
.service-card__desc { font-size: 14px; color: var(--smoke); line-height: 1.75; margin-bottom: 24px; font-weight: 300; }
.service-card__includes-label { font-size: 10px; color: var(--rose-dusk); letter-spacing: 0.15em; text-transform: uppercase; margin-bottom: 8px; display: block; }
.service-card__includes { font-size: 13px; color: var(--smoke); line-height: 1.9; font-weight: 300; }
.service-card__price { font-family: var(--serif); font-size: 28px; font-weight: 300; color: var(--champagne); margin-top: 24px; display: block; }
.service-card__arrow { position: absolute; top: 52px; right: 44px; font-size: 20px; color: var(--mauve); transition: color var(--transition), transform var(--transition); }
.service-card:hover .service-card__arrow { color: var(--champagne); transform: translate(4px,-4px); }

/* ── PROCESS ── */
.process-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--velvet); margin-top: var(--space-lg); }
.process-step { background: var(--deep-plum); padding: 44px 36px; }
.process-step__num { font-family: var(--serif); font-size: 72px; font-weight: 300; color: rgba(200,170,130,0.1); line-height: 1; margin-bottom: 24px; }
.process-step__title { font-family: var(--serif); font-size: 22px; font-weight: 400; color: var(--ivory); margin-bottom: 12px; }
.process-step__desc { font-size: 13px; color: var(--smoke); line-height: 1.75; font-weight: 300; }

/* ── TESTIMONIALS ── */
.testimonials-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-top: var(--space-lg); }
.testimonial-card { background: var(--deep-plum); padding: 44px 40px; display: flex; flex-direction: column; }
.testimonial-card__stars { color: var(--champagne); font-size: 13px; letter-spacing: 5px; margin-bottom: 22px; }
.testimonial-card__text { font-family: var(--serif); font-size: 18px; font-weight: 300; font-style: italic; color: var(--pearl); line-height: 1.7; margin-bottom: 22px; flex: 1; }
.testimonial-card__author { font-size: 11px; color: var(--smoke); letter-spacing: 0.12em; text-transform: uppercase; }

/* ── CTA SECTION ── */
.cta-section { text-align: center; position: relative; overflow: hidden; }
.cta-section__bg-text {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  font-family: var(--serif); font-size: clamp(80px,16vw,200px); font-weight: 300;
  color: rgba(200,170,130,0.04); white-space: nowrap; letter-spacing: 0.3em; pointer-events: none;
}
.cta-section__content { position: relative; z-index: 1; }

/* ── FOOTER ── */
.site-footer {
  background: var(--obsidian);
  border-top: 1px solid rgba(200,170,130,0.1);
  padding: 64px var(--space-lg) 40px;
}
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 48px; margin-bottom: var(--space-lg); }
.footer-logo { font-family: var(--serif); font-size: 22px; font-weight: 500; letter-spacing: 0.18em; color: var(--champagne); text-transform: uppercase; display: block; margin-bottom: var(--space-sm); }
.footer-brand__desc { font-size: 13px; color: var(--smoke); line-height: 1.7; font-weight: 300; max-width: 260px; }
.footer-col__title { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--champagne); margin-bottom: var(--space-sm); display: block; }
.footer-col__list { list-style: none; }
.footer-col__list li { margin-bottom: 10px; }
.footer-col__list a { font-size: 13px; color: var(--smoke); transition: color var(--transition); font-weight: 300; }
.footer-col__list a:hover { color: var(--pearl); }
.footer-bottom { border-top: 1px solid rgba(200,170,130,0.1); padding-top: 28px; display: flex; justify-content: space-between; align-items: center; font-size: 11px; color: var(--mauve); }

/* ── AUTH MODAL ── */
.modal-backdrop {
  display: none; position: fixed; inset: 0; z-index: 300;
  background: rgba(11,8,10,0.88); backdrop-filter: blur(6px);
  align-items: center; justify-content: center; padding: 20px;
  opacity: 0; transition: opacity 0.3s ease;
}
.modal-backdrop.open {
  display: flex;
  opacity: 1;
}
.modal {
  background: var(--deep-plum);
  border: 1px solid rgba(200,170,130,0.18);
  width: 100%; max-width: 440px; position: relative;
  animation: modalIn 0.35s ease;
}
@keyframes modalIn {
  from { opacity:0; transform: translateY(18px) scale(0.97); }
  to   { opacity:1; transform: translateY(0)    scale(1); }
}
.modal__close { position: absolute; top: 18px; right: 18px; background: none; border: none; color: var(--smoke); font-size: 22px; cursor: pointer; line-height: 1; transition: color var(--transition); padding: 4px; }
.modal__close:hover { color: var(--champagne); }
.modal__header { padding: 44px 44px 0; }
.modal__eyebrow { font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--champagne); margin-bottom: 10px; display: flex; align-items: center; gap: 12px; }
.modal__eyebrow::before { content:''; width:18px; height:1px; background: var(--champagne); }
.modal__title { font-family: var(--serif); font-size: 32px; font-weight: 300; color: var(--ivory); line-height: 1.15; }
.modal__title em { font-style: italic; color: var(--champagne); }
.modal__tabs { display: flex; border-bottom: 1px solid rgba(200,170,130,0.1); padding: 0 44px; margin-top: 28px; }
.modal__tab { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--smoke); padding: 12px 0; margin-right: 28px; background: none; border: none; cursor: pointer; font-family: var(--sans); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: all var(--transition); }
.modal__tab.active { color: var(--champagne); border-bottom-color: var(--champagne); }
.modal__body { padding: 32px 44px 44px; }
.modal__form { display: none; }
.modal__form.active { display: block; }

/* form fields */
.form-group { margin-bottom: 20px; }
.form-label { display: block; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--smoke); margin-bottom: 8px; }
.form-input {
  width: 100%; padding: 14px 16px;
  background: var(--velvet); border: 1px solid rgba(200,170,130,0.12);
  color: var(--pearl); font-family: var(--sans); font-size: 14px;
  outline: none; transition: border-color var(--transition);
  border-radius: 0; appearance: none;
}
.form-input:focus { border-color: var(--champagne); }
.form-input::placeholder { color: var(--rose-dusk); font-size: 13px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-checkbox-row { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 24px; }
.form-checkbox { width: 16px; height: 16px; flex-shrink: 0; margin-top: 2px; background: var(--velvet); border: 1px solid rgba(200,170,130,0.3); cursor: pointer; appearance: none; position: relative; border-radius: 0; }
.form-checkbox:checked { background: var(--champagne); border-color: var(--champagne); }
.form-checkbox:checked::after { content:''; position:absolute; top:2px; left:5px; width:5px; height:9px; border:2px solid var(--obsidian); border-left:none; border-top:none; transform:rotate(45deg); }
.form-checkbox-label { font-size: 12px; color: var(--smoke); line-height: 1.5; }
.form-checkbox-label a { color: var(--champagne); }
.form-divider { display: flex; align-items: center; gap: 16px; margin: 20px 0; font-size: 11px; color: var(--rose-dusk); letter-spacing: 0.1em; }
.form-divider::before, .form-divider::after { content:''; flex:1; height:1px; background: rgba(200,170,130,0.1); }
.form-alert { font-size: 12px; padding: 12px 16px; margin-bottom: 16px; display: none; }
.form-alert.show { display: block; }
.form-alert--error { background: rgba(192,72,40,0.12); border: 1px solid rgba(192,72,40,0.25); color: #E88068; }
.form-alert--success { background: rgba(59,109,17,0.12); border: 1px solid rgba(59,109,17,0.25); color: #8BC96A; text-align: center; }
.forgot-link { display: block; text-align: right; font-size: 11px; color: var(--rose-dusk); margin-top: -12px; margin-bottom: 20px; letter-spacing: 0.06em; transition: color var(--transition); }
.forgot-link:hover { color: var(--champagne); }
.modal__switch { text-align: center; font-size: 12px; color: var(--smoke); }
.modal__switch button { background: none; border: none; color: var(--champagne); font-family: var(--sans); font-size: 12px; cursor: pointer; text-decoration: underline; text-underline-offset: 3px; padding: 0; }

/* ── WOOCOMMERCE ARCHIVE ── */
.archive-hero { background: var(--deep-plum); padding: 64px var(--space-lg) 48px; border-bottom: 1px solid rgba(200,170,130,0.08); }
.filter-bar { padding: 20px var(--space-lg); background: var(--velvet); display: flex; align-items: center; gap: 12px; flex-wrap: wrap; border-bottom: 1px solid rgba(200,170,130,0.08); }
.filter-label { font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--smoke); margin-right: 8px; }
.filter-pill { font-size: 11px; letter-spacing: 0.08em; padding: 7px 18px; border: 1px solid rgba(200,170,130,0.18); background: none; color: var(--smoke); cursor: pointer; font-family: var(--sans); transition: all 0.2s; }
.filter-pill:hover, .filter-pill.active { background: var(--champagne); color: var(--obsidian); border-color: var(--champagne); }
.sort-select { background: var(--velvet); border: 1px solid rgba(200,170,130,0.18); color: var(--smoke); font-family: var(--sans); font-size: 11px; letter-spacing: 0.06em; padding: 7px 14px; cursor: pointer; outline: none; }

/* product grid (WooCommerce ul.products override) */
ul.products,
.products-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 2px;
  list-style: none; padding: var(--space-lg); margin: 0;
}
li.product, .product-card {
  background: var(--velvet); position: relative;
  transition: background var(--transition);
}
li.product:hover, .product-card:hover { background: var(--mauve); }

.product-card__img-wrap { aspect-ratio: 1/1; overflow: hidden; position: relative; background: var(--deep-plum); display: flex; align-items: center; justify-content: center; }
.product-card__img-wrap img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.85) saturate(0.8); transition: transform 0.6s ease, filter 0.4s; }
.product-card:hover .product-card__img-wrap img { transform: scale(1.04); filter: brightness(0.7) saturate(0.7); }
.product-card__badge { position: absolute; top: 14px; left: 14px; background: var(--champagne); color: var(--obsidian); font-size: 9px; letter-spacing: 0.14em; padding: 4px 10px; font-weight: 500; text-transform: uppercase; z-index: 1; }
.product-card__badge--new { background: var(--rose-dusk); color: var(--ivory); }
.product-card__quick-add { position: absolute; bottom: 0; left: 0; right: 0; background: var(--champagne); color: var(--obsidian); font-family: var(--sans); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; padding: 13px; text-align: center; font-weight: 500; transform: translateY(100%); transition: transform 0.35s ease; z-index: 1; border: none; cursor: pointer; }
.product-card:hover .product-card__quick-add { transform: translateY(0); }
.product-card__info { padding: 20px 22px 24px; }
.product-card__cat { font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--rose-dusk); margin-bottom: 6px; }
.product-card__name { font-family: var(--serif); font-size: 20px; font-weight: 300; color: var(--ivory); margin-bottom: 6px; line-height: 1.2; }
.product-card__excerpt { font-size: 12px; color: var(--smoke); line-height: 1.6; margin-bottom: 12px; font-weight: 300; }
.product-card__price { font-family: var(--serif); font-size: 22px; font-weight: 300; color: var(--champagne); }
.product-card__price del { font-size: 14px; color: var(--rose-dusk); margin-left: 8px; }
.product-card__stars { color: var(--champagne); font-size: 11px; letter-spacing: 2px; margin-top: 6px; }

/* ── WOOCOMMERCE SINGLE ── */
.breadcrumb { padding: 24px var(--space-lg) 0; font-size: 11px; color: var(--smoke); display: flex; gap: 8px; align-items: center; }
.breadcrumb a { color: var(--smoke); transition: color var(--transition); }
.breadcrumb a:hover { color: var(--champagne); }
.breadcrumb__sep { color: var(--rose-dusk); }

.single-product-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; padding: 40px var(--space-lg) var(--space-2xl); max-width: var(--container); margin: 0 auto; }

/* gallery */
.product-gallery__main { aspect-ratio: 1/1; overflow: hidden; background: var(--velvet); }
.product-gallery__main img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.88) saturate(0.82); transition: transform 0.5s ease; }
.product-gallery__main img:hover { transform: scale(1.03); }
.product-gallery__thumbs { display: grid; grid-template-columns: repeat(4,1fr); gap: 2px; margin-top: 2px; }
.product-gallery__thumb { aspect-ratio: 1/1; background: var(--velvet); cursor: pointer; border: 2px solid transparent; overflow: hidden; display: flex; align-items: center; justify-content: center; transition: border-color var(--transition); }
.product-gallery__thumb.active { border-color: var(--champagne); }
.product-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.75) saturate(0.7); transition: filter var(--transition); }
.product-gallery__thumb:hover img, .product-gallery__thumb.active img { filter: brightness(0.9) saturate(0.9); }
.photo-credit { font-size: 10px; color: var(--mauve); margin-top: 8px; letter-spacing: 0.06em; }

/* product summary */
.product-summary__cat { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--champagne); margin-bottom: 14px; display: flex; align-items: center; gap: 10px; }
.product-summary__cat::before { content:''; width:18px; height:1px; background: var(--champagne); }
.product-summary__title { margin-bottom: 16px; }
.product-summary__title em { font-style: italic; color: var(--champagne); }
.product-summary__rating { display: flex; align-items: center; gap: 10px; margin-bottom: 24px; font-size: 12px; color: var(--smoke); }
.product-summary__stars { color: var(--champagne); font-size: 13px; letter-spacing: 3px; }
.product-summary__stars a { color: var(--champagne); }
.product-summary__price { font-family: var(--serif); font-size: 44px; font-weight: 300; color: var(--champagne); line-height: 1; margin-bottom: 6px; }
.product-summary__price del { font-size: 22px; color: var(--rose-dusk); margin-left: 12px; }
.product-summary__price-note { font-size: 12px; color: var(--smoke); margin-bottom: 28px; letter-spacing: 0.06em; }
.product-summary__divider { height: 1px; background: rgba(200,170,130,0.1); margin-bottom: 28px; }
.product-summary__desc { font-size: 14px; color: var(--smoke); line-height: 1.8; font-weight: 300; margin-bottom: 28px; }
.product-summary__desc strong { color: var(--pearl); font-weight: 400; }

/* options */
.product-option__label { font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--smoke); margin-bottom: 10px; display: block; }
.product-option__pills { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 24px; }
.product-option__pill { font-size: 12px; padding: 8px 18px; border: 1px solid rgba(200,170,130,0.18); background: none; color: var(--smoke); cursor: pointer; font-family: var(--sans); transition: all 0.2s; }
.product-option__pill:hover, .product-option__pill.active { background: var(--champagne); color: var(--obsidian); border-color: var(--champagne); }

/* qty + add to cart */
.product-actions { display: flex; gap: 12px; align-items: stretch; margin-bottom: 16px; }
.qty-control { display: flex; align-items: stretch; border: 1px solid rgba(200,170,130,0.2); }
.qty-btn { width: 44px; background: none; border: none; color: var(--champagne); font-size: 18px; cursor: pointer; transition: background 0.2s; }
.qty-btn:hover { background: var(--velvet); }
.qty-input { width: 52px; background: none; border: none; border-left: 1px solid rgba(200,170,130,0.12); border-right: 1px solid rgba(200,170,130,0.12); text-align: center; color: var(--pearl); font-family: var(--serif); font-size: 18px; font-weight: 300; outline: none; }
.btn-add-to-cart { flex: 1; }
.btn-wishlist { width: 52px; background: none; border: 1px solid rgba(200,170,130,0.18); color: var(--smoke); font-size: 18px; cursor: pointer; transition: all var(--transition); flex-shrink: 0; }
.btn-wishlist:hover { border-color: var(--champagne); color: var(--champagne); }

/* trust row */
.product-trust { display: flex; flex-direction: column; gap: 10px; padding: 20px; background: var(--velvet); margin-bottom: 28px; }
.product-trust__item { display: flex; align-items: center; gap: 12px; font-size: 12px; color: var(--smoke); }
.product-trust__icon { color: var(--champagne); font-size: 13px; flex-shrink: 0; width: 18px; text-align: center; }

/* product tabs */
.product-tabs { border-top: 1px solid rgba(200,170,130,0.1); margin-top: 4px; }
.product-tabs__nav { display: flex; border-bottom: 1px solid rgba(200,170,130,0.1); }
.product-tabs__link { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--smoke); padding: 14px 0; margin-right: 28px; background: none; border: none; cursor: pointer; font-family: var(--sans); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: all 0.2s; }
.product-tabs__link.active { color: var(--champagne); border-bottom-color: var(--champagne); }
.product-tabs__pane { display: none; padding: 28px 0; font-size: 13px; color: var(--smoke); line-height: 1.8; }
.product-tabs__pane.active { display: block; }

/* reviews */
.review { padding: 20px 0; border-bottom: 1px solid rgba(200,170,130,0.07); }
.review__header { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.review__avatar { width: 32px; height: 32px; border-radius: 50%; background: var(--mauve); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 14px; color: var(--champagne); flex-shrink: 0; }
.review__name { font-size: 13px; color: var(--pearl); }
.review__date { font-size: 11px; color: var(--smoke); margin-left: auto; }
.review__stars { color: var(--champagne); font-size: 11px; letter-spacing: 2px; }
.review__text { font-size: 13px; color: var(--smoke); line-height: 1.7; font-style: italic; }

/* related */
.related-products { background: var(--deep-plum); padding: var(--space-xl) var(--space-lg); border-top: 1px solid rgba(200,170,130,0.08); }
.related-products h2 { font-family: var(--serif); font-size: clamp(26px,3vw,40px); font-weight: 300; color: var(--ivory); margin-bottom: var(--space-lg); margin-top: 12px; }
.related-products ul.products, .related-grid { grid-template-columns: repeat(4,1fr); padding: 0; }

/* cart added notification */
.cart-notice { background: rgba(59,109,17,0.14); border: 1px solid rgba(59,109,17,0.28); color: #8BC96A; font-size: 12px; padding: 12px 16px; margin-bottom: 16px; display: none; letter-spacing: 0.04em; }
.cart-notice.show { display: block; }
.cart-notice a { color: #8BC96A; text-decoration: underline; }

/* mobile sticky bar */
.mobile-sticky-cta { display: none; }

/* ── BLOG ── */
.blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-top: var(--space-lg); }
.post-card { background: var(--velvet); text-decoration: none; display: block; transition: background var(--transition); }
.post-card:hover { background: var(--mauve); }
.post-card__img { aspect-ratio: 16/9; overflow: hidden; background: var(--deep-plum); }
.post-card__img img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.8) saturate(0.8); transition: transform 0.5s ease; }
.post-card:hover .post-card__img img { transform: scale(1.04); }
.post-card__body { padding: 24px 26px 28px; }
.post-card__cat { font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--champagne); margin-bottom: 8px; }
.post-card__title { font-family: var(--serif); font-size: 22px; font-weight: 300; color: var(--ivory); margin-bottom: 10px; line-height: 1.2; }
.post-card__excerpt { font-size: 13px; color: var(--smoke); line-height: 1.65; font-weight: 300; margin-bottom: 16px; }
.post-card__meta { font-size: 11px; color: var(--rose-dusk); letter-spacing: 0.06em; }
.post-card__read-more { font-size: 11px; color: var(--champagne); letter-spacing: 0.1em; text-transform: uppercase; margin-top: 12px; display: inline-block; transition: gap 0.2s; }
.post-card__read-more::after { content: ' →'; }

/* ── PAGINATION ── */
.noiatar-pagination { padding: var(--space-lg); display: flex; align-items: center; justify-content: center; gap: 4px; }
.noiatar-pagination a, .noiatar-pagination span { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; font-size: 12px; color: var(--smoke); border: 1px solid rgba(200,170,130,0.15); transition: all 0.2s; text-decoration: none; }
.noiatar-pagination a:hover, .noiatar-pagination .current { border-color: var(--champagne); color: var(--champagne); }

/* ── SCROLL REVEAL ── */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ════════════════════════════
   RESPONSIVE
════════════════════════════ */
@media (max-width: 1024px) {
  .services-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .footer-brand { grid-column: 1 / -1; }
}

@media (max-width: 900px) {
  :root { --nav-height: 58px; }
  .site-header { padding: 0 20px; grid-template-columns: 1fr auto; }
  .nav-primary { display: none; }
  .nav-hamburger { display: flex; }
  .btn-nav-login, .btn-nav-register { display: none; }

  .hero { grid-template-columns: 1fr; min-height: auto; }
  .hero__image { height: 60vw; min-height: 260px; max-height: 420px; }
  .hero__overlay { background: linear-gradient(to bottom, rgba(17,13,16,0) 0%, rgba(17,13,16,0.7) 65%, rgba(17,13,16,1) 100%); }
  .hero__content { padding: 36px 20px 80px; }

  .section { padding: var(--space-xl) 20px; }
  .proof-bar { padding: 24px 20px; flex-direction: column; align-items: flex-start; gap: 0; }
  .proof-divider { display: none; }
  .proof-quote { width: 100%; border-top: 1px solid rgba(200,170,130,0.15); padding-top: 20px; margin-top: 16px; }

  .services-grid { gap: 2px; }
  .service-card { padding: 40px 28px; }
  .service-card__badge { left: 28px; }
  .service-card__arrow { top: 40px; right: 28px; }

  .process-grid { grid-template-columns: 1fr 1fr; }
  .process-step { padding: 28px 20px; }

  .testimonials-grid { grid-template-columns: 1fr; }
  .testimonial-card { padding: 32px 24px; }

  ul.products, .products-grid { grid-template-columns: 1fr 1fr; padding: 20px; gap: 2px; }

  .single-product-layout { grid-template-columns: 1fr; gap: 36px; padding: 24px 20px 64px; }

  .related-products { padding: var(--space-lg) 20px; }
  .related-products ul.products, .related-grid { grid-template-columns: 1fr 1fr; }

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

  .archive-hero, .filter-bar { padding: 40px 20px; }

  .breadcrumb { padding: 20px 20px 0; }

  .footer-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
  .site-footer { padding: 48px 20px 32px; }
  .footer-bottom { flex-direction: column; gap: 8px; text-align: center; }

  .modal__header { padding: 32px 24px 0; }
  .modal__tabs { padding: 0 24px; }
  .modal__body { padding: 24px 24px 36px; }
  .form-row { grid-template-columns: 1fr; }
  .modal-backdrop { align-items: flex-end; padding: 0; }
  .modal { border-radius: 0; }

  .mobile-sticky-cta {
    display: flex !important; position: fixed; bottom: 0; left: 0; right: 0; z-index: 150;
    background: var(--champagne); opacity: 0; transition: opacity 0.4s; pointer-events: none;
  }
  .mobile-sticky-cta.visible { opacity: 1; pointer-events: auto; }
  .mobile-sticky-cta__btn {
    flex: 1; display: flex; align-items: center; justify-content: center;
    font-family: var(--sans); font-size: 11px; font-weight: 500;
    letter-spacing: 0.14em; text-transform: uppercase;
    color: var(--obsidian); text-decoration: none; background: none; border: none;
    cursor: pointer; padding: 18px 12px;
  }
  .mobile-sticky-cta__btn:first-child { border-right: 1px solid rgba(17,13,16,0.15); }
}

@media (max-width: 480px) {
  .process-grid { grid-template-columns: 1fr; }
  ul.products, .products-grid { grid-template-columns: 1fr; }
  .related-products ul.products, .related-grid { grid-template-columns: 1fr; }
  .product-actions { flex-wrap: wrap; }
  .btn-add-to-cart { min-height: 52px; }
}

/* ════════════════════════════════════════════════════════
   BLOGI — ARCHIVE & SINGLE
════════════════════════════════════════════════════════ */
.blog-layout { display: grid; grid-template-columns: 1fr 300px; gap: 64px; }
.blog-posts { min-width: 0; }

.post-card { background: var(--deep-plum); display: grid; grid-template-columns: 260px 1fr; margin-bottom: 2px; text-decoration: none; transition: background 0.25s; }
.post-card:hover { background: var(--velvet); }
.post-card-image { position: relative; overflow: hidden; }
.post-card-image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.post-card-image-placeholder { height: 200px; display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 44px; color: var(--champagne); opacity: 0.1; }
.post-card-cat-badge { position: absolute; top: 12px; left: 12px; background: var(--champagne); color: var(--obsidian); font-size: 9px; letter-spacing: 0.12em; padding: 4px 9px; font-weight: 500; text-transform: uppercase; }
.post-card-body { padding: 28px 32px; display: flex; flex-direction: column; }
.post-card-cat { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--champagne); margin-bottom: 8px; }
.post-card-cat a { color: inherit; text-decoration: none; transition: opacity 0.2s; }
.post-card-title { font-family: var(--serif); font-size: 22px; font-weight: 300; color: var(--ivory); margin-bottom: 10px; line-height: 1.25; }
.post-card-title a { color: inherit; text-decoration: none; }
.post-card-title a:hover { color: var(--champagne); }
.post-card-excerpt { font-size: 13px; color: var(--smoke); line-height: 1.75; font-weight: 300; flex: 1; margin-bottom: 18px; }
.post-card-footer { display: flex; align-items: center; gap: 8px; font-size: 11px; }
.post-card-date,.post-card-reading { color: var(--rose-dusk); }
.post-card-sep { color: var(--mauve); }
.post-card-more { color: var(--champagne); letter-spacing: 0.06em; text-transform: uppercase; text-decoration: none; margin-left: auto; transition: letter-spacing 0.2s; }
.post-card:hover .post-card-more { letter-spacing: 0.12em; }

/* Blog no-posts */
.no-posts { text-align: center; padding: 64px 24px; }
.no-posts-sym { font-family: var(--serif); font-size: 56px; opacity: 0.1; color: var(--champagne); margin-bottom: 20px; }
.no-posts-title { font-family: var(--serif); font-size: 28px; font-weight: 300; color: var(--ivory); margin-bottom: 10px; }
.no-posts-text { font-size: 14px; color: var(--smoke); margin-bottom: 24px; }

/* Pagination */
.pagination-wrap { margin-top: 36px; }
.pagination-wrap ul { display: flex; gap: 4px; list-style: none; flex-wrap: wrap; }
.pagination-wrap ul li a,.pagination-wrap ul li span { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; font-size: 13px; color: var(--smoke); border: 1px solid rgba(200,170,130,0.14); text-decoration: none; transition: all 0.2s; }
.pagination-wrap ul li a:hover,.pagination-wrap ul li span.current { border-color: var(--champagne); color: var(--champagne); }

/* Single post */
.reading-bar { position: sticky; top: var(--nav-height, 60px); left: 0; right: 0; height: 2px; background: var(--velvet); z-index: 100; }
.reading-progress { height: 100%; background: var(--champagne); width: 0; transition: width 0.1s linear; }

.post-layout { display: grid; grid-template-columns: 1fr 280px; gap: 64px; padding: 64px 0; }
.post-article {}

.post-header { margin-bottom: 32px; }
.post-category { font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--champagne); margin-bottom: 12px; }
.post-category a { color: inherit; text-decoration: none; }
.post-title { font-family: var(--serif); font-size: clamp(28px, 4vw, 48px); font-weight: 300; color: var(--ivory); line-height: 1.15; margin-bottom: 16px; }

.post-meta-bar { display: flex; align-items: center; gap: 12px; font-size: 12px; color: var(--smoke); flex-wrap: wrap; }
.post-author-info { display: flex; align-items: center; gap: 8px; }
.post-author-avatar { width: 28px; height: 28px; border-radius: 50%; background: var(--velvet); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 12px; color: var(--champagne); flex-shrink: 0; }
.post-author-name { color: var(--smoke); text-decoration: none; }
.post-meta-sep { color: var(--mauve); }
.post-date,.post-reading-time { color: var(--smoke); }
.post-comments-count { color: var(--champagne); text-decoration: none; }

.post-cover { margin-bottom: 36px; position: relative; }
.post-cover img { width: 100%; height: 420px; object-fit: cover; display: block; }
.photo-credit { position: absolute; bottom: 12px; right: 14px; font-size: 10px; color: rgba(200,170,130,0.4); letter-spacing: 0.06em; }

.post-body { font-size: 16px; color: var(--smoke); line-height: 1.85; font-weight: 300; }
.post-body h2 { font-family: var(--serif); font-size: clamp(22px, 2.5vw, 30px); font-weight: 300; color: var(--ivory); margin: 40px 0 18px; line-height: 1.2; }
.post-body h3 { font-family: var(--serif); font-size: 20px; font-weight: 300; color: var(--ivory); margin: 28px 0 12px; }
.post-body p { margin-bottom: 22px; }
.post-body a { color: var(--champagne); text-decoration: underline; text-decoration-color: rgba(200,170,130,0.3); transition: color 0.2s; }
.post-body a:hover { color: var(--pearl); }
.post-body strong { color: var(--pearl); font-weight: 400; }
.post-body blockquote { border-left: 2px solid var(--champagne); padding: 18px 26px; margin: 32px 0; background: var(--deep-plum); }
.post-body blockquote p { color: var(--ivory); font-family: var(--serif); font-size: 19px; font-weight: 300; font-style: italic; margin: 0; line-height: 1.5; }
.post-body ul,.post-body ol { padding-left: 24px; margin-bottom: 22px; }
.post-body li { margin-bottom: 8px; }
.post-body img { max-width: 100%; height: auto; display: block; margin: 28px 0; }
.post-body hr { border: none; border-top: 1px solid rgba(200,170,130,0.12); margin: 36px 0; }

.post-footer { margin-top: 36px; padding-top: 28px; border-top: 1px solid rgba(200,170,130,0.09); }
.post-tags { display: flex; gap: 8px; flex-wrap: wrap; }
.post-tag { font-size: 11px; padding: 6px 14px; border: 1px solid rgba(200,170,130,0.16); color: var(--smoke); text-decoration: none; transition: all 0.2s; }
.post-tag:hover { border-color: var(--champagne); color: var(--champagne); }

.author-box { background: var(--deep-plum); padding: 26px 30px; display: flex; gap: 20px; margin: 40px 0; border-left: 2px solid var(--champagne); }
.author-box-avatar { width: 64px; height: 64px; border-radius: 50%; background: var(--velvet); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 26px; color: var(--champagne); flex-shrink: 0; }
.author-box-info {}
.author-box-name { font-family: var(--serif); font-size: 18px; font-weight: 300; color: var(--ivory); margin-bottom: 4px; }
.author-box-title { font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--champagne); margin-bottom: 10px; }
.author-box-bio { font-size: 13px; color: var(--smoke); line-height: 1.7; font-weight: 300; }

.related-posts { margin-top: 48px; padding-top: 40px; border-top: 1px solid rgba(200,170,130,0.09); }
.related-posts-title { font-family: var(--serif); font-size: 26px; font-weight: 300; color: var(--ivory); margin-bottom: 24px; }
.related-posts-title em { font-style: italic; color: var(--champagne); }
.related-posts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; }
.related-post-card { background: var(--deep-plum); text-decoration: none; transition: background 0.2s; display: block; }
.related-post-card:hover { background: var(--velvet); }
.related-post-img { height: 140px; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.related-post-img img { width: 100%; height: 100%; object-fit: cover; }
.related-post-img--empty { background: var(--velvet); font-family: var(--serif); font-size: 32px; color: var(--champagne); opacity: 0.2; }
.related-post-body { padding: 16px 18px; }
.related-post-title { font-size: 14px; color: var(--pearl); line-height: 1.4; margin-bottom: 6px; }
.related-post-date { font-size: 11px; color: var(--smoke); }

/* Post sidebar */
.post-sidebar {}
.sidebar-block { margin-bottom: 36px; }
.sidebar-block-title { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--champagne); margin-bottom: 14px; display: flex; align-items: center; gap: 8px; }
.sidebar-block-title::before { content: ''; width: 14px; height: 1px; background: var(--champagne); }
.sidebar-newsletter-box { background: var(--deep-plum); padding: 20px; }
.sidebar-newsletter-text { font-size: 12px; color: var(--smoke); line-height: 1.6; margin-bottom: 14px; font-weight: 300; }
.sidebar-cat-list { list-style: none; }
.sidebar-cat-item { display: flex; align-items: center; justify-content: space-between; padding: 9px 0; border-bottom: 1px solid rgba(200,170,130,0.07); font-size: 13px; }
.sidebar-cat-item a { color: var(--smoke); text-decoration: none; transition: color 0.2s; }
.sidebar-cat-item a:hover { color: var(--champagne); }
.sidebar-cat-count { font-size: 11px; color: var(--rose-dusk); }
.sidebar-post-item { display: flex; gap: 12px; padding: 12px 0; border-bottom: 1px solid rgba(200,170,130,0.06); text-decoration: none; transition: opacity 0.2s; }
.sidebar-post-item:hover { opacity: 0.8; }
.sidebar-post-thumb { width: 50px; height: 50px; background: var(--velvet); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 18px; color: var(--champagne); opacity: 0.35; flex-shrink: 0; overflow: hidden; }
.sidebar-post-thumb img { width: 100%; height: 100%; object-fit: cover; }
.sidebar-post-title { font-size: 12px; color: var(--pearl); line-height: 1.4; margin-bottom: 3px; }
.sidebar-post-date { font-size: 11px; color: var(--smoke); }
.sidebar-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.sidebar-tag { font-size: 11px; padding: 6px 12px; border: 1px solid rgba(200,170,130,0.14); color: var(--smoke); text-decoration: none; transition: all 0.2s; }
.sidebar-tag:hover { border-color: var(--champagne); color: var(--champagne); }

/* Comments */
.comments-section { margin-top: 52px; padding-top: 40px; border-top: 1px solid rgba(200,170,130,0.09); }
.comments-title { font-family: var(--serif); font-size: 26px; font-weight: 300; color: var(--ivory); margin-bottom: 28px; }
.comment-item { display: flex; gap: 16px; margin-bottom: 28px; padding-bottom: 28px; border-bottom: 1px solid rgba(200,170,130,0.07); }
.comment-item:last-of-type { border: none; }
.comment-avatar-circle { width: 44px; height: 44px; border-radius: 50%; background: var(--velvet); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 16px; color: var(--champagne); flex-shrink: 0; }
.comment-meta-bar { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.comment-name { font-size: 14px; color: var(--pearl); font-weight: 400; }
.comment-date { font-size: 11px; color: var(--smoke); }
.comment-text { font-size: 14px; color: var(--smoke); line-height: 1.7; font-weight: 300; margin-bottom: 8px; }
.comment-text p { margin-bottom: 8px; }
.comment-actions { font-size: 11px; }
.comment-actions a { color: var(--champagne); text-decoration: none; letter-spacing: 0.06em; text-transform: uppercase; }
.comment-pending { font-size: 12px; color: var(--rose-dusk); font-style: italic; margin-bottom: 8px; }
.comment-form-wrap { background: var(--deep-plum); padding: 32px; margin-top: 40px; }
.comment-form-title { font-family: var(--serif); font-size: 22px; font-weight: 300; color: var(--ivory); margin-bottom: 20px; }
.comment-fields-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.comments-nav-prev,.comments-nav-next { display: inline-block; margin-top: 8px; }
.comments-nav-prev a,.comments-nav-next a { font-size: 12px; color: var(--champagne); text-decoration: none; letter-spacing: 0.08em; }
.comments-closed { font-size: 13px; color: var(--smoke); font-style: italic; }

/* ════════════════════════════════════════════════════════
   SEARCH
════════════════════════════════════════════════════════ */
.search-bar-section { background: var(--deep-plum); padding: 44px 0; border-bottom: 1px solid rgba(200,170,130,0.08); }
.search-form-bar { display: flex; gap: 0; max-width: 680px; }
.search-input-bar { flex: 1; padding: 16px 20px; background: var(--velvet); border: 1px solid rgba(200,170,130,0.2); color: var(--pearl); font-family: var(--serif); font-size: 18px; font-weight: 300; font-style: italic; outline: none; transition: border-color 0.25s; }
.search-input-bar:focus { border-color: var(--champagne); }
.search-input-bar::placeholder { color: var(--rose-dusk); font-size: 16px; }
.search-submit-bar { width: 52px; background: var(--champagne); border: none; color: var(--obsidian); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background 0.2s; }
.search-submit-bar:hover { background: var(--pearl); }
.search-result-count { font-size: 13px; color: var(--smoke); margin-top: 12px; }
.search-result-count strong { color: var(--champagne); }

.search-results-wrap {}
.search-results-list { display: flex; flex-direction: column; gap: 2px; }
.search-result-row { background: var(--deep-plum); padding: 22px 26px; text-decoration: none; transition: background 0.2s; display: flex; gap: 20px; align-items: flex-start; }
.search-result-row:hover { background: var(--velvet); }
.search-result-thumb { width: 72px; height: 72px; background: var(--velvet); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 28px; color: var(--champagne); opacity: 0.3; flex-shrink: 0; overflow: hidden; }
.search-result-thumb img { width: 100%; height: 100%; object-fit: cover; opacity: 1; }
.search-result-type { font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--champagne); margin-bottom: 6px; }
.search-result-title { font-family: var(--serif); font-size: 20px; font-weight: 300; color: var(--ivory); margin-bottom: 6px; line-height: 1.2; }
.search-result-excerpt { font-size: 13px; color: var(--smoke); line-height: 1.6; font-weight: 300; margin-bottom: 0; }
.search-result-meta { font-size: 11px; color: var(--rose-dusk); margin-top: 8px; }
.search-empty { text-align: center; padding: 72px 24px; }
.search-empty-sym { font-family: var(--serif); font-size: 64px; opacity: 0.1; color: var(--champagne); margin-bottom: 20px; line-height: 1; }
.search-empty-title { font-family: var(--serif); font-size: 28px; font-weight: 300; color: var(--ivory); margin-bottom: 10px; }
.search-empty-text { font-size: 14px; color: var(--smoke); margin-bottom: 24px; font-weight: 300; }
.search-suggestions { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
.search-sug-pill { font-size: 12px; padding: 8px 16px; border: 1px solid rgba(200,170,130,0.18); color: var(--smoke); text-decoration: none; transition: all 0.18s; }
.search-sug-pill:hover { border-color: var(--champagne); color: var(--champagne); }

/* ════════════════════════════════════════════════════════
   404
════════════════════════════════════════════════════════ */
.error-wrap { min-height: calc(100vh - 60px); display: flex; align-items: center; justify-content: center; padding: 48px 24px; text-align: center; }
.error-inner { max-width: 560px; width: 100%; }
.error-num { font-family: var(--serif); font-size: 130px; font-weight: 300; color: var(--champagne); opacity: 0.1; line-height: 1; margin-bottom: -24px; }
.error-sym { font-family: var(--serif); font-size: 56px; color: var(--champagne); opacity: 0.22; line-height: 1; margin-bottom: 24px; }
.error-title { font-family: var(--serif); font-size: clamp(28px, 4vw, 44px); font-weight: 300; color: var(--ivory); margin-bottom: 14px; }
.error-title em { font-style: italic; color: var(--champagne); }
.error-text { font-size: 15px; color: var(--smoke); line-height: 1.8; margin-bottom: 32px; font-weight: 300; }
.error-actions { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-bottom: 36px; }
.error-search { display: flex; gap: 0; max-width: 380px; margin: 24px auto 0; }
.error-search-input { flex: 1; padding: 14px 16px; background: var(--deep-plum); border: 1px solid rgba(200,170,130,0.16); color: var(--pearl); font-family: var(--sans); font-size: 14px; outline: none; transition: border-color 0.25s; }
.error-search-input:focus { border-color: var(--champagne); }
.error-quick-links { background: var(--deep-plum); padding: 22px 26px; text-align: left; }
.error-quick-title { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--champagne); margin-bottom: 14px; }
.error-quick-list { list-style: none; }
.error-quick-link { font-size: 14px; color: var(--smoke); text-decoration: none; display: flex; align-items: center; justify-content: space-between; padding: 9px 0; border-bottom: 1px solid rgba(200,170,130,0.06); transition: color 0.2s; }
.error-quick-link:last-child { border: none; }
.error-quick-link:hover { color: var(--champagne); }
.error-quick-link::after { content: '→'; color: var(--champagne); opacity: 0.4; font-size: 12px; }

/* ════════════════════════════════════════════════════════
   CHECKOUT
════════════════════════════════════════════════════════ */
.noiatar-checkout-form,.noiatar-checkout-layout { margin: 0; }
.noiatar-checkout-layout { display: grid; grid-template-columns: 1fr 380px; min-height: 80vh; gap: 0; }
.checkout-fields-col { background: var(--obsidian); padding: 48px 56px; }
.checkout-summary-col { background: var(--deep-plum); padding: 40px 36px; border-left: 1px solid rgba(200,170,130,0.08); }
.checkout-breadcrumb { display: flex; align-items: center; gap: 8px; margin-bottom: 32px; flex-wrap: wrap; }
.co-step { font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--mauve); display: flex; align-items: center; gap: 8px; }
.co-step.done { color: var(--smoke); }
.co-step.on { color: var(--champagne); }
.co-step-num { width: 22px; height: 22px; border-radius: 50%; border: 1px solid currentColor; display: flex; align-items: center; justify-content: center; font-size: 10px; flex-shrink: 0; }
.co-step.on .co-step-num { background: var(--champagne); color: var(--obsidian); border-color: var(--champagne); }
.co-sep { color: var(--velvet); font-size: 10px; }
.checkout-section { margin-bottom: 36px; }
.checkout-section-title { font-family: var(--serif); font-size: 22px; font-weight: 300; color: var(--ivory); margin-bottom: 20px; }
.checkout-section-title em { font-style: italic; color: var(--champagne); }
.checkout-terms { font-size: 12px; color: var(--smoke); margin: 18px 0; line-height: 1.6; }
.checkout-terms a { color: var(--champagne); }
.checkout-submit-btn { width: 100%; padding: 17px; margin-top: 8px; }
.checkout-secure-note { font-size: 11px; color: var(--rose-dusk); text-align: center; margin-top: 20px; display: flex; align-items: center; justify-content: center; gap: 6px; }
.checkout-summary-title { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--champagne); margin-bottom: 18px; display: flex; align-items: center; gap: 8px; }
.checkout-summary-title::before { content: ''; width: 14px; height: 1px; background: var(--champagne); }
.checkout-order-summary {}

/* WooCommerce checkout field overrides */
.noiatar-checkout-form .form-row { margin-bottom: 18px; }
.noiatar-checkout-form .form-row label { display: block; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--smoke); margin-bottom: 8px; }
.noiatar-checkout-form .form-row .input-text,
.noiatar-checkout-form .form-row select { width: 100%; padding: 14px 15px; background: var(--deep-plum); border: 1px solid rgba(200,170,130,0.12); color: var(--pearl); font-family: var(--sans); font-size: 16px; outline: none; transition: border-color 0.25s; -webkit-appearance: none; border-radius: 0; min-height: 48px; }
.noiatar-checkout-form .form-row .input-text:focus,
.noiatar-checkout-form .form-row select:focus { border-color: var(--champagne); }
.noiatar-checkout-form .form-row-wide { width: 100%; }
.noiatar-checkout-form .form-row-first { float: left; width: calc(50% - 7px); }
.noiatar-checkout-form .form-row-last { float: right; width: calc(50% - 7px); }
.noiatar-checkout-form .clear { clear: both; }

/* Payment methods */
.noiatar-payment-methods { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.noiatar-payment-method { background: var(--deep-plum); border: 1px solid rgba(200,170,130,0.12); transition: border-color 0.2s; }
.noiatar-payment-label { display: flex; align-items: center; gap: 14px; padding: 14px 16px; cursor: pointer; font-size: 14px; color: var(--pearl); }
.noiatar-payment-method input[type=radio] { width: 16px; height: 16px; accent-color: var(--champagne); cursor: pointer; }
.noiatar-payment-method:has(input:checked) { border-color: var(--champagne); }
.payment-icon img { max-height: 24px; opacity: 0.7; }
.payment_box { padding: 12px 16px 16px; border-top: 1px solid rgba(200,170,130,0.08); }

/* ════════════════════════════════════════════════════════
   ORDER RECEIVED / DETAILS
════════════════════════════════════════════════════════ */
.order-received-wrap { text-align: center; padding: 64px 24px 48px; max-width: 680px; margin: 0 auto; }
.order-received-sym { font-family: var(--serif); font-size: 80px; color: var(--champagne); opacity: 0.2; line-height: 1; margin-bottom: 24px; }
.order-received-title { font-family: var(--serif); font-size: clamp(30px,4vw,50px); font-weight: 300; color: var(--ivory); margin-bottom: 14px; }
.order-received-title em { font-style: italic; color: var(--champagne); }
.order-received-text { font-size: 15px; color: var(--smoke); line-height: 1.8; margin-bottom: 32px; font-weight: 300; }
.order-received-meta { display: grid; grid-template-columns: repeat(4,1fr); gap: 2px; margin-bottom: 36px; }
.order-meta-item { background: var(--deep-plum); padding: 16px; }
.order-meta-label { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--smoke); margin-bottom: 6px; }
.order-meta-val { font-family: var(--serif); font-size: 15px; color: var(--champagne); font-weight: 300; }
.order-next-steps { background: var(--deep-plum); padding: 28px; margin-bottom: 32px; border-left: 2px solid var(--champagne); text-align: left; }
.order-next-title { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--champagne); margin-bottom: 18px; }
.order-steps-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; }
.order-step { background: var(--velvet); padding: 18px; }
.order-step-num { font-family: var(--serif); font-size: 28px; color: var(--champagne); opacity: 0.3; margin-bottom: 8px; line-height: 1; }
.order-step-t { font-size: 13px; color: var(--pearl); margin-bottom: 4px; }
.order-step-s { font-size: 12px; color: var(--smoke); line-height: 1.5; font-weight: 300; }
.order-received-actions { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.order-details-wrap { max-width: 680px; margin: 0 auto; padding: 0 0 64px; }
.order-details-title { font-family: var(--serif); font-size: 28px; font-weight: 300; color: var(--ivory); margin-bottom: 32px; }
.order-details-title em { font-style: italic; color: var(--champagne); }
.order-details-section { margin-bottom: 32px; }
.order-details-section-title { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--champagne); margin-bottom: 14px; display: flex; align-items: center; gap: 8px; }
.order-details-section-title::before { content: ''; width: 14px; height: 1px; background: var(--champagne); }
.order-items-list { background: var(--deep-plum); }
.order-item { display: flex; justify-content: space-between; align-items: center; padding: 14px 18px; border-bottom: 1px solid rgba(200,170,130,0.06); font-size: 14px; }
.order-item:last-child { border: none; }
.order-item-name { color: var(--pearl); }
.order-item-name a { color: inherit; text-decoration: none; }
.order-item-qty { color: var(--smoke); font-size: 12px; margin-left: 6px; }
.order-item-price { color: var(--champagne); font-family: var(--serif); font-size: 16px; }
.order-totals { padding-top: 4px; }
.order-total-row { display: flex; justify-content: space-between; padding: 7px 18px; font-size: 13px; border-bottom: 1px solid rgba(200,170,130,0.04); }
.order-total-row:last-child { border: none; }
.order-total-label { color: var(--smoke); }
.order-total-value { color: var(--pearl); }
.order-total-final { background: var(--deep-plum); padding: 12px 18px; border-top: 1px solid rgba(200,170,130,0.12) !important; }
.order-total-final .order-total-label { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; }
.order-total-final .order-total-value { font-family: var(--serif); font-size: 20px; color: var(--champagne); }
.order-download-item { display: flex; align-items: center; justify-content: space-between; padding: 14px 18px; background: var(--deep-plum); margin-bottom: 2px; gap: 16px; }
.order-download-name { font-size: 14px; color: var(--pearl); }
.order-address { font-size: 14px; color: var(--smoke); line-height: 1.7; font-style: normal; font-weight: 300; }
.order-address a { color: var(--champagne); text-decoration: none; }

/* ════════════════════════════════════════════════════════
   MINU KONTO
════════════════════════════════════════════════════════ */
.noiatar-myaccount { min-height: 80vh; }
.myaccount-layout { display: grid; grid-template-columns: 260px 1fr; min-height: 80vh; }
.myaccount-sidebar { background: var(--deep-plum); padding: 0; }
.myaccount-user-box { padding: 28px 24px 22px; border-bottom: 1px solid rgba(200,170,130,0.1); display: flex; align-items: center; gap: 14px; }
.myaccount-avatar { width: 48px; height: 48px; border-radius: 50%; background: var(--mauve); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 20px; color: var(--champagne); flex-shrink: 0; }
.myaccount-user-name { font-family: var(--serif); font-size: 16px; font-weight: 300; color: var(--ivory); }
.myaccount-user-email { font-size: 12px; color: var(--smoke); margin-top: 2px; }
.myaccount-nav-list { list-style: none; padding: 8px 0; }
.myaccount-nav-item a { display: flex; align-items: center; gap: 12px; padding: 13px 24px; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--smoke); text-decoration: none; border-left: 2px solid transparent; transition: all 0.2s; min-height: 48px; }
.myaccount-nav-item a:hover { color: var(--pearl); background: rgba(200,170,130,0.04); }
.myaccount-nav-item.is-active a,.myaccount-nav-item.current-menu-item a { color: var(--champagne); border-left-color: var(--champagne); background: rgba(200,170,130,0.06); }
.myaccount-nav-icon { font-family: var(--serif); font-size: 14px; width: 18px; text-align: center; flex-shrink: 0; }

.myaccount-main { background: var(--obsidian); padding: 40px 52px; }
.myaccount-section { }
.myaccount-section-title { font-family: var(--serif); font-size: 26px; font-weight: 300; color: var(--ivory); margin-bottom: 24px; }
.myaccount-section-title em { font-style: italic; color: var(--champagne); }
.myaccount-greeting { font-family: var(--serif); font-size: 32px; font-weight: 300; color: var(--ivory); margin-bottom: 6px; }
.myaccount-greeting em { font-style: italic; color: var(--champagne); }
.myaccount-greeting-sub { font-size: 14px; color: var(--smoke); margin-bottom: 32px; font-weight: 300; }
.myaccount-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-bottom: 36px; }
.myaccount-stat { background: var(--deep-plum); padding: 20px 22px; }
.myaccount-stat-num { font-family: var(--serif); font-size: 32px; color: var(--champagne); font-weight: 300; line-height: 1; margin-bottom: 6px; }
.myaccount-stat-num bdi { font-family: var(--serif); }
.myaccount-stat-label { font-size: 10px; color: var(--smoke); letter-spacing: 0.1em; text-transform: uppercase; }
.myaccount-recent-title { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--champagne); margin-bottom: 14px; display: flex; align-items: center; gap: 8px; }
.myaccount-recent-title::before { content: ''; width: 14px; height: 1px; background: var(--champagne); }

.myaccount-orders-list { display: flex; flex-direction: column; gap: 2px; }
.myaccount-order-row { background: var(--deep-plum); padding: 16px 20px; display: flex; align-items: center; gap: 14px; text-decoration: none; transition: background 0.2s; cursor: pointer; }
.myaccount-order-row:hover { background: var(--velvet); }
.myaccount-order-icon { width: 38px; height: 38px; background: var(--velvet); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 16px; color: var(--champagne); flex-shrink: 0; }
.myaccount-order-info { flex: 1; min-width: 0; }
.myaccount-order-name { font-family: var(--serif); font-size: 15px; color: var(--ivory); font-weight: 300; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.myaccount-order-meta { font-size: 11px; color: var(--smoke); margin-top: 3px; }
.myaccount-order-price { font-family: var(--serif); font-size: 16px; color: var(--champagne); flex-shrink: 0; }
.myaccount-order-arrow { font-size: 12px; color: var(--champagne); opacity: 0.5; flex-shrink: 0; }
.myaccount-status-badge { font-size: 10px; padding: 2px 7px; letter-spacing: 0.06em; }
.myaccount-status-badge.status-completed,.myaccount-status-badge.status-processing { color: #8BC96A; background: rgba(59,109,17,0.14); }
.myaccount-status-badge.status-pending { color: var(--champagne); background: rgba(200,170,130,0.12); }
.myaccount-status-badge.status-cancelled { color: #CC8282; background: rgba(180,50,50,0.14); }

.myaccount-section-divider { margin: 28px 0 20px; padding-top: 24px; border-top: 1px solid rgba(200,170,130,0.09); }
.myaccount-subsection-title { font-family: var(--serif); font-size: 20px; font-weight: 300; color: var(--ivory); margin-bottom: 4px; }
.myaccount-subsection-title em { font-style: italic; color: var(--champagne); }
.myaccount-subsection-sub { font-size: 13px; color: var(--smoke); font-weight: 300; }
.myaccount-fields-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.myaccount-form-actions { margin-top: 24px; display: flex; gap: 10px; flex-wrap: wrap; }
.myaccount-empty { padding: 40px 0; }
.myaccount-empty p { font-size: 14px; color: var(--smoke); margin-bottom: 16px; }
.myaccount-empty a,.myaccount-empty p a { color: var(--champagne); }
.myaccount-pagination { display: flex; gap: 10px; margin-top: 24px; }
.myaccount-address-overview { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; }
.myaccount-address-card { background: var(--deep-plum); padding: 24px; }
.myaccount-address-card-title { font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--champagne); margin-bottom: 14px; }
.myaccount-no-address { font-size: 13px; color: var(--smoke); font-style: italic; }
address.woocommerce-address,.myaccount-address-card address { font-style: normal; font-size: 14px; color: var(--smoke); line-height: 1.7; font-weight: 300; }

/* WC form fields inside myaccount */
.myaccount-main .form-row { margin-bottom: 18px; }
.myaccount-main .form-row label { display: block; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--smoke); margin-bottom: 8px; }
.myaccount-main .form-row .input-text,
.myaccount-main .form-row input[type=text],
.myaccount-main .form-row input[type=email],
.myaccount-main .form-row input[type=password],
.myaccount-main .form-row select { width: 100%; padding: 14px 15px; background: var(--deep-plum); border: 1px solid rgba(200,170,130,0.12); color: var(--pearl); font-family: var(--sans); font-size: 16px; outline: none; transition: border-color 0.25s; border-radius: 0; -webkit-appearance: none; }
.myaccount-main .form-row .input-text:focus,
.myaccount-main .form-row input:focus,
.myaccount-main .form-row select:focus { border-color: var(--champagne); }
.form-hint { font-size: 11px; color: var(--smoke); margin-top: 6px; display: block; }

/* ════════════════════════════════════════════════════════
   MINUST LEHT
════════════════════════════════════════════════════════ */
.about-grid { display: grid; grid-template-columns: 1fr 1fr; min-height: calc(100vh - 60px); }
.about-left { position: relative; background: var(--deep-plum); display: flex; align-items: flex-end; min-height: 600px; overflow: hidden; }
.about-photo { width: 100%; height: 100%; object-fit: cover; object-position: center 20%; position: absolute; inset: 0; }
.about-photo-placeholder { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.about-photo-sym { font-family: var(--serif); font-size: 120px; color: var(--champagne); opacity: 0.07; line-height: 1; }
.about-left-overlay { position: relative; z-index: 1; padding: 44px; background: linear-gradient(to top, rgba(17,13,16,0.92) 0%, rgba(17,13,16,0) 100%); width: 100%; }
.about-quote { font-family: var(--serif); font-size: 21px; font-weight: 300; color: var(--ivory); font-style: italic; line-height: 1.45; margin-bottom: 10px; }
.about-quote-attr { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--champagne); }
.about-right { background: var(--obsidian); padding: 72px 64px; display: flex; flex-direction: column; justify-content: center; }
.about-title { font-family: var(--serif); font-size: clamp(28px,3vw,44px); font-weight: 300; color: var(--ivory); margin-bottom: 24px; line-height: 1.15; }
.about-title em { font-style: italic; color: var(--champagne); }
.about-body { font-size: 15px; color: var(--smoke); line-height: 1.85; font-weight: 300; margin-bottom: 32px; }
.about-body strong { color: var(--pearl); font-weight: 400; }
.about-body p { margin-bottom: 18px; }
.about-values { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; margin-bottom: 32px; }
.about-value-card { background: var(--deep-plum); padding: 20px 22px; }
.about-value-icon { font-family: var(--serif); font-size: 20px; color: var(--champagne); opacity: 0.45; margin-bottom: 10px; }
.about-value-title { font-size: 13px; color: var(--pearl); font-weight: 400; margin-bottom: 5px; }
.about-value-text { font-size: 12px; color: var(--smoke); line-height: 1.6; font-weight: 300; }
.about-credentials { margin-bottom: 32px; }
.about-cred-label { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--champagne); margin-bottom: 14px; }
.about-cred-list { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.about-cred-list li { font-size: 13px; color: var(--smoke); font-weight: 300; display: flex; align-items: flex-start; gap: 10px; line-height: 1.5; }
.about-cred-list li::before { content: '◈'; color: var(--champagne); font-family: var(--serif); font-size: 11px; flex-shrink: 0; margin-top: 2px; }
.about-cta-row { display: flex; gap: 10px; flex-wrap: wrap; }

/* ════════════════════════════════════════════════════════
   KKK LEHT
════════════════════════════════════════════════════════ */
.kkk-layout { display: grid; grid-template-columns: 200px 1fr; gap: 56px; }
.kkk-sidebar-nav { position: sticky; top: calc(60px + 24px); align-self: start; }
.kkk-nav-label { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--champagne); margin-bottom: 14px; }
.kkk-nav-list { list-style: none; }
.kkk-nav-link { font-size: 12px; color: var(--smoke); display: block; padding: 8px 0 8px 13px; border-left: 2px solid transparent; letter-spacing: 0.05em; transition: all 0.2s; text-decoration: none; line-height: 1.3; }
.kkk-nav-link:hover,.kkk-nav-link.active { color: var(--champagne); border-left-color: var(--champagne); }
.kkk-group { margin-bottom: 48px; }
.kkk-group-title { font-family: var(--serif); font-size: 22px; font-weight: 300; color: var(--ivory); margin-bottom: 18px; padding-bottom: 12px; border-bottom: 1px solid rgba(200,170,130,0.1); }
.kkk-group-title em { font-style: italic; color: var(--champagne); }
.kkk-item { border-bottom: 1px solid rgba(200,170,130,0.07); }
.kkk-btn { width: 100%; display: flex; align-items: center; justify-content: space-between; padding: 17px 0; background: none; border: none; cursor: pointer; font-family: var(--sans); font-size: 14px; color: var(--pearl); text-align: left; gap: 14px; transition: color 0.2s; min-height: 48px; }
.kkk-btn:hover,.kkk-btn[aria-expanded=true] { color: var(--champagne); }
.kkk-plus { font-size: 20px; color: var(--champagne); flex-shrink: 0; transition: transform 0.3s; line-height: 1; width: 20px; text-align: center; }
.kkk-btn[aria-expanded=true] .kkk-plus { transform: rotate(45deg); }
.kkk-answer { padding: 0 0 18px; font-size: 14px; color: var(--smoke); line-height: 1.8; font-weight: 300; }
.kkk-answer p { margin-bottom: 10px; }
.kkk-answer p:last-child { margin-bottom: 0; }
.kkk-answer a { color: var(--champagne); }
.kkk-answer strong { color: var(--pearl); font-weight: 400; }
.kkk-cta-box { background: var(--deep-plum); padding: 28px; border-left: 2px solid var(--champagne); margin-top: 16px; }
.kkk-cta-title { font-family: var(--serif); font-size: 20px; color: var(--ivory); margin-bottom: 8px; font-weight: 300; }
.kkk-cta-text { font-size: 14px; color: var(--smoke); margin-bottom: 18px; font-weight: 300; }

/* ════════════════════════════════════════════════════════
   TAGASISIDE LEHT
════════════════════════════════════════════════════════ */
.reviews-stats-row { display: grid; grid-template-columns: auto 1fr; gap: 40px; align-items: center; margin-bottom: 48px; }
.reviews-big-score { text-align: center; }
.reviews-score-num { font-family: var(--serif); font-size: 72px; font-weight: 300; color: var(--champagne); line-height: 1; }
.reviews-stars-row { display: flex; gap: 4px; justify-content: center; margin: 8px 0 6px; }
.reviews-score-sub { font-size: 12px; color: var(--smoke); letter-spacing: 0.1em; text-transform: uppercase; }
.reviews-bar-row { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; font-size: 12px; color: var(--smoke); }
.reviews-bar-star { width: 12px; text-align: right; flex-shrink: 0; }
.reviews-bar-track { flex: 1; height: 4px; background: var(--velvet); position: relative; }
.reviews-bar-fill { position: absolute; left: 0; top: 0; bottom: 0; background: var(--champagne); }
.reviews-bar-count { width: 24px; flex-shrink: 0; text-align: right; }
.reviews-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; margin-bottom: 52px; }
.review-card { background: var(--deep-plum); padding: 26px 28px; }
.review-card-stars { display: flex; gap: 3px; margin-bottom: 14px; }
.review-card-text { font-family: var(--serif); font-size: 16px; font-weight: 300; color: var(--ivory); line-height: 1.65; font-style: italic; margin-bottom: 16px; }
.review-card-author { display: flex; align-items: center; gap: 10px; }
.review-card-avatar { width: 36px; height: 36px; border-radius: 50%; background: var(--velvet); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 14px; color: var(--champagne); flex-shrink: 0; }
.review-card-name { font-size: 13px; color: var(--pearl); }
.review-card-service { font-size: 11px; color: var(--smoke); margin-top: 1px; }
.review-card-date { font-size: 11px; color: var(--rose-dusk); margin-left: auto; }
.review-form-section { max-width: 680px; }
.review-form-wrap { background: var(--deep-plum); padding: 40px; border-left: 2px solid var(--champagne); }
.review-form-title { font-family: var(--serif); font-size: 28px; font-weight: 300; color: var(--ivory); margin-bottom: 8px; }
.review-form-title em { font-style: italic; color: var(--champagne); }
.review-form-sub { font-size: 14px; color: var(--smoke); margin-bottom: 28px; font-weight: 300; }
/* Star rating CSS-only */
.star-rating-input { display: flex; flex-direction: row-reverse; gap: 4px; }
.star-rating-input input { display: none; }
.star-rating-input label { font-size: 28px; color: var(--velvet); cursor: pointer; transition: color 0.15s; font-family: var(--serif); }
.star-rating-input input:checked ~ label,
.star-rating-input label:hover,
.star-rating-input label:hover ~ label { color: var(--champagne); }
.review-login-prompt { background: var(--velvet); padding: 24px; text-align: center; }
.review-login-prompt p { font-size: 14px; color: var(--smoke); margin-bottom: 16px; }

/* ════════════════════════════════════════════════════════
   PAGE GENERAL
════════════════════════════════════════════════════════ */
.page-content {}
.page-article {}
.page-header { margin-bottom: 40px; }
.page-title { font-family: var(--serif); font-size: clamp(28px,4vw,48px); font-weight: 300; color: var(--ivory); line-height: 1.15; }
.page-body { font-size: 16px; color: var(--smoke); line-height: 1.85; font-weight: 300; max-width: 720px; }
.page-body h2 { font-family: var(--serif); font-size: 26px; font-weight: 300; color: var(--ivory); margin: 36px 0 16px; }
.page-body p { margin-bottom: 20px; }
.page-body a { color: var(--champagne); }
.page-body ul,.page-body ol { padding-left: 22px; margin-bottom: 18px; }
.page-body li { margin-bottom: 8px; }

/* ════════════════════════════════════════════════════════
   RESPONSIVE SUPPLEMENTS
════════════════════════════════════════════════════════ */
@media (max-width: 960px) {
  .blog-layout,.post-layout { grid-template-columns: 1fr; gap: 40px; }
  .post-sidebar { display: none; }
  .post-cover img { height: 280px; }
  .related-posts-grid { grid-template-columns: 1fr 1fr; }
  .noiatar-checkout-layout { grid-template-columns: 1fr; }
  .checkout-fields-col { padding: 32px 20px; }
  .checkout-summary-col { padding: 28px 20px; border-left: none; border-top: 1px solid rgba(200,170,130,0.08); }
  .myaccount-layout { grid-template-columns: 1fr; }
  .myaccount-sidebar { display: none; }
  .myaccount-main { padding: 28px 20px; }
  .myaccount-stats { grid-template-columns: repeat(3,1fr); }
  .about-grid { grid-template-columns: 1fr; }
  .about-left { min-height: 320px; }
  .about-right { padding: 40px 24px; }
  .about-values { grid-template-columns: 1fr 1fr; }
  .kkk-layout { grid-template-columns: 1fr; }
  .kkk-sidebar-nav { display: none; }
  .reviews-stats-row { grid-template-columns: 1fr; gap: 20px; }
  .reviews-grid { grid-template-columns: 1fr; }
  .order-received-meta { grid-template-columns: repeat(2,1fr); }
  .order-steps-grid { grid-template-columns: 1fr; }
  .myaccount-address-overview { grid-template-columns: 1fr; }
  .myaccount-fields-grid { grid-template-columns: 1fr; }
  .noiatar-checkout-form .form-row-first,.noiatar-checkout-form .form-row-last { float: none; width: 100%; }
  .comment-fields-row { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .post-card { grid-template-columns: 1fr; }
  .post-card-image { height: 180px; }
  .related-posts-grid { grid-template-columns: 1fr; }
  .myaccount-stats { grid-template-columns: 1fr 1fr; }
  .about-values { grid-template-columns: 1fr; }
  .error-wrap { padding: 32px 16px; }
}

/* ════════════════════════════════════════════════════════
   LEHE LAIUSE FIX — eemaldab kõik välised wrapper-id
   mis piiravad sisu ~500px kastiks
════════════════════════════════════════════════════════ */

/* WP admin bar kompensatsioon */
html { margin-top: 0 !important; }
body.admin-bar { margin-top: 0 !important; }
body.admin-bar .site-header { top: 32px; }
@media screen and (max-width: 782px) {
  body.admin-bar .site-header { top: 46px; }
}

/* Elementor page wrapper — täislaiuseks */
.elementor-page .elementor,
.elementor-page .elementor-section-wrap,
.e-con-inner,
.elementor-container {
  max-width: none !important;
  width: 100% !important;
}

/* Kõik WP ja plugin wrapper-id täislaiuseks */
#page,
#content,
#primary,
.site,
.site-content,
.content-area,
.col-full,
div[class*="wp-container"],
div[id*="wp-container"] {
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
}

/* Body ei tohi olla hall — alati obsidian */
html, body {
  background: var(--obsidian) !important;
  min-height: 100vh;
}

/* ════════════════════════════════════════════════════════
   TÄISLAIUSE FIX v2 — WC 10.x + kõik pluginad
   Eemaldab kõik võimalikud kitsendavad wrapper-id
════════════════════════════════════════════════════════ */
html { margin-top: 0 !important; background: #110D10 !important; }
body { background: #110D10 !important; max-width: none !important; width: 100% !important; }

/* Admin bar kompensatsioon */
body.admin-bar .site-header { top: 32px !important; }
@media screen and (max-width: 782px) {
  body.admin-bar .site-header { top: 46px !important; }
}

/* Kõik tuntud WP/WC/plugin wrapper-id */
.site, .site-content, #page, #content, #primary, #secondary,
.col-full, .col-left, .col-right,
.woocommerce, .woocommerce-page .woocommerce,
.content-area, .widget-area,
div.woocommerce,
#woocommerce_before_main_content,
.woocommerce-notices-wrapper,
.entry-content, .entry, .post,
div[class*="wp-container-"],
div[id*="wp-container-"] {
  max-width: none !important;
  width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  float: none !important;
  box-sizing: border-box !important;
}

/* WP Fastest Cache ei lisa valget tausta */
#page-wrap, #wrapper, .page-wrapper, #outer-wrapper {
  background: #110D10 !important;
  max-width: none !important;
  width: 100% !important;
}

/* Jetpack ei piira laiust */
.jp-relatedposts, .jetpack-related-posts { max-width: none !important; }

/* ════════════════════════════════════════════════════════
   PAGE HERO — siselehtede päis
════════════════════════════════════════════════════════ */
.page-hero {
  background: var(--deep-plum);
  padding: calc(var(--nav-height) + 48px) var(--space-lg) 48px;
  border-bottom: 1px solid rgba(200,170,130,0.08);
  margin-top: 0;
}
.page-hero .container { max-width: var(--container); margin: 0 auto; padding: 0 var(--space-lg); }
.hero-h { font-family: var(--serif); font-size: clamp(28px, 4vw, 52px); font-weight: 300; color: var(--ivory); line-height: 1.15; margin-bottom: 10px; }
.hero-h em { font-style: italic; color: var(--champagne); }
.hero-sub { font-size: 15px; color: var(--smoke); font-weight: 300; line-height: 1.7; max-width: 520px; }

/* Minust — peida WP automaatne pealkiri */
body.page-template-page-minust .page-title,
body.page-template-page-minust .entry-title,
body.page-template-page-minust h1.page-title { display: none !important; }

/* About grid — nav-i kompensatsioon */
.about-grid { margin-top: var(--nav-height); }

/* KKK sidebar nav lingid */
.kkk-nav-link { text-decoration: none; display: block; }

/* Üldine page sisu — nav kompensatsioon */
.page-content { padding-top: var(--nav-height); }
.page-content .container { padding-top: 48px; padding-bottom: 72px; }
.page-header { padding-top: 8px; }

/* ════════════════════════════════════════════════════════
   TEENUSED LEHT
════════════════════════════════════════════════════════ */
.services-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-bottom: 36px; }
.service-card { background: var(--deep-plum); padding: 32px 28px; display: flex; flex-direction: column; position: relative; }
.service-card--featured { background: var(--velvet); }
.service-card-badge { position: absolute; top: -1px; left: 50%; transform: translateX(-50%); background: var(--champagne); color: var(--obsidian); font-size: 9px; font-weight: 500; letter-spacing: .12em; text-transform: uppercase; padding: 4px 14px; white-space: nowrap; }
.service-card-num { font-family: var(--serif); font-size: 13px; color: var(--champagne); opacity: .4; margin-bottom: 6px; letter-spacing: .1em; }
.service-card-tag { font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--champagne); margin-bottom: 14px; }
.service-card-title { font-family: var(--serif); font-size: 28px; font-weight: 300; color: var(--ivory); margin-bottom: 14px; line-height: 1.2; }
.service-card-desc { font-size: 14px; color: var(--smoke); line-height: 1.75; font-weight: 300; margin-bottom: 20px; }
.service-card-list { list-style: none; margin-bottom: 24px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.service-card-list li { font-size: 13px; color: var(--smoke); font-weight: 300; padding-left: 16px; position: relative; line-height: 1.5; }
.service-card-list li::before { content: '·'; position: absolute; left: 0; color: var(--champagne); }
.service-card-price { font-family: var(--serif); font-size: 36px; font-weight: 300; color: var(--champagne); margin-bottom: 20px; line-height: 1; }
.service-card-unit { font-size: 16px; color: var(--rose); }
.service-card-btn { display: inline-flex; align-items: center; padding: 12px 24px; background: transparent; border: 1px solid var(--mauve); color: var(--champagne); font-family: var(--sans); font-size: 11px; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; text-decoration: none; transition: all .25s; align-self: flex-start; }
.service-card-btn:hover { border-color: var(--champagne); background: var(--champagne); color: var(--obsidian); }
.services-faq-cta { text-align: center; padding: 20px 0; font-size: 14px; color: var(--smoke); }
.services-faq-cta a { color: var(--champagne); text-decoration: none; }
.services-process-section { background: var(--deep-plum); padding: 72px 0; border-top: 1px solid rgba(200,170,130,.08); }
.section-title-h2 { font-family: var(--serif); font-size: clamp(28px,3vw,44px); font-weight: 300; color: var(--ivory); margin-bottom: 40px; line-height: 1.15; }
.section-title-h2 em { font-style: italic; color: var(--champagne); }
.services-cta-section { background: var(--obsidian); border-top: 1px solid rgba(200,170,130,.08); }

/* ════════════════════════════════════════════════════════
   KONTAKT LEHT
════════════════════════════════════════════════════════ */
.contact-layout { display: grid; grid-template-columns: 1fr 380px; min-height: 60vh; }
.contact-form-col { background: var(--obsidian); padding: 56px 64px; }
.contact-info-col { background: var(--deep-plum); padding: 56px 48px; border-left: 1px solid rgba(200,170,130,.08); }
.contact-form-title { font-family: var(--serif); font-size: 28px; font-weight: 300; color: var(--ivory); margin-bottom: 28px; line-height: 1.2; }
.contact-form-title em { font-style: italic; color: var(--champagne); }
.contact-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.contact-success { background: rgba(59,109,17,.15); border: 1px solid rgba(59,109,17,.28); color: #8BC96A; padding: 14px 18px; margin-bottom: 20px; font-size: 13px; }
.contact-info-block { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 24px; }
.contact-info-icon { width: 36px; height: 36px; background: var(--velvet); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 14px; color: var(--champagne); flex-shrink: 0; }
.contact-info-label { font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--smoke); margin-bottom: 3px; }
.contact-info-val { font-size: 14px; color: var(--pearl); }
.contact-info-val a { color: var(--champagne); text-decoration: none; }

/* ════════════════════════════════════════════════════════
   LEGAL LEHED (müügitingimused, privaatsus)
════════════════════════════════════════════════════════ */
.legal-content { max-width: 760px; padding: 56px 0 80px; }
.legal-section { margin-bottom: 40px; }
.legal-section h2 { font-family: var(--sans); font-size: 16px; font-weight: 500; color: var(--ivory); margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid rgba(200,170,130,.09); letter-spacing: .04em; text-transform: uppercase; }
.legal-section p { font-size: 15px; color: var(--smoke); line-height: 1.8; font-weight: 300; margin-bottom: 12px; font-family: var(--sans); }
.legal-section ul { padding-left: 20px; margin-bottom: 12px; }
.legal-section ul li { font-size: 15px; color: var(--smoke); line-height: 1.7; font-weight: 300; margin-bottom: 6px; font-family: var(--sans); }
.legal-section a { color: var(--champagne); }
.legal-section strong { color: var(--pearl); font-weight: 500; }

/* ════════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════════ */
@media (max-width: 960px) {
  .services-grid { grid-template-columns: 1fr; }
  .service-card--featured { order: -1; }
  .contact-layout { grid-template-columns: 1fr; }
  .contact-form-col { padding: 36px 20px; }
  .contact-info-col { padding: 36px 20px; border-left: none; border-top: 1px solid rgba(200,170,130,.08); }
  .contact-form-grid { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════
   MOBIIL BOTTOM NAV + DRAWER
════════════════════════════════════════════════════════ */
@media (min-width: 901px) {
  .mob-overlay,.mob-drawer,.mob-bottom-nav { display: none !important; }
}

@media (max-width: 900px) {
  body { padding-bottom: calc(64px + env(safe-area-inset-bottom,0px)) !important; }

  .mob-overlay {
    display: none; position: fixed; inset: 0; z-index: 398;
    background: rgba(0,0,0,0.72);
  }
  .mob-overlay.open { display: block; }

  .mob-drawer {
    position: fixed; top: 0; right: 0; bottom: 0; z-index: 399;
    width: min(320px,88vw);
    background: #1E1520;
    transform: translateX(100%);
    transition: transform 0.32s cubic-bezier(0.4,0,0.2,1);
    display: flex; flex-direction: column; overflow-y: auto;
  }
  .mob-drawer.open { transform: translateX(0); }

  .mob-drawer__head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 20px 22px; border-bottom: 1px solid rgba(200,170,130,.1); flex-shrink: 0;
  }
  .mob-drawer__logo {
    font-family: 'Cormorant Garamond',Georgia,serif;
    font-size: 17px; font-weight: 500; letter-spacing: .18em;
    color: #C8AA82; text-transform: uppercase; text-decoration: none;
  }
  .mob-drawer__close {
    background: none; border: none; color: #9A8A90; cursor: pointer;
    width: 40px; height: 40px; display: flex; align-items: center; justify-content: center;
  }
  .mob-drawer__user {
    display: flex; align-items: center; gap: 12px;
    padding: 18px 22px; border-bottom: 1px solid rgba(200,170,130,.1); flex-shrink: 0;
  }
  .mob-drawer__avatar {
    width: 42px; height: 42px; border-radius: 50%; background: #2A1E28;
    display: flex; align-items: center; justify-content: center;
    font-family: 'Cormorant Garamond',Georgia,serif; font-size: 17px; color: #C8AA82; flex-shrink: 0;
  }
  .mob-drawer__user-name { font-size: 15px; color: #E8DDD0; font-family: 'Cormorant Garamond',Georgia,serif; font-weight: 300; }
  .mob-drawer__user-email { font-size: 12px; color: #9A8A90; }
  .mob-drawer__nav { flex: 1; padding: 8px 0; }
  .mob-drawer__link {
    display: flex; align-items: center; gap: 14px; width: 100%;
    padding: 14px 22px; font-size: 14px; color: #9A8A90;
    background: none; border: none; cursor: pointer;
    font-family: 'DM Sans',system-ui,sans-serif;
    text-decoration: none; text-align: left; min-height: 48px;
    -webkit-tap-highlight-color: transparent; transition: color .15s, background .15s;
  }
  .mob-drawer__link:active { background: rgba(200,170,130,.07); color: #E8DDD0; }
  .mob-drawer__icon {
    font-family: 'Cormorant Garamond',Georgia,serif; font-size: 14px;
    color: #C8AA82; width: 20px; text-align: center; flex-shrink: 0;
  }
  .mob-drawer__divider { height: 1px; background: rgba(200,170,130,.08); margin: 4px 22px; }
  .mob-drawer__cta { padding: 18px 22px; border-top: 1px solid rgba(200,170,130,.1); flex-shrink: 0; }
  .mob-drawer__cta-btn {
    display: flex; align-items: center; justify-content: center; width: 100%;
    padding: 14px; background: #C8AA82; color: #110D10;
    font-family: 'DM Sans',system-ui,sans-serif; font-size: 11px; font-weight: 500;
    letter-spacing: .16em; text-transform: uppercase; text-decoration: none;
    border: none; cursor: pointer; min-height: 48px;
  }

  /* ── BOTTOM NAV ── */
  .mob-bottom-nav {
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 300;
    height: calc(64px + env(safe-area-inset-bottom,0px));
    padding-bottom: env(safe-area-inset-bottom,0px);
    background: rgba(30,21,32,.98);
    border-top: 1px solid rgba(200,170,130,.1);
    display: grid; grid-template-columns: repeat(5,1fr);
  }
  .mob-bnav {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 4px; color: #9A8A90; text-decoration: none;
    background: none; border: none; cursor: pointer;
    font-family: 'DM Sans',system-ui,sans-serif; padding: 0;
    transition: color .18s; -webkit-tap-highlight-color: transparent;
    height: 64px;
  }
  .mob-bnav span { font-size: 10px; letter-spacing: .04em; text-transform: uppercase; line-height: 1; }
  .mob-bnav--on { color: #C8AA82; }
  .mob-bnav--cta { color: #C8AA82; position: relative; }
  .mob-bnav-ring {
    width: 46px; height: 46px; border-radius: 50%;
    background: #C8AA82;
    display: flex; align-items: center; justify-content: center;
    margin-top: -20px;
    box-shadow: 0 0 0 5px rgba(30,21,32,.98);
  }
  .mob-bnav:active { opacity: .7; }
}

/* ════════════════════════════════════════════════════════
   MOBIIL KRIITILISED FIXID — horisontaalne scroll + header
════════════════════════════════════════════════════════ */

/* Globaalne horisontaalne scroll fix */
html, body {
  overflow-x: hidden !important;
  max-width: 100vw !important;
}

* { box-sizing: border-box; }

@media (max-width: 900px) {

  /* Header mobiilis */
  .site-header {
    padding: 0 16px !important;
    grid-template-columns: auto 1fr !important;
    height: 56px !important;
  }

  /* Logo väiksemaks */
  .site-logo { font-size: 16px !important; }
  .site-logo__sub { font-size: 9px !important; }

  /* Peidetud desktop elemendid */
  .nav-primary-wrap { display: none !important; }
  .btn-nav-login, .btn-nav-register { display: none !important; }

  /* Nav right — ainult cart + hamburger */
  .nav-right {
    justify-content: flex-end !important;
    gap: 6px !important;
  }

  /* Hamburger nähtav */
  .nav-hamburger { display: flex !important; }

  /* Hero mobiilis */
  .hero {
    grid-template-columns: 1fr !important;
    min-height: 100svh !important;
    position: relative;
  }
  .hero__image {
    position: absolute !important;
    inset: 0 !important;
    height: 100% !important;
    max-height: none !important;
  }
  .hero__image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center 15% !important;
  }
  .hero__image-overlay {
    background: linear-gradient(to bottom,
      rgba(17,13,16,0.2) 0%,
      rgba(17,13,16,0.5) 50%,
      rgba(17,13,16,0.95) 100%) !important;
  }
  .hero__content {
    position: relative !important;
    z-index: 2 !important;
    padding: calc(var(--nav-height) + 40vh) 20px 100px !important;
    background: transparent !important;
    grid-column: 1 !important;
  }

  /* Konteiner täislaiuseks */
  .container {
    padding-left: 20px !important;
    padding-right: 20px !important;
    max-width: 100% !important;
  }

  /* Section padding */
  .section { padding-left: 20px !important; padding-right: 20px !important; }

  /* Minust leht */
  .about-grid {
    grid-template-columns: 1fr !important;
    margin-top: 56px !important;
  }
  .about-left { min-height: 60vw !important; max-height: 80vw !important; }
  .about-right { padding: 32px 20px 100px !important; }

  /* Footer */
  .footer-grid {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  .site-footer { padding: 48px 20px 32px !important; }
  .footer-bottom {
    flex-direction: column !important;
    gap: 8px !important;
    text-align: center !important;
  }

  /* Teenuste grid */
  .services-grid { grid-template-columns: 1fr !important; }

  /* Process grid */
  .process-grid { grid-template-columns: 1fr 1fr !important; }

  /* Kontakt */
  .contact-layout { grid-template-columns: 1fr !important; }
  .contact-form-col, .contact-info-col { padding: 32px 20px !important; }

  /* Legal */
  .legal-content { padding: 32px 0 60px !important; }

  /* Checkout */
  .noiatar-checkout-layout { grid-template-columns: 1fr !important; }
  .checkout-fields-col { padding: 24px 20px !important; }
  .checkout-summary-col { padding: 24px 20px !important; }

  /* Minu konto */
  .myaccount-layout { grid-template-columns: 1fr !important; }
  .myaccount-sidebar { display: none !important; }
  .myaccount-main { padding: 24px 20px !important; }

  /* KKK */
  .kkk-layout { grid-template-columns: 1fr !important; }
  .kkk-sidebar-nav { display: none !important; }

  /* Tagasiside */
  .reviews-stats-row { grid-template-columns: 1fr !important; }
  .reviews-grid { grid-template-columns: 1fr !important; }

  /* Poe tooted */
  ul.products, .products-grid {
    grid-template-columns: 1fr 1fr !important;
    padding: 0 !important;
  }

  /* Üksik toode */
  .single-product-layout {
    grid-template-columns: 1fr !important;
    padding: 20px !important;
  }

  /* Checkout form row */
  .noiatar-checkout-form .form-row-first,
  .noiatar-checkout-form .form-row-last {
    float: none !important;
    width: 100% !important;
  }
}

@media (max-width: 480px) {
  ul.products, .products-grid {
    grid-template-columns: 1fr !important;
  }
  .process-grid { grid-template-columns: 1fr !important; }
  .myaccount-stats { grid-template-columns: 1fr 1fr !important; }
  .order-received-meta { grid-template-columns: 1fr 1fr !important; }
  .order-steps-grid { grid-template-columns: 1fr !important; }
}

/* ════════════════════════════════════════════════════════
   MOBIIL HEADER — sticky fix + hamburger/cart peitmine
════════════════════════════════════════════════════════ */
@media (max-width: 900px) {

  /* Header alati sticky ja nähtav */
  .site-header {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 300 !important;
    background: rgba(17,13,16,0.97) !important;
    box-shadow: 0 1px 0 rgba(200,170,130,0.08) !important;
  }

  /* Admin bar kompensatsioon mobiilis */
  body.admin-bar .site-header {
    top: 46px !important;
  }

  /* Peida hamburger — bottom nav-is on Menüü */
  .nav-hamburger { display: none !important; }

  /* Peida cart ikoon — bottom nav-is on Pood */
  .nav-cart-link { display: none !important; }

  /* Peida login/register nupud — drawer-is on olemas */
  .btn-nav-login, .btn-nav-register { display: none !important; }

  /* Nav right — tühi mobiilis */
  .nav-right { gap: 0 !important; }

  /* Header grid — logo vasakul, parem tühi */
  .site-header {
    grid-template-columns: 1fr !important;
  }
}

/* ════════════════════════════════════════════════════════
   AVALEHT — ABOUT + SHOP RESPONSIVE
════════════════════════════════════════════════════════ */

/* About grid */
.fp-about-grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 80px;
  align-items: center;
}
.fp-about-img {
  position: relative;
}

/* Shop grid */
.fp-shop-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
}

@media (max-width: 900px) {
  /* About — foto peale, tekst alla */
  .fp-about-grid {
    grid-template-columns: 1fr !important;
    gap: 0 !important;
  }
  .fp-about-img {
    width: 100%;
    max-height: 60vw;
    overflow: hidden;
    margin-bottom: 32px;
  }
  .fp-about-img img {
    width: 100%;
    height: 60vw;
    object-fit: cover;
    object-position: center 20%;
  }
  .fp-about-img > div { display: none; } /* peida dekoratiivne border */

  /* Shop — 2 kaarti mobiilis */
  .fp-shop-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 2px !important;
  }
}

@media (max-width: 480px) {
  /* Shop — 1 kaart väga väikesel ekraanil */
  .fp-shop-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ── Tähekesed ── */
.product-stars { display: flex; align-items: center; gap: 2px; }
.star--full, .star--half { color: var(--champagne); font-size: 12px; }
.star--empty { color: var(--velvet); font-size: 12px; }
.star-count { font-size: 11px; color: var(--smoke); margin-left: 4px; }

/* ── Toote placeholder ── */
.product-card__placeholder {
  font-family: var(--serif); font-size: 48px;
  color: var(--champagne); opacity: 0.12;
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%;
}

/* ── WC product loop override ── */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(3,1fr) !important;
  gap: 2px !important;
  padding: 32px !important;
  margin: 0 !important;
  list-style: none !important;
}
.woocommerce ul.products li.product {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
}
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(3,1fr) !important;
  gap: 2px !important;
  padding: 32px !important;
  list-style: none !important;
  margin: 0 !important;
}

/* Kategooria arhiiv hero */
.archive-h1 {
  font-family: var(--serif);
  font-size: clamp(32px,4vw,56px);
  font-weight: 300; color: var(--ivory);
  line-height: 1.15; margin-bottom: 8px;
}
.archive-h1 em { font-style: italic; color: var(--champagne); }
.archive-sub { font-size: 15px; color: var(--smoke); font-weight: 300; line-height: 1.7; max-width: 520px; margin-top: 10px; }

/* Filter bar paremale */
.filter-right { margin-left: auto; }

@media (max-width: 900px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: 1fr 1fr !important;
    padding: 20px !important;
  }
  .products-grid {
    grid-template-columns: 1fr 1fr !important;
    padding: 20px !important;
  }
}
@media (max-width: 480px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products,
  .products-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ════════════════════════════════════════════════════════
   POOD — täielik disain mockupi järgi
════════════════════════════════════════════════════════ */

/* Hero */
.shop-hero {
  background: var(--deep-plum);
  padding: calc(var(--nav-height) + 48px) 0 44px;
  border-bottom: 1px solid rgba(200,170,130,.08);
}
.shop-hero-title {
  font-family: var(--serif);
  font-size: clamp(36px, 5vw, 64px);
  font-weight: 300; color: var(--ivory);
  line-height: 1.1; margin-bottom: 10px;
}
.shop-hero-title em { font-style: italic; color: var(--champagne); }
.shop-hero-sub { font-size: 15px; color: var(--smoke); font-weight: 300; line-height: 1.7; max-width: 480px; }

/* Filter bar */
.shop-filter-bar {
  background: var(--velvet);
  border-bottom: 1px solid rgba(200,170,130,.08);
  position: sticky; top: var(--nav-height); z-index: 100;
}
.shop-filter-inner {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 14px; padding-bottom: 14px; flex-wrap: wrap; gap: 10px;
}
.shop-filter-cats { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.shop-filter-label {
  font-size: 10px; letter-spacing: .16em; text-transform: uppercase;
  color: var(--smoke); margin-right: 6px; white-space: nowrap;
}
.shop-filter-pill {
  display: inline-flex; align-items: center;
  padding: 7px 16px;
  border: 1px solid rgba(200,170,130,.16);
  background: none; color: var(--smoke);
  font-family: var(--sans); font-size: 12px;
  text-decoration: none; transition: all .2s;
  white-space: nowrap; cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.shop-filter-pill:hover { border-color: var(--champagne); color: var(--champagne); }
.shop-filter-pill.active { background: var(--champagne); color: var(--obsidian); border-color: var(--champagne); }
.shop-sort-select {
  background: var(--deep-plum); border: 1px solid rgba(200,170,130,.16);
  color: var(--smoke); font-family: var(--sans); font-size: 12px;
  padding: 7px 28px 7px 12px; cursor: pointer; outline: none;
  -webkit-appearance: none; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239A8A90' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 10px center;
}

/* Products wrap */
.shop-products-wrap { padding: 0; }

/* Grid */
.shop-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  padding: 32px;
}

/* Kaart */
.shop-card {
  background: var(--velvet);
  text-decoration: none;
  display: flex; flex-direction: column;
  transition: background .25s;
  position: relative;
}
.shop-card:hover { background: var(--mauve); }

/* Pilt */
.shop-card-img {
  position: relative; overflow: hidden;
  aspect-ratio: 1 / 1;
  background: var(--deep-plum);
  display: flex; align-items: center; justify-content: center;
}
.shop-card-img img {
  width: 100%; height: 100%; object-fit: cover;
  filter: brightness(.88) saturate(.82);
  transition: transform .6s ease, filter .4s;
  display: block;
}
.shop-card:hover .shop-card-img img {
  transform: scale(1.04);
  filter: brightness(.7) saturate(.7);
}
.shop-card-img-placeholder {
  font-family: var(--serif); font-size: 56px;
  color: var(--champagne); opacity: .1;
}

/* Overlay */
.shop-card-overlay {
  position: absolute; inset: 0;
  background: rgba(17,13,16,.55);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .3s;
}
.shop-card:hover .shop-card-overlay { opacity: 1; }
.shop-card-overlay-text {
  font-family: var(--sans); font-size: 11px;
  font-weight: 500; letter-spacing: .18em;
  text-transform: uppercase; color: var(--champagne);
  border: 1px solid var(--champagne); padding: 10px 22px;
}

/* Badgeid */
.shop-card-badge {
  position: absolute; top: 14px; left: 14px;
  font-size: 9px; font-weight: 500; letter-spacing: .12em;
  text-transform: uppercase; padding: 4px 10px; z-index: 2;
}
.shop-card-badge--sale    { background: var(--champagne); color: var(--obsidian); }
.shop-card-badge--new     { background: var(--rose); color: var(--ivory); }
.shop-card-badge--digital { background: var(--velvet); color: var(--champagne); border: 1px solid rgba(200,170,130,.3); top: auto; bottom: 14px; left: 14px; }

/* Info */
.shop-card-info { padding: 20px 22px 24px; display: flex; flex-direction: column; flex: 1; }
.shop-card-cat {
  font-size: 10px; letter-spacing: .16em; text-transform: uppercase;
  color: var(--rose); margin-bottom: 6px;
}
.shop-card-title {
  font-family: var(--serif); font-size: 20px; font-weight: 300;
  color: var(--ivory); margin-bottom: 8px; line-height: 1.2;
}
.shop-card-rating { display: flex; align-items: center; gap: 6px; margin-bottom: 8px; }
.shop-card-stars { display: flex; gap: 2px; }
.shop-card-rev-count { font-size: 11px; color: var(--smoke); }
.shop-card-price {
  font-family: var(--serif); font-size: 22px; font-weight: 300;
  color: var(--champagne); margin-bottom: 14px; flex: 1;
  display: flex; align-items: flex-end;
}
.shop-card-price del { font-size: 15px; color: var(--rose); margin-left: 8px; opacity: .7; }
.shop-card-action {
  display: flex; align-items: center; gap: 8px;
  font-size: 11px; font-weight: 500; letter-spacing: .1em;
  text-transform: uppercase; color: var(--champagne);
  opacity: 0; transform: translateY(4px);
  transition: opacity .25s, transform .25s;
  padding-top: 12px; border-top: 1px solid rgba(200,170,130,.1);
}
.shop-card:hover .shop-card-action { opacity: 1; transform: translateY(0); }

/* Pagination */
.shop-pagination {
  padding: 40px var(--space-lg);
  display: flex; justify-content: center;
}
.shop-pagination ul { display: flex; gap: 4px; list-style: none; }
.shop-pagination ul li a,
.shop-pagination ul li span {
  display: flex; align-items: center; justify-content: center;
  min-width: 44px; height: 44px; padding: 0 12px;
  font-size: 13px; color: var(--smoke);
  border: 1px solid rgba(200,170,130,.14);
  text-decoration: none; transition: all .2s;
}
.shop-pagination ul li a:hover { border-color: var(--champagne); color: var(--champagne); }
.shop-pagination ul li span.current { border-color: var(--champagne); color: var(--champagne); }

/* Tühi olek */
.shop-empty {
  text-align: center; padding: 80px var(--space-lg);
}
.shop-empty-sym { font-family: var(--serif); font-size: 64px; color: var(--champagne); opacity: .12; margin-bottom: 20px; }
.shop-empty-title { font-family: var(--serif); font-size: 28px; font-weight: 300; color: var(--ivory); margin-bottom: 10px; }
.shop-empty-text { font-size: 14px; color: var(--smoke); margin-bottom: 24px; font-weight: 300; }

/* ── Responsive ── */
@media (max-width: 900px) {
  .shop-hero { padding: calc(var(--nav-height) + 28px) 0 28px; }
  .shop-filter-bar { position: static; }
  .shop-filter-inner { padding-top: 12px; padding-bottom: 12px; }
  .shop-grid { grid-template-columns: 1fr 1fr; }
  .shop-card-action { opacity: 1; transform: none; }
}
@media (max-width: 480px) {
  .shop-grid { grid-template-columns: 1fr; }
  .shop-card-img { aspect-ratio: 4/3; }
}

/* Shop hero count */
.shop-hero-count {
  font-size: 12px; color: var(--smoke); margin-top: 8px;
  letter-spacing: .08em;
}

/* Shop grid spacing fix */
.shop-products-wrap { padding: 0; }
.shop-grid { padding: 32px !important; gap: 16px !important; }

@media (max-width: 900px) {
  .shop-grid { padding: 16px !important; gap: 10px !important; }
}

/* ════════════════════════════════
   SINGLE PRODUCT STIILID
════════════════════════════════ */
.sp-breadcrumb { padding:16px var(--space-lg); font-size:12px; color:var(--smoke); display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.sp-breadcrumb a { color:var(--smoke); text-decoration:none; }
.sp-breadcrumb a:hover { color:var(--champagne); }
.sp-bc-sep { color:var(--mauve); }

/* Layout */
.sp-layout { display:grid; grid-template-columns:1fr 1fr; min-height:80vh; }

/* Galerii */
.sp-gallery { background:var(--deep-plum); padding:48px; display:flex; flex-direction:column; gap:14px; }
.sp-gallery-main { position:relative; overflow:hidden; background:var(--velvet); }
.sp-gallery-main img { width:100%; height:100%; object-fit:cover; display:block; filter:brightness(.9) saturate(.85); transition:filter .4s; }
.sp-gallery-main img:hover { filter:brightness(1) saturate(1); }
.sp-gallery-ph { aspect-ratio:1/1; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:80px; color:var(--champagne); opacity:.1; }
.sp-badge { position:absolute; top:16px; left:16px; font-size:9px; font-weight:500; letter-spacing:.12em; text-transform:uppercase; padding:5px 12px; z-index:2; }
.sp-badge--sale { background:var(--champagne); color:var(--obsidian); }
.sp-badge--digital { background:var(--velvet); color:var(--champagne); border:1px solid rgba(200,170,130,.3); }
.sp-photo-credit { position:absolute; bottom:10px; right:12px; font-size:10px; color:rgba(200,170,130,.35); letter-spacing:.06em; }

/* Pisipildid */
.sp-thumbs { display:flex; gap:6px; flex-wrap:wrap; }
.sp-thumb { width:72px; height:72px; overflow:hidden; border:2px solid transparent; cursor:pointer; background:none; padding:0; transition:border-color .2s; flex-shrink:0; }
.sp-thumb img { width:100%; height:100%; object-fit:cover; filter:brightness(.65); transition:filter .2s; }
.sp-thumb.active, .sp-thumb:hover { border-color:var(--champagne); }
.sp-thumb.active img, .sp-thumb:hover img { filter:brightness(1); }

/* Info */
.sp-info { background:var(--obsidian); padding:52px 56px; display:flex; flex-direction:column; }
.sp-cat { font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--champagne); margin-bottom:16px; display:flex; align-items:center; gap:10px; }
.sp-cat::before { content:''; width:18px; height:1px; background:var(--champagne); flex-shrink:0; }
.sp-cat a { color:inherit; text-decoration:none; }
.sp-title { font-family:var(--serif); font-size:clamp(28px,3.5vw,48px); font-weight:300; color:var(--ivory); line-height:1.15; margin-bottom:16px; }
.sp-title em { font-style:italic; color:var(--champagne); }

/* Rating */
.sp-rating { display:flex; align-items:center; gap:10px; margin-bottom:22px; font-size:13px; }
.sp-stars { display:flex; gap:2px; }
.sp-rating-count { color:var(--smoke); }
.sp-rating-link { color:var(--champagne); text-decoration:none; }

/* Hind */
.sp-price { font-family:var(--serif); font-size:44px; font-weight:300; color:var(--champagne); line-height:1; margin-bottom:6px; }
.sp-price del { font-size:22px; color:var(--rose); opacity:.7; margin-left:10px; }
.sp-price ins { text-decoration:none; }
.sp-price-note { font-size:12px; color:var(--smoke); letter-spacing:.06em; margin-bottom:24px; }

/* Lühikirjeldus */
.sp-short-desc { font-size:15px; color:var(--smoke); line-height:1.8; font-weight:300; margin-bottom:24px; padding-bottom:20px; border-bottom:1px solid rgba(200,170,130,.08); }

/* Variandid */
.sp-var-group { margin-bottom:20px; }
.sp-var-label { font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--smoke); margin-bottom:10px; }
.sp-var-pills { display:flex; gap:8px; flex-wrap:wrap; }
.sp-var-pill { cursor:pointer; }
.sp-var-pill input { display:none; }
.sp-var-pill span { display:inline-flex; align-items:center; height:40px; padding:0 20px; border:1px solid rgba(200,170,130,.2); font-family:var(--sans); font-size:13px; color:var(--smoke); transition:all .2s; white-space:nowrap; }
.sp-var-pill.active span, .sp-var-pill input:checked + span { background:var(--champagne); color:var(--obsidian); border-color:var(--champagne); }
.sp-var-pill:hover span { border-color:var(--champagne); color:var(--champagne); }

/* Ostukorv */
.sp-form { margin-bottom:20px; }
.sp-action-row { display:flex; gap:10px; align-items:center; }
.sp-qty { display:flex; align-items:center; border:1px solid rgba(200,170,130,.18); flex-shrink:0; height:52px; }
.sp-qty-btn { width:44px; height:100%; background:none; border:none; color:var(--champagne); font-size:22px; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .2s; }
.sp-qty-btn:hover { background:rgba(200,170,130,.1); }
.sp-qty-inp { width:52px; height:100%; background:none; border:none; border-left:1px solid rgba(200,170,130,.12); border-right:1px solid rgba(200,170,130,.12); text-align:center; color:var(--pearl); font-family:var(--serif); font-size:18px; font-weight:300; outline:none; -moz-appearance:textfield; }
.sp-qty-inp::-webkit-inner-spin-button, .sp-qty-inp::-webkit-outer-spin-button { -webkit-appearance:none; }
.sp-add-btn { flex:1; height:52px; background:var(--champagne); color:var(--obsidian); border:none; font-family:var(--sans); font-size:11px; font-weight:500; letter-spacing:.18em; text-transform:uppercase; cursor:pointer; display:flex; align-items:center; justify-content:center; gap:10px; transition:background .2s; }
.sp-add-btn:hover { background:var(--pearl); }
.sp-wishlist-btn { width:52px; height:52px; background:none; border:1px solid rgba(200,170,130,.2); color:var(--smoke); cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all .2s; }
.sp-wishlist-btn:hover { border-color:var(--champagne); color:var(--champagne); }
.sp-out-stock { font-size:13px; color:var(--smoke); padding:14px; border:1px solid rgba(200,170,130,.1); }

/* Usaldus */
.sp-trust { display:flex; flex-direction:column; gap:9px; margin-top:4px; padding-top:20px; border-top:1px solid rgba(200,170,130,.08); }
.sp-trust-item { display:flex; align-items:center; gap:10px; font-size:13px; color:var(--smoke); font-weight:300; }
.sp-trust-check { color:var(--champagne); font-size:10px; flex-shrink:0; }

/* ── TABS ── */
.sp-tabs-section { border-top:1px solid rgba(200,170,130,.08); background:var(--obsidian); }
.sp-tabs-nav { display:flex; gap:0; border-bottom:1px solid rgba(200,170,130,.12); padding:0 56px; }
.sp-tab-btn { padding:18px 28px; background:none; border:none; border-bottom:2px solid transparent; color:var(--smoke); font-family:var(--sans); font-size:12px; font-weight:500; letter-spacing:.1em; text-transform:uppercase; cursor:pointer; transition:all .2s; margin-bottom:-1px; }
.sp-tab-btn:hover { color:var(--pearl); }
.sp-tab-btn.active { color:var(--champagne); border-bottom-color:var(--champagne); }
.sp-tab-content { display:none; }
.sp-tab-content.active { display:block; }
.sp-tab-inner { max-width:none; padding:40px 56px 64px; }
.sp-desc-body { font-size:15px; color:var(--smoke); line-height:1.9; font-weight:300; }
.sp-desc-body p { margin-bottom:16px; }

/* How it works */
.sp-how-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; }
.sp-how-step { background:var(--deep-plum); padding:28px 24px; }
.sp-how-num { font-family:var(--serif); font-size:36px; font-weight:300; color:var(--champagne); opacity:.2; margin-bottom:12px; line-height:1; }
.sp-how-title { font-size:14px; color:var(--pearl); margin-bottom:8px; font-weight:400; }
.sp-how-text { font-size:13px; color:var(--smoke); line-height:1.6; font-weight:300; }

/* Related */
.sp-related { padding:64px 0; background:var(--deep-plum); border-top:1px solid rgba(200,170,130,.08); }
.sp-related-title { font-family:var(--serif); font-size:clamp(26px,3vw,40px); font-weight:300; color:var(--ivory); margin-bottom:32px; line-height:1.2; }
.sp-related-title em { font-style:italic; color:var(--champagne); }
.sp-related-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; }

/* ── RESPONSIVE ── */
@media (max-width:768px) {
  .sp-layout { grid-template-columns:1fr; }
  .sp-gallery { padding:24px 20px; }
  .sp-info { padding:28px 20px; }
  .sp-how-steps { grid-template-columns:1fr 1fr; }
  .sp-related-grid { grid-template-columns:1fr 1fr; }
  .sp-tabs-nav { padding:0 20px; overflow-x:auto; }
  .sp-tab-btn { white-space:nowrap; padding:14px 20px; }
  .sp-tab-inner { padding:32px 20px 48px; }
  .sp-action-row { flex-wrap:wrap; }
  .sp-add-btn { min-height:52px; }
}
@media (max-width:480px) {
  .sp-how-steps { grid-template-columns:1fr; }
  .sp-related-grid { grid-template-columns:1fr 1fr; }
}

/* ── SP layout täpsustused ── */
.sp-layout { align-items: start; }
.sp-gallery { position: sticky; top: var(--nav-height); max-height: calc(100vh - var(--nav-height)); overflow: hidden; }
.sp-gallery-main { aspect-ratio: 3/4; }
.sp-gallery-main img { width: 100%; height: 100%; object-fit: cover; object-position: center 15%; }
.sp-desc-body { white-space: pre-line; }

/* Foto puudumisel placeholder suurem */
.sp-gallery-ph { aspect-ratio: 3/4; min-height: 400px; }

/* Nimi väiketähed */
.sp-title { text-transform: none !important; }

/* ── SP täpsustused v2 ── */

/* Galerii — portrait kuvasuhe nagu mockupis */
.sp-gallery { padding: 0; background: var(--deep-plum); }
.sp-gallery-main { aspect-ratio: unset; height: 600px; }
.sp-gallery-main img { object-position: center 20%; }
.sp-gallery-ph { height: 600px; aspect-ratio: unset; }
.sp-thumbs { padding: 8px; background: var(--deep-plum); gap: 8px; }

/* Info padding */
.sp-info { padding: 48px 52px; }

/* Hind ilma komakohata kui täisarv */
.sp-price .woocommerce-Price-amount { font-family: var(--serif); }

/* Tabs — täislaius aga piiratud container */
.sp-tabs-section { background: var(--obsidian); }
.sp-tabs-nav { padding: 0 52px; margin: 0; }
.sp-tab-inner { padding: 40px 52px 64px; max-width: 800px; }

/* Kirjeldus */
.sp-desc-body { font-size: 14px; line-height: 1.85; white-space: normal; }

/* Variant pills kompaktsemad */
.sp-var-pill span { height: 36px; padding: 0 16px; font-size: 13px; }

/* Usaldus ikoon */
.sp-trust-check { color: var(--champagne); font-size: 8px; }

/* Related grid */
.sp-related { padding: 56px 0; }

@media (max-width: 768px) {
  .sp-gallery-main { height: 56vw; }
  .sp-gallery-ph { height: 56vw; }
  .sp-info { padding: 28px 20px; }
  .sp-tabs-nav { padding: 0 20px; }
  .sp-tab-inner { padding: 28px 20px 48px; }
}

/* ══════════════════════════════════════════════════════════
   LISAVÄLJAD: tekstiväljad, konditsionaalsed, küsimused, note
══════════════════════════════════════════════════════════ */

.sp-field-group {
  margin-bottom: 20px;
}

.sp-field-label {
  display: block;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--smoke);
  margin-bottom: 8px;
  font-weight: 400;
  font-family: var(--sans);
}

.sp-field-req {
  color: var(--rose-dusk);
}

.sp-field-input,
.sp-field-textarea {
  width: 100%;
  background: var(--deep-plum);
  border: 1px solid rgba(200,170,130,0.18);
  color: var(--pearl);
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 300;
  padding: 13px 16px;
  outline: none;
  border-radius: 0;
  transition: border-color 0.25s;
  -webkit-appearance: none;
  appearance: none;
}

.sp-field-input:focus,
.sp-field-textarea:focus {
  border-color: var(--champagne);
}

.sp-field-input::placeholder,
.sp-field-textarea::placeholder {
  color: var(--rose-dusk);
  opacity: 0.65;
}

.sp-field-textarea {
  resize: vertical;
  min-height: 100px;
  line-height: 1.65;
}

/* Konditsionaalne väli — pehme ilmumine */
.sp-conditional-field {
  transition: opacity 0.2s;
}
.sp-conditional-field[style*="display:none"],
.sp-conditional-field[style*="display: none"] {
  opacity: 0;
}

/* Infobox (note) */
.sp-field-note {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: var(--velvet);
  border: 1px solid rgba(200,170,130,0.12);
  padding: 16px 18px;
  margin-bottom: 20px;
  font-size: 13px;
  color: var(--smoke);
  line-height: 1.65;
  font-weight: 300;
}

.sp-field-note p { margin: 0; }

.sp-field-note-icon {
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 1px;
  color: var(--champagne);
}

/* Koguse-küsimuste kontainer — visuaalne eraldaja ülalt */
.sp-questions-container {
  margin-bottom: 4px;
}

.sp-questions-container .sp-field-group {
  margin-bottom: 14px;
}


/* ============================================================
   SINGLE PRODUCT — mockup layout override (noiatar_shop_pages.html)
   ============================================================ */
body.single-product .site-main {
  background: var(--obsidian);
}

body.single-product .sp-breadcrumb {
  padding: 24px 48px 0;
  max-width: 1296px;
  margin: 0 auto;
  font-size: 11px;
  color: var(--smoke);
  letter-spacing: .06em;
  display: flex;
  gap: 8px;
  align-items: center;
}

body.single-product .sp-breadcrumb a {
  color: var(--smoke);
  text-decoration: none;
  transition: color .3s;
}

body.single-product .sp-breadcrumb a:hover { color: var(--champagne); }
body.single-product .sp-bc-sep { color: var(--rose-dusk); }

body.single-product .sp-single-wrap {
  padding: 0 48px 80px;
  max-width: 1296px;
  margin: 0 auto;
}

body.single-product .sp-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 64px;
  padding-top: 40px;
  min-height: 0;
  align-items: start;
}

body.single-product .sp-gallery {
  position: static;
  max-height: none;
  overflow: visible;
  padding: 0;
  background: transparent;
  display: block;
}

body.single-product .sp-gallery-main {
  aspect-ratio: 1 / 1;
  height: auto;
  overflow: hidden;
  background: var(--velvet);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

body.single-product .sp-gallery-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: brightness(.88) saturate(.82);
  transition: transform .6s ease, filter .4s ease;
}

body.single-product .sp-gallery-main:hover img {
  transform: scale(1.02);
  filter: brightness(.94) saturate(.9);
}

body.single-product .sp-gallery-ph {
  aspect-ratio: 1 / 1;
  height: auto;
  min-height: 0;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--serif);
  font-size: 96px;
  opacity: .12;
  color: var(--champagne);
}

body.single-product .sp-thumbs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  margin-top: 2px;
  padding: 0;
  background: transparent;
}

body.single-product .sp-thumb {
  width: auto;
  height: auto;
  aspect-ratio: 1 / 1;
  background: var(--velvet);
  cursor: pointer;
  border: 2px solid transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

body.single-product .sp-thumb.active,
body.single-product .sp-thumb:hover {
  border-color: var(--champagne);
}

body.single-product .sp-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(.8) saturate(.7);
}

body.single-product .sp-photo-credit {
  right: 14px;
  bottom: 12px;
  background: rgba(17,13,16,.42);
  color: rgba(232,221,208,.72);
  padding: 4px 8px;
  backdrop-filter: blur(6px);
}

body.single-product .sp-info {
  background: transparent;
  padding: 0;
  display: flex;
  flex-direction: column;
}

body.single-product .sp-cat {
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--champagne);
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
}

body.single-product .sp-cat::before {
  content: "";
  width: 18px;
  height: 1px;
  background: var(--champagne);
}

body.single-product .sp-title {
  font-family: var(--serif);
  font-size: clamp(32px, 3vw, 46px);
  font-weight: 300;
  color: var(--ivory);
  line-height: 1.12;
  margin-bottom: 16px;
  text-transform: none !important;
}

body.single-product .sp-title em {
  font-style: italic;
  color: var(--champagne);
  margin-left: .18em;
}

body.single-product .sp-rating {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 24px;
  font-size: 13px;
}

body.single-product .sp-stars {
  color: var(--champagne);
  letter-spacing: 3px;
}

body.single-product .sp-rating-count {
  font-size: 12px;
  color: var(--smoke);
}

body.single-product .sp-rating-link {
  color: var(--champagne);
  text-decoration: none;
}

body.single-product .sp-price {
  font-family: var(--serif);
  font-size: 42px;
  font-weight: 300;
  color: var(--champagne);
  margin-bottom: 8px;
  line-height: 1;
}

body.single-product .sp-price del {
  font-size: 22px;
  color: var(--rose-dusk);
  opacity: .75;
  margin-left: 10px;
}

body.single-product .sp-price ins { text-decoration: none; }

body.single-product .sp-price-note {
  font-size: 12px;
  color: var(--smoke);
  margin-bottom: 28px;
  letter-spacing: .06em;
}

body.single-product .sp-divider {
  height: 1px;
  background: rgba(200,170,130,.1);
  margin-bottom: 28px;
}

body.single-product .sp-short-desc {
  font-size: 14px;
  color: var(--smoke);
  line-height: 1.8;
  font-weight: 300;
  margin-bottom: 32px;
  padding-bottom: 0;
  border-bottom: 0;
}

body.single-product .sp-var-label,
body.single-product .sp-field-label {
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--smoke);
  margin-bottom: 10px;
  display: block;
}

body.single-product .sp-var-pills {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

body.single-product .sp-var-group { margin-bottom: 24px; }

body.single-product .sp-var-pill span {
  height: auto;
  font-size: 12px;
  padding: 8px 18px;
  border: 1px solid rgba(200,170,130,.2);
  background: none;
  color: var(--smoke);
  cursor: pointer;
  font-family: var(--sans);
  transition: all .2s;
}

body.single-product .sp-var-pill:hover span {
  border-color: var(--champagne);
  color: var(--champagne);
}

body.single-product .sp-var-pill.active span,
body.single-product .sp-var-pill input:checked + span {
  background: var(--champagne);
  color: var(--obsidian);
  border-color: var(--champagne);
}

body.single-product .sp-field-input,
body.single-product .sp-field-textarea {
  background: rgba(42,30,40,.72);
  border: 1px solid rgba(200,170,130,.18);
  color: var(--pearl);
}

body.single-product .sp-action-row {
  display: flex;
  gap: 12px;
  align-items: stretch;
  margin-bottom: 16px;
}

body.single-product .sp-qty {
  display: flex;
  align-items: stretch;
  border: 1px solid rgba(200,170,130,.2);
  height: 52px;
}

body.single-product .sp-qty-btn {
  width: 44px;
  background: none;
  border: none;
  color: var(--champagne);
  font-size: 18px;
  cursor: pointer;
  transition: background .2s;
}

body.single-product .sp-qty-btn:hover { background: var(--velvet); }

body.single-product .sp-qty-inp {
  width: 52px;
  background: none;
  border: none;
  border-left: 1px solid rgba(200,170,130,.15);
  border-right: 1px solid rgba(200,170,130,.15);
  text-align: center;
  color: var(--pearl);
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 300;
  outline: none;
}

body.single-product .sp-add-btn {
  flex: 1;
  min-height: 52px;
  background: var(--champagne);
  color: var(--obsidian);
  border: none;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: .16em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .3s;
  padding: 0 24px;
}

body.single-product .sp-add-btn:hover { background: var(--pearl); }

body.single-product .sp-wishlist-btn {
  width: 52px;
  min-height: 52px;
  background: none;
  border: 1px solid rgba(200,170,130,.2);
  color: var(--smoke);
  font-size: 18px;
  cursor: pointer;
  transition: all .3s;
  flex-shrink: 0;
}

body.single-product .sp-wishlist-btn:hover {
  border-color: var(--champagne);
  color: var(--champagne);
}

body.single-product .sp-trust {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 20px;
  background: var(--velvet);
  margin: 0 0 28px;
  border-top: 0;
}

body.single-product .sp-trust-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 12px;
  color: var(--smoke);
}

body.single-product .sp-trust-check {
  color: var(--champagne);
  font-size: 11px;
  width: 18px;
  text-align: center;
}

body.single-product .sp-tabs-section {
  border-top: 1px solid rgba(200,170,130,.1);
  background: transparent;
}

body.single-product .sp-tabs-nav {
  display: flex;
  border-bottom: 1px solid rgba(200,170,130,.1);
  padding: 0;
  margin: 0;
  overflow-x: auto;
}

body.single-product .sp-tab-btn {
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--smoke);
  padding: 14px 0;
  margin: 0 28px -1px 0;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  font-family: var(--sans);
  transition: all .2s;
  white-space: nowrap;
}

body.single-product .sp-tab-btn.active {
  color: var(--champagne);
  border-bottom-color: var(--champagne);
}

body.single-product .sp-tab-inner {
  max-width: none;
  padding: 28px 0;
  font-size: 13px;
  color: var(--smoke);
  line-height: 1.8;
}

body.single-product .sp-desc-body {
  font-size: 13px;
  color: var(--smoke);
  line-height: 1.8;
  white-space: normal;
}

body.single-product .sp-how-steps {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2px;
}

body.single-product .sp-how-step {
  background: var(--velvet);
  padding: 20px;
}

body.single-product .sp-how-num {
  font-size: 28px;
  margin-bottom: 8px;
}

body.single-product .sp-related {
  background: var(--deep-plum);
  padding: 64px 48px;
  border-top: 1px solid rgba(200,170,130,.08);
}

body.single-product .sp-related .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0;
}

body.single-product .sp-related-title {
  margin-bottom: 40px;
}

body.single-product .sp-related-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
}

@media (max-width: 900px) {
  body.single-product .sp-breadcrumb {
    padding: 20px 20px 0;
  }

  body.single-product .sp-single-wrap {
    padding: 0 20px 60px;
  }

  body.single-product .sp-layout {
    grid-template-columns: 1fr;
    gap: 36px;
    padding-top: 32px;
  }

  body.single-product .sp-related {
    padding: 48px 20px;
  }

  body.single-product .sp-related-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 480px) {
  body.single-product .sp-action-row {
    flex-wrap: wrap;
  }

  body.single-product .sp-add-btn {
    min-height: 52px;
  }

  body.single-product .sp-how-steps,
  body.single-product .sp-related-grid {
    grid-template-columns: 1fr;
  }
}

/* Peida nähtav scrollbar single product lehel ja tabide real, kerimine jääb tööle */
body.single-product,
body.single-product .sp-tabs-nav,
body.single-product .sp-gallery,
body.single-product .sp-tab-content,
body.single-product .sp-tab-inner {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

body.single-product::-webkit-scrollbar,
body.single-product .sp-tabs-nav::-webkit-scrollbar,
body.single-product .sp-gallery::-webkit-scrollbar,
body.single-product .sp-tab-content::-webkit-scrollbar,
body.single-product .sp-tab-inner::-webkit-scrollbar {
  width: 0 !important;
  height: 0 !important;
  display: none !important;
}

body.single-product .sp-tabs-nav {
  overflow-y: hidden !important;
}

html.noiatar-single-product-page,
html.noiatar-single-product-page body {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

html.noiatar-single-product-page::-webkit-scrollbar,
html.noiatar-single-product-page body::-webkit-scrollbar {
  width: 0 !important;
  height: 0 !important;
  display: none !important;
}

/* ── Single Product: ostukorvi rida + lisamise teade ── */
body.single-product .sp-action-row {
  display: grid;
  grid-template-columns: auto minmax(220px, 1fr) 52px;
  gap: 12px;
  align-items: stretch;
  margin-bottom: 16px;
}

body.single-product .sp-qty {
  height: 26px;
  min-height: 26px;
  align-self: center;
  border: 1px solid rgba(200,170,130,.20);
  background: transparent;
}

body.single-product .sp-qty-btn {
  width: 46px;
  height: 24px;
  min-height: 24px;
  line-height: 1;
  color: var(--champagne);
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}

body.single-product .sp-qty-inp {
  width: 52px;
  height: 24px;
  min-height: 24px;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .16em;
}

body.single-product .sp-add-btn {
  min-height: 26px;
  height: 26px;
  padding: 0 24px;
  background: var(--champagne);
  color: var(--obsidian);
  border: none;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .20em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
}

body.single-product .sp-wishlist-btn {
  width: 52px;
  min-height: 26px;
  height: 26px;
  align-self: center;
  background: transparent;
  border: 1px solid rgba(200,170,130,.20);
  color: var(--smoke);
}

body.single-product .sp-product-notices {
  margin: 0 0 18px;
}

body.single-product .sp-product-notices:empty {
  display: none;
}

body.single-product .sp-product-notices .woocommerce-message {
  margin: 0;
  padding: 14px 18px;
  width: 100%;
  min-height: 46px;
  background: rgba(49, 100, 22, .14);
  border: 1px solid rgba(91, 153, 47, .28);
  color: #9BE66E;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  font-size: 13px;
  line-height: 1.45;
  opacity: 1;
  transform: translateY(0);
  transition: opacity .35s ease, transform .35s ease;
}

body.single-product .sp-product-notices .woocommerce-message::before,
body.single-product .sp-product-notices .woocommerce-message::after {
  display: none !important;
  content: none !important;
}

body.single-product .sp-product-notices .woocommerce-message.sp-notice-is-hiding {
  opacity: 0;
  transform: translateY(-4px);
}

body.single-product .sp-product-notices .woocommerce-message .noiatar-cart-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 14px;
  font-weight: 600;
}

body.single-product .sp-product-notices .woocommerce-message .noiatar-cart-text,
body.single-product .sp-product-notices .woocommerce-message .noiatar-cart-sep,
body.single-product .sp-product-notices .woocommerce-message .noiatar-cart-link {
  display: inline-flex;
  align-items: center;
}

body.single-product .sp-product-notices .woocommerce-message .noiatar-cart-text,
body.single-product .sp-product-notices .woocommerce-message .noiatar-cart-sep {
  flex: 0 0 auto;
}

body.single-product .sp-product-notices .woocommerce-message .button,
body.single-product .sp-product-notices .woocommerce-message .wc-forward {
  float: none !important;
  order: 0;
  margin: 0;
  padding: 0;
  background: transparent !important;
  border: 0 !important;
  color: inherit !important;
  text-decoration: underline;
  font-family: var(--sans);
  font-size: inherit;
  letter-spacing: 0;
  text-transform: none;
  box-shadow: none;
}

body.single-product .sp-product-notices .woocommerce-error,
body.single-product .sp-product-notices .woocommerce-info {
  margin: 0;
  padding: 14px 18px;
  width: 100%;
  min-height: 52px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  font-size: 13px;
  line-height: 1.45;
  list-style: none;
}

body.single-product .sp-product-notices .woocommerce-error {
  background: rgba(118, 28, 30, .18);
  border: 1px solid rgba(224, 88, 72, .28);
  color: #F08A72;
}

body.single-product .sp-product-notices .woocommerce-info {
  background: rgba(200,170,130,.10);
  border: 1px solid rgba(200,170,130,.22);
  color: var(--champagne);
}

body.single-product .sp-product-notices .woocommerce-error::before,
body.single-product .sp-product-notices .woocommerce-error::after,
body.single-product .sp-product-notices .woocommerce-info::before,
body.single-product .sp-product-notices .woocommerce-info::after {
  display: none !important;
  content: none !important;
}

body.single-product .sp-product-notices .woocommerce-error li,
body.single-product .sp-product-notices .woocommerce-info li {
  margin: 0;
  padding: 0;
  width: 100%;
  list-style: none;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}

body.single-product .sp-product-notices .woocommerce-error li::before,
body.single-product .sp-product-notices .woocommerce-info li::before {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 16px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
}

body.single-product .sp-product-notices .woocommerce-error li::before {
  content: '!';
  color: #F08A72;
  border: 1px solid rgba(240,138,114,.72);
}

body.single-product .sp-product-notices .woocommerce-info li::before {
  content: 'i';
  color: var(--champagne);
  border: 1px solid rgba(200,170,130,.60);
  font-family: var(--serif);
  font-style: italic;
}

body.single-product .sp-product-notices .woocommerce-error .button,
body.single-product .sp-product-notices .woocommerce-error .wc-forward,
body.single-product .sp-product-notices .woocommerce-info .button,
body.single-product .sp-product-notices .woocommerce-info .wc-forward {
  float: none !important;
  margin: 0 0 0 4px;
  padding: 9px 18px;
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--champagne) !important;
  border: 1px solid var(--champagne) !important;
  color: var(--obsidian) !important;
  text-decoration: none !important;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  box-shadow: none !important;
  transition: background .25s ease, border-color .25s ease, color .25s ease;
}

body.single-product .sp-product-notices .woocommerce-error .button:hover,
body.single-product .sp-product-notices .woocommerce-error .wc-forward:hover,
body.single-product .sp-product-notices .woocommerce-info .button:hover,
body.single-product .sp-product-notices .woocommerce-info .wc-forward:hover {
  background: var(--pearl) !important;
  border-color: var(--pearl) !important;
  color: var(--obsidian) !important;
}

@media (max-width: 560px) {
  body.single-product .sp-action-row {
    grid-template-columns: 1fr 52px;
  }
  body.single-product .sp-qty {
    grid-column: 1 / -1;
    width: 100%;
  }
  body.single-product .sp-qty-btn,
  body.single-product .sp-qty-inp {
    flex: 1;
  }
}

/* ════════════════════════════════════════════════════════
   MINU KONTO — v2 mockup polish
   Keeps only account sections: Ülevaade, Tellimused, Allalaadimised, Aadress, Seaded
════════════════════════════════════════════════════════ */
.noiatar-myaccount,
.noiatar-myaccount * { box-sizing: border-box; }
.noiatar-myaccount { min-height: 80vh; background: var(--obsidian); overflow-x: hidden; }
.noiatar-myaccount a { text-decoration: none; }
.myaccount-layout { display: grid !important; grid-template-columns: 240px minmax(0, 1fr) !important; min-height: 80vh; width: 100%; }
.myaccount-sidebar { background: var(--deep-plum); padding: 28px 0 !important; }
.myaccount-user-box { padding: 0 24px 24px !important; border-bottom: 1px solid rgba(200,170,130,.1); margin-bottom: 8px; display: block !important; }
.myaccount-avatar { width: 52px !important; height: 52px !important; border-radius: 50%; background: var(--mauve); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 20px; color: var(--champagne); margin-bottom: 10px; }
.myaccount-user-name { font-family: var(--serif); font-size: 17px !important; line-height: 1.2; font-weight: 300; color: var(--ivory); }
.myaccount-user-email { font-size: 12px; color: var(--smoke); margin-top: 2px; word-break: break-word; }
.myaccount-nav-list { list-style: none; padding: 0 !important; margin: 0; }
.myaccount-nav-divider { height: 1px; background: rgba(200,170,130,.08); margin: 6px 24px; }
.myaccount-nav-item a { display: flex; align-items: center; gap: 12px; width: 100%; padding: 13px 24px !important; font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--smoke); background: none; border-left: 2px solid transparent; min-height: 48px; transition: all .2s; }
.myaccount-nav-item a:hover { color: var(--pearl); background: rgba(200,170,130,.04); }
.myaccount-nav-item.is-active a { color: var(--champagne); border-left-color: var(--champagne); background: rgba(200,170,130,.06); }
.myaccount-nav-logout a { color: var(--rose-dusk); }
.myaccount-nav-icon { font-size: 14px; width: 18px; text-align: center; flex-shrink: 0; color: var(--champagne); font-family: var(--serif); }
.myaccount-main { background: var(--obsidian); padding: 40px 48px !important; min-width: 0; }
.myaccount-section { max-width: 100%; }
.myaccount-greeting { font-family: var(--serif); font-size: 30px !important; font-weight: 300; color: var(--ivory); margin: 0 0 5px !important; line-height: 1.2; }
.myaccount-greeting em { font-style: italic; color: var(--champagne); }
.myaccount-greeting-sub { font-size: 14px; color: var(--smoke); margin: 0 0 36px !important; font-weight: 300; }
.myaccount-section-title { font-family: var(--serif); font-size: 26px !important; line-height: 1.2; font-weight: 300; color: var(--ivory); margin: 0 0 24px !important; }
.myaccount-section-title.compact { font-size: 20px !important; margin-bottom: 18px !important; padding-bottom: 12px; border-bottom: 1px solid rgba(200,170,130,.1); }
.myaccount-section-title em { font-style: italic; color: var(--champagne); }
.myaccount-stats { display: grid !important; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 2px; margin-bottom: 36px; }
.myaccount-stat { background: var(--deep-plum); padding: 22px 24px !important; min-width: 0; }
.myaccount-stat-num { font-family: var(--serif); font-size: 34px !important; font-weight: 300; color: var(--champagne); line-height: 1; margin: 0 0 5px !important; }
.myaccount-stat-num .woocommerce-Price-amount,
.myaccount-stat-num bdi { font-family: var(--serif); color: var(--champagne); }
.myaccount-stat-label { font-size: 10px; color: var(--smoke); letter-spacing: .1em; text-transform: uppercase; }
.myaccount-table-wrap { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.myaccount-data-table { width: 100%; border-collapse: collapse; }
.myaccount-data-table th { font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--smoke); font-weight: 400; padding: 10px 14px; text-align: left; border-bottom: 1px solid rgba(200,170,130,.1); white-space: nowrap; }
.myaccount-data-table td { padding: 14px; border-bottom: 1px solid rgba(200,170,130,.06); font-size: 13px; vertical-align: middle; }
.myaccount-data-table tr:hover td { background: rgba(200,170,130,.025); }
.t-title { font-family: var(--serif); font-size: 15px; color: var(--ivory); font-weight: 300; line-height: 1.25; }
.t-meta { font-size: 11px; color: var(--smoke); margin-top: 1px; }
.t-date { font-size: 13px; color: var(--smoke); }
.t-price { font-family: var(--serif); font-size: 17px !important; color: var(--champagne); white-space: nowrap; }
.t-price .woocommerce-Price-amount,
.t-price bdi { font-family: var(--serif); color: var(--champagne); }
.t-link { font-size: 11px; color: var(--champagne); letter-spacing: .06em; text-transform: uppercase; transition: color .2s; white-space: nowrap; }
.t-link:hover { color: var(--pearl); }
.myaccount-status-badge { display: inline-flex; align-items: center; font-size: 10px; padding: 4px 10px !important; letter-spacing: .07em; text-transform: uppercase; font-weight: 500; white-space: nowrap; }
.myaccount-status-badge.status-completed,
.myaccount-status-badge.status-processing { background: rgba(59,109,17,.18); color: #8BC96A; }
.myaccount-status-badge.status-pending,
.myaccount-status-badge.status-on-hold { background: rgba(200,170,130,.14); color: var(--champagne); }
.myaccount-status-badge.status-cancelled,
.myaccount-status-badge.status-failed { background: rgba(180,50,50,.14); color: #CC8282; }
.myaccount-mobile-user,
.myaccount-mobile-tabs,
.myaccount-mobile-list { display: none; }
.myaccount-all-orders { margin-top: 16px; display: inline-flex; font-size: 10px; padding: 12px 20px; }
.myaccount-fields-grid { display: grid !important; grid-template-columns: 1fr 1fr; gap: 14px; }
.myaccount-form-actions { margin-top: 24px; display: flex; gap: 10px; flex-wrap: wrap; }
.myaccount-section-divider { margin: 28px 0 20px; padding-top: 24px; border-top: 1px solid rgba(200,170,130,.09); }
.myaccount-subsection-title { font-family: var(--serif); font-size: 20px; font-weight: 300; color: var(--ivory); margin: 0 0 4px; }
.myaccount-subsection-title em { font-style: italic; color: var(--champagne); }
.myaccount-subsection-sub { font-size: 13px; color: var(--smoke); font-weight: 300; }
.myaccount-main .form-group { margin-bottom: 18px; }
.myaccount-main .form-label,
.myaccount-main .form-row label { display: block; font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--smoke); margin-bottom: 8px; }
.myaccount-main .form-input,
.myaccount-main .form-select,
.myaccount-main .input-text,
.myaccount-main input[type="text"],
.myaccount-main input[type="email"],
.myaccount-main input[type="tel"],
.myaccount-main input[type="password"],
.myaccount-main select,
.myaccount-main textarea { width: 100%; padding: 14px 15px; background: var(--deep-plum); border: 1px solid rgba(200,170,130,.12); color: var(--pearl); font-family: var(--sans); font-size: 16px; outline: none; transition: border-color .25s; border-radius: 0; appearance: none; -webkit-appearance: none; min-height: 48px; }
.myaccount-main .form-input:focus,
.myaccount-main .input-text:focus,
.myaccount-main input:focus,
.myaccount-main select:focus,
.myaccount-main textarea:focus { border-color: var(--champagne); }
.myaccount-main .form-input::placeholder,
.myaccount-main input::placeholder,
.myaccount-main textarea::placeholder { color: var(--rose-dusk); }
.myaccount-main .woocommerce-address-fields__field-wrapper { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.myaccount-main .woocommerce-address-fields__field-wrapper .form-row { margin: 0 0 4px !important; width: 100% !important; float: none !important; }
.myaccount-main .woocommerce-address-fields__field-wrapper .form-row-wide { grid-column: 1 / -1; }
.myaccount-address-overview { display: grid !important; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 2px; }
.myaccount-address-card { background: var(--deep-plum); padding: 24px; }
.myaccount-address-card-title { font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--champagne); margin-bottom: 14px; }
.myaccount-address-card address,
.myaccount-address-card p,
address.woocommerce-address { font-style: normal; font-size: 14px; color: var(--smoke); line-height: 1.7; font-weight: 300; }
.myaccount-empty { background: var(--deep-plum); border-left: 2px solid var(--champagne); padding: 24px 28px !important; }
.myaccount-empty p { font-size: 14px; color: var(--smoke); margin-bottom: 16px; }
.myaccount-login-wrap { max-width: 560px; margin: 64px auto; padding: 40px; background: var(--deep-plum); border-left: 2px solid var(--champagne); }
.myaccount-login-title { font-family: var(--serif); font-size: 34px; font-weight: 300; margin-bottom: 8px; }
.myaccount-login-title em { color: var(--champagne); font-style: italic; }
.myaccount-login-sub { font-size: 14px; margin-bottom: 24px; color: var(--smoke); }

@media (max-width: 900px) {
  .noiatar-myaccount { padding-bottom: 24px; }
  .myaccount-layout { grid-template-columns: 1fr !important; min-height: 0; }
  .myaccount-sidebar { display: none !important; }
  .myaccount-mobile-user { display: flex; align-items: center; gap: 14px; padding: 24px 20px; background: var(--deep-plum); border-bottom: 1px solid rgba(200,170,130,.1); }
  .myaccount-mobile-avatar { width: 48px; height: 48px; border-radius: 50%; background: var(--mauve); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 18px; color: var(--champagne); flex-shrink: 0; }
  .myaccount-mobile-name { font-family: var(--serif); font-size: 17px; color: var(--ivory); font-weight: 300; }
  .myaccount-mobile-email { font-size: 12px; color: var(--smoke); word-break: break-word; }
  .myaccount-mobile-tabs { display: flex; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; border-bottom: 1px solid rgba(200,170,130,.1); background: var(--deep-plum); }
  .myaccount-mobile-tabs::-webkit-scrollbar { display: none; }
  .myaccount-mobile-tab { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--smoke); padding: 14px 18px; border-bottom: 2px solid transparent; white-space: nowrap; min-height: 48px; }
  .myaccount-mobile-tab.is-active { color: var(--champagne); border-bottom-color: var(--champagne); }
  .myaccount-main { padding: 24px 20px !important; background: transparent; }
  .myaccount-greeting { font-size: 24px !important; }
  .myaccount-greeting-sub { font-size: 13px; margin-bottom: 20px !important; }
  .myaccount-stats { display: flex !important; gap: 10px; overflow-x: auto; -webkit-overflow-scrolling: touch; margin: 0 -20px 24px; padding: 0 20px 4px; }
  .myaccount-stats::-webkit-scrollbar { display: none; }
  .myaccount-stat { min-width: 118px; padding: 14px 20px !important; text-align: center; flex: 0 0 auto; }
  .myaccount-stat-num { font-size: 28px !important; }
  .myaccount-section-title { font-size: 22px !important; }
  .myaccount-section-title.compact { font-size: 20px !important; }
  .myaccount-table-wrap { display: none !important; }
  .myaccount-mobile-list { display: block; margin: 0 -20px; }
  .myaccount-mobile-card { background: var(--deep-plum); padding: 18px 20px; margin-bottom: 2px; display: flex; align-items: center; gap: 14px; color: inherit; min-width: 0; }
  .myaccount-mobile-card-icon { width: 40px; height: 40px; background: var(--velvet); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 18px; color: var(--champagne); flex-shrink: 0; }
  .myaccount-mobile-card-body { flex: 1; min-width: 0; }
  .myaccount-mobile-card-title { font-family: var(--serif); font-size: 16px; color: var(--ivory); font-weight: 300; line-height: 1.2; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .myaccount-mobile-card-meta { font-size: 11px; color: var(--smoke); margin-top: 3px; }
  .myaccount-mobile-card-side { text-align: right; flex-shrink: 0; }
  .myaccount-mobile-card-price { font-family: var(--serif); font-size: 17px; color: var(--champagne); }
  .myaccount-fields-grid,
  .myaccount-main .woocommerce-address-fields__field-wrapper,
  .myaccount-address-overview { grid-template-columns: 1fr !important; }
  .myaccount-main .woocommerce-address-fields__field-wrapper .form-row-wide { grid-column: auto; }
  .myaccount-form-actions .btn { width: 100%; }
  .myaccount-login-wrap { margin: 32px 16px; padding: 28px 20px; }
}

@media (max-width: 480px) {
  .myaccount-main { padding: 22px 16px !important; }
  .myaccount-stats { margin-left: -16px; margin-right: -16px; padding-left: 16px; padding-right: 16px; }
  .myaccount-mobile-list { margin-left: -16px; margin-right: -16px; }
  .myaccount-mobile-card { padding-left: 16px; padding-right: 16px; }
}

/* My Account header offset fix — keep account content below fixed nav. */
body.woocommerce-account .site-header {
  background: rgba(17,13,16,0.97) !important;
  border-bottom: 1px solid rgba(200,170,130,0.08) !important;
  box-shadow: 0 1px 0 rgba(200,170,130,0.04) !important;
}
body.woocommerce-account .site-main.myaccount-page-main {
  padding-top: var(--nav-height, 68px) !important;
  background: var(--obsidian) !important;
  overflow-x: hidden !important;
}
body.woocommerce-account .noiatar-myaccount {
  min-height: calc(100vh - var(--nav-height, 68px)) !important;
}
body.woocommerce-account .myaccount-layout {
  min-height: calc(100vh - var(--nav-height, 68px)) !important;
}
body.woocommerce-account .myaccount-sidebar {
  min-height: calc(100vh - var(--nav-height, 68px)) !important;
}
@media (max-width: 900px) {
  body.woocommerce-account .site-main.myaccount-page-main {
    padding-top: var(--nav-height, 58px) !important;
  }
  body.woocommerce-account .noiatar-myaccount,
  body.woocommerce-account .myaccount-layout,
  body.woocommerce-account .myaccount-sidebar {
    min-height: 0 !important;
  }
}

/* My Account avatar spacing fix */
body.woocommerce-account .myaccount-user-box { padding-top: 20px !important; }
body.woocommerce-account .myaccount-avatar { margin-top: 4px !important; }
@media (max-width: 900px) {
  body.woocommerce-account .myaccount-user-box { padding-top: 16px !important; }
}


/* My Account address edit form — final layout fix */
body.woocommerce-account .myaccount-user-box { padding-top: 20px !important; }
body.woocommerce-account .myaccount-avatar { margin-top: 4px !important; }
body.woocommerce-account .woocommerce-EditAccountForm.edit-address {
  max-width: none !important;
  width: 100% !important;
}
body.woocommerce-account .woocommerce-EditAccountForm.edit-address .myaccount-fields-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px 18px !important;
  align-items: start !important;
  width: 100% !important;
}
body.woocommerce-account .woocommerce-EditAccountForm.edit-address .form-row,
body.woocommerce-account .woocommerce-EditAccountForm.edit-address p.form-row,
body.woocommerce-account .woocommerce-EditAccountForm.edit-address .woocommerce-form-row {
  display: block !important;
  float: none !important;
  clear: none !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  position: static !important;
  grid-column: auto !important;
}
body.woocommerce-account .woocommerce-EditAccountForm.edit-address .form-row-wide,
body.woocommerce-account .woocommerce-EditAccountForm.edit-address #billing_company_field,
body.woocommerce-account .woocommerce-EditAccountForm.edit-address #shipping_company_field,
body.woocommerce-account .woocommerce-EditAccountForm.edit-address #billing_country_field,
body.woocommerce-account .woocommerce-EditAccountForm.edit-address #shipping_country_field,
body.woocommerce-account .woocommerce-EditAccountForm.edit-address #billing_address_1_field,
body.woocommerce-account .woocommerce-EditAccountForm.edit-address #shipping_address_1_field,
body.woocommerce-account .woocommerce-EditAccountForm.edit-address #billing_address_2_field,
body.woocommerce-account .woocommerce-EditAccountForm.edit-address #shipping_address_2_field {
  grid-column: 1 / -1 !important;
}
body.woocommerce-account .woocommerce-EditAccountForm.edit-address .form-row label {
  display: block !important;
  width: auto !important;
  margin: 0 0 8px !important;
  padding: 0 !important;
  font-size: 10px !important;
  line-height: 1.2 !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
  color: var(--smoke) !important;
  text-align: left !important;
}
body.woocommerce-account .woocommerce-EditAccountForm.edit-address .required {
  color: #a02b2b !important;
  text-decoration: none !important;
}
body.woocommerce-account .woocommerce-EditAccountForm.edit-address .woocommerce-input-wrapper {
  display: block !important;
  width: 100% !important;
}
body.woocommerce-account .woocommerce-EditAccountForm.edit-address input.input-text,
body.woocommerce-account .woocommerce-EditAccountForm.edit-address input[type="text"],
body.woocommerce-account .woocommerce-EditAccountForm.edit-address input[type="email"],
body.woocommerce-account .woocommerce-EditAccountForm.edit-address input[type="tel"],
body.woocommerce-account .woocommerce-EditAccountForm.edit-address select,
body.woocommerce-account .woocommerce-EditAccountForm.edit-address textarea,
body.woocommerce-account .woocommerce-EditAccountForm.edit-address .select2-container .select2-selection--single {
  display: block !important;
  width: 100% !important;
  min-height: 48px !important;
  height: 48px !important;
  padding: 14px 15px !important;
  background: var(--deep-plum) !important;
  border: 1px solid rgba(200,170,130,.12) !important;
  color: var(--pearl) !important;
  border-radius: 0 !important;
  font-family: var(--sans) !important;
  font-size: 16px !important;
  line-height: 1.2 !important;
  box-shadow: none !important;
}
body.woocommerce-account .woocommerce-EditAccountForm.edit-address .select2-container { width: 100% !important; display: block !important; }
body.woocommerce-account .woocommerce-EditAccountForm.edit-address .select2-selection__rendered {
  color: var(--pearl) !important;
  padding: 0 !important;
  line-height: 18px !important;
}
body.woocommerce-account .woocommerce-EditAccountForm.edit-address .select2-selection__arrow { height: 48px !important; }
body.woocommerce-account .woocommerce-EditAccountForm.edit-address .myaccount-form-actions {
  margin-top: 26px !important;
  display: flex !important;
  justify-content: flex-start !important;
}
body.woocommerce-account .woocommerce-EditAccountForm.edit-address .myaccount-form-actions .btn,
body.woocommerce-account .woocommerce-EditAccountForm.edit-address .myaccount-form-actions button {
  background: var(--champagne) !important;
  color: var(--obsidian) !important;
  border: 0 !important;
  min-height: 48px !important;
  padding: 14px 28px !important;
  font-size: 11px !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
}
@media (max-width: 900px) {
  body.woocommerce-account .woocommerce-EditAccountForm.edit-address .myaccount-fields-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  body.woocommerce-account .woocommerce-EditAccountForm.edit-address .form-row-wide,
  body.woocommerce-account .woocommerce-EditAccountForm.edit-address #billing_company_field,
  body.woocommerce-account .woocommerce-EditAccountForm.edit-address #shipping_company_field,
  body.woocommerce-account .woocommerce-EditAccountForm.edit-address #billing_country_field,
  body.woocommerce-account .woocommerce-EditAccountForm.edit-address #shipping_country_field,
  body.woocommerce-account .woocommerce-EditAccountForm.edit-address #billing_address_1_field,
  body.woocommerce-account .woocommerce-EditAccountForm.edit-address #shipping_address_1_field,
  body.woocommerce-account .woocommerce-EditAccountForm.edit-address #billing_address_2_field,
  body.woocommerce-account .woocommerce-EditAccountForm.edit-address #shipping_address_2_field {
    grid-column: auto !important;
  }
  body.woocommerce-account .woocommerce-EditAccountForm.edit-address .myaccount-form-actions .btn,
  body.woocommerce-account .woocommerce-EditAccountForm.edit-address .myaccount-form-actions button {
    width: 100% !important;
  }
}
