/*
Theme Name: Shop4Profis AI V2
Theme URI: https://shop.kober-aufzugtechnik.de
Author: Kober Aufzugtechnik
Description: Handcrafted premium WooCommerce starter theme for Shop4Profis.
Version: 1.0.16
Text Domain: shop4profis-ai-v2
*/

:root{
  --bg:#f3f6fa;
  --surface:#ffffff;
  --surface-2:#eef3f9;
  --text:#122033;
  --muted:#5f6f84;
  --line:#dbe4ef;
  --blue-900:#0b2340;
  --blue-800:#10365f;
  --blue-700:#14508f;
  --blue-600:#1a73d9;
  --blue-500:#2f8cff;
  --accent:#ffcc1a;
  --success:#1f9d55;
  --shadow:0 10px 30px rgba(9,31,56,.08);
  --radius:18px;
  --radius-sm:12px;
  --container:1400px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,Arial,Helvetica,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.5;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
.screen-reader-text{display:none}

.site-shell{
  min-height:100vh;
  display:flex;
  flex-direction:column;
}
.site-main{
  flex:1;
}

.container{
  width:min(100% - 32px, var(--container));
  margin-inline:auto;
}

.topbar{
  background:#081a30;
  color:#dce7f7;
  font-size:13px;
}
.topbar__inner{
  min-height:42px;
  display:flex;
  gap:18px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}
.topbar__left,
.topbar__right{
  display:flex;
  gap:18px;
  align-items:center;
  flex-wrap:wrap;
}
.topbar__badge{
  color:#081a30;
  background:var(--accent);
  padding:4px 10px;
  border-radius:999px;
  font-weight:700;
}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(11,35,64,.96);
  backdrop-filter:blur(10px);
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.site-header__row{
  display:grid;
  grid-template-columns:260px minmax(280px,1fr) 220px;
  gap:20px;
  align-items:center;
  min-height:88px;
}
.brand{
  display:flex;
  align-items:center;
  gap:14px;
}
.brand__mark{
  width:52px;
  height:52px;
  border-radius:14px;
  background:linear-gradient(135deg,var(--blue-500),#36d3ff);
  display:grid;
  place-items:center;
  color:#fff;
  font-weight:800;
  box-shadow:0 10px 24px rgba(47,140,255,.35);
}
.brand__text{
  display:flex;
  flex-direction:column;
  line-height:1.05;
}
.brand__title{
  font-size:22px;
  font-weight:800;
  letter-spacing:.2px;
}
.brand__sub{
  font-size:12px;
  color:#b9c8dc;
  text-transform:uppercase;
  letter-spacing:.14em;
}

.header-search{
  display:flex;
  align-items:center;
  background:#fff;
  border-radius:16px;
  padding:8px 10px 8px 16px;
  box-shadow:0 8px 22px rgba(0,0,0,.12);
}
.header-search input{
  width:100%;
  border:0;
  outline:0;
  color:var(--text);
  background:transparent;
}
.header-search button{
  border:0;
  border-radius:12px;
  background:linear-gradient(135deg,var(--blue-600),var(--blue-500));
  color:#fff;
  padding:12px 16px;
  cursor:pointer;
  font-weight:700;
}

.header-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
}
.header-action{
  min-width:64px;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  color:#fff;
  background:rgba(255,255,255,.06);
  text-align:center;
  font-size:13px;
}
.header-action strong{
  display:block;
  font-size:15px;
}

.navbar{
  background:linear-gradient(90deg,var(--blue-800),var(--blue-700));
  color:#fff;
}
.navbar__inner{
  min-height:58px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.menu-primary-menu-container ul,
.navbar__links{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:20px;
  align-items:center;
  flex-wrap:wrap;
}
.menu-primary-menu-container a,
.navbar__links a{
  color:#fff;
  font-weight:600;
  font-size:15px;
  opacity:.96;
}
.navbar__cta{
  color:#081a30;
  background:#fff;
  padding:10px 14px;
  border-radius:999px;
  font-weight:800;
  white-space:nowrap;
}

.hero{
  padding:28px 0 0;
}
.hero__grid{
  display:grid;
  grid-template-columns:1.25fr .75fr;
  gap:22px;
}
.hero-card{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  box-shadow:var(--shadow);
}
.hero-main{
  min-height:520px;
  padding:56px;
  color:#fff;
  background:
    radial-gradient(circle at 85% 20%, rgba(255,255,255,.18), transparent 26%),
    radial-gradient(circle at 70% 85%, rgba(255,204,26,.18), transparent 24%),
    linear-gradient(135deg,#0a1f39 0%, #114173 48%, #1a73d9 100%);
}
.hero-main::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px);
  background-size:28px 28px;
  opacity:.18;
  pointer-events:none;
}
.hero-kicker{
  position:relative;
  display:inline-flex;
  gap:10px;
  align-items:center;
  padding:9px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  font-weight:700;
  margin-bottom:18px;
}
.hero-main h1{
  position:relative;
  margin:0 0 16px;
  font-size:clamp(38px, 5vw, 66px);
  line-height:.98;
  letter-spacing:-.03em;
  max-width:760px;
}
.hero-main p{
  position:relative;
  margin:0;
  max-width:640px;
  color:#e4edf8;
  font-size:18px;
}
.hero-actions{
  position:relative;
  margin-top:28px;
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:0 22px;
  border-radius:14px;
  font-weight:800;
  border:0;
}
.btn--primary{
  background:#fff;
  color:var(--blue-900);
}
.btn--secondary{
  background:rgba(255,255,255,.10);
  color:#fff;
  border:1px solid rgba(255,255,255,.16);
}

.hero-stats{
  position:relative;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-top:28px;
  max-width:680px;
}
.hero-stat{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  padding:16px 18px;
}
.hero-stat strong{
  display:block;
  font-size:28px;
  line-height:1;
  margin-bottom:6px;
}
.hero-stat span{
  font-size:13px;
  color:#d8e6f8;
}

.hero-side{
  display:grid;
  gap:22px;
}
.hero-panel{
  min-height:249px;
  padding:28px;
  background:#fff;
}
.hero-panel--dark{
  background:linear-gradient(135deg,#0b2340,#113963);
  color:#fff;
}
.hero-panel__eyebrow{
  display:inline-block;
  margin-bottom:12px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#7e92ab;
}
.hero-panel--dark .hero-panel__eyebrow{
  color:#b7cae5;
}
.hero-panel h3{
  margin:0 0 10px;
  font-size:28px;
  line-height:1.05;
}
.hero-panel p{
  margin:0;
  color:var(--muted);
}
.hero-panel--dark p{
  color:#d6e2f3;
}
.hero-chip-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.hero-chip{
  padding:9px 12px;
  border-radius:999px;
  background:#eef4fb;
  color:#0d3158;
  font-weight:700;
  font-size:13px;
}
.hero-panel--dark .hero-chip{
  background:rgba(255,255,255,.1);
  color:#fff;
}

.section{
  padding:26px 0 0;
}
.section__head{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
}
.section__eyebrow{
  display:block;
  color:var(--blue-600);
  font-size:12px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin-bottom:6px;
}
.section__title{
  margin:0;
  font-size:34px;
  line-height:1.05;
  letter-spacing:-.03em;
}
.section__text{
  margin:0;
  color:var(--muted);
  max-width:760px;
}
.section__link{
  color:var(--blue-700);
  font-weight:800;
}

.category-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.category-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:22px;
  padding:22px;
  box-shadow:var(--shadow);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.category-card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 38px rgba(9,31,56,.12);
  border-color:#c8d9ee;
}
.category-card__icon{
  width:56px;
  height:56px;
  border-radius:16px;
  display:grid;
  place-items:center;
  margin-bottom:18px;
  font-size:24px;
  background:linear-gradient(135deg,#e9f3ff,#d7eaff);
  color:var(--blue-700);
}
.category-card__label{
  color:var(--muted);
  font-size:13px;
  margin-bottom:4px;
}
.category-card__title{
  margin:0 0 8px;
  font-size:22px;
  line-height:1.1;
}
.category-card__meta{
  color:var(--muted);
  font-size:14px;
}

.usp-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.usp-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:22px;
  padding:24px;
  box-shadow:var(--shadow);
}
.usp-card__icon{
  width:54px;
  height:54px;
  border-radius:16px;
  display:grid;
  place-items:center;
  margin-bottom:16px;
  background:linear-gradient(135deg,var(--blue-800),var(--blue-600));
  color:#fff;
  font-size:24px;
}
.usp-card h3{
  margin:0 0 8px;
  font-size:21px;
}
.usp-card p{
  margin:0;
  color:var(--muted);
}

.brand-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:14px;
}
.brand-card{
  min-height:104px;
  display:grid;
  place-items:center;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow:var(--shadow);
  font-weight:900;
  font-size:24px;
  color:#22324a;
  letter-spacing:.04em;
}

