/*
Theme Name: Blocks Pro
Description: Custom WordPress theme for construction blocks landing page. Features modern design with multiple color themes, responsive layout, and product catalog functionality.
Author: Custom Development
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 7.2.24
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: blocks-pro
*/

/* -----------------------
   Base & Theme Variables
----------------------- */
:root{
  --bg: #ffffff;
  --surface: #f6f7f9;
  --surface-2:#eceff3;
  --text: #111418;
  --muted:#5b6470;
  --accent:#ff5a2b;
  --accent-2:#ff7a2b;
  --accent-contrast:#ffffff;
  --radius: 16px;
  --shadow: 0 8px 22px rgba(16,24,40,.08), 0 2px 6px rgba(16,24,40,.06);
  --card-border: 1px solid rgba(17,20,24,.08);
  --ring: 0 0 0 3px color-mix(in oklab, var(--accent), #fff 80%);
  --maxw: 1200px;
  --container-pad: clamp(14px, 2.6vw, 24px);
}


/* Reset */
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font: 16px/1.55 system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji";
  background: var(--bg);
  color: var(--text);
  letter-spacing:.2px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw); margin-inline:auto; padding-inline:var(--container-pad)}

/* Buttons */
.btn{display:inline-flex; align-items:center; gap:10px; padding:12px 18px; border-radius:12px; border:1px solid transparent; cursor:pointer; font-weight:600; transition: .2s ease; box-shadow:none; }
.btn:focus-visible{outline:none; box-shadow: var(--ring)}
.btn--primary{ background:linear-gradient(135deg, var(--accent), var(--accent-2)); color:var(--accent-contrast); box-shadow: var(--shadow)}
.btn--primary:hover{ transform:translateY(-1px) scale(1.01)}
.btn--ghost{ background:transparent; border:1px dashed color-mix(in oklab, var(--text), #fff 70%); color:var(--text)}
.btn--ghost:hover{ border-style:solid; transform:translateY(-1px)}

/* Inputs */
.field{display:grid; gap:6px}
.field label{font-weight:700; font-size:14px}
.field input[type="text"], .field input[type="tel"], .field input[type="number"], .field select, .field textarea{
  padding:12px 12px; border-radius: 12px;
  border:1px solid color-mix(in oklab, var(--text), #fff 82%);
  background: var(--bg); color: var(--text);
}
.field input:focus, .field select:focus, .field textarea:focus{outline:none; box-shadow: var(--ring)}

/* Pills / badges */
.pill{display:inline-flex; align-items:center; gap:8px; border-radius:999px; padding:8px 12px; background:var(--surface-2); border:var(--card-border); color:var(--muted); font-weight:600;}

/* Header */
header.site-header{
  position:sticky; top:0; z-index:50; backdrop-filter:saturate(1.2) blur(10px);
  background: color-mix(in oklab, var(--bg), transparent 10%);
  border-bottom: 1px solid color-mix(in oklab, var(--text), transparent 92%);
}
.nav{display:flex; align-items:center; justify-content:space-between; padding-block: clamp(10px, 1.6vw, 14px); gap:16px}
.brand{display:flex; align-items:center; gap:12px; font-weight:900; letter-spacing:.4px; font-size:20px}
.brand .logo{width:40px; height:40px; border-radius:10px; background: url(/wp-content/uploads/2026/02/cropped-cropped-block-icon.png) no-repeat center center / cover; box-shadow: var(--shadow)}
.nav-links{display:flex; gap:18px; align-items:center; flex-wrap:wrap}
.nav-links a{opacity:.9}
.nav-cta{display:flex; gap:12px; align-items:center}

.menu-btn{display:none}

/* Mobile drawer */
.drawer{position:fixed; inset:0 0 0 auto; width:min(86%, 360px); background:var(--bg); border-left:var(--card-border); transform:translateX(100%); transition:transform .25s ease; z-index:60; display:flex; flex-direction:column}
.drawer.open{transform:none}
.drawer header{display:flex; justify-content:space-between; align-items:center; padding:14px var(--container-pad); border-bottom:1px solid color-mix(in oklab, var(--text), transparent 90%)}
.drawer nav{display:grid; gap:10px; padding:12px var(--container-pad) 24px}
.drawer-backdrop{position:fixed; inset:0; background: color-mix(in oklab, var(--text), transparent 70%); opacity:0; pointer-events:none; transition:.2s; z-index:59}
.drawer-backdrop.open{opacity:1; pointer-events:auto}

/* Hero */
.hero{position:relative; padding: clamp(32px, 6vw, 56px) 0 32px; overflow:hidden; background:
  radial-gradient(1200px 500px at 85% -10%, color-mix(in oklab, var(--accent), transparent 80%), transparent),
  radial-gradient(800px 400px at -10% 10%, color-mix(in oklab, var(--accent-2), transparent 85%), transparent);
}
.hero-grid{display:grid; grid-template-columns: 1.1fr .9fr; gap: clamp(16px, 3vw, 36px); align-items:center}
.hero h1{font-size: clamp(28px, 4vw, 56px); line-height:1.05; margin: 6px 0 16px; letter-spacing:.2px}
.hero p.lead{font-size: clamp(16px, 1.4vw, 20px); color:var(--muted); margin:0 0 22px}
.hero .action{display:flex; gap:12px; flex-wrap:wrap}
.hero .card{background:var(--surface); border:var(--card-border); padding: 18px; border-radius: var(--radius); box-shadow: var(--shadow)}

/* Sections & Grid */
section{padding: clamp(30px, 6vw, 48px) 0}
.section-head{display:flex; align-items:end; justify-content:space-between; gap:16px; margin-bottom:18px}
.section-head h2{font-size: clamp(22px, 2.6vw, 34px); margin:0}
.grid{display:grid; grid-template-columns: repeat(12, 1fr); gap: clamp(12px, 2vw, 18px)}
.grid.cards>.card{grid-column: span 4; min-width: 250px}
.card{ background: var(--bg); border:var(--card-border); border-radius: var(--radius); box-shadow: var(--shadow); padding:18px; display:flex; flex-direction:column; gap:12px}
.card .thumb{background: var(--surface-2); border-radius: 12px; aspect-ratio: 16/10; display:grid; place-items:center; border:var(--card-border);}
.card .thumb img{width:100%; height: 100%; object-fit: contain; }
.card .thumb svg{opacity:.9}
.card h3{margin:0; font-size:18px}
.card .meta{color:var(--muted); font-size:14px}
.card .meta.sizes{white-space: pre-line}
.card .row{display:flex; justify-content:space-between; align-items:center; gap:12px; margin-top: auto}

/* Features */
.features{display:grid; grid-template-columns: repeat(3, 1fr); gap: clamp(12px, 2vw, 18px)}
.feature{background:var(--surface); border:var(--card-border); border-radius:var(--radius); padding:18px; display:flex; gap:14px; align-items:flex-start}
.feature h4{margin:2px 0 6px}
.feature p{margin:0; color:var(--muted)}
.avatar{min-width:40px; height:40px; border-radius:999px; box-shadow: var(--shadow)}

/* Reviews */
.people-reviews{display:grid; grid-template-columns: repeat(3, 1fr); gap: clamp(12px,2vw,18px)}

/* Contact */
.contact{display:grid; grid-template-columns: 1fr 1fr; gap: clamp(12px, 2vw, 18px)}
.contact .card{gap:14px}
.contact .card ul{margin:0; padding-left: 18px}
.contact .card li{margin:6px 0; color:var(--muted)}

/* Selection inside contact */
.selection{display:grid; gap:10px}
.sel-row{display:grid; grid-template-columns: 1fr 160px; gap:8px; align-items:center}
.sel-row .name{display:flex; align-items:center; gap:10px}

/* Footer */
footer{padding:32px 0 60px; margin-top:18px; color:var(--muted)}

/* Modal */
.modal{position:fixed; inset:0; background: color-mix(in oklab, var(--text), transparent 70%); display:none; place-items:center; padding:24px}
.modal.open{display:grid}
.modal .dialog{background:var(--bg); border:var(--card-border); border-radius: 18px; width:min(720px, 100%); box-shadow: var(--shadow)}
.dialog header{display:flex; align-items:center; justify-content:space-between; padding:16px 18px; border-bottom: 1px solid color-mix(in oklab, var(--text), transparent 88%)}
.dialog .body{padding:18px}

/* Animations */
[data-animate]{opacity:0; transform: translateY(8px); transition:.5s ease}
[data-animate].in{opacity:1; transform:none}

/* Responsive tweaks */
@media (max-width: 1180px){
  .grid.cards>.card{grid-column: span 6}
}
@media (max-width: 860px){
  .features{grid-template-columns:1fr}
  .people-reviews{grid-template-columns:1fr}
  .nav-links{display:none}
  .menu-btn{display:inline-flex}
  .hero-grid{grid-template-columns: 1fr}
  .sel-row{grid-template-columns: 1fr 1fr}
}
@media (max-width: 540px){
  .grid.cards>.card{grid-column: span 12}
  .hero .action{flex-direction:column; align-items:stretch}
  .contact{grid-template-columns: 1fr}
  .brand{font-size:18px}
  .brand .logo{width:30px; height:30px}
  .btn{padding:12px 14px}
  #call > div[style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns: 1fr !important;
  }
}

/* WordPress specific styles */
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
}

@supports (-webkit-touch-callout: none) {

  .card .thumb{
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
  }

  .card .thumb img{
    width: auto;        /* ключ: НЕ 100% */
    height: auto;       /* ключ */
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    display: block;
  }

}

/* Admin bar adjustments */
.admin-bar .site-header {
  top: 32px;
}

@media screen and (max-width: 782px) {
  .admin-bar .site-header {
    top: 46px;
  }
}