/* ============================================
   PATRISOFT OUTSOURCING — Main Stylesheet
   Colors derived from logo: Navy, Blue, Cyan
   ============================================ */

/* ---------- Custom Properties ---------- */
:root {
    --navy:        #0f1d35;
    --navy-mid:    #162847;
    --navy-light:  #1e3560;
    --blue:        #3366b8;
    --blue-light:  #4a80d4;
    --cyan:        #22c1d6;
    --cyan-light:  #5adaea;
    --cyan-pale:   #e8f9fb;

    --white:       #ffffff;
    --off-white:   #f6f8fc;
    --gray-50:     #f0f3f8;
    --gray-100:    #e2e7f0;
    --gray-200:    #c8d0de;
    --gray-300:    #a3aec2;
    --gray-400:    #7b8aa3;
    --gray-500:    #586580;
    --gray-600:    #3d4a61;
    --gray-700:    #283548;

    --accent:      var(--cyan);
    --accent-glow: rgba(34,193,214,0.12);

    --font-heading: 'Instrument Serif', Georgia, serif;
    --font-body:    'DM Sans', system-ui, -apple-system, sans-serif;

    --container-lg: 1200px;
    --container-md: 960px;
    --container-sm: 720px;

    --section-py:  clamp(4.5rem, 8vw, 7.5rem);
    --radius:      10px;
    --radius-lg:   16px;
    --shadow-sm:   0 1px 3px rgba(15,29,53,0.06);
    --shadow-md:   0 4px 16px rgba(15,29,53,0.08);
    --shadow-lg:   0 12px 40px rgba(15,29,53,0.1);
    --shadow-glow: 0 4px 24px rgba(34,193,214,0.25);

    --ease:        cubic-bezier(0.25,0.46,0.45,0.94);
    --ease-spring: cubic-bezier(0.34,1.56,0.64,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{font-family:var(--font-body);font-size:1rem;line-height:1.72;color:var(--gray-500);background:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color .3s var(--ease)}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,textarea,select{font-family:inherit;font-size:inherit}

/* ---------- Utility ---------- */
.container{width:min(var(--container-lg),92%);margin-inline:auto}
.container--md{width:min(var(--container-md),92%);margin-inline:auto}
.container--sm{width:min(var(--container-sm),92%);margin-inline:auto}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ---------- Typography ---------- */
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--navy);line-height:1.18;font-weight:400}
h1{font-size:clamp(2.5rem,5.5vw,4rem)}
h2{font-size:clamp(1.9rem,3.8vw,2.8rem)}
h3{font-size:clamp(1.35rem,2.4vw,1.75rem)}
h4{font-size:1.15rem;font-family:var(--font-body);font-weight:600;color:var(--navy)}

p + p { margin-top: 1rem; }

.section-label{
    display:inline-block;font-family:var(--font-body);font-size:.72rem;
    font-weight:700;letter-spacing:.14em;text-transform:uppercase;
    color:var(--cyan);background:var(--accent-glow);
    padding:.4em 1.1em;border-radius:100px;margin-bottom:1rem;
}
.section-intro{max-width:600px;font-size:1.08rem;color:var(--gray-400);margin-top:.8rem}

/* ---------- Buttons ---------- */
.btn{
    display:inline-flex;align-items:center;gap:.5rem;
    padding:.8rem 1.7rem;font-size:.92rem;font-weight:600;
    border-radius:8px;transition:all .35s var(--ease);position:relative;
}
.btn-primary{
    background:linear-gradient(135deg,var(--blue),var(--cyan));
    color:var(--white);box-shadow:var(--shadow-glow);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(34,193,214,.4)}
.btn-outline{
    border:2px solid var(--gray-100);color:var(--navy);background:var(--white);
}
.btn-outline:hover{border-color:var(--cyan);color:var(--cyan)}
.btn-white{background:var(--white);color:var(--navy);box-shadow:var(--shadow-md)}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-link{
    color:var(--blue);font-weight:600;padding:0;font-size:.92rem;
}
.btn-link:hover{color:var(--cyan)}
.btn-link .arrow{transition:transform .3s var(--ease)}
.btn-link:hover .arrow{transform:translateX(4px)}

/* ============================================
   HEADER / NAVIGATION
   ============================================ */
.site-header{
    position:fixed;top:0;left:0;right:0;z-index:1000;
    background:rgba(255,255,255,.92);backdrop-filter:blur(14px);
    border-bottom:1px solid rgba(15,29,53,.05);
    transition:box-shadow .3s var(--ease);
}
.site-header.scrolled{box-shadow:var(--shadow-md)}

