:root {
  --color-primary: #172968;
  --color-secondary: #117bb8;
  --color-white: #ffffff;
  --color-dark-glass: rgba(25, 25, 25, 0.75);
  --color-ink: #111827;
  --color-muted: #627084;
  --color-soft: #eef5fb;
  --radius-xl: 28px;
  --radius-lg: 20px;
  --shadow-soft: 0 24px 70px rgba(16, 35, 76, 0.14);
  --shadow-card: 0 16px 40px rgba(16, 35, 76, 0.12);
  --font-main: 'Exo', sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-main);
  color: var(--color-ink);
  background: #ffffff;
  line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button, input, textarea, select { font: inherit; }

.container { width: min(1180px, calc(100% - 32px)); margin: 0 auto; }
.section { padding: 96px 0; position: relative; overflow: hidden; }
.eyebrow { color: var(--color-secondary); text-transform: uppercase; letter-spacing: .16em; font-size: .78rem; font-weight: 800; }
.section-heading { margin-bottom: 36px; }
.section-heading.center { text-align: center; max-width: 760px; margin-left: auto; margin-right: auto; }
.section-heading.light, .section-heading.light .eyebrow { color: #fff; }
h1, h2, h3 { line-height: 1.1; margin: 0; }
h2 { font-size: clamp(2rem, 4vw, 3.35rem); color: var(--color-primary); font-weight: 900; }
h3 { font-size: 1.25rem; }
p { margin: 0; color: var(--color-muted); }
.lead { font-size: 1.12rem; font-weight: 600; color: #3b4961; }
.rich { color: #3f4d63; margin-top: 18px; }
.rich p { margin: 0 0 12px; }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 0;
  border-radius: 999px;
  padding: 13px 22px;
  background: linear-gradient(135deg, var(--color-secondary), var(--color-primary));
  color: #fff;
  font-weight: 800;
  cursor: pointer;
  box-shadow: 0 12px 28px rgba(17, 123, 184, .28);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 16px 36px rgba(17, 123, 184, .38); }
.btn-secondary { background: var(--color-primary); }
.btn-ghost { background: rgba(17, 123, 184, .08); color: var(--color-primary); box-shadow: none; }
.btn-small { padding: 8px 13px; font-size: .88rem; }
.danger { background: #b42318; box-shadow: none; }

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 50;
  min-height: 92px;
  display: grid;
  grid-template-columns: minmax(130px, 220px) 1fr minmax(40px, 220px);
  align-items: stretch;
  padding: 0 34px;
  background: rgba(25,25,25,.88);
  backdrop-filter: blur(18px) brightness(.72);
  border-bottom: 1px solid rgba(17,123,184,.18);
  transition: min-height .25s ease, background .25s ease;
}
.site-header.shrunk { min-height: 66px; background: rgba(25,25,25,.92); }
.brand { display: flex; align-items: center; }
.brand img { max-height: 58px; width: auto; transition: max-height .25s ease; }
.site-header.shrunk .brand img { max-height: 42px; }
.brand-text {
  font-weight: 900;
  font-size: clamp(1.5rem, 2.3vw, 2.15rem);
  letter-spacing: -.02em;
  line-height: 1;
  white-space: nowrap;
}
.brand-text .pro { color: #ffffff; }
.brand-text .soporte { color: var(--color-secondary); }
.brand-text .dotnet { color: #ffffff; }
.main-nav { display: flex; justify-content: center; align-items: stretch; gap: 2px; }
.brand,
.main-nav,
.header-right {
  position: relative;
  z-index: 1;
}
.main-nav a {
  color: #fff;
  display: flex;
  align-items: center;
  padding: 0 18px;
  font-weight: 700;
  position: relative;
  overflow: hidden;
}
.main-nav a::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--color-secondary), var(--color-primary));
  opacity: 0;
  transform: scaleY(.6);
  transition: opacity .2s ease, transform .2s ease;
  z-index: -1;
}
.main-nav a:hover::before { opacity: .95; transform: scaleY(1); }
.header-right {
  justify-self: end;
  align-self: center;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}
.header-contact-mail {
  color: #ffffff;
  font-weight: 400;
  font-size: .95rem;
  white-space: nowrap;
  opacity: .95;
  position: relative;
  transition: opacity .2s ease, color .2s ease, transform .2s ease;
}
.header-contact-mail::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: -6px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--color-secondary), #79d8ff);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .22s ease;
}
.header-contact-mail:hover {
  color: #9ee3ff;
  opacity: 1;
  text-decoration: none;
  transform: translateY(-1px);
}
.header-contact-mail:hover::after {
  transform: scaleX(1);
}
.header-side-logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 58px;
  height: 58px;
  background: transparent;
  border: 0;
  position: relative;
  transition: transform .2s ease;
}
.header-side-logo::before {
  content: '';
  position: absolute;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(38, 211, 102, .34), rgba(17, 123, 184, .08) 62%, transparent 72%);
  opacity: 0;
  transform: scale(.74);
  transition: opacity .2s ease, transform .2s ease;
}
.header-side-logo img {
  width: 44px;
  height: 44px;
  object-fit: contain;
  position: relative;
  z-index: 1;
  transition: transform .2s ease, filter .2s ease;
}
.header-whatsapp-link img {
  width: 36px;
  height: 36px;
}
.header-whatsapp-link:hover {
  transform: translateY(-1px);
}
.header-whatsapp-link:hover::before {
  opacity: 1;
  transform: scale(1);
}
.header-whatsapp-link:hover img {
  transform: scale(1.06);
  filter: drop-shadow(0 8px 18px rgba(38, 211, 102, .34));
}
.menu-toggle { display: none; background: transparent; border: 0; width: 44px; justify-self: end; align-self: center; cursor: pointer; }
.menu-toggle span { display: block; height: 3px; background: #fff; border-radius: 999px; margin: 7px 0; transition: transform .2s ease, opacity .2s ease; }
.menu-toggle.active span:nth-child(1) { transform: translateY(10px) rotate(45deg); }
.menu-toggle.active span:nth-child(2) { opacity: 0; }
.menu-toggle.active span:nth-child(3) { transform: translateY(-10px) rotate(-45deg); }

.hero { min-height: 100vh; position: relative; background: #0f1a3e; overflow: hidden; }
.hero-slider, .hero-slide { position: absolute; inset: 0; }
.hero-slide {
  opacity: 0;
  transform: scale(1.02);
  transition: opacity .8s ease, transform 1.4s ease;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #0f1a3e;
  filter: saturate(1.04);
  pointer-events: none;
  z-index: 1;
}
.hero-slide::after {
  content: '';
  position: absolute;
  inset: 0;
  backdrop-filter: blur(3px);
  background:
    radial-gradient(circle at 70% 20%, rgba(17,123,184,.18), transparent 30%),
    rgba(2, 7, 22, .16);
  pointer-events: none;
}
.hero-slide.active {
  opacity: 1;
  transform: scale(1);
  pointer-events: auto;
  z-index: 2;
}
.hero-glass {
  position: relative;
  z-index: 4;
  width: min(920px, calc(100% - 32px));
  min-height: 100vh;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  color: #fff;
  padding-top: 90px;
}
.hero-glass .btn {
  position: relative;
  z-index: 5;
}
.hero-glass h1 {
  font-size: clamp(2.4rem, 7vw, 5.6rem);
  font-weight: 900;
  letter-spacing: -.04em;
  text-shadow: 0 12px 42px rgba(0,0,0,.45);
  margin: 14px 0 28px;
}
.hero-glass h1 strong { color: #fff; }
.hero-dots { position: absolute; z-index: 4; bottom: 28px; left: 50%; transform: translateX(-50%); display: flex; gap: 10px; }
.hero-dot { width: 34px; height: 5px; border-radius: 999px; border: 0; background: rgba(255,255,255,.38); cursor: pointer; }
.hero-dot.active { background: #fff; }

.about { background: #fff; }
.about::before { content: ''; position: absolute; right: -140px; top: 80px; width: 320px; height: 320px; border-radius: 50%; background: rgba(17,123,184,.08); }
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 54px; align-items: center; }
.about-media { border-radius: var(--radius-xl); padding: 0; background: linear-gradient(135deg, rgba(23,41,104,.08), rgba(17,123,184,.12)); box-shadow: var(--shadow-soft); overflow: hidden; min-height: 430px; }
.about-media img { width: 100%; height: 100%; min-height: 430px; aspect-ratio: 1.1; object-fit: cover; border-radius: 0; background: #fff; padding: 0; }
.section-copy { display: grid; gap: 14px; }

.store { background: linear-gradient(180deg, #f6fbff, #ffffff); }
.store::before { display: none; }
.store .container {
  position: relative;
  padding: clamp(28px, 5vw, 56px);
  border-radius: 42px;
  background:
    radial-gradient(circle at 16% 12%, rgba(23,41,104,.12), transparent 30%),
    radial-gradient(circle at 88% 18%, rgba(17,123,184,.14), transparent 32%),
    linear-gradient(135deg, rgba(23,41,104,.10), rgba(17,123,184,.08));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.72);
}
.product-grid { position: relative; display: flex; flex-wrap: wrap; justify-content: center; gap: 28px; max-width: 1040px; margin: 0 auto; }
.product-card {
  position: relative;
  flex: 0 1 calc((100% - 56px) / 3);
  background: rgba(255,255,255,.74);
  backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,.8);
  border-radius: var(--radius-lg);
  padding: 28px;
  min-height: 100%;
  display: grid;
  gap: 18px;
  justify-items: start;
  box-shadow: var(--shadow-card);
  transition: transform .2s ease, box-shadow .2s ease;
}
.product-card:hover { transform: translateY(-6px); box-shadow: 0 26px 60px rgba(16,35,76,.18); }
.product-badge {
  position: absolute;
  top: 18px;
  left: 18px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 11px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ff8a00, #e53935);
  color: #fff;
  font-size: .78rem;
  font-weight: 900;
  line-height: 1;
  box-shadow: 0 12px 28px rgba(229, 57, 53, .28);
}
.product-card img { width: 100%; height: 260px; object-fit: contain; background: #fff; border-radius: 18px; padding: 12px; }
.product-card h3 { font-size: clamp(1.2rem, 1.8vw, 1.55rem); }
.product-description { color: #5c6b80; font-size: .94rem; line-height: 1.45; margin-top: -8px; }
.product-rating {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: -6px;
  margin-bottom: -10px;
  line-height: 1;
}
.rating-stars {
  --rating-percent: 0%;
  position: relative;
  display: inline-block;
  color: transparent;
  font-size: 1.08rem;
  line-height: 1;
  letter-spacing: 1px;
}
.stars-base {
  color: transparent;
  -webkit-text-stroke: 1px #d6a21c;
}
.stars-fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--rating-percent);
  overflow: hidden;
  color: #f5b301;
  white-space: nowrap;
}
.rating-value {
  color: #6c7687;
  font-size: .9rem;
  font-weight: 800;
}
.price-block {
  display: grid;
  gap: 0;
  line-height: 1;
  margin-top: -4px;
}
.price { color: var(--color-primary); font-size: 1.72rem; font-weight: 900; line-height: 1; }
.old-price {
  color: #98a2b3;
  font-size: .92rem;
  font-weight: 800;
  line-height: 1;
  text-decoration: line-through;
  text-decoration-thickness: 2px;
}
.empty-state { position: relative; padding: 32px; border-radius: var(--radius-lg); background: rgba(255,255,255,.8); box-shadow: var(--shadow-card); text-align: center; color: var(--color-primary); font-weight: 800; }

.services { background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)); color: #fff; }
.services::before { content: ''; position: absolute; width: 520px; height: 520px; border-radius: 50%; background: rgba(255,255,255,.1); right: -180px; top: -160px; }
.services .section-heading h2 { color: #ffffff; }
.services .section-heading p { color: rgba(255,255,255,.84); }
.service-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 22px;
  position: relative;
}
.service-card {
  flex: 0 1 calc((100% - 66px) / 4);
  max-width: calc((100% - 66px) / 4);
  padding: 26px;
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.13);
  border: 1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(16px);
  transition: transform .2s ease, background .2s ease;
}
.service-card:hover { transform: translateY(-6px); background: rgba(255,255,255,.2); }
.service-card h3 { margin: 14px 0 10px; color: #fff; }
.service-card p { color: rgba(255,255,255,.82); }
.service-icon, .service-fallback { width: 58px; height: 58px; border-radius: 18px; background: #fff; object-fit: contain; padding: 10px; color: var(--color-primary); font-weight: 900; display: grid; place-items: center; text-transform: uppercase; }

.clients {
  background-color: var(--color-primary);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.clients::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(120deg, rgba(10, 20, 48, .82), rgba(10, 20, 48, .66)),
    radial-gradient(circle at 14% 16%, rgba(17,123,184,.24), transparent 34%),
    radial-gradient(circle at 88% 84%, rgba(255,255,255,.10), transparent 34%);
  backdrop-filter: blur(6px);
  pointer-events: none;
}
.clients .container {
  position: relative;
  z-index: 2;
  padding: clamp(28px, 5vw, 56px);
  border-radius: 34px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.22);
  box-shadow: var(--shadow-card);
}
.store .btn-secondary:hover {
  background: #2a4ea8;
  box-shadow: 0 16px 36px rgba(42, 78, 168, .34);
}
.clients .section-heading h2,
.clients .section-heading p,
.clients .section-heading .eyebrow { color: #fff; }
.clients-carousel { position: relative; overflow: hidden; }
.clients-track { display: grid; }
.client-card {
  display: none;
  text-align: center;
  gap: 14px;
  align-content: center;
  justify-items: center;
  min-height: 340px;
  padding: 24px;
  border-radius: 24px;
  background: rgba(255,255,255,.74);
  border: 1px solid rgba(255,255,255,.9);
}
.client-card.active {
  display: grid;
  animation: clientFade .45s ease;
}
.client-logo {
  width: min(220px, 72%);
  height: 96px;
  object-fit: contain;
}
.client-card h3 { color: var(--color-primary); font-size: 1.6rem; }
.client-card p { max-width: 760px; }
.clients-dots {
  margin-top: 16px;
  display: flex;
  justify-content: center;
  gap: 10px;
}
.clients-dot {
  width: 34px;
  height: 5px;
  border: 0;
  border-radius: 999px;
  background: rgba(23,41,104,.2);
  cursor: pointer;
}
.clients-dot.active { background: var(--color-primary); }
@keyframes clientFade {
  from { opacity: .5; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
.contact { background: #f7fbff; }
.contact-grid { display: grid; grid-template-columns: .82fr 1.18fr; gap: 28px; align-items: stretch; }
.contact-info, .contact-form { border-radius: var(--radius-xl); background: #fff; box-shadow: var(--shadow-soft); padding: clamp(24px, 4vw, 38px); }
.contact-info { display: flex; flex-direction: column; gap: 16px; }
.contact-line { color: var(--color-primary); font-weight: 800; }
.social-link { display: inline-flex; align-items: center; gap: 10px; color: var(--color-primary); font-weight: 800; }
.social-link img { width: 28px; height: 28px; object-fit: contain; }
.contact-visual { margin-top: auto; border-radius: 22px; overflow: hidden; min-height: 180px; }
.contact-visual img { width: 100%; height: 220px; object-fit: cover; }
.contact-form { display: grid; gap: 16px; }
.contact-form .btn:disabled {
  cursor: wait;
  opacity: .72;
  transform: none;
}
.contact-form-logo {
  width: 150px;
  height: auto;
  object-fit: contain;
  margin: 0 auto 6px;
}
.contact-form label, .admin-form label { display: grid; gap: 8px; font-weight: 800; color: #26344d; }
input, textarea, select { width: 100%; border: 1px solid #d8e2ed; border-radius: 14px; padding: 13px 14px; background: #fff; color: #172033; outline: none; transition: border .2s ease, box-shadow .2s ease; }
textarea { resize: vertical; }
input:focus, textarea:focus, select:focus { border-color: var(--color-secondary); box-shadow: 0 0 0 4px rgba(17,123,184,.13); }
.hp { position: absolute; left: -9999px; }
.notice { border-radius: 14px; padding: 12px 14px; font-weight: 700; margin-bottom: 14px; }
.notice.success { background: #e9f8ef; color: #146c3b; }
.notice.error { background: #fff0f0; color: #a42318; }

.purchase-ok-page {
  margin: 0;
  min-height: 100vh;
  height: 100vh;
  overflow: hidden;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 12% 18%, rgba(17,123,184,.20), transparent 34%),
    radial-gradient(circle at 88% 82%, rgba(23,41,104,.18), transparent 34%),
    linear-gradient(135deg, #f5f9ff, #eaf2fb);
}
.purchase-ok-card {
  width: min(720px, calc(100% - 28px));
  border-radius: 30px;
  padding: clamp(28px, 5vw, 46px);
  text-align: center;
  background: rgba(255,255,255,.84);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(255,255,255,.9);
  box-shadow: var(--shadow-soft);
  display: grid;
  gap: 16px;
  justify-items: center;
}
.purchase-ok-logo {
  width: min(220px, 62%);
  height: auto;
  object-fit: contain;
}
.purchase-ok-eyebrow {
  color: var(--color-secondary);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: .78rem;
  font-weight: 900;
}
.purchase-ok-card h1 {
  font-size: clamp(1.9rem, 4.4vw, 3.1rem);
  color: var(--color-primary);
  font-weight: 900;
  letter-spacing: -.02em;
}
.purchase-ok-card p {
  color: #4a5b75;
  font-size: 1.05rem;
  max-width: 58ch;
}

.site-footer { background: #101827; color: #fff; padding: 30px 0; }
.footer-inner { display: flex; gap: 18px; justify-content: space-between; align-items: center; flex-wrap: wrap; }
.footer-inner span, .footer-inner small { color: rgba(255,255,255,.72); }
.webfriends-footer { margin-top: 26px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.12); }
.webfriends-footer h2 { color: #fff; font-size: 1rem; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 14px; }
.webfriends-footer ul { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; }
.webfriends-footer li { display: grid; gap: 2px; padding: 12px 14px; border-radius: 14px; background: rgba(255,255,255,.06); }
.webfriends-footer a { color: #fff; font-weight: 900; }
.webfriends-footer span { color: rgba(255,255,255,.66); font-size: .88rem; }
.webfriend-logo { width: 42px; height: 42px; object-fit: contain; margin-bottom: 6px; }

.login-body, .admin-body { min-height: 100vh; background: radial-gradient(circle at top left, rgba(17,123,184,.18), transparent 34%), #eef4f9; }
.login-body { display: grid; place-items: center; padding: 24px; }
.login-card { width: min(440px, 100%); background: #fff; border-radius: 28px; padding: 34px; box-shadow: var(--shadow-soft); }
.login-logo { max-width: 180px; margin-bottom: 24px; }
.login-card h1 { color: var(--color-primary); font-size: 2rem; }
.login-card p { margin: 8px 0 22px; }
.admin-shell { min-height: 100vh; display: grid; grid-template-columns: 280px 1fr; }
.admin-sidebar { position: sticky; top: 0; height: 100vh; padding: 24px; background: #101827; color: #fff; display: flex; flex-direction: column; gap: 24px; }
.admin-brand { font-size: 1.55rem; font-weight: 900; letter-spacing: -.03em; }
.admin-brand span { color: var(--color-secondary); }
.admin-nav { display: grid; gap: 8px; }
.admin-nav a { padding: 12px 14px; border-radius: 14px; color: rgba(255,255,255,.72); font-weight: 800; }
.admin-nav a:hover, .admin-nav a.active { background: rgba(255,255,255,.1); color: #fff; }
.admin-user { margin-top: auto; display: grid; gap: 4px; color: rgba(255,255,255,.78); }
.admin-user a { color: #fff; font-weight: 800; }
.admin-main { padding: 28px; min-width: 0; }
.admin-topbar { display: flex; justify-content: space-between; gap: 18px; align-items: center; margin-bottom: 24px; }
.admin-topbar h1 { color: var(--color-primary); font-size: clamp(1.8rem, 4vw, 2.8rem); }
.admin-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 18px; margin-bottom: 18px; }
.admin-card { background: rgba(255,255,255,.88); border: 1px solid rgba(255,255,255,.9); border-radius: 24px; box-shadow: var(--shadow-card); padding: 24px; margin-bottom: 18px; }
.stat-card { display: grid; gap: 8px; }
.stat-card span { color: var(--color-muted); font-weight: 800; }
.stat-card strong { color: var(--color-primary); font-size: 2.4rem; line-height: 1; }
.quick-link { display: grid; gap: 8px; }
.quick-link strong { color: var(--color-primary); font-size: 1.1rem; }
.quick-link span { color: var(--color-muted); }
.card-heading { display: flex; justify-content: space-between; gap: 18px; align-items: flex-start; margin-bottom: 20px; }
.card-heading h2 { font-size: 1.5rem; }
.admin-form { display: grid; gap: 16px; }
.admin-form.stacked { gap: 18px; }
.form-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.form-grid.two { grid-template-columns: repeat(2, 1fr); }
.span-two { grid-column: 1 / -1; }
.check { align-content: end; grid-auto-flow: column; justify-content: start; align-items: center; }
.check input { width: auto; }
.edit-block { border: 1px solid #dce6f0; border-radius: 20px; padding: 18px; }
.edit-block legend { color: var(--color-primary); font-weight: 900; padding: 0 8px; }
.preview-row { display: grid; grid-template-columns: 130px 1fr; gap: 16px; align-items: center; }
.preview-row img { width: 130px; height: 100px; object-fit: contain; border-radius: 16px; background: #f4f7fb; padding: 8px; }
.table-wrap { overflow-x: auto; }
.admin-table { width: 100%; border-collapse: collapse; min-width: 720px; }
.admin-table th, .admin-table td { padding: 12px 10px; border-bottom: 1px solid #e4edf5; text-align: left; vertical-align: middle; }
.admin-table th { color: var(--color-primary); font-size: .86rem; text-transform: uppercase; letter-spacing: .08em; }
.thumb { width: 56px; height: 46px; object-fit: contain; background: #f4f7fb; border-radius: 10px; }
.pill { display: inline-flex; border-radius: 999px; padding: 4px 10px; font-size: .82rem; font-weight: 900; }
.pill.on { background: #e9f8ef; color: #146c3b; }
.pill.off { background: #f2f4f7; color: #667085; }
.actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.inline { display: inline; }
small { color: var(--color-muted); }

@media (max-width: 860px) {
  .site-header { min-height: 74px; grid-template-columns: 1fr auto; padding: 0 18px; }
  .brand img { max-height: 46px; }
  .brand-text { font-size: 1.4rem; }
  .header-right { display: none; }
  .header-contact-mail { display: none; }
  .header-side-logo { display: none; }
  .menu-toggle { display: block; }
  .main-nav { position: fixed; top: 74px; left: 14px; right: 14px; display: grid; justify-content: stretch; align-items: stretch; gap: 0; padding: 10px; border-radius: 22px; background: rgba(25,25,25,.94); transform: translateY(-16px); opacity: 0; pointer-events: none; transition: opacity .2s ease, transform .2s ease; }
  .main-nav.open { opacity: 1; transform: translateY(0); pointer-events: auto; }
  .main-nav a { min-height: 48px; border-radius: 14px; }
  .hero-glass { align-items: flex-start; text-align: left; }
  .about-grid, .contact-grid { grid-template-columns: 1fr; }
  .about-media, .about-media img { min-height: 330px; }
  .product-grid { max-width: 720px; }
  .product-card { flex-basis: calc((100% - 28px) / 2); }
  .product-card img { height: 220px; }
  .service-card {
    flex-basis: calc((100% - 22px) / 2);
    max-width: calc((100% - 22px) / 2);
  }
  .section { padding: 72px 0; }
  .admin-shell { grid-template-columns: 1fr; }
  .admin-sidebar { position: relative; height: auto; }
  .admin-nav { grid-template-columns: repeat(2, 1fr); }
  .admin-main { padding: 18px; }
  .admin-topbar { align-items: flex-start; flex-direction: column; }
  .form-grid, .form-grid.two { grid-template-columns: 1fr; }
}

@media (max-width: 560px) {
  .container { width: min(100% - 22px, 1180px); }
  .hero-glass h1 { font-size: clamp(2.1rem, 12vw, 3.4rem); }
  .product-card, .service-card, .contact-info, .contact-form, .admin-card { border-radius: 20px; padding: 20px; }
  .store .container { padding: 22px; border-radius: 28px; }
  .product-grid { display: grid; grid-template-columns: 1fr; }
  .product-card { flex-basis: auto; }
  .product-card img { height: 240px; }
  .service-card {
    flex-basis: 100%;
    max-width: 100%;
  }
  .footer-inner { display: grid; }
  .preview-row { grid-template-columns: 1fr; }
  .preview-row img { width: 100%; height: 150px; }
  .admin-nav { grid-template-columns: 1fr; }
}
