/* Poirier-inspired styles for Shahdag prototype */
:root{
  --bg:#ffffff;
  --muted:#6b7280;
  --brand:#0f172a; /* dark navy */
  --accent:#004aad; /* brand accent (blue) */
  --soft:#f7f7f9;
  --reveal-stagger: 80ms; /* base stagger for project reveal */
  --radius:12px;
  --max-width:1200px;
  --pad:1.25rem;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial;
  margin:0;background:var(--soft);color:var(--brand);line-height:1.5;-webkit-font-smoothing:antialiased;
}
.visually-hidden{position:absolute!important;height:1px!important;width:1px!important;overflow:hidden!important;clip:rect(1px,1px,1px,1px)!important;white-space:nowrap!important;border:0!important;padding:0!important;margin:-1px!important}
/* Strong focus indicator for accessibility */
:focus-visible{outline:3px solid rgba(0,74,173,0.35);outline-offset:3px}
a.btn:focus-visible, button.btn:focus-visible{outline-color:rgba(0,74,173,0.5)}
.field-error{color:#b00020;font-size:.9rem;margin-top:.25rem}
.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--pad)}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

/* Topbar */
.topbar{background:#fff;border-bottom:1px solid #ececec}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;padding:.45rem 0;font-size:.95rem;color:var(--muted)}
.topbar .top-links a{margin-left:1rem;color:var(--muted);text-decoration:none}

/* Header */
.site-header{background:transparent;position:sticky;top:0;z-index:110;backface-visibility:hidden}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 0}
.brand{display:flex;align-items:center;gap:.6rem;color:var(--brand);text-decoration:none;font-weight:800}
.brand .logo{display:block;height:52px;width:auto}
.brand .brand-name{font-family:Merriweather,serif;font-size:1.3rem;letter-spacing:.02em;color:var(--brand)}
@media (max-width:700px){
  .brand .logo{height:42px}
  .brand .brand-name{font-size:1.15rem}
}
.site-nav{display:flex;gap:1rem;align-items:center}
.site-nav a{color:var(--brand);text-decoration:none;padding:.4rem .6rem;border-radius:6px;font-weight:600}
.site-nav a.cta{background:var(--brand);color:#fff;padding:.6rem .9rem}
.nav-toggle{display:none;background:none;border:0;font-size:1.25rem}

/* Header shrink styles (applies when JS toggles .shrink) */
.site-header{transition:background .18s ease, box-shadow .18s ease;position:fixed;left:0;right:0;top:0;width:100%}
.site-header.shrink{background:rgba(255,255,255,0.95);box-shadow:0 6px 24px rgba(2,6,23,0.06);backdrop-filter:blur(6px)}
.site-header.shrink .header-inner{padding:.5rem 0;transition:padding .24s ease}
.site-nav a{transition:color .18s ease, transform .18s ease, opacity .24s ease}

/* When the header sits over a dark hero (not scrolled), use light nav items for readability on desktop.
   When the header has .shrink (on scroll) it sits on a light background so use the brand color then. */
/* Desktop: use brand color for nav items by default (darker text on first load) */
.site-nav a{color:var(--brand)}

/* Hero reveal */
.hero-content{opacity:0;transform:translateY(10px);transition:opacity .7s cubic-bezier(.2,.9,.2,1), transform .7s cubic-bezier(.2,.9,.2,1)}
.hero-content.reveal{opacity:1;transform:none}

/* Ensure main content sits below fixed header */
#main{padding-top:72px}

/* Projects reveal on scroll */
.project{opacity:0;transform:translateY(18px);transition:opacity .6s cubic-bezier(.2,.9,.2,1), transform .6s cubic-bezier(.2,.9,.2,1)}
.project.in-view{opacity:1;transform:none}
.projects-grid .project:nth-child(1){transition-delay: calc(var(--reveal-stagger) * 0)}
.projects-grid .project:nth-child(2){transition-delay: calc(var(--reveal-stagger) * 1)}
.projects-grid .project:nth-child(3){transition-delay: calc(var(--reveal-stagger) * 2)}

/* Ensure image fallbacks inside project-media cover properly */
.project-media img{display:block;width:100%;height:100%;object-fit:cover}


/* Mobile nav link stagger (links animate when .open is toggled) */
.site-nav.open a{opacity:1;transform:none}


/* Hero */
.hero{position:relative;color:#fff;overflow:hidden}
.hero-large{min-height:80vh;background-size:cover;background-position:center center;background-repeat:no-repeat;background-attachment:fixed;display:flex;align-items:center}
.hero.hero-large{background-image:url('../assets/herobg.png');}
.hero .overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,23,42,0.74),rgba(15,23,42,0.52))}
.hero-inner{position:relative;padding:4rem 0}
.hero-content{max-width:720px}

