/*
Theme Name: Smart Cafe
Theme URI: https://smartcafe.com.ua/
Author: Smart Cafe
Author URI: https://smartcafe.com.ua/
Description: Кастомна тема для інтернет-магазину Smart Cafe — кава, сиропи, аксесуари для кав'ярень. Інтегрується з WooCommerce.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: smartcafe
Tags: e-commerce, custom-colors, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ── DESIGN TOKENS ── */
:root{
  --bg:#FBF7F0;
  --bg2:#F5EFE3;
  --card:#FFFFFF;
  --border:#E8DDD0;
  --border2:#D8C8B8;
  --coffee:#2C1A0A;
  --brown:#5C3318;
  --caramel:#C87820;
  --orange:#E8921A;
  --orange-h:#F5A030;
  --cream:#F0E0C0;
  --text:#1E1008;
  --text2:#6B4A30;
  --text3:#A0856A;
  --green:#256B28;
  --green-bg:#EBF5EB;
  --red:#C0281A;
  --shadow:0 2px 16px rgba(44,26,10,.09);
  --shadow-h:0 8px 36px rgba(44,26,10,.18);
  --r:8px;
  --fd:'Playfair Display',Georgia,serif;
  --fb:'Nunito',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;}
body{background:var(--bg);color:var(--text);font-family:var(--fb);-webkit-font-smoothing:antialiased;overflow-x:hidden;}
a{color:inherit;}
img{max-width:100%;height:auto;}

