/* =====================================================================
   BOYLE GLOBAL — Stylesheet
   Brand: deep blue (--primary) + orange (--accent), set in config.php
   ===================================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
    --primary:#0f4c81;--accent:#f7941e;--dark:#0b2239;
    --ink:#1d2939;--muted:#667085;--line:#e6e9ef;--bg:#ffffff;--bg-soft:#f5f7fb;
    --radius:14px;--shadow:0 18px 40px -18px rgba(11,34,57,.28);
    --maxw:1180px;--header-h:84px;
    --font:'Open Sans',system-ui,Segoe UI,Roboto,Arial,sans-serif;
    --head:'Poppins',var(--font);
}
html{scroll-behavior:smooth;scroll-padding-top:var(--header-h)}
body{font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,h5{font-family:var(--head);line-height:1.2;color:var(--dark);font-weight:700}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
[dir="rtl"] body{text-align:right}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--head);font-weight:600;
    font-size:.95rem;padding:.85rem 1.7rem;border-radius:50px;border:2px solid transparent;
    cursor:pointer;transition:.25s ease;letter-spacing:.2px}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 10px 24px -10px rgba(247,148,30,.8)}
.btn-accent:hover{transform:translateY(-3px);box-shadow:0 16px 30px -10px rgba(247,148,30,.9)}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--dark);transform:translateY(-3px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn-ghost:hover{background:#fff;color:var(--primary);border-color:#fff}

/* =====================================================================
   HEADER / NAV
   ===================================================================== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-h);
    display:flex;align-items:center;background:rgba(255,255,255,.0);transition:.3s ease}
.site-header.scrolled{background:#fff;height:70px;box-shadow:0 6px 24px -12px rgba(11,34,57,.25)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;width:100%}
.brand img{height:38px}
.brand .logo-dark{display:none}                       /* dark hero → light logo */
.site-header.scrolled .logo-light{display:none}       /* white header → dark logo */
.site-header.scrolled .logo-dark{display:block}
.main-nav{display:flex;align-items:center;gap:2rem}
.main-nav ul:not(.lang-menu){display:flex;align-items:center;gap:1.6rem;list-style:none}
.main-nav a{font-family:var(--head);font-weight:500;font-size:.93rem;color:#fff;position:relative;padding:.3rem 0;transition:.2s}
.site-header.scrolled .main-nav a{color:var(--ink)}
.main-nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--accent);transition:.25s}
.main-nav a:hover,.main-nav a.active{color:var(--accent)}
.main-nav a:hover::after,.main-nav a.active::after{width:100%}

/* language switcher */
.lang-switch{position:relative}
.lang-current{display:flex;align-items:center;gap:.45rem;background:rgba(255,255,255,.15);
    border:1px solid rgba(255,255,255,.35);color:#fff;padding:.45rem .8rem;border-radius:50px;
    cursor:pointer;font-family:var(--head);font-weight:600;font-size:.85rem;transition:.2s}
.site-header.scrolled .lang-current{background:var(--bg-soft);border-color:var(--line);color:var(--ink)}
.lang-current:hover{border-color:var(--accent)}
.lang-current .flag{font-size:1.05rem;line-height:1}
.lang-current .caret{font-size:.7rem;opacity:.8}
.lang-menu{position:absolute;top:calc(100% + 10px);right:0;min-width:190px;background:#fff;
    border-radius:12px;box-shadow:var(--shadow);list-style:none;padding:.4rem;opacity:0;visibility:hidden;
    transform:translateY(8px);transition:.2s;z-index:120}
[dir="rtl"] .lang-menu{right:auto;left:0}
.lang-switch.open .lang-menu{opacity:1;visibility:visible;transform:translateY(0)}
.lang-menu li a{display:flex;align-items:center;gap:.6rem;padding:.55rem .7rem;border-radius:8px;color:var(--ink);font-size:.9rem;transition:.15s}
.lang-menu li a:hover{background:var(--bg-soft)}
.lang-menu li.is-active a{background:rgba(15,76,129,.08);font-weight:700}
.lang-menu .flag{font-size:1.15rem}
.lang-menu .code{font-weight:700;width:26px;font-family:var(--head)}
.lang-menu .name{color:var(--muted);font-size:.85rem}

