/* ============================================================
   LAKSHAY CAPITAL — site.css
   Brand: Blue #1A56DB · Gold #C9963C
   Fonts: Playfair Display + DM Sans
   ============================================================ */

:root {
  --blue:        #1A56DB;
  --blue-dark:   #1040B0;
  --blue-light:  #E8F0FE;
  --gold:        #C9963C;
  --gold-light:  #FBF0DC;
  --dark:        #0D1B2A;
  --dark-2:      #1C2E45;
  --gray:        #64748B;
  --gray-light:  #F1F5F9;
  --white:       #FFFFFF;
  --border:      #E2E8F0;
  --shadow:      0 4px 24px rgba(26,86,219,.08);
  --shadow-lg:   0 12px 48px rgba(26,86,219,.16);
  --radius:      16px;
  --radius-sm:   8px;
  --nav-h:       72px;
  --ease:        cubic-bezier(.4,0,.2,1);
  --trans:       .3s var(--ease);
  --container:   1180px;
}

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'DM Sans',sans-serif;color:var(--dark);background:var(--white);line-height:1.65;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
address{font-style:normal}

/* ── Typography ─────────────────────────────────────────────── */
h1,h2,h3,h4{font-family:'Playfair Display',serif;line-height:1.2;font-weight:700}
h1{font-size:clamp(2rem,5vw,3.8rem);font-weight:900}
h2{font-size:clamp(1.5rem,3vw,2.5rem)}
h3{font-size:1.25rem}
em{font-style:italic;color:var(--gold)}
p{font-size:1rem;color:var(--gray);line-height:1.7}

/* ── Container ──────────────────────────────────────────────── */
.container{max-width:var(--container);margin:0 auto;padding:0 clamp(16px,4vw,32px)}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn-primary{
  display:inline-block;background:var(--blue);color:var(--white);
  padding:.75rem 2rem;border-radius:50px;font-weight:600;font-size:.95rem;
  border:none;cursor:pointer;transition:background var(--trans),transform var(--trans),box-shadow var(--trans);
  white-space:nowrap;text-align:center;
}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(26,86,219,.3)}
.btn-primary.large{padding:1rem 2.5rem;font-size:1.05rem}
.btn-primary.full{width:100%;display:block}

.btn-outline{
  display:inline-block;border:2px solid var(--white);color:var(--white);
  padding:.7rem 1.8rem;border-radius:50px;font-weight:600;font-size:.95rem;
  transition:background var(--trans),color var(--trans);white-space:nowrap;
}
.btn-outline:hover{background:var(--white);color:var(--blue)}

/* ── Nav ─────────────────────────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,.97);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);transition:box-shadow var(--trans);
}
.nav.scrolled{box-shadow:var(--shadow)}
.nav-inner{
  max-width:var(--container);margin:0 auto;padding:0 clamp(16px,4vw,32px);
  height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.nav-logo img{height:44px;width:auto}
.nav-links{display:flex;gap:2rem}
.nav-links a{
  font-size:.9rem;font-weight:500;color:var(--dark);position:relative;padding-bottom:3px;
  transition:color var(--trans);
}
.nav-links a::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:var(--gold);border-radius:2px;transform:scaleX(0);
  transition:transform var(--trans);
}
.nav-links a:hover,.nav-links a.active{color:var(--blue)}
.nav-links a.active::after,.nav-links a:hover::after{transform:scaleX(1)}

.btn-nav{
  background:var(--blue);color:var(--white);padding:.5rem 1.25rem;border-radius:50px;
  font-size:.85rem;font-weight:600;white-space:nowrap;
  transition:background var(--trans),transform var(--trans);
}
.btn-nav:hover{background:var(--blue-dark);transform:translateY(-1px)}

.hamburger{
  display:none;flex-direction:column;gap:5px;cursor:pointer;
  border:none;background:none;padding:6px;border-radius:6px;
  transition:background var(--trans);
}
.hamburger:hover{background:var(--gray-light)}
.hamburger span{display:block;width:22px;height:2px;background:var(--dark);border-radius:2px;transition:var(--trans)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{
  display:none;flex-direction:column;padding:0 clamp(16px,4vw,32px) 12px;
  border-top:1px solid var(--border);background:var(--white);
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  padding:12px 0;font-weight:500;color:var(--dark);
  border-bottom:1px solid var(--border);transition:color var(--trans);
}
.mobile-menu a:last-child{border-bottom:none}
.mobile-menu a:hover{color:var(--blue)}

/* ── Section Tags ─────────────────────────────────────────────── */
.section-tag{
  display:inline-block;background:var(--blue-light);color:var(--blue);
  font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:4px 14px;border-radius:50px;margin-bottom:1rem;
}
.section-tag.light{background:rgba(255,255,255,.2);color:var(--white)}

