/* ============================================================
   REDS EDS — app.css  (v2 — fixed hero, robust layout)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow+Condensed:wght@500;700&family=Barlow:wght@400;500;600&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --red:#C8181A;--red-dk:#9e1012;--red-lt:#fde8e8;
  --dark:#1e1e1e;--dark2:#2a2a2a;--mid:#4a4a4a;--light:#f5f5f5;
  --white:#fff;--border:#e2e2e2;--muted:#686868;
  --fh:'Bebas Neue',Impact,'Arial Narrow',Arial,sans-serif;
  --fc:'Barlow Condensed','Arial Narrow',Arial,sans-serif;
  --fb:'Barlow',Arial,sans-serif;
  --r:8px;--rl:14px;
  --sh:0 2px 16px rgba(0,0,0,.08);
  --shl:0 8px 40px rgba(0,0,0,.14);
  --t:.22s ease;
  --wrap:1180px;
}

html{scroll-behavior:smooth}
body{font-family:var(--fb);color:var(--dark);background:var(--white);font-size:16px;line-height:1.7}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
p{margin-bottom:1rem}
.container{max-width:var(--wrap);margin:0 auto;padding:0 28px}
.text-red{color:var(--red)}

/* ── TYPOGRAPHY ──────────────────────── */
h1,h2,h3,h4{font-family:var(--fh);letter-spacing:.03em;line-height:1.05}
h1{font-size:clamp(2.8rem,5.5vw,5.5rem)}
h2{font-size:clamp(2rem,3.5vw,3.2rem)}
h3{font-family:var(--fc);font-size:1.5rem;font-weight:700}

.label{
  display:inline-block;font-family:var(--fc);font-size:12px;
  font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--red);margin-bottom:10px;
}

/* ── BUTTONS ─────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--fc);font-weight:700;font-size:15px;
  letter-spacing:.07em;text-transform:uppercase;
  padding:13px 30px;border-radius:var(--r);
  border:2px solid transparent;cursor:pointer;transition:all var(--t);
}
.btn-primary{background:var(--red);color:var(--white);border-color:var(--red)}
.btn-primary:hover{background:var(--red-dk);border-color:var(--red-dk);transform:translateY(-2px);box-shadow:0 6px 20px rgba(200,24,26,.35)}
.btn-ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.55)}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:var(--white)}
.btn-white{background:var(--white);color:var(--red);border-color:var(--white)}
.btn-white:hover{background:var(--red-lt);transform:translateY(-2px)}
.btn-full{width:100%;justify-content:center}

/* ── NAVBAR ──────────────────────────── */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:900;
  height:68px;background:rgba(20,20,20,.97);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.07);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:100%}
.nav-logo img{height:46px;width:auto;object-fit:contain}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{
  font-family:var(--fc);font-weight:700;font-size:14px;
  letter-spacing:.07em;text-transform:uppercase;
  color:rgba(255,255,255,.75);padding:8px 14px;border-radius:6px;transition:all var(--t);
}
.nav-links a:hover,.nav-links a.active{color:var(--white);background:rgba(255,255,255,.09)}
.nav-cta{background:var(--red)!important;color:var(--white)!important;padding:9px 20px!important;border-radius:var(--r)!important}
.nav-cta:hover{background:var(--red-dk)!important}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-burger span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:all var(--t)}

/* ── HERO ────────────────────────────────────────────────────
   Layout: text (left col) | photo collage (right col)
   The collage uses explicit pixel heights so images never collapse.
──────────────────────────────────────────────────────────── */
.hero{
  background:var(--dark2);
  padding-top:68px; /* = navbar height */
  overflow:hidden;position:relative;
}
.hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 60% 80% at 75% 50%,rgba(200,24,26,.14) 0%,transparent 70%);
}

.hero-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:calc(100vh - 68px);
  align-items:center;
  column-gap:48px;
  position:relative;z-index:1;
  padding-top:56px;padding-bottom:72px;
}

.hero-text{display:flex;flex-direction:column;align-items:flex-start}

