/*
Theme Name: Petronord
Theme URI: https://petronord.eu
Author: Petronord OÜ
Description: Premium staff leasing & recruitment theme for Northern Europe. Multilingual (Polylang), SEO-optimized, fast, no page builders.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GPLv2
Text Domain: petronord
*/

/* ==========================================================
   VARIABLES
   ========================================================== */
:root {
  --c-navy:      #0B1F3B;
  --c-navy-90:   #112847;
  --c-navy-80:   #1A3358;
  --c-blue:      #1E5FAA;
  --c-blue-l:    #3B8BEB;
  --c-accent:    #00B4D8;
  --c-accent-d:  #0097B2;
  --c-accent-glow: rgba(0,180,216,.25);
  --c-sky:       #E8F1FB;
  --c-ice:       #F4F8FC;
  --c-white:     #FFFFFF;
  --c-gray:      #6B7D92;
  --c-gray-l:    #CDD5DE;
  --c-text:      #1C2A3A;
  --c-glass:     rgba(255,255,255,.06);
  --c-glass-b:   rgba(255,255,255,.1);

  --ff-head: 'Plus Jakarta Sans','Inter','Segoe UI',system-ui,sans-serif;
  --ff-body: 'Plus Jakarta Sans','Inter','Segoe UI',system-ui,sans-serif;
  --ff-mono: 'JetBrains Mono','Fira Code',monospace;

  --fs-hero:  clamp(2.4rem,5vw,4rem);
  --fs-h1:    clamp(1.9rem,4vw,3.2rem);
  --fs-h2:    clamp(1.5rem,3vw,2.3rem);
  --fs-h3:    clamp(1.15rem,2vw,1.45rem);
  --fs-body:  1rem;
  --fs-sm:    .875rem;
  --fs-xs:    .8rem;

  --shadow-s: 0 1px 3px rgba(11,31,59,.06),0 4px 12px rgba(11,31,59,.06);
  --shadow-m: 0 4px 16px rgba(11,31,59,.08),0 12px 40px rgba(11,31,59,.08);
  --shadow-l: 0 8px 24px rgba(11,31,59,.1),0 20px 60px rgba(11,31,59,.12);
  --shadow-g: 0 4px 16px rgba(0,180,216,.2),0 12px 40px rgba(0,180,216,.12);

  --r-s:  8px;
  --r-m:  16px;
  --r-l:  24px;
  --r-xl: 32px;

  --ease: .35s cubic-bezier(.4,0,.2,1);
  --container: 1200px;
}

/* ==========================================================
   RESET
   ========================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--ff-body);font-size:var(--fs-body);line-height:1.7;color:var(--c-text);background:var(--c-white);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg{max-width:100%;height:auto;display:block}
a{color:var(--c-blue);text-decoration:none;transition:color var(--ease)}
a:hover{color:var(--c-accent)}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--ff-head);font-weight:700;line-height:1.25;color:var(--c-navy)}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--c-accent);color:#fff}

/* ==========================================================
   LAYOUT
   ========================================================== */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.section--dark{background:var(--c-navy);color:rgba(255,255,255,.85)}
