/* ================================================================
   CHE EUROPA - FIGMA DESIGN (Blue/Purple/Dark Slate)
   ================================================================ */
:root {
  --grad-brand:   linear-gradient(135deg,#3b82f6 0%,#7c3aed 100%);
  --grad-brand-h: linear-gradient(135deg,#2563eb 0%,#6d28d9 100%);
  --grad-malta:   linear-gradient(135deg,#f59e0b 0%,#ea580c 100%);
  --grad-ireland: linear-gradient(135deg,#10b981 0%,#0d9488 100%);
  --grad-cta:     linear-gradient(135deg,#2563eb 0%,#7c3aed 100%);
  --blue-50:#eff6ff;--blue-100:#dbeafe;--blue-200:#bfdbfe;--blue-300:#93c5fd;
  --blue-400:#60a5fa;--blue-500:#3b82f6;--blue-600:#2563eb;--blue-900:#1e3a8a;
  --purple-100:#f3e8ff;--purple-300:#d8b4fe;--purple-400:#c084fc;
  --purple-500:#a855f7;--purple-600:#7c3aed;--purple-700:#6d28d9;
  --pink-300:#f9a8d4;--pink-600:#db2777;
  --slate-50:#f8fafc;--slate-200:#e2e8f0;--slate-300:#cbd5e1;
  --slate-400:#94a3b8;--slate-500:#64748b;--slate-600:#475569;
  --slate-700:#334155;--slate-800:#1e293b;--slate-900:#0f172a;
  --amber-100:#fef3c7;--amber-500:#f59e0b;
  --yellow-400:#facc15;--white:#ffffff;
  --font-sans:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --section-py:clamp(4.5rem,8vw,6rem);
  --container:1280px;--container-pad:clamp(1rem,5vw,1.5rem);
  --r-sm:6px;--r-md:12px;--r-lg:16px;--r-xl:20px;--r-2xl:24px;--r-3xl:28px;--r-full:9999px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.1);--shadow-md:0 4px 20px rgba(0,0,0,.12);
  --shadow-lg:0 10px 40px rgba(0,0,0,.18);--shadow-xl:0 20px 60px rgba(0,0,0,.24);
  --shadow-blue:0 10px 40px rgba(59,130,246,.35);
  --t:250ms cubic-bezier(.4,0,.2,1);--t-slow:500ms cubic-bezier(.4,0,.2,1);
  --header-h:72px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-sans);font-size:1rem;line-height:1.65;color:var(--slate-900);background:var(--white);-webkit-font-smoothing:antialiased;overflow-x:hidden}
body.menu-open{overflow:hidden}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
button{cursor:pointer;background:none;border:none;font-family:inherit}
ul,ol{list-style:none}
p{margin-bottom:1rem}p:last-child{margin-bottom:0}
h1,h2,h3,h4,h5,h6{line-height:1.15;font-weight:700}
h1{font-size:clamp(2.75rem,6vw,5rem)}
h2{font-size:clamp(2rem,4.5vw,3.5rem)}
h3{font-size:clamp(1.25rem,2.5vw,1.75rem)}

.text-grad{background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.text-grad-light{background:linear-gradient(135deg,#93c5fd,#d8b4fe,#f9a8d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.container{max-width:var(--container);margin:0 auto;padding:0 var(--container-pad)}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;padding:.75em 1.75em;border-radius:var(--r-full);font-family:var(--font-sans);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--t);white-space:nowrap;border:none}
.btn-primary{background:var(--grad-cta);color:var(--white);box-shadow:var(--shadow-blue)}
.btn-primary:hover{background:var(--grad-brand-h);transform:translateY(-2px);box-shadow:0 14px 40px rgba(59,130,246,.5)}
.btn-outline-white{background:transparent;border:2px solid rgba(255,255,255,.35);color:var(--white);backdrop-filter:blur(4px)}
.btn-outline-white:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.6)}
.btn-white{background:var(--white);color:var(--purple-600);box-shadow:var(--shadow-lg)}
.btn-white:hover{background:var(--blue-50);transform:translateY(-2px)}
.btn-outline-wh{background:transparent;border:2px solid var(--white);color:var(--white)}
.btn-outline-wh:hover{background:rgba(255,255,255,.12)}
.btn-malta{background:var(--grad-malta);color:var(--white)}
.btn-ireland{background:var(--grad-ireland);color:var(--white)}
.btn-malta:hover,.btn-ireland:hover{opacity:.9;transform:translateY(-2px)}
.btn-dark{background:linear-gradient(135deg,#0f172a,#1e293b);color:var(--white);border-radius:var(--r-xl)}
.btn-lg{padding:.9em 2.25em;font-size:1.1rem}
.btn-xl{padding:1em 2.5em;font-size:1.15rem}
.btn-block{width:100%}
.btn .arrow,.btn i,.btn svg{transition:transform var(--t)}
.btn:hover .arrow{transform:translateX(4px)}

/* Sections */
.section{padding:var(--section-py) 0}
.section-badge{display:inline-block;padding:.35em 1em;border-radius:var(--r-full);font-size:.8rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:1rem}
.badge-blue{background:var(--blue-100);color:var(--blue-600)}
.badge-purple{background:var(--purple-100);color:var(--purple-700)}
.badge-blue-glass{background:rgba(59,130,246,.15);color:var(--blue-300)}
.badge-white-glass{background:rgba(255,255,255,.12);color:rgba(255,255,255,.9);backdrop-filter:blur(4px)}
.section-title{margin-bottom:.75rem}
.section-desc{font-size:1.15rem;max-width:700px}

/* Animations */
.anim{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.anim.in-view{opacity:1;transform:none}
.anim-d1.in-view{transition-delay:.1s}.anim-d2.in-view{transition-delay:.2s}
.anim-d3.in-view{transition-delay:.3s}.anim-d4.in-view{transition-delay:.4s}
.anim-d5.in-view{transition-delay:.5s}

@keyframes blobPulse{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.25);opacity:1}}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
@keyframes scrollDot{0%,100%{transform:translateY(0)}50%{transform:translateY(16px)}}

/* ---- HEADER ---- */
.site-shell{display:flex;flex-direction:column;min-height:100vh}
.site-header{position:fixed;top:0;left:0;right:0;height:var(--header-h);z-index:900;transition:background var(--t),box-shadow var(--t);background:transparent}
.site-header.scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-md)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);gap:2rem}
.nav-logo{display:flex;align-items:center;gap:.65rem;flex-shrink:0}
.nav-logo__icon{display:flex;align-items:center;justify-content:center;transition:transform var(--t)}
/* LOGO MENÚ: cambiá height para agrandar/achicar (actual: 52px) */
.nav-logo__icon img{height:52px;width:auto;max-width:200px;object-fit:contain;filter:brightness(0) invert(1);transition:filter var(--t)}
.site-header.scrolled .nav-logo__icon img{filter:none}
.nav-logo__text{display:none}
.nav-logo__icon svg{width:22px;height:22px;color:var(--white)}
.main-navigation{flex:1}
.nav-menu,
.main-navigation ul{display:flex;flex-direction:row;gap:.25rem;justify-content:center;list-style:none;margin:0;padding:0}
.nav-menu li,
.main-navigation ul li{list-style:none}
.nav-menu a,
.main-navigation ul a{padding:.45em .9em;font-size:.9rem;font-weight:500;color:rgba(255,255,255,.85);border-radius:var(--r-sm);transition:all var(--t);white-space:nowrap}
.nav-menu a:hover,
.main-navigation ul a:hover{color:var(--white);background:rgba(255,255,255,.1)}
.site-header.scrolled .nav-menu a,
.site-header.scrolled .main-navigation ul a{color:var(--slate-700)}
.site-header.scrolled .nav-menu a:hover,
.site-header.scrolled .main-navigation ul a:hover{color:var(--blue-600);background:var(--blue-50)}
.btn-nav-cta{background:var(--grad-brand);color:var(--white);padding:.55em 1.4em;border-radius:var(--r-full);font-size:.9rem;font-weight:600;transition:all var(--t);flex-shrink:0;border:none;cursor:pointer}
.site-header:not(.scrolled) .btn-nav-cta{background:var(--white);color:var(--purple-600)}
.btn-nav-cta:hover{transform:translateY(-1px);box-shadow:var(--shadow-blue)}
.menu-toggle{display:none;flex-direction:column;gap:5px;padding:5px;color:var(--white)}
.menu-toggle span{display:block;width:22px;height:2px;background:currentColor;border-radius:2px;transition:all var(--t)}
.site-header.scrolled .menu-toggle{color:var(--slate-900)}
.menu-toggle.is-active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.is-active span:nth-child(2){opacity:0}
.menu-toggle.is-active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1000;opacity:0;transition:opacity var(--t)}
.mobile-overlay.is-open{opacity:1}
.mobile-menu{position:absolute;top:0;right:0;width:min(360px,90vw);height:100%;background:var(--white);padding:2rem 1.5rem;display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto;transform:translateX(100%);transition:transform var(--t-slow)}
.mobile-overlay.is-open .mobile-menu{transform:none}
.mobile-menu__close{position:absolute;top:1rem;right:1rem;color:var(--slate-500);font-size:1.4rem;padding:.4rem;transition:color var(--t)}
.mobile-menu__close:hover{color:var(--slate-900)}
.mobile-menu .mobile-nav-menu{display:flex;flex-direction:column;gap:.25rem}
.mobile-menu .mobile-nav-menu a{display:block;padding:.75em 1em;font-size:1.05rem;font-weight:500;color:var(--slate-700);border-radius:var(--r-md);transition:all var(--t)}
.mobile-menu .mobile-nav-menu a:hover{background:var(--blue-50);color:var(--blue-600)}
.social-links{display:flex;gap:.6rem}
.social-links a{width:36px;height:36px;border-radius:50%;background:var(--slate-100);color:var(--slate-500);display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:all var(--t)}
.social-links a:hover{background:var(--grad-brand);color:var(--white)}

/* ---- HERO ---- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover}
.hero__bg-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(30,58,138,.9) 0%,rgba(91,33,182,.85) 50%,rgba(157,23,77,.8) 100%)}
.hero__blob{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;animation:blobPulse 8s ease-in-out infinite}
.hero__blob--1{width:280px;height:280px;background:rgba(59,130,246,.12);top:80px;left:40px}
.hero__blob--2{width:350px;height:350px;background:rgba(236,72,153,.1);bottom:80px;right:40px;animation-delay:2s;animation-duration:10s}
.hero__content{position:relative;z-index:2;max-width:900px;padding:calc(var(--header-h) + 3rem) 0 4rem}
.hero__eyebrow{display:flex;align-items:center;justify-content:center;gap:.6rem;color:#bfdbfe;font-size:1.05rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.25rem}
.hero__eyebrow svg{width:28px;height:28px;color:#93c5fd}
.hero__title{color:var(--white);font-size:clamp(3rem,7vw,5.5rem);font-weight:800;line-height:1.05;margin-bottom:1.25rem}
.hero__sub{font-size:clamp(1.1rem,2vw,1.35rem);color:#dbeafe;max-width:680px;margin:0 auto 1rem}
.hero__sub2{font-size:1.05rem;color:#bfdbfe;max-width:560px;margin:0 auto 2.5rem}
.hero__btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:4.5rem}
.hero__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:720px;margin:0 auto}
.hero__stat{background:rgba(255,255,255,.1);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:var(--r-2xl);padding:1.5rem}
.hero__stat-num{font-size:2.5rem;font-weight:800;color:var(--white);line-height:1;margin-bottom:.35rem}
.hero__stat-lbl{font-size:.85rem;color:#bfdbfe}
.hero__scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;animation:scrollBounce 2s ease infinite}
.hero__scroll-track{width:24px;height:40px;border:2px solid rgba(255,255,255,.45);border-radius:var(--r-full);display:flex;justify-content:center;padding-top:5px}
.hero__scroll-dot{width:5px;height:5px;background:var(--white);border-radius:50%;animation:scrollDot 2s ease infinite}

/* ---- OUR EXPERIENCE ---- */
.experience{background:linear-gradient(to bottom,#f1f5f9,var(--white));position:relative;overflow:hidden}
.experience__blob{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}
.experience__blob--tl{width:380px;height:380px;background:rgba(219,234,254,.5);top:-160px;left:-160px}
.experience__blob--br{width:380px;height:380px;background:rgba(243,232,255,.5);bottom:-160px;right:-160px}
.experience__head{text-align:center;margin-bottom:4rem}
.experience__grid{display:grid;grid-template-columns:1fr 1fr;gap:1.75rem;align-items:stretch}
.exp-card{position:relative;display:flex;flex-direction:column}
.exp-card__glow{position:absolute;inset:0;background:linear-gradient(135deg,rgba(59,130,246,.08),rgba(124,58,237,.08));border-radius:var(--r-3xl);filter:blur(20px);transition:filter var(--t)}
.exp-card:hover .exp-card__glow{filter:blur(32px)}
.exp-card__inner{position:relative;background:var(--white);padding:2rem;border-radius:var(--r-3xl);border:1px solid var(--slate-200);box-shadow:var(--shadow-md);transition:box-shadow var(--t),transform var(--t);flex:1;display:flex;flex-direction:column}
.exp-card:hover .exp-card__inner{box-shadow:var(--shadow-xl);transform:translateY(-6px) scale(1.01)}
.exp-card__icon{width:54px;height:54px;background:var(--grad-brand);border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;transition:transform var(--t)}
.exp-card:hover .exp-card__icon{transform:scale(1.1)}
.exp-card__icon svg,.exp-card__icon i{width:26px;height:26px;font-size:1.2rem;color:var(--white)}
.exp-card__title{font-size:1.35rem;color:var(--slate-900);margin-bottom:.75rem}
.exp-card__desc{color:var(--slate-500);line-height:1.7;margin:0}
.experience__quote{margin-top:5rem;text-align:center}
.experience__quote-inner{position:relative;display:inline-block}
.experience__quote-glow{position:absolute;inset:0;background:var(--grad-brand);border-radius:var(--r-3xl);filter:blur(40px);opacity:.15}
.experience__quote-box{position:relative;background:linear-gradient(135deg,#0f172a,#1e293b);color:var(--white);padding:3rem 3.5rem;border-radius:var(--r-3xl);max-width:800px}
.experience__quote-text{font-size:clamp(1.2rem,2.5vw,1.5rem);font-weight:500;font-style:italic;margin-bottom:1rem;color:var(--white)}
.experience__quote-author{color:#93c5fd;font-size:1rem;margin:0}

/* ---- DESTINATIONS ---- */
.destinations{background:var(--slate-900);position:relative;overflow:hidden}
.destinations__pattern{position:absolute;inset:0;opacity:.04;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='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='1'%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/g%3E%3C/svg%3E")}
.destinations__head{text-align:center;margin-bottom:4rem}
.destinations__head h2{color:var(--white)}
.destinations__head .section-desc{color:var(--slate-300)}
.destinations__grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.dest-card{background:var(--slate-800);border:1px solid var(--slate-700);border-radius:var(--r-3xl);overflow:hidden;transition:border-color var(--t),box-shadow var(--t)}
.dest-card:hover{border-color:var(--slate-600);box-shadow:var(--shadow-xl)}
.dest-card__img-wrap{position:relative;height:260px;overflow:hidden}
.dest-card__img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.dest-card:hover .dest-card__img-wrap img{transform:scale(1.1)}
.dest-card__img-overlay{position:absolute;inset:0;background:linear-gradient(to top,#0f172a 0%,rgba(15,23,42,.5) 50%,transparent 100%)}
.dest-card__badge{position:absolute;top:1rem;left:1rem;display:flex;align-items:center;gap:.45rem;padding:.45em 1.1em;border-radius:var(--r-full);color:var(--white);font-weight:600;font-size:.85rem;box-shadow:var(--shadow-md)}
.dest-card__badge--malta{background:var(--grad-malta)}
.dest-card__badge--ireland{background:var(--grad-ireland)}
.dest-card__badge svg,.dest-card__badge i{width:15px;height:15px;font-size:.75rem}
.dest-card__body{padding:2rem}
.dest-card__tagline{font-size:1.6rem;font-weight:700;color:var(--white);margin-bottom:.6rem}
.dest-card__desc{color:var(--slate-300);line-height:1.7;margin-bottom:1.5rem}
.dest-card__highlights{display:flex;flex-direction:column;gap:.7rem;margin-bottom:1.75rem}
.dest-card__hl{display:flex;align-items:center;gap:.75rem;color:var(--slate-300);font-size:.9rem}
.dest-card__hl-icon{width:32px;height:32px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dest-card__hl-icon--malta{background:var(--grad-malta)}
.dest-card__hl-icon--ireland{background:var(--grad-ireland)}
.dest-card__hl-icon svg,.dest-card__hl-icon i{width:15px;height:15px;font-size:.75rem;color:var(--white)}
.destinations__sub{margin-top:3rem;text-align:center;color:var(--slate-400);font-size:1.05rem}
.destinations__sub a{color:#60a5fa;font-weight:600;text-decoration:underline;text-underline-offset:4px}
.destinations__sub a:hover{color:#93c5fd}

/* ---- SERVICES / HOW WE HELP ---- */
.services{background:linear-gradient(to bottom,var(--white),rgba(219,234,254,.18),var(--white));position:relative}
.services__blob{position:absolute;border-radius:50%;filter:blur(70px);pointer-events:none}
.services__blob--l{width:300px;height:300px;background:rgba(191,219,254,.25);top:25%;left:0}
.services__blob--r{width:380px;height:380px;background:rgba(221,214,254,.25);bottom:25%;right:0}
.services__head{text-align:center;margin-bottom:3rem}
.services__notice{max-width:800px;margin:0 auto 3.5rem;background:var(--blue-50);border-left:4px solid var(--blue-500);border-radius:0 var(--r-xl) var(--r-xl) 0;padding:1.5rem 2rem;display:flex;gap:1.25rem;align-items:flex-start}
.services__notice-icon{color:#1e40af;flex-shrink:0;margin-top:2px}
.services__notice-icon svg,.services__notice-icon i{width:22px;height:22px;font-size:1.1rem}
.services__notice-title{font-weight:700;color:#1e3a8a;margin-bottom:.4rem}
.services__notice-text{color:#1e40af;font-size:.92rem;line-height:1.65;margin:0}
.services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;padding-top:14px}
.svc-card{position:relative;z-index:0}
.svc-card:hover{z-index:10}
.svc-card--warning{z-index:5}
.svc-card{position:relative}
.svc-card__glow{position:absolute;inset:0;background:linear-gradient(135deg,rgba(59,130,246,.04),rgba(124,58,237,.04));border-radius:var(--r-2xl);filter:blur(16px);transition:filter var(--t)}
.svc-card:hover .svc-card__glow{filter:blur(28px)}
.svc-card__inner{position:relative;background:var(--white);border:2px solid var(--slate-200);border-radius:var(--r-2xl);padding:1.75rem;height:100%;box-shadow:var(--shadow-sm);transition:box-shadow var(--t),transform var(--t),border-color var(--t)}
.svc-card:hover .svc-card__inner{box-shadow:var(--shadow-xl);transform:translateY(-8px)}
.svc-card--warning .svc-card__inner{border-color:#fcd34d}
.svc-card__badge-warn{position:absolute;top:-12px;right:-10px;background:var(--amber-500);color:var(--white);font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:.3em .8em;border-radius:var(--r-full);z-index:20;box-shadow:0 2px 8px rgba(245,158,11,.4)}
.svc-card__icon{width:48px;height:48px;border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;transition:transform var(--t)}
.svc-card:hover .svc-card__icon{transform:scale(1.1)}
.svc-card__icon svg,.svc-card__icon i{width:22px;height:22px;font-size:1.05rem;color:var(--white)}
.svc-card__icon--default{background:var(--grad-brand)}
.svc-card__icon--warn{background:var(--grad-malta)}
.svc-card__title{font-size:1.1rem;color:var(--slate-900);margin-bottom:.5rem}
.svc-card__tag{display:inline-block;padding:.2em .75em;border-radius:var(--r-full);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.75rem}
.svc-card__tag--default{background:var(--blue-100);color:#1d4ed8}
.svc-card__tag--warn{background:var(--amber-100);color:#92400e}
.svc-card__desc{color:var(--slate-500);font-size:.9rem;line-height:1.65;margin:0}
.services__bottom{margin-top:3.5rem;display:flex;justify-content:center}
.services__bottom-box{background:linear-gradient(135deg,#0f172a,#1e293b);color:var(--white);padding:1.75rem 2.5rem;border-radius:var(--r-2xl);max-width:750px;text-align:center;font-size:1rem;line-height:1.65}
.services__bottom-box svg,.services__bottom-box i{display:block;width:30px;height:30px;font-size:1.4rem;color:#60a5fa;margin:0 auto .75rem}
.services__bottom-box strong{color:var(--white)}

/* ---- PROCESS ---- */
.process{background:var(--slate-900);position:relative;overflow:hidden}
.process__blob{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;animation:blobPulse 8s ease-in-out infinite}
.process__blob--tl{width:380px;height:380px;background:rgba(59,130,246,.08);top:0;left:25%}
.process__blob--br{width:380px;height:380px;background:rgba(124,58,237,.08);bottom:0;right:25%;animation-delay:1s}
.process__head{text-align:center;margin-bottom:5rem}
.process__head h2{color:var(--white)}
.process__head .section-desc{color:var(--slate-300)}
.process__steps{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.process__line{display:none;position:absolute;top:50%;left:0;right:0;height:2px;background:linear-gradient(to right,#3b82f6,#a855f7,#ec4899);transform:translateY(-50%);pointer-events:none}
.step-card{position:relative}
.step-card__glow{position:absolute;inset:0;background:linear-gradient(135deg,rgba(59,130,246,.18),rgba(124,58,237,.18));border-radius:var(--r-3xl);filter:blur(20px);transition:filter var(--t)}
.step-card:hover .step-card__glow{filter:blur(30px)}
.step-card__inner{position:relative;background:var(--slate-800);border:2px solid var(--slate-700);border-radius:var(--r-3xl);padding:1.75rem;transition:border-color var(--t)}
.step-card:hover .step-card__inner{border-color:var(--slate-600)}
.step-card__num{position:absolute;top:-16px;right:-16px;width:48px;height:48px;background:var(--grad-brand);border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--white);font-size:.9rem;box-shadow:var(--shadow-blue)}
.step-card__icon-wrap{width:64px;height:64px;background:rgba(59,130,246,.15);border:1px solid rgba(59,130,246,.3);border-radius:var(--r-2xl);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;backdrop-filter:blur(4px)}
.step-card__icon-wrap svg,.step-card__icon-wrap i{width:30px;height:30px;font-size:1.4rem;color:#60a5fa}
.step-card__title{font-size:1.35rem;color:var(--white);margin-bottom:.5rem}
.step-card__tag{display:inline-block;background:rgba(124,58,237,.2);color:#d8b4fe;border:1px solid rgba(124,58,237,.3);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.25em .8em;border-radius:var(--r-full);margin-bottom:.75rem}
.step-card__desc{color:var(--slate-300);font-size:.9rem;line-height:1.65;margin:0}
.process__cta{text-align:center;margin-top:4rem}
.process__cta-note{color:var(--slate-400);font-size:.9rem;margin-top:.75rem}

/* ---- TESTIMONIALS ---- */
.testimonials{background:linear-gradient(to bottom,var(--white),#f1f5f9);position:relative;overflow:hidden}
.testimonials__blob{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}
.testimonials__blob--tr{width:380px;height:380px;background:rgba(243,232,255,.5);top:0;right:0;transform:translate(50%,-50%)}
.testimonials__blob--bl{width:380px;height:380px;background:rgba(219,234,254,.5);bottom:0;left:0;transform:translate(-50%,50%)}
.testimonials__head{text-align:center;margin-bottom:4rem}
.testimonials__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.t-card{position:relative}
.t-card__glow{position:absolute;inset:0;background:linear-gradient(135deg,rgba(59,130,246,.08),rgba(124,58,237,.08));border-radius:var(--r-3xl);filter:blur(20px);transition:filter var(--t)}
.t-card:hover .t-card__glow{filter:blur(32px)}
.t-card__inner{position:relative;background:var(--white);border:1px solid var(--slate-200);border-radius:var(--r-3xl);padding:2rem;box-shadow:var(--shadow-md);transition:box-shadow var(--t),transform var(--t)}
.t-card:hover .t-card__inner{box-shadow:var(--shadow-xl);transform:translateY(-10px)}
.t-card__quote-icon{position:absolute;top:-16px;left:-16px;width:48px;height:48px;background:var(--grad-brand);border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-blue)}
.t-card__quote-icon svg,.t-card__quote-icon i{width:22px;height:22px;font-size:1rem;color:var(--white)}
.t-card__stars{display:flex;gap:.2em;margin-bottom:1rem}
.t-card__stars svg,.t-card__stars i{width:18px;height:18px;font-size:.9rem;fill:var(--yellow-400);color:var(--yellow-400)}
.t-card__text{color:var(--slate-700);font-style:italic;line-height:1.75;margin-bottom:1.5rem;font-size:.95rem}
.t-card__text::before{content:'\201C'}.t-card__text::after{content:'\201D'}
.t-card__author{display:flex;align-items:center;gap:1rem;padding-top:1.25rem;border-top:1px solid var(--slate-200)}
.t-card__avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--grad-brand)}
.t-card__avatar img{width:100%;height:100%;object-fit:cover;opacity:.85}
.t-card__name{font-weight:700;color:var(--slate-900);font-size:.95rem}
.t-card__dest{font-size:.82rem;color:var(--slate-500)}
.testimonials__trust{margin-top:4rem;text-align:center}
.testimonials__trust-badge{display:inline-flex;align-items:center;gap:.6rem;background:linear-gradient(135deg,#0f172a,#1e293b);color:var(--white);padding:.75em 1.75em;border-radius:var(--r-full);font-weight:600;font-size:.95rem}
.testimonials__trust-badge svg,.testimonials__trust-badge i{width:18px;height:18px;font-size:.85rem;fill:var(--yellow-400);color:var(--yellow-400)}

/* ---- FINAL CTA ---- */
.final-cta{position:relative;padding:clamp(5rem,10vw,8rem) 0;overflow:hidden}
.final-cta__bg{position:absolute;inset:0;background:linear-gradient(135deg,#2563eb 0%,#7c3aed 50%,#db2777 100%)}
.final-cta__blob{position:absolute;width:380px;height:380px;background:rgba(255,255,255,.1);border-radius:50%;filter:blur(60px)}
.final-cta__blob--tl{top:0;left:0;animation:blobPulse 10s ease-in-out infinite}
.final-cta__blob--br{bottom:0;right:0;animation:blobPulse 12s ease-in-out 2s infinite}
.final-cta__pattern{position:absolute;inset:0;opacity:.08;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='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='1'%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/g%3E%3C/svg%3E")}
.final-cta__inner{position:relative;z-index:1;text-align:center;max-width:900px;margin:0 auto}
.final-cta__title{font-size:clamp(2.5rem,5.5vw,4.5rem);font-weight:800;color:var(--white);line-height:1.1;margin-bottom:1.25rem}
.final-cta__sub{font-size:1.2rem;color:#dbeafe;margin-bottom:3rem;max-width:680px;margin-left:auto;margin-right:auto}
.final-cta__btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:4rem}
.final-cta__contacts{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:800px;margin:0 auto}
.contact-card{background:rgba(255,255,255,.1);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:var(--r-2xl);padding:1.75rem;text-align:center;transition:background var(--t),transform var(--t);color:var(--white)}
.contact-card:hover{background:rgba(255,255,255,.2);transform:scale(1.05)}
.contact-card svg,.contact-card i{width:30px;height:30px;font-size:1.4rem;margin:0 auto .75rem;display:block}
.contact-card__label{font-weight:700;margin-bottom:.3rem;font-size:.95rem}
.contact-card__value{font-size:.85rem;color:#dbeafe}

/* ---- FOOTER ---- */
.site-footer{background:var(--slate-900);color:var(--slate-300);padding:4rem 0 0;border-top:1px solid var(--slate-800)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2.5rem;margin-bottom:3rem}
.footer-brand__logo{display:flex;align-items:center;gap:.65rem;margin-bottom:1rem}
.footer-brand__logo-icon{width:40px;height:40px;background:var(--grad-brand);border-radius:12px;display:flex;align-items:center;justify-content:center}
.footer-brand__logo-icon svg,.footer-brand__logo-icon i{width:22px;height:22px;font-size:1rem;color:var(--white)}
.footer-brand__name{font-size:1.3rem;font-weight:700;color:var(--white)}
.footer-brand__desc{font-size:.88rem;color:var(--slate-400);line-height:1.7;max-width:360px;margin-bottom:1.25rem}
.footer-brand__social{display:flex;gap:.6rem}
.footer-brand__social a{width:38px;height:38px;background:var(--slate-800);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--slate-400);font-size:.9rem;transition:all var(--t)}
.footer-brand__social .s-mail:hover{background:var(--blue-600);color:var(--white)}
.footer-brand__social .s-wa:hover{background:#16a34a;color:var(--white)}
.footer-brand__social .s-ig:hover{background:var(--pink-600);color:var(--white)}
.footer-col h3{color:var(--white);font-size:.95rem;font-weight:600;margin-bottom:1rem}
.footer-links{display:flex;flex-direction:column;gap:.55rem}
.footer-links a{font-size:.88rem;color:var(--slate-400);transition:color var(--t)}
.footer-links a:hover{color:#60a5fa}
.footer-bottom{border-top:1px solid var(--slate-800);padding:1.5rem 0;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer-bottom p{font-size:.82rem;color:var(--slate-500);margin:0}
.footer-bottom__heart{display:flex;align-items:center;gap:.4rem;font-size:.82rem;color:var(--slate-500)}
.footer-bottom__heart svg,.footer-bottom__heart i{width:14px;height:14px;font-size:.7rem;fill:#ef4444;color:#ef4444}

/* ---- FLOATS ---- */
.whatsapp-float{position:fixed;bottom:1.75rem;right:1.75rem;z-index:800;width:56px;height:56px;background:linear-gradient(135deg,#25d366,#128c7e);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--white);box-shadow:0 4px 22px rgba(37,211,102,.45);transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .25s ease}
.whatsapp-float:hover{transform:scale(1.12);box-shadow:0 6px 28px rgba(37,211,102,.6)}
.scroll-top{position:fixed;bottom:4.75rem;right:1.75rem;z-index:799;width:40px;height:40px;background:var(--slate-800);border:1px solid var(--slate-700);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--slate-300);font-size:.8rem;opacity:0;pointer-events:none;transition:all .25s ease}
.scroll-top.visible{opacity:1;pointer-events:all}
.scroll-top:hover{background:var(--blue-600);color:var(--white);border-color:var(--blue-600)}

/* ---- GENERIC ---- */
.page-hero{background:linear-gradient(135deg,#0f172a,#1e293b);padding:clamp(5rem,10vw,8rem) 0 clamp(3rem,6vw,5rem);text-align:center}
.page-hero h1{color:var(--white)}
.page-inner{padding:clamp(3.5rem,7vw,6rem) 0}
.error-404{min-height:65vh;display:flex;align-items:center;justify-content:center;text-align:center}
.error-404__num{font-size:clamp(6rem,15vw,11rem);font-weight:900;line-height:1;background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ---- RESPONSIVE ---- */
@media(max-width:1024px){
  .experience__grid{grid-template-columns:1fr}
  .destinations__grid{grid-template-columns:1fr}
  .services__grid{grid-template-columns:1fr 1fr}
  .process__steps{grid-template-columns:1fr 1fr}
  .testimonials__grid{grid-template-columns:1fr 1fr}
  .final-cta__contacts{grid-template-columns:1fr;max-width:400px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(min-width:1025px){
  .process__line{display:block}
  .experience__grid{grid-template-columns:1fr 1fr}
  .testimonials__grid{grid-template-columns:repeat(3,1fr)}
  .final-cta__contacts{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  .main-navigation,.site-header__actions>a{display:none}
  .menu-toggle{display:flex}
  .mobile-overlay{display:block}
  .hero__stats{grid-template-columns:1fr;max-width:320px}
  .hero__btns{flex-direction:column;align-items:center}
  .hero__btns .btn{width:100%;max-width:300px}
  .services__grid{grid-template-columns:1fr}
  .process__steps{grid-template-columns:1fr}
  .testimonials__grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .final-cta__btns{flex-direction:column;align-items:center}
  .final-cta__btns .btn{width:100%;max-width:300px}
  .experience__quote-box{padding:2rem 1.75rem}
  .services__notice{flex-direction:column}

  /* ── Mobile menu: make fallback nav-menu links visible ── */
  .mobile-menu .nav-menu,
  .mobile-menu ul{display:flex!important;flex-direction:column!important;gap:.25rem}
  .mobile-menu .nav-menu a,
  .mobile-menu ul a{color:var(--slate-700)!important;font-size:1.05rem;font-weight:500;padding:.75em 1em;border-radius:var(--r-md)}
  .mobile-menu .nav-menu a:hover,
  .mobile-menu ul a:hover{background:var(--blue-50);color:var(--blue-600)!important}
  .mobile-menu .nav-menu li,
  .mobile-menu ul li{list-style:none}

  /* ── Contact page mobile fixes ── */
  .contact-page{padding:2rem 0}
  .contact-page .container{padding-left:1rem;padding-right:1rem}
  .contact-form-card{padding:1.5rem;border-radius:var(--r-xl);margin:0 -0.25rem}
  .contact-info-card{padding:1rem 1.15rem}
  .about-page__hero{padding:3rem 1rem 2rem}
  .about-page__hero h1{font-size:1.75rem}
  .about-page__hero p{font-size:.95rem}

  /* ── HubSpot form mobile overrides ── */
  .hs-form-frame,
  .hs-form-frame iframe,
  .hs_cos_wrapper_type_form{width:100%!important;max-width:100%!important}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* ================================================================
   DESTINATION PAGES - Responsive grid overrides
   ================================================================ */
@media (max-width: 768px) {
  /* About grid inside destinations */
  [style*="grid-template-columns:1.1fr 1fr"],
  [style*="grid-template-columns:1fr 1.1fr"] {
    grid-template-columns: 1fr !important;
  }
  /* Packages grid */
  [style*="grid-template-columns:repeat(3,1fr)"] {
    grid-template-columns: 1fr !important;
  }
  /* Featured card reset */
  [style*="transform:translateY(-8px) scale(1.02)"] {
    transform: none !important;
  }
}

/* ================================================================
   PARTNERS SECTION
   ================================================================ */
.partners {
  background: var(--white);
  border-top: 1px solid var(--slate-200);
  padding: 3.5rem 0;
}
.partners__head {
  text-align: center;
  margin-bottom: 2.5rem;
}
.partners__label {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--slate-400);
}
.partners__label::before,
.partners__label::after {
  content: '';
  display: block;
  width: 40px;
  height: 1px;
  background: var(--slate-300);
}
.partners__grid {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 2rem 3.5rem;
}
.partner-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .75rem;
  transition: all var(--t);
}
.partner-item:hover {
  transform: translateY(-3px);
}
.partner-item img {
  height: 91px;
  width: auto;
  max-width: 245px;
  object-fit: contain;
}
.partner-item__name {
  font-size: .72rem;
  font-weight: 600;
  color: var(--slate-400);
  letter-spacing: .05em;
  text-transform: uppercase;
}
.partners__trust {
  text-align: center;
  margin-top: 2.5rem;
  font-size: .85rem;
  color: var(--slate-400);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
}
.partners__trust i { color: var(--blue-400); }

/* ================================================================
   CONTACT FORM PAGE
   ================================================================ */
.contact-page { padding: clamp(4rem,8vw,6rem) 0; background: linear-gradient(to bottom,#f8fafc,var(--white)); }
.contact-page__grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 4rem; align-items: start; max-width: 1100px; margin: 0 auto; }
.contact-page__info h1 { font-size: clamp(2rem,4vw,2.75rem); margin-bottom: 1rem; }
.contact-page__info p  { color: var(--slate-500); font-size: 1.05rem; line-height: 1.75; margin-bottom: 2rem; }
.contact-info-card {
  background: var(--white);
  border: 1px solid var(--slate-200);
  border-radius: var(--r-xl);
  padding: 1.25rem 1.5rem;
  display: flex; align-items: center; gap: 1rem;
  margin-bottom: .75rem;
  transition: box-shadow var(--t);
  text-decoration: none; color: inherit;
}
.contact-info-card:hover { box-shadow: var(--shadow-md); }
.contact-info-card__icon {
  width: 44px; height: 44px; border-radius: var(--r-md);
  background: var(--grad-brand);
  display: flex; align-items: center; justify-content: center;
  color: var(--white); font-size: 1rem; flex-shrink: 0;
}
.contact-info-card__label { font-size: .75rem; text-transform: uppercase; letter-spacing: .06em; color: var(--slate-400); font-weight: 600; }
.contact-info-card__value { font-size: .95rem; font-weight: 600; color: var(--slate-800); }

/* Form card — see HUBSPOT FORM INTEGRATION section below for full styling */

.cform-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1rem; }
.cform-row--full { grid-template-columns: 1fr; }
.cform-field { display: flex; flex-direction: column; gap: .4rem; }
.cform-field label { font-size: .82rem; font-weight: 600; color: var(--slate-700); letter-spacing: .02em; }
.cform-field label span { color: #ef4444; margin-left: .15em; }
.cform-field input,
.cform-field select,
.cform-field textarea {
  padding: .75em 1em;
  border: 1.5px solid var(--slate-200);
  border-radius: var(--r-md);
  font-family: var(--font-sans);
  font-size: .92rem;
  color: var(--slate-800);
  background: var(--white);
  transition: border-color var(--t), box-shadow var(--t);
  outline: none;
}
.cform-field input:focus,
.cform-field select:focus,
.cform-field textarea:focus {
  border-color: var(--blue-500);
  box-shadow: 0 0 0 3px rgba(59,130,246,.12);
}
.cform-field textarea { resize: vertical; min-height: 110px; }
.cform-field select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%2394a3b8' d='M6 8L0 0h12z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1em center; padding-right: 2.5em; }
.cform-submit { margin-top: 1.5rem; }
.cform-submit .btn { width: 100%; font-size: 1rem; padding: 1em; }
.cform-notice {
  padding: 1rem 1.25rem;
  border-radius: var(--r-md);
  font-size: .9rem;
  margin-bottom: 1.25rem;
  display: none;
}
.cform-notice--success { background: #f0fdf4; border: 1px solid #86efac; color: #15803d; }
.cform-notice--error   { background: #fef2f2; border: 1px solid #fca5a5; color: #dc2626; }
.cform-notice.visible  { display: block; }

/* ================================================================
   ABOUT / SOBRE NOSOTROS PAGE
   ================================================================ */
.about-page { padding: clamp(4rem,8vw,6rem) 0; }
.about-page__hero {
  background: linear-gradient(135deg, var(--slate-900), #1e1b4b);
  padding: clamp(4rem,8vw,6rem) 0;
  text-align: center;
  position: relative; overflow: hidden;
}
.about-page__hero::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 30% 50%, rgba(59,130,246,.15), transparent 60%),
              radial-gradient(ellipse at 70% 50%, rgba(124,58,237,.15), transparent 60%);
}
.about-page__hero h1 { color: var(--white); position: relative; }
.about-page__hero p  { color: rgba(255,255,255,.7); font-size: 1.15rem; max-width: 600px; margin: 1rem auto 0; position: relative; }

.team-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; max-width: 900px; margin: 4rem auto 0; }
.team-card {
  background: var(--white);
  border: 1px solid var(--slate-200);
  border-radius: var(--r-2xl);
  padding: 2.5rem 2rem;
  text-align: center;
  box-shadow: var(--shadow-md);
  transition: transform var(--t), box-shadow var(--t);
  position: relative; overflow: hidden;
}
.team-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: var(--grad-brand);
}
.team-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-xl); }
.team-card__avatar {
  width: 96px; height: 96px;
  border-radius: 50%;
  background: var(--grad-brand);
  display: flex; align-items: center; justify-content: center;
  font-size: 2.25rem; font-weight: 800; color: var(--white);
  margin: 0 auto 1.5rem;
  box-shadow: 0 6px 24px rgba(59,130,246,.3);
  overflow: hidden;
}
.team-card__name    { font-size: 1.35rem; font-weight: 700; color: var(--slate-900); margin-bottom: .3rem; }
.team-card__role    { font-size: .88rem; font-weight: 600; color: var(--blue-600); text-transform: uppercase; letter-spacing: .05em; margin-bottom: .25rem; }
.team-card__uni     { font-size: .82rem; color: var(--slate-400); margin-bottom: 1.25rem; display: flex; align-items: center; justify-content: center; gap: .4rem; }
.team-card__uni i   { color: var(--purple-500); }
.team-card__bio     { font-size: .9rem; color: var(--slate-600); line-height: 1.7; margin-bottom: 1.5rem; }
.team-card__tags    { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: center; }
.team-card__tag {
  background: var(--blue-50); color: var(--blue-700);
  font-size: .72rem; font-weight: 600; padding: .3em .8em;
  border-radius: var(--r-full); letter-spacing: .03em;
}

.about-values { max-width: 900px; margin: 4rem auto; }
.about-values h2 { text-align: center; margin-bottom: 2.5rem; }
.about-values__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.about-value-card {
  background: var(--white); border: 1px solid var(--slate-200);
  border-radius: var(--r-xl); padding: 1.75rem; text-align: center;
  transition: all var(--t);
}
.about-value-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.about-value-card i { font-size: 1.75rem; background: var(--grad-brand); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; margin-bottom: .75rem; display: block; }
.about-value-card h3 { font-size: 1rem; margin-bottom: .5rem; }
.about-value-card p  { font-size: .85rem; color: var(--slate-500); margin: 0; line-height: 1.6; }

@media (max-width: 768px) {
  .contact-page__grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .cform-row { grid-template-columns: 1fr; }
  .team-grid { grid-template-columns: 1fr; }
  .about-values__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .about-values__grid { grid-template-columns: 1fr; }
  .contact-form-card { padding: 1.25rem; }
  .cform-submit .btn { font-size: .92rem; padding: .85em; }
}

/* ================================================================
   HUBSPOT FORM INTEGRATION
   ================================================================ */

/* ── Container & iframe ── */
.contact-form-card .hs-form-frame {
  width: 100%;
  max-width: 100%;
  min-height: 420px;
}
.contact-form-card .hs-form-frame iframe {
  width: 100% !important;
  max-width: 100% !important;
  border: none !important;
}

/* ── Card styling upgrade ── */
.contact-form-card {
  background: var(--white);
  border: 1px solid var(--slate-200);
  border-radius: var(--r-2xl);
  padding: 2.5rem;
  box-shadow: 0 8px 32px rgba(0,0,0,.08), 0 2px 8px rgba(59,130,246,.06);
  position: relative;
  overflow: hidden;
}
.contact-form-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: var(--grad-brand);
  border-radius: var(--r-2xl) var(--r-2xl) 0 0;
}
.contact-form-card h2 {
  font-size: 1.5rem;
  margin-bottom: .4rem;
  color: var(--slate-900);
}
.contact-form-card > p {
  color: var(--slate-500);
  font-size: .9rem;
  margin-bottom: 1.75rem;
  line-height: 1.6;
}

/* ── HubSpot inline form overrides (if rendered inline) ── */
.contact-form-card .hs-form fieldset { max-width: 100% !important; }
.contact-form-card .hs-form .hs-form-field { margin-bottom: 1.15rem; }
.contact-form-card .hs-form label:not(.hs-error-msg) {
  font-size: .82rem !important;
  font-weight: 600 !important;
  color: var(--slate-700) !important;
  letter-spacing: .02em;
  margin-bottom: .4rem !important;
  display: block;
}
.contact-form-card .hs-form .hs-input,
.contact-form-card .hs-form select,
.contact-form-card .hs-form textarea {
  width: 100% !important;
  padding: .75em 1em !important;
  border: 1.5px solid var(--slate-200) !important;
  border-radius: var(--r-md) !important;
  font-family: var(--font-sans) !important;
  font-size: .92rem !important;
  color: var(--slate-800) !important;
  background: var(--white) !important;
  transition: border-color var(--t), box-shadow var(--t) !important;
  outline: none !important;
  box-sizing: border-box !important;
  -webkit-appearance: none;
  appearance: none;
}
.contact-form-card .hs-form .hs-input:focus,
.contact-form-card .hs-form select:focus,
.contact-form-card .hs-form textarea:focus {
  border-color: var(--blue-500) !important;
  box-shadow: 0 0 0 3px rgba(59,130,246,.12) !important;
}
.contact-form-card .hs-form select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%2394a3b8' d='M6 8L0 0h12z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 1em center !important;
  padding-right: 2.5em !important;
}
.contact-form-card .hs-form textarea {
  resize: vertical !important;
  min-height: 100px !important;
}
.contact-form-card .hs-form .hs-error-msg,
.contact-form-card .hs-form .hs-error-msgs label {
  color: #dc2626 !important;
  font-size: .8rem !important;
  font-weight: 500 !important;
  margin-top: .3rem !important;
}
.contact-form-card .hs-form .hs-button,
.contact-form-card .hs-form input[type="submit"] {
  width: 100% !important;
  padding: 1em 2em !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  font-family: var(--font-sans) !important;
  color: var(--white) !important;
  background: var(--grad-brand) !important;
  border: none !important;
  border-radius: var(--r-full) !important;
  cursor: pointer !important;
  transition: all var(--t) !important;
  margin-top: .75rem;
  letter-spacing: .02em;
}
.contact-form-card .hs-form .hs-button:hover,
.contact-form-card .hs-form input[type="submit"]:hover {
  transform: translateY(-2px) !important;
  box-shadow: var(--shadow-blue) !important;
  opacity: .95;
}
/* ── HubSpot form grid (side-by-side fields) ── */
.contact-form-card .hs-form .form-columns-2 {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 1rem !important;
}
.contact-form-card .hs-form .form-columns-2 .hs-form-field {
  width: 100% !important;
  float: none !important;
}
/* ── Legal & consent text ── */
.contact-form-card .hs-form .legal-consent-container,
.contact-form-card .hs-form .hs-richtext {
  font-size: .8rem !important;
  color: var(--slate-400) !important;
  line-height: 1.5 !important;
}
/* ── Phone input with country code ── */
.contact-form-card .hs-form .hs-phone {
  display: flex;
  gap: .5rem;
}
.contact-form-card .hs-form .hs-fieldtype-intl-phone .input {
  display: flex !important;
  gap: .5rem !important;
}

/* ── Mobile responsive for form ── */
@media (max-width: 768px) {
  .contact-form-card .hs-form .form-columns-2 {
    grid-template-columns: 1fr !important;
  }
}
