
/* === Homepage specific styles === */

/* HERO */
.hero{position:relative;min-height:90vh;display:flex;align-items:center;overflow:hidden;padding:100px 0 60px}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--blue) 0%,var(--blue-mid) 60%,var(--blue-light) 100%)}
.hero-overlay{position:absolute;inset:0;background: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='0.03'%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")}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}
.hero-eyebrow{font-size:.9rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.hero-heading{font-family:var(--font-display);font-size:clamp(2rem,4.5vw,3.4rem);font-weight:900;color:var(--white);line-height:1.15;margin-bottom:20px}
.hero-sub{font-size:1.1rem;color:rgba(255,255,255,.85);line-height:1.7;margin-bottom:36px;max-width:480px}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap}
.hero-image-wrap{position:relative}
.hero-image-wrap img{border-radius:24px;box-shadow:0 40px 80px rgba(0,0,0,.4);width:100%;height:auto;object-fit:cover;mix-blend-mode:luminosity;opacity:.92}
.hero-image-wrap::before{content:'';position:absolute;inset:-4px;border-radius:28px;background:linear-gradient(135deg,var(--accent),transparent);z-index:-1;opacity:.5}

/* COUNTRY SECTION */
.country-search-wrap{position:relative;max-width:480px;margin:0 auto 32px}
.country-search-wrap input{width:100%;padding:14px 48px 14px 20px;border:2px solid var(--border);border-radius:50px;font-size:1rem;font-family:var(--font-body);outline:none;transition:border-color var(--transition)}
.country-search-wrap input:focus{border-color:var(--blue-mid)}
.country-search-wrap svg{position:absolute;right:18px;top:50%;transform:translateY(-50%);color:var(--grey);pointer-events:none}
.country-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.country-card{display:flex;align-items:center;gap:16px;padding:18px 20px;border:2px solid var(--border);border-radius:var(--radius);background:var(--white);transition:all var(--transition);min-height:72px;text-decoration:none;color:inherit}
.country-card:hover{border-color:var(--blue-mid);box-shadow:0 8px 32px rgba(26,58,107,.12);transform:translateY(-3px);color:inherit}
.country-flag{width:56px;height:38px;border-radius:4px;overflow:hidden;flex-shrink:0;border:1px solid rgba(0,0,0,.1)}
.country-flag svg{width:100%;height:100%}
.country-info{flex:1}
.country-info strong{display:block;font-size:1rem;font-weight:600;color:var(--blue)}
.country-info span{font-size:.85rem;color:var(--grey)}
.country-arrow{color:var(--grey);flex-shrink:0;transition:transform var(--transition)}
.country-card:hover .country-arrow{transform:translateX(4px);color:var(--blue-mid)}

/* BENEFITS */
.benefits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:28px}
.benefit-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:32px;transition:all var(--transition)}
.benefit-card:hover{box-shadow:0 12px 40px rgba(26,58,107,.1);transform:translateY(-4px)}
.benefit-icon{width:64px;height:64px;background:linear-gradient(135deg,var(--blue),var(--blue-mid));border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--white)}

/* REVIEWS */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.review-card{background:var(--off-white);border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:all var(--transition)}
.review-card:hover{box-shadow:0 8px 32px rgba(26,58,107,.1)}
.stars{color:var(--accent);font-size:1.2rem;margin-bottom:12px;letter-spacing:2px}
.reviewer{margin-top:16px;font-size:.9rem;color:var(--grey)}

/* PRODUCTS */
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:28px}
.product-spec{padding:28px;border:1px solid var(--border);border-radius:var(--radius);background:var(--white);transition:all var(--transition)}
.product-spec:hover{box-shadow:0 12px 40px rgba(26,58,107,.1);transform:translateY(-4px)}
.product-spec-icon{width:56px;height:56px;background:var(--off-white);border:2px solid var(--border);border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;color:var(--blue)}

/* FIFI */
.fifi-section{background:linear-gradient(135deg,var(--off-white) 0%,rgba(59,114,212,.06) 100%)}
.fifi-inner{display:grid;grid-template-columns:auto 1fr;gap:60px;align-items:center;max-width:900px;margin:0 auto}
.fifi-emoji-wrap{display:flex;flex-direction:column;align-items:center;gap:16px}
.fifi-avatar{width:160px;height:160px;background:white;border-radius:50%;box-shadow:0 20px 60px rgba(26,58,107,.15);display:flex;align-items:center;justify-content:center;border:4px solid var(--border)}
.fifi-eyebrow{font-size:.85rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-mid);margin-bottom:8px}
.fifi-desc{font-size:1.05rem;font-weight:500;color:var(--blue);margin-bottom:12px}
.fifi-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.fifi-tag{background:var(--blue);color:var(--white);padding:6px 14px;border-radius:50px;font-size:.8rem;font-weight:600}

/* COMPANY */
.company-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.company-detail{display:flex;align-items:flex-start;gap:16px;padding:24px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius)}
.company-detail svg{flex-shrink:0;color:var(--blue-mid);margin-top:2px}
.company-detail h4{margin-bottom:4px}
.company-detail p{margin:0;font-size:.95rem;color:var(--grey)}
.company-detail a{color:var(--blue-mid)}

/* CONTACT */
.contact-methods{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}
.contact-method{display:flex;align-items:center;gap:16px;padding:24px 32px;border:2px solid var(--border);border-radius:var(--radius);background:var(--off-white);transition:all var(--transition);text-decoration:none;color:inherit;min-width:280px}
.contact-method:hover{border-color:var(--blue-mid);box-shadow:0 8px 32px rgba(26,58,107,.1);transform:translateY(-3px);color:inherit}
.contact-method svg{color:var(--blue-mid);flex-shrink:0}
.contact-method strong{display:block;font-size:1rem;color:var(--blue)}
.contact-method span{font-size:.9rem;color:var(--grey)}

/* FINAL CTA */
.cta-section{background:linear-gradient(135deg,var(--blue) 0%,var(--blue-mid) 100%);padding:100px 0}

@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:40px;text-align:center}
  .hero-ctas{justify-content:center}
  .hero-sub{margin:0 auto 36px}
  .hero-image-wrap{order:-1;max-width:440px;margin:0 auto}
  .fifi-inner{grid-template-columns:1fr;text-align:center}
  .fifi-emoji-wrap{margin:0 auto}
  .fifi-tags{justify-content:center}
}
@media(max-width:600px){
  .hero{min-height:auto;padding:80px 0 60px}
  .contact-methods{flex-direction:column;align-items:stretch}
  .contact-method{min-width:auto}
}
