/* ===== TechCenters — design system ===== */
@import url('https://fonts.googleapis.com/css2?family=Roboto+Flex:opsz,wght@8..144,300..900&display=swap');

:root{
  --bg:#ffffff;
  --bg-soft:#f6f7f9;
  --bg-soft2:#eef0f3;
  --ink:#1b1d22;
  --ink-2:#3a3f48;
  --muted:#7a818d;
  --muted-2:#9aa1ad;
  --line:#e8e9ed;
  --line-2:#dcdee3;

  --gold:#f2b500;          /* primary saturated gold */
  --gold-deep:#dca200;     /* darker / hover */
  --gold-head:#e9ac1a;     /* big headline accent on white */
  --gold-wash:#fdf4d6;     /* soft gold tint bg */

  --navy:#22262e;          /* dark band */
  --navy-2:#2c313a;
  --blue:#1e9bd7;          /* secondary accent / links */
  --blue-deep:#1888c0;
  --green:#27a567;         /* verified / success */

  --shadow-sm:0 1px 2px rgba(20,22,28,.06), 0 1px 3px rgba(20,22,28,.05);
  --shadow-md:0 6px 22px rgba(20,22,28,.09);
  --shadow-lg:0 20px 60px rgba(20,22,28,.18);
  --r:14px;
  --maxw:1200px;
  font-synthesis-weight:none;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Roboto Flex',system-ui,sans-serif;
  color:var(--ink);
  background:var(--bg);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  font-variation-settings:'wdth' 100;
}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none}
a{color:inherit;text-decoration:none}
input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}

h1,h2{font-weight:bold;line-height:1.08;letter-spacing:-.02em}
h3,h4{font-weight:800;line-height:1.08;letter-spacing:-.02em}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.sec{padding:78px 0}
.sec-soft{background:var(--bg-soft)}
.center{text-align:center}

.sec-title{font-size:38px;font-weight:bold;color:var(--ink)}
.sec-sub{font-size:18px;color:var(--muted);margin-top:10px;font-weight:400}

/* ===== buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  height:52px;padding:0 28px;border-radius:11px;font-weight:700;font-size:16px;
  transition:transform .12s ease, background .18s ease, box-shadow .18s ease;
}
.btn:active{transform:translateY(1px)}
.btn-gold{background:var(--gold);color:#241c00}
.btn-gold:hover{background:var(--gold-deep)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000}
.btn-ghost{background:#fff;color:var(--ink);border:1.5px solid var(--line-2)}
.btn-ghost:hover{border-color:var(--ink);background:#fff}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:var(--blue-deep)}
.btn-lg{height:58px;font-size:17px;padding:0 36px}

/* ===== HEADER ===== */
.site-header{
  position:sticky;top:0;z-index:60;background:#fff;
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;gap:34px;height:74px}
.logo{display:flex;flex-direction:column;line-height:1;font-weight:800;flex:0 0 auto}
.logo .l1{font-size:28px;font-weight:800;color:var(--gold);white-space:nowrap;letter-spacing:1px}
.logo .l2{font-size:25px;color:var(--ink);white-space:nowrap}
.nav-links{display:flex;align-items:center;gap:30px;flex:1 1 auto}
.nav-link{
  display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:15.5px;color:var(--ink);
  padding:26px 0;position:relative;white-space:nowrap;background:none;
}
.nav-link .chev{transition:transform .2s ease}
.nav-link:hover{color:var(--gold-deep)}
.nav-item.open>.nav-link{color:var(--blue)}
.nav-item.open>.nav-link .chev{transform:rotate(180deg)}
.nav-item{position:relative;display:flex;align-items:center}
.nav-right{display:flex;align-items:center;gap:20px;flex:0 0 auto}
.icon-btn{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:var(--ink)}
.icon-btn:hover{background:var(--bg-soft)}
.nav-cta{margin-left:6px}

/* phone in header */
.nav-phone{display:flex;align-items:center;gap:9px;font-weight:800;font-size:16px;color:var(--ink);flex:0 0 auto;white-space:nowrap;transition:color .15s}
.nav-phone svg{width:19px;height:19px;color:var(--gold-deep)}
.nav-phone:hover{color:var(--gold-deep)}