.section-head{text-align:center;margin-bottom:3rem}
.section-head h2{margin-bottom:.75rem}
.section-head p{max-width:560px;margin:0 auto}
.section-head.light h2{color:var(--white)}
.section-head.light p{color:rgba(255,255,255,.8)}

/* ── Hero ─────────────────────────────────────────────────────── */
.hero{
  min-height:100vh;
  background:linear-gradient(135deg,var(--dark) 0%,var(--dark-2) 55%,#1A3060 100%);
  display:flex;flex-direction:column;justify-content:center;
  padding:calc(var(--nav-h) + 60px) clamp(16px,4vw,32px) 60px;
  position:relative;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-circle{position:absolute;border-radius:50%;
  background:radial-gradient(circle,rgba(201,150,60,.12),transparent 70%)}
.hero-circle.c1{width:min(600px,100vw);height:min(600px,100vw);top:-150px;right:-100px}
.hero-circle.c2{width:400px;height:400px;bottom:-100px;left:-80px}
.hero-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:60px 60px;
}
.hero-content{max-width:var(--container);margin:0 auto;width:100%;position:relative;z-index:1}
.hero-tag{
  display:inline-block;font-size:.75rem;letter-spacing:.1em;font-weight:600;
  color:var(--gold);background:rgba(201,150,60,.1);border:1px solid rgba(201,150,60,.3);
  padding:4px 14px;border-radius:50px;margin-bottom:1.5rem;
}
.hero-title{color:var(--white);margin-bottom:1.25rem;max-width:680px}
.hero-sub{color:rgba(255,255,255,.72);font-size:clamp(1rem,2vw,1.15rem);max-width:540px;margin-bottom:2.5rem}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:4rem}

.hero-stats{
  max-width:var(--container);margin:0 auto;width:100%;position:relative;z-index:1;
  display:flex;align-items:center;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius);padding:clamp(1rem,3vw,2rem) clamp(1rem,4vw,2.5rem);
  backdrop-filter:blur(8px);flex-wrap:wrap;gap:1rem;
}
.stat{flex:1;text-align:center;min-width:100px}
.stat-num{display:block;font-family:'Playfair Display',serif;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:900;color:var(--white)}
.stat-num sup{font-size:.85rem;color:var(--gold)}
.stat-label{font-size:.8rem;color:rgba(255,255,255,.6);font-weight:500}
.stat-divider{width:1px;height:48px;background:rgba(255,255,255,.15);flex-shrink:0}

/* ── About Strip ──────────────────────────────────────────────── */
.about-strip{padding:clamp(60px,8vw,100px) 0}
.about-strip .container{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.strip-text h2{margin-bottom:1rem}
.strip-text p{margin-bottom:2rem}
.strip-image{position:relative}
.strip-image img{border-radius:var(--radius);width:100%;height:420px;object-fit:cover;box-shadow:var(--shadow-lg)}
.strip-badge{
  position:absolute;bottom:-20px;right:-20px;
  background:var(--gold);color:var(--white);padding:1rem 1.5rem;
  border-radius:var(--radius-sm);text-align:center;box-shadow:var(--shadow);
}
.strip-badge strong{display:block;font-size:1.1rem;font-weight:700}
.strip-badge span{font-size:.8rem;opacity:.9}

/* ── Values ───────────────────────────────────────────────────── */
.values{padding:clamp(60px,8vw,100px) 0;background:var(--gray-light)}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:3rem}
.value-card{
  background:var(--white);border-radius:var(--radius);padding:2rem;
  box-shadow:var(--shadow);transition:transform var(--trans),box-shadow var(--trans);
  border:1px solid var(--border);
}
.value-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.value-icon{font-size:2rem;margin-bottom:1rem}
.value-card h3{margin-bottom:.5rem;font-size:1.1rem}

