/* PCDoktor Mannheim — PC Reparatur & IT-Service booking page
   Only affects /termin and /programare pages. */

body.pcw-booking-page{
  --booking-card: rgba(8, 22, 38, .92);
  --booking-card-2: rgba(13, 31, 52, .88);
  --booking-line: rgba(58, 143, 232, .34);
  --booking-line-soft: rgba(73, 146, 226, .22);
  --booking-shadow: 0 22px 70px rgba(0, 0, 0, .28);
}

.pcw-booking-page .pw-page{
  min-height:100vh;
}

.pcw-booking-page .pw-header-inner{
  grid-template-columns:340px 1fr 210px !important;
  padding:0 86px !important;
}

.pcw-booking-page .pw-nav{
  gap:42px !important;
  justify-content:center !important;
}

.pb-hero{
  min-height:300px;
  display:grid;
  grid-template-columns:620px 1fr;
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(90deg, rgba(3,16,31,.98) 0%, rgba(6,22,36,.95) 45%, rgba(2,9,18,.98) 100%);
  border-left:1px solid var(--line);
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
}

.pb-hero::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:470px;
  background:
    linear-gradient(135deg, rgba(0,130,255,.16), transparent 66%),
    linear-gradient(90deg, rgba(42,170,255,.08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(42,170,255,.06) 1px, transparent 1px);
  background-size:auto,22px 22px,22px 22px;
  opacity:.76;
  pointer-events:none;
}

.pb-hero-copy{
  position:relative;
  z-index:2;
  padding:42px 26px 32px 96px;
}

.pb-hero-copy h1{
  margin:0;
  max-width:500px;
  font-size:56px;
  line-height:.92;
  letter-spacing:-.075em;
  font-weight:950;
  color:#fff;
  text-shadow:0 2px 20px rgba(0,0,0,.24);
}

.pb-hero-copy p{
  max-width:530px;
  margin:16px 0 18px;
  color:rgba(232,242,255,.86);
  font-size:16px;
  line-height:1.42;
  font-weight:650;
}

.pb-summary{
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:center;
  gap:14px;
  max-width:520px;
  min-height:52px;
  padding:10px 14px;
  border:1px solid rgba(74,148,230,.28);
  border-radius:16px;
  background:rgba(8,22,38,.70);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}

.pb-summary span{
  color:#81dfff;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:11px;
  font-weight:950;
}

.pb-summary strong{
  min-width:0;
  color:#fff;
  font-size:16px;
  font-weight:900;
  text-align:right;
}

.pb-mini-trust{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
  max-width:560px;
}

.pb-mini-trust span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:34px;
  padding:4px 12px 4px 5px;
  border-radius:999px;
  border:1px solid rgba(70,150,228,.26);
  background:rgba(10,26,45,.52);
  color:#dceeff;
  font-size:12px;
  font-weight:850;
}

.pb-mini-trust i{
  width:24px;
  height:24px;
  display:grid;
  place-items:center;
  border-radius:999px;
  color:#6ee6ff;
  background:rgba(3,139,255,.18);
  font-style:normal;
}

.pb-hero-media{
  min-height:300px;
  position:relative;
  background:#06101d;
  overflow:hidden;
}

.pb-hero-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  filter:saturate(1.05) contrast(1.03);
}

.pb-hero-media::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(2,9,18,.48), rgba(2,9,18,0) 21%, rgba(2,9,18,.07));
  pointer-events:none;
}

.pb-hero-note{
  position:absolute;
  right:28px;
  bottom:24px;
  z-index:2;
  min-width:300px;
  padding:16px 18px;
  border:1px solid rgba(78,151,232,.38);
  border-radius:18px;
  background:rgba(2,10,20,.76);
  box-shadow:0 18px 48px rgba(0,0,0,.38);
  backdrop-filter:blur(14px);
}

.pb-hero-note span{
  display:block;
  color:#72dfff;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:11px;
  font-weight:950;
}

.pb-hero-note strong{
  display:block;
  margin-top:5px;
  color:#fff;
  font-size:17px;
}