.header-inner{
    display:flex;align-items:center;justify-content:space-between;
    height:78px;
}
.logo{display:flex;align-items:center;gap:.6rem}
.logo img{height:66px;width:auto}
.logo-text{font-family:var(--font-body);font-weight:700;font-size:1.05rem;color:var(--navy);line-height:1.2}
.logo-text span{display:block;font-size:.72rem;font-weight:500;color:var(--gray-400);letter-spacing:.06em;text-transform:uppercase}

.main-nav{display:flex;align-items:center;gap:2rem}
.main-nav a{
    font-size:.9rem;font-weight:500;color:var(--gray-500);
    padding:.4rem 0;position:relative;
}
.main-nav a::after{
    content:'';position:absolute;bottom:0;left:0;width:0;height:2px;
    background:var(--cyan);transition:width .3s var(--ease);
}
.main-nav a:hover,
.main-nav a.active{color:var(--navy)}
.main-nav a:hover::after,
.main-nav a.active::after{width:100%}

.header-cta{margin-left:.5rem}

/* Mobile menu toggle */
.menu-toggle{
    display:none;flex-direction:column;gap:5px;padding:8px;
}
.menu-toggle span{
    display:block;width:24px;height:2px;background:var(--navy);
    transition:all .3s var(--ease);border-radius:2px;
}
.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ============================================
   HERO SECTIONS
   ============================================ */
.hero{
    padding-top:clamp(7rem,14vw,10rem);
    padding-bottom:var(--section-py);
    position:relative;overflow:hidden;
}
.hero--home{
    background:linear-gradient(160deg,var(--off-white) 0%,var(--white) 50%,var(--cyan-pale) 100%);
    min-height:85vh;display:flex;align-items:center;
}
.hero--home::before{
    content:'';position:absolute;top:-120px;right:-180px;
    width:600px;height:600px;border-radius:50%;
    background:radial-gradient(circle,rgba(34,193,214,.08) 0%,transparent 70%);
    pointer-events:none;
}
.hero--home::after{
    content:'';position:absolute;bottom:-100px;left:-100px;
    width:400px;height:400px;border-radius:50%;
    background:radial-gradient(circle,rgba(51,102,184,.06) 0%,transparent 70%);
    pointer-events:none;
}
.hero__grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.hero__content{position:relative;z-index:2}
.hero__title{margin-bottom:1.2rem}
.hero__title em{font-style:italic;color:var(--blue)}
.hero__desc{font-size:1.12rem;color:var(--gray-400);max-width:500px;margin-bottom:2rem}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero__visual{position:relative;z-index:1}

.hero__stats{
    display:flex;gap:2.5rem;margin-top:2.5rem;padding-top:2rem;
    border-top:1px solid var(--gray-100);
}
.hero__stat-number{
    font-family:var(--font-heading);font-size:2.2rem;color:var(--navy);line-height:1;
}
.hero__stat-label{font-size:.82rem;color:var(--gray-400);margin-top:.2rem}

/* Page hero (inner pages) */
.hero--page{
    background:var(--navy);color:var(--white);text-align:center;
    padding-top:clamp(8rem,12vw,10rem);padding-bottom:clamp(3rem,6vw,5rem);
    position:relative;overflow:hidden;
}
.hero--page::before{
    content:'';position:absolute;inset:0;
    background:
        radial-gradient(ellipse at 20% 80%,rgba(34,193,214,.12) 0%,transparent 50%),
        radial-gradient(ellipse at 80% 20%,rgba(51,102,184,.1) 0%,transparent 50%);
    pointer-events:none;
}
.hero--page h1{color:var(--white);margin-bottom:.6rem}
.hero--page p{color:var(--gray-300);font-size:1.1rem;max-width:600px;margin-inline:auto}
.breadcrumb{
    display:flex;justify-content:center;gap:.5rem;
    font-size:.82rem;color:var(--gray-400);margin-top:1.2rem;
}
.breadcrumb a{color:var(--cyan)}
.breadcrumb a:hover{text-decoration:underline}

/* ============================================
   SECTION PATTERNS
   ============================================ */
.section{padding:var(--section-py) 0}
.section--gray{background:var(--off-white)}
.section--dark{background:var(--navy);color:var(--gray-300)}
.section--dark h2,.section--dark h3,.section--dark h4{color:var(--white)}
.section--dark .section-label{background:rgba(34,193,214,.15)}

