/*
Theme Name: VesselIndia
Theme URI: https://www.vesselindia.com
Author: VB Web Consultant
Author URI: https://www.vbwebconsultant.com
Description: Professional Industrial Vessel & Process Equipment B2B WordPress Theme for VesselIndia.com. Includes pages for Pharmaceutical, Chemical, Food & Beverage, Oil & Refinery, Fertilizer, Cosmetic vessels, Pressure Vessels, Storage Tanks, Our Associates, Contact, and all legal pages. 100% SEO optimized with schema markup, WhatsApp button, inquiry forms, and responsive design.
Version: 2.0.0
Requires at least: 5.8
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: vesselindia
Tags: business, industrial, b2b, responsive, custom-menu, custom-logo, featured-images

© 2026 VB Web and Software Solution - https://www.vbwebsol.com
Developed By: VB Web Consultant - https://www.vbwebconsultant.com
*/

/* =====================================================
   GOOGLE FONTS – loaded via @import as fallback
   (also enqueued in functions.php)
===================================================== */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow:ital,wght@0,300;0,400;0,500;0,600;0,700;0,900&family=Barlow+Condensed:wght@400;600;700;900&display=swap');

/* =====================================================
   CSS CUSTOM PROPERTIES
===================================================== */
:root {
  --vi-navy:       #0a1628;
  --vi-navy2:      #0f2040;
  --vi-steel:      #1a3a5c;
  --vi-accent:     #e8821a;
  --vi-accent2:    #f5a623;
  --vi-silver:     #c8d8e8;
  --vi-light:      #f0f4f8;
  --vi-white:      #ffffff;
  --vi-text:       #2c3e50;
  --vi-muted:      #6b7f95;
  --vi-border:     #dde8f2;
  --vi-gradient:   linear-gradient(135deg,#0a1628 0%,#1a3a5c 100%);
  --vi-font-head:  'Bebas Neue','Arial Black',sans-serif;
  --vi-font-cond:  'Barlow Condensed','Arial Narrow',sans-serif;
  --vi-font-body:  'Barlow','Segoe UI',Tahoma,sans-serif;
  --vi-radius:     10px;
  --vi-shadow:     0 4px 24px rgba(10,22,40,.10);
  --vi-shadow-lg:  0 12px 48px rgba(10,22,40,.16);
}

/* =====================================================
   RESET & BASE
===================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--vi-font-body);color:var(--vi-text);background:#fff;overflow-x:hidden;line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{color:var(--vi-accent);text-decoration:none;transition:color .2s}
a:hover{color:var(--vi-accent2)}
ul{list-style:none}
p{margin-bottom:1rem}
h1,h2,h3,h4,h5,h6{font-family:var(--vi-font-cond);color:var(--vi-navy);line-height:1.15;font-weight:700;margin-bottom:.5rem}

/* =====================================================
   LAYOUT
===================================================== */
.vi-container{max-width:1240px;margin:0 auto;padding:0 20px}
.vi-section{padding:80px 0}
.vi-section-sm{padding:48px 0}
.vi-text-center{text-align:center}

.vi-label{display:block;font-size:.75rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--vi-accent);margin-bottom:8px}
.vi-section-title{font-family:var(--vi-font-head);font-size:clamp(1.9rem,3.5vw,2.8rem);color:var(--vi-navy);letter-spacing:.03em;line-height:1.08;margin-bottom:12px}
.vi-section-desc{font-size:1rem;color:var(--vi-muted);line-height:1.75;max-width:580px;margin-bottom:0}
.vi-text-center .vi-section-desc{margin:0 auto}