/* burger + mobile phone (hidden on desktop) */
.burger,.phone-mini{display:none}
.burger{width:44px;height:44px;border-radius:10px;place-items:center;color:var(--ink)}
.burger:hover{background:var(--bg-soft)}
.burger .ic-close{display:none}
.burger.open .ic-open{display:none}
.burger.open .ic-close{display:block}
.phone-mini{width:44px;height:44px;border-radius:50%;place-items:center;background:var(--gold-wash)}
.phone-mini svg{width:21px;height:21px;color:var(--gold-deep)}

/* mobile slide-in menu */
.mobile-menu{position:fixed;inset:74px 0 0;z-index:55;background:#fff;transform:translateX(100%);transition:transform .26s ease;overflow-y:auto;display:none}
.mobile-menu.open{transform:none}
.mm-panel{padding:14px 24px 48px;display:flex;flex-direction:column}
.mnav{font-size:19px;font-weight:700;color:var(--ink);padding:17px 2px;border-bottom:1px solid var(--line)}
.macc{border-bottom:1px solid var(--line)}
.macc-head{width:100%;display:flex;justify-content:space-between;align-items:center;font-size:19px;font-weight:700;color:var(--ink);padding:17px 2px;text-align:left}
.macc-head svg{transition:transform .2s ease;width:20px;height:20px;color:var(--muted);flex:0 0 auto}
.macc.open .macc-head svg{transform:rotate(180deg)}
.macc-body{display:none;flex-direction:column;padding:0 2px 14px}
.macc.open .macc-body{display:flex}
.macc-body a{padding:11px 0;color:var(--ink);font-size:16px;font-weight:600}
.macc-body a span{display:block;font-size:13.5px;color:var(--muted);font-weight:400;margin-top:1px}
.mm-grouplabel{font-size:12.5px;font-weight:700;color:var(--muted-2);letter-spacing:.04em;text-transform:uppercase;margin:14px 0 2px}
.mm-login{margin-top:24px;width:100%}
.mm-phone{margin-top:22px;display:flex;align-items:center;gap:11px;font-size:21px;font-weight:800;color:var(--ink)}
.mm-phone svg{width:22px;height:22px;color:var(--gold-deep)}
.mm-phone small{display:block;font-size:13px;color:var(--muted);font-weight:500}

/* ===== MEGAMENU POPUP (RepairPal style) ===== */
.megamenu{
  position:absolute;top:calc(100% - 6px);left:0;
  background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);
  border:1px solid var(--line);padding:30px 34px;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .18s ease, transform .18s ease, visibility .18s;
  z-index:70;
}
.nav-item.open .megamenu{opacity:1;visibility:visible;transform:translateY(0)}
.megamenu.mm-right{left:auto;right:0}
.mm-cols{display:grid;gap:46px}
.mm-cols.two{grid-template-columns:repeat(2,minmax(248px,1fr))}
.mm-colhead{font-size:13px;font-weight:600;color:var(--muted-2);margin-bottom:18px;letter-spacing:.01em}
.mm-item{display:flex;gap:15px;align-items:flex-start;padding:9px 0;border-radius:10px}
.mm-item:hover .mm-ic{border-color:var(--gold);color:var(--gold-deep)}
.mm-item:hover .mm-t{color:var(--gold-deep)}
.mm-ic{
  flex:0 0 auto;width:38px;height:38px;border-radius:9px;border:1.5px solid var(--line-2);
  display:grid;place-items:center;color:var(--ink-2);transition:.18s;
}
.mm-ic svg{width:21px;height:21px}
.mm-t{display:block;font-weight:700;font-size:15.5px;color:var(--ink);transition:.15s}
.mm-d{display:block;font-size:13.5px;color:var(--muted);margin-top:2px}
.mm-foot{margin-top:22px;padding-top:22px;border-top:1px solid var(--line)}
.mm-foot .btn{width:100%}
.mm-note{text-align:center;font-size:13.5px;color:var(--muted);margin-top:14px}
.mm-note a{color:var(--gold-deep);font-weight:700}