.section-header{margin-bottom:3rem}
.section-header--center{text-align:center}
.section-header--center .section-intro{margin-inline:auto}

/* ============================================
   CARDS
   ============================================ */
.card{
    background:var(--white);border-radius:var(--radius-lg);
    border:1px solid var(--gray-100);padding:2rem;
    transition:all .4s var(--ease);position:relative;overflow:hidden;
}
.card:hover{
    border-color:transparent;box-shadow:var(--shadow-lg);
    transform:translateY(-4px);
}
.card__icon{
    width:52px;height:52px;border-radius:12px;display:flex;
    align-items:center;justify-content:center;margin-bottom:1.2rem;
    background:var(--accent-glow);color:var(--cyan);font-size:1.4rem;
}
.card__title{margin-bottom:.6rem}
.card__text{font-size:.92rem;color:var(--gray-400)}

/* Service card variant */
.service-card{padding:2.2rem}
.service-card .card__icon{
    width:56px;height:56px;border-radius:14px;
    background:linear-gradient(135deg,var(--accent-glow),rgba(51,102,184,.08));
}

/* Case study card */
.case-card{padding:0;overflow:hidden}
.case-card__img{
    width:100%;height:220px;object-fit:cover;
    transition:transform .5s var(--ease);
}
.case-card:hover .case-card__img{transform:scale(1.05)}
.case-card__body{padding:1.8rem}
.case-card__tag{
    display:inline-block;font-size:.72rem;font-weight:700;
    text-transform:uppercase;letter-spacing:.08em;
    color:var(--cyan);margin-bottom:.6rem;
}
.case-card__title{font-size:1.2rem;margin-bottom:.5rem}
.case-card__text{font-size:.88rem;color:var(--gray-400);margin-bottom:1rem}

/* Blog card */
.blog-card{padding:0;overflow:hidden}
.blog-card__img{
    width:100%;height:200px;object-fit:cover;
    transition:transform .5s var(--ease);
}
.blog-card:hover .blog-card__img{transform:scale(1.05)}
.blog-card__body{padding:1.6rem}
.blog-card__meta{
    display:flex;align-items:center;gap:1rem;
    font-size:.78rem;color:var(--gray-400);margin-bottom:.6rem;
}
.blog-card__category{
    color:var(--cyan);font-weight:600;text-transform:uppercase;
    letter-spacing:.06em;
}
.blog-card__title{
    font-family:var(--font-heading);font-size:1.18rem;color:var(--navy);
    line-height:1.35;margin-bottom:.5rem;transition:color .3s var(--ease);
}
.blog-card:hover .blog-card__title{color:var(--blue)}
.blog-card__excerpt{font-size:.88rem;color:var(--gray-400)}

/* ============================================
   GRIDS
   ============================================ */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}

/* ============================================
   CLIENTS / LOGOS
   ============================================ */
.clients-bar{
    display:flex;align-items:center;justify-content:center;
    gap:3rem;flex-wrap:wrap;padding:2rem 0;opacity:.5;
}
.clients-bar img{height:28px;filter:grayscale(1);transition:filter .3s,opacity .3s}
.clients-bar img:hover{filter:grayscale(0);opacity:1}

/* ============================================
   TECH STACK
   ============================================ */
.tech-grid{
    display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.5rem;
}
.tech-badge{
    display:inline-flex;align-items:center;gap:.5rem;
    padding:.55rem 1.1rem;border-radius:100px;
    background:var(--white);border:1px solid var(--gray-100);
    font-size:.85rem;font-weight:500;color:var(--gray-600);
    transition:all .3s var(--ease);
}
.tech-badge:hover{border-color:var(--cyan);color:var(--cyan);background:var(--cyan-pale)}
.tech-badge svg,.tech-badge img{width:18px;height:18px}

/* ============================================
   FAQ ACCORDION
   ============================================ */
.faq-item{
    border-bottom:1px solid var(--gray-100);
}
.faq-question{
    display:flex;align-items:center;justify-content:space-between;
    width:100%;padding:1.4rem 0;font-size:1.02rem;font-weight:600;
    color:var(--navy);text-align:left;transition:color .3s;
    cursor:pointer;gap:1rem;
}
.faq-question:hover{color:var(--blue)}
.faq-icon{
    flex-shrink:0;width:28px;height:28px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    background:var(--gray-50);transition:all .3s var(--ease);
    font-size:.9rem;color:var(--gray-400);
}
.faq-item.active .faq-icon{background:var(--cyan);color:var(--white);transform:rotate(45deg)}
.faq-answer{
    max-height:0;overflow:hidden;transition:max-height .4s var(--ease),padding .4s;
}
.faq-answer__inner{
    padding-bottom:1.4rem;font-size:.94rem;color:var(--gray-400);
    max-width:760px;line-height:1.75;
}