.hero-eyebrow{
  font-family:var(--fc);font-size:12px;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--red);border-left:3px solid var(--red);
  padding-left:12px;margin-bottom:20px;
}
.hero-title{
  font-family:var(--fh);
  font-size:clamp(3.6rem,6vw,6.8rem);
  line-height:.98;color:var(--white);margin-bottom:24px;
}
.hero-sub{color:rgba(255,255,255,.62);font-size:16px;line-height:1.75;max-width:440px;margin-bottom:36px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}

/* Photo collage — right column
   Three images: tall main (left), two stacked (right) */
.hero-photos{
  /* fixed height so browser never collapses the grid */
  height:480px;
  display:grid;
  grid-template-columns:1.55fr 1fr;
  grid-template-rows:1fr 1fr;
  gap:10px;
}
.hp{border-radius:12px;overflow:hidden;background:#333}
.hp img{width:100%;height:100%;object-fit:cover;object-position:center}
.hp-main{grid-row:1/3} /* spans both rows */
.hp-top{grid-column:2;grid-row:1}
.hp-bot{grid-column:2;grid-row:2}

/* ── STATS ───────────────────────────── */
.stats{background:var(--red)}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr);text-align:center}
.stat{padding:22px 16px;border-right:1px solid rgba(255,255,255,.2)}
.stat:last-child{border-right:none}
.stat-n{font-family:var(--fh);font-size:2.8rem;color:var(--white);line-height:1}
.stat-l{font-family:var(--fc);font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-top:4px}

/* ── SECTIONS ────────────────────────── */
.section{padding:96px 0}
.section-alt{background:var(--light)}
.sec-hdr{text-align:center;max-width:620px;margin:0 auto 60px}
.sec-hdr h2{margin-bottom:12px}
.sec-hdr p{color:var(--muted);font-size:17px;margin:0}

/* ── SERVICE CARDS ───────────────────── */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.svc-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--rl);padding:26px 22px;
  display:flex;flex-direction:column;gap:10px;
  transition:all var(--t);position:relative;overflow:hidden;
}
.svc-card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform var(--t);
}
.svc-card:hover::after{transform:scaleX(1)}
.svc-card:hover{box-shadow:var(--shl);transform:translateY(-4px);border-color:rgba(200,24,26,.18)}
.svc-ico{width:46px;height:46px;background:var(--red-lt);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:2px}
.svc-card h3{font-size:16px;color:var(--dark)}
.svc-card p{color:var(--muted);font-size:13.5px;line-height:1.6;margin:0;flex:1}
.svc-arrow{color:var(--red);font-size:18px;transition:transform var(--t);margin-top:6px}
.svc-card:hover .svc-arrow{transform:translateX(6px)}

