/* Ventira corporate website UI kit — layout styling (consumes DS tokens) */

.vw-app { background: var(--surface-card); overflow-x: clip; }
.vw-hero__title, .vw-svc__title, .vw-seg__title, .vw-projcard__name, .vw-post__title, .vw-post__rowtitle, .vw-om__title, .vw-statsband__title { overflow-wrap: break-word; }
/* O&M / dark section: keep the emphasised word readable on dark */
.vw-section--dark .v-heading__title em, .vw-statsband .v-heading__title em { color: var(--red-400) !important; }
.vw-container { max-width: var(--container-max); margin: 0 auto; padding: 0 var(--space-8); }

/* ---------- Header ---------- */
.vw-header { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,0.92);
  backdrop-filter: saturate(1.4) blur(8px); border-bottom: 1px solid var(--border-subtle); }
.vw-header__inner { max-width: var(--container-wide); margin: 0 auto; padding: 0 var(--space-8);
  height: 72px; display: flex; align-items: center; gap: var(--space-8); }
.vw-header__logo { cursor: pointer; display: flex; align-items: center; }
.vw-nav { display: flex; gap: var(--space-6); margin-left: var(--space-4); flex: 1; }
.vw-nav__link { font-family: var(--font-display); font-weight: var(--fw-semibold); font-size: var(--fs-sm);
  color: var(--ink-700); cursor: pointer; padding: 6px 0; position: relative; letter-spacing: .01em; }
.vw-nav__link::after { content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 2px;
  background: var(--red-500); transform: scaleX(0); transition: transform var(--dur-base) var(--ease-out); }
.vw-nav__link:hover { color: var(--ink-900); }
.vw-nav__link:hover::after, .vw-nav__link.is-active::after { transform: scaleX(1); }
.vw-nav__link.is-active { color: var(--red-600); }
.vw-header__cta { display: flex; align-items: center; gap: var(--space-5); }
.vw-header__phone { display: flex; align-items: center; gap: 6px; font-family: var(--font-mono);
  font-size: var(--fs-xs); color: var(--ink-600); white-space: nowrap; }
.vw-header__phone i { width: 15px; height: 15px; color: var(--red-500); }
.vw-lang { display: inline-flex; align-items: center; gap: 4px; }
.vw-lang__btn { appearance: none; border: 0; background: transparent; cursor: pointer; padding: 4px 4px;
  font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-2xs); letter-spacing: .04em;
  color: var(--ink-400); transition: color var(--dur-fast) var(--ease-standard); }
.vw-lang__btn.is-on { color: var(--red-600); }
.vw-lang__btn:hover { color: var(--ink-800); }
.vw-lang__sep { color: var(--ink-300); font-size: var(--fs-2xs); }
.vw-burger { display: none; align-items: center; justify-content: center; width: 42px; height: 42px;
  border: 0; background: transparent; color: var(--ink-800); cursor: pointer; padding: 0; }
.vw-burger i { width: 26px; height: 26px; }
.vw-mobilemenu { display: none; flex-direction: column; padding: var(--space-3) var(--space-5) var(--space-6);
  background: #fff; border-bottom: 1px solid var(--border-subtle); box-shadow: var(--shadow-md); }
.vw-mobilemenu.is-open { display: flex; }
.vw-mobilemenu__link { font-family: var(--font-display); font-weight: var(--fw-semibold); text-transform: uppercase;
  letter-spacing: var(--ls-wide); font-size: var(--fs-sm); color: var(--ink-700); padding: var(--space-4) 0;
  border-bottom: 1px solid var(--border-subtle); cursor: pointer; }
.vw-mobilemenu__phone { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono);
  font-size: var(--fs-sm); color: var(--ink-700); padding: var(--space-4) 0; text-decoration: none; }
.vw-mobilemenu__phone i { width: 16px; height: 16px; color: var(--red-500); }
.vw-mobilemenu .v-btn { margin-top: var(--space-3); }

/* ---------- Hero ---------- */
.vw-hero { position: relative; min-height: 600px; display: flex; align-items: center; overflow: hidden; }
.vw-hero__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.vw-hero__scrim { position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(20,20,20,.82) 0%, rgba(20,20,20,.55) 45%, rgba(20,20,20,.15) 100%); }
.vw-hero__inner { position: relative; max-width: var(--container-max); margin: 0 auto; padding: var(--space-20) var(--space-8); width: 100%; }
.vw-hero__kicker { font-family: var(--font-display); font-style: italic; font-weight: var(--fw-bold);
  font-size: var(--fs-sm); letter-spacing: var(--ls-wider); text-transform: uppercase; color: #fff; margin: 0 0 var(--space-4);
  display: inline-flex; align-items: center; gap: 10px; }