/* ============================================
   CONTACT FORM
   ============================================ */
.form-group{margin-bottom:1.4rem}
.form-label{
    display:block;font-size:.85rem;font-weight:600;color:var(--navy);
    margin-bottom:.4rem;
}
.form-input,
.form-textarea,
.form-select{
    width:100%;padding:.75rem 1rem;border:1.5px solid var(--gray-100);
    border-radius:8px;font-size:.95rem;color:var(--navy);
    background:var(--white);transition:border-color .3s,box-shadow .3s;
}
.form-input:focus,
.form-textarea:focus,
.form-select:focus{
    outline:none;border-color:var(--cyan);
    box-shadow:0 0 0 3px var(--accent-glow);
}
.form-textarea{resize:vertical;min-height:140px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}

/* ============================================
   CTA BANNER
   ============================================ */
.cta-banner{
    background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);
    border-radius:var(--radius-lg);padding:clamp(2.5rem,5vw,4rem);
    display:flex;align-items:center;justify-content:space-between;
    gap:2rem;position:relative;overflow:hidden;
}
.cta-banner::before{
    content:'';position:absolute;top:-60%;right:-10%;
    width:500px;height:500px;border-radius:50%;
    background:radial-gradient(circle,rgba(34,193,214,.1) 0%,transparent 60%);
}
.cta-banner h2{color:var(--white);margin-bottom:.5rem}
.cta-banner p{color:var(--gray-300);max-width:500px}
.cta-banner__actions{flex-shrink:0;display:flex;gap:1rem}

/* ============================================
   FOOTER
   ============================================ */
.site-footer{
    background:var(--navy);color:var(--gray-400);
    padding:clamp(3rem,6vw,5rem) 0 0;
}
.footer-grid{
    display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:3rem;
    padding-bottom:3rem;
}
.footer-brand .logo-text{color:var(--white)}
.footer-brand .logo-text span{color:var(--gray-400)}
.footer-brand p{margin-top:1rem;font-size:.9rem;max-width:280px;color:var(--gray-400)}
.footer-heading{
    font-family:var(--font-body);font-size:.82rem;font-weight:700;
    text-transform:uppercase;letter-spacing:.12em;color:var(--gray-300);
    margin-bottom:1.2rem;
}
.footer-links li{margin-bottom:.6rem}
.footer-links a{font-size:.9rem;color:var(--gray-400);transition:color .2s}
.footer-links a:hover{color:var(--cyan)}

.footer-bottom{
    border-top:1px solid rgba(255,255,255,.06);
    padding:1.5rem 0;display:flex;justify-content:space-between;
    align-items:center;font-size:.82rem;
}
.footer-social{display:flex;gap:.8rem}
.footer-social a{
    width:36px;height:36px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    background:rgba(255,255,255,.05);color:var(--gray-400);
    transition:all .3s;font-size:.9rem;
}
.footer-social a:hover{background:var(--cyan);color:var(--white)}

/* ============================================
   ABOUT PAGE — SPECIFICS
   ============================================ */