/* ── Clients ──────────────────────────────────────────────────── */
.clients-served{padding:clamp(60px,8vw,100px) 0}
.clients-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:3rem}
.client-img{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4}
.client-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.client-img:hover img{transform:scale(1.05)}
.client-img span{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(transparent,rgba(13,27,42,.85));
  color:var(--white);padding:1.5rem 1rem .75rem;
  font-size:.85rem;font-weight:600;
}

/* ── Why Partner ──────────────────────────────────────────────── */
.why-partner{
  padding:clamp(60px,8vw,100px) 0;
  background:linear-gradient(135deg,var(--dark) 0%,var(--dark-2) 100%);
}
.quote-hero{
  font-family:'Playfair Display',serif;font-size:1.05rem;font-style:italic;
  color:rgba(255,255,255,.7);border-left:3px solid var(--gold);padding-left:1.5rem;
  margin:1.5rem auto 0;max-width:600px;text-align:left;
}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.why-card{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius);padding:2rem;transition:background var(--trans);
}
.why-card:hover{background:rgba(255,255,255,.1)}
.why-num{font-family:'Playfair Display',serif;font-size:2.5rem;font-weight:900;color:var(--gold);opacity:.5;display:block;margin-bottom:.5rem}
.why-card h3{color:var(--white);margin-bottom:.75rem;font-size:1.05rem}
.why-card p{color:rgba(255,255,255,.65);font-size:.9rem}

/* ── CTA Banner ───────────────────────────────────────────────── */
.cta-banner{
  padding:clamp(50px,7vw,80px) 0;
  background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%);
  text-align:center;
}
.cta-banner h2{color:var(--white);margin-bottom:.75rem}
.cta-banner p{color:rgba(255,255,255,.8);margin-bottom:2rem}

/* ── Footer ───────────────────────────────────────────────────── */
.footer{background:var(--dark);padding:clamp(40px,6vw,60px) 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1.5fr;gap:3rem;padding-bottom:3rem}
.footer-brand img{height:40px;margin-bottom:1rem}
.footer-brand p{color:rgba(255,255,255,.6);font-size:.9rem}
.footer-brand .cin{color:rgba(255,255,255,.35);font-size:.75rem;margin-top:.5rem}
.footer-links{display:flex;flex-direction:column;gap:.5rem}
.footer-links h4,.footer-contact h4{color:var(--white);font-family:'DM Sans',sans-serif;font-weight:700;margin-bottom:1rem;font-size:.95rem}
.footer-links a{color:rgba(255,255,255,.6);font-size:.9rem;transition:color var(--trans)}
.footer-links a:hover{color:var(--gold)}
.footer-contact p{color:rgba(255,255,255,.6);font-size:.9rem;margin-bottom:.5rem}
.footer-contact a{color:rgba(255,255,255,.6);transition:color var(--trans)}
.footer-contact a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:1.5rem 0;text-align:center}
.footer-bottom p{color:rgba(255,255,255,.4);font-size:.8rem}
.footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

.footer-bottom-left {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    color: #64748b
}

.shobi-link {
    display: flex;
    align-items: center;
    gap: 5px;
    text-decoration: none;
    color: inherit;
}

    .shobi-link img {
        height: 20px;
    }

.footer-bottom-right p {
    margin: 0;
    text-align: right;
}

/* ── Page Hero ────────────────────────────────────────────────── */
.page-hero{
  padding:calc(var(--nav-h) + 80px) clamp(16px,4vw,32px) 80px;
  background:linear-gradient(135deg,var(--dark) 0%,var(--dark-2) 60%,#1A3060 100%);
  position:relative;overflow:hidden;text-align:center;
}
.page-hero-bg{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);
  background-size:60px 60px;
}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{color:var(--white);margin:.75rem 0}
.page-hero p{color:rgba(255,255,255,.72);font-size:1.1rem;max-width:500px;margin:0 auto}