.section--dark h2,.section--dark h3{color:#fff}
.section--ice{background:var(--c-ice)}
.section-label{display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--c-accent);margin-bottom:14px}
.section-label::before{content:'';width:24px;height:2px;background:linear-gradient(90deg,var(--c-accent),transparent);border-radius:2px;animation:labelLine 2s ease-in-out infinite alternate}
@keyframes labelLine{0%{width:16px;opacity:.5}100%{width:28px;opacity:1}}
.section-title{font-size:var(--fs-h2);margin-bottom:16px}
.section-sub{font-size:1.05rem;color:var(--c-gray);max-width:580px;line-height:1.75}
.text-center{text-align:center}
.mx-auto{margin-left:auto;margin-right:auto}
.grid{display:grid;gap:28px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

/* ==========================================================
   BUTTONS
   ========================================================== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;font-family:var(--ff-head);font-size:var(--fs-sm);font-weight:700;border-radius:10px;border:2px solid transparent;cursor:pointer;transition:all .3s cubic-bezier(.25,.8,.25,1);line-height:1.4;text-decoration:none;position:relative;overflow:hidden}
.btn svg{width:16px;height:16px;transition:transform .3s cubic-bezier(.25,.8,.25,1)}
.btn:hover svg{transform:translateX(4px)}
.btn:active{transform:scale(.97)}
.btn--primary{background:linear-gradient(135deg,var(--c-accent) 0%,var(--c-accent-d) 100%);color:#fff;border-color:transparent;box-shadow:0 2px 8px var(--c-accent-glow)}
.btn--primary:hover{transform:translateY(-3px);box-shadow:var(--shadow-g);color:#fff;filter:brightness(1.08)}
.btn--outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.btn--outline:hover{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.6);transform:translateY(-2px)}
.btn--white{background:#fff;color:var(--c-navy);border-color:#fff;box-shadow:var(--shadow-s)}
.btn--white:hover{background:var(--c-sky);transform:translateY(-3px);box-shadow:var(--shadow-m)}
.btn--ghost{background:transparent;color:var(--c-accent);border-color:var(--c-accent)}
.btn--ghost:hover{background:var(--c-accent);color:#fff;transform:translateY(-2px);box-shadow:0 4px 16px var(--c-accent-glow)}

/* ==========================================================
   HEADER
   ========================================================== */
.site-header{position:fixed;top:0;left:0;width:100%;z-index:1000;padding:18px 0;transition:all var(--ease)}
.site-header.scrolled{background:rgba(11,31,59,.96);backdrop-filter:blur(14px);padding:10px 0;box-shadow:var(--shadow-l)}
.hdr{display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo img{height:38px;width:auto}
.nav-main{display:flex;align-items:center;gap:32px}
.nav-main li{list-style:none;margin:0;padding:0}
.nav-main a{color:rgba(255,255,255,.75);font-size:var(--fs-sm);font-weight:600;position:relative;transition:color var(--ease)}
.nav-main a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--c-accent);transition:width var(--ease);border-radius:2px}
.nav-main a:hover,.nav-main a.active{color:#fff}
.nav-main a:hover::after,.nav-main a.active::after{width:100%}
.hdr-right{display:flex;align-items:center;gap:16px}
.hdr-cta{padding:10px 22px;font-size:var(--fs-xs)}
.menu-toggle{display:none;background:none;border:none;padding:6px;flex-direction:column;gap:5px}
.menu-toggle span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:all var(--ease)}