/* ── NAV ── */
.site-header{position:sticky;top:0;z-index:200;background:#fff;border-bottom:2px solid var(--border);box-shadow:0 2px 12px rgba(44,26,10,.07);}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 28px;height:66px;display:flex;align-items:center;justify-content:space-between;gap:20px;}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;}
.logo-mark{width:38px;height:38px;background:linear-gradient(135deg,var(--brown),var(--caramel));border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;box-shadow:0 2px 8px rgba(200,120,32,.3);color:#fff;}
.logo-name{font-family:var(--fd);font-size:20px;font-weight:700;color:var(--coffee);letter-spacing:.01em;}
.nav-mid{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0;}
.nav-mid li{list-style:none;}
.nav-mid a,.nav-link{padding:8px 16px;border-radius:var(--r);font-size:14px;font-weight:700;color:var(--text2);text-decoration:none;cursor:pointer;transition:.18s;border:none;background:none;font-family:var(--fb);display:inline-block;}
.nav-mid a:hover,.nav-mid .current-menu-item > a,.nav-link:hover,.nav-link.active{background:var(--bg2);color:var(--coffee);}
.nav-right{display:flex;align-items:center;gap:12px;}
.nav-phone{font-size:14px;font-weight:800;color:var(--brown);text-decoration:none;letter-spacing:.01em;}
.cart-btn{display:flex;align-items:center;gap:8px;background:var(--orange);color:#fff;border:none;border-radius:var(--r);padding:11px 20px;font-family:var(--fb);font-size:14px;font-weight:800;cursor:pointer;transition:.2s;text-decoration:none;}
.cart-btn:hover{background:var(--orange-h);transform:translateY(-1px);box-shadow:0 4px 16px rgba(232,146,26,.4);color:#fff;}
.cart-pill{background:rgba(255,255,255,.28);border-radius:20px;padding:2px 8px;font-size:12px;font-weight:900;min-width:22px;text-align:center;}

/* ── HERO ── */
.hero{background:linear-gradient(125deg,#2C1A0A 0%,#4A2510 40%,#64371A 100%);padding:0;overflow:hidden;position:relative;}
.hero-inner{max-width:1240px;margin:0 auto;padding:52px 40px;display:grid;grid-template-columns:1fr 480px;gap:32px;align-items:center;min-height:420px;position:relative;z-index:1;}
.hero-label{display:inline-flex;align-items:center;gap:6px;background:rgba(232,146,26,.2);border:1px solid rgba(232,146,26,.4);border-radius:20px;padding:5px 14px;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--orange-h);margin-bottom:16px;}
.hero h1{font-family:var(--fd);font-size:clamp(32px,4vw,54px);font-weight:700;color:#fff;line-height:1.15;margin-bottom:14px;}
.hero h1 span{color:var(--orange-h);font-style:italic;}
.hero p{font-size:16px;color:rgba(255,255,255,.75);line-height:1.7;margin-bottom:28px;max-width:480px;}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;}
.hero-btn-main{background:var(--orange);color:#fff;border:none;padding:14px 32px;border-radius:var(--r);font-family:var(--fb);font-size:15px;font-weight:800;cursor:pointer;transition:.2s;text-decoration:none;display:inline-flex;align-items:center;gap:8px;box-shadow:0 4px 16px rgba(232,146,26,.4);}
.hero-btn-main:hover{background:var(--orange-h);transform:translateY(-1px);color:#fff;}
.hero-visual{display:flex;align-items:center;justify-content:center;}
.hero-visual img{width:100%;max-width:480px;height:auto;object-fit:contain;display:block;}
@media(max-width:900px){.hero-visual{display:none;}.hero-inner{grid-template-columns:1fr;padding:40px 20px;min-height:auto;}}

/* ── PROMO STRIP ── */
.strip{background:var(--caramel);padding:11px 28px;}
.strip-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:center;align-items:center;gap:36px;flex-wrap:wrap;}
.s-item{display:flex;align-items:center;gap:8px;color:#fff;font-size:13px;font-weight:800;}
.s-sep{color:rgba(255,255,255,.4);font-size:18px;}

/* ── ABOUT STRIP ── */
.astrip{background:linear-gradient(110deg,#3D1C05 0%,#6B3010 50%,#8B4515 100%);padding:20px 28px 28px;margin-top:-2px;}
.astrip-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.astrip-item{background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.18);border-radius:16px;padding:22px 14px 18px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center;gap:12px;}
.astrip-item strong{font-size:14px;font-weight:800;color:#fff;display:block;line-height:1.4;}
.astrip-icon{width:64px;height:64px;background:rgba(200,100,20,.35);border:none;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:32px;flex-shrink:0;}

/* ── CATALOG ── */
.catalog{padding:52px 28px;}
.catalog-inner{max-width:1200px;margin:0 auto;}
.catalog-top{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;gap:16px;flex-wrap:wrap;}
.catalog-top h2{font-family:var(--fd);font-size:clamp(26px,4vw,38px);font-weight:700;color:var(--coffee);}
.catalog-top p{font-size:14px;color:var(--text3);margin-top:3px;}
.filters{display:flex;gap:8px;flex-wrap:wrap;}
.f-btn{padding:8px 18px;border-radius:20px;border:1.5px solid var(--border2);background:#fff;color:var(--text2);font-family:var(--fb);font-size:13px;font-weight:700;cursor:pointer;transition:.18s;text-decoration:none;display:inline-block;}
.f-btn:hover{border-color:var(--caramel);color:var(--caramel);}
.f-btn.on{background:var(--coffee);color:#fff;border-color:var(--coffee);}

/* ── PRODUCT GRID ── */
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:20px;list-style:none;margin:0;padding:0;}
.prod-card{background:var(--card);border:1.5px solid var(--border);border-radius:14px;overflow:hidden;transition:.22s;cursor:pointer;position:relative;display:flex;flex-direction:column;}
.prod-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-h);border-color:rgba(200,120,32,.35);}
.prod-img{aspect-ratio:1;position:relative;overflow:hidden;background:var(--bg2);}
.prod-img a{display:block;width:100%;height:100%;}
.prod-img img{width:100%;height:100%;object-fit:cover;transition:.5s cubic-bezier(.4,0,.2,1);}
.prod-card:hover .prod-img img{transform:scale(1.08);}
.prod-flag{position:absolute;top:12px;left:12px;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;z-index:2;}
.flag-hit{background:#D4380D;color:#fff;}
.flag-new{background:var(--caramel);color:#fff;}
.flag-opt{background:var(--coffee);color:var(--cream);}
.flag-sale{background:var(--green);color:#fff;}
.prod-body{padding:18px 18px 20px;flex:1;display:flex;flex-direction:column;}
.prod-cat{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--caramel);margin-bottom:5px;display:block;text-decoration:none;}
.prod-name{font-family:var(--fd);font-size:19px;font-weight:700;color:var(--coffee);line-height:1.28;margin-bottom:7px;text-decoration:none;display:block;}
.prod-name a{color:inherit;text-decoration:none;}
.prod-desc{font-size:13px;color:var(--text3);line-height:1.6;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.prod-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;padding-top:14px;border-top:1.5px solid var(--border);margin-top:auto;}
.prod-price-wrap{min-width:0;flex:1;}
.prod-avail{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:800;color:var(--green);margin-bottom:4px;white-space:nowrap;}
.prod-avail::before{content:'';width:7px;height:7px;background:var(--green);border-radius:50%;}
.prod-price{font-family:var(--fd);font-size:22px;font-weight:700;color:var(--coffee);display:block;line-height:1;}
.prod-price-old{font-size:13px;color:var(--text3);text-decoration:line-through;display:block;margin-bottom:2px;}
.prod-price-hint{font-size:11px;color:var(--caramel);font-weight:700;background:rgba(200,120,32,.08);border-radius:4px;padding:3px 7px;display:inline-block;margin-top:4px;}

/* ── BUY BTN ── */
.buy-btn{display:flex;align-items:center;justify-content:center;gap:6px;background:var(--orange);color:#fff;border:none;border-radius:var(--r);padding:12px 14px;font-family:var(--fb);font-size:13px;font-weight:900;cursor:pointer;transition:.2s;white-space:nowrap;flex-shrink:0;box-shadow:0 3px 10px rgba(232,146,26,.3);text-decoration:none;}
.buy-btn:hover{background:var(--orange-h);transform:translateY(-2px);box-shadow:0 6px 20px rgba(232,146,26,.5);color:#fff;}
.buy-btn:active{transform:translateY(0);}
.buy-btn svg{flex-shrink:0;}

/* ── FOOTER ── */
.site-footer{background:var(--coffee);padding:48px 28px 28px;margin-top:52px;color:#fff;}
.foot-inner{max-width:1200px;margin:0 auto;}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:36px;}
.foot-logo strong{font-family:var(--fd);font-size:22px;color:#fff;display:block;margin-bottom:12px;}
.foot-logo p{font-size:13px;color:rgba(255,255,255,.45);line-height:1.7;max-width:240px;}
.foot-col h4{font-size:11px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:var(--orange);margin-bottom:14px;}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:9px;margin:0;padding:0;}
.foot-col ul li{font-size:13px;color:rgba(255,255,255,.45);list-style:none;}
.foot-col ul li a{color:rgba(255,255,255,.45);text-decoration:none;}
.foot-col ul li a:hover{color:rgba(255,255,255,.8);}
.foot-bottom{padding-top:20px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;}
.foot-bottom p{font-size:12px;color:rgba(255,255,255,.3);}
.pay-icons{display:flex;gap:8px;}
.pay-icon{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:4px;padding:4px 10px;font-size:11px;font-weight:800;color:rgba(255,255,255,.55);}

/* ── SEO TEXT BLOCK ── */
.seo-block{background:#fff;padding:52px 28px 0;}
.seo-block-inner{max-width:860px;margin:0 auto;}
.seo-block h2{font-family:var(--fd);font-size:clamp(24px,3vw,36px);font-weight:700;color:#2C1A0A;margin-bottom:20px;line-height:1.2;}
.seo-block p{font-size:15px;color:#6B4A30;line-height:1.8;margin-bottom:14px;}
.seo-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px;margin-bottom:52px;}
.seo-tag{background:#F5EFE3;border:1px solid #E8DDD0;border-radius:20px;padding:6px 14px;font-size:12px;font-weight:700;color:#5C3318;}

/* ── FAQ ── */
.faq-block{background:#F5EFE3;padding:52px 28px;}
.faq-inner{max-width:860px;margin:0 auto;}
.faq-block h2{font-family:var(--fd);font-size:clamp(24px,3vw,36px);font-weight:700;color:#2C1A0A;margin-bottom:8px;text-align:center;}
.faq-block .faq-lead{text-align:center;color:#A0856A;font-size:15px;margin-bottom:36px;}
.faq-item{background:#fff;border:1.5px solid #E8DDD0;border-radius:12px;margin-bottom:10px;overflow:hidden;}
.faq-item summary{padding:18px 22px;font-weight:800;font-size:15px;color:#2C1A0A;cursor:pointer;display:flex;justify-content:space-between;align-items:center;list-style:none;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item .faq-plus{color:#C87820;font-size:20px;flex-shrink:0;margin-left:12px;transition:.2s;}
.faq-item[open] .faq-plus{transform:rotate(45deg);}
.faq-item .faq-answer{padding:0 22px 18px;font-size:14px;color:#6B4A30;line-height:1.75;}
.faq-cta{text-align:center;margin-top:32px;}
.faq-cta a{display:inline-flex;align-items:center;gap:10px;background:#2C1A0A;color:#fff;padding:15px 32px;border-radius:8px;font-family:var(--fb);font-size:15px;font-weight:800;text-decoration:none;}

/* ── TOAST ── */
.toast{position:fixed;bottom:28px;right:28px;background:var(--coffee);color:#fff;border-left:4px solid var(--orange);border-radius:var(--r);padding:14px 20px;font-size:14px;font-weight:700;z-index:9999;transform:translateX(120%);transition:transform .35s cubic-bezier(.4,0,.2,1);max-width:300px;display:flex;align-items:center;gap:10px;box-shadow:0 8px 32px rgba(0,0,0,.3);}
.toast.show{transform:translateX(0);}

/* ── PAGE WRAPPERS ── */
.smartcafe-page{padding:40px 28px 60px;}
.smartcafe-page-inner{max-width:1200px;margin:0 auto;}
.smartcafe-page h1,.smartcafe-page h2.entry-title{font-family:var(--fd);font-size:clamp(26px,4vw,38px);font-weight:700;color:var(--coffee);margin-bottom:24px;}
.smartcafe-page .entry-content{font-size:15px;color:var(--text2);line-height:1.75;}
.smartcafe-page .entry-content h2{font-family:var(--fd);color:var(--coffee);margin:24px 0 12px;}
.smartcafe-page .entry-content h3{font-family:var(--fd);color:var(--coffee);margin:20px 0 10px;}
.smartcafe-page .entry-content a{color:var(--caramel);}
.smartcafe-page .entry-content ul,.smartcafe-page .entry-content ol{margin:12px 0 12px 24px;}

/* ── BREADCRUMBS ── */
.breadcrumb,.woocommerce-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:32px;font-size:13px;color:var(--text3);flex-wrap:wrap;}
.breadcrumb a,.woocommerce-breadcrumb a{color:var(--caramel);text-decoration:none;font-weight:700;}
.breadcrumb span,.woocommerce-breadcrumb > *{color:var(--text3);}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}
.fade-up{animation:fadeUp .45s ease both;}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .astrip-inner{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:600px){
  .nav-mid{display:none;}
  .nav-inner{padding:0 14px;gap:10px;}
  .nav-phone{font-size:12px;}
  .cart-btn{padding:10px 12px;font-size:13px;gap:6px;}
  .foot-grid{grid-template-columns:1fr;}
  .prod-grid{grid-template-columns:1fr 1fr;gap:12px;}
  .prod-body{padding:12px 12px 14px;}
  .prod-name{font-size:15px;}
  .prod-desc{font-size:12px;}
  .prod-price{font-size:18px;}
  .prod-price-hint{font-size:10px;padding:2px 5px;}
  .buy-btn{padding:10px 10px;font-size:12px;gap:4px;}
  .buy-btn svg{width:13px;height:13px;}
  .prod-foot{gap:6px;}
  .catalog{padding:36px 14px;}
  .astrip-inner{grid-template-columns:repeat(2,1fr);gap:10px;}
  .astrip{padding:20px 14px;}
  .smartcafe-page{padding:24px 14px 40px;}
}

/* ── FOOTER redesign ── */
.foot-main {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
  margin-bottom: 36px;
}
@media (max-width: 720px) {
  .foot-main { grid-template-columns: 1fr; gap: 28px; }
}

.foot-logo { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.foot-tagline { font-size: 13px; color: var(--text3); margin-bottom: 20px; }

.foot-contact-list { list-style: none; margin: 0 0 20px; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.foot-contact-list li { display: flex; align-items: flex-start; gap: 9px; font-size: 14px; color: var(--caramel); }
.foot-contact-list li svg { flex-shrink: 0; margin-top: 2px; stroke: var(--caramel); }
.foot-contact-list li a { color: var(--caramel); text-decoration: none; font-weight: 700; }
.foot-contact-list li a:hover { color: var(--caramel); }

.foot-socials { display: flex; gap: 10px; flex-wrap: wrap; }
.foot-social-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 16px; border-radius: var(--r);
  font-size: 13px; font-weight: 700; text-decoration: none;
  transition: opacity .18s;
}
.foot-social-btn:hover { opacity: .85; }
.foot-tg { background: #29a8e8; color: #fff; }
.foot-vb { background: #7b519c; color: #fff; }

.foot-map { display: flex; flex-direction: column; gap: 12px; }
.foot-map iframe { width: 100%; height: 260px; border-radius: 14px; border: 1.5px solid var(--border); }
.foot-map-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 700; color: var(--caramel);
  text-decoration: none;
}
.foot-map-link:hover { text-decoration: underline; }

/* ── Filter buttons (home page, JS-based) ── */
.filters .f-btn.active {
  background: var(--coffee);
  color: #fff;
  border-color: var(--coffee);
}