/* ── About Page ───────────────────────────────────────────────── */
.founder-section{padding:clamp(60px,8vw,100px) 0}
.founder-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(2rem,5vw,5rem);align-items:start}
.founder-image-wrap{position:relative}
.founder-img{width:100%;border-radius:var(--radius);height:520px;object-fit:cover;box-shadow:var(--shadow-lg)}
.founder-badge-group{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}
.founder-badge{background:var(--blue-light);color:var(--blue);padding:.5rem 1rem;border-radius:var(--radius-sm);font-weight:600;font-size:.85rem;text-align:center}
.founder-badge.gold{background:var(--gold-light);color:var(--gold)}
.founder-text h2{margin:.5rem 0 1rem}
.lead{font-size:1.05rem;color:var(--dark);margin-bottom:1.5rem}
.founder-list{margin-bottom:2rem}
.founder-list li{padding:.5rem 0;font-size:.95rem;border-bottom:1px solid var(--border)}
.key-impacts h3{margin-bottom:1rem}
.impact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.impact-item{background:var(--blue-light);border-radius:var(--radius-sm);padding:1rem;display:flex;flex-direction:column}
.impact-item strong{color:var(--blue);font-size:1.1rem;font-family:'Playfair Display',serif}
.impact-item span{font-size:.8rem;color:var(--gray);margin-top:.25rem}

.vm-section{padding:clamp(50px,7vw,80px) 0;background:var(--gray-light)}
.vm-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:3rem}
.vm-card{background:var(--white);border-radius:var(--radius);padding:2.5rem;border-top:4px solid var(--blue);box-shadow:var(--shadow)}
.vm-card.mission{border-color:var(--gold)}
.vm-icon{font-size:2.5rem;margin-bottom:1rem}
.vm-card h3{margin-bottom:.75rem;font-size:1.4rem}
.vm-desc{background:var(--white);border-radius:var(--radius);padding:2rem;border:1px solid var(--border)}
.vm-desc p{font-size:1rem;color:var(--dark);line-height:1.8}

.registrations{padding:clamp(60px,8vw,80px) 0}
.reg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:3rem}
.reg-card{border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem;text-align:center;background:var(--white);box-shadow:var(--shadow)}
.reg-icon{font-size:2rem;margin-bottom:.75rem}
.reg-card h3{font-size:1rem;margin-bottom:.5rem}
.reg-card p{font-size:.85rem}
.cert-img-wrap{margin-top:3rem;border-radius:var(--radius);overflow:hidden;max-height:300px}
.cert-img{width:100%;height:300px;object-fit:cover}

/* ── Services Page ────────────────────────────────────────────── */
.services-section{padding:clamp(60px,8vw,100px) 0}
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:3rem}
.service-card{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius);
  padding:2.5rem;box-shadow:var(--shadow);position:relative;overflow:hidden;
  transition:transform var(--trans),box-shadow var(--trans);
}
.service-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--blue),var(--gold));
}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.service-icon{font-size:2.5rem;margin-bottom:1rem}
.service-card h3{margin-bottom:.75rem}
.service-card>p{margin-bottom:1rem}
.service-card ul{display:flex;flex-direction:column;gap:.4rem}
.service-card ul li{font-size:.9rem;color:var(--blue);font-weight:500;padding-left:1rem;position:relative}
.service-card ul li::before{content:'›';position:absolute;left:0;color:var(--gold)}

.operating-model{padding:clamp(60px,8vw,100px) 0;background:linear-gradient(135deg,var(--dark) 0%,var(--dark-2) 100%)}
.model-steps{display:flex;align-items:stretch;gap:1rem;margin-top:3rem;flex-wrap:wrap}
.model-step{
  flex:1;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius);padding:2rem;min-width:200px;
}
.step-num{font-family:'Playfair Display',serif;font-size:2.5rem;font-weight:900;color:var(--gold);opacity:.5;display:block;margin-bottom:.5rem}
.step-content h3{color:var(--white);margin-bottom:.5rem}
.step-content p{color:rgba(255,255,255,.65);font-size:.9rem}
.model-arrow{font-size:1.5rem;color:var(--gold);flex-shrink:0;align-self:center;margin-top:.5rem}