.pb-booking{
  display:grid;
  grid-template-columns:470px 1fr 520px;
  gap:18px;
  align-items:start;
  padding:28px 96px 34px;
  background:
    linear-gradient(90deg, rgba(2,11,21,.82), rgba(3,15,29,.78)),
    linear-gradient(90deg, rgba(0,120,230,.08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(0,120,230,.055) 1px, transparent 1px);
  background-size:auto,28px 28px,28px 28px;
  border-left:1px solid var(--line);
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
}

.pb-card{
  border:1px solid var(--booking-line);
  border-radius:18px;
  background:linear-gradient(180deg, var(--booking-card-2), var(--booking-card));
  box-shadow:var(--booking-shadow), inset 0 1px 0 rgba(255,255,255,.04);
  overflow:visible;
}

.pb-service-card,
.pb-contact-card{
  padding:22px;
}

.pb-calendar-card{
  padding:22px;
}

.pb-card-head{
  display:flex;
  align-items:center;
  gap:13px;
  margin-bottom:18px;
}

.pb-card-head h2{
  margin:0;
  color:#fff;
  font-size:26px;
  line-height:1.05;
  letter-spacing:-.055em;
  font-weight:950;
}

.pb-kicker-small{
  margin:0 0 4px;
  color:#83dcff;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:11px;
  font-weight:950;
}

.pb-step-number{
  width:34px;
  height:34px;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  border-radius:999px;
  color:#fff;
  background:linear-gradient(135deg,#0788ff,#19c4ff);
  box-shadow:0 0 0 7px rgba(12,144,255,.10);
  font-size:15px;
  font-weight:950;
}

.custom-field > span,
.pb-form-grid label span{
  display:block;
  margin:0 0 8px;
  color:rgba(220,235,255,.78);
  font-size:13px;
  font-weight:850;
}

.custom-select{
  position:relative;
  z-index:30;
}

.custom-select-trigger,
.pb-form-grid input,
.pb-form-grid textarea{
  width:100%;
  min-height:54px;
  padding:0 17px;
  color:#fff;
  font:inherit;
  font-weight:850;
  border:1px solid rgba(88,157,235,.28);
  border-radius:14px;
  background:rgba(8,19,34,.92);
  outline:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.custom-select-trigger{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  text-align:left;
  cursor:pointer;
}

.custom-select-trigger:hover,
.pb-form-grid input:focus,
.pb-form-grid textarea:focus{
  border-color:rgba(18,171,255,.75);
  box-shadow:0 0 0 4px rgba(8,141,255,.12), inset 0 1px 0 rgba(255,255,255,.05);
}

.custom-select-chevron{
  color:#19c4ff;
  font-size:22px;
  line-height:1;
}

.custom-select-menu{
  display:none;
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  right:0;
  z-index:50;
  max-height:350px;
  overflow:auto;
  padding:8px;
  border:1px solid rgba(88,157,235,.36);
  border-radius:16px;
  background:rgba(5,14,27,.98);
  box-shadow:0 24px 65px rgba(0,0,0,.52);
}

.custom-select.is-open .custom-select-menu{display:block;}

.custom-select-option{
  width:100%;
  display:grid;
  gap:3px;
  padding:13px 12px;
  color:#fff;
  text-align:left;
  border:0;
  border-radius:12px;
  background:transparent;
  cursor:pointer;
}

.custom-select-option:hover,
.custom-select-option[aria-selected="true"]{
  background:linear-gradient(135deg, rgba(7,140,255,.22), rgba(31,203,255,.10));
}

.custom-select-option strong{
  font-size:14px;
  font-weight:950;
}

.custom-select-option span{
  color:rgba(217,232,255,.72);
  font-size:12px;
  font-weight:750;
}

.pb-help{
  margin:16px 0 0;
  color:rgba(222,236,255,.70);
  font-size:13px;
  line-height:1.45;
  font-weight:650;
}

.pb-calendar-head-wrap{
  display:grid;
  grid-template-columns:34px 1fr auto;
  align-items:center;
}

.pb-calendar-actions{
  display:flex;
  gap:10px;
}

.calendar-arrow{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  color:#dff1ff;
  border:1px solid rgba(88,157,235,.32);
  border-radius:14px;
  background:rgba(11,28,48,.86);
  cursor:pointer;
  font-size:30px;
  line-height:1;
  font-weight:900;
  transition:transform .16s ease, border-color .16s ease, background .16s ease;
}

.calendar-arrow:hover{
  transform:translateY(-1px);
  border-color:rgba(25,196,255,.62);
  background:rgba(14,42,70,.92);
}

.weekday-row{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:8px;
  margin:4px 0 8px;
  color:rgba(204,222,246,.74);
  text-align:center;
  font-size:12px;
  font-weight:950;
}

.booking-calendar{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:8px;
}

.calendar-day{
  min-height:76px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:5px;
  color:#eaf5ff;
  border:1px solid rgba(88,157,235,.25);
  border-radius:15px;
  background:rgba(12,30,51,.78);
  cursor:pointer;
  font:inherit;
  transition:transform .16s ease, border-color .16s ease, background .16s ease, box-shadow .16s ease;
}

.calendar-day strong{
  font-size:20px;
  font-weight:950;
}

.calendar-day span{
  color:rgba(220,235,255,.70);
  font-size:11px;
  line-height:1.1;
  font-weight:850;
}

.calendar-day.has-slots{
  border-color:rgba(34,201,255,.44);
  background:linear-gradient(180deg,rgba(14,44,75,.90),rgba(10,28,48,.86));
}

.calendar-day.has-slots:hover{
  transform:translateY(-2px);
  border-color:rgba(27,203,255,.82);
  box-shadow:0 12px 30px rgba(0,0,0,.24);
}

.calendar-day.is-selected{
  color:#fff;
  border-color:rgba(57,218,255,.95);
  background:linear-gradient(135deg,rgba(8,142,255,.45),rgba(21,197,255,.18));
  box-shadow:0 0 0 4px rgba(10,152,255,.13);
}

.calendar-day.is-today{
  outline:1px solid rgba(255,255,255,.16);
}

.calendar-day:disabled{
  cursor:not-allowed;
  opacity:.48;
  filter:saturate(.75);
}

.calendar-day.is-empty{
  visibility:hidden;
  pointer-events:none;
}

.slot-picker{
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid rgba(88,157,235,.18);
}

.slot-picker h3{
  margin:0 0 12px;
  color:#fff;
  font-size:19px;
  letter-spacing:-.035em;
  font-weight:950;
}

.slot-buttons{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.slot-button{
  min-height:42px;
  padding:0 14px;
  color:#fff;
  border:1px solid rgba(88,157,235,.32);
  border-radius:999px;
  background:rgba(11,28,48,.88);
  cursor:pointer;
  font:inherit;
  font-size:13px;
  font-weight:900;
  transition:transform .16s ease, border-color .16s ease, background .16s ease;
}

.slot-button:hover,
.slot-button.is-selected{
  transform:translateY(-1px);
  border-color:rgba(24,198,255,.85);
  background:linear-gradient(135deg,#0788ff,#19c4ff);
}

.empty-text{
  margin:0;
  color:rgba(222,236,255,.70);
  font-size:13px;
  font-weight:700;
}

.pb-form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.pb-full{grid-column:1/-1;}

.pb-form-grid textarea{
  min-height:130px;
  padding-top:15px;
  resize:vertical;
  line-height:1.45;
}

.pb-submit{
  width:100%;
  min-height:52px;
  margin-top:18px;
  border:0;
  cursor:pointer;
  font-size:16px;
}

.form-status{
  min-height:24px;
  margin:13px 0 0;
  color:rgba(221,236,255,.78);
  font-weight:800;
  line-height:1.35;
}

.form-status[data-type="success"]{color:#4affaa;}
.form-status[data-type="error"]{color:#ff7979;}

.pb-footer{
  border-left:1px solid var(--line);
  border-right:1px solid var(--line);
}

@media (max-width:1500px){
  .pcw-booking-page .pw-header-inner{padding:0 36px !important;grid-template-columns:280px 1fr 190px !important;}
  .pb-hero{grid-template-columns:540px 1fr;}
  .pb-hero-copy{padding-left:52px;}
  .pb-hero-copy h1{font-size:49px;}
  .pb-booking{grid-template-columns:390px 1fr; padding:24px 36px 32px;}
  .pb-contact-card{grid-column:1/-1;}
}

@media (max-width:1050px){
  .pcw-booking-page .pw-header{height:auto;position:relative;}
  .pcw-booking-page .pw-header-inner{height:auto;grid-template-columns:1fr !important;padding:14px 16px !important;gap:10px;}
  .pcw-booking-page .pw-brand{justify-content:center;}
  .pcw-booking-page .pw-nav{justify-content:center !important;}
  .pcw-booking-page .pw-controls{justify-content:center;}
  .pb-hero{grid-template-columns:1fr;}
  .pb-hero-copy{padding:32px 22px 26px;}
  .pb-hero-copy h1{font-size:clamp(38px,8vw,54px);max-width:720px;}
  .pb-hero-copy p{max-width:720px;}
  .pb-hero-media{min-height:260px;}
  .pb-booking{grid-template-columns:1fr; padding:20px 18px 28px;}
  .pb-contact-card{grid-column:auto;}
  .pb-footer{grid-template-columns:1fr 1fr;}
}

@media (max-width:680px){
  .pb-hero-copy h1{font-size:40px;}
  .pb-summary{grid-template-columns:1fr;gap:5px;}
  .pb-summary strong{text-align:left;}
  .pb-card{border-radius:16px;}
  .pb-service-card,.pb-calendar-card,.pb-contact-card{padding:17px;}
  .pb-card-head h2{font-size:23px;}
  .pb-calendar-head-wrap{grid-template-columns:34px 1fr;}
  .pb-calendar-actions{grid-column:1/-1;margin-top:12px;}
  .weekday-row,.booking-calendar{gap:5px;}
  .calendar-day{min-height:58px;border-radius:12px;}
  .calendar-day strong{font-size:17px;}
  .calendar-day span{font-size:9px;}
  .pb-form-grid{grid-template-columns:1fr;}
  .pb-footer{grid-template-columns:1fr;}
  .pb-hero-note{left:16px;right:16px;min-width:0;}
}

/* === V11 Modern booking / Termin polish === */
.pcw-booking-page .pb-hero{
  min-height:330px;
  background:
    radial-gradient(circle at 12% 5%,rgba(0,132,255,.22),transparent 31%),
    linear-gradient(90deg,rgba(3,16,31,.98) 0%,rgba(6,22,36,.96) 45%,rgba(2,9,18,.98) 100%);
}
.pcw-booking-page .pb-hero-copy h1{
  max-width:540px;
}
.pcw-booking-page .pb-summary{
  border-radius:18px;
  background:linear-gradient(180deg,rgba(16,32,49,.80),rgba(8,20,34,.82));
  border-color:rgba(84,145,215,.34);
}
.pcw-booking-page .pb-mini-trust span{
  border-color:rgba(84,145,215,.30);
  background:linear-gradient(180deg,rgba(16,32,49,.76),rgba(8,20,34,.82));
}
.pcw-booking-page .pb-hero-note{
  border-radius:20px;
  background:linear-gradient(180deg,rgba(13,30,49,.82),rgba(4,14,25,.84));
  border-color:rgba(84,145,215,.40);
}
.pcw-booking-page .pb-booking{
  gap:20px;
  padding-top:32px;
  padding-bottom:40px;
}
.pcw-booking-page .pb-card{
  border-radius:20px;
  border-color:rgba(84,145,215,.34);
  background:linear-gradient(180deg,rgba(16,32,49,.94),rgba(7,18,31,.97));
  box-shadow:0 26px 60px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.05);
}
.pcw-booking-page .pb-card-head{
  gap:15px;
  margin-bottom:20px;
}
.pcw-booking-page .pb-card-head h2{
  font-size:27px;
}
.pcw-booking-page .pb-step-number{display:none;}
.pb-step-badge{
  width:48px;
  height:48px;
  position:relative;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  border-radius:15px;
  color:#76d2ff;
  border:1px solid rgba(79,177,255,.42);
  background:linear-gradient(180deg,rgba(12,84,143,.34),rgba(7,38,69,.90));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 12px 22px rgba(0,0,0,.20);
}
.pb-step-badge em{
  position:absolute;
  right:-7px;
  bottom:-7px;
  min-width:24px;
  height:24px;
  padding:0 5px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  border:1px solid rgba(74,182,255,.36);
  background:#081527;
  color:#dff5ff;
  font-size:9px;
  font-style:normal;
  font-weight:950;
  letter-spacing:.08em;
}
.pb-step-icon svg{
  width:23px;
  height:23px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.pcw-booking-page .custom-select-trigger,
.pcw-booking-page .pb-form-grid input,
.pcw-booking-page .pb-form-grid textarea{
  border-radius:16px;
  background:linear-gradient(180deg,rgba(8,22,38,.94),rgba(5,16,29,.96));
}
.pcw-booking-page .calendar-arrow,
.pcw-booking-page .calendar-day,
.pcw-booking-page .slot-button{
  border-color:rgba(84,145,215,.30);
  background:linear-gradient(180deg,rgba(16,32,49,.82),rgba(8,20,34,.92));
}
.pcw-booking-page .calendar-day.has-slots{
  border-color:rgba(34,201,255,.48);
  background:linear-gradient(180deg,rgba(16,54,90,.92),rgba(9,29,50,.92));
}
.pcw-booking-page .calendar-day.is-selected{
  border-color:rgba(57,218,255,.95);
  background:linear-gradient(135deg,rgba(8,142,255,.58),rgba(21,197,255,.22));
}
.pcw-booking-page .pb-submit{
  border-radius:16px;
  box-shadow:0 14px 28px rgba(0,105,220,.24);
}
.pcw-booking-page .pb-footer{
  border-top:1px solid rgba(42,139,237,.24);
}
.pcw-booking-page .pb-footer .pw-footer-brand-card p::after{
  content:"Schnell & unkompliziert online anfragen.";
  display:block;
  margin-top:4px;
  color:rgba(116,204,255,.86);
  font-weight:850;
}

@media (max-width:1500px){
  .pcw-booking-page .pb-booking{grid-template-columns:390px 1fr;}
}
@media (max-width:1050px){
  .pcw-booking-page .pb-booking{grid-template-columns:1fr;padding:22px 18px 30px;}
}
@media (max-width:680px){
  .pb-step-badge{width:44px;height:44px;}
  .pcw-booking-page .pb-card-head h2{font-size:23px;}
}

/* === V12 refinements: clearer calendar header and spacing === */
.pcw-booking-page .pb-card-head{
  align-items:flex-start;
}
.pcw-booking-page .pb-card-head > div{
  min-width:0;
}
.pcw-booking-page .pb-card-head .pb-kicker-small{
  margin-bottom:6px;
}
.pcw-booking-page .pb-calendar-head-wrap{
  display:grid;
  grid-template-columns:56px minmax(0,1fr) auto;
  column-gap:16px;
  row-gap:6px;
  align-items:start;
}
.pcw-booking-page .pb-calendar-head-wrap .pb-step-badge{
  margin-top:2px;
}
.pcw-booking-page .pb-calendar-head-wrap h2{
  font-size:24px;
  line-height:1.05;
}
.pcw-booking-page .pb-calendar-actions{
  justify-self:end;
  align-self:start;
  gap:12px;
  margin-left:16px;
}
.pcw-booking-page .pb-step-badge em{
  right:-4px;
  bottom:-4px;
}
.pcw-booking-page .pb-step-badge{
  width:50px;
  height:50px;
}
.pcw-booking-page .pb-step-icon svg{
  width:22px;
  height:22px;
}
@media (max-width:680px){
  .pcw-booking-page .pb-calendar-head-wrap{
    grid-template-columns:52px minmax(0,1fr);
    column-gap:14px;
  }
  .pcw-booking-page .pb-calendar-actions{
    grid-column:1 / -1;
    justify-self:start;
    margin-left:0;
    margin-top:8px;
  }
  .pcw-booking-page .pb-step-badge{
    width:46px;
    height:46px;
  }
  .pcw-booking-page .pb-calendar-head-wrap h2{
    font-size:22px;
  }
}
/* === FORCE PCDoktor logo only === */
.pw-brand,
header .pw-brand,
.pw-header .pw-brand,
.pw-nav .pw-brand {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  height: auto !important;
}

.pw-brand img,
header .pw-brand img,
.pw-header .pw-brand img,
.pw-nav .pw-brand img {
  height: 76px !important;
  width: auto !important;
  max-width: 460px !important;
  min-width: 260px !important;
  object-fit: contain !important;
  display: block !important;
}

.pw-brand-copy {
  display: none !important;
}

/* === PCDoktor booking header layout polish v4 === */

.pw-header {
  min-height: 96px !important;
}

.pw-nav {
  min-height: 96px !important;
  display: grid !important;
  grid-template-columns: minmax(260px, 420px) 1fr minmax(150px, 220px) !important;
  align-items: center !important;
  gap: 28px !important;
}

.pw-brand {
  justify-self: start !important;
  display: flex !important;
  align-items: center !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.pw-brand img {
  height: 82px !important;
  width: auto !important;
  max-width: 390px !important;
  min-width: 300px !important;
  object-fit: contain !important;
  object-position: left center !important;
  filter: drop-shadow(0 0 18px rgba(0, 180, 255, 0.20)) !important;
}

.pw-brand-copy {
  display: none !important;
}

.pw-menu {
  justify-self: center !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 34px !important;
  width: auto !important;
}

.pw-menu a {
  font-size: 1.02rem !important;
  font-weight: 800 !important;
  padding: 12px 4px !important;
  border-radius: 0 !important;
  background: transparent !important;
  border: none !important;
  color: rgba(245, 250, 255, 0.92) !important;
  white-space: nowrap !important;
  box-shadow: none !important;
}

.pw-menu a:hover {
  color: #24c8ff !important;
  background: transparent !important;
  box-shadow: none !important;
}

.pw-menu a.active,
.pw-menu a[aria-current="page"] {
  color: #24c8ff !important;
  position: relative !important;
}

.pw-menu a.active::after,
.pw-menu a[aria-current="page"]::after,
.pw-menu a:hover::after {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 3px !important;
  height: 3px !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, #00d5ff, #1b78ff) !important;
  box-shadow: 0 0 16px rgba(0, 213, 255, 0.45) !important;
}

.pw-lang,
.pw-language,
.pw-lang-switch,
.pw-langbar {
  justify-self: end !important;
}

@media (max-width: 1100px) {
  .pw-nav {
    grid-template-columns: minmax(220px, 330px) 1fr minmax(120px, 180px) !important;
    gap: 18px !important;
  }

  .pw-brand img {
    height: 70px !important;
    min-width: 250px !important;
    max-width: 330px !important;
  }

  .pw-menu {
    gap: 22px !important;
  }
}

@media (max-width: 820px) {
  .pw-nav {
    display: flex !important;
    min-height: 78px !important;
    justify-content: space-between !important;
    gap: 14px !important;
  }

  .pw-brand img {
    height: 56px !important;
    min-width: 210px !important;
    max-width: 260px !important;
  }
}


/* === PCDoktor booking header container alignment fix === */

.pw-header {
  width: 100% !important;
}

.pw-nav {
  width: min(100% - 48px, 1720px) !important;
  max-width: 1720px !important;
  margin: 0 auto !important;

  display: grid !important;
  grid-template-columns: 360px 1fr 170px !important;
  align-items: center !important;
  gap: 28px !important;

  min-height: 94px !important;
}

.pw-brand {
  justify-self: start !important;
  width: auto !important;
  max-width: 360px !important;
}

.pw-brand img {
  height: 78px !important;
  width: auto !important;
  max-width: 340px !important;
  min-width: 260px !important;
  object-fit: contain !important;
}

.pw-menu {
  justify-self: center !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 54px !important;
  width: auto !important;
  max-width: none !important;
}

.pw-menu a {
  display: inline-flex !important;
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;

  padding: 10px 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;

  font-size: 1rem !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
  position: relative !important;
}

.pw-menu a::after {
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
}

.pw-lang,
.pw-language,
.pw-lang-switch,
.pw-langbar {
  justify-self: end !important;
}

@media (max-width: 1100px) {
  .pw-nav {
    width: min(100% - 32px, 1720px) !important;
    grid-template-columns: 280px 1fr 140px !important;
    gap: 18px !important;
  }

  .pw-brand img {
    height: 64px !important;
    min-width: 220px !important;
    max-width: 280px !important;
  }

  .pw-menu {
    gap: 28px !important;
  }
}

@media (max-width: 820px) {
  .pw-nav {
    display: flex !important;
    width: min(100% - 24px, 1720px) !important;
    justify-content: space-between !important;
    min-height: 76px !important;
  }

  .pw-brand img {
    height: 52px !important;
    min-width: 190px !important;
    max-width: 230px !important;
  }

  .pw-menu {
    gap: 18px !important;
  }
}


/* === PCDoktor final booking header: compact centered menu === */

.pw-nav {
  position: relative !important;
  width: min(100% - 48px, 1720px) !important;
  max-width: 1720px !important;
  margin: 0 auto !important;
  min-height: 92px !important;

  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

.pw-brand {
  flex: 0 0 auto !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  z-index: 2 !important;
}

.pw-brand img {
  height: 76px !important;
  width: auto !important;
  min-width: 260px !important;
  max-width: 340px !important;
  object-fit: contain !important;
}

.pw-menu {
  position: absolute !important;
  left: 50% !important;
  transform: translateX(-50%) !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  width: auto !important;
  max-width: none !important;
  gap: 34px !important;
  margin: 0 !important;
  padding: 0 !important;
}

.pw-menu a {
  display: inline-flex !important;
  flex: 0 0 auto !important;

  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;

  padding: 10px 0 !important;
  margin: 0 !important;

  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;

  color: rgba(245, 250, 255, 0.92) !important;
  font-size: 1rem !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
  position: relative !important;
}

.pw-menu a:hover,
.pw-menu a.active,
.pw-menu a[aria-current="page"] {
  color: #22c8ff !important;
}

.pw-menu a::after {
  content: none !important;
}

.pw-menu a:hover::after,
.pw-menu a.active::after,
.pw-menu a[aria-current="page"]::after {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  right: auto !important;
  bottom: 2px !important;
  width: 100% !important;
  height: 3px !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, #00d5ff, #1b78ff) !important;
  box-shadow: 0 0 14px rgba(0, 213, 255, 0.45) !important;
}

.pw-lang,
.pw-language,
.pw-lang-switch,
.pw-langbar {
  flex: 0 0 auto !important;
  margin-left: auto !important;
  z-index: 2 !important;
}

@media (max-width: 1100px) {
  .pw-nav {
    width: min(100% - 32px, 1720px) !important;
  }

  .pw-brand img {
    height: 64px !important;
    min-width: 220px !important;
    max-width: 280px !important;
  }

  .pw-menu {
    gap: 24px !important;
  }

  .pw-menu a {
    font-size: 0.95rem !important;
  }
}

@media (max-width: 820px) {
  .pw-nav {
    position: static !important;
    min-height: 78px !important;
  }

  .pw-menu {
    position: static !important;
    transform: none !important;
    gap: 16px !important;
  }

  .pw-brand img {
    height: 52px !important;
    min-width: 180px !important;
    max-width: 230px !important;
  }
}

