/* ===== Worldwide Security Services — Theme (dark default + light toggle) =====
   Single brand color = logo green #207026 used for glows, borders, gradient
   fills, badges and buttons. Theme flips via html[data-theme="light"]. */
:root{
    /* brand green (constant in both themes) */
    --acc:#207026;
    --acc-light:#2c9a36;
    --acc-dark:#0d3315;
    --on-acc:#ffffff;            /* text on green fills */
    --grad:linear-gradient(135deg,#2c9a36 0%,#207026 100%);
    --grad-deep:linear-gradient(135deg,#0d3315 0%,#207026 60%,#2c9a36 100%);
    --glow-1:rgba(32,112,38,.40);
    --glow-2:rgba(32,112,38,.30);

    /* legacy names mapped to the brand green */
    --navy:#207026; --navy-2:#207026; --navy-3:#2c9a36;
    --gold:#3aa84a;              /* accent text/icons (theme-aware) */
    --gold-2:#2c9a36;

    /* DARK theme surfaces (default) */
    --bg:#0a0d09;
    --bg-2:#0e130c;
    --bg-soft:#141a12;           /* cards */
    --surface-2:#1b2417;         /* hover/raised */
    --field-bg:#0d1209;
    --header-bg:rgba(10,13,9,.82);
    --footer-bg:#070907;
    --stat-grad:linear-gradient(135deg,#172012,#0e130c);
    --line:#243021;
    --ink:#bac6b5;
    --muted:#828f7d;
    --head:#ffffff;

    --white:#fff;
    --radius:16px;
    --shadow:0 28px 60px -28px rgba(0,0,0,.8);
    --shadow-sm:0 14px 34px -20px rgba(0,0,0,.7);
    --maxw:1180px;
    --band:linear-gradient(180deg,#0e130c 0%,#0a0d09 100%);
}
html[data-theme="light"]{
    --gold:#207026;             /* logo green reads on white */
    --gold-2:#2c9a36;
    --bg:#f3f9f5;
    --bg-2:#e9f5f0;
    --bg-soft:#ffffff;
    --surface-2:#ffffff;
    --field-bg:#ffffff;
    --header-bg:rgba(255,255,255,.88);
    --footer-bg:#e9f5f0;
    --stat-grad:linear-gradient(135deg,#ffffff,#f1f9f4);
    --line:#d8e6dc;
    --ink:#1b2a21;
    --muted:#5b6c61;
    --head:#0d3315;
    --shadow:0 26px 56px -32px rgba(13,77,34,.30);
    --shadow-sm:0 14px 32px -22px rgba(13,77,34,.20);
    --band:linear-gradient(180deg,#ffffff 0%,#e9f5f0 100%);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
    font-family:'Inter',system-ui,sans-serif;
    color:var(--ink);
    background:
        radial-gradient(900px circle at 6% -4%,rgba(32,112,38,.16),transparent 45%),
        radial-gradient(820px circle at 100% 6%,rgba(44,154,54,.10),transparent 42%),
        radial-gradient(1000px circle at 50% 120%,rgba(32,112,38,.14),transparent 55%),
        var(--bg);
    background-attachment:fixed;
    line-height:1.65;
    -webkit-font-smoothing:antialiased;
    transition:background-color .3s,color .3s;
}
h1,h2,h3,h4{font-family:'Plus Jakarta Sans',sans-serif;line-height:1.2;color:var(--head)}
/* Indic script fonts when Hindi / Kannada is active */
html[lang="hi"] body,html[lang="hi"] h1,html[lang="hi"] h2,html[lang="hi"] h3,html[lang="hi"] h4,
html[lang="hi"] .btn,html[lang="hi"] .brand-name,html[lang="hi"] input,html[lang="hi"] textarea,html[lang="hi"] select{
    font-family:'Noto Sans Devanagari','Inter',system-ui,sans-serif}
html[lang="kn"] body,html[lang="kn"] h1,html[lang="kn"] h2,html[lang="kn"] h3,html[lang="kn"] h4,
html[lang="kn"] .btn,html[lang="kn"] .brand-name,html[lang="kn"] input,html[lang="kn"] textarea,html[lang="kn"] select{
    font-family:'Noto Sans Kannada','Inter',system-ui,sans-serif}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ===== Buttons ===== */
.btn{
    display:inline-flex;align-items:center;gap:8px;
    padding:14px 28px;border-radius:50px;font-weight:700;font-size:.95rem;
    font-family:'Plus Jakarta Sans',sans-serif;cursor:pointer;border:2px solid transparent;
    transition:.25s ease;white-space:nowrap;
}
.btn-primary{background:var(--grad);color:var(--on-acc);box-shadow:0 14px 32px -12px rgba(32,112,38,.55)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -12px rgba(32,112,38,.7)}
.btn-ghost{border-color:var(--acc);color:var(--gold)}
.btn-ghost:hover{background:var(--acc);color:var(--on-acc)}
.btn-ghost-light{border-color:rgba(255,255,255,.4);color:#fff}
.btn-ghost-light:hover{background:rgba(255,255,255,.14)}

/* ===== Inline Hugeicons ===== */
svg{vertical-align:middle}
.btn svg{flex:none}
.fc-line{display:flex;align-items:flex-start;gap:9px}
.fc-line svg{width:18px;height:18px;color:var(--gold);flex:none;margin-top:3px}
.footer-social{display:flex;gap:10px;margin-top:18px}
.footer-social a{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;
    display:flex;align-items:center;justify-content:center;color:var(--muted);transition:.25s}
.footer-social a:hover{color:var(--on-acc);background:var(--acc);border-color:var(--acc)}
.footer-social svg{width:18px;height:18px}
.svc-link{display:inline-flex;align-items:center;gap:6px}
.svc-link svg{transition:transform .2s}
.svc-link:hover svg{transform:translateX(3px)}
.whatsapp-float svg{width:28px;height:28px}

/* ===== Topbar ===== */
.topbar{background:var(--bg-2);color:var(--muted);font-size:.82rem;border-bottom:1px solid var(--line)}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;height:40px}
.topbar a{color:var(--muted);transition:.2s}
.topbar a:hover{color:var(--gold)}
.topbar .sep{margin:0 10px;opacity:.4}
.topbar-social a{margin-left:16px}

/* ===== Header ===== */
.site-header{
    position:sticky;top:0;z-index:50;
    background:var(--header-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
    border-bottom:1px solid var(--line);transition:.3s;
}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.site-header .container{max-width:1360px}
.header-inner{display:flex;align-items:center;gap:14px;height:74px}
.brand{display:flex;align-items:center;gap:11px;margin-right:auto;flex:none;min-width:0}
.brand-logo{width:46px;height:46px;object-fit:contain;flex:none;display:block;
    filter:drop-shadow(0 0 12px rgba(32,112,38,.4))}
.brand-logo--footer{width:60px;height:60px}
.brand-badge{
    width:46px;height:46px;border-radius:12px;flex:none;
    background:var(--grad);
    color:var(--on-acc);font-family:'Plus Jakarta Sans';font-weight:800;
    display:flex;align-items:center;justify-content:center;font-size:1rem;letter-spacing:.5px;
}
.brand-text{display:flex;flex-direction:column;line-height:1.18;min-width:0}
.brand-name{font-family:'Plus Jakarta Sans';font-weight:800;font-size:.98rem;color:var(--head);white-space:nowrap}
.brand-sub{font-size:.68rem;color:var(--muted);letter-spacing:.2px;white-space:nowrap}

.main-nav{display:flex;align-items:center;gap:18px}
.main-nav a{font-weight:600;font-size:.9rem;color:var(--ink);position:relative;transition:.2s}
.main-nav a:not(.nav-cta):hover,.main-nav a.active{color:var(--gold)}
.main-nav a:not(.nav-cta)::after{
    content:'';position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--acc);transition:.25s;
}
.main-nav a:not(.nav-cta):hover::after,.main-nav a.active::after{width:100%}
.nav-cta{background:var(--grad);color:var(--on-acc)!important;padding:9px 18px;border-radius:50px;font-weight:700}
.nav-cta:hover{filter:brightness(1.08);transform:translateY(-1px)}

/* ===== Header tools (theme + language) ===== */
.header-tools{display:flex;align-items:center;gap:8px;flex:none}
.theme-toggle{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);
    background:var(--bg-soft);color:var(--gold);display:flex;align-items:center;justify-content:center;
    cursor:pointer;transition:.25s;flex:none}
.theme-toggle:hover{border-color:var(--acc);color:var(--acc-light);transform:translateY(-1px)}
.theme-toggle svg{width:18px;height:18px}
.theme-toggle .ic-sun{display:none}
html[data-theme="light"] .theme-toggle .ic-sun{display:block}
html[data-theme="light"] .theme-toggle .ic-moon{display:none}
.lang-select{position:relative}
.lang-btn{display:inline-flex;align-items:center;gap:6px;height:38px;padding:0 12px;border-radius:50px;
    border:1px solid var(--line);background:var(--bg-soft);color:var(--ink);font-weight:700;font-size:.8rem;
    font-family:'Plus Jakarta Sans',sans-serif;cursor:pointer;transition:.25s}
.lang-btn:hover{border-color:var(--acc);color:var(--gold)}
.lang-btn svg{width:16px;height:16px;color:var(--gold)}
.lang-btn .chev{width:12px;height:12px;transition:transform .25s}
.lang-select.open .lang-btn .chev{transform:rotate(180deg)}
.lang-menu{position:absolute;right:0;top:50px;min-width:150px;background:var(--bg-soft);
    border:1px solid var(--line);border-radius:14px;padding:6px;box-shadow:var(--shadow);
    opacity:0;visibility:hidden;transform:translateY(-8px);transition:.22s;z-index:70}
.lang-select.open .lang-menu{opacity:1;visibility:visible;transform:none}
.lang-menu{min-width:172px}
.lang-menu a{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;
    border-radius:10px;color:var(--ink);font-size:.92rem;font-weight:600;transition:.18s}
.lang-menu a .ln-name{flex:1}
.lang-menu a:hover{background:var(--bg-2);color:var(--gold)}
.lang-code{font-size:.66rem;font-weight:800;letter-spacing:.5px;padding:3px 8px;border-radius:50px;
    background:var(--bg-2);border:1px solid var(--line);color:var(--muted);transition:.18s}
.lang-menu a:hover .lang-code{color:var(--gold);border-color:var(--acc)}
.lang-menu a.active{color:var(--acc-light);background:rgba(32,112,38,.10)}
.lang-menu a.active .lang-code{background:var(--grad);color:var(--on-acc);border-color:transparent}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;z-index:80}
.nav-toggle span{width:26px;height:3px;background:var(--head);border-radius:3px;transition:.3s}
.nav-toggle.open span{background:var(--acc-light)}
.nav-toggle.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* Sidebar backdrop */
.nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);
    opacity:0;visibility:hidden;transition:.3s;z-index:45}
.nav-overlay.open{opacity:1;visibility:visible}

/* ===== Hero ===== */
.hero{position:relative;color:var(--ink);background:var(--bg);overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;z-index:0;
    background:radial-gradient(820px circle at 80% 42%,var(--glow-1),transparent 55%),
               radial-gradient(620px circle at 18% 92%,var(--glow-2),transparent 55%)}
.hero::after{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
    background-image:linear-gradient(rgba(127,127,127,.06) 1px,transparent 1px),
                     linear-gradient(90deg,rgba(127,127,127,.06) 1px,transparent 1px);
    background-size:48px 48px;
    -webkit-mask-image:radial-gradient(circle at 60% 40%,#000,transparent 75%);
    mask-image:radial-gradient(circle at 60% 40%,#000,transparent 75%)}
.hero-inner{position:relative;z-index:2;padding:96px 24px 110px;
    display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.hero-content{max-width:640px}

.hero-visual{display:flex;justify-content:center;align-items:center;perspective:1200px}
.hero-logo-stage{position:relative;transform-style:preserve-3d;animation:heroFloat 6s ease-in-out infinite}
.hero-logo-stage::after{content:'';position:absolute;inset:-18% -12% auto -12%;height:96%;z-index:-1;
    background:radial-gradient(circle,rgba(44,154,54,.5),rgba(32,112,38,.28) 45%,transparent 70%);filter:blur(38px)}
.hero-logo-3d{width:min(420px,80%);max-width:100%;display:block;margin:0 auto;
    transform-style:preserve-3d;will-change:transform;
    transition:transform .15s ease-out;filter:drop-shadow(0 18px 40px rgba(0,0,0,.45))}
@keyframes heroFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
.hero-eyebrow{
    display:inline-flex;align-items:center;gap:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
    font-size:.78rem;color:var(--gold);margin-bottom:18px;
    border:1px solid var(--line);padding:8px 18px;border-radius:50px;background:var(--bg-soft)}
.hero-title{font-size:clamp(2.2rem,5.5vw,4rem);color:var(--head);font-weight:800;letter-spacing:-1px}
.hero-title .accent{background:var(--grad);-webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;color:var(--acc-light)}
.hero-text{font-size:1.1rem;color:var(--muted);margin:24px 0 34px;max-width:600px}
.hero-text strong{color:var(--head)}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:38px}
.hero-badges{display:flex;gap:22px;flex-wrap:wrap;font-size:.9rem;color:var(--muted);font-weight:500}

/* ===== Stats ===== */
.stats{background:transparent;position:relative;z-index:3;margin-top:-50px}
.stats-grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
    background:var(--stat-grad);overflow:hidden;
    border:1px solid var(--line);border-radius:var(--radius);
    padding:38px;box-shadow:var(--shadow);transform:translateY(-50px)}
.stats-grid::before{content:'';position:absolute;left:0;top:0;width:100%;height:5px;background:var(--grad)}
.stat{text-align:center;color:var(--ink);border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat-value{font-family:'Plus Jakarta Sans';font-weight:800;font-size:2.6rem;color:var(--gold)}
.stat-label{font-size:.9rem;color:var(--muted);margin-top:4px}

/* ===== Sections ===== */
.section{padding:90px 0}
.section-head{text-align:center;max-width:680px;margin:0 auto 56px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
    font-size:.76rem;color:var(--gold);margin-bottom:14px;
    border:1px solid var(--line);padding:7px 16px;border-radius:50px;background:var(--bg-soft)}
.section-title{font-size:clamp(1.7rem,3.5vw,2.5rem);font-weight:800;letter-spacing:-.5px;color:var(--head)}
.section-head .section-title{display:block}
.section-head .section-title::after{content:'';display:block;width:64px;height:4px;border-radius:4px;
    margin:18px auto 0;background:var(--grad)}
.section-sub{color:var(--muted);margin-top:14px;font-size:1.05rem}
.section-head--light .eyebrow{color:var(--gold)}
.section-head--light .section-title{color:var(--head)}
.section-head--light .section-sub{color:var(--muted)}

/* ===== About ===== */
.about{background:transparent}
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center}
.about-media{display:flex;flex-direction:column;gap:22px}
.about-card{padding:30px;border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--line);background:var(--bg-soft)}
.about-card h4{color:var(--gold);font-size:1.15rem;margin-bottom:10px}
.about-card p{color:var(--muted)}
.about-content p{color:var(--muted);margin-bottom:16px}
.about-points{list-style:none;margin-top:22px;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.about-points li{position:relative;padding-left:28px;font-weight:600;color:var(--ink);font-size:.95rem}
.about-points li::before{content:'\2713';position:absolute;left:0;top:0;color:var(--gold);
    font-weight:800;background:rgba(32,112,38,.16);width:20px;height:20px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;font-size:.7rem}

/* ===== Services ===== */
.services{background:var(--band)}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.service-card{background:var(--bg-soft);border-radius:var(--radius);padding:34px 26px;border:1px solid var(--line);
    transition:.3s;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}
.service-card::before{content:'';position:absolute;left:0;top:0;height:4px;width:100%;
    background:var(--grad);transform:scaleX(0);transform-origin:left;transition:.3s}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:var(--acc);background:var(--surface-2)}
.service-card:hover::before{transform:scaleX(1)}
.service-num{font-family:'Plus Jakarta Sans';font-weight:800;font-size:1.6rem;color:var(--gold);opacity:.8;margin-bottom:14px}
.service-card h3{font-size:1.2rem;margin-bottom:12px;color:var(--head)}
.service-card p{color:var(--muted);font-size:.92rem;margin-bottom:18px}
.service-tags{display:flex;flex-wrap:wrap;gap:8px}
.service-tags span{font-size:.72rem;font-weight:600;color:var(--gold);
    background:rgba(32,112,38,.12);border:1px solid var(--line);padding:5px 11px;border-radius:50px}

/* ===== Why ===== */
.why{background:transparent}
.why-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.why-card{background:var(--bg-soft);border:1px solid var(--line);box-shadow:var(--shadow-sm);
    border-radius:var(--radius);padding:28px 22px;transition:.3s}
.why-card:hover{background:var(--surface-2);border-color:var(--acc);transform:translateY(-6px);box-shadow:var(--shadow)}
.why-num{font-family:'Plus Jakarta Sans';font-weight:800;font-size:1.5rem;color:var(--gold);display:block;margin-bottom:14px}
.why-card h4{color:var(--head);font-size:1.02rem;margin-bottom:10px}
.why-card p{color:var(--muted);font-size:.86rem}

/* ===== R&D ===== */
.rnd{background:var(--band)}
.rnd-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:54px;align-items:center}
.rnd-content p{color:var(--muted);margin-top:14px}
.rnd-list{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.rnd-item{background:var(--bg-soft);border-radius:var(--radius);padding:24px;border-left:4px solid var(--acc);
    box-shadow:var(--shadow-sm);transition:.3s}
.rnd-item:hover{transform:translateY(-4px);box-shadow:var(--shadow);background:var(--surface-2)}
.rnd-item h4{font-size:1.05rem;margin-bottom:8px;color:var(--head)}
.rnd-item p{color:var(--muted);font-size:.88rem}

/* ===== Presence ===== */
.presence{background:transparent}
.cities{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}
.city-chip{display:flex;align-items:center;gap:10px;background:var(--bg-soft);border:1px solid var(--line);
    padding:16px 28px;border-radius:50px;font-weight:700;color:var(--head);box-shadow:var(--shadow-sm);
    font-family:'Plus Jakarta Sans';transition:.3s}
.city-chip:hover{background:var(--grad);color:var(--on-acc);transform:translateY(-4px);border-color:transparent}
.city-chip span{font-size:1.1rem}

/* ===== CTA ===== */
.cta{position:relative;background:var(--grad-deep);padding:64px 0;overflow:hidden;
    border-top:1px solid var(--acc);border-bottom:1px solid var(--acc)}
.cta::before{content:'';position:absolute;inset:0;
    background:radial-gradient(600px circle at 90% 16%,rgba(44,154,54,.45),transparent 55%),
               radial-gradient(500px circle at 2% 110%,rgba(32,112,38,.4),transparent 55%)}
.cta-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.cta-text h2{color:#fff;font-size:1.9rem}
.cta-text p{color:#d6f0d2;font-weight:500;margin-top:6px}
.cta-actions{display:flex;gap:14px;flex-wrap:wrap}
.cta .btn-primary{background:#fff;color:var(--acc);box-shadow:0 14px 30px -14px rgba(0,0,0,.5)}
.cta .btn-primary:hover{background:#eafff0}
.cta .btn-ghost-light{border-color:rgba(255,255,255,.8);color:#fff}
.cta .btn-ghost-light:hover{background:rgba(255,255,255,.15)}

/* ===== Footer ===== */
.site-footer{position:relative;background:var(--footer-bg);
    color:var(--muted);padding-top:60px;border-top:1px solid var(--line)}
.site-footer::before{content:'';position:absolute;left:0;top:0;width:100%;height:4px;background:var(--grad)}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1.4fr;gap:48px;padding-bottom:40px;align-items:start}
.brand--footer .brand-name{color:var(--head)}
.brand--footer .brand-sub{color:var(--muted)}
.footer-tagline{color:var(--gold);font-style:italic;margin:18px 0 12px;font-weight:500}
.footer-note{font-size:.9rem;color:var(--muted)}
.footer-col h4{color:var(--head);font-size:1.05rem;margin-bottom:18px}
.footer-links{list-style:none}
.footer-links li{margin-bottom:10px}
.footer-links a{color:var(--muted);font-size:.92rem;transition:.2s}
.footer-links a:hover{color:var(--gold);padding-left:4px}
.fc-line{font-size:.9rem;margin-bottom:12px;color:var(--muted)}
.fc-line a{color:var(--muted);transition:.2s}
.fc-line a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid var(--line);padding:22px 0}
.footer-bottom-inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:.85rem;color:var(--muted)}

/* ===== Page banner (sub-pages) ===== */
.page-banner{position:relative;overflow:hidden;border-bottom:1px solid var(--line);background:var(--bg)}
.page-banner::before{content:'';position:absolute;inset:0;
    background:radial-gradient(620px circle at 90% 4%,var(--glow-1),transparent 55%),
               radial-gradient(560px circle at 0% 120%,var(--glow-2),transparent 55%)}
.page-banner::after{content:'';position:absolute;inset:0;pointer-events:none;
    background-image:linear-gradient(rgba(127,127,127,.06) 1px,transparent 1px),
                     linear-gradient(90deg,rgba(127,127,127,.06) 1px,transparent 1px);
    background-size:46px 46px;
    -webkit-mask-image:radial-gradient(circle at 75% 30%,#000,transparent 78%);
    mask-image:radial-gradient(circle at 75% 30%,#000,transparent 78%)}
.page-banner-inner{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:30px;padding:66px 24px}
.page-banner-text{max-width:680px}
.page-banner-eyebrow{display:inline-flex;align-items:center;gap:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;font-size:.76rem;
    color:var(--gold);background:var(--bg-soft);border:1px solid var(--line);padding:8px 18px;border-radius:50px}
.page-banner-title{font-size:clamp(2rem,5vw,3.2rem);color:var(--head);font-weight:800;margin:16px 0 12px;letter-spacing:-.5px}
.page-banner-crumb{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:.92rem;font-weight:500}
.page-banner-crumb a{color:var(--gold);transition:.2s}
.page-banner-crumb a:hover{color:var(--head)}
.page-banner-crumb span{opacity:.5}
.page-banner-logo{flex:none;width:128px;height:128px;object-fit:contain;padding:16px;border-radius:26px;
    background:radial-gradient(circle,rgba(32,112,38,.2),rgba(32,112,38,0) 70%);
    filter:drop-shadow(0 0 26px rgba(44,154,54,.5)) drop-shadow(0 12px 26px rgba(0,0,0,.4))}
@media(max-width:680px){
    .page-banner-inner{flex-direction:column-reverse;text-align:center;padding:48px 24px;gap:18px}
    .page-banner-crumb{justify-content:center}
    .page-banner-logo{width:96px;height:96px}
}

/* ===== About intro ===== */
.about-intro-grid{display:grid;grid-template-columns:.9fr 1.3fr;gap:56px;align-items:center}
.about-intro-text .lead{font-size:1.2rem;color:var(--ink);margin-bottom:18px}
.about-intro-text p{color:var(--muted);margin-bottom:16px}
.about-badge-stack{display:flex;flex-direction:column;gap:14px;margin-top:24px}
.ab-badge{display:flex;align-items:baseline;gap:12px;
    background:linear-gradient(145deg,#15401d,#0c2713);
    border:1px solid rgba(60,181,71,.25);border-left:4px solid var(--acc-light);
    border-radius:12px;padding:16px 20px;box-shadow:0 12px 26px -18px rgba(0,0,0,.6)}
.ab-badge strong{font-family:'Plus Jakarta Sans';font-size:1.5rem;color:#ffffff;line-height:1}
.ab-badge span{color:rgba(255,255,255,.74);font-weight:600;font-size:.92rem}

/* ===== Vision / Mission ===== */
.vm{background:transparent;position:relative;overflow:hidden}
.vm::before{content:'';position:absolute;width:480px;height:480px;border-radius:50%;
    background:radial-gradient(circle,rgba(32,112,38,.16),transparent 70%);top:-160px;right:-120px}
.vm-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;perspective:1400px}
.vm-card{position:relative;background:var(--bg-soft);border:1px solid var(--line);
    border-radius:var(--radius);padding:44px 36px;transition:transform .45s cubic-bezier(.2,.7,.2,1),box-shadow .45s,border-color .45s;
    transform-style:preserve-3d;overflow:hidden;box-shadow:var(--shadow-sm)}
.vm-card::after{content:'';position:absolute;inset:0;border-radius:var(--radius);
    background:linear-gradient(135deg,rgba(32,112,38,.14),transparent 45%);opacity:0;transition:.45s}
.vm-card:hover{transform:translateY(-8px);border-color:var(--acc);box-shadow:var(--shadow)}
.vm-card:hover::after{opacity:1}
.vm-icon{position:relative;width:84px;height:84px;border-radius:20px;display:flex;align-items:center;justify-content:center;
    font-size:2.2rem;margin-bottom:24px;
    background:linear-gradient(145deg,#3bb547,var(--acc) 55%,#0d3315);
    box-shadow:0 16px 30px -16px rgba(32,112,38,.55)}
.vm-icon::before{content:'';position:absolute;inset:6px;border-radius:14px;
    background:linear-gradient(160deg,rgba(255,255,255,.35),transparent 60%);pointer-events:none}
.vm-card h3{color:var(--head);font-size:1.5rem;margin-bottom:14px;transform:translateZ(20px)}
.vm-quote{color:var(--gold);font-style:italic;font-size:1.06rem;margin-bottom:16px;line-height:1.5}
.vm-card p{color:var(--muted);font-size:.94rem}

/* ===== About: certificates / team photo grids ===== */
.about-photos{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:8px}
.ph-card{background:var(--bg-soft);border:1px solid var(--line);border-radius:16px;overflow:hidden;
    transition:border-color .25s,transform .25s,box-shadow .25s}
.ph-card:hover{border-color:var(--acc);transform:translateY(-4px);box-shadow:var(--shadow)}
.ph-thumb{position:relative;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;
    background:linear-gradient(145deg,rgba(32,112,38,.14),transparent);overflow:hidden}
.ph-thumb.team-thumb{aspect-ratio:1/1}
.ph-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ph-fallback{color:var(--acc);opacity:.55}
.ph-meta{padding:14px 16px;text-align:center}
.ph-meta strong{display:block;color:var(--head);font-size:1rem}
.ph-meta span{display:block;color:var(--muted);font-size:.83rem;margin-top:3px}
.ph-card.ph-hidden{display:none}
.about-photos.show-all .ph-card.ph-hidden{display:block}
.section-cta{text-align:center;margin-top:36px}
.ga-noimg{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--acc);opacity:.5}

/* about page heading (eyebrow + headline + subtitle) */
.page-hero{position:relative;overflow:hidden;padding:72px 0 8px}
.page-hero::before{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
    background:
        radial-gradient(circle at 88% 18%,rgba(60,181,71,.12),transparent 42%),
        linear-gradient(180deg,rgba(32,112,38,.06),transparent 65%)}
.page-hero::after{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
    background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
    background-size:46px 46px;-webkit-mask-image:linear-gradient(180deg,#000,transparent 70%);mask-image:linear-gradient(180deg,#000,transparent 70%)}
.page-hero .container{position:relative;z-index:1}
.page-hero-eyebrow{margin-bottom:18px}
.page-hero-title{font-size:clamp(2.2rem,5vw,3.4rem);font-weight:800;color:var(--head);letter-spacing:-.5px;line-height:1.12}
.page-hero-title::after{content:'';display:block;width:72px;height:4px;border-radius:4px;background:var(--grad);margin-top:22px}
.page-hero-sub{margin-top:20px;max-width:640px;color:var(--muted);font-size:1.14rem;line-height:1.6}
.page-hero + .section{padding-top:52px}
.page-hero + .about-intro{padding-top:38px}
.page-hero + .svc-section{padding-top:54px}

/* services hero (full-width) */
.svc-hero{padding:64px 0 56px}
.svc-hero .page-hero-sub{max-width:760px}
.svc-hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
@media(max-width:860px){.svc-hero{padding:54px 0 46px}}

/* ===== Reviews page ===== */
.review-single{max-width:720px;margin:0 auto}
.review-grid{display:grid;grid-template-columns:1.25fr .9fr;gap:44px;align-items:start}
.review-form-wrap{background:var(--bg-soft);border:1px solid var(--line);border-radius:18px;padding:30px 30px 32px;box-shadow:var(--shadow-sm)}
.review-form-title{font-size:1.4rem;color:var(--head);margin-bottom:20px}
.review-success{display:flex;align-items:center;gap:9px;background:rgba(32,112,38,.12);border:1px solid rgba(32,112,38,.35);color:var(--acc);border-radius:12px;padding:14px 16px;margin-bottom:20px;font-weight:600}
.star-input{display:inline-flex;gap:6px;margin-top:4px}
.star-input .star{background:none;border:0;cursor:pointer;font-size:2rem;line-height:1;color:var(--line);padding:0;transition:color .15s,transform .15s}
.star-input .star:hover{transform:scale(1.12)}
.star-input .star.on{color:#f5b301}
.review-list-title{font-size:1.2rem;color:var(--head);margin-bottom:18px}
.review-card{background:var(--bg-soft);border:1px solid var(--line);border-radius:16px;padding:20px;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.review-stars{color:#f5b301;font-size:1.05rem;letter-spacing:2px;margin-bottom:8px}
.review-msg{color:var(--ink);font-size:.95rem;line-height:1.55;margin-bottom:14px}
.review-by{display:flex;align-items:center;gap:11px}
.review-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(145deg,#3bb547,var(--acc));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;flex:none}
.review-by strong{display:block;color:var(--head);font-size:.92rem}
.review-by small{color:var(--muted);font-size:.8rem}
.review-empty{color:var(--muted);font-style:italic}
@media(max-width:880px){.review-grid{grid-template-columns:1fr;gap:32px}}

/* reviews — admin */
.rv-stars{color:#f5b301;letter-spacing:2px;white-space:nowrap}
.rv-badge{display:inline-block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:3px 9px;border-radius:20px;background:rgba(128,128,128,.18);color:var(--muted)}
.rv-badge.on{background:rgba(32,112,38,.16);color:var(--acc)}

/* about intro strengths checklist */
.about-checklist{list-style:none;margin:24px 0 0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:14px 26px}
.about-checklist li{display:flex;align-items:flex-start;gap:11px;color:var(--ink);font-weight:500;font-size:.96rem;line-height:1.4}
.about-checklist .chk{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;
    background:rgba(60,181,71,.16);color:var(--acc-light);flex:none;margin-top:1px}
@media(max-width:600px){.about-checklist{grid-template-columns:1fr}}
@media(max-width:900px){.about-photos{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.about-photos{grid-template-columns:1fr}}

/* ===== Registrations ===== */
.regs{background:var(--band);position:relative}
.reg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;perspective:1200px}
.reg-card{position:relative;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:32px 22px;
    text-align:center;transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s,border-color .4s,opacity .55s ease;
    display:flex;flex-direction:column;align-items:center;gap:14px;box-shadow:var(--shadow-sm)}
.reg-card:hover{transform:translateY(-8px);border-color:var(--acc);box-shadow:var(--shadow);background:var(--surface-2)}
.reg-abbr{position:relative;width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;
    font-family:'Plus Jakarta Sans';font-weight:800;font-size:1rem;color:var(--on-acc);
    background:linear-gradient(145deg,#3bb547,var(--acc) 50%,#0d3315);
    box-shadow:0 14px 26px -14px rgba(32,112,38,.55)}
.reg-abbr::after{content:'';position:absolute;inset:5px;border-radius:50%;border:1px dashed rgba(255,255,255,.45)}
.reg-name{font-weight:700;color:var(--ink);font-size:.92rem}

/* ===== Services page ===== */
.svc-section{background:transparent}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.svc-card{position:relative;background:var(--bg-soft);border:1px solid var(--line);border-radius:20px;
    padding:38px 30px;text-align:center;overflow:hidden;box-shadow:var(--shadow-sm);
    transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s,border-color .4s,opacity .6s ease}
.svc-card::before{content:'';position:absolute;left:0;top:0;width:100%;height:5px;
    background:var(--grad);transform:scaleX(0);transform-origin:left;transition:.35s}
.svc-card:hover{transform:translateY(-10px);border-color:var(--acc);box-shadow:var(--shadow);background:var(--surface-2)}
.svc-card:hover::before{transform:scaleX(1)}
.svc-icon{width:120px;height:120px;margin:0 auto 22px;display:flex;align-items:center;justify-content:center;
    border-radius:26px;background:var(--field-bg);border:1px solid var(--line);transition:.45s}
.svc-icon img{width:80px;height:80px;object-fit:contain;transition:transform .45s ease}
.svc-card:hover .svc-icon{transform:translateY(-4px);border-color:var(--acc)}
.svc-card:hover .svc-icon img{transform:scale(1.12) translateY(-4px)}
.svc-card h3{font-size:1.18rem;margin-bottom:10px;color:var(--head)}
.svc-card p{color:var(--muted);font-size:.92rem;margin-bottom:18px}
.svc-link{font-weight:700;color:var(--gold);font-size:.9rem;font-family:'Plus Jakarta Sans';transition:.2s}
.svc-link:hover{color:var(--head);letter-spacing:.3px}

.svc-card{opacity:0;transform:translateY(36px)}
.svc-section.in .svc-card{opacity:1;transform:translateY(0)}
.svc-section.in .svc-card:nth-child(1){transition-delay:.05s}
.svc-section.in .svc-card:nth-child(2){transition-delay:.12s}
.svc-section.in .svc-card:nth-child(3){transition-delay:.19s}
.svc-section.in .svc-card:nth-child(4){transition-delay:.26s}
.svc-section.in .svc-card:nth-child(5){transition-delay:.33s}
.svc-section.in .svc-card:nth-child(6){transition-delay:.40s}
.svc-section.in .svc-card:nth-child(7){transition-delay:.47s}
.svc-section.in .svc-card:nth-child(8){transition-delay:.54s}
.svc-section.in .svc-card:nth-child(9){transition-delay:.61s}

/* ===== GST bar ===== */
.gst-bar{margin:36px auto 0;max-width:360px;display:flex;align-items:center;justify-content:center;gap:14px;
    background:var(--grad);color:var(--on-acc);border-radius:50px;padding:14px 28px;
    box-shadow:0 16px 30px -18px rgba(32,112,38,.55)}
.gst-label{font-size:.8rem;letter-spacing:1px;text-transform:uppercase;color:#dff0d4;font-weight:700}
.gst-no{font-family:'Plus Jakarta Sans';font-weight:800;font-size:1.1rem;letter-spacing:1px;color:var(--on-acc)}

/* ===== Contact page ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:50px;align-items:start}
.contact-lead{color:var(--muted);margin:14px 0 24px}
.info-card{display:flex;align-items:flex-start;gap:16px;background:var(--bg-soft);border:1px solid var(--line);
    border-radius:14px;padding:18px 20px;margin-bottom:14px;transition:border-color .3s,transform .3s,box-shadow .3s;color:var(--ink);box-shadow:var(--shadow-sm)}
.info-card:hover{border-color:var(--acc);transform:translateX(4px);box-shadow:var(--shadow)}
.info-ic{width:46px;height:46px;flex:none;border-radius:12px;background:var(--grad);color:var(--on-acc);
    display:flex;align-items:center;justify-content:center}
.info-txt{display:flex;flex-direction:column;gap:2px}
.info-txt strong{color:var(--head);font-family:'Plus Jakarta Sans';font-size:.98rem}
.info-txt span{color:var(--muted);font-size:.9rem;line-height:1.45}
.contact-social{display:flex;gap:10px;margin-top:22px}
.contact-social a{width:42px;height:42px;border:1px solid var(--line);border-radius:50%;color:var(--ink);
    display:flex;align-items:center;justify-content:center;transition:.25s}
.contact-social a:hover{background:var(--grad);color:var(--on-acc);border-color:transparent}
.contact-social svg{width:19px;height:19px}

.contact-form-wrap{position:relative}
.contact-form{background:var(--bg-soft);border:1px solid var(--line);border-radius:18px;padding:34px;box-shadow:var(--shadow-sm)}
.contact-form h3{font-size:1.3rem;margin-bottom:20px;color:var(--head)}
.field{margin-bottom:16px;display:flex;flex-direction:column}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{font-weight:600;font-size:.85rem;color:var(--head);margin-bottom:6px;font-family:'Plus Jakarta Sans'}
.field input,.field textarea,.field select{font-family:'Inter',sans-serif;font-size:.95rem;padding:12px 15px;border:1px solid var(--line);
    border-radius:10px;background:var(--field-bg);color:var(--ink);transition:border-color .2s;resize:vertical;width:100%}
.field input::placeholder,.field textarea::placeholder{color:var(--muted);opacity:.7}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--acc)}
.field select{appearance:none;cursor:pointer;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%232c9a36' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}
.field .err{color:#e8674f;font-size:.78rem;margin-top:5px}
.contact-form .btn{margin-top:6px;border:0;cursor:pointer}
.form-success-box{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:6px;min-height:340px;animation:fadeUp .5s ease both}
.form-success-box .fs-ic{display:inline-flex;width:72px;height:72px;border-radius:50%;background:var(--grad);color:var(--on-acc);
    align-items:center;justify-content:center;margin-bottom:10px}
.form-success-box h3{color:var(--gold);font-size:1.5rem}
.form-success-box p{color:var(--muted);font-size:.95rem;max-width:340px;margin-bottom:14px}
.contact-map{margin-top:56px;border-radius:18px;overflow:hidden;border:1px solid var(--line)}
.contact-map iframe{display:block}
html[data-theme="light"] .contact-map iframe{filter:grayscale(.15)}
html:not([data-theme="light"]) .contact-map iframe{filter:invert(.92) hue-rotate(75deg) brightness(.9) contrast(.95)}

/* ===== R&D page ===== */
.rd-intro{background:transparent;padding-bottom:0}
.rd-intro-inner{max-width:760px;text-align:center;margin:0 auto}
.rd-intro-inner p{color:var(--muted);margin-top:14px;font-size:1.05rem}
.rd-section{background:transparent}
.rd-grid-page{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.rd-card{background:var(--bg-soft);border:1px solid var(--line);border-radius:18px;padding:32px 28px;
    box-shadow:var(--shadow-sm);transition:transform .35s ease,border-color .35s ease,box-shadow .35s ease,background .35s ease}
.rd-card:hover{transform:translateY(-6px);border-color:var(--acc);box-shadow:var(--shadow);background:var(--surface-2)}
.rd-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.rd-icon{width:60px;height:60px;border-radius:16px;display:flex;align-items:center;justify-content:center;
    background:var(--grad);color:var(--on-acc)}
.rd-icon svg{width:30px;height:30px}
.rd-no{font-family:'Plus Jakarta Sans';font-weight:800;font-size:1.7rem;color:var(--gold);opacity:.6}
.rd-card h3{font-size:1.18rem;margin-bottom:10px;color:var(--head)}
.rd-card p{color:var(--muted);font-size:.92rem}
.rd-card{opacity:0;transform:translateY(28px)}
.rd-section.in .rd-card{opacity:1;transform:translateY(0)}
.rd-section.in .rd-card:nth-child(2){transition-delay:.1s}
.rd-section.in .rd-card:nth-child(3){transition-delay:.2s}
.rd-section.in .rd-card:nth-child(4){transition-delay:.3s}
.rd-section.in .rd-card:nth-child(5){transition-delay:.4s}

/* ===== Presence map ===== */
.presence-map{background:var(--band)}
.presence-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:center}
.city-list{list-style:none;display:flex;flex-direction:column;gap:14px;margin:0;padding:0}
.city-item{display:flex;align-items:center;gap:16px;background:var(--bg-soft);border:1px solid var(--line);
    border-radius:14px;padding:15px 20px;box-shadow:var(--shadow-sm);transition:.3s;cursor:default}
.city-item:hover,.city-item.active{transform:translateX(6px);border-color:var(--acc);box-shadow:var(--shadow);background:var(--surface-2)}
.city-no{font-family:'Plus Jakarta Sans';font-weight:800;color:var(--gold);font-size:1.15rem;min-width:30px}
.city-info{display:flex;flex-direction:column;flex:1}
.city-info strong{color:var(--head);font-size:1.05rem;font-family:'Plus Jakarta Sans'}
.city-info small{color:var(--muted);font-size:.8rem}
.city-dot{width:11px;height:11px;border-radius:50%;background:var(--acc-light);box-shadow:0 0 0 4px rgba(32,112,38,.22);transition:.3s}
.city-item:hover .city-dot,.city-item.active .city-dot{box-shadow:0 0 0 6px rgba(32,112,38,.32)}
.india-map-wrap{position:relative;width:100%;max-width:460px;margin:0 auto}
.india-map-img{width:100%;height:auto;display:block}
html:not([data-theme="light"]) .india-map-img{filter:invert(.9) hue-rotate(65deg) saturate(1.2) brightness(.95)}
.map-pin{position:absolute;width:14px;height:14px;transform:translate(-50%,-50%);z-index:2}
.map-pin::before{content:'';position:absolute;inset:0;border-radius:50%;background:var(--acc-light);
    border:2px solid var(--bg);transition:.25s}
.map-pin::after{content:'';position:absolute;inset:-5px;border-radius:50%;border:2px solid var(--acc-light);
    opacity:.7;animation:pinPulse 2.2s ease-out infinite}
@keyframes pinPulse{0%{transform:scale(.5);opacity:.8}100%{transform:scale(2);opacity:0}}
.map-pin-label{position:absolute;left:50%;bottom:160%;transform:translateX(-50%);background:var(--surface-2);
    color:var(--head);font-size:.72rem;font-weight:600;font-family:'Plus Jakarta Sans';padding:4px 9px;border-radius:6px;
    white-space:nowrap;opacity:0;pointer-events:none;transition:.2s;z-index:3;border:1px solid var(--line)}
.map-pin-label::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);
    border:5px solid transparent;border-top-color:var(--surface-2)}
.map-pin:hover .map-pin-label,.map-pin.active .map-pin-label{opacity:1}
.map-pin:hover::before,.map-pin.active::before{background:var(--acc-light);box-shadow:0 0 0 3px var(--acc-light);transform:scale(1.15)}

.city-item{opacity:0;transform:translateX(-24px)}
.presence-map.in .city-item{opacity:1;transform:translateX(0);transition:opacity .5s ease,transform .5s ease,box-shadow .3s,border-color .3s}
.presence-map.in .city-item:nth-child(1){transition-delay:.05s}
.presence-map.in .city-item:nth-child(2){transition-delay:.13s}
.presence-map.in .city-item:nth-child(3){transition-delay:.21s}
.presence-map.in .city-item:nth-child(4){transition-delay:.29s}
.presence-map.in .city-item:nth-child(5){transition-delay:.37s}
.presence-map.in .city-item:nth-child(6){transition-delay:.45s}

/* ===== Organization chart ===== */
.orgchart-section{background:transparent}
.org-scroll{overflow-x:auto;padding:8px 4px 24px}
.tree{display:inline-block;min-width:100%;text-align:center}
.tree ul{position:relative;padding:26px 0 0;white-space:nowrap;margin:0;text-align:center;list-style:none;display:flex;justify-content:center}
.tree li{display:inline-block;vertical-align:top;text-align:center;list-style:none;position:relative;padding:26px 10px 0}
.tree li::before,.tree li::after{content:'';position:absolute;top:0;right:50%;border-top:2px solid var(--line);width:50%;height:26px}
.tree li::after{right:auto;left:50%;border-left:2px solid var(--line)}
.tree li:only-child::before,.tree li:only-child::after{display:none}
.tree li:only-child{padding-top:26px}
.tree li:first-child::before,.tree li:last-child::after{border:0 none}
.tree li:last-child::before{border-right:2px solid var(--line);border-radius:0 6px 0 0}
.tree li:first-child::after{border-radius:6px 0 0 0}
.tree ul ul::before{content:'';position:absolute;top:0;left:50%;border-left:2px solid var(--line);width:0;height:26px}
.tree>ul{padding-top:0}
.node{display:inline-block;padding:13px 20px;border-radius:12px;font-family:'Plus Jakarta Sans';font-weight:700;
    font-size:.88rem;color:var(--ink);background:var(--bg-soft);border:1px solid var(--line);white-space:nowrap;
    box-shadow:var(--shadow-sm);transition:.25s}
.node:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--acc)}
.node--ceo{background:var(--grad);color:var(--on-acc);font-size:1.15rem;padding:16px 40px;border:0}
.node--lead{background:var(--grad-deep);color:#fff;font-size:1rem;padding:14px 32px;border:0}
.node--mgr{background:var(--bg-soft);border:1px solid var(--line);border-bottom:3px solid var(--acc)}

/* ===== Entrance animations ===== */
.page-banner-inner{animation:fadeUp .9s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.about-intro-side{opacity:0;transform:translateX(-44px);transition:.8s cubic-bezier(.2,.7,.2,1)}
.about-intro-text{opacity:0;transform:translateX(44px);transition:.8s cubic-bezier(.2,.7,.2,1)}
.about-intro.in .about-intro-side,.about-intro.in .about-intro-text{opacity:1;transform:none}
.ab-badge{opacity:0;transform:translateY(22px);transition:.6s ease}
.about-intro.in .ab-badge{opacity:1;transform:none}
.about-intro.in .ab-badge:nth-child(1){transition-delay:.3s}
.about-intro.in .ab-badge:nth-child(2){transition-delay:.45s}
.about-intro.in .ab-badge:nth-child(3){transition-delay:.6s}
.vm-card{opacity:0;transform:translateY(46px)}
.vm.in .vm-card{opacity:1;transform:translateY(0);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.vm.in .vm-card:nth-child(2){transition-delay:.18s}
.reg-card{opacity:0;transform:translateY(34px)}
.regs.in .reg-card{opacity:1;transform:translateY(0)}
.regs.in .reg-card:nth-child(1){transition-delay:.05s}
.regs.in .reg-card:nth-child(2){transition-delay:.13s}
.regs.in .reg-card:nth-child(3){transition-delay:.21s}
.regs.in .reg-card:nth-child(4){transition-delay:.29s}
.regs.in .reg-card:nth-child(5){transition-delay:.37s}
.regs.in .reg-card:nth-child(6){transition-delay:.45s}
.regs.in .reg-card:nth-child(7){transition-delay:.53s}
.regs.in .reg-card:nth-child(8){transition-delay:.61s}

@media(prefers-reduced-motion:reduce){
    .about-intro-side,.about-intro-text,.ab-badge,.vm-card,.reg-card,.svc-card,.rd-card,.city-item,.page-banner-inner{
        opacity:1!important;transform:none!important;animation:none!important}
    .map-pin::after{animation:none}
    .vm-icon{animation:none}
}

/* ===== WhatsApp float ===== */
.whatsapp-float{position:fixed;right:22px;bottom:22px;width:56px;height:56px;border-radius:50%;
    background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;
    font-size:1.8rem;z-index:60;transition:.3s;box-shadow:0 12px 28px -10px rgba(37,211,102,.6)}
.whatsapp-float:hover{transform:scale(1.1)}

/* ===== Reveal animation ===== */
.section,.stat{opacity:0;transform:translateY(28px);transition:.7s ease}
.section.in,.stat.in{opacity:1;transform:none}

/* ===== Responsive ===== */
@media(max-width:980px){
    .hero-inner{grid-template-columns:1fr;text-align:center;gap:24px;padding-top:64px}
    .hero-content{max-width:640px;margin:0 auto}
    .hero-actions{justify-content:center}
    .hero-visual{order:-1}
    .hero-logo-3d{width:min(320px,70%)}
    .stats-grid{grid-template-columns:repeat(2,1fr);gap:30px}
    .stat:nth-child(2n){border-right:0}
    .services-grid{grid-template-columns:repeat(2,1fr)}
    .why-grid{grid-template-columns:repeat(2,1fr)}
    .about-grid,.rnd-grid{grid-template-columns:1fr;gap:40px}
    .rnd-list{grid-template-columns:1fr 1fr}
    .about-intro-grid,.vm-grid{grid-template-columns:1fr;gap:32px}
    .reg-grid{grid-template-columns:repeat(2,1fr)}
    .svc-grid{grid-template-columns:repeat(2,1fr)}
    .rd-grid-page{grid-template-columns:repeat(2,1fr)}
    .contact-grid{grid-template-columns:1fr;gap:36px}
    .presence-grid{grid-template-columns:1fr;gap:36px;max-width:520px;margin:0 auto}
}
@media(max-width:1300px){
    .topbar{display:none}
    .nav-toggle{display:flex}
    .lang-btn .lang-name{display:none}
    .main-nav{position:fixed;top:0;right:0;bottom:0;width:min(82vw,320px);
        background:var(--bg-2);
        flex-direction:column;align-items:stretch;gap:0;padding:96px 0 28px;
        border-left:1px solid var(--line);box-shadow:-12px 0 40px -24px rgba(0,0,0,.6);
        transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);
        z-index:70;overflow-y:auto}
    .main-nav.open{transform:translateX(0)}
    .main-nav a{width:100%;padding:16px 28px;color:var(--ink);font-size:1.05rem;
        border-bottom:1px solid var(--line)}
    .main-nav a:not(.nav-cta)::after{display:none}
    .main-nav a:not(.nav-cta):hover,.main-nav a.active{color:var(--gold);background:rgba(32,112,38,.08)}
    .main-nav .nav-cta{margin:22px 28px 0;width:auto;text-align:center;border-bottom:0;
        background:var(--grad);color:var(--on-acc)!important;border-radius:50px}
    body.nav-open{overflow:hidden}
    .about-points{grid-template-columns:1fr}
    .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media(max-width:560px){
    .services-grid,.why-grid,.rnd-list,.svc-grid,.rd-grid-page{grid-template-columns:1fr}
    .field-row{grid-template-columns:1fr}
    .stats-grid{grid-template-columns:1fr 1fr;padding:26px}
    .stat-value{font-size:2.1rem}
    .footer-grid{grid-template-columns:1fr}
    .hero-inner{padding:64px 24px 90px}
    .cta-inner{flex-direction:column;text-align:center}
}

/* ===== Google Translate engine (hidden — driven by custom .lang-select) ===== */
.gtranslate{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);
    opacity:0;pointer-events:none;left:-9999px}
.goog-te-banner-frame,.goog-te-gadget-icon,.skiptranslate iframe{display:none!important}
body{top:0!important;position:static!important}
.goog-te-gadget{font-size:0!important;color:transparent!important}
.goog-te-gadget .goog-te-combo{
    margin:0!important;height:40px;padding:0 30px 0 14px;border-radius:50px;
    border:1px solid var(--line);background:var(--bg-soft);color:var(--ink);
    font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:.82rem;cursor:pointer;
    appearance:none;-webkit-appearance:none;outline:none;transition:.25s;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%232c9a36' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 11px center}
.goog-te-gadget .goog-te-combo:hover{border-color:var(--acc);color:var(--gold)}
font.goog-text-highlight{background:none!important;box-shadow:none!important}

.field-opt{color:var(--muted);font-weight:500;font-size:.78rem}

/* ===== Jobs page ===== */
.jobs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.job-card{display:flex;flex-direction:column;background:var(--bg-soft);border:1px solid var(--line);
    border-radius:var(--radius);padding:28px 26px;box-shadow:var(--shadow-sm);transition:.3s}
.job-card:hover{transform:translateY(-6px);border-color:var(--acc);box-shadow:var(--shadow);background:var(--surface-2)}
.job-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.job-ic{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;
    background:var(--grad);color:var(--on-acc)}
.job-type{font-size:.72rem;font-weight:700;color:var(--gold);background:rgba(32,112,38,.12);
    border:1px solid var(--line);padding:5px 12px;border-radius:50px}
.job-title{font-size:1.2rem;margin-bottom:12px;color:var(--head)}
.job-meta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:14px;font-size:.82rem;color:var(--muted)}
.job-meta span{display:inline-flex;align-items:center;gap:5px}
.job-meta svg{color:var(--gold)}
.job-dept{font-weight:700;color:var(--gold)!important}
.job-desc{color:var(--muted);font-size:.92rem;margin-bottom:20px;flex:1}
.job-apply{align-self:flex-start;margin-top:auto}

.apply-section{background:var(--band)}
.apply-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:50px;align-items:start}
.apply-intro .contact-lead{margin-bottom:22px}
.apply-mail{color:var(--gold);font-weight:700}

/* ===== Gallery page ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.gallery-item{position:relative;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
    background:radial-gradient(circle at 50% 35%,var(--surface-2),var(--bg-soft));aspect-ratio:4/3;
    cursor:zoom-in;padding:0;display:block;box-shadow:var(--shadow-sm);transition:.35s}
.gallery-item:hover{transform:translateY(-6px);border-color:var(--acc);box-shadow:var(--shadow)}
.gallery-item img{width:62%;height:62%;object-fit:contain;position:absolute;left:50%;top:42%;
    transform:translate(-50%,-50%);transition:.4s}
.gallery-item:hover img{transform:translate(-50%,-50%) scale(1.08)}
.gallery-overlay{position:absolute;left:0;right:0;bottom:0;padding:16px 18px;text-align:left;
    display:flex;flex-direction:column;gap:2px;
    background:linear-gradient(to top,rgba(0,0,0,.55),transparent);opacity:0;transition:.35s}
html[data-theme="light"] .gallery-overlay{background:linear-gradient(to top,rgba(13,51,21,.55),transparent)}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-cat{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--acc-light)}
.gallery-title{font-family:'Plus Jakarta Sans';font-weight:700;color:#fff;font-size:1rem}
.gallery-zoom{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;
    background:var(--grad);color:var(--on-acc);display:flex;align-items:center;justify-content:center;
    transform:scale(.6);opacity:0;transition:.3s}
.gallery-item:hover .gallery-zoom{transform:scale(1);opacity:1}

.lightbox{position:fixed;inset:0;z-index:100;background:rgba(3,8,5,.9);
    display:flex;align-items:center;justify-content:center;padding:30px;
    opacity:0;visibility:hidden;transition:.3s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.lightbox.open{opacity:1;visibility:visible}
.lightbox-figure{max-width:680px;text-align:center;margin:0}
.lightbox-figure img{max-width:100%;max-height:74vh;border-radius:16px;border:1px solid var(--line);
    background:var(--bg-soft);padding:30px}
.lightbox-figure figcaption{color:#fff;margin-top:16px;font-family:'Plus Jakarta Sans';font-weight:700;font-size:1.1rem}
.lightbox-close{position:absolute;top:22px;right:26px;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.3);
    background:rgba(255,255,255,.08);color:#fff;font-size:1.8rem;line-height:1;cursor:pointer;transition:.25s}
.lightbox-close:hover{background:var(--grad);border-color:transparent;color:var(--on-acc)}

/* ===== Blog page ===== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.blog-card{display:flex;flex-direction:column;background:var(--bg-soft);border:1px solid var(--line);
    border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.3s}
.blog-card:hover{transform:translateY(-6px);border-color:var(--acc);box-shadow:var(--shadow)}
.blog-thumb{position:relative;aspect-ratio:16/10;overflow:hidden;
    background:radial-gradient(circle at 50% 35%,var(--surface-2),var(--bg-soft));
    display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--line)}
.blog-thumb img{width:48%;height:48%;object-fit:contain;transition:.4s}
.blog-card:hover .blog-thumb img{transform:scale(1.08)}
.blog-cat{position:absolute;top:14px;left:14px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
    background:var(--grad);color:var(--on-acc);padding:5px 12px;border-radius:50px}
.blog-body{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.blog-date{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;color:var(--muted);margin-bottom:10px}
.blog-date svg{color:var(--gold)}
.blog-title{font-size:1.12rem;line-height:1.35;margin-bottom:10px;color:var(--head)}
.blog-excerpt{color:var(--muted);font-size:.9rem;margin-bottom:16px;flex:1}

/* ===== Single blog article ===== */
.post-wrap{max-width:820px;margin:0 auto}
.post-back{margin-bottom:26px;padding:10px 20px;font-size:.9rem}
.post-thumb{border-radius:18px;overflow:hidden;border:1px solid var(--line);
    background:radial-gradient(circle at 50% 35%,var(--surface-2),var(--bg-soft));
    aspect-ratio:16/7;display:flex;align-items:center;justify-content:center;margin-bottom:24px}
.post-thumb img{width:34%;height:64%;object-fit:contain}
.post-meta{display:flex;align-items:center;gap:14px;color:var(--muted);font-size:.85rem;margin-bottom:16px}
.post-meta span{display:inline-flex;align-items:center;gap:6px}
.post-meta .pm-cat{background:var(--grad);color:var(--on-acc);padding:5px 13px;border-radius:50px;
    font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.5px}
.post-meta svg{color:var(--gold)}
.post-headline{font-size:clamp(1.6rem,3.4vw,2.3rem);color:var(--head);line-height:1.25;margin-bottom:14px}
.post-lead{font-size:1.12rem;color:var(--ink);line-height:1.7;margin-bottom:24px;
    padding-bottom:24px;border-bottom:1px solid var(--line)}
.post-body{font-size:1.02rem;line-height:1.85}
.post-body h2,.post-body h3{color:var(--head);margin:28px 0 10px;font-size:1.25rem}
.post-body p{margin-bottom:16px;color:var(--muted)}
.post-foot{margin-top:32px;padding-top:24px;border-top:1px solid var(--line)}

/* ===== Admin auth pages ===== */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 16px;position:relative;overflow:hidden}
.auth-page::before{content:'';position:absolute;inset:0;z-index:0;
    background:radial-gradient(720px circle at 82% 18%,var(--glow-1),transparent 55%),
               radial-gradient(620px circle at 8% 92%,var(--glow-2),transparent 55%)}
.auth-card{position:relative;z-index:1;width:100%;max-width:420px;background:var(--bg-soft);
    border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);padding:38px 34px}
.auth-brand{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;margin-bottom:24px}
.auth-brand img{width:64px;height:64px;object-fit:contain;filter:drop-shadow(0 0 16px rgba(32,112,38,.45))}
.auth-brand h1{font-size:1.35rem;color:var(--head)}
.auth-brand p{color:var(--muted);font-size:.88rem}
.auth-card .field{margin-bottom:16px}
.auth-err{display:flex;align-items:center;gap:8px;background:rgba(232,103,79,.12);
    border:1px solid rgba(232,103,79,.4);color:#e8674f;padding:11px 14px;border-radius:10px;
    font-size:.86rem;margin-bottom:18px}
.auth-card .btn{width:100%;justify-content:center;margin-top:6px}
.auth-foot{text-align:center;margin-top:18px;font-size:.84rem;color:var(--muted)}
.auth-foot a{color:var(--gold);font-weight:600}
.pw-wrap{position:relative}
.pw-wrap input{padding-right:64px}
.pw-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:0;
    color:var(--gold);cursor:pointer;font-size:.78rem;font-weight:700}

/* ===== Admin dashboard ===== */
.admin-body{background:var(--bg)}
.admin-shell{display:flex;min-height:100vh}
.admin-side{width:248px;flex:none;background:var(--bg-2);border-right:1px solid var(--line);
    display:flex;flex-direction:column;padding:22px 16px;position:sticky;top:0;height:100vh;overflow-y:auto}
.admin-nav{scrollbar-width:thin}
.admin-brand{display:flex;align-items:center;gap:10px;padding:4px 8px 18px;border-bottom:1px solid var(--line);margin-bottom:14px}
.admin-brand img{width:40px;height:40px;object-fit:contain;filter:drop-shadow(0 0 12px rgba(32,112,38,.45))}
.admin-brand strong{display:block;color:var(--head);font-family:'Plus Jakarta Sans';font-size:1rem}
.admin-brand small{color:var(--muted);font-size:.72rem}
.admin-nav{display:flex;flex-direction:column;gap:4px;flex:1}
.admin-nav a{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:10px;color:var(--ink);font-weight:600;font-size:.92rem;transition:.2s}
.admin-nav a svg{color:var(--muted);transition:.2s;flex:none}
.admin-nav a:hover{background:var(--bg-soft);color:var(--gold)}
.admin-nav a:hover svg{color:var(--gold)}
.admin-nav a.active{background:var(--grad);color:var(--on-acc)}
.admin-nav a.active svg{color:var(--on-acc)}
.admin-side-foot{border-top:1px solid var(--line);padding-top:12px;margin-top:12px}
.admin-logout{display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:10px;color:var(--muted);font-weight:600;font-size:.92rem;transition:.2s}
.admin-logout:hover{color:#e8674f;background:var(--bg-soft)}
.admin-overlay{display:none}
.admin-main{flex:1;min-width:0;display:flex;flex-direction:column}
.admin-top{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:16px;padding:0 26px;height:68px;
    background:var(--header-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.admin-title{font-size:1.2rem;color:var(--head);flex:1}
.admin-user{display:flex;align-items:center;gap:10px}
.admin-avatar{width:38px;height:38px;border-radius:50%;background:var(--grad);color:var(--on-acc);
    display:flex;align-items:center;justify-content:center;font-weight:800;font-family:'Plus Jakarta Sans'}
.admin-uname{color:var(--ink);font-weight:600;font-size:.9rem}
.admin-top-logout{display:inline-flex;align-items:center;gap:7px;padding:8px 15px;border-radius:50px;
    border:1px solid var(--line);background:var(--bg-soft);color:var(--ink);font-weight:700;font-size:.84rem;
    font-family:'Plus Jakarta Sans',sans-serif;transition:.22s;cursor:pointer}
.admin-top-logout:hover{border-color:#e8674f;color:#e8674f;background:rgba(232,103,79,.08)}
.admin-top-logout svg{flex:none}
.admin-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.admin-burger span{width:24px;height:2.5px;background:var(--head);border-radius:3px}
.admin-content{padding:26px;flex:1}

.stat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px}
.stat-card{display:flex;align-items:center;gap:16px;background:var(--bg-soft);border:1px solid var(--line);
    border-radius:16px;padding:22px;box-shadow:var(--shadow-sm)}
.sc-ic{width:50px;height:50px;border-radius:14px;background:var(--grad);color:var(--on-acc);
    display:flex;align-items:center;justify-content:center;flex:none}
.stat-card b{display:block;font-family:'Plus Jakarta Sans';font-size:1.7rem;color:var(--head);line-height:1.1}
.stat-card small{color:var(--muted);font-size:.84rem}
a.stat-card{text-decoration:none;transition:transform .25s,border-color .25s,box-shadow .25s}
a.stat-card:hover{transform:translateY(-3px);border-color:var(--acc);box-shadow:var(--shadow)}

/* dashboard charts */
.dash-charts{display:grid;gap:20px;margin-bottom:24px}
.dash-charts.cols-1{grid-template-columns:minmax(0,680px)}
.dash-charts.cols-2{grid-template-columns:1.5fr 1fr}
.dash-charts.cols-3{grid-template-columns:1.6fr 1fr 1fr}
.dash-recent{display:grid;gap:20px;margin-bottom:24px}
.dash-recent.cols-1{grid-template-columns:1fr}
.dash-recent.cols-2{grid-template-columns:1fr 1fr}
.dash-recent.cols-3{grid-template-columns:1fr 1fr 1fr}
.chart-card{background:var(--bg-soft);border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:var(--shadow-sm)}
.chart-card .admin-panel-head{margin-bottom:14px}
.chart-card .admin-panel-head h2{font-size:1.1rem;color:var(--head)}
.chart-box{position:relative;height:300px}
.chart-box--sm{height:240px}
@media(max-width:1100px){.dash-charts.cols-3,.dash-recent.cols-3{grid-template-columns:1fr 1fr}}
@media(max-width:900px){.dash-charts,.dash-recent,.dash-charts.cols-2,.dash-charts.cols-3,.dash-recent.cols-2,.dash-recent.cols-3{grid-template-columns:1fr}}

/* ===== Admin roles & permissions ===== */
.admin-role-badge{display:inline-block;margin-left:4px;font-size:.66rem;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:2px 7px;border-radius:20px;background:rgba(128,128,128,.18);color:var(--muted);vertical-align:middle}
.admin-role-badge.super{background:rgba(32,112,38,.16);color:var(--acc);border:1px solid rgba(32,112,38,.4)}
.you-badge{display:inline-block;font-size:.62rem;font-weight:700;text-transform:uppercase;padding:1px 6px;border-radius:20px;background:rgba(232,164,79,.18);color:#c9892f;vertical-align:middle}
.access-cell{max-width:340px}
.access-all{display:inline-flex;align-items:center;gap:5px;font-weight:600;color:var(--acc);font-size:.82rem}
.access-all svg{flex:none}
.access-chip{display:inline-block;font-size:.72rem;padding:2px 8px;margin:2px 3px 2px 0;border-radius:20px;background:rgba(32,112,38,.1);border:1px solid var(--line);color:var(--head)}
.access-none{color:var(--muted);font-size:.82rem;font-style:italic}
.btn-mini.btn-danger{background:transparent;border-color:rgba(214,69,69,.5);color:#d64545}
.btn-mini.btn-danger:hover{background:rgba(214,69,69,.12)}

.perm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:6px}
.perm-item{display:flex;align-items:center;gap:8px;padding:9px 11px;border:1px solid var(--line);border-radius:10px;cursor:pointer;font-size:.86rem;color:var(--head);background:var(--bg-soft);transition:border-color .2s,background .2s;user-select:none}
.perm-item:hover{border-color:var(--acc)}
.perm-item input{accent-color:var(--acc);width:16px;height:16px;flex:none}
.perm-item .perm-ic{display:inline-flex;color:var(--acc);flex:none}
.perm-item:has(input:checked){border-color:var(--acc);background:rgba(32,112,38,.08)}
.perm-tools{display:flex;align-items:center;gap:8px;margin-top:8px;color:var(--muted)}
.link-btn{background:none;border:0;color:var(--acc);font:inherit;font-size:.82rem;font-weight:600;cursor:pointer;padding:0}
.link-btn:hover{text-decoration:underline}
.perm-super-note{display:flex;align-items:center;gap:8px;padding:11px 13px;border-radius:10px;background:rgba(32,112,38,.1);border:1px solid rgba(32,112,38,.3);color:var(--head);font-size:.86rem;margin-top:4px}
.perm-super-note svg{color:var(--acc);flex:none}
@media(max-width:680px){.perm-grid{grid-template-columns:repeat(2,1fr)}}

/* Activity history */
.log-list{list-style:none;margin:0;padding:0}
.log-list li{display:flex;gap:12px;padding:11px 2px;border-bottom:1px solid var(--line)}
.log-list li:last-child{border-bottom:0}
.log-dot{width:9px;height:9px;border-radius:50%;background:var(--acc);margin-top:6px;flex:none;box-shadow:0 0 0 3px rgba(32,112,38,.15)}
.log-body{flex:1}
.log-line{font-size:.9rem;color:var(--head);line-height:1.4}
.log-det{color:var(--muted)}
.log-time{display:block;font-size:.76rem;color:var(--muted);margin-top:2px}
.admin-role-badge.super{margin-left:0}

/* flatpickr accent (date pickers) */
.flatpickr-day.selected,.flatpickr-day.selected:hover,.flatpickr-day.startRange,.flatpickr-day.endRange{background:var(--acc);border-color:var(--acc)}
.flatpickr-day.today{border-color:var(--acc)}
.flatpickr-day.today:hover{background:var(--acc);border-color:var(--acc);color:#fff}
.flatpickr-months .flatpickr-month,.flatpickr-current-month input.cur-year,.flatpickr-monthDropdown-months{font-weight:600}

/* compact document upload drop */
.file-drop--sm{padding:10px 12px;gap:8px;font-size:.85rem;min-height:0}
.file-drop--sm .doc-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ga-current img{max-height:54px;border-radius:6px;border:1px solid var(--line)}

/* employee view (read-only profile) */
.ev-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.ev-bar-actions{display:flex;gap:8px}
.ev-head{display:flex;align-items:center;gap:18px}
.ev-photo{width:84px;height:84px;border-radius:14px;object-fit:cover;border:1px solid var(--line);display:block}
.ev-initial{display:flex;align-items:center;justify-content:center;background:rgba(32,112,38,.12);color:var(--acc);font-size:2rem;font-weight:700}
.ev-id h2{margin:0 0 4px;color:var(--head)}
.ev-id p{margin:0;color:var(--muted)}
.ev-id .ev-sub{font-size:.86rem;margin-top:2px}
.ev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px 22px}
.ev-item{display:flex;flex-direction:column;gap:3px;min-width:0}
.ev-item span{font-size:.74rem;text-transform:uppercase;letter-spacing:.4px;color:var(--muted)}
.ev-item b{color:var(--head);font-weight:600;word-break:break-word}
.ev-item.ev-wide{grid-column:1/-1}
@media(max-width:900px){.ev-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.ev-grid{grid-template-columns:1fr}}

/* document thumbnails */
.emp-docs{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}
.emp-doc{display:block;border:1px solid var(--line);border-radius:12px;overflow:hidden;text-decoration:none;background:var(--bg-soft);transition:border-color .2s,transform .2s}
.emp-doc:hover{border-color:var(--acc);transform:translateY(-2px)}
.emp-doc img{width:100%;height:120px;object-fit:cover;display:block;background:#0c1410}
.emp-doc span{display:flex;align-items:center;justify-content:center;gap:5px;padding:8px;font-size:.82rem;color:var(--head)}
.emp-doc.doc-broken img{display:none}

.admin-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.admin-panel{background:var(--bg-soft);border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:var(--shadow-sm)}
.admin-panel--narrow{max-width:480px}
.admin-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.admin-panel-head h2{font-size:1.1rem;color:var(--head)}
.admin-link{color:var(--gold);font-size:.85rem;font-weight:700}
.count-badge{background:var(--bg-2);border:1px solid var(--line);color:var(--gold);font-size:.78rem;padding:2px 9px;border-radius:50px;margin-left:6px}
.table-scroll{overflow-x:auto}
.admin-table{width:100%;border-collapse:collapse;font-size:.88rem}
.admin-table th{text-align:left;color:var(--muted);font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.5px;padding:10px 12px;border-bottom:1px solid var(--line);white-space:nowrap}
.admin-table td{padding:12px;border-bottom:1px solid var(--line);color:var(--ink);vertical-align:top}
.admin-table tr:last-child td{border-bottom:0}
.admin-table tbody tr:hover{background:var(--bg-2)}
.admin-table a{color:var(--gold)}
.admin-empty{text-align:center;color:var(--muted)!important;padding:26px!important}
.msg-cell{max-width:280px;color:var(--muted)!important;font-size:.84rem}
.btn-mini{display:inline-flex;align-items:center;gap:5px;background:var(--grad);color:var(--on-acc);border:0;padding:7px 13px;border-radius:8px;font-weight:700;font-size:.78rem;cursor:pointer;font-family:'Plus Jakarta Sans'}
.btn-mini svg{flex:none}
.btn-mini:hover{filter:brightness(1.08)}
.admin-table a.btn-mini{color:var(--on-acc)}
.admin-table a.btn-mini:hover{color:var(--on-acc)}
.btn-danger{background:transparent;color:#e8674f;border:1px solid rgba(232,103,79,.45)}
.btn-danger:hover{background:rgba(232,103,79,.12);filter:none}
.row-actions{display:flex;gap:8px;white-space:nowrap}
.pill-on{display:inline-block;font-size:.72rem;font-weight:700;color:var(--gold);background:rgba(32,112,38,.12);border:1px solid rgba(32,112,38,.4);padding:3px 11px;border-radius:50px}
.pill-off{display:inline-block;font-size:.72rem;font-weight:700;color:var(--muted);background:var(--bg-2);border:1px solid var(--line);padding:3px 11px;border-radius:50px}

/* admin gallery / blog grid — compact cards */
.gallery-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:14px;margin-top:6px}
.ga-card{background:var(--bg-2);border:1px solid var(--line);border-radius:12px;overflow:hidden;display:flex;flex-direction:column}
.ga-thumb{position:relative;aspect-ratio:4/3;background:radial-gradient(circle at 50% 35%,var(--surface-2),var(--bg-2));
    display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--line)}
.ga-thumb img{width:100%;height:100%;object-fit:cover}
.ga-hidden{position:absolute;top:6px;left:6px;background:rgba(0,0,0,.6);color:#fff;font-size:.62rem;font-weight:700;padding:2px 8px;border-radius:50px}
.ga-info{padding:9px 11px 2px;display:flex;flex-direction:column;gap:1px}
.ga-info strong{color:var(--head);font-size:.82rem;line-height:1.25}
.ga-info small{color:var(--muted);font-size:.72rem}
.ga-actions{display:flex;gap:6px;padding:8px 11px 11px;margin-top:auto}
.ga-actions .btn-mini{flex:1;justify-content:center;padding:6px 8px;font-size:.7rem;gap:4px}
.ga-current{display:flex;align-items:center;gap:10px;margin-top:10px;flex-wrap:wrap}
.ga-current span{color:var(--muted);font-size:.82rem}
.ga-current img{width:54px;height:54px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}
.ga-current small{color:var(--muted);font-size:.78rem}
@media(max-width:480px){.gallery-admin-grid{grid-template-columns:repeat(2,1fr)}}
.ga-noimg{font-family:'Plus Jakarta Sans';font-weight:800;color:var(--head);font-size:.85rem;text-align:center;padding:0 10px}
.svc-thumb img{object-fit:contain!important;padding:16%}

/* ===== Get a Quote button ===== */
.btn-quote{display:inline-flex;align-items:center;gap:6px;background:var(--grad);color:var(--on-acc);border:0;
    padding:9px 15px;border-radius:50px;font-weight:700;font-size:.82rem;font-family:'Plus Jakarta Sans',sans-serif;
    cursor:pointer;white-space:nowrap;box-shadow:0 12px 26px -10px rgba(32,112,38,.6);transition:.25s}
.btn-quote:hover{transform:translateY(-1px);filter:brightness(1.07)}
.btn-quote svg{flex:none}
.footer-quote{margin-top:18px}

/* ===== Clientele nav dropdown ===== */
.nav-dd{position:relative;display:flex;align-items:center}
.nav-dd a::after{content:none!important}
.nav-dd-toggle{display:inline-flex;align-items:center;gap:5px;font-weight:600;font-size:.95rem;color:var(--ink);cursor:pointer;transition:.2s}
.nav-dd-toggle:hover,.nav-dd-toggle.active{color:var(--gold)}
.dd-chev{width:13px;height:13px;transition:transform .25s}
.nav-dd:hover .dd-chev{transform:rotate(180deg)}
.nav-dd-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);min-width:188px;
    background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:6px;box-shadow:var(--shadow);
    opacity:0;visibility:hidden;transition:.22s;z-index:60}
.nav-dd:hover .nav-dd-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(2px)}
.nav-dd-menu a{display:block;padding:10px 14px;border-radius:9px;color:var(--ink);font-size:.9rem;font-weight:600;transition:.18s}
.nav-dd-menu a:hover,.nav-dd-menu a.active{background:var(--bg-2);color:var(--gold)}

/* ===== Get a Quote modal ===== */
.quote-modal{position:fixed;inset:0;z-index:130;background:rgba(3,8,5,.86);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
    display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto;opacity:0;visibility:hidden;transition:.3s}
.quote-modal.open{opacity:1;visibility:visible}
.quote-dialog{width:100%;max-width:520px;margin:auto;background:var(--bg-soft);border:1px solid var(--line);border-radius:20px;
    box-shadow:var(--shadow);overflow:hidden;transform:translateY(22px);transition:.3s}
.quote-modal.open .quote-dialog{transform:none}
.quote-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px 26px;border-bottom:1px solid var(--line)}
.quote-eyebrow{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--gold)}
.quote-head h3{font-size:1.25rem;color:var(--head);margin-top:4px}
.quote-body{padding:18px 26px 24px}
.quote-form .field{margin-bottom:14px}
.quote-form .btn{width:100%;justify-content:center;margin-top:4px}
.quote-success{display:none;flex-direction:column;align-items:center;text-align:center;padding:28px 10px 24px;gap:6px}
.quote-modal.is-success .quote-success{display:flex;animation:fadeUp .4s ease both}
.quote-modal.is-success .quote-form{display:none}
.quote-success h3{color:var(--head);font-size:1.4rem}
.quote-success p{color:var(--muted);font-size:.95rem;max-width:340px}

/* ===== Our Clients page ===== */
.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}
.client-link{display:block}
.client-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:150px;
    background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:26px 20px;box-shadow:var(--shadow-sm);transition:.3s;text-align:center;height:100%}
.client-card:hover{transform:translateY(-6px);border-color:var(--acc);box-shadow:var(--shadow)}
.client-logo{max-width:130px;max-height:64px;object-fit:contain}
.client-name{font-family:'Plus Jakarta Sans';font-weight:800;font-size:1.05rem;color:var(--head)}
.client-cap{color:var(--muted);font-size:.82rem}

/* ===== Testimonials page ===== */
.tmnl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px}
.tmnl-card{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;
    box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px;transition:.3s}
.tmnl-card:hover{transform:translateY(-6px);border-color:var(--acc);box-shadow:var(--shadow)}
.tmnl-stars{color:#f1b81e;font-size:1.05rem;letter-spacing:2px}
.tmnl-msg{color:var(--ink);font-size:.96rem;line-height:1.65;font-style:italic;flex:1}
.tmnl-foot{display:flex;align-items:center;gap:12px;border-top:1px solid var(--line);padding-top:14px}
.tmnl-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;flex:none}
.tmnl-initial{display:flex;align-items:center;justify-content:center;background:var(--grad);color:var(--on-acc);font-weight:800;font-family:'Plus Jakarta Sans';font-size:1.1rem}
.tmnl-who{display:flex;flex-direction:column}
.tmnl-who strong{color:var(--head);font-family:'Plus Jakarta Sans';font-size:.98rem}
.tmnl-who small{color:var(--muted);font-size:.82rem}

.nav-quote{display:none}
@media(max-width:1300px){
    .header-tools .btn-quote{display:none}
    .main-nav .nav-quote{display:flex;align-items:center;justify-content:center;gap:7px;margin:22px 28px 0;
        width:auto;border:0;border-radius:50px;padding:14px 22px;background:var(--grad);color:var(--on-acc);
        font-family:'Plus Jakarta Sans';font-weight:700;font-size:1rem;cursor:pointer}
    .main-nav .nav-dd{flex-direction:column;align-items:stretch;width:100%}
    .nav-dd-toggle{width:100%;padding:16px 28px;justify-content:space-between;border-bottom:1px solid var(--line);color:var(--ink)}
    .nav-dd-menu{position:static;opacity:1!important;visibility:visible!important;transform:none!important;
        background:transparent;border:0;box-shadow:none;padding:0;min-width:0}
    .nav-dd-menu a{padding:14px 44px;border-bottom:1px solid var(--line);border-radius:0}
    .nav-dd:hover .dd-chev{transform:none}
}
.admin-notice{display:flex;align-items:center;gap:8px;background:rgba(32,112,38,.12);border:1px solid rgba(32,112,38,.4);
    color:var(--gold);padding:12px 16px;border-radius:12px;margin-bottom:18px;font-size:.9rem;font-weight:600}

/* confirm + resume actions */
.admin-dialog--sm{max-width:440px}
.admin-dialog--lg{max-width:700px}
.emp-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;display:inline-block;vertical-align:middle}
.emp-initial{display:inline-flex;align-items:center;justify-content:center;background:var(--grad);color:var(--on-acc);font-weight:800;font-family:'Plus Jakarta Sans';font-size:.9rem}
.emp-toolbar{display:flex;align-items:center;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.emp-toolbar h2{font-size:1.1rem;color:var(--head)}
.emp-search{flex:1;min-width:200px;max-width:420px;display:flex;align-items:center;gap:8px;background:var(--field-bg);
    border:1px solid var(--line);border-radius:50px;padding:0 16px;height:42px}
.emp-search svg{color:var(--muted);flex:none}
.emp-search input{flex:1;border:0;background:none;outline:none;color:var(--ink);font-size:.9rem;font-family:'Inter',sans-serif}
.emp-toolbar #addEmp{margin-left:auto}
.bulk-bar{display:none;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px;
    background:rgba(32,112,38,.08);border:1px solid rgba(32,112,38,.35);border-radius:12px;padding:10px 16px}
.bulk-bar.show{display:flex}
.bulk-count{font-weight:700;color:var(--gold);font-size:.9rem}
.bulk-actions{display:flex;gap:10px;flex-wrap:wrap}
.chk-col{width:40px;text-align:center}
.chk-col input{width:16px;height:16px;accent-color:var(--acc);cursor:pointer}
.emp-noresult{text-align:center;color:var(--muted);padding:20px}
.confirm-text{color:var(--ink);font-size:.95rem;line-height:1.6;margin:6px 0 22px}
.confirm-text strong{color:var(--head)}
.confirm-actions{display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap}
.btn-confirm-del{background:linear-gradient(135deg,#e8674f,#c0392b);color:#fff;box-shadow:none}
.btn-confirm-del:hover{filter:brightness(1.06)}
.resume-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}
.ra-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:9px;border:1px solid var(--line);
    background:var(--bg-2);color:var(--ink);font-weight:600;font-size:.82rem;cursor:pointer;transition:.2s;font-family:'Plus Jakarta Sans'}
.ra-btn svg{color:var(--gold);flex:none}
.ra-btn:hover{border-color:var(--acc);color:var(--gold)}

/* stats editor */
.admin-panel--mid{max-width:640px}
.admin-hint{color:var(--muted);font-size:.88rem;line-height:1.6;margin-bottom:18px}
.admin-hint code{background:var(--bg-2);border:1px solid var(--line);padding:1px 6px;border-radius:5px;color:var(--gold)}
.stats-form{display:flex;flex-direction:column;gap:10px}
.stats-head{display:grid;grid-template-columns:96px 84px 1fr;gap:12px;color:var(--muted);font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:0 2px}
.stats-row{display:grid;grid-template-columns:96px 84px 1fr;gap:12px}
.stats-form input{font-family:'Inter',sans-serif;font-size:.95rem;padding:11px 13px;border:1px solid var(--line);border-radius:10px;background:var(--field-bg);color:var(--ink);width:100%}
.stats-form input:focus{outline:none;border-color:var(--acc)}
.stats-form .btn{margin-top:10px;align-self:flex-start}
@media(max-width:560px){
    .stats-head{display:none}
    .stats-row{grid-template-columns:1fr;gap:8px;padding-bottom:12px;border-bottom:1px solid var(--line)}
}
.admin-form .field{margin-bottom:16px}
.admin-form .btn{margin-top:4px}

.admin-modal{position:fixed;inset:0;z-index:120;background:rgba(3,8,5,.86);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
    display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto;opacity:0;visibility:hidden;transition:.3s}
.admin-modal.open{opacity:1;visibility:visible}
.admin-dialog{width:100%;max-width:560px;margin:auto;background:var(--bg-soft);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);overflow:hidden}
.admin-dialog-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line)}
.admin-dialog-head h3{font-size:1.1rem;color:var(--head)}
.admin-dialog-body{padding:6px 22px 22px;max-height:72vh;overflow-y:auto}
.kv{display:grid;grid-template-columns:160px 1fr;gap:0;margin:0}
.kv dt{color:var(--muted);font-size:.82rem;padding:10px 0;border-bottom:1px solid var(--line);font-weight:600}
.kv dd{color:var(--ink);font-size:.9rem;padding:10px 0;border-bottom:1px solid var(--line);word-break:break-word;margin:0}
.kv dd i{color:var(--muted)}

@media(max-width:900px){
    .stat-cards{grid-template-columns:1fr 1fr}
    .admin-cols{grid-template-columns:1fr}
}
@media(max-width:760px){
    .admin-side{position:fixed;left:0;top:0;bottom:0;height:100vh;transform:translateX(-100%);transition:transform .3s;z-index:80}
    .admin-side.open{transform:none}
    .admin-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:70;display:block;opacity:0;visibility:hidden;transition:.3s}
    .admin-overlay.open{opacity:1;visibility:visible}
    .admin-burger{display:flex}
    .kv{grid-template-columns:1fr}
    .kv dt{padding-bottom:2px;border-bottom:0}.kv dd{padding-top:2px}
}
@media(max-width:520px){
    .stat-cards{grid-template-columns:1fr}
    .admin-uname{display:none}
    .admin-top-logout span{display:none}
    .admin-top-logout{padding:8px 11px}
}

@media(max-width:980px){
    .jobs-grid,.gallery-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
    .apply-grid{grid-template-columns:1fr;gap:36px}
}
@media(max-width:620px){
    .jobs-grid,.gallery-grid,.blog-grid{grid-template-columns:1fr}
}

/* ===== Apply modal ===== */
.apply-modal{position:fixed;inset:0;z-index:120;background:rgba(3,8,5,.86);
    -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
    display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto;
    opacity:0;visibility:hidden;transition:.3s}
.apply-modal.open{opacity:1;visibility:visible}
.apply-dialog{width:100%;max-width:680px;margin:auto;background:var(--bg-soft);border:1px solid var(--line);
    border-radius:20px;box-shadow:var(--shadow);overflow:hidden;transform:translateY(24px);transition:.3s}
.apply-modal.open .apply-dialog{transform:none}
.apply-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px 26px;
    border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--bg-soft);z-index:2}
.apply-eyebrow{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--gold)}
.apply-head h3{font-size:1.25rem;color:var(--head);margin-top:4px}
.apply-head #applyJobName{color:var(--gold)}
.apply-close{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:var(--bg-2);
    color:var(--ink);font-size:1.6rem;line-height:1;cursor:pointer;flex:none;transition:.25s}
.apply-close:hover{background:var(--grad);color:var(--on-acc);border-color:transparent}
.apply-body{padding:6px 26px 6px}
.form-section{border:0;margin:22px 0 0;padding:0;min-width:0}
.form-section legend{display:flex;align-items:center;gap:10px;font-family:'Plus Jakarta Sans';font-weight:800;
    font-size:1.02rem;color:var(--head);margin-bottom:14px;padding:0}
.fs-num{width:26px;height:26px;border-radius:8px;background:var(--grad);color:var(--on-acc);
    display:inline-flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;flex:none}
.field label i{color:#e8674f;font-style:normal;font-weight:700}
.hw-row,.phone-row{display:flex;align-items:center;gap:10px}
.hw-row input{width:100%}
.hw-unit{color:var(--muted);font-weight:600;font-size:.85rem}
.phone-cc{display:inline-flex;align-items:center;align-self:stretch;padding:0 14px;border:1px solid var(--line);
    border-radius:10px;background:var(--bg-2);color:var(--head);font-weight:700;flex:none}
.phone-row input{flex:1}
.same-addr{display:flex!important;align-items:center;gap:8px;font-weight:600!important;font-size:.84rem!important;
    color:var(--ink)!important;margin-bottom:8px;cursor:pointer}
.same-addr input{width:auto;accent-color:var(--acc)}
.radio-row{display:flex;flex-wrap:wrap;gap:10px}
.radio-pill{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border:1px solid var(--line);
    border-radius:50px;background:var(--field-bg);cursor:pointer;font-weight:600;font-size:.88rem;transition:.2s;margin:0!important}
.radio-pill input{width:auto;accent-color:var(--acc)}
.radio-pill:hover{border-color:var(--acc);color:var(--gold)}
.fresher-pill{margin-left:auto!important}
.exp-yes{display:none;margin-top:4px}
.exp-yes.show{display:block;animation:fadeUp .3s ease both}
textarea.is-locked{opacity:.65;cursor:not-allowed}
.file-drop{display:flex;align-items:center;gap:12px;padding:16px 18px;border:1.5px dashed var(--line);
    border-radius:12px;background:var(--field-bg);color:var(--muted);cursor:pointer;transition:.25s;font-size:.9rem}
.file-drop:hover{border-color:var(--acc);color:var(--gold)}
.file-drop svg{color:var(--gold);flex:none}
.file-drop input{display:none}
.file-drop.file-bad{border-color:#e8674f;color:#e8674f}
.locked-note{font-weight:500;font-size:.72rem;color:var(--muted);text-transform:none;letter-spacing:0}
.field select.locked-field:disabled{opacity:1;cursor:not-allowed;background-color:var(--bg-2);
    color:var(--head);font-weight:600;border-style:dashed}
.ref-note{display:block;margin-top:5px;font-size:.76rem;font-weight:600;min-height:1em}
.ref-note.ref-ok{color:var(--gold)}
.ref-note.ref-bad{color:#e8674f}
.apply-foot{display:flex;justify-content:flex-end;gap:12px;padding:18px 26px 24px;border-top:1px solid var(--line);
    position:sticky;bottom:0;background:var(--bg-soft)}
.apply-foot .btn-ghost{padding:12px 22px}

/* Apply success (thank-you) view inside the popup */
.apply-success{display:none;flex-direction:column;align-items:center;justify-content:center;text-align:center;
    padding:48px 30px 56px;gap:6px}
.apply-dialog.is-success .apply-success{display:flex;animation:fadeUp .4s ease both}
.apply-dialog.is-success .apply-form{display:none}
.apply-dialog.is-success .apply-head{border-bottom:0}
.as-ic{width:84px;height:84px;border-radius:50%;background:var(--grad);color:var(--on-acc);
    display:flex;align-items:center;justify-content:center;margin-bottom:10px;
    box-shadow:0 16px 34px -16px rgba(32,112,38,.6)}
.apply-success h3{font-size:1.6rem;color:var(--head)}
.apply-success p{color:var(--muted);font-size:.95rem;line-height:1.6}

.apply-toast{position:fixed;left:50%;top:90px;transform:translateX(-50%);z-index:90;display:flex;align-items:center;gap:12px;
    background:var(--bg-soft);border:1px solid var(--acc);border-left:4px solid var(--acc);border-radius:12px;
    padding:14px 18px;box-shadow:var(--shadow);max-width:92%;animation:fadeUp .4s ease both}
.apply-toast .at-ic{width:30px;height:30px;border-radius:50%;background:var(--grad);color:var(--on-acc);
    display:flex;align-items:center;justify-content:center;flex:none}
.apply-toast strong{color:var(--head)}
.at-close{background:none;border:0;color:var(--muted);font-size:1.4rem;cursor:pointer;line-height:1;margin-left:6px}
@media(max-width:560px){
    .apply-foot{flex-direction:column-reverse}
    .apply-foot .btn{width:100%;justify-content:center}
    .fresher-pill{margin-left:0!important}
}
