/* ============================================================
   VERATEM THEME — main.css
   Styles core Gutenberg blocks + embedded header/banner/footer.
   Loaded on the front end AND in the editor (add_editor_style).
   ============================================================ */

:root{
  --vt-teal:#0e8c8c; --vt-teal-deep:#0a6d6d; --vt-teal-soft:#e6f4f4;
  --vt-ink:#0b2a3a; --vt-ink-soft:#3d5563; --vt-line:#dfe7ea;
  --vt-mist:#f5f8f9; --vt-paper:#fff; --vt-accent:#f7941d; --vt-lime:#8bc34a;
  --vt-r:14px;
}

/* ---------- base ---------- */
body{font-family:'Inter',system-ui,-apple-system,sans-serif;color:var(--vt-ink);background:var(--vt-paper);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5,h6{font-family:'Space Grotesk',system-ui,sans-serif;letter-spacing:-.01em;line-height:1.12;color:var(--vt-ink)}
a{color:var(--vt-teal-deep)}
.vt-eyebrow,.is-style-vt-eyebrow{font-size:.78rem !important;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--vt-teal) !important;margin-bottom:.4rem}

/* ============================================================
   HEADER (template part)
   ============================================================ */
.vt-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--vt-line)}
.vt-header-inner{max-width:1160px;margin:0 auto;padding:0 26px;height:70px;display:flex;align-items:center;justify-content:space-between}
.vt-brand{display:flex;align-items:center;gap:10px;font-family:'Space Grotesk';font-weight:700;font-size:1.35rem;color:var(--vt-ink);text-decoration:none}
.vt-brand svg{width:30px;height:30px}
.vt-nav{display:flex;align-items:center;gap:30px}
.vt-nav ul,.vt-menu{list-style:none;display:flex;gap:30px;align-items:center;margin:0;padding:0}
.vt-nav li{position:relative}
.vt-nav a,.vt-menu a{font-size:.94rem;font-weight:500;color:var(--vt-ink-soft);text-decoration:none;transition:color .18s}
.vt-nav a:hover,.vt-menu a:hover,.vt-nav .current-menu-item>a{color:var(--vt-teal)}
/* dropdown submenu (WP menu children) */
.vt-nav .sub-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(6px);background:#fff;border:1px solid var(--vt-line);border-radius:12px;box-shadow:0 22px 48px -20px rgba(11,42,58,.3);padding:8px;min-width:210px;display:none;flex-direction:column;gap:2px}
.vt-nav li:hover>.sub-menu{display:flex}
.vt-nav .sub-menu a{display:block;padding:9px 13px;border-radius:8px;color:var(--vt-ink)}
.vt-nav .sub-menu a:hover{background:var(--vt-teal-soft);color:var(--vt-teal-deep)}
.vt-header-cta{background:var(--vt-ink);color:#fff !important;padding:10px 20px;border-radius:999px;font-size:.9rem;font-weight:600;text-decoration:none;transition:background .18s}
.vt-header-cta:hover{background:var(--vt-teal)}
.vt-burger{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.vt-burger span{width:24px;height:2px;background:var(--vt-ink);display:block}

/* ============================================================
   OMS GAMES DIVISION BANNER (template part)
   ============================================================ */
.vt-oms-section{padding-block:6px 10px}
.vt-oms-wrap{width:100%}
.vt-oms{width:100%;margin:0 auto;position:relative;display:block;border-radius:20px;overflow:hidden;border:1px solid var(--vt-line);box-shadow:0 30px 60px -30px rgba(11,42,58,.35);text-decoration:none;isolation:isolate}
.vt-oms::after{content:"";position:absolute;inset:0;border-radius:20px;pointer-events:none;box-shadow:inset 0 0 0 1.5px rgba(18,179,179,.55),inset 0 0 40px rgba(18,179,179,.15);z-index:3}
.vt-oms-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:1;transition:transform .6s ease}
.vt-oms:hover .vt-oms-bg{transform:scale(1.04)}
.vt-oms-content{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:30px;padding:44px 46px;flex-wrap:wrap}
.vt-oms-left{display:flex;flex-direction:column;gap:14px;max-width:640px}
.vt-oms-eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#7fe3e3}
.vt-oms-logo{width:min(440px,72vw);height:auto;filter:drop-shadow(0 2px 14px rgba(0,0,0,.5))}
.vt-oms-tag{color:#dbe9ee;font-size:1.02rem;max-width:46ch}
.vt-oms-btn{flex:0 0 auto;background:var(--vt-accent);color:#3a2400;font-weight:600;padding:15px 28px;border-radius:999px;font-size:1rem;box-shadow:0 8px 22px -8px rgba(247,148,29,.7);transition:transform .15s;text-decoration:none}
.vt-oms:hover .vt-oms-btn{transform:translateY(-2px)}
@media(max-width:760px){.vt-oms-content{padding:32px 26px;flex-direction:column;align-items:flex-start}.vt-oms-btn{width:100%;text-align:center}}

/* ============================================================
   SELECTABLE SECTION BACKGROUNDS (block styles)
   Apply via the block's Styles panel on Group / Cover / Columns.
   ============================================================ */
.is-style-vt-light{background:var(--vt-paper) !important;color:var(--vt-ink)}
.is-style-vt-mist{background:var(--vt-mist) !important;color:var(--vt-ink)}
.is-style-vt-dark{background:var(--vt-ink) !important;color:#e8eef2}
.is-style-vt-dark :where(h1,h2,h3,h4,h5,h6){color:#fff}
.is-style-vt-dark a{color:#7fd6d6}
.is-style-vt-teal{background:linear-gradient(120deg,#0b2a3a,#124e5c) !important;color:#eaf5f6}
.is-style-vt-teal :where(h1,h2,h3,h4,h5,h6){color:#fff}
.is-style-vt-teal a{color:#9fe6e6}
/* give the background styles comfortable section padding by default */
.is-style-vt-light,.is-style-vt-mist,.is-style-vt-dark,.is-style-vt-teal{
  padding-block:clamp(3rem,6vw,5rem);padding-inline:26px;border-radius:0
}
/* full-width sections: keep the coloured band edge-to-edge but centre inner content */
.alignfull.is-style-vt-light,.alignfull.is-style-vt-mist,
.alignfull.is-style-vt-dark,.alignfull.is-style-vt-teal{
  margin-inline:0 !important;max-width:none !important
}
.alignfull.is-style-vt-light > .wp-block-columns,
.alignfull.is-style-vt-mist > .wp-block-columns,
.alignfull.is-style-vt-dark > .wp-block-columns,
.alignfull.is-style-vt-teal > .wp-block-columns,
.alignfull.is-style-vt-light > :where(p,h2,h3),
.alignfull.is-style-vt-mist > :where(p,h2,h3),
.alignfull.is-style-vt-dark > :where(p,h2,h3),
.alignfull.is-style-vt-teal > :where(p,h2,h3){
  max-width:1160px;margin-inline:auto
}

/* Frosted "card" style for Group blocks */
.is-style-vt-card{
  background:var(--vt-paper);border:1px solid var(--vt-line);border-radius:var(--vt-r);
  padding:clamp(24px,3vw,34px);box-shadow:0 20px 40px -28px rgba(11,42,58,.3);
  transition:box-shadow .2s,transform .2s;height:100%
}
.is-style-vt-card:hover{box-shadow:0 26px 50px -26px rgba(11,42,58,.34);transform:translateY(-3px)}
/* cards inside dark/teal sections flip to a translucent frosted look */
.is-style-vt-dark .is-style-vt-card,.is-style-vt-teal .is-style-vt-card{
  background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16);color:#e8eef2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)
}

/* ---------- buttons (core button block, themed via theme.json too) ---------- */
.wp-block-button__link{border-radius:999px;font-weight:600;padding:14px 26px}
.wp-block-button.is-style-outline .wp-block-button__link{border:1.5px solid var(--vt-line);color:var(--vt-ink);background:#fff}
.wp-block-button.is-style-outline .wp-block-button__link:hover{border-color:var(--vt-teal);color:var(--vt-teal)}

/* ---------- pill tags (paragraph eyebrow used inline) ---------- */
.vt-tag{display:inline-block;font-size:.82rem;font-weight:500;color:var(--vt-teal-deep);background:var(--vt-teal-soft);border:1px solid #cfe8e8;padding:6px 13px;border-radius:999px;margin:0 6px 6px 0}

/* ---------- footer (template part) ---------- */
.vt-footer{background:var(--vt-ink);color:#c3d6de;padding:56px 26px 28px;margin-top:20px}
.vt-footer-grid{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:30px;padding-bottom:32px;border-bottom:1px solid #1e4657}
.vt-foot-brand{font-family:'Space Grotesk';font-weight:700;font-size:1.4rem;color:#fff;display:flex;align-items:center;gap:10px}
.vt-footer h5{color:#fff;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px}
.vt-footer ul{list-style:none;margin:0;padding:0}
.vt-footer li{margin-bottom:9px}
.vt-footer a{font-size:.92rem;color:#a9c2cd;text-decoration:none}
.vt-footer a:hover{color:var(--vt-teal)}
.vt-foot-bottom{max-width:1160px;margin:0 auto;padding-top:22px;font-size:.85rem;color:#7fa0ad;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---------- content width helpers ---------- */
.vt-narrow{max-width:820px;margin-inline:auto}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .vt-nav{display:none}
  .vt-burger{display:flex}
  .vt-nav.vt-open{display:flex;position:absolute;top:70px;left:0;right:0;background:#fff;border-bottom:1px solid var(--vt-line);flex-direction:column;padding:18px 26px}
  .vt-nav.vt-open ul{flex-direction:column;gap:14px;align-items:flex-start}
  .vt-footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){.vt-footer-grid{grid-template-columns:1fr}}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto !important}.vt-oms-bg{transition:none}}

/* ============================================================
   HERO pattern — grid background, panel, node diagram, tags
   ============================================================ */
.vt-hero{position:relative;overflow:hidden}
/* subtle teal grid background */
.vt-hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(to right, rgba(14,140,140,.07) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(14,140,140,.07) 1px, transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:linear-gradient(180deg,#000,transparent 92%);
  mask-image:linear-gradient(180deg,#000,transparent 92%);
}
.vt-hero > *{position:relative;z-index:1}
.vt-hero-cols{gap:40px}
.vt-hero .wp-block-heading{font-size:clamp(2.4rem,5vw,3.7rem);font-weight:700}

/* tag pills */
.vt-tags{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 4px}

/* architecture node panel */
.vt-hero-panel{background:#fff;border:1px solid var(--vt-line);border-radius:var(--vt-r);box-shadow:0 30px 60px -30px rgba(11,42,58,.28);overflow:hidden}
.vt-hero-panel-cap{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:1px solid var(--vt-line);font-size:.82rem;color:var(--vt-ink-soft);font-weight:500}
.vt-dot{width:10px;height:10px;border-radius:50%;display:inline-block}
.vt-hero-panel svg{display:block;width:100%;height:auto}

@media(max-width:900px){
  .vt-hero-panel{max-width:440px;margin:10px auto 0}
}

/* ============================================================
   COMBINED TOP (Banner + Hero on one shared grid)
   ============================================================ */
.vt-top{position:relative;overflow:hidden;padding-block:28px clamp(3rem,6vw,5rem)}
/* shared teal grid behind BOTH banner and hero */
.vt-top::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(to right, rgba(14,140,140,.07) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(14,140,140,.07) 1px, transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:linear-gradient(180deg,#000,transparent 96%);
  mask-image:linear-gradient(180deg,#000,transparent 96%);
}
.vt-top > *{position:relative;z-index:1}
.vt-top .vt-hero-cols{gap:40px;margin-top:26px}
.vt-top .wp-block-heading{font-size:clamp(2.4rem,5vw,3.7rem);font-weight:700}

/* SLIM banner variant — thinner strip, wide, inline on the grid */
.vt-oms-slim{width:100%;max-width:1160px;margin:0 auto;display:block;position:relative;
  border-radius:16px;overflow:hidden;border:1px solid var(--vt-line);
  box-shadow:0 22px 48px -30px rgba(11,42,58,.35);text-decoration:none;isolation:isolate}
.vt-oms-slim::after{content:"";position:absolute;inset:0;border-radius:16px;pointer-events:none;
  box-shadow:inset 0 0 0 1.5px rgba(18,179,179,.55),inset 0 0 34px rgba(18,179,179,.14);z-index:3}
.vt-oms-slim .vt-oms-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:1;transition:transform .6s ease}
.vt-oms-slim:hover .vt-oms-bg{transform:scale(1.04)}
.vt-oms-slim .vt-oms-content{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px 30px;flex-wrap:wrap}
.vt-oms-slim .vt-oms-left{display:flex;flex-direction:column;gap:4px}
.vt-oms-slim .vt-oms-eyebrow{font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#7fe3e3}
.vt-oms-slim .vt-oms-logo{width:min(300px,60vw);height:auto;filter:drop-shadow(0 2px 12px rgba(0,0,0,.5))}
.vt-oms-slim .vt-oms-btn{flex:0 0 auto;background:var(--vt-accent);color:#3a2400;font-weight:600;padding:12px 22px;border-radius:999px;font-size:.95rem;box-shadow:0 8px 22px -8px rgba(247,148,29,.7);transition:transform .15s;text-decoration:none}
.vt-oms-slim:hover .vt-oms-btn{transform:translateY(-2px)}
@media(max-width:640px){
  .vt-oms-slim .vt-oms-content{flex-direction:column;align-items:flex-start;padding:18px 22px}
  .vt-oms-slim .vt-oms-btn{width:100%;text-align:center}
}

/* ============================================================
   SUB-PAGE hero (Services/About) + CTA section
   ============================================================ */
.vt-subhero{position:relative;overflow:hidden;padding-block:64px;background:linear-gradient(180deg,#fff,var(--vt-mist))}
.vt-subhero::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:linear-gradient(to right,rgba(14,140,140,.07) 1px,transparent 1px),linear-gradient(to bottom,rgba(14,140,140,.07) 1px,transparent 1px);
  background-size:46px 46px;-webkit-mask-image:linear-gradient(180deg,#000,transparent 92%);mask-image:linear-gradient(180deg,#000,transparent 92%)}
.vt-subhero > *{position:relative;z-index:1}
.vt-subhero .wp-block-heading{font-size:clamp(2.2rem,4.6vw,3.4rem);font-weight:700}
.vt-crumb{font-size:.85rem;color:var(--vt-ink-soft)}
.vt-crumb a{color:var(--vt-teal-deep);font-weight:500}
.vt-cta-section{padding-block:clamp(3rem,6vw,5rem);text-align:center}

/* ============================================================
   CLASSIC MENU (wp_nav_menu) — header dropdowns
   ============================================================ */
.vt-menu{list-style:none;display:flex;gap:30px;align-items:center;margin:0;padding:0}
.vt-menu li{position:relative}
.vt-menu a{font-size:.94rem;font-weight:500;color:var(--vt-ink-soft);text-decoration:none;transition:color .18s}
.vt-menu a:hover,.vt-menu .current-menu-item>a{color:var(--vt-teal)}
/* dropdown submenus */
/* parent needs padding-bottom so the hover zone reaches the submenu (no dead gap) */
.vt-menu .menu-item-has-children{padding-bottom:18px;margin-bottom:-18px}
.vt-menu .sub-menu{position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--vt-line);border-radius:12px;box-shadow:0 22px 48px -20px rgba(11,42,58,.3);padding:8px;min-width:210px;list-style:none;margin:0;display:none;z-index:60}
/* invisible bridge across any remaining gap so the cursor never "leaves" */
.vt-menu .sub-menu::before{content:"";position:absolute;top:-18px;left:0;right:0;height:18px}
.vt-menu .menu-item-has-children:hover > .sub-menu,
.vt-menu .sub-menu:hover{display:block}
.vt-menu .sub-menu li{width:100%}
.vt-menu .sub-menu a{display:block;padding:9px 13px;border-radius:8px;color:var(--vt-ink);white-space:nowrap}
.vt-menu .sub-menu a:hover{background:var(--vt-teal-soft);color:var(--vt-teal-deep)}
/* caret on parents */
.vt-menu .menu-item-has-children > a::after{content:"▾";margin-left:5px;font-size:.7em;opacity:.7}
@media(max-width:900px){
  .vt-menu{flex-direction:column;gap:14px;align-items:flex-start}
  .vt-menu .sub-menu{position:static;display:block;box-shadow:none;border:0;padding:4px 0 4px 14px;min-width:0}
}

/* ============================================================
   IT SERVICE AREA (Services to IT Companies page)
   ============================================================ */
.vt-area{border:1px solid var(--vt-line);border-radius:20px;overflow:hidden;margin-bottom:34px;background:#fff;box-shadow:0 24px 50px -34px rgba(11,42,58,.22);padding:0}
.vt-area-head{align-items:center;gap:22px;padding:30px 34px;border-bottom:1px solid var(--vt-line);margin:0}
.vt-area-brand{font-family:'Space Grotesk';font-weight:700;font-size:1.7rem;color:var(--vt-teal-deep);margin:0;flex:0 0 auto;min-width:150px}
.vt-area-head .is-style-vt-eyebrow{margin-bottom:2px}
.vt-area-head h2{font-size:1.5rem;margin:0}
.vt-area-intro{padding:24px 34px;color:var(--vt-ink-soft);font-size:1rem;border-bottom:1px solid var(--vt-line);background:var(--vt-mist);margin:0}
.vt-area-body{padding:34px;gap:34px;margin:0}
.vt-area-body h4{font-size:.82rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--vt-teal-deep);margin:0 0 8px}
.vt-area-body ul{margin:0 0 20px;padding-left:20px}
.vt-area-body li{font-size:.94rem;color:var(--vt-ink-soft);margin-bottom:5px}
/* accordion */
.vt-acc{border:1px solid var(--vt-line);border-radius:12px;background:var(--vt-mist);padding:16px 20px}
.vt-acc summary{cursor:pointer;font-weight:600;font-family:'Space Grotesk';color:var(--vt-ink);font-size:1rem}
.vt-acc ol{margin:14px 0 0;padding-left:22px}
.vt-acc li{font-size:.9rem;color:var(--vt-ink-soft);margin-bottom:5px}
.vt-area .wp-block-buttons{padding:22px 34px;border-top:1px solid var(--vt-line);margin:0}
@media(max-width:900px){
  .vt-area-head{flex-direction:column;align-items:flex-start;gap:12px}
  .vt-area-body{flex-direction:column}
}
.vt-acc-note{margin-top:12px;font-style:italic;color:var(--vt-ink-soft);font-size:.88rem}

/* ============================================================
   ABOUT — editorial story sections
   ============================================================ */
.vt-story{padding-block:clamp(3rem,6vw,4.5rem);border-bottom:1px solid var(--vt-line)}
.vt-story.is-style-vt-mist{border-bottom:1px solid var(--vt-line)}
.vt-story-cols{gap:50px !important;align-items:flex-start}
.vt-story-head{position:sticky;top:100px}
.vt-story-head .is-style-vt-eyebrow{margin-bottom:8px}
.vt-story-head h2{font-size:clamp(1.7rem,3vw,2.3rem);margin:0}
.vt-story-body p{color:var(--vt-ink-soft);margin-bottom:20px;max-width:70ch}
.vt-story-body p:last-child{margin-bottom:0}
.vt-story-body strong{color:var(--vt-ink);font-weight:600}
@media(max-width:820px){
  .vt-story-cols{gap:20px !important}
  .vt-story-head{position:static}
}

/* ============================================================
   CONTACT page
   ============================================================ */
.vt-contact-cols{gap:26px !important;align-items:stretch}
.vt-contact-card,.vt-contact-form{height:100%}
.vt-contact-list{margin:16px 0 22px;display:grid;grid-template-columns:1fr;gap:0}
.vt-contact-list dt{font-family:'Space Grotesk';font-weight:600;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:var(--vt-teal-deep);margin-top:16px}
.vt-contact-list dt:first-child{margin-top:0}
.vt-contact-list dd{color:var(--vt-ink-soft);font-size:1rem;margin:3px 0 0}
.vt-contact-list dd a{color:var(--vt-teal-deep);font-weight:500}
.vt-form-placeholder{border:2px dashed var(--vt-line);border-radius:12px;padding:26px;color:var(--vt-ink-soft);font-size:.95rem;background:var(--vt-mist);text-align:center}
/* style WPForms to match the theme once inserted */
.vt-contact-form .wpforms-field-label{font-family:'Space Grotesk';font-weight:600;font-size:.9rem;color:var(--vt-ink)}
.vt-contact-form .wpforms-field input,
.vt-contact-form .wpforms-field textarea,
.vt-contact-form .wpforms-field select{border:1px solid var(--vt-line) !important;border-radius:10px !important;padding:12px 14px !important;font-family:inherit !important}
.vt-contact-form .wpforms-submit{background:var(--vt-accent) !important;color:#3a2400 !important;border:0 !important;border-radius:999px !important;padding:14px 28px !important;font-weight:600 !important}
@media(max-width:820px){.vt-contact-cols{gap:20px !important}}