.about-values{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.value-card{text-align:center;padding:2.5rem 1.5rem}
.value-card .card__icon{margin-inline:auto}
.timeline{position:relative;padding-left:2.5rem}
.timeline::before{
    content:'';position:absolute;left:0;top:0;bottom:0;width:2px;
    background:var(--gray-100);
}
.timeline-item{position:relative;padding-bottom:2.5rem}
.timeline-item::before{
    content:'';position:absolute;left:-2.5rem;top:.4rem;
    width:12px;height:12px;border-radius:50%;
    background:var(--cyan);border:3px solid var(--white);
    box-shadow:0 0 0 3px var(--accent-glow);
}
.timeline-year{
    font-size:.78rem;font-weight:700;color:var(--cyan);
    text-transform:uppercase;letter-spacing:.08em;margin-bottom:.3rem;
}

/* ============================================
   BLOG POST PAGE
   ============================================ */
.post-header{
    text-align:center;padding-top:clamp(7rem,12vw,9rem);padding-bottom:2rem;
    background:var(--off-white);
}
.post-header__meta{
    display:flex;justify-content:center;align-items:center;gap:1rem;
    font-size:.85rem;color:var(--gray-400);margin-bottom:1rem;
}
.post-header__category{color:var(--cyan);font-weight:600}
.post-header h1{max-width:760px;margin-inline:auto;font-size:clamp(2rem,4vw,2.8rem)}
.post-hero-img{
    max-width:860px;margin:-2rem auto 0;border-radius:var(--radius-lg);
    overflow:hidden;box-shadow:var(--shadow-lg);position:relative;z-index:2;
}
.post-hero-img img{width:100%;height:auto;display:block}
.post-content{
    max-width:720px;margin:3rem auto;font-size:1.05rem;line-height:1.85;color:var(--gray-600);
}
.post-content h2{margin:2.5rem 0 1rem;font-size:1.6rem}
.post-content h3{margin:2rem 0 .8rem;font-size:1.3rem}
.post-content p{margin-bottom:1.2rem}
.post-content ul,.post-content ol{margin:1rem 0 1.2rem 1.5rem;list-style:disc}
.post-content li{margin-bottom:.4rem}
.post-content blockquote{
    border-left:3px solid var(--cyan);padding:1rem 1.5rem;margin:1.5rem 0;
    background:var(--cyan-pale);border-radius:0 var(--radius) var(--radius) 0;
    font-style:italic;color:var(--gray-600);
}
.post-content code{
    background:var(--gray-50);padding:.15em .4em;border-radius:4px;
    font-size:.9em;
}
.post-content pre{
    background:var(--navy);color:var(--gray-200);padding:1.5rem;
    border-radius:var(--radius);overflow-x:auto;margin:1.5rem 0;
}
.post-content pre code{background:none;padding:0;color:inherit}

.post-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin:2rem 0}
.post-tag{
    padding:.35rem .9rem;border-radius:100px;font-size:.78rem;
    font-weight:600;background:var(--gray-50);color:var(--gray-500);
}

.post-author{
    display:flex;align-items:center;gap:1.2rem;
    padding:1.5rem;border-radius:var(--radius-lg);
    background:var(--off-white);margin:2rem 0;
}
.post-author__avatar{
    width:56px;height:56px;border-radius:50%;background:var(--gray-100);
    flex-shrink:0;display:flex;align-items:center;justify-content:center;
    font-size:1.4rem;color:var(--gray-400);
}
.post-author__name{font-weight:600;color:var(--navy)}
.post-author__bio{font-size:.85rem;color:var(--gray-400)}

/* Sidebar (blog list) */
.blog-layout{display:grid;grid-template-columns:1fr 320px;gap:3rem;align-items:start}
.sidebar{position:sticky;top:100px}
.sidebar-widget{
    background:var(--off-white);border-radius:var(--radius-lg);
    padding:1.6rem;margin-bottom:1.5rem;
}
.sidebar-widget h4{margin-bottom:1rem;font-size:1rem}
.sidebar-tags{display:flex;flex-wrap:wrap;gap:.4rem}
.sidebar-tag{
    padding:.3rem .8rem;border-radius:100px;font-size:.78rem;
    font-weight:500;background:var(--white);border:1px solid var(--gray-100);
    color:var(--gray-500);transition:all .3s;
}
.sidebar-tag:hover{border-color:var(--cyan);color:var(--cyan)}

/* ============================================
   ANIMATIONS — Reveal on scroll (progressive enhancement)
   Content is ALWAYS visible by default. Animations only
   activate after JS adds .js-ready to <html>, so content
   is never hidden if JS fails to load.
   ============================================ */