.vw-hero__kicker::before { content: ""; width: 36px; height: 3px; background: var(--red-500); border-radius: 999px; }
.vw-hero__title { font-family: var(--font-display); font-weight: var(--fw-black); text-transform: uppercase;
  letter-spacing: var(--ls-tight); line-height: 1.02; font-size: clamp(2.4rem, 5vw, 4rem); color: #fff; margin: 0 0 var(--space-5); max-width: 16ch; }
.vw-hero__title em { font-style: normal; color: var(--red-500); }
.vw-hero__sub { font-family: var(--font-body); font-size: var(--fs-lg); line-height: var(--lh-body);
  color: rgba(255,255,255,.9); max-width: 60ch; margin: 0 0 var(--space-8); text-align: justify; text-justify: inter-word; }
.vw-hero__actions { display: flex; gap: var(--space-4); flex-wrap: wrap; }

/* Justified body copy site-wide */
.v-heading__sub, .vw-post__excerpt, .vw-seg__desc { text-align: justify; text-justify: inter-word; }

/* ---------- Sections ---------- */
.vw-section { padding: var(--section-y) 0; }
.vw-section--tint { background: var(--surface-page); }
.vw-grid3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); margin-top: var(--space-10); }

/* Services card icon spacing handled by Card; references */
.vw-ref__head { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-3); }
.vw-ref__loc { display: inline-flex; align-items: center; gap: 5px; font-size: var(--fs-xs); color: var(--text-muted); margin-top: 3px; }
.vw-ref__loc i { width: 13px; height: 13px; }

/* ---------- GES steps ---------- */
.vw-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); margin: var(--space-12) 0; }
.vw-step { position: relative; display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-2); }
.vw-step strong { font-family: var(--font-display); text-transform: uppercase; letter-spacing: var(--ls-wide); font-size: var(--fs-sm); color: var(--ink-800); margin-top: 6px; }
.vw-step span { font-size: var(--fs-sm); color: var(--text-muted); }
.vw-step__arrow { position: absolute; top: 24px; right: -14px; width: 26px; height: 26px; color: var(--red-300); }

/* GES advantage panel — dark, with a red accent rule */
.vw-panel { display: grid; grid-template-columns: 1.1fr 0.9fr; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); margin-top: var(--space-12); }
.vw-panel__text { background: var(--ink-950); color: #fff; padding: var(--space-12); display: flex; flex-direction: column; gap: var(--space-4); justify-content: center; position: relative; }
.vw-panel__text::before { content: ""; position: absolute; left: 0; top: var(--space-12); bottom: var(--space-12); width: 3px; background: var(--red-500); border-radius: 999px; }
.vw-panel__kicker { font-family: var(--font-display); font-style: italic; font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: var(--ls-wider); font-size: var(--fs-sm); color: var(--red-400); }
.vw-panel__text h3 { color: #fff; font-size: var(--fs-2xl); margin: 0; line-height: var(--lh-heading); }
.vw-panel__text p { color: rgba(255,255,255,.78); font-size: var(--fs-md); line-height: var(--lh-body); margin: 0; }
.vw-panel__text .v-btn { align-self: flex-start; margin-top: var(--space-2); }
.vw-panel__media { position: relative; min-height: 280px; }
.vw-panel__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }

/* ---------- Stats band ---------- */
.vw-statsband { background: var(--ink-950); color: #fff; padding: var(--space-12) 0; }
.vw-statsband__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-10); flex-wrap: wrap; }
.vw-statsband__kicker { font-family: var(--font-display); font-style: italic; font-weight: var(--fw-bold);
  text-transform: uppercase; letter-spacing: var(--ls-wider); font-size: var(--fs-sm); margin: 0 0 4px; color: var(--red-400); }