/* ── GALLERY ─────────────────────────── */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;gap:12px}
.gi{border-radius:12px;overflow:hidden;position:relative;background:#ccc}
.gi--tall{grid-row:span 2}
.gi img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.gi:hover img{transform:scale(1.06)}
.gi-cap{
  position:absolute;inset:auto 0 0 0;
  background:linear-gradient(transparent,rgba(0,0,0,.72));
  color:#fff;font-family:var(--fc);font-size:13px;font-weight:700;
  letter-spacing:.04em;padding:28px 14px 12px;
  transform:translateY(100%);transition:transform .3s ease;
}
.gi:hover .gi-cap{transform:translateY(0)}

/* ── WHY REDS ────────────────────────── */
.why-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.why-content h2{margin-bottom:30px}
.why-list{display:flex;flex-direction:column;gap:20px;margin-bottom:36px}
.why-item{display:flex;gap:14px;align-items:flex-start}
.why-chk{
  width:28px;height:28px;flex-shrink:0;
  background:var(--red);color:var(--white);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:14px;margin-top:2px;
}
.why-item strong{font-family:var(--fc);font-size:17px;font-weight:700;display:block;margin-bottom:2px}
.why-item p{color:var(--muted);font-size:14px;margin:0}
.why-photos{position:relative;height:400px}
.why-photos img{position:absolute;border-radius:14px;object-fit:cover;box-shadow:var(--shl)}
.why-photos img:first-child{width:270px;height:310px;top:0;left:0;transform:rotate(-3.5deg);object-position:center top}
.why-photos img:last-child{width:230px;height:250px;bottom:0;right:0;transform:rotate(3deg);border:5px solid var(--white)}

/* ── BRANDS ──────────────────────────── */
.brands{background:var(--light);padding:44px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.brands-row{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.brand-pill{
  font-family:var(--fc);font-weight:700;font-size:14px;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--mid);background:var(--white);border:1px solid var(--border);
  border-radius:100px;padding:9px 26px;transition:all var(--t);
}
.brand-pill:hover{border-color:var(--red);color:var(--red);background:var(--red-lt)}

/* ── CTA BANNER ──────────────────────── */
.cta-banner{background:linear-gradient(130deg,var(--red-dk) 0%,var(--red) 100%);padding:68px 0}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.cta-inner h2{font-size:clamp(2rem,3vw,2.8rem);color:var(--white);margin-bottom:8px}
.cta-inner p{color:rgba(255,255,255,.8);font-size:17px;margin:0}

/* ── PAGE HERO ───────────────────────── */
.page-hero{background:var(--dark2);padding:140px 0 80px;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(200,24,26,.14) 0%,transparent 60%)}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{color:var(--white);margin-bottom:16px}
.page-hero p{color:rgba(255,255,255,.62);font-size:18px;max-width:560px;margin:0}

/* ── SERVICES PAGE ───────────────────── */
.svc-block{display:grid;grid-template-columns:1fr auto;gap:64px;align-items:center;padding:64px 0;border-bottom:1px solid var(--border)}
.svc-block:last-child{border-bottom:none}
.svc-block--alt{direction:rtl}
.svc-block--alt .svc-block-content{direction:ltr}
.svc-block-content h2{margin-bottom:14px}
.svc-block-content p{color:var(--muted);margin-bottom:22px}
.svc-items{list-style:none;margin-bottom:32px;display:flex;flex-direction:column;gap:10px}
.svc-items li{display:flex;align-items:flex-start;gap:10px;font-size:15px;color:var(--muted)}
.svc-items li::before{content:'▸';color:var(--red);font-size:13px;flex-shrink:0;margin-top:3px}
.svc-num-wrap{width:200px;height:200px;flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative;direction:ltr}
.svc-num-wrap::before{content:'';position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle,var(--red-lt) 0%,transparent 70%)}
.svc-num{font-family:var(--fh);font-size:5rem;color:var(--red);opacity:.28;position:relative;z-index:1}