/* ===== HERO ===== */
.hero{padding:104px 0 90px;text-align:center;position:relative;overflow:hidden;background:var(--navy)}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;z-index:0;background-image:url(img/klo3glklo3glklo3.jpg);background-size:cover;background-position:center}
.hero-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(18,20,26,.72) 0%,rgba(18,20,26,.6) 45%,rgba(18,20,26,.78) 100%)}
.hero .wrap{position:relative;z-index:2}
.hero h1{font-size:74px;font-weight:bold;color:#fff;line-height:1.02;text-shadow:0 2px 24px rgba(0,0,0,.35)}
.hero h1 .accent{color:var(--gold);display:block}
.hero-sub{font-size:19px;color:#e6e8ec;margin:26px auto 0;max-width:660px;text-shadow:0 1px 12px rgba(0,0,0,.4)}
.searchbar{
  display:flex;gap:14px;justify-content:center;align-items:stretch;
  margin:46px auto 0;max-width:740px;flex-wrap:wrap;
}
.search-field{
  position:relative;flex:1 1 280px;min-width:240px;
}
.search-field .pin{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--gold)}
.search-field select,.search-field input{
  width:100%;height:66px;border:1.5px solid var(--line-2);border-radius:12px;
  background:#fff;padding:0 20px;font-size:16.5px;font-weight:500;color:var(--ink);
  appearance:none;cursor:pointer;transition:border-color .15s, box-shadow .15s;
}
.search-field.with-pin select,.search-field.with-pin input{padding-left:46px}
.search-field select:focus,.search-field input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 4px var(--gold-wash)}
.search-field .caret{position:absolute;right:18px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
.search-go{flex:0 0 auto;width:66px;height:66px;border-radius:12px;background:var(--gold);color:#241c00;display:grid;place-items:center;transition:.16s}
.search-go:hover{background:var(--gold-deep)}
.club{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:22px;font-size:15px;color:#eceef1;font-weight:500;text-shadow:0 1px 10px rgba(0,0,0,.4)}
.club input{width:18px;height:18px;accent-color:var(--gold);cursor:pointer}

/* USP strip */
.usp-strip{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:40px}
.usp-pill{
  display:inline-flex;align-items:center;gap:10px;background:var(--gold-wash);
  border:1px solid #f2e3a8;color:#6b5400;border-radius:999px;padding:11px 20px;font-weight:700;font-size:15px;
}
.usp-pill svg{width:18px;height:18px;color:var(--gold-deep)}

/* ===== DARK BAND ===== */
.band{background:var(--navy);color:#fff;text-align:center;padding:96px 0}
.band h2{font-size:46px;font-weight:bold;line-height:1.06;max-width:900px;margin:0 auto;color:#fff}
.band p{font-size:18px;color:#b9bfca;max-width:620px;margin:22px auto 0}
.band .btn{margin-top:38px}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:0}
.step{display:flex;flex-direction:column;gap:14px}
.step-top{display:flex;align-items:flex-start;gap:16px}
.step-ic{flex:0 0 auto;width:54px;height:54px;border-radius:12px;background:var(--gold-wash);display:grid;place-items:center;color:var(--gold-deep);position:relative}
.step-ic svg{width:26px;height:26px}
.step-num{position:absolute;right:-8px;top:-8px;width:24px;height:24px;border-radius:50%;background:var(--ink);color:#fff;font-size:13px;font-weight:800;display:grid;place-items:center}
.step h3{font-size:19px;font-weight:800;color:var(--ink);line-height:1.2}
.step p{font-size:15px;color:var(--muted);line-height:1.55}

/* ===== CATALOG ===== */
.city-tabs{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:34px 0 40px}
.city-tab{
  height:44px;padding:0 22px;border-radius:999px;border:1.5px solid var(--line-2);
  background:#fff;font-weight:700;font-size:15px;color:var(--ink-2);display:inline-flex;align-items:center;gap:8px;transition:.15s;
}
.city-tab:hover{border-color:var(--gold)}
.city-tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.city-tab .dot{width:7px;height:7px;border-radius:50%;background:var(--gold)}
.catalog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.sto-card{
  background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .16s, box-shadow .16s;display:flex;flex-direction:column;
}
.sto-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.sto-photo{aspect-ratio:16/10;position:relative}
.sto-photo image-slot{display:block;width:100%;height:100%}
.photo-row image-slot{display:block;width:100%;height:100%}
.sto-verified{position:absolute;top:12px;left:12px;display:inline-flex;align-items:center;gap:6px;background:#fff;color:var(--green);font-size:12.5px;font-weight:800;padding:6px 11px;border-radius:999px;box-shadow:var(--shadow-sm)}
.sto-verified svg{width:14px;height:14px}
.sto-body{padding:20px 22px 22px;display:flex;flex-direction:column;gap:12px;flex:1}
.sto-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.sto-name{font-size:20px;font-weight:800;color:var(--ink);letter-spacing:-.01em}
.rating{display:inline-flex;align-items:center;gap:6px;flex:0 0 auto}
.stars{display:inline-flex;gap:1px;color:var(--gold);font-size:15px;letter-spacing:1px}
.stars .empty{color:var(--line-2)}
.rating b{font-size:15px;font-weight:800}
.rating span{font-size:13px;color:var(--muted)}
.sto-addr{display:flex;align-items:flex-start;gap:8px;color:var(--ink-2);font-size:14.5px}
.sto-addr svg{flex:0 0 auto;width:17px;height:17px;color:var(--muted-2);margin-top:1px}
.sto-tags{display:flex;flex-wrap:wrap;gap:7px}
.tag{background:var(--bg-soft2);color:var(--ink-2);font-size:12.5px;font-weight:600;padding:5px 11px;border-radius:7px}
.sto-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:auto;padding-top:6px}
.sto-foot .btn{height:46px;flex:1}
.catalog-more{display:flex;justify-content:center;margin-top:40px}

/* ===== SERVICES GRID ===== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc{
  display:flex;align-items:center;gap:18px;text-align:left;
  background:var(--bg-soft);border:1px solid transparent;border-radius:12px;padding:0 22px;height:90px;overflow:hidden;transition:.15s;
}
.svc:hover{background:#fff;border-color:var(--line-2);box-shadow:var(--shadow-sm)}
.svc:hover .svc-ic{background:var(--gold);color:#241c00}
.svc-name{font-size:16px;font-weight:700;color:var(--ink)}
.svc-ic{flex:0 0 auto;width:56px;height:56px;border-radius:13px;background:var(--gold-wash);color:var(--gold-deep);display:grid;place-items:center;transition:.15s}
.svc-ic svg{width:30px;height:30px}

/* promos */
.promos{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:54px}
.promo{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:16/7;box-shadow:var(--shadow-sm)}
.promo-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.promo::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(20,22,28,.72) 0%,rgba(20,22,28,.45) 55%,rgba(20,22,28,.15) 100%)}
.promo-cap{position:absolute;left:26px;bottom:24px;z-index:2;color:#fff;max-width:72%;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.promo-cap h3{font-size:24px;font-weight:800}
.promo-cap p{font-size:14.5px;margin-top:5px;font-weight:500}

/* ===== BRANDS ===== */
.brand-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px 26px}
.brand{display:flex;align-items:center;gap:13px;padding:13px 12px;border-radius:11px;transition:.14s}
.brand:hover{background:var(--bg-soft)}
.brand-mark{
  width:46px;height:46px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;
  background:var(--bg-soft2);color:var(--ink);font-weight:800;font-size:15px;border:1px solid var(--line);
}
.brand-name{font-weight:600;font-size:15.5px;color:var(--ink);flex:1}
.brand-go{width:24px;height:24px;border-radius:50%;border:1.5px solid var(--line-2);display:grid;place-items:center;color:var(--muted);flex:0 0 auto}
.brand:hover .brand-go{border-color:var(--gold);color:var(--gold-deep)}
.all-brands{display:flex;justify-content:center;margin-top:40px}

/* ===== REVIEWS ===== */
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.review{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px}
.review-svc{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.review-svc h4{font-size:16px;font-weight:800;color:var(--ink)}
.review-brand{width:38px;height:38px;border-radius:50%;background:var(--bg-soft2);display:grid;place-items:center;font-size:11px;font-weight:800;color:var(--ink-2);flex:0 0 auto}
.review-rate{display:flex;align-items:center;gap:8px}
.review-text{font-size:15px;color:var(--ink-2);line-height:1.6;flex:1}
.review-meta{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:13px;color:var(--muted);border-top:1px solid var(--line);padding-top:14px}
.review-meta .who{display:flex;align-items:center;gap:7px;font-weight:600;color:var(--ink-2)}

/* ===== SERVICES PHOTOS / 500 ===== */
.photo-row{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:0}
.photo-row .ph{aspect-ratio:4/3;border-radius:14px;overflow:hidden}

/* СМИ */
.media-bar{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.media-inner{display:flex;align-items:center;gap:30px;padding:30px 0;flex-wrap:wrap}
.media-label{font-size:14px;font-weight:700;color:var(--muted);flex:0 0 auto}
.media-logos{display:flex;align-items:center;gap:40px;flex:1;flex-wrap:wrap;justify-content:center}
.media-logo{font-weight:800;color:var(--muted-2);font-size:18px;letter-spacing:.02em;opacity:.75}

/* CTA row */
.cta-row{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:46px 0;flex-wrap:wrap}
.cta-phone{display:flex;align-items:center;gap:16px}
.cta-phone .ring{width:54px;height:54px;border-radius:50%;background:var(--bg-soft);display:grid;place-items:center;color:var(--ink)}
.cta-phone .num{font-size:24px;font-weight:800;color:var(--ink);letter-spacing:-.01em}
.cta-phone .hrs{font-size:14px;color:var(--muted)}
.cta-actions{display:flex;gap:16px;flex-wrap:wrap}

/* ===== FOOTER ===== */
.footer{background:#fff;border-top:1px solid var(--line);padding:54px 0 40px}
.foot-top{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr 1fr;gap:40px}
.foot-soc{display:flex;gap:11px;margin-bottom:22px}
.soc{width:40px;height:40px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;transition:.15s}
.soc:hover{background:var(--gold);color:#241c00}
.soc svg{width:18px;height:18px}
.foot-contact{display:flex;flex-direction:column;gap:12px;font-size:14.5px;color:var(--ink-2)}
.foot-contact div{display:flex;align-items:center;gap:10px}
.foot-contact svg{width:17px;height:17px;color:var(--muted-2);flex:0 0 auto}
.foot-col h5{font-size:13px;font-weight:800;letter-spacing:.04em;color:var(--ink);text-transform:uppercase;margin-bottom:16px}
.foot-col a{display:block;font-size:14.5px;color:var(--ink-2);padding:6px 0;font-weight:500}
.foot-col a:hover{color:var(--gold-deep)}
.foot-bottom{display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px;margin-top:46px;padding-top:34px;border-top:1px solid var(--line)}
.foot-bottom h5{font-size:12px;font-weight:800;letter-spacing:.04em;color:var(--muted);text-transform:uppercase;margin-bottom:14px}
.pay-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.pay{height:34px;padding:0 14px;border-radius:7px;background:var(--bg-soft);border:1px solid var(--line);display:grid;place-items:center;font-weight:800;font-size:13px;color:var(--ink-2)}
.app-badge{height:48px;padding:0 20px;border-radius:9px;background:var(--ink);color:#fff;display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:14px}
.copyright{margin-top:34px;font-size:13.5px;color:var(--muted)}

/* ===== MODAL / FORM ===== */
.modal-overlay{
  position:fixed;inset:0;z-index:120;background:rgba(20,22,28,.55);backdrop-filter:blur(3px);
  display:none;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto;
}
.modal-overlay.open{display:flex}
.modal{
  background:#fff;border-radius:20px;max-width:680px;width:100%;box-shadow:var(--shadow-lg);
  overflow:hidden;animation:pop .22s ease;
}
@keyframes pop{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.modal-head{padding:30px 36px 0;position:relative}
.modal-head h2{font-size:28px;font-weight:bold}
.modal-head p{color:var(--muted);font-size:15px;margin-top:6px}
.modal-close{position:absolute;top:24px;right:24px;width:40px;height:40px;border-radius:50%;background:var(--bg-soft);display:grid;place-items:center;color:var(--ink-2)}
.modal-close:hover{background:var(--bg-soft2)}
.modal-body{padding:26px 36px 36px}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:7px}
.field.full{grid-column:1/-1}
.field label{font-size:14px;font-weight:700;color:var(--ink-2)}
.field label .req{color:var(--gold-deep)}
.field input,.field select,.field textarea{
  height:50px;border:1.5px solid var(--line-2);border-radius:10px;padding:0 15px;font-size:15.5px;
  background:#fff;transition:.15s;width:100%;
}
.field textarea{height:auto;padding:13px 15px;resize:vertical;min-height:92px;line-height:1.5}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 4px var(--gold-wash)}
.dropzone{
  border:2px dashed var(--line-2);border-radius:12px;padding:26px;text-align:center;color:var(--muted);
  cursor:pointer;transition:.15s;background:var(--bg-soft)
}
.dropzone:hover{border-color:var(--gold);background:var(--gold-wash);color:var(--ink-2)}
.dropzone svg{width:30px;height:30px;color:var(--muted-2);margin:0 auto 8px}
.dropzone b{color:var(--ink-2);font-weight:700}
.dz-files{font-size:13.5px;color:var(--green);font-weight:700;margin-top:8px;min-height:0}
.modal-submit{margin-top:8px}
.modal-submit .btn{width:100%}

/* consent checkbox */
.consent{display:flex;align-items:flex-start;gap:11px;margin-top:18px;cursor:pointer;font-size:13.5px;line-height:1.5;color:var(--muted)}
.consent input{flex:0 0 auto;width:19px;height:19px;margin-top:1px;accent-color:var(--gold);cursor:pointer}
.consent a{color:var(--gold-deep);font-weight:700;text-decoration:underline;text-underline-offset:2px}
.consent a:hover{color:var(--gold)}

/* category popup */
.modal-svc{max-width:560px}
.svc-modal-head{display:flex;align-items:flex-start;gap:18px}
.svc-modal-ic{flex:0 0 auto;width:62px;height:62px;border-radius:15px;background:var(--gold-wash);color:var(--gold-deep);display:grid;place-items:center}
.svc-modal-ic svg{width:34px;height:34px}
.svc-modal-head h2{font-size:26px}
.svc-modal-head p{color:var(--muted);font-size:15px;margin-top:6px;line-height:1.5}
.svc-works-label{font-size:13px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--muted-2);margin-bottom:14px}
.svc-works{display:grid;grid-template-columns:1fr 1fr;gap:12px 22px;margin-bottom:26px}
.svc-work{display:flex;align-items:center;gap:10px;font-size:15.5px;font-weight:600;color:var(--ink-2)}
.svc-work svg{flex:0 0 auto;width:19px;height:19px;color:var(--green)}
.svc-modal-cta{width:100%}

/* ===== PLACEHOLDER (striped) ===== */
.ph{
  width:100%;height:100%;position:relative;
  background:
    repeating-linear-gradient(135deg,#eceef1 0 11px,#f4f5f7 11px 22px);
  display:grid;place-items:center;color:#aab0ba;
}
.ph.dark{background:repeating-linear-gradient(135deg,#2c313a 0 11px,#333944 11px 22px);color:#6c7484}
.ph-label{font-family:ui-monospace,'SF Mono',Menlo,monospace;font-size:12px;letter-spacing:.02em;padding:4px 10px;background:rgba(255,255,255,.7);border-radius:6px;color:#7a818d}
.ph.dark .ph-label{background:rgba(0,0,0,.25);color:#9aa1ad}

/* ===== RESPONSIVE ===== */
/* tablet/laptop: tighten nav, show phone as icon so nothing overflows */
@media (max-width:1300px){
  .nav{gap:20px}
  .nav-links{gap:16px}
  .nav-link{font-size:14.5px}
  .nav-phone{display:none}
  .phone-mini{display:grid}
}
@media (max-width:1080px){
  .nav-links{display:none}
  .burger{display:grid}
  .phone-mini{margin-left:auto}
  .mobile-menu{display:block}
}
@media (max-width:980px){
  .hero h1{font-size:52px}
  .catalog-grid,.svc-grid,.review-grid{grid-template-columns:repeat(2,1fr)}
  .brand-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:1fr;gap:26px}
  .photo-row{grid-template-columns:repeat(2,1fr)}
  .foot-top{grid-template-columns:1fr 1fr}
  .foot-bottom{grid-template-columns:1fr}
  .band h2{font-size:34px}
}
@media (max-width:640px){
  .wrap{padding:0 18px}
  .hero h1{font-size:38px}
  .sec-title{font-size:28px}
  .catalog-grid,.svc-grid,.review-grid,.promos,.brand-grid,.photo-row{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}
  .searchbar{flex-direction:column}
  .search-field{flex:0 0 auto;width:100%;min-width:0}
  .search-go{width:100%;height:60px}
  .modal-head,.modal-body{padding-left:22px;padding-right:22px}
}
