/* Home page styles (moved from Components/Pages/Home.razor.css) */

.home-page .hero{position:relative;background-color:#0b1220;background-image:url('../images/PCB.webp');background-repeat:no-repeat;background-position:center bottom;background-size:cover;min-height:clamp(360px,55vh,720px);padding-top:6.5rem}
@media (min-width:992px){.home-page .hero{padding-top:7.5rem}}
.home-page .hero .hero-bg{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.55) 0,rgba(0,0,0,.3) 35%,rgba(0,0,0,0) 75%);pointer-events:none}
.home-page .hero .hero-discover{border:1px solid rgba(255,255,255,.6);color:#fff;background:rgba(0,0,0,.25);backdrop-filter:blur(4px);padding:.9rem 1.4rem}
.home-page .hero .hero-discover:hover{background:rgba(255,255,255,.1);color:#fff;border-color:#fff}
/* Position CTA at bottom center of hero image, above overlay */
.home-page .hero .container{position:static}
.home-page .hero .hero-discover{position:absolute;left:50%;transform:translateX(-50%);bottom:2.5rem;z-index:2}
@media (min-width:992px){.home-page .hero .hero-discover{bottom:4rem}}
.home-page .glass{backdrop-filter:saturate(140%) blur(6px);background:rgba(255,255,255,.65);border:1px solid rgba(0,0,0,.06)}
.home-page .section-title{font-weight:700}

/* Ensure images from wwwroot fill their containers */
.home-page .img-cover{width:100%;height:100%;object-fit:cover;display:block}

/* Services */
.home-page .card.service{border:0;border-radius:1rem;box-shadow:0 10px 30px rgba(0,0,0,.06)}
.home-page .card.service .card-body{padding:1.5rem}
.home-page .card.service .icon{width:3rem;height:3rem;display:grid;place-items:center;border-radius:.75rem;background:#eff6ff;color:#2563eb;font-size:1.25rem;margin-bottom:.75rem}
.home-page .card.service:hover{transform:translateY(-4px);transition:transform .2s ease}

/* Process timeline */
.process-grid{position:relative}
.process-card{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);border-radius:1rem;padding:1.25rem;box-shadow:0 10px 30px rgba(0,0,0,.06);transition:transform .2s ease, box-shadow .2s ease, background-color .2s ease}
.process-card:hover{transform:translateY(-3px);background:rgba(255,255,255,.07);box-shadow:0 14px 34px rgba(0,0,0,.12)}
.process-card:focus{outline:2px solid #60a5fa;outline-offset:2px}
.process-card .process-icon{width:2.5rem;height:2.5rem;display:grid;place-items:center;border-radius:.75rem;background:#0b1220;border:1px solid rgba(255,255,255,.08);color:#93c5fd;font-size:1.1rem;margin-bottom:.5rem}
.step-badge{position:absolute;top:.75rem;right:.75rem;display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border-radius:999px;background:#111827;color:#fff;border:1px solid rgba(255,255,255,.18);font-size:.85rem;line-height:1}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .process-card{transition:none}
  .home-page .card.service:hover,.process-card:hover{transform:none}
}

/* Portfolio cases */
.home-page .case{position:relative}
.home-page .case .case-caption{position:absolute;left:0;right:0;bottom:0;padding:1rem;background:linear-gradient(180deg,rgba(0,0,0,0) 0,rgba(0,0,0,.6) 100%);color:#fff}
.home-page .case .case-caption span{display:block;font-size:.9rem;opacity:.85}

/* Steps */
.home-page .bg-gradient{background:linear-gradient(180deg,#000 0,#0b0f12 100%)}
.home-page .steps{display:flex;gap:1rem;justify-content:space-between;flex-wrap:wrap}
.home-page .step{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex:1 1 120px;padding:1rem;border-radius:.75rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12)}
.home-page .step i{font-size:1.25rem}

/* CTA */
.home-page .cta-banner{box-shadow:0 20px 40px rgba(0,0,0,.08)}

/* Placeholder overrides (no ::deep needed in global CSS) */
.home-page .placeholder{background:#0b122033;border:1px solid #0b122044}
.home-page .placeholder img{display:block}

/* New sections: Capabilities, Workshop log, timeline, sticky quote bar */
.section-dark{background:#1c2024;color:#fff}
.label-en{opacity:.6;font-weight:400;margin-left:.5rem}
.subtle{opacity:.7}

.cap-grid{display:grid;gap:1rem;grid-template-columns:1fr;align-items:stretch}
@media (min-width:900px){.cap-grid{grid-template-columns:1fr 1fr}}
.cap-tile{position:relative;border-radius:18px;overflow:hidden;display:block;min-height:280px;color:#fff}
@media (max-width:576px){.cap-tile{min-height:auto}}
.cap-bg{position:absolute;inset:0;display:block}
.cap-bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.6;transform:scale(1);transition:transform .35s}
/* Allow alternative contain fit to avoid cropping when needed */
.cap-tile--contain .cap-bg img{object-fit:contain;background:#03070c}
/* Fine-tune focal point for mobile crops */
@media (max-width:576px){
  .cap-tile--software .cap-bg img{object-position:center 35%}
  .cap-tile--hardware .cap-bg img{object-position:center}
}
.cap-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.6),rgba(0,0,0,.3))}
.cap-content{position:relative;padding:1.5rem 1.5rem 1rem 1.5rem;max-width:52ch;display:flex;flex-direction:column;gap:.5rem;word-break:break-word;overflow-wrap:anywhere}
@media (min-width:768px){.cap-content{padding:2rem}}
@media (max-width:576px){.cap-content{max-width:unset}}
.cap-tile:hover .cap-bg img{transform:scale(1.05)}
.pill{background:rgba(255,255,255,.12);border-radius:999px;padding:.2rem .5rem;font-size:.75rem}

/* Improved text lists within capability tiles */
.cap-list{margin:.35rem 0 0 0;padding-left:1.1rem;opacity:.95}
.cap-list li{margin:.15rem 0}

.workshop-grid{display:grid;gap:1rem;grid-template-columns:1fr}
@media (min-width:900px){.workshop-grid{grid-template-columns:1fr 1fr 1fr}}
.workshop-card{position:relative;border-radius:18px;overflow:hidden;display:block;aspect-ratio:16/9}
@media (max-width:576px){.workshop-card{aspect-ratio:4/3}}
.card-bg{position:absolute;inset:0;display:block}
.card-bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1);transition:transform .35s}
.card-gradient{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.6),rgba(0,0,0,.1))}
.workshop-card:hover .card-bg img{transform:scale(1.05)}
.card-meta{position:absolute;left:1rem;bottom:1rem}
.card-title{font-weight:600;margin-top:.35rem}
.card-sub{opacity:.8;font-size:.9rem}

/* Timeline: centered, responsive, cleaner rhythm */
.timeline{position:relative;padding-top:2.75rem;display:grid;gap:1.1rem 2rem;align-items:start}
.timeline--horizontal{grid-template-columns:repeat(5,minmax(200px,1fr))}
.timeline::before{content:"";position:absolute;left:0;right:0;top:.35rem;height:1px;background:rgba(255,255,255,.12)}
.timeline li{position:relative;list-style:none;text-align:center;padding-top:.25rem}
.timeline li h3{margin:.55rem 0 .35rem;line-height:1.25;min-height:2.2em}
.timeline li p{margin:0;opacity:.8;max-width:32ch;margin-inline:auto;min-height:3.2em}
.timeline .dot{position:absolute;top:-.8rem;left:50%;transform:translateX(-50%);width:28px;height:28px;border-radius:50%;background:#3A7BFA;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;box-shadow:0 0 0 2px rgba(0,0,0,.25)}

/* Inline step head for process timeline */
.timeline .step-head{display:inline-flex;gap:.5rem;align-items:center;justify-content:center;margin-bottom:.4rem}
.timeline .dot-inline{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#3A7BFA;color:#fff;font-weight:700;box-shadow:0 0 0 2px rgba(0,0,0,.25)}

/* Responsive columns so steps don’t feel cramped at smaller widths */
@media (max-width:1200px){
  .timeline--horizontal{grid-template-columns:repeat(4,minmax(200px,1fr))}
}
@media (max-width:992px){
  .timeline--horizontal{grid-template-columns:repeat(3,minmax(180px,1fr))}
}
@media (max-width:768px){
  .timeline--horizontal{grid-template-columns:repeat(2,1fr)}
}

/* Mobile: change to vertical rail with left-aligned content */
@media (max-width:576px){
  .timeline{grid-template-columns:1fr;padding-top:0;gap:1.25rem 0}
  .timeline::before{left:22px;top:0;bottom:0;height:auto;width:2px}
  .timeline li{text-align:left;padding-left:56px;padding-top:0}
  .timeline li h3{margin:.1rem 0 .25rem}
  .timeline li p{margin:0;min-height:auto;max-width:unset}
  .timeline .dot{left:22px;top:.2rem;transform:translate(-50%,0)}
}

/* Sticky quote bar */
.quote-bar{position:fixed;left:50%;transform:translateX(-50%);bottom:1rem;width:min(980px,92%);background:rgba(0,0,0,.6);backdrop-filter:blur(8px);color:#fff;border-radius:18px;padding:.75rem 1rem;display:flex;gap:.75rem;align-items:center;justify-content:space-between;z-index:1040}
.quote-bar.hidden{display:none}
.quote-bar__form{display:flex;gap:.5rem;align-items:center}
.quote-bar select,.quote-bar button{height:40px;border-radius:10px;border:none;padding:0 .75rem}
.quote-bar button.btn-primary{background:#3A7BFA;color:#fff}
.btn-ghost{border-radius:10px;padding:.6rem 1rem;background:rgba(255,255,255,.1)}

/* Better small-screen layout for sticky bar */
@media (max-width:576px){
  .quote-bar{flex-direction:column;align-items:stretch;gap:.5rem}
  .quote-bar__form{justify-content:space-between}
  .quote-bar select{flex:1}
}

/* Hero CTA wrapper pinned to the bottom center */
.home-page .hero .hero-cta{position:absolute;left:50%;transform:translateX(-50%);bottom:2.5rem;z-index:2;display:flex;justify-content:center;width:100%}
@media (min-width:992px){.home-page .hero .hero-cta{bottom:4rem}}