/* ── ABOUT PAGE ──────────────────────── */
.about-cols{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.about-cols h2{margin-bottom:22px}
.about-cols p{color:var(--muted)}
.values{display:flex;flex-direction:column;gap:18px}
.val-card{background:var(--white);border:1px solid var(--border);border-left:4px solid var(--red);border-radius:var(--r);padding:18px 22px}
.val-card strong{font-family:var(--fc);font-size:17px;font-weight:700;display:block;margin-bottom:4px}
.val-card p{color:var(--muted);font-size:14px;margin:0}

.action-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;gap:12px}
.ap{border-radius:12px;overflow:hidden;position:relative;background:#ccc}
.ap--wide{grid-column:span 2}
.ap img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .4s ease}
.ap:hover img{transform:scale(1.05)}
.ap-lbl{position:absolute;inset:auto 0 0 0;background:linear-gradient(transparent,rgba(0,0,0,.7));color:#fff;font-family:var(--fc);font-size:13px;font-weight:700;letter-spacing:.04em;padding:24px 12px 10px}

.supply-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.sp{border-radius:12px;overflow:hidden;position:relative;height:250px;background:#ccc}
.sp img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.sp:hover img{transform:scale(1.04)}
.sp-lbl{position:absolute;inset:auto 0 0 0;background:linear-gradient(transparent,rgba(0,0,0,.7));color:#fff;font-family:var(--fc);font-size:13px;font-weight:700;letter-spacing:.04em;padding:24px 14px 12px}

.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.team-card{background:var(--white);border:1px solid var(--border);border-radius:var(--rl);padding:28px 20px;text-align:center}
.team-ico{font-size:30px;margin-bottom:12px;color:var(--red)}
.team-card strong{font-family:var(--fc);font-size:15px;font-weight:700;display:block;margin-bottom:6px}
.team-card p{color:var(--muted);font-size:13px;margin:0}

/* ── CONTACT PAGE ────────────────────── */
.contact-cols{display:grid;grid-template-columns:1fr 1.7fr;gap:64px;align-items:start}
.contact-info h3,.contact-form-wrap h3{font-family:var(--fc);font-size:22px;font-weight:700;margin-bottom:28px}
.c-item{display:flex;gap:14px;margin-bottom:22px}
.c-ico{font-size:22px;flex-shrink:0}
.c-item strong{font-family:var(--fc);font-size:14px;font-weight:700;letter-spacing:.04em;display:block;margin-bottom:2px}
.c-item p,.c-item a{color:var(--muted);font-size:14px;margin:0}
.c-item a:hover{color:var(--red)}
.contact-form{display:flex;flex-direction:column;gap:18px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-family:var(--fc);font-weight:700;font-size:13px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.req{color:var(--red)}
.form-group input,.form-group select,.form-group textarea{
  font-family:var(--fb);font-size:15px;padding:12px 16px;
  border:1.5px solid var(--border);border-radius:var(--r);
  outline:none;background:var(--white);color:var(--dark);transition:border-color var(--t);
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(200,24,26,.1)}
.form-group textarea{resize:vertical}
.alert{padding:14px 18px;border-radius:var(--r);margin-bottom:18px;font-size:15px}
.alert-ok{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}
.alert-err{background:#fdecea;color:#c62828;border:1px solid #ef9a9a}
.alert-err ul{padding-left:18px;margin:0}

/* ── FOOTER ──────────────────────────── */
.footer{background:var(--dark2);padding-top:72px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:44px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-logo{height:46px;width:auto;object-fit:contain;margin-bottom:14px}
.footer-tag{font-size:14px;color:rgba(255,255,255,.5);line-height:1.7;margin-bottom:18px}
.footer-socials{display:flex;gap:10px}
.footer-socials a{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;transition:background var(--t)}
.footer-socials a:hover{background:var(--red)}
.footer-col h4{font-family:var(--fc);font-size:14px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--white);margin-bottom:18px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col ul a,.footer-col address p{font-size:14px;color:rgba(255,255,255,.55);transition:color var(--t)}
.footer-col ul a:hover{color:var(--red)}
.footer-col address{font-style:normal;display:flex;flex-direction:column;gap:10px}
.footer-col address a{color:rgba(255,255,255,.55)}
.footer-col address a:hover{color:var(--red)}
.footer-btm{padding:18px 0;text-align:center}
.footer-btm p{font-size:13px;color:rgba(255,255,255,.3);margin:0}

/* ── RESPONSIVE ──────────────────────── */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;padding-top:48px}
  .hero-photos{display:none}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .gi--tall{grid-row:span 1}
  .why-inner{grid-template-columns:1fr}
  .why-photos{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .about-cols{grid-template-columns:1fr}
  .action-grid{grid-template-columns:repeat(2,1fr)}
  .ap--wide{grid-column:span 2}
  .supply-grid{grid-template-columns:1fr 1fr}
  .contact-cols{grid-template-columns:1fr}
}
@media(max-width:768px){
  .nav-links{display:none;flex-direction:column;position:fixed;top:68px;left:0;right:0;background:rgba(18,18,18,.98);padding:16px 20px;gap:4px}
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 16px;width:100%}
  .nav-burger{display:flex}
  .hero-inner{min-height:auto;padding:40px 0 56px}
  .hero-title{font-size:3.2rem}
  .svc-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr;grid-auto-rows:180px}
  .gi--tall{grid-row:span 1}
  .footer-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .action-grid{grid-template-columns:1fr 1fr}
  .ap--wide{grid-column:span 2}
  .supply-grid{grid-template-columns:1fr}
  .row2{grid-template-columns:1fr}
  .cta-inner{flex-direction:column;text-align:center}
  .svc-block{grid-template-columns:1fr}
  .svc-block--alt{direction:ltr}
  .svc-num-wrap{display:none}
}

/* ── ACTION GRID EXTENDED (10 items) ── */
.action-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 230px;
  gap: 12px;
}
.ap--wide { grid-column: span 2; }

@media(max-width:1024px) {
  .action-grid { grid-template-columns: repeat(2,1fr); }
  .ap--wide { grid-column: span 2; }
}
@media(max-width:600px) {
  .action-grid { grid-template-columns: 1fr 1fr; grid-auto-rows: 160px; }
  .ap--wide { grid-column: span 2; }
}