.vw-statsband__title { font-family: var(--font-display); font-weight: var(--fw-extra); text-transform: uppercase;
  font-size: var(--fs-2xl); margin: 0; color: #fff; }
.vw-statsband__stats { display: flex; gap: var(--space-12); }

/* ---------- Contact ---------- */
.vw-contact { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-16); align-items: start; }
.vw-contact__list { list-style: none; padding: 0; margin: var(--space-8) 0 0; display: flex; flex-direction: column; gap: var(--space-5); }
.vw-contact__list li { display: flex; gap: var(--space-4); align-items: flex-start; }
.vw-contact__list li > div { display: flex; flex-direction: column; gap: 2px; padding-top: 2px; flex: 1 1 auto; min-width: 0; }
.vw-contact__list li > div strong { display: block; font-family: var(--font-body); color: var(--ink-800); font-size: var(--fs-md); line-height: var(--lh-snug); white-space: nowrap; }
.vw-contact__list li > div span { display: block; color: var(--text-muted); font-size: var(--fs-sm); line-height: var(--lh-snug); }
.vw-contact__list li > div strong a, .vw-contact__list li > div span a { color: inherit; text-decoration: none; }
.vw-contact__list li > div span a:hover { color: var(--red-600); }
.vw-wa { display: inline-flex; align-items: center; gap: 10px; margin-top: var(--space-6);
  background: #25D366; color: #fff; font-family: var(--font-display); font-weight: var(--fw-bold);
  text-transform: uppercase; letter-spacing: var(--ls-wide); font-size: var(--fs-xs);
  padding: 0 var(--space-6); height: var(--control-h-md); border-radius: var(--radius-md);
  text-decoration: none; transition: background var(--dur-fast) var(--ease-standard), transform var(--dur-fast) var(--ease-standard); }
.vw-wa:hover { background: #1da851; color: #fff; text-decoration: none; }
.vw-wa:active { transform: translateY(1px); }
.vw-wa i { width: 18px; height: 18px; }
.vw-contact__form { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg);
  padding: var(--space-8); box-shadow: var(--shadow-card); display: flex; flex-direction: column; gap: var(--space-5); }
.vw-contact__two { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }

/* ---------- Footer ---------- */
.vw-footer { background: var(--ink-950); color: rgba(255,255,255,.8); padding-top: var(--space-16); }
.vw-footer__inner { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--space-8); padding-bottom: var(--space-12); }
.vw-footer__brand p { margin: var(--space-4) 0 0; font-size: var(--fs-sm); line-height: var(--lh-body); max-width: 38ch; color: rgba(255,255,255,.6); }
.vw-footer__col { display: flex; flex-direction: column; gap: var(--space-3); }
.vw-footer__col h5 { font-family: var(--font-display); text-transform: uppercase; letter-spacing: var(--ls-wide);
  font-size: var(--fs-xs); color: #fff; margin: 0 0 var(--space-2); }
.vw-footer__col a, .vw-footer__col span { font-size: var(--fs-sm); color: rgba(255,255,255,.62); cursor: pointer; }
.vw-footer__col a:hover { color: var(--red-400); }
.vw-footer__bar { border-top: 1px solid rgba(255,255,255,.1); padding: var(--space-5) 0; }
.vw-footer__barinner { display: flex; justify-content: space-between; font-size: var(--fs-xs); color: rgba(255,255,255,.5); }

@media (max-width: 920px) {
  .vw-nav, .vw-header__phone, .vw-header__teklif { display: none; }
  .vw-burger { display: inline-flex; }
  .vw-header__inner { gap: var(--space-4); padding: 0 var(--space-5); }
  .vw-header__cta { gap: var(--space-3); margin-left: auto; }
  .vw-container { padding: 0 var(--space-5); }
  .vw-section { padding: var(--space-16) 0; }
  .vw-hero { min-height: 500px; }
  .vw-hero__inner { padding: var(--space-16) var(--space-5); }
  .vw-grid3, .vw-steps, .vw-contact, .vw-footer__inner { grid-template-columns: 1fr; }
  .vw-panel { grid-template-columns: 1fr; }
  .vw-statsband__inner { justify-content: flex-start; }
  .vw-statsband__stats { flex-wrap: wrap; gap: var(--space-8); }
  .vw-svcgrid { grid-template-columns: repeat(2, 1fr); }
  .vw-om__grid { grid-template-columns: repeat(2, 1fr); }
  .vw-blog__grid { grid-template-columns: 1fr; }
  .vw-om__head { flex-direction: column; align-items: flex-start; gap: var(--space-6); }
  .vw-contact__two { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .vw-svcgrid, .vw-om__grid { grid-template-columns: 1fr; }
  .vw-post--row { flex-direction: column; }
  .vw-post__thumb { width: 100%; height: 160px; }
  .vw-contact__two { grid-template-columns: 1fr; }
  .vw-contact__form { padding: var(--space-5); }
  .vw-statsband__stats { gap: var(--space-6); }
  .vw-proj__head, .vw-blog__head { flex-direction: column; align-items: flex-start; gap: var(--space-4); }
  .vw-footer__inner { grid-template-columns: 1fr 1fr; }
  .vw-hero__inner { padding: var(--space-12) var(--space-5); }
}

/* ---------- Services grid ---------- */
.vw-svcgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); margin-top: var(--space-10); }
.vw-svc .v-card__body { gap: var(--space-3); padding: var(--space-6); }
.vw-svc__top { display: flex; align-items: center; justify-content: space-between; gap: var(--space-2); }
.vw-svc__title { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-lg);
  color: var(--ink-800); margin: var(--space-1) 0 0; line-height: var(--lh-heading); }