.sourcing-channels{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.channel-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:1.75rem}
.channel-card h4{color:var(--gold);margin-bottom:.5rem;font-family:'DM Sans',sans-serif;font-size:1rem}
.channel-card p{color:rgba(255,255,255,.65);font-size:.9rem}

/* ── Roadmap Page ─────────────────────────────────────────────── */
.roadmap-section{padding:clamp(60px,8vw,100px) 0}
.timeline{display:flex;flex-direction:column;gap:2rem;position:relative}
.timeline::before{
  content:'';position:absolute;left:50%;top:0;bottom:0;width:2px;
  background:linear-gradient(var(--blue),var(--gold));transform:translateX(-50%);
}
.timeline-item{display:grid;grid-template-columns:1fr 60px 1fr;gap:0;align-items:start}
.timeline-dot-wrap{display:flex;justify-content:center;padding-top:1.5rem}
.timeline-dot{
  width:20px;height:20px;border-radius:50%;background:var(--blue);
  border:4px solid var(--white);box-shadow:0 0 0 3px var(--blue);
  flex-shrink:0;
}
.timeline-item.active .timeline-dot{background:var(--gold);box-shadow:0 0 0 3px var(--gold)}
.timeline-content{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow)}
.timeline-content.left{grid-column:1}
.timeline-milestone{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:1rem;
}
.milestone-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gray)}
.milestone-value{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;color:var(--blue)}
.phase-badge{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:3px 10px;border-radius:50px;background:var(--blue-light);color:var(--blue);margin-bottom:.75rem}
.phase-badge.current{background:var(--gold-light);color:var(--gold)}
.timeline-content h3{color:var(--gold);font-size:1rem;margin-bottom:.25rem}
.timeline-content h4{font-size:1.2rem;margin-bottom:.75rem}
.timeline-content p{margin-bottom:.75rem;font-size:.9rem}
.timeline-content ul{display:flex;flex-direction:column;gap:.35rem}
.timeline-content ul li{font-size:.88rem;color:var(--dark)}

.roadmap-summary{margin-top:4rem}
.roadmap-summary h3{text-align:center;margin-bottom:1.5rem}
.summary-table{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow)}
.summary-row{display:grid;grid-template-columns:2fr 1fr 1.5fr 1fr;padding:1rem 1.5rem;gap:1rem;align-items:center}
.summary-row.header{background:var(--blue);color:var(--white);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}
.summary-row:not(.header){border-top:1px solid var(--border);background:var(--white);font-size:.9rem}
.summary-row:nth-child(even):not(.header){background:var(--gray-light)}
.summary-row.gold{background:var(--gold-light) !important}
.summary-row.gold strong{color:var(--gold)}