/* =====================================================
   BUTTONS
===================================================== */
.vi-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 28px;border-radius:var(--vi-radius);font-family:var(--vi-font-body);font-size:.9rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;text-decoration:none;cursor:pointer;border:2px solid transparent;transition:all .2s;white-space:nowrap;line-height:1}
.vi-btn-primary{background:var(--vi-accent);color:#fff;border-color:var(--vi-accent)}
.vi-btn-primary:hover{background:#d4720e;color:#fff;border-color:#d4720e;transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,130,26,.4)}
.vi-btn-navy{background:var(--vi-navy);color:#fff;border-color:var(--vi-navy)}
.vi-btn-navy:hover{background:var(--vi-steel);color:#fff;border-color:var(--vi-steel)}
.vi-btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.vi-btn-outline:hover{border-color:#fff;background:rgba(255,255,255,.1);color:#fff}
.vi-btn-wa{background:#25d366;color:#fff;border-color:#25d366}
.vi-btn-wa:hover{background:#128c7e;color:#fff;border-color:#128c7e}
.vi-btn-sm{padding:9px 18px;font-size:.8rem}
.vi-btn-full{width:100%;justify-content:center}

/* =====================================================
   TOP BAR
===================================================== */
#vi-topbar{background:var(--vi-navy);color:var(--vi-silver);font-size:.78rem;font-weight:500;padding:7px 0;letter-spacing:.03em;position:relative;z-index:200}
.vi-topbar-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:6px}
.vi-topbar-left,.vi-topbar-right{display:flex;align-items:center;gap:16px}
.vi-topbar-left a,.vi-topbar-right a{color:var(--vi-accent2)}
.vi-topbar-left span,.vi-topbar-right span{display:flex;align-items:center;gap:5px}
.vi-social-bar{display:flex;gap:7px}
.vi-social-bar a{width:27px;height:27px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:.78rem;color:var(--vi-silver);text-decoration:none;transition:background .2s;font-style:normal}
.vi-social-bar a:hover{background:var(--vi-accent);color:#fff}

/* =====================================================
   HEADER
===================================================== */
#vi-header{background:#fff;box-shadow:0 2px 20px rgba(10,22,40,.1);position:sticky;top:0;z-index:1000}
.vi-header-inner{display:flex;align-items:center;justify-content:space-between;padding:10px 0;gap:20px}

/* ── LOGO ── */
.vi-logo-wrap{display:flex;align-items:center;gap:13px;text-decoration:none;flex-shrink:0}
.vi-logo-icon{width:54px;height:54px;background:var(--vi-gradient);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.vi-logo-icon svg{width:36px;height:36px}
.vi-logo-text{line-height:1}
.vi-logo-text .vi-brand{font-family:var(--vi-font-head);font-size:1.9rem;color:var(--vi-navy);letter-spacing:.05em;display:block;line-height:1}
.vi-logo-text .vi-tagline{font-size:.62rem;color:var(--vi-accent);font-weight:700;letter-spacing:.15em;text-transform:uppercase;display:block;margin-top:2px}

/* ── NAV ── */
.vi-nav{display:flex;align-items:center}
.vi-nav-list{display:flex;list-style:none;gap:2px;align-items:center;margin:0;padding:0}
.vi-nav-list>li{position:relative}
.vi-nav-list>li>a{display:block;padding:10px 13px;font-size:.85rem;font-weight:600;color:var(--vi-navy);letter-spacing:.04em;text-transform:uppercase;border-radius:7px;transition:all .2s;white-space:nowrap;text-decoration:none}
.vi-nav-list>li>a:hover,.vi-nav-list>li.current-menu-item>a,.vi-nav-list>li.current-menu-parent>a{color:var(--vi-accent);background:rgba(232,130,26,.07)}
.vi-nav-cta{background:var(--vi-accent)!important;color:#fff!important;border-radius:7px;padding:10px 18px!important}
.vi-nav-cta:hover{background:var(--vi-accent2)!important;color:#fff!important}
/* Dropdown */
.vi-dropdown{position:absolute;top:calc(100% + 6px);left:0;background:#fff;border:1px solid #e5edf6;border-radius:10px;box-shadow:0 10px 40px rgba(10,22,40,.15);min-width:248px;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .22s;z-index:500}
.vi-nav-list>li:hover .vi-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.vi-dropdown li a{display:block;padding:9px 18px;font-size:.84rem;font-weight:500;color:var(--vi-text);border-bottom:1px solid #f0f5fb;transition:all .15s;text-decoration:none;text-transform:none;letter-spacing:0}
.vi-dropdown li:last-child a{border-bottom:none}
.vi-dropdown li a:hover{color:var(--vi-accent);background:#fff8f0;padding-left:24px}

/* ── HAMBURGER ── */
.vi-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px;z-index:1001}
.vi-hamburger span{width:24px;height:2px;background:var(--vi-navy);border-radius:2px;transition:all .3s;display:block}
.vi-hamburger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.vi-hamburger.is-open span:nth-child(2){opacity:0}
.vi-hamburger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile Nav */
@media(max-width:1024px){
  .vi-nav{display:none;position:fixed;inset:0;background:#fff;z-index:999;flex-direction:column;padding:88px 24px 32px;overflow-y:auto;align-items:flex-start;justify-content:flex-start}
  .vi-nav.vi-nav-open{display:flex}
  .vi-nav-list{flex-direction:column;gap:4px;width:100%}
  .vi-nav-list>li>a{font-size:1.05rem;padding:12px 16px}
  .vi-dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;background:var(--vi-light);border-radius:8px;margin:4px 0}
  .vi-hamburger{display:flex}
}

/* =====================================================
   HERO
===================================================== */
.vi-hero{min-height:92vh;background:var(--vi-gradient);position:relative;display:flex;align-items:center;overflow:hidden}
.vi-hero::before{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23fff' fill-opacity='.025'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E")}
.vi-hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1;padding:80px 0}
.vi-hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(232,130,26,.15);border:1px solid rgba(232,130,26,.4);border-radius:50px;padding:6px 16px;font-size:.77rem;font-weight:700;color:var(--vi-accent2);letter-spacing:.1em;text-transform:uppercase;margin-bottom:18px}
.vi-hero h1{font-family:var(--vi-font-head);font-size:clamp(2.8rem,5vw,4.6rem);line-height:1.04;color:#fff;letter-spacing:.02em;margin-bottom:18px}
.vi-hero h1 span{color:var(--vi-accent2)}
.vi-hero-lead{font-size:1.05rem;line-height:1.75;color:rgba(255,255,255,.82);margin-bottom:32px;max-width:500px}
.vi-hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:36px}
.vi-hero-stats{display:flex;gap:32px;padding-top:28px;border-top:1px solid rgba(255,255,255,.12);flex-wrap:wrap}
.vi-stat-num{font-family:var(--vi-font-head);font-size:2.2rem;color:var(--vi-accent2);line-height:1;display:block}
.vi-stat-lbl{font-size:.72rem;color:rgba(255,255,255,.55);font-weight:500;text-transform:uppercase;letter-spacing:.07em;margin-top:3px;display:block}

/* Hero Visual */
.vi-hero-visual{display:flex;align-items:center;justify-content:center;position:relative}
.vi-vessel-wrap{position:relative;width:420px;height:460px}
.vi-vessel-ring{width:380px;height:380px;border-radius:50%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);animation:vi-pulse 3s ease-in-out infinite}
.vi-vessel-ring.ring2{width:290px;height:290px;background:rgba(232,130,26,.05);border-color:rgba(232,130,26,.2);animation-delay:.5s}
.vi-vessel-svg-main{position:absolute;top:50%;left:50%;transform:translate(-50%,-53%);width:190px;filter:drop-shadow(0 20px 40px rgba(0,0,0,.4))}
@keyframes vi-pulse{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.05);opacity:1}}
.vi-float-badge{position:absolute;background:rgba(255,255,255,.96);border-radius:10px;padding:9px 14px;box-shadow:0 8px 24px rgba(0,0,0,.22);font-size:.74rem;font-weight:700;color:var(--vi-navy);display:flex;align-items:center;gap:8px;animation:vi-float 4s ease-in-out infinite;font-family:var(--vi-font-body)}
.vi-float-badge.fb1{top:12%;right:0}
.vi-float-badge.fb2{bottom:22%;left:0;animation-delay:1s}
.vi-float-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;flex-shrink:0}
@keyframes vi-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* =====================================================
   INDUSTRY STRIP
===================================================== */
.vi-industry-strip{background:var(--vi-light);padding:20px 0;border-top:3px solid var(--vi-accent)}
.vi-strip-inner{display:flex;align-items:center;gap:12px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.vi-strip-inner::-webkit-scrollbar{display:none}
.vi-strip-label{font-size:.76rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--vi-muted);white-space:nowrap;flex-shrink:0}
.vi-industry-pill{display:flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--vi-border);border-radius:50px;padding:8px 16px;font-size:.82rem;font-weight:600;color:var(--vi-navy);white-space:nowrap;transition:all .2s;text-decoration:none;flex-shrink:0}
.vi-industry-pill:hover{background:var(--vi-navy);color:#fff;border-color:var(--vi-navy)}

/* =====================================================
   CATEGORY CARDS
===================================================== */
.vi-cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;margin-top:48px}
.vi-cat-card{border-radius:12px;overflow:hidden;border:1px solid var(--vi-border);transition:all .3s;text-decoration:none;display:flex;flex-direction:column;background:#fff}
.vi-cat-card:hover{transform:translateY(-6px);box-shadow:var(--vi-shadow-lg);border-color:var(--vi-accent)}
.vi-cat-thumb{width:100%;height:180px;display:flex;align-items:center;justify-content:center;font-size:3.5rem;background:var(--vi-gradient);overflow:hidden;transition:transform .4s;flex-shrink:0}
.vi-cat-card:hover .vi-cat-thumb{transform:scale(1.05)}
.vi-cat-thumb img{width:100%;height:100%;object-fit:cover}
.vi-cat-body{padding:20px;flex:1}
.vi-cat-ind{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--vi-accent);margin-bottom:6px}
.vi-cat-body h3{font-size:1.15rem;color:var(--vi-navy);margin-bottom:8px}
.vi-cat-body p{font-size:.84rem;color:var(--vi-muted);line-height:1.55;margin-bottom:14px}
.vi-cat-arrow{font-size:.8rem;font-weight:700;color:var(--vi-accent);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:4px}

/* =====================================================
   PRODUCT CARDS
===================================================== */
.vi-prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;margin-top:48px}
.vi-prod-card{background:#fff;border-radius:12px;overflow:hidden;border:1px solid var(--vi-border);transition:all .3s;display:flex;flex-direction:column}
.vi-prod-card:hover{box-shadow:var(--vi-shadow-lg);transform:translateY(-4px);border-color:rgba(232,130,26,.4)}
.vi-prod-thumb{width:100%;height:220px;background:var(--vi-gradient);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;flex-shrink:0}
.vi-prod-thumb img{width:100%;height:100%;object-fit:cover}
.vi-prod-thumb-icon{display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.vi-prod-thumb-icon svg{width:100px;height:160px;filter:drop-shadow(0 8px 24px rgba(0,0,0,.35))}
.vi-prod-badge{position:absolute;top:12px;right:12px;background:var(--vi-accent);color:#fff;font-size:.68rem;font-weight:700;padding:4px 11px;border-radius:50px;text-transform:uppercase;letter-spacing:.06em;font-family:var(--vi-font-body)}
.vi-prod-body{padding:20px;flex:1;display:flex;flex-direction:column}
.vi-prod-cat{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--vi-accent);margin-bottom:5px}
.vi-prod-body h3{font-size:1.15rem;color:var(--vi-navy);margin-bottom:10px}
.vi-prod-body h3 a{color:inherit;text-decoration:none}
.vi-prod-body h3 a:hover{color:var(--vi-accent)}
.vi-prod-specs{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px}
.vi-spec-tag{background:var(--vi-light);border:1px solid #d5e3ee;border-radius:4px;padding:3px 9px;font-size:.71rem;font-weight:600;color:var(--vi-steel);font-family:var(--vi-font-body)}
.vi-prod-body p{font-size:.84rem;color:var(--vi-muted);line-height:1.55;flex:1;margin-bottom:16px}
.vi-prod-actions{display:flex;gap:9px;margin-top:auto}
.vi-inq-btn{flex:1;background:var(--vi-navy);color:#fff;border:none;border-radius:7px;padding:11px 14px;font-size:.84rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s;font-family:var(--vi-font-body);text-decoration:none;letter-spacing:.02em}
.vi-inq-btn:hover{background:var(--vi-accent);color:#fff}
.vi-wa-icon-btn{width:42px;height:42px;background:#25d366;color:#fff;border:none;border-radius:7px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;text-decoration:none;flex-shrink:0}
.vi-wa-icon-btn:hover{background:#128c7e;color:#fff}
.vi-wa-icon-btn svg{width:20px;height:20px}

/* =====================================================
   WHY US
===================================================== */
.vi-why{background:var(--vi-navy)}
.vi-why-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:22px;margin-top:48px}
.vi-why-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:28px 24px;transition:all .3s}
.vi-why-card:hover{background:rgba(232,130,26,.1);border-color:rgba(232,130,26,.3);transform:translateY(-4px)}
.vi-why-ico{width:52px;height:52px;background:rgba(232,130,26,.15);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:16px}
.vi-why-card h4{font-size:1.05rem;color:#fff;margin-bottom:8px}
.vi-why-card p{font-size:.84rem;color:rgba(255,255,255,.55);line-height:1.6;margin:0}

/* =====================================================
   PAGE HERO (inner pages)
===================================================== */
.vi-page-hero{background:var(--vi-gradient);padding:58px 0 44px;position:relative;overflow:hidden}
.vi-page-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--vi-accent),var(--vi-accent2))}
.vi-page-hero h1{font-family:var(--vi-font-head);font-size:clamp(2rem,4vw,3.2rem);color:#fff;letter-spacing:.04em;margin-bottom:10px}
.vi-page-hero p{color:rgba(255,255,255,.72);font-size:.98rem;max-width:620px;margin:0}
.vi-breadcrumb{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:14px;font-size:.78rem;color:rgba(255,255,255,.5)}
.vi-breadcrumb a{color:var(--vi-accent2)}

/* =====================================================
   SEO BOX
===================================================== */
.vi-seo-box{background:var(--vi-light);border-left:4px solid var(--vi-accent);border-radius:0 10px 10px 0;padding:26px 30px;margin-top:48px}
.vi-seo-box h2{font-size:1.1rem;font-weight:700;color:var(--vi-navy);margin-bottom:12px;text-transform:uppercase;letter-spacing:.04em}
.vi-seo-box p{font-size:.87rem;color:var(--vi-muted);line-height:1.8;margin-bottom:.5rem}
.vi-seo-box p:last-child{margin-bottom:0}
.vi-seo-box strong{color:var(--vi-navy)}

/* =====================================================
   ABOUT PAGE
===================================================== */
.vi-about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-top:48px}
.vi-about-visual{background:var(--vi-gradient);border-radius:16px;overflow:hidden;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center}
.vi-about-visual img{width:100%;height:100%;object-fit:cover}
.vi-features-list{display:flex;flex-direction:column;gap:16px;margin-top:24px}
.vi-feature-item{display:flex;gap:14px;align-items:flex-start}
.vi-feature-check{width:26px;height:26px;background:rgba(232,130,26,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--vi-accent);font-size:.85rem;font-weight:900}
.vi-feature-item h5{font-size:.93rem;font-weight:700;color:var(--vi-navy);margin-bottom:2px}
.vi-feature-item p{font-size:.82rem;color:var(--vi-muted);line-height:1.5;margin:0}

/* =====================================================
   FORMS
===================================================== */
.vi-form-wrap{background:#fff;border-radius:14px;padding:38px;box-shadow:var(--vi-shadow);max-width:780px;margin:0 auto}
.vi-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.vi-form-group{display:flex;flex-direction:column;gap:6px}
.vi-form-group.full{grid-column:1/-1}
.vi-form-group label{font-size:.8rem;font-weight:600;color:var(--vi-navy);letter-spacing:.02em}
.vi-form-field,.vi-form-group input,.vi-form-group select,.vi-form-group textarea{border:1.5px solid #d5e2ee;border-radius:8px;padding:11px 14px;font-size:.9rem;font-family:var(--vi-font-body);color:var(--vi-text);background:var(--vi-light);outline:none;transition:border .2s,background .2s;width:100%}
.vi-form-field:focus,.vi-form-group input:focus,.vi-form-group select:focus,.vi-form-group textarea:focus{border-color:var(--vi-accent);background:#fff}
.vi-form-group textarea{resize:vertical;min-height:110px}
.vi-contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;margin-top:48px}
.vi-contact-items{display:flex;flex-direction:column;gap:22px}
.vi-contact-item{display:flex;gap:14px;align-items:flex-start}
.vi-contact-ico{width:46px;height:46px;background:rgba(232,130,26,.1);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.vi-contact-item h5{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--vi-muted);margin-bottom:2px}
.vi-contact-item a,.vi-contact-item p{font-size:.93rem;color:var(--vi-navy);font-weight:500;margin:0}

/* Associate Steps */
.vi-steps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;margin-bottom:48px}
.vi-step-card{text-align:center;padding:24px 18px;background:#fff;border:1px solid var(--vi-border);border-radius:12px}
.vi-step-ico{font-size:2.2rem;margin-bottom:12px}
.vi-step-card h4{font-size:1rem;color:var(--vi-navy);margin-bottom:6px}
.vi-step-card p{font-size:.82rem;color:var(--vi-muted);margin:0;line-height:1.55}

/* =====================================================
   PARTNER BANNER
===================================================== */
.vi-partner-bar{background:linear-gradient(135deg,#1a3a5c,#0a1628);padding:28px 0;text-align:center}
.vi-partner-bar p{color:rgba(255,255,255,.65);font-size:.88rem;margin-bottom:6px}
.vi-partner-bar a{color:var(--vi-accent2);font-weight:700;font-size:1.05rem}
.vi-partner-bar a:hover{text-decoration:underline}

/* =====================================================
   LEGAL PAGES
===================================================== */
.vi-legal{max-width:860px;margin:0 auto;padding:40px 0 60px}
.vi-legal h2{font-size:1.2rem;font-weight:700;color:var(--vi-navy);margin:28px 0 10px;text-transform:uppercase;letter-spacing:.04em}
.vi-legal p{font-size:.9rem;color:var(--vi-muted);line-height:1.82;margin-bottom:10px}
.vi-legal ul{margin-left:20px;margin-bottom:14px}
.vi-legal ul li{font-size:.9rem;color:var(--vi-muted);line-height:1.8;margin-bottom:4px;list-style:disc}

/* =====================================================
   WHATSAPP FLOAT
===================================================== */
.vi-wa-float{position:fixed;bottom:28px;right:28px;z-index:9999;display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.vi-wa-float-btn{width:58px;height:58px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.5);text-decoration:none;transition:transform .2s;animation:vi-wa-pulse 2.2s ease-in-out infinite}
.vi-wa-float-btn:hover{transform:scale(1.12)}
.vi-wa-float-btn svg{width:30px;height:30px}
@keyframes vi-wa-pulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.5)}50%{box-shadow:0 4px 30px rgba(37,211,102,.8),0 0 0 8px rgba(37,211,102,.12)}}
.vi-wa-tooltip{background:var(--vi-navy);color:#fff;font-size:.77rem;font-weight:600;padding:6px 14px;border-radius:50px;white-space:nowrap;opacity:0;transform:translateX(10px);transition:all .2s;font-family:var(--vi-font-body)}
.vi-wa-float:hover .vi-wa-tooltip{opacity:1;transform:translateX(0)}

/* =====================================================
   INQUIRY MODAL
===================================================== */
.vi-modal-bg{position:fixed;inset:0;background:rgba(10,22,40,.72);backdrop-filter:blur(4px);z-index:9000;display:none;align-items:center;justify-content:center;padding:20px}
.vi-modal-bg.vi-open{display:flex}
.vi-modal{background:#fff;border-radius:16px;padding:38px;max-width:520px;width:100%;position:relative;box-shadow:0 24px 64px rgba(0,0,0,.3);max-height:90vh;overflow-y:auto}
.vi-modal-close{position:absolute;top:14px;right:14px;width:32px;height:32px;background:var(--vi-light);border:none;border-radius:50%;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;color:var(--vi-muted);transition:all .2s;line-height:1}
.vi-modal-close:hover{background:#fce;color:#c00}
.vi-modal h3{font-size:1.45rem;color:var(--vi-navy);margin-bottom:4px}
.vi-modal-prod{font-size:.8rem;color:var(--vi-accent);font-weight:600;margin-bottom:20px;display:block}
.vi-modal-form{display:flex;flex-direction:column;gap:12px}

/* =====================================================
   FOOTER
===================================================== */
#vi-footer{background:#060e1c;color:rgba(255,255,255,.65);padding:60px 0 0}
.vi-footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.06)}
.vi-footer-brand p{font-size:.83rem;line-height:1.75;color:rgba(255,255,255,.45);margin-bottom:16px}
.vi-footer-brand .vi-logo-wrap{margin-bottom:14px}
.vi-footer-brand .vi-brand{color:#fff}
.vi-footer-contact-list{display:flex;flex-direction:column;gap:9px}
.vi-footer-contact-list a{font-size:.83rem;color:rgba(255,255,255,.45);text-decoration:none;display:flex;align-items:flex-start;gap:8px;line-height:1.5;transition:color .2s}
.vi-footer-contact-list a:hover{color:var(--vi-accent2)}
.vi-footer-social{display:flex;gap:8px;margin-top:14px}
.vi-footer-social a{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;font-size:.73rem;color:rgba(255,255,255,.5);text-decoration:none;transition:all .2s;font-style:normal}
.vi-footer-social a:hover{background:var(--vi-accent);color:#fff}
#vi-footer h5{font-size:.82rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin-bottom:16px}
.vi-footer-links{display:flex;flex-direction:column;gap:8px}
.vi-footer-links a{font-size:.83rem;color:rgba(255,255,255,.45);text-decoration:none;transition:color .2s;display:flex;align-items:center;gap:5px}
.vi-footer-links a::before{content:'›';color:var(--vi-accent)}
.vi-footer-links a:hover{color:var(--vi-accent2);padding-left:2px}
.vi-footer-dev-box{margin-top:20px;padding:14px;background:rgba(232,130,26,.08);border:1px solid rgba(232,130,26,.18);border-radius:8px}
.vi-footer-dev-box small{font-size:.72rem;color:rgba(255,255,255,.35);display:block;margin-bottom:4px}
.vi-footer-dev-box a{font-size:.82rem;font-weight:600;color:var(--vi-accent2);display:block;text-decoration:none}
.vi-footer-dev-box a.dev2{font-size:.74rem;color:rgba(255,255,255,.35);margin-top:2px}
.vi-footer-bottom{padding:18px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.vi-footer-bottom p{font-size:.76rem;color:rgba(255,255,255,.3);margin:0}
.vi-footer-bottom a{color:rgba(255,255,255,.45);text-decoration:none}
.vi-footer-bottom a:hover{color:var(--vi-accent)}
.vi-footer-legal-links{display:flex;gap:14px;flex-wrap:wrap}
.vi-footer-legal-links a{font-size:.74rem;color:rgba(255,255,255,.35);text-decoration:none}
.vi-footer-legal-links a:hover{color:var(--vi-accent2)}

/* =====================================================
   SINGLE VESSEL
===================================================== */
.vi-prod-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.vi-spec-table{width:100%;border-collapse:collapse;border:1px solid var(--vi-border);border-radius:10px;overflow:hidden}
.vi-spec-table tr{border-bottom:1px solid var(--vi-border)}
.vi-spec-table tr:last-child{border-bottom:none}
.vi-spec-table td{padding:10px 16px;font-size:.88rem}
.vi-spec-table td:first-child{font-size:.8rem;font-weight:700;color:var(--vi-navy);background:var(--vi-light);width:42%;text-transform:uppercase;letter-spacing:.04em}

/* =====================================================
   CF7 Compatibility
===================================================== */
.wpcf7{margin:0!important}
.wpcf7-form p{margin-bottom:14px}
.wpcf7-form input[type=text],.wpcf7-form input[type=email],.wpcf7-form input[type=tel],.wpcf7-form input[type=url],.wpcf7-form select,.wpcf7-form textarea{width:100%;border:1.5px solid #d5e2ee!important;border-radius:8px!important;padding:11px 14px!important;font-size:.9rem!important;font-family:var(--vi-font-body)!important;background:var(--vi-light)!important;outline:none!important}
.wpcf7-form input:focus,.wpcf7-form select:focus,.wpcf7-form textarea:focus{border-color:var(--vi-accent)!important;background:#fff!important}
.wpcf7-submit{background:var(--vi-accent)!important;color:#fff!important;border:none!important;border-radius:8px!important;padding:12px 28px!important;font-weight:700!important;font-size:.9rem!important;cursor:pointer!important;letter-spacing:.04em!important;font-family:var(--vi-font-body)!important}
.wpcf7-submit:hover{background:var(--vi-accent2)!important}
.wpcf7-mail-sent-ok{background:#dcfce7;color:#166534;border:none!important;border-radius:8px!important;padding:10px 16px!important}
.wpcf7-mail-sent-ng,.wpcf7-validation-errors{background:#fee2e2;color:#991b1b;border:none!important;border-radius:8px!important;padding:10px 16px!important}

/* =====================================================
   PAGINATION
===================================================== */
.nav-links{display:flex;gap:8px;justify-content:center;margin-top:40px;flex-wrap:wrap}
.nav-links .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 10px;border-radius:8px;border:1.5px solid var(--vi-border);font-size:.88rem;font-weight:600;color:var(--vi-navy);text-decoration:none;transition:all .2s}
.nav-links .page-numbers.current,.nav-links .page-numbers:hover{background:var(--vi-accent);color:#fff;border-color:var(--vi-accent)}

/* =====================================================
   RESPONSIVE
===================================================== */
@media(max-width:1024px){
  .vi-footer-grid{grid-template-columns:1fr 1fr}
  .vi-vessel-wrap{width:320px;height:360px}
  .vi-vessel-ring{width:300px;height:300px}
  .vi-vessel-ring.ring2{width:240px;height:240px}
}
@media(max-width:900px){
  .vi-hero-inner{grid-template-columns:1fr}
  .vi-hero-visual{display:none}
  .vi-about-grid{grid-template-columns:1fr}
  .vi-contact-grid{grid-template-columns:1fr}
  .vi-prod-detail-grid{grid-template-columns:1fr!important}
}
@media(max-width:768px){
  .vi-section{padding:52px 0}
  .vi-footer-grid{grid-template-columns:1fr;gap:28px}
  .vi-footer-bottom{flex-direction:column;text-align:center}
  .vi-form-grid{grid-template-columns:1fr}
  .vi-topbar-left{display:none}
  .vi-topbar-inner{justify-content:center}
  .vi-hero-stats{gap:18px}
}
@media(max-width:480px){
  .vi-prod-grid{grid-template-columns:1fr}
  .vi-cat-grid{grid-template-columns:1fr}
  .vi-hero h1{font-size:2.4rem}
  .vi-hero-btns{flex-direction:column}
  .vi-hero-btns .vi-btn{width:100%;justify-content:center}
  .vi-steps-grid{grid-template-columns:1fr}
  .vi-form-wrap{padding:24px 16px}
  .vi-modal{padding:28px 18px}
}

/* Body lock */
body.vi-modal-open,body.vi-nav-open-body{overflow:hidden}
/* Skip link */
.skip-link{position:absolute;top:-100%;left:16px;background:var(--vi-accent);color:#fff;padding:8px 16px;border-radius:0 0 8px 8px;z-index:9999;font-weight:700;text-decoration:none}
.skip-link:focus{top:0}
/* Screen reader */
.screen-reader-text{clip:rect(1px,1px,1px,1px);height:1px;overflow:hidden;position:absolute!important;width:1px}
/* WP align */
.aligncenter{margin:0 auto;text-align:center}
.alignleft{float:left;margin-right:20px}
.alignright{float:right;margin-left:20px}
.wp-block-image img{border-radius:var(--vi-radius)}
