/*
Theme Name: Huts Scandi Shop
Theme URI: https://huts.pro
Author: HUTS.PRO by Anastasiya Huts
Author URI: https://huts.pro
Description: Светлый скандинавский интернет-магазин на WooCommerce. Минимализм, природные оттенки шалфея и светлого дерева, шрифт Montserrat. Создана студией HUTS.PRO.
Version: 1.1.3
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: huts-scandi
Tags: e-commerce, woocommerce, custom-menu, custom-logo, translation-ready, light, minimal
*/

/* =========================================================
   0. ПЕРЕМЕННЫЕ — фирменная палитра «Светлый скандинавский»
   ========================================================= */
:root{
  --color-bg:        #FFFFFF; /* Основной — белый */
  --color-bg-soft:   #FBFAF8; /* мягкий молочный для секций */
  --color-accent:    #8FA68E; /* Акцент — шалфейный */
  --color-accent-dark:#76906F; /* шалфей для hover */
  --color-wood:      #D8B38A; /* Дополнительный — светлое дерево */
  --color-wood-soft: #EFE0CC; /* светлее дерево для фонов/бейджей */
  --color-text:      #333333; /* Текст — темно-серый */
  --color-text-muted:#6E6E6E;
  --color-line:      #E7E3DC; /* тонкие разделители */
  --radius-s: 6px;
  --radius-m: 14px;
  --radius-l: 28px;
  --shadow-soft: 0 10px 30px rgba(51,51,51,0.06);
  --container: 1240px;
  --font-main: 'Montserrat', -apple-system, BlinkMacSystemFont, sans-serif;
}

/* =========================================================
   1. RESET / BASE
   ========================================================= */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--color-bg);
  color:var(--color-text);
  font-family:var(--font-main);
  font-weight:400;
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4,h5{
  font-family:var(--font-main);
  font-weight:600;
  letter-spacing:-0.01em;
  margin:0 0 0.6em;
  color:var(--color-text);
}
h1{ font-size:clamp(2rem,4vw,3.2rem); font-weight:500; }
h2{ font-size:clamp(1.5rem,3vw,2.2rem); }
h3{ font-size:1.25rem; }
p{ margin:0 0 1em; }
.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 24px;
}
.eyebrow{
  display:inline-block;
  font-size:12px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--color-accent-dark);
  font-weight:600;
  margin-bottom:10px;
}
.section{ padding:72px 0; }
.section--soft{ background:var(--color-bg-soft); }
.divider{
  width:100%;
  height:1px;
  background:var(--color-line);
  border:0;
  margin:0;
}
.skip-link{ position:absolute; left:-9999px; }
.skip-link:focus{
  left:16px; top:16px; z-index:9999;
  background:var(--color-text); color:#fff; padding:10px 16px; border-radius:var(--radius-s);
}
:focus-visible{ outline:2px solid var(--color-accent-dark); outline-offset:3px; }

/* кнопки */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:14px 30px;
  border-radius:999px;
  font-size:14px;
  font-weight:600;
  letter-spacing:0.03em;
  text-transform:uppercase;
  border:1px solid transparent;
  cursor:pointer;
  transition:all .25s ease;
}
.btn--primary{ background:var(--color-accent); color:#fff; }
.btn--primary:hover{ background:var(--color-accent-dark); transform:translateY(-1px); }
.btn--ghost{ background:transparent; color:var(--color-text); border-color:var(--color-text); }
.btn--ghost:hover{ background:var(--color-text); color:#fff; }
.btn--wood{ background:var(--color-wood); color:var(--color-text); }
.btn--wood:hover{ background:#cda172; }

/* =========================================================
   2. HEADER
   ========================================================= */
.site-header{
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--color-line);
  position:sticky; top:0; z-index:500;
}
.site-header-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; padding:0 24px; min-height:78px;
}
.site-branding .logo{ display:flex; align-items:center; gap:12px; }
.site-branding .site-title{
  font-size:22px; font-weight:700; letter-spacing:0.02em;
}
.site-branding img.custom-logo{ max-height:48px; width:auto; }
.logo-mark{
  width:42px; height:42px; border-radius:50%;
  background:var(--color-accent); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:18px; font-weight:700; flex-shrink:0;
}
.logo-text{ display:flex; flex-direction:column; line-height:1.15; }
.logo-title{ font-size:16px; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:var(--color-text); }
.logo-sub{ font-size:10px; font-weight:500; letter-spacing:0.03em; color:var(--color-text-muted); text-transform:uppercase; }

.main-navigation{ flex:1; display:flex; justify-content:center; }
#primary-menu{ display:flex; gap:34px; }
#primary-menu a{
  font-size:13px; font-weight:500; color:var(--color-text-muted);
  position:relative; padding:6px 0; transition:color .2s ease;
}
#primary-menu a:hover{ color:var(--color-text); }
#primary-menu a::after{
  content:''; position:absolute; left:0; bottom:0; width:0; height:1.5px;
  background:var(--color-accent); transition:width .25s ease;
}
#primary-menu a:hover::after, #primary-menu .current-menu-item > a::after{ width:100%; }
.menu-toggle{
  display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px;
}
.menu-toggle span{ width:24px; height:2px; background:var(--color-text); }