.vw-svc__desc { font-size: var(--fs-sm); color: var(--text-muted); line-height: var(--lh-body); margin: 0; }
.vw-svclink { text-decoration: none; color: inherit; display: block; }
.vw-svclink .vw-svc { height: 100%; }
.vw-svc__more { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-display);
  font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: var(--ls-wide); font-size: var(--fs-2xs);
  color: var(--red-600); margin-top: auto; padding-top: var(--space-2); opacity: 0; transform: translateX(-4px);
  transition: opacity var(--dur-base) var(--ease-standard), transform var(--dur-base) var(--ease-standard); }
.vw-svc__more i { width: 14px; height: 14px; }
.vw-svclink:hover .vw-svc__more { opacity: 1; transform: translateX(0); }
.vw-postlink { text-decoration: none; color: inherit; display: block; }

/* ---------- GES segments ---------- */
.vw-seggrid { align-items: stretch; }
.vw-seg .v-card__body { gap: var(--space-2); }
.vw-seg__title { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-xl);
  color: var(--ink-800); margin: 2px 0 0; }
.vw-seg__range { align-self: flex-start; font-family: var(--font-mono); letter-spacing: 0; text-transform: none; }
.vw-seg__desc { font-size: var(--fs-sm); color: var(--text-muted); line-height: var(--lh-body); margin: var(--space-1) 0 0; }
.vw-seg--featured { box-shadow: var(--shadow-lg); }

/* ---------- O&M (dark section) ---------- */
.vw-section--dark { background: var(--ink-950); color: rgba(255,255,255,.8); }
.vw-om__head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-8); }
.vw-om__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); margin: var(--space-12) 0 var(--space-10); }
.vw-om__card { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.09); border-radius: var(--radius-md);
  padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-3); transition: border-color var(--dur-base) var(--ease-standard), background var(--dur-base) var(--ease-standard); }
.vw-om__card:hover { border-color: rgba(237,28,36,.5); background: rgba(255,255,255,.06); }
.vw-om__title { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-md);
  color: #fff; margin: var(--space-1) 0 0; line-height: var(--lh-heading); }
.vw-om__desc { font-size: var(--fs-sm); color: rgba(255,255,255,.62); line-height: var(--lh-body); margin: 0; }
.vw-om__standards { display: flex; align-items: center; gap: var(--space-5); flex-wrap: wrap;
  border-top: 1px solid rgba(255,255,255,.1); padding-top: var(--space-6); }
.vw-om__stdlabel { font-family: var(--font-display); text-transform: uppercase; letter-spacing: var(--ls-caps);
  font-size: var(--fs-2xs); color: rgba(255,255,255,.5); }
.vw-om__chips { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.vw-om__chip { color: rgba(255,255,255,.85); border-color: rgba(255,255,255,.22); font-family: var(--font-mono); letter-spacing: 0; }

/* ---------- Projects slider ---------- */
.vw-proj__head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-8); }
.vw-proj__nav { display: flex; gap: var(--space-2); flex: 0 0 auto; }
.vw-proj__scroller { overflow-x: auto; overflow-y: hidden; margin-top: var(--space-10); scroll-snap-type: x mandatory;
  scrollbar-width: thin; -webkit-overflow-scrolling: touch; }
