/* ===== PIXSTONE theme styles — собрано из утверждённых макетов ===== */

/* --- БАЗА: variant4_shop (главная, шапка, футер, каталог, карточки) --- */

:root{
    --bg:#ffffff; --soft:#f5f6f7; --soft2:#eceef0; --ink:#1a1d21; --txt:#33373d;
    --mut:#80868e; --line:#e4e6e9; --accent:#1f5d52; --accent2:#27776a; --price:#15181c;
    --ok:#2e9e5b; --star:#f5a623;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  body{background:var(--bg);color:var(--txt);font-family:'Inter',sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased;font-size:15px}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:1320px;margin:0 auto;padding:0 24px}
  /* stone textures */
  .stone-marble{background:linear-gradient(135deg,#eef0ef,#d9dcdb);position:relative;overflow:hidden}
  .stone-marble:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(48deg,rgba(90,95,100,.13) 0 1px,transparent 1px 26px),repeating-linear-gradient(126deg,rgba(120,128,132,.07) 0 2px,transparent 2px 18px)}
  .stone-granite{background:#c9ccc6;background-image:radial-gradient(rgba(55,60,58,.34) 1px,transparent 1.4px),radial-gradient(rgba(140,146,142,.30) 1px,transparent 1.4px);background-size:6px 6px,10px 10px}
  .stone-onyx{background:linear-gradient(135deg,#e7d6b4,#cdac76);position:relative;overflow:hidden}
  .stone-onyx:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(70deg,rgba(150,110,55,.20) 0 2px,transparent 2px 16px)}
  .stone-travertine{background:#e2d7c3;background-image:radial-gradient(rgba(120,100,68,.20) 1.5px,transparent 2px);background-size:8px 8px}
  .stone-quartzite{background:linear-gradient(135deg,#dde0e5,#c4c8d0);position:relative;overflow:hidden}
  .stone-quartzite:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(100deg,rgba(100,108,128,.16) 0 1px,transparent 1px 20px)}
  .stone-limestone{background:linear-gradient(135deg,#eae3d4,#d6ccb9)}
  .stone-slate{background:linear-gradient(135deg,#3a4047,#22272c);position:relative;overflow:hidden}
  .stone-slate:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(60deg,rgba(255,255,255,.05) 0 1px,transparent 1px 24px)}

  /* ===== top utility bar ===== */
  .util{background:var(--ink);color:#c2c7cd;font-size:13px}
  .util .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
  .util a{color:#c2c7cd}.util a:hover{color:#fff}
  .util .l span{margin-right:22px}
  .util .r a{margin-left:20px}

  /* ===== header ===== */
  header{border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;background:#fff}
  .hbar{display:flex;align-items:center;gap:26px;height:78px}
  .logo{font-weight:800;font-size:25px;letter-spacing:.02em;color:var(--ink);white-space:nowrap}
  .logo b{color:var(--accent)}
  .logo i{display:block;font-style:normal;font-size:10px;font-weight:500;letter-spacing:.24em;color:var(--mut);text-transform:uppercase}
  /* catalog button */
  .catbtn{display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:#fff;font-weight:600;font-size:15px;padding:13px 20px;border-radius:8px;cursor:pointer;white-space:nowrap}
  .catbtn:hover{background:var(--accent2)}
  .catbtn .bars{display:inline-flex;flex-direction:column;gap:3px}
  .catbtn .bars i{width:16px;height:2px;background:#fff;border-radius:2px}
  /* search */
  .search{flex:1;display:flex;border:1.5px solid var(--line);border-radius:9px;overflow:hidden}
  .search input{flex:1;border:none;padding:13px 16px;font-family:inherit;font-size:15px;color:var(--ink)}
  .search input:focus{outline:none}
  .search button{border:none;background:var(--soft2);color:var(--ink);padding:0 18px;cursor:pointer;font-size:17px}
  .search button:hover{background:var(--line)}
  /* header icons */
  .hicons{display:flex;gap:8px}
  .hicon{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 12px;border-radius:8px;color:var(--txt);font-size:11.5px;position:relative;cursor:pointer}
  .hicon:hover{background:var(--soft)}
  .hicon .ic{font-size:21px}
  .hicon .cnt{position:absolute;top:2px;right:6px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}
  .hphone{text-align:right;white-space:nowrap}
  .hphone a{font-weight:700;font-size:17px;color:var(--ink)}
  .hphone small{display:block;font-size:11.5px;color:var(--mut)}
  /* nav row */
  .navrow{border-top:1px solid var(--line)}
  .navrow ul{display:flex;gap:28px;list-style:none;height:46px;align-items:center;font-size:14px;font-weight:500}
  .navrow a{color:var(--txt)}.navrow a:hover{color:var(--accent)}
  .navrow .sale{color:#d23f3f}

  /* ===== hero (compact promo) ===== */
  .hero{padding:22px 0}
  .hero .grid{display:grid;grid-template-columns:1fr 320px;gap:18px}
  .promo{position:relative;border-radius:14px;overflow:hidden;min-height:340px;display:flex;align-items:center}
  .promo .bg{position:absolute;inset:0}
  .promo .bg:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(16,22,20,.9),rgba(16,22,20,.4) 60%,transparent)}
  .promo .in{position:relative;z-index:1;color:#fff;padding:0 48px;max-width:600px}
  .promo .tag{display:inline-block;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);font-size:12.5px;font-weight:600;padding:6px 13px;border-radius:20px;margin-bottom:16px}
  .promo h1{font-size:38px;font-weight:800;line-height:1.08;margin-bottom:14px;letter-spacing:-.02em}
  .promo p{font-size:15.5px;color:#dfe4e1;margin-bottom:22px;max-width:440px}
  .promo .row{display:flex;gap:12px;align-items:center}
  .btn{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;font-weight:600;font-size:15px;padding:14px 26px;border-radius:9px;border:none;cursor:pointer;font-family:inherit;transition:.2s}
  .btn:hover{background:var(--accent2)}
  .btn-w{background:#fff;color:var(--ink)}.btn-w:hover{background:#eef0f0}
  .btn-out{background:transparent;border:1.5px solid var(--line);color:var(--ink)}.btn-out:hover{border-color:var(--ink)}
  /* side promos */
  .sidep{display:flex;flex-direction:column;gap:18px}
  .spromo{flex:1;border-radius:14px;padding:22px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;min-height:161px}
  .spromo .bg{position:absolute;inset:0}.spromo .bg:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(20,24,22,.78))}
  .spromo .in{position:relative;z-index:1;color:#fff}
  .spromo h4{font-size:18px;font-weight:700;margin-bottom:4px}
  .spromo span{font-size:13px;color:#e0e4e2}

  /* ===== benefits strip ===== */
  .bstrip{border:1px solid var(--line);border-radius:14px;display:grid;grid-template-columns:repeat(4,1fr);margin:8px 0 6px;overflow:hidden}
  .bstrip .b{display:flex;gap:13px;align-items:center;padding:18px 22px;border-right:1px solid var(--line)}
  .bstrip .b:last-child{border-right:none}
  .bstrip .ic{font-size:23px;color:var(--accent)}
  .bstrip h5{font-size:14.5px;font-weight:600;color:var(--ink);margin-bottom:1px}
  .bstrip p{font-size:12.5px;color:var(--mut)}

  /* ===== section heads ===== */
  section{padding:34px 0}
  .shead{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
  .shead h2{font-size:26px;font-weight:800;color:var(--ink);letter-spacing:-.01em}
  .shead a{color:var(--accent);font-weight:600;font-size:14px}

  /* ===== category tiles ===== */
  .ctiles{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
  .ctile{border:1px solid var(--line);border-radius:12px;overflow:hidden;text-align:center;transition:.18s;background:#fff}
  .ctile:hover{border-color:var(--accent);box-shadow:0 8px 22px rgba(31,93,82,.10)}
  .ctile .img{height:104px}
  .ctile .b{padding:12px 8px 14px}
  .ctile h4{font-size:14px;font-weight:600;color:var(--ink)}
  .ctile span{font-size:12px;color:var(--mut)}

  /* ===== catalog: filters + product grid ===== */
  .catalog{display:grid;grid-template-columns:248px 1fr;gap:24px;align-items:start}
  .filters{border:1px solid var(--line);border-radius:14px;padding:20px;position:sticky;top:140px}
  .filters h3{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:14px}
  .fgroup{border-top:1px solid var(--line);padding:15px 0}
  .fgroup>p{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:10px;display:flex;justify-content:space-between}
  .fopt{display:flex;align-items:center;gap:9px;font-size:13.5px;margin-bottom:9px;cursor:pointer;color:var(--txt)}
  .fopt input{accent-color:var(--accent);width:15px;height:15px}
  .fopt .c{margin-left:auto;color:var(--mut);font-size:12px}
  .prange{display:flex;gap:8px;margin-top:4px}
  .prange input{width:50%;border:1px solid var(--line);border-radius:7px;padding:9px;font-size:13px;font-family:inherit}
  /* toolbar */
  .ctop{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:14px;flex-wrap:wrap}
  .chips{display:flex;gap:8px;flex-wrap:wrap}
  .chip{background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px 14px;font-size:13.5px;font-weight:500;cursor:pointer}
  .chip.on,.chip:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
  .sort{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--mut)}
  .sort select{border:1px solid var(--line);border-radius:8px;padding:9px 12px;font-family:inherit;font-size:13.5px;color:var(--ink)}
  /* product grid */
  .pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
  .prod{border:1px solid var(--line);border-radius:13px;overflow:hidden;background:#fff;transition:.18s;display:flex;flex-direction:column}
  .prod:hover{box-shadow:0 12px 30px rgba(26,29,33,.10);border-color:#d3d6da}
  .prod .img{height:188px;position:relative}
  .prod .lab{position:absolute;top:10px;left:10px;display:flex;gap:6px}
  .prod .lab span{font-size:11px;font-weight:700;padding:4px 9px;border-radius:6px}
  .lab .hit{background:#fde9d6;color:#c5651f}
  .lab .new{background:#dff3e6;color:#1f7a45}
  .prod .fav{position:absolute;top:10px;right:10px;width:32px;height:32px;border-radius:8px;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;color:var(--mut);cursor:pointer}
  .prod .fav:hover{color:#d23f3f}
  .prod .b{padding:14px 15px 16px;display:flex;flex-direction:column;flex:1}
  .prod .avail{font-size:12px;color:var(--ok);font-weight:600;display:flex;align-items:center;gap:6px;margin-bottom:7px}
  .prod .avail:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--ok)}
  .prod h3{font-size:15.5px;font-weight:600;color:var(--ink);margin-bottom:5px;line-height:1.3}
  .prod .meta{font-size:12.5px;color:var(--mut);margin-bottom:14px}
  .prod .rate{font-size:12px;color:var(--mut);margin-bottom:12px}
  .prod .rate b{color:var(--star)}
  .prod .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px}
  .prod .price{font-weight:800;font-size:19px;color:var(--price);white-space:nowrap}
  .prod .price small{display:block;font-size:11px;color:var(--mut);font-weight:500}
  .addcart{background:var(--accent);color:#fff;border:none;border-radius:9px;padding:11px 16px;font-weight:600;font-size:13.5px;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
  .addcart:hover{background:var(--accent2)}
  .loadmore{text-align:center;margin-top:22px}

  /* ===== stone catalog row ===== */
  .stones{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
  .stone{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff;transition:.18s}
  .stone:hover{border-color:var(--accent);box-shadow:0 8px 22px rgba(31,93,82,.10)}
  .stone .sw{height:130px}
  .stone .b{padding:12px 14px 14px;display:flex;justify-content:space-between;align-items:center}
  .stone h4{font-size:15px;font-weight:600;color:var(--ink)}
  .stone span{font-size:12px;color:var(--mut)}
  .stone .pr{font-size:13px;font-weight:700;color:var(--accent)}

  /* ===== how / steps ===== */
  .howsec{background:var(--soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .steps{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
  .stp{background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px 18px}
  .stp .n{font-weight:800;font-size:14px;color:#fff;background:var(--ink);width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
  .stp h3{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:7px}
  .stp p{font-size:13px;color:var(--mut)}

  /* ===== seo text + faq ===== */
  .seo{display:grid;grid-template-columns:1.3fr 1fr;gap:40px}
  .seo h2{font-size:24px;font-weight:800;color:var(--ink);margin-bottom:14px}
  .seo p{font-size:14.5px;color:var(--txt);margin-bottom:12px}
  details{border:1px solid var(--line);border-radius:11px;margin-bottom:10px;padding:0 18px;background:#fff}
  summary{cursor:pointer;list-style:none;padding:16px 0;font-weight:600;font-size:15px;color:var(--ink);display:flex;justify-content:space-between;gap:14px}
  summary::-webkit-details-marker{display:none}
  summary:after{content:"+";color:var(--accent);font-size:20px}
  details[open] summary:after{content:"–"}
  details p{padding:0 0 18px;color:var(--mut);font-size:14px}

  /* ===== footer ===== */
  footer{background:var(--ink);color:#aab0b7;padding:50px 0 26px;font-size:14px;margin-top:8px}
  .subbar{background:#15181c;border-radius:14px;padding:26px 30px;display:flex;justify-content:space-between;align-items:center;gap:20px;margin-bottom:40px;flex-wrap:wrap}
  .subbar h3{color:#fff;font-size:20px;font-weight:700;margin-bottom:4px}
  .subbar p{color:#9aa0a7;font-size:13.5px}
  .subbar .f{display:flex;gap:10px}
  .subbar input{border:1px solid #343a40;background:#1d2126;color:#fff;border-radius:9px;padding:13px 16px;font-family:inherit;width:240px}
  .fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:38px}
  .fgrid .logo{color:#fff;font-size:21px;margin-bottom:12px}
  .fgrid .logo b{color:var(--accent2)}
  .fgrid h4{color:#fff;font-size:13.5px;font-weight:700;margin-bottom:16px}
  .fgrid ul{list-style:none;display:flex;flex-direction:column;gap:10px}
  .fgrid a:hover{color:#fff}
  .fbot{border-top:1px solid #2a2f35;padding-top:22px;display:flex;justify-content:space-between;color:#7b818a;font-size:12.5px;flex-wrap:wrap;gap:10px}

  @media(max-width:1100px){
    .ctiles,.stones{grid-template-columns:repeat(3,1fr)}
    .catalog{grid-template-columns:1fr}.filters{position:static}
    .pgrid{grid-template-columns:repeat(2,1fr)}
    .hero .grid{grid-template-columns:1fr}.sidep{flex-direction:row}
  }
  @media(max-width:760px){
    .util,.navrow,.hphone small,.search{display:none}
    .bstrip,.steps{grid-template-columns:1fr 1fr}
    .ctiles,.stones,.pgrid,.sidep{grid-template-columns:1fr 1fr}
    .seo{grid-template-columns:1fr}.promo h1{font-size:28px}
    .bstrip .b{border-right:none;border-bottom:1px solid var(--line)}
  }

/* --- КАТЕГОРИЯ: листинг, фильтры-сайдбар, крошки, пагинация, свотчи --- */

:root{--bg:#fff;--soft:#f5f6f7;--soft2:#eceef0;--ink:#1a1d21;--txt:#33373d;--mut:#80868e;--line:#e4e6e9;--accent:#1f5d52;--accent2:#27776a;--price:#15181c;--ok:#2e9e5b;--star:#f5a623}
  *{margin:0;padding:0;box-sizing:border-box}
  body{background:var(--bg);color:var(--txt);font-family:'Inter',sans-serif;line-height:1.55;font-size:15px;-webkit-font-smoothing:antialiased}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:1320px;margin:0 auto;padding:0 24px}
  .stone-marble{background:linear-gradient(135deg,#eef0ef,#d9dcdb);position:relative;overflow:hidden}
  .stone-marble:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(48deg,rgba(90,95,100,.13) 0 1px,transparent 1px 26px),repeating-linear-gradient(126deg,rgba(120,128,132,.07) 0 2px,transparent 2px 18px)}
  .stone-granite{background:#c9ccc6;background-image:radial-gradient(rgba(55,60,58,.34) 1px,transparent 1.4px),radial-gradient(rgba(140,146,142,.30) 1px,transparent 1.4px);background-size:6px 6px,10px 10px}
  .stone-onyx{background:linear-gradient(135deg,#e7d6b4,#cdac76);position:relative;overflow:hidden}
  .stone-onyx:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(70deg,rgba(150,110,55,.20) 0 2px,transparent 2px 16px)}
  .stone-travertine{background:#e2d7c3;background-image:radial-gradient(rgba(120,100,68,.20) 1.5px,transparent 2px);background-size:8px 8px}
  .stone-quartzite{background:linear-gradient(135deg,#dde0e5,#c4c8d0);position:relative;overflow:hidden}
  .stone-quartzite:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(100deg,rgba(100,108,128,.16) 0 1px,transparent 1px 20px)}
  .stone-limestone{background:linear-gradient(135deg,#eae3d4,#d6ccb9)}
  .stone-slate{background:linear-gradient(135deg,#3a4047,#22272c);position:relative;overflow:hidden}
  .stone-slate:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(60deg,rgba(255,255,255,.05) 0 1px,transparent 1px 24px)}
  /* util + header (shared) */
  .util{background:var(--ink);color:#c2c7cd;font-size:13px}
  .util .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
  .util a{color:#c2c7cd}.util a:hover{color:#fff}.util .l span{margin-right:22px}.util .r a{margin-left:20px}
  header{border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;background:#fff}
  .hbar{display:flex;align-items:center;gap:26px;height:78px}
  .logo{font-weight:800;font-size:25px;color:var(--ink);white-space:nowrap}.logo b{color:var(--accent)}
  .logo i{display:block;font-style:normal;font-size:10px;font-weight:500;letter-spacing:.24em;color:var(--mut);text-transform:uppercase}
  .catbtn{display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:#fff;font-weight:600;padding:13px 20px;border-radius:8px;cursor:pointer;white-space:nowrap}
  .catbtn:hover{background:var(--accent2)}.catbtn .bars{display:inline-flex;flex-direction:column;gap:3px}.catbtn .bars i{width:16px;height:2px;background:#fff;border-radius:2px}
  .search{flex:1;display:flex;border:1.5px solid var(--line);border-radius:9px;overflow:hidden}
  .search input{flex:1;border:none;padding:13px 16px;font-family:inherit;font-size:15px;color:var(--ink)}.search input:focus{outline:none}
  .search button{border:none;background:var(--soft2);color:var(--ink);padding:0 18px;cursor:pointer;font-size:17px}
  .hicons{display:flex;gap:8px}.hicon{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 12px;border-radius:8px;font-size:11.5px;position:relative;cursor:pointer}
  .hicon:hover{background:var(--soft)}.hicon .ic{font-size:21px}
  .hicon .cnt{position:absolute;top:2px;right:6px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}
  .hphone{text-align:right;white-space:nowrap}.hphone a{font-weight:700;font-size:17px;color:var(--ink)}.hphone small{display:block;font-size:11.5px;color:var(--mut)}
  .navrow{border-top:1px solid var(--line)}.navrow ul{display:flex;gap:28px;list-style:none;height:46px;align-items:center;font-size:14px;font-weight:500}
  .navrow a:hover{color:var(--accent)}.navrow .sale{color:#d23f3f}
  .btn{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;font-weight:600;font-size:15px;padding:13px 24px;border-radius:9px;border:none;cursor:pointer;font-family:inherit;transition:.2s}
  .btn:hover{background:var(--accent2)}
  .btn-out{background:#fff;border:1.5px solid var(--line);color:var(--ink)}.btn-out:hover{border-color:var(--ink)}

  /* breadcrumbs */
  .crumbs{font-size:13px;color:var(--mut);padding:16px 0}
  .crumbs a:hover{color:var(--accent)}.crumbs span{margin:0 8px}
  /* category head */
  .chead{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:8px;flex-wrap:wrap}
  .chead h1{font-size:30px;font-weight:800;color:var(--ink);letter-spacing:-.01em}
  .chead .cnt{color:var(--mut);font-size:14px;margin-top:4px}
  /* subcategory quick chips */
  .subcats{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 22px}
  .subcat{display:flex;align-items:center;gap:9px;border:1px solid var(--line);border-radius:30px;padding:7px 7px 7px 14px;font-size:13.5px;font-weight:500;background:#fff}
  .subcat:hover{border-color:var(--accent)}
  .subcat .ph{width:30px;height:30px;border-radius:50%}

  /* layout */
  .layout{display:grid;grid-template-columns:262px 1fr;gap:26px;align-items:start;padding-bottom:20px}
  .filters{border:1px solid var(--line);border-radius:14px;padding:20px;position:sticky;top:140px}
  .filters h3{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:6px;display:flex;justify-content:space-between}
  .filters h3 a{font-size:12px;color:var(--accent);font-weight:500}
  .fgroup{border-top:1px solid var(--line);padding:15px 0}
  .fgroup>p{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:10px}
  .fopt{display:flex;align-items:center;gap:9px;font-size:13.5px;margin-bottom:9px;cursor:pointer}
  .fopt input{accent-color:var(--accent);width:15px;height:15px}.fopt .c{margin-left:auto;color:var(--mut);font-size:12px}
  .prange{display:flex;gap:8px}.prange input{width:50%;border:1px solid var(--line);border-radius:7px;padding:9px;font-size:13px;font-family:inherit}
  .swatches{display:flex;gap:8px;flex-wrap:wrap}
  .swatches .s{width:30px;height:30px;border-radius:7px;border:1px solid var(--line);cursor:pointer}
  .swatches .s.on{outline:2px solid var(--accent);outline-offset:2px}

  /* toolbar */
  .ctop{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:14px;flex-wrap:wrap}
  .chips{display:flex;gap:8px;flex-wrap:wrap}
  .chip{background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px 14px;font-size:13.5px;font-weight:500;cursor:pointer}
  .chip.on,.chip:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
  .sort{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--mut)}
  .sort select{border:1px solid var(--line);border-radius:8px;padding:9px 12px;font-family:inherit;font-size:13.5px;color:var(--ink)}
  .viewtog{display:flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}
  .viewtog span{padding:8px 11px;cursor:pointer;font-size:15px;color:var(--mut)}.viewtog span.on{background:var(--soft);color:var(--ink)}

  /* product grid */
  .pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
  .prod{border:1px solid var(--line);border-radius:13px;overflow:hidden;background:#fff;transition:.18s;display:flex;flex-direction:column}
  .prod:hover{box-shadow:0 12px 30px rgba(26,29,33,.10);border-color:#d3d6da}
  .prod .img{height:188px;position:relative;display:block}
  .prod .lab{position:absolute;top:10px;left:10px;display:flex;gap:6px}
  .prod .lab span{font-size:11px;font-weight:700;padding:4px 9px;border-radius:6px}
  .lab .hit{background:#fde9d6;color:#c5651f}.lab .new{background:#dff3e6;color:#1f7a45}.lab .sale{background:#fde0e0;color:#cc3434}
  .prod .fav{position:absolute;top:10px;right:10px;width:32px;height:32px;border-radius:8px;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;color:var(--mut);cursor:pointer}
  .prod .fav:hover{color:#d23f3f}
  .prod .b{padding:14px 15px 16px;display:flex;flex-direction:column;flex:1}
  .prod .avail{font-size:12px;color:var(--ok);font-weight:600;display:flex;align-items:center;gap:6px;margin-bottom:7px}
  .prod .avail:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--ok)}
  .prod h3{font-size:15.5px;font-weight:600;color:var(--ink);margin-bottom:5px;line-height:1.3}
  .prod .meta{font-size:12.5px;color:var(--mut);margin-bottom:11px}
  .prod .rate{font-size:12px;color:var(--mut);margin-bottom:12px}.prod .rate b{color:var(--star)}
  .prod .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px}
  .prod .price{font-weight:800;font-size:19px;color:var(--price);white-space:nowrap}
  .prod .price .old{display:block;font-size:12px;color:var(--mut);font-weight:500;text-decoration:line-through}
  .prod .price small{display:block;font-size:11px;color:var(--mut);font-weight:500}
  .addcart{background:var(--accent);color:#fff;border:none;border-radius:9px;padding:11px 15px;font-weight:600;font-size:13.5px;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
  .addcart:hover{background:var(--accent2)}

  /* pagination */
  .pager{display:flex;gap:8px;justify-content:center;margin:30px 0 6px}
  .pager a{min-width:42px;height:42px;border:1px solid var(--line);border-radius:9px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;color:var(--txt)}
  .pager a.on{background:var(--accent);color:#fff;border-color:var(--accent)}.pager a:hover:not(.on){border-color:var(--ink)}

  /* seo block */
  .seo{border-top:1px solid var(--line);padding:34px 0}
  .seo h2{font-size:22px;font-weight:800;color:var(--ink);margin-bottom:14px}
  .seo p{font-size:14.5px;color:var(--txt);margin-bottom:12px;max-width:980px}
  .seo h3{font-size:17px;font-weight:700;color:var(--ink);margin:18px 0 8px}
  .seo ul{margin:0 0 12px 20px;color:var(--txt);font-size:14.5px}.seo li{margin-bottom:6px}

  /* footer */
  footer{background:var(--ink);color:#aab0b7;padding:50px 0 26px;font-size:14px;margin-top:10px}
  .fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:38px}
  .fgrid .logo{color:#fff;font-size:21px;margin-bottom:12px}.fgrid .logo b{color:var(--accent2)}
  .fgrid h4{color:#fff;font-size:13.5px;font-weight:700;margin-bottom:16px}
  .fgrid ul{list-style:none;display:flex;flex-direction:column;gap:10px}.fgrid a:hover{color:#fff}
  .fbot{border-top:1px solid #2a2f35;padding-top:22px;display:flex;justify-content:space-between;color:#7b818a;font-size:12.5px;flex-wrap:wrap;gap:10px}
  @media(max-width:1100px){.layout{grid-template-columns:1fr}.filters{position:static}.pgrid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:760px){.util,.navrow,.hphone small,.search{display:none}.pgrid{grid-template-columns:1fr 1fr}.fgrid{grid-template-columns:1fr 1fr}}

/* --- КАРТОЧКА ТОВАРА: галерея, конфигуратор, табы, похожие --- */

:root{--bg:#fff;--soft:#f5f6f7;--soft2:#eceef0;--ink:#1a1d21;--txt:#33373d;--mut:#80868e;--line:#e4e6e9;--accent:#1f5d52;--accent2:#27776a;--price:#15181c;--ok:#2e9e5b;--star:#f5a623}
  *{margin:0;padding:0;box-sizing:border-box}
  body{background:var(--bg);color:var(--txt);font-family:'Inter',sans-serif;line-height:1.55;font-size:15px;-webkit-font-smoothing:antialiased}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:1320px;margin:0 auto;padding:0 24px}
  .stone-marble{background:linear-gradient(135deg,#eef0ef,#d9dcdb);position:relative;overflow:hidden}
  .stone-marble:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(48deg,rgba(90,95,100,.13) 0 1px,transparent 1px 26px),repeating-linear-gradient(126deg,rgba(120,128,132,.07) 0 2px,transparent 2px 18px)}
  .stone-granite{background:#c9ccc6;background-image:radial-gradient(rgba(55,60,58,.34) 1px,transparent 1.4px),radial-gradient(rgba(140,146,142,.30) 1px,transparent 1.4px);background-size:6px 6px,10px 10px}
  .stone-onyx{background:linear-gradient(135deg,#e7d6b4,#cdac76);position:relative;overflow:hidden}
  .stone-onyx:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(70deg,rgba(150,110,55,.20) 0 2px,transparent 2px 16px)}
  .stone-quartzite{background:linear-gradient(135deg,#dde0e5,#c4c8d0);position:relative;overflow:hidden}
  .stone-quartzite:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(100deg,rgba(100,108,128,.16) 0 1px,transparent 1px 20px)}
  .stone-travertine{background:#e2d7c3;background-image:radial-gradient(rgba(120,100,68,.20) 1.5px,transparent 2px);background-size:8px 8px}
  /* util + header */
  .util{background:var(--ink);color:#c2c7cd;font-size:13px}
  .util .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
  .util a{color:#c2c7cd}.util a:hover{color:#fff}.util .l span{margin-right:22px}.util .r a{margin-left:20px}
  header{border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;background:#fff}
  .hbar{display:flex;align-items:center;gap:26px;height:78px}
  .logo{font-weight:800;font-size:25px;color:var(--ink);white-space:nowrap}.logo b{color:var(--accent)}
  .logo i{display:block;font-style:normal;font-size:10px;font-weight:500;letter-spacing:.24em;color:var(--mut);text-transform:uppercase}
  .catbtn{display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:#fff;font-weight:600;padding:13px 20px;border-radius:8px;cursor:pointer;white-space:nowrap}
  .catbtn:hover{background:var(--accent2)}.catbtn .bars{display:inline-flex;flex-direction:column;gap:3px}.catbtn .bars i{width:16px;height:2px;background:#fff;border-radius:2px}
  .search{flex:1;display:flex;border:1.5px solid var(--line);border-radius:9px;overflow:hidden}
  .search input{flex:1;border:none;padding:13px 16px;font-family:inherit;font-size:15px;color:var(--ink)}.search input:focus{outline:none}
  .search button{border:none;background:var(--soft2);color:var(--ink);padding:0 18px;cursor:pointer;font-size:17px}
  .hicons{display:flex;gap:8px}.hicon{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 12px;border-radius:8px;font-size:11.5px;position:relative;cursor:pointer}
  .hicon:hover{background:var(--soft)}.hicon .ic{font-size:21px}
  .hicon .cnt{position:absolute;top:2px;right:6px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}
  .hphone{text-align:right;white-space:nowrap}.hphone a{font-weight:700;font-size:17px;color:var(--ink)}.hphone small{display:block;font-size:11.5px;color:var(--mut)}
  .navrow{border-top:1px solid var(--line)}.navrow ul{display:flex;gap:28px;list-style:none;height:46px;align-items:center;font-size:14px;font-weight:500}
  .navrow a:hover{color:var(--accent)}.navrow .sale{color:#d23f3f}
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--accent);color:#fff;font-weight:600;font-size:15px;padding:14px 24px;border-radius:9px;border:none;cursor:pointer;font-family:inherit;transition:.2s}
  .btn:hover{background:var(--accent2)}
  .btn-out{background:#fff;border:1.5px solid var(--line);color:var(--ink)}.btn-out:hover{border-color:var(--ink)}

  .crumbs{font-size:13px;color:var(--mut);padding:16px 0}.crumbs a:hover{color:var(--accent)}.crumbs span{margin:0 8px}

  /* product top */
  .ptop{display:grid;grid-template-columns:1.15fr 1fr;gap:34px;padding-bottom:20px}
  /* gallery */
  .gal .main{height:430px;border-radius:14px;position:relative;overflow:hidden;border:1px solid var(--line)}
  .gal .main .lab{position:absolute;top:14px;left:14px;background:#fde9d6;color:#c5651f;font-size:12px;font-weight:700;padding:5px 11px;border-radius:6px}
  .gal .thumbs{display:flex;gap:10px;margin-top:12px}
  .gal .thumbs .t{width:84px;height:70px;border-radius:9px;border:1px solid var(--line);cursor:pointer;overflow:hidden}
  .gal .thumbs .t.on{outline:2px solid var(--accent);outline-offset:1px}

  /* info column */
  .pinfo h1{font-size:27px;font-weight:800;color:var(--ink);letter-spacing:-.01em;line-height:1.2;margin-bottom:10px}
  .pmeta{display:flex;gap:18px;align-items:center;font-size:13px;color:var(--mut);margin-bottom:16px;flex-wrap:wrap}
  .pmeta .rate b{color:var(--star)}
  .pmeta .art{color:var(--mut)}
  .pavail{font-size:13.5px;color:var(--ok);font-weight:600;display:flex;align-items:center;gap:7px;margin-bottom:18px}
  .pavail:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--ok)}
  .pricebox{background:var(--soft);border:1px solid var(--line);border-radius:13px;padding:18px 20px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
  .pricebox .big{font-weight:800;font-size:30px;color:var(--price)}
  .pricebox .big small{font-size:14px;color:var(--mut);font-weight:500}
  .pricebox .note{font-size:12.5px;color:var(--mut);max-width:200px}

  /* configurator */
  .cfg{margin-bottom:8px}
  .cfg .row{margin-bottom:18px}
  .cfg .lbl{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:9px;display:flex;justify-content:space-between}
  .cfg .lbl span{color:var(--mut);font-weight:500}
  .opts{display:flex;gap:9px;flex-wrap:wrap}
  .opt{border:1.5px solid var(--line);border-radius:9px;padding:9px 15px;font-size:13.5px;font-weight:500;cursor:pointer;background:#fff}
  .opt.on{border-color:var(--accent);background:#eef4f2;color:var(--accent)}
  .opt:hover{border-color:var(--accent)}
  .stoneopts{display:flex;gap:10px;flex-wrap:wrap}
  .stoneopt{width:54px;cursor:pointer;text-align:center}
  .stoneopt .sw{width:54px;height:44px;border-radius:8px;border:1px solid var(--line)}
  .stoneopt.on .sw{outline:2px solid var(--accent);outline-offset:2px}
  .stoneopt span{font-size:10.5px;color:var(--mut);display:block;margin-top:4px}
  .dims{display:flex;gap:10px}
  .dims input{border:1.5px solid var(--line);border-radius:9px;padding:11px 13px;font-family:inherit;font-size:14px;width:110px}
  .dims input:focus{outline:none;border-color:var(--accent)}

  .buybar{display:flex;gap:12px;margin:22px 0 18px}
  .buybar .btn{flex:1;padding:16px}
  .buybar .fav{width:54px;border:1.5px solid var(--line);border-radius:9px;background:#fff;font-size:20px;color:var(--mut);cursor:pointer}
  .buybar .fav:hover{color:#d23f3f;border-color:#d23f3f}

  .ubenefits{display:grid;grid-template-columns:1fr 1fr;gap:12px;border-top:1px solid var(--line);padding-top:18px}
  .ub{display:flex;gap:11px;align-items:flex-start;font-size:13px}
  .ub .ic{font-size:18px;color:var(--accent)}
  .ub b{display:block;color:var(--ink);font-size:13.5px}.ub span{color:var(--mut)}

  /* tabs */
  .tabs{border-top:1px solid var(--line);margin-top:14px;padding-top:30px}
  .tabnav{display:flex;gap:8px;border-bottom:1px solid var(--line);margin-bottom:24px;flex-wrap:wrap}
  .tabnav a{padding:12px 20px;font-weight:600;font-size:15px;color:var(--mut);border-bottom:2px solid transparent;margin-bottom:-1px}
  .tabnav a.on{color:var(--ink);border-color:var(--accent)}
  .tabbody h3{font-size:18px;font-weight:700;color:var(--ink);margin:0 0 12px}
  .tabbody p{font-size:14.5px;margin-bottom:12px;max-width:820px}
  .tabpane{display:none}
  .tabpane.on{display:block}
  .spec{border:1px solid var(--line);border-radius:12px;overflow:hidden;align-self:start}
  .spec .r{display:flex;justify-content:space-between;gap:18px;padding:12px 16px;font-size:13.5px;border-bottom:1px solid var(--line)}
  .spec .r:last-child{border-bottom:none}.spec .r:nth-child(odd){background:var(--soft)}
  .spec .r span{color:var(--mut);flex:0 0 auto}.spec .r b{color:var(--ink);font-weight:600;text-align:right}
  .spec-full{max-width:760px}
  .spec-note{font-size:12.5px;color:var(--mut);margin-top:12px;max-width:760px}

  /* related */
  .rel{padding:40px 0}
  .rel h2{font-size:24px;font-weight:800;color:var(--ink);margin-bottom:20px}
  .pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
  .prod{border:1px solid var(--line);border-radius:13px;overflow:hidden;background:#fff;transition:.18s;display:flex;flex-direction:column}
  .prod:hover{box-shadow:0 12px 30px rgba(26,29,33,.10)}
  .prod .img{height:170px;display:block}
  .prod .b{padding:13px 14px 15px;display:flex;flex-direction:column;flex:1}
  .prod h3{font-size:14.5px;font-weight:600;color:var(--ink);margin-bottom:5px}
  .prod .meta{font-size:12px;color:var(--mut);margin-bottom:12px}
  .prod .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between}
  .prod .price{font-weight:800;font-size:17px;color:var(--price)}.prod .price small{display:block;font-size:11px;color:var(--mut);font-weight:500}
  .addcart{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:9px 13px;font-weight:600;font-size:13px;cursor:pointer;font-family:inherit}
  .addcart:hover{background:var(--accent2)}

  footer{background:var(--ink);color:#aab0b7;padding:50px 0 26px;font-size:14px;margin-top:8px}
  .fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:38px}
  .fgrid .logo{color:#fff;font-size:21px;margin-bottom:12px}.fgrid .logo b{color:var(--accent2)}
  .fgrid h4{color:#fff;font-size:13.5px;font-weight:700;margin-bottom:16px}
  .fgrid ul{list-style:none;display:flex;flex-direction:column;gap:10px}.fgrid a:hover{color:#fff}
  .fbot{border-top:1px solid #2a2f35;padding-top:22px;display:flex;justify-content:space-between;color:#7b818a;font-size:12.5px;flex-wrap:wrap;gap:10px}
  @media(max-width:1100px){.ptop{grid-template-columns:1fr}.pgrid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:760px){.util,.navrow,.hphone small,.search{display:none}.ubenefits,.fgrid{grid-template-columns:1fr}.gal .main{height:300px}}
/* === Доработки 2026-06-10: связка landing↔каталог, рейтинг, чипсы-ссылки === */
.chip{display:inline-block;text-decoration:none;color:var(--txt)}
a.chip{color:var(--txt)}
a.chip.on,a.chip:hover{color:#fff}
.prod .rate{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--mut);margin-bottom:10px}
.prod .rate .stars{color:var(--star);letter-spacing:1px}
.prod .rate .rv{font-weight:700;color:var(--ink)}
.rate .stars{color:var(--star,#f5a623);letter-spacing:1px}
.rate .rv{font-weight:700}
.catalog-embed{margin:38px 0 6px}
.catalog-embed .shead{margin-bottom:18px}
.catalog-embed .pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.embed-more{margin-top:22px;display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
@media(max-width:1100px){.catalog-embed .pgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.catalog-embed .pgrid{grid-template-columns:1fr}}

/* === Форма заявки в подвале (CF7) — аккуратная вёрстка === */
.subbar .f{max-width:460px;width:100%}
.subbar .f form{margin:0}
.subbar .f .leadform{display:flex;flex-wrap:wrap;gap:10px}
.subbar .f .wpcf7-form-control-wrap{flex:1 1 150px;display:block}
.subbar .f input[type=text],.subbar .f input[type=tel]{width:100%;border:1px solid #343a40;background:#1d2126;color:#fff;border-radius:9px;padding:13px 16px;font-family:inherit;font-size:14.5px}
.subbar .f input::placeholder{color:#7b818a}
.subbar .f input:focus{outline:none;border-color:var(--accent2);background:#22272d}
.subbar .f .wpcf7-submit{flex:1 1 100%;width:100%;background:var(--accent);color:#fff;border:none;border-radius:9px;padding:14px 20px;font-weight:600;font-size:15px;cursor:pointer;font-family:inherit;transition:.2s}
.subbar .f .wpcf7-submit:hover{background:var(--accent2)}
.subbar .f .wpcf7-spinner{margin:10px auto 0;display:block}
.subbar .f .wpcf7-response-output{flex:1 1 100%;margin:8px 0 0!important;padding:9px 13px!important;border-radius:8px;font-size:13px;color:#fff;border-color:rgba(255,255,255,.25)!important}
.subbar .f .wpcf7-not-valid-tip{color:#ff9b9b;font-size:12px;margin-top:4px}
@media(max-width:760px){.subbar{flex-direction:column;align-items:stretch}.subbar .f{max-width:none}}

/* === MIDBAND (прослойка между категориями и камнем) === */
.midband{padding:48px 0 10px;text-align:center}
.midband .eyebrow{display:inline-block;font-size:12.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.midband h2{font-size:30px;font-weight:800;color:var(--ink);letter-spacing:-.02em;max-width:780px;margin:0 auto 16px;line-height:1.12}
.midband p{font-size:15.5px;color:var(--txt);max-width:760px;margin:0 auto 12px;line-height:1.7}

/* === SEO + FAQ редизайн === */
.seo-sec{background:var(--soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-top:18px}
.seo-sec .wrap{padding-top:54px;padding-bottom:54px}
.seo-sec .seo{display:grid;grid-template-columns:1.1fr 1fr;gap:50px;align-items:start;border:0;padding:0;max-width:none}
.seo-sec .eyebrow{display:inline-block;font-size:12.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.seo-sec .seo-main h2{font-size:27px;font-weight:800;color:var(--ink);letter-spacing:-.02em;margin-bottom:14px}
.seo-sec .seo-main p{font-size:15px;color:var(--txt);line-height:1.7;margin-bottom:0;max-width:none}
.seo-stats{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:26px}
.seo-stats .st{background:#fff;border:1px solid var(--line);border-radius:13px;padding:18px 20px}
.seo-stats .st b{display:block;font-size:23px;font-weight:800;color:var(--accent);letter-spacing:-.01em;line-height:1.1;margin-bottom:5px}
.seo-stats .st span{font-size:13px;color:var(--mut)}
.seo-faq h2{font-size:22px;font-weight:800;color:var(--ink);margin-bottom:16px}
.seo-sec details{border:1px solid var(--line);border-radius:12px;margin-bottom:10px;padding:0 18px;background:#fff;transition:.18s;box-shadow:0 1px 2px rgba(0,0,0,.03)}
.seo-sec details[open]{border-color:var(--accent2);box-shadow:0 8px 22px rgba(31,93,82,.08)}
.seo-sec summary{cursor:pointer;list-style:none;padding:16px 0;font-weight:600;font-size:15px;color:var(--ink);display:flex;justify-content:space-between;gap:14px;transition:.15s}
.seo-sec summary:hover{color:var(--accent)}
.seo-sec summary::-webkit-details-marker{display:none}
.seo-sec summary:after{content:"+";color:var(--accent);font-size:21px;line-height:1;flex-shrink:0}
.seo-sec details[open] summary:after{content:"–"}
.seo-sec details p{padding:0 0 18px;color:var(--mut);font-size:14px;line-height:1.6}
@media(max-width:900px){.seo-sec .seo{grid-template-columns:1fr;gap:36px}.midband h2{font-size:24px}}
@media(max-width:560px){.seo-stats{grid-template-columns:1fr}}

/* === «Как сделать заказ» — таймлайн === */
.howsec .steps{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;position:relative;padding-top:22px}
.howsec .steps:before{content:"";position:absolute;top:21px;left:9%;right:9%;height:2px;background:linear-gradient(90deg,var(--accent2),var(--accent));opacity:.35;z-index:0}
.howsec .stp{background:#fff;border:1px solid var(--line);border-radius:14px;padding:30px 20px 22px;text-align:center;position:relative;z-index:1;transition:.18s}
.howsec .stp:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(26,29,33,.10);border-color:var(--accent)}
.howsec .stp .n{position:absolute;top:-19px;left:50%;transform:translateX(-50%);width:38px;height:38px;border-radius:50%;background:var(--accent);color:#fff;font-weight:800;font-size:15px;display:flex;align-items:center;justify-content:center;border:4px solid var(--soft);box-shadow:0 5px 12px rgba(31,93,82,.28);z-index:2}
.howsec .stp:hover .n{background:var(--accent2)}
.howsec .stp .ic{font-size:30px;line-height:1;margin:10px 0 12px;color:var(--accent)}
.howsec .stp h3{font-size:16.5px;font-weight:700;color:var(--ink);margin-bottom:8px}
.howsec .stp p{font-size:13px;color:var(--mut);line-height:1.55}
@media(max-width:900px){.howsec .steps{grid-template-columns:repeat(2,1fr);gap:26px 18px}.howsec .steps:before{display:none}}
@media(max-width:560px){.howsec .steps{grid-template-columns:1fr}}

/* === Иконки-картинки в преимуществах и шагах === */
.bstrip .ic{display:inline-flex;align-items:center;justify-content:center}
.bstrip .ic img{width:46px;height:46px;object-fit:contain;display:block}
.howsec .stp .ic img{width:60px;height:60px;object-fit:contain;display:inline-block}
.howsec .stp .ic{display:flex;align-items:center;justify-content:center;min-height:60px}

/* === Сворачиваемый текст внизу страницы «Каталог» === */
.catalog-bottom{margin-top:34px;border-top:1px solid var(--line);padding-top:26px}
.catalog-more{max-width:980px}
.catalog-more summary{cursor:pointer;list-style:none;display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:16px;color:var(--accent);padding:11px 18px;border:1px solid var(--line);border-radius:10px;background:#fff;transition:.18s}
.catalog-more summary:hover{border-color:var(--accent);background:var(--soft)}
.catalog-more summary::-webkit-details-marker{display:none}
.catalog-more summary:after{content:"▾";font-size:13px;transition:.2s}
.catalog-more[open] summary:after{content:"▴"}
.catalog-more-in{margin-top:18px;animation:cmfade .25s ease}
.catalog-more-in h2{font-size:22px;font-weight:800;color:var(--ink);margin:22px 0 10px}
.catalog-more-in h3{font-size:17px;font-weight:700;color:var(--ink);margin:18px 0 8px}
.catalog-more-in p{font-size:14.5px;color:var(--txt);line-height:1.7;margin-bottom:12px}
.catalog-more-in ul,.catalog-more-in ol{margin:0 0 14px 22px;color:var(--txt);font-size:14.5px;line-height:1.7}
.catalog-more-in li{margin-bottom:6px}
.catalog-more-in a{color:var(--accent);font-weight:600}
@keyframes cmfade{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

/* ===== Карточка: кнопки избранного/сравнения + фикс «Подробнее» ===== */
.prod{position:relative}
.prod .fav,.prod .cmp{position:absolute;right:10px;width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:rgba(255,255,255,.94);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;color:var(--mut);z-index:3;transition:.15s;padding:0;line-height:1}
.prod .fav{top:10px}
.prod .cmp{top:52px;font-size:15px}
.prod .fav:hover{color:#d23f3f;border-color:#d23f3f}
.prod .cmp:hover{color:var(--accent);border-color:var(--accent)}
.prod .fav.on{color:#fff;background:#d23f3f;border-color:#d23f3f}
.prod .cmp.on{color:#fff;background:var(--accent);border-color:var(--accent)}
.prod .foot{gap:8px;flex-wrap:wrap}
.prod .price{font-size:17px}
.prod .addcart{padding:9px 14px;font-size:13px;flex:1 1 auto;min-width:104px;justify-content:center}

/* ===== Тост ===== */
.px-toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,20px);background:var(--ink);color:#fff;padding:13px 22px;border-radius:10px;font-size:14px;font-weight:600;z-index:9999;opacity:0;pointer-events:none;transition:.25s;box-shadow:0 12px 30px rgba(0,0,0,.28)}
.px-toast.show{opacity:1;transform:translate(-50%,0)}

/* ===== Шапка: иконки-ссылки ===== */
.hicon{text-decoration:none}
a.hicon:hover{background:var(--soft)}
.hicon .cnt[hidden]{display:none}

/* ===== Карусели (отзывы/портфолио) ===== */
.car-nav{display:flex;gap:8px}
.car-prev,.car-next{width:40px;height:40px;border-radius:9px;border:1px solid var(--line);background:#fff;cursor:pointer;font-size:20px;color:var(--ink);display:flex;align-items:center;justify-content:center;transition:.15s}
.car-prev:hover,.car-next:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.carousel{position:relative}
.car-track{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px;scrollbar-width:none;-ms-overflow-style:none}
.car-track::-webkit-scrollbar{display:none}
.car-item{scroll-snap-align:start;flex:0 0 auto}

/* отзывы */
.reviews-sec{padding:36px 0;background:var(--soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.review-card{width:360px;max-width:82vw;background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px 26px;display:flex;flex-direction:column;gap:13px}
.rv-stars{color:var(--star);font-size:16px;letter-spacing:2px}
.rv-stars .off{color:#d8dadd}
.rv-text{font-size:14.5px;color:var(--txt);line-height:1.65;flex:1;margin:0}
.rv-author{display:flex;align-items:center;gap:12px}
.rv-ava{width:42px;height:42px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;flex:0 0 auto}
.rv-author b{font-size:14.5px;color:var(--ink);display:block}
.rv-city{font-size:12.5px;color:var(--mut)}

/* портфолио */
.portfolio-sec{padding:32px 0}
.pf-item{width:400px;max-width:86vw;margin:0}
.pf-img{height:290px;border-radius:14px;border:1px solid var(--line)}
.pf-item figcaption{padding:12px 4px 0}
.pf-item figcaption b{display:block;font-size:15.5px;color:var(--ink)}
.pf-item figcaption span{font-size:13px;color:var(--mut)}

/* ===== Страницы «Избранное» / «Сравнение» ===== */
.list-empty{padding:50px 20px;text-align:center;color:var(--mut);font-size:15px;background:var(--soft);border-radius:14px}
.card-rm{position:absolute;top:10px;right:10px;width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:rgba(255,255,255,.94);cursor:pointer;font-size:18px;color:var(--mut);z-index:3;line-height:1}
.card-rm:hover{color:#d23f3f;border-color:#d23f3f}
.cmp-scroll{overflow-x:auto}
.cmp-tbl{border-collapse:collapse;width:100%;min-width:560px}
.cmp-tbl th,.cmp-tbl td{border:1px solid var(--line);padding:14px;text-align:center;vertical-align:top;font-size:14px;color:var(--txt)}
.cmp-l{text-align:left!important;font-weight:600;color:var(--ink)!important;background:var(--soft);white-space:nowrap}
.cmp-head{display:flex;flex-direction:column;align-items:center;gap:8px}
.cmp-img{width:120px;height:90px;border-radius:8px;display:block;border:1px solid var(--line)}
.cmp-name{font-weight:600;color:var(--ink);font-size:13.5px}
.cmp-rm{border:none;background:none;color:#d23f3f;cursor:pointer;font-size:12px;text-decoration:underline;padding:0}
.cmp-tbl .btn{padding:9px 14px;font-size:13px}
@media(max-width:560px){.review-card{width:300px}.pf-item{width:300px}.pf-img{height:220px}}

/* ===== Портфолио — верх страницы ===== */
.pf-head{max-width:1080px;margin:0 auto}
.pf-head .eyebrow{display:inline-block;font-size:12.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.pf-head h1{font-size:34px;font-weight:800;color:var(--ink);letter-spacing:-.02em;margin:0 0 12px}
.pf-lead{font-size:17px;color:var(--txt);line-height:1.7;max-width:820px;margin:0 0 24px}
.pf-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.pf-stats .st{background:#fff;border:1px solid var(--line);border-radius:13px;padding:18px 20px}
.pf-stats .st b{display:block;font-size:23px;font-weight:800;color:var(--accent);line-height:1.1;margin-bottom:5px}
.pf-stats .st span{font-size:13px;color:var(--mut)}
.pf-chips{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px}
.pf-chips-l{font-size:14px;color:var(--mut);margin-right:4px}
.car-track{cursor:grab}
.car-track.dragging{cursor:grabbing;scroll-behavior:auto}
.car-track.dragging a{pointer-events:none}
@media(max-width:760px){.pf-stats{grid-template-columns:1fr 1fr}.pf-head h1{font-size:27px}}

/* ===== Кнопки на карточке (В заявку / Заказать) ===== */
.prod .foot{align-items:center}
.prod .more-link{font-size:13px;color:var(--accent);font-weight:600;white-space:nowrap}
.prod .more-link:hover{text-decoration:underline}
.prod .cardbtns{display:flex;gap:8px;padding:0 15px 15px;margin-top:-2px}
.prod .cardbtns .btn{flex:1;padding:9px 8px;font-size:12.5px;justify-content:center;min-width:0;border-radius:8px}
.prod .toreq.on{background:#e8f1ee;color:var(--accent);border-color:var(--accent)}

/* ===== Модалка заказа ===== */
.order-modal{position:fixed;inset:0;z-index:1000;display:none}
.order-modal.open{display:block}
.order-ov{position:absolute;inset:0;background:rgba(16,20,18,.62)}
.order-box{position:relative;max-width:470px;margin:6vh auto;background:#fff;border-radius:18px;padding:30px 30px 26px;box-shadow:0 30px 70px rgba(0,0,0,.32);max-height:88vh;overflow:auto}
.order-close{position:absolute;top:12px;right:14px;border:none;background:none;font-size:28px;line-height:1;color:var(--mut);cursor:pointer;padding:4px}
.order-close:hover{color:var(--ink)}
.order-box h3{font-size:22px;font-weight:800;color:var(--ink);margin:0 0 8px;padding-right:26px;letter-spacing:-.01em}
.order-sub{font-size:13.5px;color:var(--mut);margin:0 0 16px;line-height:1.5}
.order-items{margin-bottom:16px}
.of-row{display:flex;justify-content:space-between;gap:12px;padding:11px 14px;background:var(--soft);border-radius:10px;margin-bottom:7px;font-size:14px}
.of-row span{color:var(--ink)}
.of-row b{color:var(--accent);white-space:nowrap;font-weight:700}
.order-form .wpcf7-form-control-wrap[data-name="your-items"]{display:none}
.order-form form{margin:0}
.order-form .leadform{display:flex;flex-direction:column;gap:10px}
.order-form input[type=text],.order-form input[type=tel]{width:100%;border:1px solid #d9dde0;border-radius:9px;padding:13px 16px;font-family:inherit;font-size:15px;color:var(--ink)}
.order-form input::placeholder{color:#9aa0a7}
.order-form input:focus{outline:none;border-color:var(--accent2)}
.order-form .wpcf7-submit{width:100%;background:var(--accent);color:#fff;border:none;border-radius:9px;padding:14px;font-weight:700;font-size:15px;cursor:pointer;transition:.2s}
.order-form .wpcf7-submit:hover{background:var(--accent2)}
.order-form .wpcf7-acceptance{font-size:11.5px;color:var(--mut);display:block;margin-top:8px}
.order-form .wpcf7-acceptance .wpcf7-list-item{margin:0}
.order-form .wpcf7-response-output{margin:10px 0 0!important;font-size:13px;border-radius:8px;padding:8px 12px!important}
.order-form .wpcf7-not-valid-tip{font-size:12px;color:#d23f3f;margin-top:4px}

/* страница заявки */
.zayavka-sub{color:var(--mut);font-size:15px;margin:-8px 0 18px}
.req-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:22px;padding:18px 22px;background:var(--soft);border-radius:14px;flex-wrap:wrap}
.req-bar span{font-weight:600;color:var(--ink)}
.req-bar .btn{padding:13px 28px}

/* ===== Логотип-картинка в шапке ===== */
.logo-img{display:inline-flex;align-items:center;line-height:0}
.logo-img img{height:44px;width:auto;display:block}
@media(max-width:760px){.logo-img img{height:34px}}

/* ===== Поле прикрепления файла в формах ===== */
.file-field{display:block;font-size:13px;color:var(--mut);border:1px dashed #c4ccca;border-radius:9px;padding:11px 14px;cursor:pointer;flex:1 1 100%}
.file-field input[type=file]{display:block;margin-top:7px;font-size:12.5px;width:100%;color:inherit}
.file-field input[type=file]::file-selector-button{border:1px solid var(--line);background:var(--soft);border-radius:7px;padding:7px 12px;font-family:inherit;font-size:12.5px;cursor:pointer;margin-right:10px;color:var(--ink)}
.subbar .f .file-field{color:#c2c7cd;border-color:#3a4047}
.subbar .f .file-field input[type=file]::file-selector-button{background:#1d2126;border-color:#3a4047;color:#fff}
.order-form .file-field,.kont-form-box .file-field{margin-top:2px}
.wpcf7-spinner{margin:8px auto 0;display:block}

/* Логотип в подвале (светлый) */
.flogo{display:inline-block;line-height:0;margin-bottom:14px}
.flogo img{height:40px;width:auto}

/* ===== Форма фильтра каталога ===== */
.frange{display:flex;align-items:center;gap:8px}
.frange input{width:100%;border:1px solid var(--line);border-radius:8px;padding:9px 10px;font-family:inherit;font-size:13.5px;color:var(--ink)}
.frange input:focus{outline:none;border-color:var(--accent2)}
.frange span{color:var(--mut)}
.fopt-color .cdot{width:16px;height:16px;border-radius:50%;border:1px solid rgba(0,0,0,.15);flex:0 0 auto}
.fgroup-scroll{max-height:210px;overflow:auto}
.fgroup-scroll::-webkit-scrollbar{width:6px}.fgroup-scroll::-webkit-scrollbar-thumb{background:#d7dadd;border-radius:3px}
.sortbox{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--mut);white-space:nowrap}
.sortbox select{border:1px solid var(--line);border-radius:8px;padding:9px 12px;font-family:inherit;font-size:13.5px;color:var(--ink);cursor:pointer}
.filters .btn{margin-top:6px}
@media(max-width:900px){.filters{position:static}}

/* ===== Read-more текст под каталогом (часть видна, остальное по «развернуть») ===== */
.readmore{position:relative}
.readmore-body{position:relative;max-height:175px;overflow:hidden;transition:max-height .3s ease}
.readmore-body:after{content:"";position:absolute;left:0;right:0;bottom:0;height:72px;background:linear-gradient(rgba(255,255,255,0),#fff);pointer-events:none;transition:opacity .2s}
.readmore.open .readmore-body{max-height:none}
.readmore.open .readmore-body:after{opacity:0}
.readmore-toggle{display:inline-block;margin-top:14px;color:var(--accent);font-weight:600;font-size:14.5px;cursor:pointer;text-decoration:underline;text-underline-offset:3px;user-select:none}
.readmore-toggle:hover{color:var(--accent2)}

/* ===== Глобально: текст кнопок-ссылок не наследует цвет ссылок контейнера ===== */
a.btn{color:#fff;text-decoration:none}
a.btn:hover{color:#fff}
a.btn.btn-out,a.btn.btn-w{color:var(--ink)}
.page-cta a.btn{color:var(--accent)}
.page-cta a.btn:hover{color:var(--accent2)}

/* ============ МОБИЛЬНАЯ ВЕРСИЯ (внедрение макета mobile.html) ============ */
.mobilebar{display:none}
.filter-toggle{display:none}
.menu-tog{display:none}
@media(max-width:760px){
  /* шапка */
  .hbar{height:62px;gap:8px}
  .catbtn{display:none}
  .logo-img img{height:30px}
  .hicons{gap:2px}
  .hicons .hlabel{display:none}
  .hicon{padding:7px 8px}
  .hicon .ic{font-size:21px}
  .hicon .cnt{top:1px;right:1px}
  .menu-tog{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid var(--line);border-radius:9px;background:#fff;font-size:20px}

  /* бургер-шторка */
  .navrow{display:block;position:fixed;top:0;left:0;bottom:0;width:82%;max-width:320px;background:#fff;z-index:120;transform:translateX(-100%);transition:transform .25s ease;overflow-y:auto;box-shadow:0 0 40px rgba(0,0,0,.28);border:0;padding:60px 0 24px}
  .navrow.open{transform:none}
  .navrow .wrap{padding:0;max-width:none}
  .navrow ul{flex-direction:column;height:auto;gap:0;align-items:stretch}
  .navrow li{border-bottom:1px solid var(--line)}
  .navrow ul a{display:block;padding:14px 22px;font-size:15.5px;color:var(--ink)}
  .nav-ov{position:fixed;inset:0;background:rgba(13,15,17,.5);z-index:110;opacity:0;visibility:hidden;transition:.25s}
  .nav-ov.show{opacity:1;visibility:visible}

  /* сетки */
  .ctiles,.stones{grid-template-columns:1fr 1fr;gap:12px}
  .ctile .img{height:96px}
  .bstrip{grid-template-columns:1fr 1fr}
  .bstrip .b:nth-child(2n){border-right:none}
  .bstrip .b{border-bottom:1px solid var(--line)}

  /* липкая нижняя панель */
  .mobilebar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:90;background:#fff;border-top:1px solid var(--line);gap:10px;padding:9px 14px;box-shadow:0 -6px 20px rgba(0,0,0,.08)}
  .mobilebar .mb-call{flex:0 0 50px;border:1.5px solid var(--line);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--accent);text-decoration:none}
  .mobilebar .mb-btn{flex:1;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;font-weight:600;font-size:15px;border-radius:10px;text-decoration:none;padding:13px}
  body{padding-bottom:72px}

  /* фильтр каталога — кнопка + скрытый блок */
  .filter-toggle{display:inline-flex;align-items:center;justify-content:center;padding:11px 16px;font-size:14px;order:-1}
  .filters{display:none}
  .filters.show{display:block;margin-bottom:18px}
  .ctop{gap:10px}
  .ctop .chips{order:1}
  .sortbox{order:2;font-size:12.5px}
  .chead{flex-direction:column;align-items:flex-start;gap:10px}
  .chead .btn{display:none}
}

/* ============ Мобильные фиксы отступов ============ */
@media(max-width:760px){
  html,body{overflow-x:hidden}
  .wrap{padding:0 16px}
  .hero{padding:0}
  .promo{border-radius:0;min-height:320px}
  .promo .in{padding:24px 16px;max-width:100%}
  .promo h1{font-size:25px}
  .sidep{padding:0 16px}
  .bstrip .b{padding:14px 14px}
  .bstrip h5{font-size:13.5px}
  .bstrip p{font-size:11.5px}
  .hphone{display:none}
}

/* ===== Кнопка «наверх» ===== */
.to-top{position:fixed;right:22px;bottom:26px;z-index:80;width:46px;height:46px;border-radius:50%;border:none;background:var(--accent);color:#fff;font-size:22px;line-height:1;cursor:pointer;box-shadow:0 8px 22px rgba(31,93,82,.35);opacity:0;visibility:hidden;transform:translateY(10px);transition:.22s}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:hover{background:var(--accent2)}
@media(max-width:760px){.to-top{right:14px;bottom:84px;width:42px;height:42px;font-size:20px}}

/* ===== Галочка согласия в формах ===== */
.wpcf7-acceptance{display:block;margin-top:10px;font-size:11.5px;line-height:1.4}
.wpcf7-acceptance .wpcf7-list-item{margin:0;display:flex;gap:8px;align-items:flex-start}
.wpcf7-acceptance .wpcf7-list-item-label{color:var(--mut)}
.wpcf7-acceptance a{color:var(--accent);text-decoration:underline}
.wpcf7-acceptance input{margin-top:2px;accent-color:var(--accent)}
.subbar .f .wpcf7-acceptance .wpcf7-list-item-label{color:#9aa0a7}
.subbar .f .wpcf7-acceptance a{color:#cfe0d9}

/* Ссылки в подвале (политика/согласие) */
.fbot a{color:#9aa0a7;text-decoration:underline}
.fbot a:hover{color:#fff}