/* Language Switcher */
.lang-switch{display:flex;align-items:center;margin-left:12px;padding-left:12px;border-left:1px solid rgba(255,255,255,.12)}
.lang-switch ul{display:flex;gap:4px;list-style:none!important;margin:0!important;padding:0!important}
.lang-switch li{list-style:none!important;margin:0!important;padding:0!important}
.lang-switch li a{display:inline-flex!important;align-items:center;gap:6px;padding:7px 14px;border-radius:6px;color:rgba(255,255,255,.65)!important;font-size:13px!important;font-weight:600;text-decoration:none!important;transition:all .2s ease;white-space:nowrap;line-height:1;text-transform:uppercase;letter-spacing:.05em;overflow:visible!important;text-overflow:clip!important;max-width:none!important}
.lang-switch li a:hover{color:#fff!important;background:rgba(255,255,255,.1)}
.lang-switch li a::after{display:none!important;width:0!important}
.lang-switch li.current-lang a{color:#fff!important;background:rgba(0,180,216,.2);box-shadow:inset 0 0 0 1px rgba(0,180,216,.35)}
.lang-switch li a img{width:18px;height:13px;object-fit:cover;border-radius:2px;box-shadow:0 0 0 1px rgba(255,255,255,.15);flex-shrink:0}

/* ==========================================================
   HERO
   ========================================================== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;background:linear-gradient(160deg,#050C18 0%,var(--c-navy) 40%,#0F2D52 100%);overflow:hidden}
.hero-bg{position:absolute;inset:0;background:url('') center/cover no-repeat;opacity:.12;mix-blend-mode:luminosity}
.hero-mesh{position:absolute;inset:0;background:
  radial-gradient(ellipse 80% 60% at 65% 35%,rgba(0,180,216,.12) 0%,transparent 70%),
  radial-gradient(ellipse 50% 50% at 20% 80%,rgba(30,95,170,.08) 0%,transparent 60%);pointer-events:none;animation:meshShift 12s ease-in-out infinite alternate}
@keyframes meshShift{0%{opacity:.8;transform:scale(1)}100%{opacity:1;transform:scale(1.05) translate(10px,-5px)}}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:72px 72px;pointer-events:none;animation:gridDrift 20s linear infinite}
@keyframes gridDrift{0%{transform:translate(0,0)}100%{transform:translate(72px,72px)}}
.hero::after{content:'';position:absolute;bottom:-2px;left:0;width:100%;height:140px;background:linear-gradient(to top,var(--c-white),transparent);pointer-events:none;z-index:2}
.hero .container{position:relative;z-index:3}
.hero-inner{display:grid;grid-template-columns:1fr 420px;gap:48px;align-items:center;padding:100px 0 80px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--c-glass);border:1px solid var(--c-glass-b);border-radius:100px;padding:8px 18px;font-size:var(--fs-xs);color:var(--c-accent);font-weight:600;margin-bottom:28px;backdrop-filter:blur(6px);animation:badgeFade .8s ease-out}
@keyframes badgeFade{0%{opacity:0;transform:translateY(-10px)}100%{opacity:1;transform:translateY(0)}}
.hero h1{font-size:var(--fs-hero);color:#fff;margin-bottom:20px;line-height:1.15;animation:heroTitle 1s cubic-bezier(.25,.8,.25,1) both;animation-delay:.2s}
@keyframes heroTitle{0%{opacity:0;transform:translateY(30px);filter:blur(4px)}100%{opacity:1;transform:translateY(0);filter:blur(0)}}
.hero h1 em{font-style:normal;background:linear-gradient(135deg,#00B4D8,#3B8BEB,#00B4D8);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientText 4s linear infinite}
@keyframes gradientText{0%{background-position:0% center}100%{background-position:200% center}}
.hero-text{font-size:1.1rem;color:rgba(255,255,255,.6);margin-bottom:36px;max-width:520px;line-height:1.8;animation:heroFade 1s ease both;animation-delay:.5s}
@keyframes heroFade{0%{opacity:0;transform:translateY(20px)}100%{opacity:1;transform:translateY(0)}}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px;animation:heroFade 1s ease both;animation-delay:.7s}
.hero-flags{display:flex;gap:16px;align-items:center;padding-top:32px;border-top:1px solid rgba(255,255,255,.08);animation:heroFade 1s ease both;animation-delay:.9s}
.hero-flag{display:flex;align-items:center;gap:8px;font-size:var(--fs-xs);color:rgba(255,255,255,.5);font-weight:500;transition:all .3s ease}
.hero-flag:hover{color:rgba(255,255,255,.9);transform:translateY(-2px)}
.hero-flag span.emoji{font-size:1.4rem;line-height:1}
/* Hero floating cards */
.hero-cards{display:flex;flex-direction:column;gap:16px;animation:heroFade 1.2s ease both;animation-delay:.4s}
.h-card{background:var(--c-glass);backdrop-filter:blur(16px);border:1px solid var(--c-glass-b);border-radius:var(--r-m);padding:22px 24px;color:#fff;transition:all .4s cubic-bezier(.25,.8,.25,1);animation:hFloat 5s ease-in-out infinite}
.h-card:hover{border-color:rgba(0,180,216,.3);background:rgba(255,255,255,.08);transform:translateY(-4px) scale(1.02)!important}
.h-card:nth-child(2){animation-delay:-1.7s}
.h-card:nth-child(3){animation-delay:-3.3s}
@keyframes hFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.h-card-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.h-card-icon{width:40px;height:40px;background:rgba(0,180,216,.12);border-radius:var(--r-s);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.h-card-icon svg{width:20px;height:20px;stroke:var(--c-accent);fill:none;stroke-width:1.5}
.h-card h4{font-size:var(--fs-sm);font-weight:700;color:#fff;line-height:1.3}
.h-card p{font-size:var(--fs-xs);color:rgba(255,255,255,.5);line-height:1.6}

/* ==========================================================
   TRUST BAR
   ========================================================== */
.trust-bar{position:relative;z-index:5;margin-top:-52px}
.trust-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.trust-item{background:#fff;border-radius:var(--r-m);padding:28px 24px;box-shadow:var(--shadow-m);display:flex;align-items:center;gap:16px;transition:all .4s cubic-bezier(.25,.8,.25,1);position:relative;overflow:hidden}
.trust-item::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,transparent,var(--c-accent),transparent);transform:scaleX(0);transition:transform .5s ease}
.trust-item:hover{transform:translateY(-6px);box-shadow:var(--shadow-l)}
.trust-item:hover::before{transform:scaleX(1)}
.trust-icon{width:48px;height:48px;background:linear-gradient(135deg,rgba(0,180,216,.1),rgba(30,95,170,.1));border-radius:var(--r-s);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s ease}
.trust-item:hover .trust-icon{background:linear-gradient(135deg,rgba(0,180,216,.2),rgba(30,95,170,.15));transform:scale(1.1)}
.trust-icon svg{width:24px;height:24px;stroke:var(--c-blue);fill:none;stroke-width:1.5}
.trust-val{font-family:var(--ff-head);font-size:1.6rem;font-weight:800;color:var(--c-navy);line-height:1}
.trust-lbl{font-size:var(--fs-xs);color:var(--c-gray);font-weight:500;margin-top:2px}

/* ==========================================================
   ABOUT
   ========================================================== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.about-img{border-radius:var(--r-l);overflow:hidden;position:relative;transition:transform .6s cubic-bezier(.25,.8,.25,1)}
.about-img:hover{transform:scale(1.02)}
.about-img img{width:100%;height:400px;object-fit:cover;transition:transform .8s cubic-bezier(.25,.8,.25,1)}
.about-img:hover img{transform:scale(1.05)}
.about-img::after{content:'';position:absolute;inset:0;border:2px solid transparent;border-image:linear-gradient(135deg,var(--c-accent),transparent,var(--c-blue)) 1;border-radius:var(--r-l);opacity:.4;pointer-events:none;transition:opacity .4s ease}
.about-img:hover::after{opacity:.8}
.about-text h2{margin-bottom:20px}
.about-text p{color:var(--c-gray);margin-bottom:16px;line-height:1.8}

/* ==========================================================
   SERVICES
   ========================================================== */
.svc-card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:var(--r-m);padding:36px 28px;transition:all .4s cubic-bezier(.25,.8,.25,1);position:relative;overflow:hidden}
.svc-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--c-blue),var(--c-accent));transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.25,.8,.25,1)}
.svc-card:hover{border-color:transparent;box-shadow:var(--shadow-m);transform:translateY(-8px)}
.svc-card:hover::before{transform:scaleX(1)}
.svc-icon{width:56px;height:56px;background:linear-gradient(135deg,rgba(0,180,216,.1),rgba(30,95,170,.1));border-radius:var(--r-m);display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:all .4s ease}
.svc-card:hover .svc-icon{background:linear-gradient(135deg,rgba(0,180,216,.2),rgba(30,95,170,.2));transform:scale(1.1) rotate(5deg)}
.svc-icon svg{width:28px;height:28px;stroke:var(--c-blue);fill:none;stroke-width:1.5;transition:stroke .3s ease}
.svc-card:hover .svc-icon svg{stroke:var(--c-accent)}
.svc-card h3{font-size:var(--fs-h3);margin-bottom:10px}
.svc-card p{color:var(--c-gray);font-size:var(--fs-sm);line-height:1.7}