@keyframes revealUp {
    from { opacity: 0; transform: translateY(30px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes staggerIn {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Only hide elements when JS is confirmed ready */
html.js-ready .reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity .7s var(--ease), transform .7s var(--ease);
}
html.js-ready .reveal.visible {
    opacity: 1;
    transform: translateY(0);
}
html.js-ready .reveal-delay-1 { transition-delay: .1s }
html.js-ready .reveal-delay-2 { transition-delay: .2s }
html.js-ready .reveal-delay-3 { transition-delay: .3s }
html.js-ready .reveal-delay-4 { transition-delay: .4s }

html.js-ready .stagger-children > * {
    opacity: 0;
    transform: translateY(24px);
}
html.js-ready .stagger-children.visible > * {
    animation: staggerIn .6s var(--ease) forwards;
}
html.js-ready .stagger-children.visible > *:nth-child(1) { animation-delay: .05s }
html.js-ready .stagger-children.visible > *:nth-child(2) { animation-delay: .12s }
html.js-ready .stagger-children.visible > *:nth-child(3) { animation-delay: .19s }
html.js-ready .stagger-children.visible > *:nth-child(4) { animation-delay: .26s }
html.js-ready .stagger-children.visible > *:nth-child(5) { animation-delay: .33s }
html.js-ready .stagger-children.visible > *:nth-child(6) { animation-delay: .40s }
html.js-ready .stagger-children.visible > *:nth-child(7) { animation-delay: .47s }

/* Respect reduced motion preference */
@media (prefers-reduced-motion: reduce) {
    html.js-ready .reveal,
    html.js-ready .stagger-children > * {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
        animation: none !important;
    }
}

/* ============================================
   CASE STUDY DETAIL (reusable)
   ============================================ */
.case-detail-hero{
    display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;
}
.case-meta{
    display:flex;gap:2rem;margin-top:1.5rem;flex-wrap:wrap;
}
.case-meta dt{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gray-400)}
.case-meta dd{font-size:.95rem;color:var(--navy);font-weight:500}

/* ============================================
   MISC PATTERNS
   ============================================ */
.feature-row{
    display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;
}
.feature-row--reverse{direction:rtl}
.feature-row--reverse > *{direction:ltr}

.icon-grid{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;
}

.numbered-list{counter-reset:step}
.numbered-list li{
    counter-increment:step;position:relative;padding-left:3rem;
    padding-bottom:1.5rem;
}
.numbered-list li::before{
    content:counter(step,decimal-leading-zero);
    position:absolute;left:0;top:0;
    font-family:var(--font-heading);font-size:1.6rem;
    color:var(--cyan);line-height:1;
}

/* Placeholder images (gradient placeholders) */
.img-placeholder{
    background:linear-gradient(135deg,var(--gray-50) 0%,var(--gray-100) 100%);
    border-radius:var(--radius-lg);display:flex;align-items:center;
    justify-content:center;color:var(--gray-300);font-size:.85rem;
    min-height:300px;
}
.img-placeholder--sm{min-height:200px}

/* Services page: outsourcing detail */
.outsource-services{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem;
}

/* Pagination */
.pagination{
    display:flex;justify-content:center;gap:.5rem;margin-top:3rem;
}
.pagination a,.pagination span{
    display:flex;align-items:center;justify-content:center;
    width:40px;height:40px;border-radius:8px;font-size:.9rem;
    font-weight:500;color:var(--gray-500);border:1px solid var(--gray-100);
    transition:all .3s;
}
.pagination a:hover{border-color:var(--cyan);color:var(--cyan)}
.pagination .active{background:var(--cyan);color:var(--white);border-color:var(--cyan)}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
    .hero__grid{grid-template-columns:1fr;text-align:center}
    .hero__desc{margin-inline:auto}
    .hero__actions{justify-content:center}
    .hero__stats{justify-content:center}
    .hero__visual{display:none}
    .grid-3{grid-template-columns:repeat(2,1fr)}
    .grid-4{grid-template-columns:repeat(2,1fr)}
    .footer-grid{grid-template-columns:1fr 1fr}
    .cta-banner{flex-direction:column;text-align:center}
    .cta-banner__actions{justify-content:center}
    .blog-layout{grid-template-columns:1fr}
    .sidebar{position:static}
    .about-values{grid-template-columns:repeat(2,1fr)}
    .feature-row{grid-template-columns:1fr;gap:2.5rem}
    .feature-row--reverse{direction:ltr}
    .case-detail-hero{grid-template-columns:1fr;gap:2rem}
}

@media(max-width:768px){
    .main-nav{
        position:fixed;top:78px;left:0;right:0;
        height:calc(100vh - 78px);height:calc(100dvh - 78px);
        background:var(--white);flex-direction:column;
        justify-content:flex-start;padding:2rem;gap:1.5rem;
        transform:translateX(100%);transition:transform .4s var(--ease);
        z-index:999;overflow:visible;
    }
    .main-nav.open{transform:translateX(0)}
    .menu-toggle{display:flex}
    .header-cta{display:none}
    .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
    .footer-grid{grid-template-columns:1fr}
    .form-row{grid-template-columns:1fr}
    .hero__stats{flex-direction:column;align-items:center;gap:1.5rem}
    .about-values{grid-template-columns:1fr}
    .post-content{padding-inline:1rem}
    .feature-row{gap:2rem}
    .case-detail-hero{gap:1.5rem}
    .case-meta{gap:1.5rem}
    .numbered-list li{padding-left:2.5rem}
}