.header-actions{ display:flex; align-items:center; gap:16px; }
.tel-link{ font-size:13.5px; font-weight:600; color:var(--color-text); white-space:nowrap; }
.btn-wa{
  display:flex; align-items:center; gap:8px;
  background:#fff; border:1px solid rgba(37,211,102,0.4); color:#159a4a;
  padding:9px 18px; border-radius:999px; font-size:12.5px; font-weight:700;
  transition:background .2s ease; white-space:nowrap;
}
.btn-wa:hover{ background:rgba(37,211,102,0.08); }
.btn-wa svg{ width:15px; height:15px; fill:#25D366; flex-shrink:0; }
.header-actions .cart-icon, .header-actions .account-icon{
  position:relative; font-size:18px; display:inline-flex; align-items:center; gap:6px;
}
.cart-count{
  position:absolute; top:-8px; right:-12px;
  background:var(--color-accent); color:#fff; font-size:11px; font-weight:700;
  width:18px; height:18px; border-radius:50%; display:flex; align-items:center; justify-content:center;
}

/* sticky-кнопки WhatsApp / звонок (на всех страницах) */
.sticky-actions{ position:fixed; bottom:24px; right:24px; display:flex; flex-direction:column; gap:12px; z-index:550; }
.sticky-btn{
  width:54px; height:54px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background:#fff; box-shadow:0 8px 24px rgba(51,51,51,0.18); transition:transform .2s ease;
}
.sticky-btn:hover{ transform:scale(1.08); }
.sticky-btn svg{ width:24px; height:24px; }
.sticky-call{ background:var(--color-accent); }

/* =========================================================
   3. ФУТЕР
   ========================================================= */
.site-footer{ background:var(--color-bg-soft); border-top:1px solid var(--color-line); padding-top:60px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:32px; padding-bottom:40px; }
.footer-widget-title{ font-size:14px; text-transform:uppercase; letter-spacing:0.05em; margin-bottom:16px; }
.footer-widget p, .footer-widget li{ font-size:14px; color:var(--color-text-muted); margin-bottom:8px; }
.site-footer-bottom{
  border-top:1px solid var(--color-line);
  padding:20px 0; font-size:13px; color:var(--color-text-muted);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
}
.site-footer-bottom a{ color:var(--color-accent-dark); font-weight:600; }

/* =========================================================
   4. АДАПТИВ
   ========================================================= */
@media (max-width:980px){
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:760px){
  .main-navigation{ position:fixed; inset:64px 0 0 0; background:var(--color-bg); flex-direction:column; padding:30px; transform:translateX(100%); transition:transform .3s ease; z-index:400; }
  .main-navigation.is-open{ transform:translateX(0); }
  #primary-menu{ flex-direction:column; gap:18px; }
  .menu-toggle{ display:flex; }
  .tel-link{ display:none; }
  .footer-grid{ grid-template-columns:1fr; text-align:left; }
}
@media (max-width:480px){
  .btn-wa span{ display:none; }
  .btn-wa{ padding:9px 12px; }
}