/* ── Contact Page ─────────────────────────────────────────────── */
.contact-section{padding:clamp(50px,7vw,80px) 0}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.contact-form-wrap h2,.contact-info-wrap h2{margin-bottom:.5rem}
.contact-form-wrap>p{margin-bottom:2rem}
.contact-form{display:flex;flex-direction:column;gap:1.25rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-group label{font-size:.85rem;font-weight:600;color:var(--dark)}
.form-group input,.form-group select,.form-group textarea{
  border:1.5px solid var(--border);border-radius:var(--radius-sm);
  padding:.75rem 1rem;font-family:'DM Sans',sans-serif;font-size:.95rem;
  background:var(--white);transition:border-color var(--trans),box-shadow var(--trans);outline:none;
  width:100%;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,86,219,.1);
}
.form-group input.input-error,.form-group select.input-error,.form-group textarea.input-error{border-color:#EF4444}
.field-error,.validation-summary{color:#EF4444;font-size:.8rem;margin-top:.25rem}
.validation-summary{background:#FEF2F2;border:1px solid #FCA5A5;border-radius:var(--radius-sm);padding:.75rem 1rem;margin-bottom:.5rem}
.form-note{font-size:.75rem;color:var(--gray);text-align:center;margin-top:.5rem}

.form-success{text-align:center;padding:3rem 2rem;background:var(--gray-light);border-radius:var(--radius);border:1px solid var(--border)}
.success-icon{font-size:3rem;margin-bottom:1rem}
.form-success h3{margin-bottom:.5rem}

.info-cards{display:flex;flex-direction:column;gap:1rem;margin:1.5rem 0 2rem}
.info-card{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--white);transition:box-shadow var(--trans)}
.info-card:hover{box-shadow:var(--shadow)}
.info-icon{font-size:1.5rem;flex-shrink:0}
.info-card h4{font-size:.85rem;font-weight:700;color:var(--dark);margin-bottom:.25rem;font-family:'DM Sans',sans-serif}
.info-card a,.info-card p{font-size:.9rem;color:var(--gray)}
.info-card a:hover{color:var(--blue)}

.map-embed{margin-bottom:2rem;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}

.partner-cta{background:var(--blue-light);border-radius:var(--radius);padding:2rem}
.partner-cta h3{margin-bottom:.5rem;font-size:1.1rem}
.partner-cta p{margin-bottom:1.5rem;font-size:.9rem}
.partner-steps{display:flex;gap:1rem;justify-content:space-between}
.pstep{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;text-align:center;color:var(--dark)}
.pstep span{width:36px;height:36px;border-radius:50%;background:var(--blue);color:var(--white);display:flex;align-items:center;justify-content:center;font-weight:700}

/* ── Animations ───────────────────────────────────────────────── */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.delay-1{transition-delay:.15s}
.delay-2{transition-delay:.3s}
.delay-3{transition-delay:.45s}
.delay-4{transition-delay:.6s}

/* ── Responsive: Tablet (≤1024px) ────────────────────────────── */
@media(max-width:1024px){
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .reg-grid{grid-template-columns:repeat(2,1fr)}
  .about-strip .container{grid-template-columns:1fr;gap:3rem}
  .strip-image img{height:340px}
  .strip-badge{position:static;margin-top:1rem;width:fit-content}
  .founder-grid{grid-template-columns:1fr;gap:3rem}
  .founder-img{height:380px}
  .clients-gallery{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-brand{grid-column:1/-1}
}

/* ── Responsive: Mobile (≤768px) ─────────────────────────────── */
@media(max-width:768px){
  /* Nav */
  .nav-links,.btn-nav{display:none}
  .hamburger{display:flex}

  /* Hero */
  .hero-stats{flex-wrap:wrap;gap:1rem;justify-content:center}
  .stat{min-width:calc(50% - 1rem)}
  .stat-divider{display:none}
  .hero-cta{flex-direction:column;align-items:flex-start}

  /* Grids → single column */
  .values-grid,.services-grid,.vm-grid,.sourcing-channels{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .reg-grid{grid-template-columns:repeat(2,1fr)}
  .clients-gallery{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .footer-brand{grid-column:auto}
  .contact-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}

  /* About strip */
  .about-strip .container{grid-template-columns:1fr}
  .strip-badge{position:static;margin-top:1rem}
  .strip-image img{height:260px}
  .founder-img{height:280px}
  .impact-grid{grid-template-columns:1fr 1fr}

  /* Roadmap timeline → stacked */
  .timeline::before{left:20px}
  .timeline-item{grid-template-columns:40px 1fr;grid-template-rows:auto auto}
  .timeline-dot-wrap{padding-top:1.2rem}
  .timeline-content.left{grid-column:2;grid-row:1}
  .timeline-milestone{grid-column:2;grid-row:2;flex-direction:row;justify-content:flex-start;gap:1rem;padding:.5rem 0 0}
  .summary-row{grid-template-columns:1.8fr 1fr 1fr;font-size:.8rem;padding:.75rem 1rem}
  .summary-row span:nth-child(3){display:none}
  .summary-row.header span:nth-child(3){display:none}

  /* Model steps */
  .model-steps{flex-direction:column}
  .model-arrow{transform:rotate(90deg);text-align:center}
}

/* ── Responsive: Small mobile (≤480px) ───────────────────────── */
@media(max-width:480px){
  .clients-gallery{grid-template-columns:1fr 1fr}
  .reg-grid{grid-template-columns:1fr}
  .impact-grid{grid-template-columns:1fr}
  .partner-steps{flex-direction:column;align-items:center}
  .hero-cta .btn-outline{text-align:center;width:100%}
}

/* ── Accessibility / Focus ────────────────────────────────────── */
:focus-visible{outline:3px solid var(--blue);outline-offset:3px;border-radius:4px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