.promo-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr .9fr;
  gap:18px;
}
.promo-card{
  overflow:hidden;
  min-height:260px;
  position:relative;
  border-radius:24px;
  box-shadow:var(--shadow);
  padding:30px;
  color:#fff;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}
.promo-card--blue{
  background:linear-gradient(135deg,#0b2340,#14508f 60%, #2f8cff);
}
.promo-card--dark{
  background:linear-gradient(135deg,#111827,#243447);
}
.promo-card--light{
  color:var(--text);
  background:linear-gradient(135deg,#fff,#edf4ff);
  border:1px solid var(--line);
}
.promo-card__tag{
  position:absolute;
  top:20px;
  left:20px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  font-size:12px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.promo-card--light .promo-card__tag{
  background:#dcecff;
  color:var(--blue-800);
}
.promo-card h3{
  margin:0 0 10px;
  font-size:34px;
  line-height:1;
}
.promo-card p{
  margin:0;
  max-width:420px;
  color:rgba(255,255,255,.88);
}
.promo-card--light p{
  color:var(--muted);
}

.site-footer{
  margin-top:42px;
  background:linear-gradient(180deg,#0b2340 0%, #091729 100%);
  color:#d9e6f8;
}
.site-footer__top{
  padding:48px 0 22px;
  display:grid;
  grid-template-columns:1.2fr .8fr .8fr .8fr;
  gap:26px;
}
.site-footer__brand h3{
  margin:0 0 12px;
  color:#fff;
  font-size:28px;
}
.site-footer__brand p{
  margin:0;
  color:#b8cae2;
  max-width:520px;
}
.site-footer__title{
  margin:0 0 14px;
  color:#fff;
  font-size:17px;
}
.site-footer ul{
  list-style:none;
  margin:0;
  padding:0;
}
.site-footer li + li{
  margin-top:10px;
}
.site-footer a{
  color:#c9d9ee;
}
.site-footer__bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding:18px 0 28px;
  display:flex;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  font-size:14px;
  color:#b8cae2;
}

.page-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:var(--shadow);
  padding:30px;
  margin:30px auto;
}

/* WooCommerce archive */

.woocommerce-page .site-main,
.woocommerce .site-main{
  padding-top:28px;
}

.woocommerce .woocommerce-breadcrumb{
  width:min(100% - 32px, var(--container));
  margin:0 auto 18px;
  color:var(--muted);
  font-size:14px;
}
.woocommerce .woocommerce-breadcrumb a{
  color:var(--blue-700);
}

.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering{
  margin-bottom:18px;
  color:var(--muted);
  font-size:14px;
}

.woocommerce .woocommerce-ordering select{
  border:1px solid var(--line);
  background:#fff;
  border-radius:12px;
  min-height:44px;
  padding:0 14px;
  color:var(--text);
}

.woocommerce ul.products{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:22px;
  margin:0;
  padding:0;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after{
  display:none !important;
}
.woocommerce ul.products li.product{
  width:auto !important;
  margin:0 !important;
  float:none !important;
  list-style:none;
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:var(--shadow);
  overflow:hidden;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.woocommerce ul.products li.product:hover{
  transform:translateY(-6px);
  box-shadow:0 18px 38px rgba(9,31,56,.12);
  border-color:#c7d8ee;
}
.woocommerce ul.products li.product a{
  text-decoration:none;
}

.s4p-card{
  display:flex;
  flex-direction:column;
  min-height:100%;
}
.s4p-card__media{
  position:relative;
  background:linear-gradient(180deg,#f8fbff 0%, #edf4fb 100%);
  aspect-ratio:1 / 1;
  overflow:hidden;
}
.s4p-card__media img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:20px;
  transition:transform .22s ease;
}
.woocommerce ul.products li.product:hover .s4p-card__media img{
  transform:scale(1.04);
}
.s4p-card__badge{
  position:absolute;
  top:14px;
  left:14px;
  z-index:2;
  padding:7px 10px;
  background:var(--accent);
  color:#111827;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
}
.s4p-card__body{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:18px 18px 20px;
}
.s4p-card__category{
  color:var(--muted);
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.s4p-card__title{
  font-size:19px;
  line-height:1.2;
  font-weight:800;
  color:var(--text);
  min-height:46px;
}
.s4p-card__price{
  font-size:22px;
  font-weight:900;
  color:var(--blue-900);
}
.s4p-card__price del{
  opacity:.5;
  font-size:.78em;
  margin-right:8px;
}
.s4p-card__meta{
  color:var(--muted);
  font-size:14px;
}
.s4p-card__actions{
  margin-top:auto;
  padding-top:4px;
}

.woocommerce ul.products li.product .button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.single_add_to_cart_button{
  width:100%;
  min-height:48px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:14px !important;
  border:0 !important;
  background:linear-gradient(135deg,var(--blue-600),var(--blue-500)) !important;
  color:#fff !important;
  font-weight:800 !important;
  box-shadow:none;
}
.woocommerce ul.products li.product .button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.single_add_to_cart_button:hover{
  background:linear-gradient(135deg,var(--blue-700),var(--blue-600)) !important;
  color:#fff !important;
}

.woocommerce span.onsale{
  display:none !important;
}

.woocommerce nav.woocommerce-pagination{
  margin:30px 0 0;
}
.woocommerce nav.woocommerce-pagination ul{
  border:0;
  display:flex;
  gap:10px;
  justify-content:center;
}
.woocommerce nav.woocommerce-pagination ul li{
  border:0;
}
.woocommerce nav.woocommerce-pagination ul li span,
.woocommerce nav.woocommerce-pagination ul li a{
  min-width:44px;
  height:44px;
  display:grid;
  place-items:center;
  border-radius:12px;
  background:#fff;
  border:1px solid var(--line);
  color:var(--text);
}
.woocommerce nav.woocommerce-pagination ul li span.current{
  background:var(--blue-600);
  color:#fff;
  border-color:var(--blue-600);
}

/* Single product */

.woocommerce div.product{
  background:transparent;
}
.woocommerce div.product .product_title{
  font-size:42px;
  line-height:1.05;
  letter-spacing:-.03em;
  color:var(--blue-900);
  margin:0 0 14px;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price{
  color:var(--blue-900);
  font-size:34px;
  font-weight:900;
  margin:0 0 20px;
}
.woocommerce div.product p.price del,
.woocommerce div.product span.price del{
  opacity:.45;
  font-size:.7em;
  margin-right:10px;
}
.woocommerce div.product .summary{
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  box-shadow:var(--shadow);
  padding:28px;
}
.woocommerce div.product div.images{
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  box-shadow:var(--shadow);
  padding:24px;
  overflow:hidden;
}
.woocommerce div.product div.images img{
  border-radius:18px;
}
.woocommerce-product-details__short-description{
  color:var(--muted);
  font-size:16px;
  margin-bottom:18px;
}
.woocommerce div.product form.cart{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
  margin-bottom:10px;
}
.woocommerce .quantity .qty{
  min-height:48px;
  min-width:88px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  padding:0 12px;
}
.woocommerce div.product .product_meta{
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid var(--line);
  color:var(--muted);
  font-size:14px;
}
.woocommerce div.product .product_meta a{
  color:var(--blue-700);
}
.woocommerce-tabs{
  margin-top:26px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs{
  padding:0;
  margin:0 0 16px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before{
  display:none !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li{
  border:0 !important;
  background:transparent !important;
  margin:0 !important;
  padding:0 !important;
  border-radius:0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after{
  display:none !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{
  display:inline-flex;
  align-items:center;
  min-height:46px;
  padding:0 18px;
  border-radius:14px;
  background:#fff;
  border:1px solid var(--line);
  color:var(--text);
  font-weight:800;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{
  background:var(--blue-600);
  color:#fff;
  border-color:var(--blue-600);
}
.woocommerce div.product .woocommerce-tabs .panel{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:var(--shadow);
  padding:26px;
}
.related.products,
.up-sells.upsells,
.cross-sells{
  margin-top:36px;
}
.related.products > h2,
.up-sells.upsells > h2,
.cross-sells > h2{
  font-size:32px;
  line-height:1.05;
  letter-spacing:-.03em;
  margin-bottom:18px;
  color:var(--blue-900);
}
.woocommerce div.product .woocommerce-product-rating{
  margin-bottom:14px;
}
.woocommerce-message,
.woocommerce-info,
.woocommerce-error{
  width:min(100% - 32px, var(--container));
  margin:18px auto;
  border:0;
  border-left:4px solid var(--blue-600);
  border-radius:16px;
  background:#fff;
  box-shadow:var(--shadow);
}
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before{
  color:var(--blue-600);
}

@media (max-width:1200px){
  .site-header__row{grid-template-columns:1fr; padding:18px 0}
  .header-actions{justify-content:flex-start}
  .hero__grid{grid-template-columns:1fr}
  .category-grid{grid-template-columns:repeat(2,1fr)}
  .usp-grid{grid-template-columns:repeat(2,1fr)}
  .brand-grid{grid-template-columns:repeat(3,1fr)}
  .promo-grid{grid-template-columns:1fr}
  .site-footer__top{grid-template-columns:1fr 1fr}
  .woocommerce ul.products{grid-template-columns:repeat(3,minmax(0,1fr))}
}

@media (max-width:700px){
  .container{width:min(100% - 20px, var(--container))}
  .topbar__inner{padding:10px 0}
  .hero-main{padding:28px 22px; min-height:auto}
  .hero-main h1{font-size:36px}
  .hero-stats{grid-template-columns:1fr}
  .category-grid,
  .usp-grid,
  .brand-grid,
  .site-footer__top,
  .woocommerce ul.products{grid-template-columns:1fr}
  .section__title{font-size:28px}
  .menu-primary-menu-container ul,.navbar__links{gap:12px}
  .woocommerce div.product .product_title{font-size:32px}
}