/* burger */
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{width:26px;height:2px;background:#fff;border-radius:2px;transition:.3s}
.site-header.scrolled .nav-toggle span{background:var(--ink)}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;
    background-size:cover;background-position:center;color:#fff;text-align:center}
.hero-inner{padding-top:var(--header-h)}
.hero-welcome{font-family:var(--head);text-transform:uppercase;letter-spacing:4px;
    font-weight:600;font-size:.95rem;color:var(--accent);margin-bottom:1.2rem}
.hero-title{font-size:clamp(2.2rem,5.5vw,4.4rem);color:#fff;font-weight:800;max-width:14ch;margin:0 auto 2.2rem;text-shadow:0 4px 30px rgba(0,0,0,.3)}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.scroll-cue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);width:26px;height:42px;
    border:2px solid rgba(255,255,255,.6);border-radius:14px;display:flex;justify-content:center}
.scroll-cue span{width:4px;height:9px;background:#fff;border-radius:4px;margin-top:7px;animation:scroll 1.6s infinite}
@keyframes scroll{0%{opacity:0;transform:translateY(0)}40%{opacity:1}80%{opacity:0;transform:translateY(14px)}}

/* =====================================================================
   SECTIONS / SHARED
   ===================================================================== */
.section{padding:96px 0}
.section-head{text-align:center;margin-bottom:56px}
.section-head.left{text-align:left}
.section-title{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:800}
.title-bar{display:block;width:64px;height:4px;background:var(--accent);border-radius:4px;margin:18px auto 0}
.section-head.left .title-bar{margin-left:0}
.section-sub{margin-top:14px;color:var(--muted);font-style:italic}

/* services */
.services{background:var(--bg-soft)}
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;max-width:920px;margin:0 auto}
.service-card{background:#fff;border-radius:var(--radius);padding:48px 38px;text-align:center;
    box-shadow:var(--shadow);transition:.35s ease;border:1px solid var(--line)}
.service-card:hover{transform:translateY(-8px);border-color:transparent}
.service-icon{width:96px;height:96px;margin:0 auto 26px;border-radius:50%;
    background:linear-gradient(135deg,rgba(15,76,129,.1),rgba(247,148,30,.12));
    display:flex;align-items:center;justify-content:center}
.service-icon img{width:52px;height:52px;object-fit:contain}
.service-card h3{font-size:1.35rem;margin-bottom:14px}
.service-card p{color:var(--muted)}
.services-included{max-width:920px;margin:56px auto 0;background:#fff;border:1px solid var(--line);
    border-radius:var(--radius);padding:44px 46px;box-shadow:var(--shadow)}
.included-title{text-align:center;font-size:1.5rem;margin-bottom:30px;position:relative}
.included-title::after{content:"";display:block;width:54px;height:4px;background:var(--accent);border-radius:4px;margin:14px auto 0}
.included-list{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:14px 28px}
.included-list li{display:flex;align-items:center;gap:12px;font-family:var(--head);font-weight:500;
    font-size:.96rem;color:var(--ink);padding:6px 0}
.included-list .check{flex:0 0 auto;width:24px;height:24px;border-radius:50%;background:rgba(15,76,129,.1);
    color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700}
@media(max-width:880px){.included-list{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.included-list{grid-template-columns:1fr}.services-included{padding:34px 26px}}

/* about */
.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.about-text .lead{color:var(--muted);font-size:1.05rem;margin:0 0 28px}
.about-values{display:flex;flex-direction:column;gap:18px}
.value-card{display:flex;gap:18px;align-items:flex-start;background:var(--bg-soft);
    border-radius:var(--radius);padding:24px 26px;border-left:4px solid var(--accent);transition:.3s}
[dir="rtl"] .value-card{border-left:0;border-right:4px solid var(--accent)}
.value-card:hover{transform:translateX(6px);box-shadow:var(--shadow);background:#fff}
.value-ico{font-size:1.9rem;line-height:1;flex:0 0 auto}
.value-card h4{font-size:1.1rem;margin-bottom:4px;color:var(--primary)}
.value-card p{color:var(--muted);font-size:.95rem;margin:0}

/* testimonials */
.testimonials{background:linear-gradient(160deg,var(--dark),var(--primary));color:#fff}
.testimonials .section-title{color:#fff}
.testi-carousel{position:relative;max-width:820px;margin:0 auto;overflow:hidden}
.testi-track{display:flex;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.testi-card{flex:0 0 100%;padding:10px 24px;text-align:center}
.quote-mark{font-family:var(--head);font-size:5rem;line-height:.6;color:var(--accent);display:block;height:40px}
.testi-card blockquote{font-size:1.15rem;font-style:italic;color:rgba(255,255,255,.92);margin:18px 0 28px;max-width:680px;margin-inline:auto}
.testi-card figcaption{display:flex;align-items:center;justify-content:center;gap:14px}
.testi-card figcaption img{width:60px;height:60px;border-radius:50%;object-fit:cover;border:3px solid var(--accent)}
.testi-card figcaption strong{display:block;font-family:var(--head);font-size:1.05rem}
.testi-card figcaption span{color:rgba(255,255,255,.65);font-size:.85rem}
.carousel-dots{display:flex;gap:10px;justify-content:center;margin-top:30px}
.carousel-dots button{width:10px;height:10px;border-radius:50%;border:0;background:rgba(255,255,255,.35);cursor:pointer;transition:.25s;padding:0}
.carousel-dots button.active{background:var(--accent);width:28px;border-radius:6px}

/* careers */
.careers-scroller{position:relative}
.careers-track{display:flex;gap:26px;overflow-x:auto;scroll-behavior:smooth;padding:10px 4px 24px;scrollbar-width:thin}
.careers-track::-webkit-scrollbar{height:8px}
.careers-track::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}
.job-card{flex:0 0 300px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
    padding:34px 30px;box-shadow:var(--shadow);transition:.3s;display:flex;flex-direction:column}
.job-card:hover{transform:translateY(-8px);border-color:var(--accent)}
.job-icon{width:78px;height:78px;border-radius:16px;overflow:hidden;margin-bottom:22px}
.job-icon img{width:100%;height:100%;object-fit:cover}
.job-card h3{font-size:1.2rem;margin-bottom:12px;min-height:2.4em}
.job-card p{color:var(--muted);font-size:.93rem;flex:1}
.job-apply{margin-top:18px;font-family:var(--head);font-weight:600;color:var(--accent);font-size:.92rem}
.job-apply:hover{color:var(--primary)}
.scroll-arrow{position:absolute;top:38%;z-index:5;width:48px;height:48px;border-radius:50%;border:0;
    background:var(--primary);color:#fff;font-size:1.6rem;cursor:pointer;box-shadow:var(--shadow);transition:.25s;display:flex;align-items:center;justify-content:center}
.scroll-arrow:hover{background:var(--accent)}
.scroll-arrow.left{left:-18px}.scroll-arrow.right{right:-18px}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:stretch}
.contact-info h3{font-size:1.5rem;margin-bottom:18px;color:var(--primary)}
.contact-info>ul{list-style:none;margin-bottom:28px}
.contact-info>ul li{display:flex;gap:12px;margin-bottom:12px;color:var(--muted)}
.contact-info .ico{flex:0 0 auto}
.contact-form .row{display:flex;gap:16px}
.contact-form .row .field{flex:1}
.contact-form .field{margin-bottom:14px}
.contact-form input,.contact-form textarea{width:100%;font-family:var(--font);font-size:.95rem;
    padding:.85rem 1rem;border:1px solid var(--line);border-radius:10px;background:var(--bg-soft);transition:.2s;resize:vertical}
.contact-form input:focus,.contact-form textarea:focus{outline:0;border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px rgba(15,76,129,.08)}
.contact-form input.invalid,.contact-form textarea.invalid{border-color:#e03e3e;background:#fff5f5;box-shadow:0 0 0 4px rgba(224,62,62,.08)}
.field-error{display:block;color:#e03e3e;font-size:.82rem;margin-top:5px;min-height:1px;font-weight:600}
.field-error:empty{display:none}
/* honeypot — invisible to humans, present for bots */
.hp-field{position:absolute!important;left:-9999px!important;top:-9999px!important;width:1px;height:1px;overflow:hidden;opacity:0}
/* captcha */
.captcha-field{background:var(--bg-soft);border:1px dashed var(--line);border-radius:10px;padding:14px 16px;margin-bottom:16px}
.captcha-q{display:block;font-family:var(--head);font-weight:600;font-size:.92rem;color:var(--ink);margin-bottom:10px}
.captcha-q strong{color:var(--primary);font-size:1.05rem;padding:0 4px}
.captcha-field input{max-width:160px;background:#fff}
.g-recaptcha{margin-bottom:14px}
/* status banner */
.form-status{margin-top:14px;padding:0;border-radius:10px;font-weight:600;font-size:.92rem;transition:.2s}
.form-status:empty{display:none}
.form-status.success{padding:14px 16px;background:rgba(22,140,84,.1);color:#157347;border:1px solid rgba(22,140,84,.25)}
.form-status.error{padding:14px 16px;background:rgba(224,62,62,.08);color:#c0392b;border:1px solid rgba(224,62,62,.25)}
.form-submit:disabled{opacity:.7;cursor:not-allowed;transform:none}
.contact-map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);min-height:380px}
.contact-map iframe{width:100%;height:100%;min-height:380px;border:0}

/* =====================================================================
   FOOTER
   ===================================================================== */
.site-footer{background:var(--dark);color:rgba(255,255,255,.78);padding-top:70px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:50px}
.footer-brand img{height:40px;margin-bottom:18px;}
.footer-tag{font-style:italic;color:rgba(255,255,255,.6);max-width:32ch}
.footer-col h4{color:#fff;font-size:1.05rem;margin-bottom:20px;position:relative;padding-bottom:10px}
.footer-col h4::after{content:"";position:absolute;left:0;bottom:0;width:36px;height:3px;background:var(--accent);border-radius:3px}
.footer-contact,.footer-links{list-style:none}
.footer-contact li{display:flex;gap:10px;margin-bottom:12px;font-size:.92rem}
.footer-links li{margin-bottom:10px}
.footer-links a,.footer-contact a{transition:.2s;font-size:.92rem}
.footer-links a:hover,.footer-contact a:hover{color:var(--accent);padding-left:4px}
.social{display:flex;gap:12px;margin-top:18px}
.social a{font-size:.85rem;border:1px solid rgba(255,255,255,.25);padding:.3rem .8rem;border-radius:50px;transition:.2s}
.social a:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:22px 0;text-align:center;font-size:.88rem;color:rgba(255,255,255,.6)}

/* back to top */
.back-to-top{position:fixed;bottom:26px;right:26px;width:46px;height:46px;border-radius:50%;
    background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;
    font-size:1.3rem;box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(14px);transition:.3s;z-index:90}
[dir="rtl"] .back-to-top{right:auto;left:26px}
.back-to-top.show{opacity:1;visibility:visible;transform:translateY(0)}

/* reveal animation — only hidden when JS is available, so no-JS users still see content */
.js [data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.js [data-reveal].in{opacity:1;transform:none;transition-delay:var(--d,0s)}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media(max-width:980px){
    .about-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
    .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
    .nav-toggle{display:flex;z-index:130}
    .site-header{background:#fff;height:70px}
    .brand .logo-light{display:none}
    .brand .logo-dark{display:block}                /* mobile header is always white */
    .site-header .main-nav a{color:var(--ink)}
    .site-header .nav-toggle span{background:var(--ink)}
    .main-nav{position:fixed;inset:0 0 0 auto;width:min(82%,340px);background:#fff;flex-direction:column;
        align-items:flex-start;justify-content:flex-start;padding:90px 32px 32px;gap:1.4rem;
        box-shadow:-12px 0 40px -20px rgba(0,0,0,.4);transform:translateX(110%);transition:.35s ease;overflow-y:auto}
    [dir="rtl"] .main-nav{inset:0 auto 0 0;transform:translateX(-110%);box-shadow:12px 0 40px -20px rgba(0,0,0,.4)}
    .main-nav.open{transform:translateX(0)}
    .main-nav ul:not(.lang-menu){flex-direction:column;align-items:flex-start;gap:1.1rem;width:100%}
    .main-nav a{font-size:1.05rem}
    /* language switcher becomes a clean inline list inside the drawer */
    .lang-switch{width:100%;margin-top:8px;border-top:1px solid var(--line);padding-top:18px}
    .lang-current{display:none}                 /* no toggle on mobile */
    .main-nav .lang-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;
        padding:0;margin:0;min-width:0;display:flex;flex-direction:row;flex-wrap:wrap;gap:10px}
    .lang-menu li{flex:0 0 auto}
    .lang-menu li a{flex-direction:row;gap:.5rem;padding:.55rem .85rem;border:1px solid var(--line);border-radius:50px;background:var(--bg-soft)}
    .lang-menu li a:hover{background:#fff;border-color:var(--accent)}
    .lang-menu li.is-active a{background:rgba(15,76,129,.08);border-color:var(--primary)}
    .lang-menu .name{display:none}              /* compact: flag + code only */
    .lang-menu .code{width:auto}
    .services-grid{grid-template-columns:1fr}
    .footer-grid{grid-template-columns:1fr}
    .contact-form .row{flex-direction:column}
    .scroll-arrow{display:none}
    .section{padding:70px 0}
}