/* ==========================================================
   COUNTRIES
   ========================================================== */
.country-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;margin-top:40px}
.country-card{background:#fff;border-radius:var(--r-m);padding:32px 20px;text-align:center;border:1px solid rgba(0,0,0,.06);transition:all .4s cubic-bezier(.25,.8,.25,1);position:relative;overflow:hidden}
.country-card::after{content:'';position:absolute;bottom:0;left:0;width:100%;height:3px;transition:height .4s cubic-bezier(.25,.8,.25,1)}
.country-card--ee::after{background:linear-gradient(90deg,#0072CE,#000000,#fff)}
.country-card--fi::after{background:linear-gradient(90deg,#003580,#fff)}
.country-card--se::after{background:linear-gradient(90deg,#006AA7,#FECC02)}
.country-card--no::after{background:linear-gradient(90deg,#BA0C2F,#00205B)}
.country-card--dk::after{background:linear-gradient(90deg,#C8102E,#fff)}
.country-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-m);border-color:transparent}
.country-card:hover::after{height:5px}
.country-emoji{font-size:2.8rem;margin-bottom:12px;line-height:1;transition:transform .4s cubic-bezier(.25,.8,.25,1);filter:drop-shadow(0 4px 8px rgba(0,0,0,.15))}
.country-card:hover .country-emoji{transform:scale(1.2) translateY(-4px)}
.country-card h3{font-size:1.1rem;margin-bottom:6px}
.country-card p{font-size:var(--fs-xs);color:var(--c-gray);line-height:1.5}

/* ==========================================================
   MAP SECTION
   ========================================================== */
.map-section{background:linear-gradient(160deg,#070F1B,var(--c-navy));padding:96px 0;position:relative;overflow:hidden}
.map-section::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}
.map-wrap{position:relative;max-width:700px;margin:40px auto 0}
.map-svg{width:100%;height:auto;filter:drop-shadow(0 0 40px rgba(0,180,216,.1))}
.map-svg .country-path{fill:rgba(255,255,255,.06);stroke:rgba(255,255,255,.12);stroke-width:.5;transition:all var(--ease)}
.map-svg .country-path.active{fill:rgba(0,180,216,.2);stroke:var(--c-accent);stroke-width:1}
.map-svg .country-path:hover{fill:rgba(0,180,216,.3)}

/* ==========================================================
   TESTIMONIALS
   ========================================================== */
.testi-card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:var(--r-m);padding:32px 28px;transition:all .5s cubic-bezier(.25,.8,.25,1);position:relative;overflow:hidden}
.testi-card::before{content:'';position:absolute;top:-1px;left:-1px;right:-1px;bottom:-1px;border-radius:var(--r-m);background:linear-gradient(135deg,transparent 40%,rgba(0,180,216,.3),transparent 60%);background-size:300% 300%;opacity:0;transition:opacity .5s ease;z-index:0;pointer-events:none}
.testi-card:hover{box-shadow:var(--shadow-l);transform:translateY(-8px)}
.testi-card:hover::before{opacity:1;animation:borderGlow 3s linear infinite}
@keyframes borderGlow{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.testi-stars{color:#F59E0B;font-size:1rem;margin-bottom:16px;letter-spacing:2px;position:relative;z-index:1}
.testi-text{color:var(--c-gray);font-size:var(--fs-sm);line-height:1.8;margin-bottom:20px;font-style:italic;position:relative;z-index:1}
.testi-author{display:flex;align-items:center;gap:12px;position:relative;z-index:1}
.testi-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--c-sky),rgba(0,180,216,.15));display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--c-blue);font-size:var(--fs-sm);flex-shrink:0;transition:transform .3s ease}
.testi-card:hover .testi-avatar{transform:scale(1.1)}
.testi-name{font-weight:700;font-size:var(--fs-sm);color:var(--c-navy)}
.testi-role{font-size:var(--fs-xs);color:var(--c-gray)}

/* ==========================================================
   FORMS
   ========================================================== */
.form-section{background:linear-gradient(160deg,var(--c-navy),#0D2B4E);padding:96px 0}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.form-card{background:var(--c-glass);backdrop-filter:blur(16px);border:1px solid var(--c-glass-b);border-radius:var(--r-l);padding:40px 32px}
.form-card h3{color:#fff;font-size:var(--fs-h3);margin-bottom:8px}
.form-card .form-sub{color:rgba(255,255,255,.5);font-size:var(--fs-sm);margin-bottom:28px}
.form-field{margin-bottom:16px}
.form-field input,.form-field textarea{width:100%;padding:15px 18px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-family:var(--ff-body);font-size:var(--fs-sm);transition:all .3s ease;outline:none}
.form-field input::placeholder,.form-field textarea::placeholder{color:rgba(255,255,255,.35)}
.form-field input:focus,.form-field textarea:focus{border-color:var(--c-accent);background:rgba(255,255,255,.1);box-shadow:0 0 0 3px var(--c-accent-glow)}
.form-field textarea{resize:vertical;min-height:100px}
.form-card .btn{width:100%;justify-content:center;margin-top:8px}
.pn-select,.form-field select{width:100%;padding:15px 18px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-family:var(--ff-body);font-size:var(--fs-sm);outline:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2300B4D8' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;transition:all .3s ease}
.pn-select:focus,.form-field select:focus{border-color:var(--c-accent);background-color:rgba(255,255,255,.1);box-shadow:0 0 0 3px rgba(0,180,216,.25)}
.pn-select option,.form-field select option{background:var(--c-navy);color:#fff;padding:10px}
.pn-select option:checked{background:var(--c-accent)}
.pn-select option[disabled]{color:rgba(255,255,255,.35)}
.form-section-label{color:var(--c-accent);font-weight:700;font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.08em;margin:16px 0 10px;padding:0}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field input[type="date"]{color-scheme:dark}

/* Form Tabs */
.form-tabs-wrap{max-width:720px;margin:0 auto}
.form-tabs{display:flex;gap:4px;margin-bottom:0;background:rgba(255,255,255,.06);border-radius:14px 14px 0 0;padding:6px 6px 0}
.form-tab{flex:1;padding:14px 20px;background:transparent;border:none;color:rgba(255,255,255,.5);font-family:var(--ff-head);font-size:var(--fs-sm);font-weight:700;cursor:pointer;border-radius:10px 10px 0 0;transition:all .3s ease}
.form-tab:hover{color:rgba(255,255,255,.8)}
.form-tab.active{background:rgba(255,255,255,.08);color:#fff;box-shadow:inset 0 2px 0 var(--c-accent)}
.form-tabs-wrap .form-card{border-radius:0 0 var(--r-l) var(--r-l)}

/* Custom File Input */
.pn-file-label{display:block;cursor:pointer;font-size:var(--fs-xs);color:rgba(255,255,255,.5);margin-bottom:4px}
.pn-file-input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.pn-file-btn{display:inline-block;padding:10px 18px;background:rgba(255,255,255,.08);border:1px dashed rgba(255,255,255,.2);border-radius:10px;color:var(--c-accent);font-weight:600;font-size:var(--fs-xs);transition:all .3s ease;margin-top:6px;cursor:pointer}
.pn-file-btn:hover{background:rgba(0,180,216,.1);border-color:var(--c-accent)}
.pn-file-name{display:block;color:rgba(255,255,255,.35);font-size:.75rem;margin-top:6px}

/* Compact Map → Network Visualization */
.network-section{background:linear-gradient(160deg,#070F1B 0%,var(--c-navy) 50%,#0D2B4E 100%);padding:80px 0;position:relative;overflow:hidden}
.network-section::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 50% 50%,rgba(0,180,216,.06) 0%,transparent 60%);pointer-events:none}
.network-wrap{position:relative;max-width:900px;margin:0 auto;min-height:360px}
#networkCanvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}
.network-nodes{position:relative;z-index:2;display:flex;justify-content:center;align-items:center;gap:0;min-height:360px;flex-wrap:wrap;padding:40px 0}
.network-node{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px 24px;border-radius:16px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);text-decoration:none;transition:all .5s cubic-bezier(.25,.8,.25,1);position:relative;cursor:pointer;min-width:140px}
.network-node:hover{background:rgba(0,180,216,.1);border-color:rgba(0,180,216,.3);transform:translateY(-8px) scale(1.05);box-shadow:0 12px 40px rgba(0,180,216,.2)}
.network-node--hq{background:rgba(0,180,216,.08);border-color:rgba(0,180,216,.2);min-width:160px;padding:24px 28px}
.network-node--hq::after{content:'';position:absolute;top:-2px;left:50%;transform:translateX(-50%);width:40px;height:3px;background:var(--c-accent);border-radius:0 0 4px 4px}
.network-node--hq .network-emoji{font-size:2.5rem}
.network-emoji{font-size:2rem;filter:drop-shadow(0 2px 8px rgba(0,0,0,.3));transition:transform .3s ease}
.network-node:hover .network-emoji{transform:scale(1.2)}
.network-name{font-weight:700;font-size:.95rem;color:#fff;letter-spacing:.02em}
.network-tag{font-size:.7rem;color:var(--c-accent);font-weight:600;text-transform:uppercase;letter-spacing:.1em;opacity:.7}
/* Pulse animation for HQ */
.network-node--hq::before{content:'';position:absolute;top:50%;left:50%;width:100%;height:100%;border-radius:16px;border:1px solid rgba(0,180,216,.15);transform:translate(-50%,-50%);animation:nodePulse 3s ease-in-out infinite}
@keyframes nodePulse{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.08);opacity:0}}

/* ==========================================================
   SEO CONTENT
   ========================================================== */
.seo-section{padding:80px 0;border-top:1px solid var(--c-gray-l)}
.seo-section h2{font-size:var(--fs-h3);margin-bottom:12px;color:var(--c-navy)}
.seo-section h3{font-size:1.1rem;margin:24px 0 8px;color:var(--c-navy-80)}
.seo-section p{color:var(--c-gray);font-size:var(--fs-sm);line-height:1.8;max-width:800px;margin-bottom:12px}

/* ==========================================================
   CTA
   ========================================================== */
.cta{background:linear-gradient(160deg,#050C18,var(--c-navy),#0D2B4E);padding:96px 0;text-align:center;position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;top:-40%;right:-15%;width:500px;height:500px;background:radial-gradient(circle,rgba(0,180,216,.15),transparent 70%);pointer-events:none;animation:ctaGlow 6s ease-in-out infinite alternate}
.cta::after{content:'';position:absolute;bottom:-30%;left:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(30,95,170,.1),transparent 70%);pointer-events:none;animation:ctaGlow 8s ease-in-out infinite alternate-reverse}
@keyframes ctaGlow{0%{opacity:.5;transform:scale(1)}100%{opacity:1;transform:scale(1.2)}}
.cta h2{font-size:var(--fs-h1);color:#fff;margin-bottom:16px;position:relative;z-index:1}
.cta p{font-size:1.1rem;color:rgba(255,255,255,.55);margin-bottom:36px;max-width:540px;margin-left:auto;margin-right:auto;position:relative;z-index:1}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}

/* ==========================================================
   FOOTER
   ========================================================== */
.site-footer{background:var(--c-navy);color:rgba(255,255,255,.55);padding:72px 0 0}
.ftr-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.07)}
.ftr-brand .logo{margin-bottom:16px}
.ftr-brand .logo img{height:32px;filter:brightness(0) invert(1)}
.ftr-brand p{font-size:var(--fs-xs);line-height:1.8;max-width:280px}
.ftr-col h4{color:#fff;font-size:var(--fs-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:18px}
.ftr-col ul li{margin-bottom:8px}
.ftr-col a{color:rgba(255,255,255,.5);font-size:var(--fs-xs);transition:color var(--ease)}
.ftr-col a:hover{color:var(--c-accent)}
.ftr-bottom{display:flex;justify-content:space-between;align-items:center;padding:24px 0;font-size:var(--fs-xs)}

/* ==========================================================
   PAGE / SINGLE
   ========================================================== */
.page-hero{background:linear-gradient(160deg,#070F1B 0%,var(--c-navy) 40%,#0D2B4E 100%);padding:150px 0 80px;text-align:center;position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:120px;background:linear-gradient(to top,var(--c-white),transparent);pointer-events:none}
.page-hero h1{color:#fff;font-size:var(--fs-h1);margin-bottom:8px;letter-spacing:-.02em}
.page-hero p{color:rgba(255,255,255,.5);font-size:1.1rem}
.page-body{padding:80px 0}
.page-body .container{max-width:800px}
.entry h2{font-size:var(--fs-h2);margin:36px 0 14px}
.entry h3{font-size:var(--fs-h3);margin:28px 0 10px}
.entry p{margin-bottom:18px;line-height:1.85}
.entry img{border-radius:var(--r-m);margin:28px 0;max-width:100%;height:auto}
.entry img[src*="unsplash"]{width:100%;aspect-ratio:12/5;object-fit:cover}
.entry img::after{content:attr(alt);display:block;padding:40px;background:var(--c-ice);color:var(--c-gray);text-align:center;border-radius:var(--r-m);font-size:var(--fs-sm)}
.entry ul,.entry ol{margin:0 0 18px 20px;list-style:disc}
.entry li{margin-bottom:6px;line-height:1.7}
.entry blockquote{border-left:4px solid var(--c-accent);padding:18px 24px;background:var(--c-ice);border-radius:0 var(--r-s) var(--r-s) 0;margin:24px 0;font-style:italic;color:var(--c-navy)}

/* ==========================================================
   ANIMATIONS
   ========================================================== */
.fade-up{opacity:0;transform:translateY(32px);transition:opacity .8s cubic-bezier(.25,.8,.25,1),transform .8s cubic-bezier(.25,.8,.25,1)}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up:nth-child(2){transition-delay:.08s}
.fade-up:nth-child(3){transition-delay:.16s}
.fade-up:nth-child(4){transition-delay:.24s}
.fade-up:nth-child(5){transition-delay:.32s}

/* PROCESS STEPS */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.step-card{text-align:center;padding:36px 24px;border-radius:var(--r-m);background:#fff;box-shadow:var(--shadow-s);border:1px solid rgba(0,0,0,.04);transition:all .4s cubic-bezier(.25,.8,.25,1)}
.step-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-m);border-color:transparent}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--c-accent),var(--c-accent-d));color:#fff;font-size:var(--fs-h3);font-weight:800;margin-bottom:18px;box-shadow:0 4px 12px var(--c-accent-glow)}
.step-card h3{font-size:1.05rem;margin-bottom:10px}
.step-card p{font-size:var(--fs-sm);color:var(--c-gray);line-height:1.65}

/* FAQ */
.faq-item{border:1px solid rgba(0,0,0,.06);border-radius:12px;margin-bottom:12px;overflow:hidden;transition:all .3s ease;background:#fff}
.faq-item:hover{border-color:rgba(0,180,216,.2);box-shadow:0 2px 12px rgba(0,180,216,.06)}
.faq-item summary{padding:20px 52px 20px 24px;font-weight:700;cursor:pointer;font-size:1rem;list-style:none;position:relative;transition:background .2s ease}
.faq-item summary::after{content:'+';position:absolute;right:22px;top:50%;transform:translateY(-50%);font-size:1.5rem;color:var(--c-accent);font-weight:300;transition:transform .3s ease}
.faq-item[open] summary::after{content:'';transform:translateY(-50%) rotate(180deg)}
.faq-item[open] summary::after{content:'\2212'}
.faq-item[open] summary{background:var(--c-ice);color:var(--c-navy)}
.faq-item p{padding:0 24px 20px;line-height:1.8;color:var(--c-gray)}

/* TRUST BADGES */
.trust-badges{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;margin-top:40px}
.trust-badge{display:flex;align-items:center;gap:14px;padding:18px 28px;background:#fff;border-radius:14px;box-shadow:var(--shadow-s);border:1px solid rgba(0,180,216,.1);transition:all .35s cubic-bezier(.25,.8,.25,1)}
.trust-badge:hover{transform:translateY(-4px);box-shadow:var(--shadow-m);border-color:rgba(0,180,216,.25)}
.trust-badge svg{width:28px;height:28px;color:var(--c-accent);flex-shrink:0}
.trust-badge span{font-weight:600;font-size:var(--fs-sm);color:var(--c-navy)}

/* ==========================================================
   RESPONSIVE
   ========================================================== */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr}
  .hero-cards{display:none}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .country-grid{grid-template-columns:repeat(3,1fr)}
  .ftr-grid{grid-template-columns:1fr 1fr;gap:28px}
  .about-grid{grid-template-columns:1fr}
  .about-img{order:-1}
}
@media(max-width:768px){
  .section{padding:56px 0}
  .menu-toggle{display:flex}
  
  /* FULLSCREEN MOBILE MENU */
  .nav-main{position:fixed;top:0;left:0;width:100%;height:100vh;height:100dvh;background:rgba(11,31,59,.98);backdrop-filter:blur(20px);flex-direction:column;align-items:center;justify-content:center;gap:24px;z-index:999;opacity:0;pointer-events:none;transition:opacity .35s ease}
  .nav-main.open{opacity:1;pointer-events:auto}
  .nav-main a{font-size:1.25rem;width:auto;text-align:center;color:rgba(255,255,255,.8);padding:8px 0}
  .nav-main a:hover{color:#fff}
  .nav-main li{list-style:none}
  
  /* Close button for mobile menu */
  .nav-main::before{content:'\00D7';position:absolute;top:20px;right:24px;font-size:2.2rem;color:rgba(255,255,255,.6);cursor:pointer;line-height:1;z-index:1000;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color .2s ease}
  
  .hdr-cta{display:none}
  .lang-switch--mobile{display:flex}
  .hero-inner{padding:80px 0 60px}
  .trust-inner{grid-template-columns:repeat(2,1fr)}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .country-grid{grid-template-columns:repeat(2,1fr)}
  .form-grid{grid-template-columns:1fr}
  .form-card [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
  .form-row{grid-template-columns:1fr}
  .ftr-grid{grid-template-columns:1fr}
  .ftr-bottom{flex-direction:column;gap:8px;text-align:center}
  .cta-btns{flex-direction:column;align-items:center}
  .trust-badges{flex-direction:column;align-items:center}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  
  /* Form fixes */
  .form-tabs{flex-direction:row}
  .form-tabs-wrap{max-width:100%}
  .pn-select,.form-field select{font-size:16px}
  .form-field input,.form-field textarea{font-size:16px}
  
  /* Compact sections */
  .network-section{padding:48px 0}
  .network-nodes{gap:8px;min-height:auto;padding:20px 0}
  .network-node{min-width:100px;padding:14px 12px}
  .network-node--hq{min-width:120px}
  .network-emoji{font-size:1.5rem}
  .network-name{font-size:.8rem}
  .network-tag{font-size:.6rem}
  #networkCanvas{display:none}
  .map-section{padding:40px 0}
  .map-wrap{max-height:280px}
  .page-hero{padding:120px 0 60px}
  .page-hero h1{font-size:clamp(1.4rem,5vw,2rem)}
  
  /* No horizontal scroll */
  body{overflow-x:hidden}
  .container{max-width:100%;overflow:hidden}
}
@media(max-width:480px){
  .container{padding:0 16px}
  .trust-inner{grid-template-columns:1fr}
  .country-grid{grid-template-columns:1fr}
}