/* Place the hero-media beneath the content so the image behaves like a background */
.hero-media{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block}
.hero .overlay{z-index:1}
.hero-content{position:relative;z-index:2}
.hero-media img{width:100%;height:100%;object-fit:cover;display:block}
.hero-media{z-index:0}
.hero-media img{opacity:1}
.hero h1{font-family:Merriweather,serif;font-size:clamp(2rem,4vw,3.2rem);line-height:1.15;margin:0 0 .75rem;color:#fff;text-shadow:0 8px 28px rgba(2,6,23,0.5)}
.eyebrow{color:#fff;margin-top:.1rem;font-weight:700;opacity:.96;text-shadow:0 6px 20px rgba(2,6,23,0.45)}
.hero-actions{display:none}
.btn{display:inline-block;padding:.65rem 1rem;border-radius:10px;text-decoration:none;font-weight:700}
.btn.primary{background:var(--accent);color:#fff}
.btn.ghost{background:transparent;border:2px solid rgba(255,255,255,0.18);color:#fff}

/* Projects / products */
.section{padding:3rem 0}
.section-title{font-family:Merriweather,serif;font-size:1.5rem;margin-bottom:.25rem}
.section-lead{color:var(--muted);margin-bottom:1rem}
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.project{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 10px 30px rgba(15,23,42,0.06);display:flex;flex-direction:column}
.project-media{height:180px;background-size:cover;background-position:center}
.project-body{padding:1rem}
.project-body h3{margin:0 0 .4rem}

.projects-cta{margin-top:1.25rem}

/* Services split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}
.services-list{list-style:none;padding:0;margin:0}.services-list li{padding:.35rem 0;color:var(--muted)}

/* Services: refined, Squarespace-like visual treatment */
.services{background:linear-gradient(180deg,#fbfbfe,#ffffff)}
.services .section-title{font-family:Merriweather,serif;font-size:2rem;margin-bottom:.25rem;color:var(--brand);letter-spacing:-0.02em}
.services .section-lead{color:var(--muted);max-width:720px;margin-bottom:1.25rem}

/* Vertical name list styling */
.tab-nav-list{background:transparent;padding:1.25rem 0}
.tab-nav-list .tab-btn{background:transparent;color:var(--muted);font-size:0.98rem;padding:.5rem .75rem;border-radius:6px;text-transform:uppercase;letter-spacing:0.12em;font-weight:700}
.tab-nav-list .tab-btn:hover{color:var(--brand);background:rgba(15,23,42,0.02)}
.tab-nav-list .tab-btn.active{color:var(--brand);position:relative;background:transparent}
.tab-nav-list .tab-btn.active::before{content:'';position:absolute;left:-14px;top:50%;transform:translateY(-50%);width:6px;height:28px;border-radius:4px;background:linear-gradient(180deg,var(--accent),#2a6fdb)}

/* Explanation card: more airy and centered like the demo */
.tab-card{max-width:720px;margin:0 auto;padding:1.4rem 1.6rem;border-radius:14px}
.tab-card-inner{padding:0;color:var(--muted);line-height:1.8}
.tab-card-inner h3{font-family:Merriweather,serif;color:var(--brand);font-size:1.25rem;margin:0 0 .4rem}
.tab-card-inner p{margin:0}

/* Testimonial / kicker style within services (if present) */
.services .testimonial{font-style:italic;color:var(--brand);margin-top:1rem}


/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 320px 320px;gap:2rem;align-items:stretch}
.contact-form{display:grid;gap:.75rem}
.contact-form input,.contact-form textarea{width:100%;padding:.65rem;border-radius:8px;border:1px solid #e6e7eb}
.contact-info{background:#fff;padding:1rem;border-radius:10px;box-shadow:0 8px 30px rgba(15,23,42,0.04)}
.contact-map{background:#fff;padding:0;border-radius:10px;box-shadow:0 8px 30px rgba(15,23,42,0.04);overflow:hidden}
.contact-map iframe{display:block;width:100%;height:100%;min-height:260px;border:0}
.form-status{margin-top:.6rem;color:var(--muted)}

/* Make the contact form's Send Message button match the light button style used for store navigation */
#contact .contact-form .btn.primary{
  background:rgba(0,74,173,0.08);
  color:var(--brand);
  border:1px solid rgba(0,74,173,0.24);
  border-radius:10px;
  padding:.55rem .9rem;
  font-size:.96rem;
  box-shadow:0 6px 16px rgba(2,6,23,0.04);
  transition:transform .12s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}
#contact .contact-form .btn.primary:hover{
  background:rgba(0,74,173,0.14);
  border-color:rgba(0,74,173,0.36);
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(2,6,23,0.06);
}
#contact .contact-form .btn.primary:active{
  transform:translateY(0);
  box-shadow:0 6px 16px rgba(2,6,23,0.04);
}
#contact .contact-form .btn.primary:focus{
  outline:3px solid rgba(0,74,173,0.18);
  outline-offset:3px;
}

/* Footer */
.site-footer{border-top:1px solid #e8e8ea;padding:1.25rem 0;margin-top:2rem;background:#fff}
.footer-inner{display:flex;justify-content:space-between;align-items:center}
.footer-nav a{margin-left:1rem;color:var(--muted);text-decoration:none}

/* Footer language switcher buttons */
#langSwitcher .btn{padding:.35rem .6rem;font-size:.92rem;border:1px solid rgba(0,74,173,0.24);border-radius:8px;background:#fff;color:var(--brand)}
#langSwitcher .btn[aria-pressed="true"]{background:rgba(0,74,173,0.08);border-color:rgba(0,74,173,0.36)}

/* Responsive */
@media (max-width:1000px){
  .projects-grid{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:700px){
  .projects-grid{grid-template-columns:1fr}
  .nav-toggle{display:block}
  .site-nav{display:none;position:fixed;right:1rem;top:72px;background:#fff;padding:1rem;border-radius:12px;box-shadow:0 12px 40px rgba(15,23,42,0.12);flex-direction:column}
  .site-nav.open{display:flex}
  /* mobile-only: hide links until the nav opens, and animate them in */
  .site-nav a{opacity:0;transform:translateY(-6px);color:var(--brand)}
  .site-nav.open a{opacity:1;transform:none}
  /* Disable fixed background on mobile for better performance/compatibility */
  .hero-large{background-attachment:scroll}
}

/* Desktop: show the nav always and ensure it stays visible while scrolling */
@media (min-width:701px){
  .site-nav{display:flex !important}
  /* Keep header fixed on desktop too so it never scrolls away */
  .site-header{position:fixed;top:0;left:0;right:0;z-index:110}
  .site-header.shrink .site-nav a{color:var(--brand)}
  /* Ensure CTA text stays white even when header shrinks */
  .site-header.shrink .site-nav a.cta{color:#fff}
}

/* Mobile / small-screen improvements */
@media (max-width:700px){
  .topbar{display:none} /* remove the small top utility bar to save vertical space */

  .hero-large{min-height:56vh;background-position:center top}
  .hero-large{min-height:70vh}
  /* stronger overlay on small screens so text remains visible over variable backgrounds */
  .hero .overlay{background:linear-gradient(180deg,rgba(15,23,42,0.78),rgba(15,23,42,0.58))}
  .hero-inner{padding:2rem 0}
  .hero-content{max-width:100%;text-align:center;padding:0 1rem}
  /* force hero text visible on mobile (avoid timing/overlay issues) */
  .hero-content{opacity:1 !important;transform:none !important}
  .hero h1{font-size:clamp(1.5rem,6vw,2.1rem);text-shadow:0 6px 18px rgba(2,6,23,0.45)}
  .eyebrow{font-size:.95rem}
  .hero-actions{flex-direction:column;gap:.6rem;align-items:center}
  .btn{width:100%;padding:.8rem 1rem;border-radius:10px}
  .btn.ghost{border-color:rgba(255,255,255,0.2)}

  /* Make mobile nav full-width and easier to tap */
  .site-nav{right:0;left:0;top:64px;margin:0;border-radius:0;padding:1.25rem 1rem}
  .site-nav a{display:block;padding:.9rem 1rem;border-radius:8px;font-size:1.02rem}
  .site-nav a.cta{background:var(--brand);color:#fff}

  /* Darker menu text on mobile for readability */
  .site-nav a{color:#0f172a !important}
  .brand{color:#fff !important;font-size:1.35rem}
  .nav-toggle{font-size:2.4rem !important;padding:.55rem .8rem !important;border-radius:8px}
  .nav-toggle{line-height:1}
  /* hide any .hero-media elements that might overlap */
  .hero-media{display:none !important}

  /* Projects: bigger media and comfortable spacing */
  .project-media{height:220px}
  .project-body{padding:1rem}

  /* Contact form: full width inputs and larger tap targets */
  .contact-form input,.contact-form textarea{padding:.9rem;font-size:1rem}
  .form-actions .btn{width:100%}

  /* Reduce container side padding on very small screens */
  .container{padding:0 .75rem}
}

/* Service card styles (animated like projects) */
.service{opacity:0;transform:translateY(18px);transition:opacity .6s cubic-bezier(.2,.9,.2,1), transform .6s cubic-bezier(.2,.9,.2,1)}
.service.in-view{opacity:1;transform:none}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.service{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 10px 30px rgba(15,23,42,0.06);display:flex;flex-direction:column}
.service-media{height:160px;background-size:cover;background-position:center}
.service-body{padding:1rem}

/* Accordion for services (used on the split/list layout) */
.services-accordion{max-width:720px;margin:0 auto}
.accordion-item{border-bottom:1px solid #ececec}
.accordion-button{width:100%;text-align:left;padding:1rem;font-weight:600;background:transparent;border:0;font-size:1rem;display:flex;justify-content:space-between;align-items:center}
.accordion-button:after{content:'+';font-size:1.1rem;opacity:.6}
.accordion-button[aria-expanded="true"]:after{content:'−'}
.accordion-panel{max-height:0;overflow:hidden;transition:max-height .36s cubic-bezier(.2,.9,.2,1), padding .2s ease;padding:0 1rem}
.accordion-panel p{margin:0;padding:1rem 0;color:var(--muted)}
.accordion-panel.open{max-height:300px;padding:1rem}

/* Services view controls */
.services-controls{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}
.view-toggle{display:flex;gap:.4rem}
.view-btn{background:transparent;border:1px solid #e6e7eb;padding:.4rem .6rem;border-radius:8px;font-weight:600}
.view-btn.active{background:var(--brand);color:#fff;border-color:transparent}

.services-views .view{padding-top:.6rem}

/* Cards view */
.service-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.card{background:#fff;border-radius:12px;box-shadow:0 12px 40px rgba(15,23,42,0.06);overflow:hidden;display:flex;flex-direction:column}
.card{display:flex;flex-direction:column;background:linear-gradient(180deg,#fff,#fbfbfe);border-radius:14px;overflow:hidden;box-shadow:0 18px 60px rgba(15,23,42,0.08)}
.card-media{font-size:2.6rem;padding:1.25rem;background:linear-gradient(180deg,rgba(0,74,173,0.06),rgba(0,0,0,0.02));text-align:center}
.card-body{padding:1rem 1.1rem 1.25rem;display:flex;flex-direction:column;gap:.6rem}
.card-body h3{margin:0;font-size:1.05rem}
.card-body p{margin:0;color:var(--muted);line-height:1.45}

/* Make cards show full explanation and keep consistent height rhythm */
.service-cards .card{min-height:180px}

/* Split rows */
.split-list{display:flex;flex-direction:column;gap:1rem}
.split-row{display:grid;grid-template-columns:88px 1fr;gap:1rem;align-items:center;background:#fff;padding:1rem;border-radius:10px;box-shadow:0 8px 30px rgba(15,23,42,0.04)}
.split-media{font-size:1.8rem;text-align:center}
.split-text h3{margin:0 0 .25rem}

/* Tabs */
.tabs{background:#fff;border-radius:10px;padding:0;box-shadow:0 12px 40px rgba(15,23,42,0.06);position:relative;overflow:hidden;display:grid;grid-template-columns:260px 1fr;min-height:260px}
/* Panels area: fixed height for smooth vertical sliding */
.tab-panels{position:relative;transition:transform .6s cubic-bezier(.2,.9,.2,1);will-change:transform;padding:1.25rem 1rem 1.25rem;height:260px;display:block;overflow:hidden}
.tab-panel{min-height:160px;height:100%;transition:transform .42s cubic-bezier(.2,.9,.2,1), opacity .42s ease;transform:translateY(8px);opacity:.6}
.tab-panel.active-panel{transform:none;opacity:1}

/* Tab card: boxed content inside each panel, scrollable if long */
.tab-card{background:#fff;border-radius:12px;padding:0;margin:6px auto;max-width:980px;box-shadow:0 18px 60px rgba(15,23,42,0.06);height:100%;display:flex;flex-direction:column;overflow:hidden}
.tab-card-inner{padding:1.1rem 1.25rem;color:var(--muted);line-height:1.6;overflow:auto}
.tab-card-inner::-webkit-scrollbar{height:8px;width:8px}
.tab-card-inner::-webkit-scrollbar-thumb{background:linear-gradient(180deg,rgba(15,23,42,0.12),rgba(15,23,42,0.18));border-radius:8px}

/* subtle top/bottom fade to hint there is more to scroll when overflow exists */
.tab-card{position:relative}
.tab-card::before,.tab-card::after{content:'';position:absolute;left:0;right:0;height:22px;pointer-events:none;opacity:0;transition:opacity .18s ease}
.tab-card::before{top:0;background:linear-gradient(180deg,rgba(255,255,255,0.9),rgba(255,255,255,0));}
.tab-card::after{bottom:0;background:linear-gradient(180deg,rgba(255,255,255,0),rgba(255,255,255,0.9));}
.tab-card.scrollable::before,.tab-card.scrollable::after{opacity:1}



/* Move tab nav to bottom and give pill-style buttons */
.tab-nav{position:relative;display:flex;align-items:stretch;gap:1rem;padding:0}
.tab-nav-list{display:flex;flex-direction:column;gap:.5rem;width:220px;flex:0 0 220px;padding:1rem;overflow:hidden;transition:transform .42s cubic-bezier(.2,.9,.2,1)}
.tab-nav-list .tab-btn{white-space:nowrap}
.tab-btn{background:transparent;border:0;padding:.6rem .75rem;border-radius:8px;font-weight:700;cursor:pointer;text-align:left;transition:transform .12s ease, background .12s ease, color .12s ease}
.tab-btn:hover{background:rgba(15,23,42,0.03)}
.tab-btn.active{background:linear-gradient(180deg,var(--brand),#0b1220);color:#fff;border-radius:8px;box-shadow:none}
.tab-btn:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(15,23,42,0.06)}
.tab-btn:focus{outline:3px solid rgba(0,74,173,0.18);outline-offset:3px}
.tab-btn.active{background:linear-gradient(180deg,var(--brand),#0b1220);color:#fff;border-color:transparent;box-shadow:0 14px 40px rgba(11,16,32,0.12);transform:none}

/* Smaller on narrow screens */
@media (max-width:700px){
  .tabs{display:block}
  .tab-panels{height:200px;padding-bottom:3.8rem}
  .tab-panel{min-height:140px}
  .tab-nav{position:absolute;left:8px;right:8px;bottom:8px}
  .tab-nav-list{flex-direction:row;width:auto}
  .tab-nav-list .tab-btn{border-radius:999px;padding:.45rem .7rem}
}

/* Prev/Next buttons for tabs */
.tabs-nav-btn{position:absolute;top:12px;width:38px;height:38px;border-radius:50%;border:0;background:rgba(255,255,255,0.9);box-shadow:0 6px 20px rgba(2,6,23,0.08);display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer}
.tabs-prev{left:10px}
.tabs-next{right:10px}
.tabs-nav-btn:active{transform:scale(.98)}

@media (max-width:700px){
  .tabs-nav-btn{width:44px;height:44px;top:10px}
  .tabs-prev{left:8px}
  .tabs-next{right:8px}
}

/* Icon list */
.icon-list{list-style:none;margin:0;padding:0;display:grid;gap:1rem}
.icon-list li{display:flex;gap:.75rem;align-items:flex-start;background:#fff;padding:1rem;border-radius:10px;box-shadow:0 8px 30px rgba(15,23,42,0.04)}
.icon-list .icon{font-size:1.6rem}

/* Social buttons in contact */
.social-buttons{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-top:1rem}
.social-buttons .btn{display:inline-flex;align-items:center;gap:.5rem;flex:0 0 auto;padding:.6rem .9rem;font-size:.96rem;border-radius:10px;box-shadow:0 6px 16px rgba(2,6,23,0.06);transition:transform .12s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;text-decoration:none}
.social-buttons .btn .icon{display:inline-block}
/* YouTube subscribe button wrapper */
.yt-subscribe-wrap{display:flex;align-items:center;height:35px}
.btn--youtube{background:#FF0000;color:#fff;border:1px solid #FF0000}
.btn--youtube:hover{background:#E60000;border-color:#E60000;transform:translateY(-1px);box-shadow:0 10px 24px rgba(2,6,23,0.08)}
.btn--youtube:focus{outline:3px solid rgba(255,0,0,0.3);outline-offset:3px}
/* Facebook (Meta Blue) */
.btn--facebook{background:#1877F2;color:#fff;border:1px solid #1877F2}
.btn--facebook:hover{background:#166FE5;border-color:#166FE5;transform:translateY(-1px);box-shadow:0 10px 24px rgba(2,6,23,0.08)}
.btn--facebook:focus{outline:3px solid rgba(24,119,242,0.3);outline-offset:3px}
/* WhatsApp Green */
.btn--whatsapp{background:#25D366;color:#fff;border:1px solid #25D366}
.btn--whatsapp:hover{background:#1EBE5B;border-color:#1EBE5B;transform:translateY(-1px);box-shadow:0 10px 24px rgba(2,6,23,0.08)}
.btn--whatsapp:focus{outline:3px solid rgba(37,211,102,0.3);outline-offset:3px}

@media (max-width:1000px){
  .service-cards{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:700px){
  .service-cards{grid-template-columns:1fr}
  .view-toggle{overflow:auto}
  .split-row{grid-template-columns:64px 1fr}
}

@media (max-width:1000px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:700px){
  .services-grid{grid-template-columns:1fr}
  .service-media{height:200px}
  .service-body{margin-top:-42px;background:#fff;padding:1rem;border-radius:10px;box-shadow:0 10px 30px rgba(15,23,42,0.06)}
}

/* Poirier-inspired mobile refinements */
@media (max-width:700px){
  /* Make projects feel image-forward with the body card overlapping the image */
  .projects-grid{gap:1rem}
  .project{background:transparent;border-radius:0;box-shadow:none;opacity:1;transform:none}
  .project-media{height:260px;border-radius:12px;overflow:hidden}
  .project-media img{border-radius:12px;display:block;width:100%;height:100%;object-fit:cover}
  .project-body{background:#fff;margin-top:-56px;padding:1rem;border-radius:12px;box-shadow:0 12px 40px rgba(15,23,42,0.06)}

  /* Larger project headings and comfortable spacing */
  .project-body h3{font-size:1.05rem}

  /* Sticky bottom CTA like many modern sites (easy to reach) */
  .mobile-cta{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;justify-content:center;padding:12px;background:linear-gradient(180deg,rgba(255,255,255,0),rgba(255,255,255,0.02));pointer-events:auto}
  .mobile-cta .btn{width:94%;max-width:720px;padding:.85rem 1rem;border-radius:999px;box-shadow:0 8px 30px rgba(15,23,42,0.08)}
  /* hidden initially, slide up on first reveal */
  .mobile-cta{transform:translateY(110%);opacity:0;transition:transform .42s cubic-bezier(.2,.9,.2,1), opacity .3s ease}
  .mobile-cta.visible{transform:translateY(0);opacity:1}

  /* Removed mobile parallax/scale effect */

  /* Make sure main footer has breathing room above the CTA */
  .site-footer{padding-bottom:76px}

  /* Increase top padding on main to account for larger fixed header on small screens */
  #main{padding-top:84px}
}

/* Hide mobile CTA on larger screens (desktop) */
@media (min-width:701px){
  .mobile-cta{display:none}
}

@media (prefers-reduced-motion: no-preference){
  .project{transition:transform .26s ease, box-shadow .26s ease}
  .project:hover{transform:translateY(-6px);box-shadow:0 18px 60px rgba(15,23,42,0.12)}
}

/* Utility */
.text-center{text-align:center}

/* (initial-lock removed as per request) */

/* ================= Services (new) ================= */
.svc-layout{display:grid;grid-template-columns:300px 1fr;gap:1.25rem;align-items:start}
.svc-nav{position:relative;padding:0.5rem 0}
.svc-item{display:block;width:100%;text-align:left;background:transparent;border:0;color:var(--muted);padding:.6rem .75rem .6rem 1.25rem;border-radius:8px;cursor:pointer;font-weight:700;text-transform:uppercase;letter-spacing:.12em}
.svc-item:hover{background:rgba(15,23,42,0.03);color:var(--brand)}
.svc-item.active{color:var(--brand);position:relative}
.svc-item.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:28px;border-radius:4px;background:linear-gradient(180deg,var(--accent),#2a6fdb)}

.svc-panel{min-height:240px}
.svc-card{background:#fff;border-radius:14px;box-shadow:0 18px 60px rgba(15,23,42,0.08);padding:1.4rem 1.6rem}
.svc-title{font-family:Merriweather,serif;margin:0 0 .5rem;color:var(--brand)}
.svc-desc{margin:0;color:var(--muted);line-height:1.8}

/* Popover shown on hover near the pointer (desktop) */
.svc-popover{display:none !important}
.svc-popover h4{margin:.1rem 0 .35rem;font-size:1rem;color:var(--brand)}
.svc-popover p{margin:0;color:var(--muted);line-height:1.6}

@media (max-width:900px){
  .svc-layout{grid-template-columns:1fr}
  .svc-nav{order:2;display:flex;gap:.5rem;flex-wrap:wrap}
  .svc-item{letter-spacing:.08em;text-transform:none;border:1px solid #e6e7eb;border-radius:999px}
  .svc-item.active::before{display:none}
  .svc-popover{display:none}
}

/* Section divider decorative element */
.section-divider{line-height:0;margin-top:-4px}
.section-divider{position:relative;line-height:0;margin-top:-4px;height:56px}
.section-divider svg{display:none} /* keep SVG as fallback in HTML but hide by default */

/* Diagonal split: use pseudo-elements to create a soft diagonal between sections */
.section-divider::before,
.section-divider::after{content:'';position:absolute;left:0;right:0;height:120%;transform-origin:center;pointer-events:none}
.section-divider[data-dir="down"]::before{top:-20%;background:linear-gradient(180deg,rgba(15,23,42,0.04),rgba(255,255,255,0));transform:skewY(-4deg)}
.section-divider[data-dir="down"]::after{bottom:-20%;background:linear-gradient(180deg, rgba(0,74,173,0.18), rgba(0,74,173,0.06) 40%, rgba(255,255,255,0));transform:skewY(-4deg)}
.section-divider[data-dir="up"]::before{top:-20%;background:linear-gradient(180deg,rgba(255,255,255,0),rgba(15,23,42,0.02));transform:skewY(4deg)}
.section-divider[data-dir="up"]::after{bottom:-20%;background:linear-gradient(180deg,rgba(15,23,42,0.04),rgba(255,255,255,0));transform:skewY(4deg)}

/* Slight shadow to separate sections */
.section-divider::after{box-shadow:0 6px 18px rgba(2,6,23,0.04)}

/* Slight accent glow for the down divider */
.section-divider[data-dir="down"]::after{filter:drop-shadow(0 8px 18px rgba(0,74,173,0.06))}

/* Stores block in contact */
.stores{margin-top:1.1rem;margin-bottom:1.2rem}
.store-buttons{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
/* Make store nav buttons compact, but clearly button-like */
.store-buttons .btn{flex:0 0 auto;padding:.55rem .9rem;font-size:.96rem;border-radius:10px;box-shadow:0 6px 16px rgba(2,6,23,0.04);transition:transform .12s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease}
/* Unified light style for both buttons */
.store-buttons .btn,
.store-buttons .btn.primary,
.store-buttons .btn.ghost{background:rgba(0,74,173,0.08);border:1px solid rgba(0,74,173,0.24);color:var(--brand)}
.store-buttons .btn:hover{background:rgba(0,74,173,0.14);border-color:rgba(0,74,173,0.36);transform:translateY(-1px);box-shadow:0 10px 24px rgba(2,6,23,0.06)}
.store-buttons .btn:active{transform:translateY(0);box-shadow:0 6px 16px rgba(2,6,23,0.04)}
.store-buttons .btn:focus{outline:3px solid rgba(0,74,173,0.18);outline-offset:3px}

@media (max-width:700px){
  .store-buttons{flex-direction:column;align-items:flex-start}
  .store-buttons .btn{width:auto;min-width:0;max-width:none;flex:none;font-size:.94rem;padding:.5rem .8rem}
}

/* Modal chooser styles */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:220}
.modal[aria-hidden="false"]{display:flex}
.modal-backdrop{position:absolute;inset:0;background:rgba(2,6,23,0.5)}
.modal-panel{position:relative;background:#fff;border-radius:12px;max-width:420px;width:94%;box-shadow:0 20px 60px rgba(2,6,23,0.2);z-index:10;overflow:hidden}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid #f1f1f4}
.modal-body{padding:1rem}
.modal-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}
.modal-actions .btn{flex:1 1 120px}
/* Make all chooser options share the same prominent color for clarity */
.modal-actions .btn{background:var(--accent);color:#fff;border:0}
.modal-actions .btn.ghost{background:var(--accent);color:#fff;border:0}

.modal-close{background:transparent;border:0;font-size:1.6rem;line-height:1}

@media (max-width:420px){
  .modal-panel{max-width:340px}
  .modal-actions .btn{flex-basis:100%}
}

/* Removed previous store button sizing; compact styles defined above */