.vw-proj__scroller::-webkit-scrollbar { height: 6px; }
.vw-proj__scroller::-webkit-scrollbar-thumb { background: var(--ink-200); border-radius: 999px; }
.vw-proj__track { display: flex; gap: var(--space-5); padding: var(--space-1) max(var(--space-8), calc((100vw - var(--container-max)) / 2)) var(--space-6); }
.vw-projcard { flex: 0 0 320px; width: 320px; background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md); overflow: hidden; box-shadow: var(--shadow-card); scroll-snap-align: start;
  transition: box-shadow var(--dur-base) var(--ease-standard), transform var(--dur-base) var(--ease-standard); }
.vw-projcard:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); }
.vw-projcard__media { position: relative; aspect-ratio: 16/10; overflow: hidden; background: var(--ink-100); }
.vw-projcard__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.vw-projcard__status { position: absolute; top: var(--space-3); left: var(--space-3); }
.vw-projcard__body { padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-2); }
.vw-projcard__name { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-lg);
  color: var(--ink-800); margin: 2px 0 0; line-height: var(--lh-heading); }
.vw-projcard__meta { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }
.vw-projcard__loc { display: inline-flex; align-items: center; gap: 5px; font-size: var(--fs-xs); color: var(--text-muted); }
.vw-projcard__loc i { width: 13px; height: 13px; }
.vw-projcard__year { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--text-subtle); }
.vw-projcard__power { font-family: var(--font-mono); font-weight: var(--fw-semibold); font-size: var(--fs-xl);
  color: var(--red-600); margin-top: 2px; letter-spacing: -0.01em; }

/* ---------- Blog ---------- */
.vw-blog__head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-8); }
.vw-blog__grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: var(--space-8); margin-top: var(--space-10); align-items: start; }
.vw-post__meta { display: flex; align-items: center; gap: var(--space-3); }
.vw-post__date { display: inline-flex; align-items: center; gap: 5px; font-size: var(--fs-xs); color: var(--text-muted); }
.vw-post__date i { width: 13px; height: 13px; }
.vw-post--featured .v-card__body { gap: var(--space-3); padding: var(--space-8); }
.vw-post__title { font-family: var(--font-display); font-weight: var(--fw-extra); font-size: var(--fs-2xl);
  color: var(--ink-800); margin: var(--space-1) 0 0; line-height: var(--lh-heading); }
.vw-post__excerpt { font-size: var(--fs-md); color: var(--text-body); line-height: var(--lh-body); margin: 0; }
.vw-post__more { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-display);
  font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: var(--ls-wide); font-size: var(--fs-xs);
  color: var(--red-600); margin-top: var(--space-1); }
.vw-post__more i { width: 15px; height: 15px; }
.vw-blog__list { display: flex; flex-direction: column; gap: var(--space-4); }
.vw-post--row { display: flex; flex-direction: row; align-items: stretch; gap: 0; }
.vw-post--row .v-card__body { flex-direction: row; gap: var(--space-4); padding: 0; align-items: stretch; }
.vw-post__thumb { width: 116px; min-height: 100%; object-fit: cover; flex: 0 0 auto; }
.vw-post__rowbody { display: flex; flex-direction: column; gap: var(--space-2); padding: var(--space-4) var(--space-4) var(--space-4) 0; justify-content: center; }
.vw-post__rowtitle { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-md);
  color: var(--ink-800); margin: 0; line-height: var(--lh-heading); }

/* ============================================================
   RESPONSIVE OVERRIDES — must stay LAST so they win over the
   base grid rules (repeat(4,1fr) etc.) defined above.
   ============================================================ */
@media (max-width: 980px) {
  .vw-svcgrid, .vw-om__grid { grid-template-columns: repeat(2, 1fr) !important; }
  .vw-blog__grid { grid-template-columns: 1fr !important; }
  .vw-om__head, .vw-proj__head, .vw-blog__head { flex-direction: column; align-items: flex-start; gap: var(--space-5); }
}
@media (max-width: 600px) {
  .vw-svcgrid, .vw-om__grid, .vw-blog__grid { grid-template-columns: 1fr !important; }
  .vw-contact, .vw-contact__two, .vw-footer__inner, .vw-grid3, .vw-panel { grid-template-columns: 1fr !important; }
  .vw-post--row { flex-direction: column; }
  .vw-post--row .v-card__body { flex-direction: column; }
  .vw-post__thumb { width: 100%; height: 170px; }
  .vw-post__rowbody { padding: var(--space-4); }
}
