/* =========================================================
   NOMAD DIGITAL DESIGNS — UNIFIED STYLE.CSS
   Works for: index.html (id="home"), services.html (class="services-page"),
              projects.html (class="projects-page")
   ========================================================= */

/* ---------- TOKENS ---------- */
:root{
  --bg:#0c0c10;
  --bg2:#0a0a0e;
  --surface:#121216;

  --text:#ececee;
  --muted:rgba(236,236,238,.78);
  --gold1:#ffcc66;
  --gold2:#d4a340;
  --line:rgba(255,255,255,.12);
  --shadow:0 28px 80px rgba(0,0,0,.60);

  --orange1:#ff9c1a;
  --orange2:#ff8300;
  --orange3:#f26e00;
  --goldCard1:#ffc574;
  --goldCard2:#ffb055;

  --navH:78px;
  --container:1200px;
}

/* ---------- RESET ---------- */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
a{color:inherit;text-decoration:none}

body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 800px at 20% 0%, rgba(255,204,102,.08), rgba(0,0,0,0) 55%),
    linear-gradient(180deg,var(--bg),var(--bg2));
  overflow-x:hidden;
}

body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  background:radial-gradient(
    1400px 900px at 50% -10%,
    rgba(255,255,255,.09),
    rgba(0,0,0,0) 60%
  );
  mix-blend-mode:screen;
}

/* ---------- LAYOUT ---------- */
.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 24px;
}

.section{
  position:relative;
  padding:74px 0 100px;
  background:linear-gradient(180deg,var(--surface),var(--bg2));
}
.section + .section{border-top:1px solid var(--line)}

/* ---------- HEADER / NAV ---------- */
.header{
  position:fixed;
  top:0;left:0;right:0;
  height:var(--navH);
  z-index:1000;
  background:linear-gradient(180deg, rgba(0,0,0,.80), rgba(0,0,0,.50));
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{
  height:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.brand img{
  height:48px;
  width:auto;
  display:block;
  transform:translateY(1px);
  transition:transform .35s ease, filter .35s ease;
}
.brand:hover img{
  transform:translateY(-1px);
  filter:drop-shadow(0 4px 12px rgba(255,204,102,.35));
}

.menu{
  display:flex;
  align-items:center;
  gap:22px;
}
.menu a{
  position:relative;
  padding:10px 14px;
  border-radius:999px;
  font-size:13px;
  letter-spacing:.10em;
  text-transform:uppercase;
  opacity:.9;
  transition:color .35s ease, transform .35s ease, opacity .35s ease;
  outline:none;
}
.menu a:hover{
  opacity:1;
  transform:translateY(-2px);
}
.menu a:focus,.menu a:active{outline:none}
.menu a:focus-visible{
  outline:2px solid rgba(255,204,102,.45);
  outline-offset:4px;
  box-shadow:0 0 0 6px rgba(255,204,102,.10);
}
.menu a::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:4px;
  width:0;
  height:1px;
  background:linear-gradient(90deg, transparent, #ffcc66, transparent);
  transform:translateX(-50%);
  transition:width .35s ease;
  opacity:.8;
}
.menu a:hover::after{width:70%}

.menu .pill{
  padding:10px 16px;
  border-radius:999px;
  border:1px solid rgba(255,204,102,.75);
  color:var(--gold1);
  background:linear-gradient(135deg, rgba(255,204,102,.18), rgba(212,163,64,.35));
  transition:transform .4s ease, box-shadow .4s ease, background .4s ease, color .4s ease;
}
.menu .pill:hover{
  transform:translateY(-3px);
  background:linear-gradient(135deg, #ffcc66, #d4a340);
  color:#111;
  box-shadow:0 12px 30px rgba(255,204,102,.45);
}
.menu .pill::after{display:none}

.menu-btn{
  display:none;
  width:44px;height:44px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.35);
  border-radius:12px;
}
.menu-btn span{
  display:block;
  height:2px;
  width:18px;
  background:#fff;
  margin:4px auto;
  opacity:.9;
}

/* ---------- HERO (shared) ---------- */
.hero{
  position:relative;
  min-height:74vh;
  padding-top:var(--navH);
  overflow:hidden;
}
.hero-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(96deg, rgba(0,0,0,.74) 0%, rgba(0,0,0,.30) 52%, rgba(0,0,0,.12) 100%),
    url("../assets/hero.jpg") center/cover no-repeat;
  z-index:-1;
}
.hero-inner{
  max-width:var(--container);
  margin:0 auto;
  padding:64px 24px;
  display:flex;
  align-items:center;
  min-height:calc(74vh - var(--navH));
}
.hero-card{
  max-width:740px;
  padding:34px 34px 30px;
  border-radius:26px;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg, rgba(9,12,20,.68), rgba(9,12,20,.38));
  box-shadow:0 30px 90px rgba(0,0,0,.48);
}
.kicker{
  color:var(--gold1);
  font-size:12px;
  letter-spacing:.30em;
  text-transform:uppercase;
  margin:0 0 14px;
  font-weight:700;
}
.h1{
  margin:0;
  font-size:clamp(40px,6vw,82px);
  line-height:1.04;
  letter-spacing:-.02em;
  font-weight:900;
}
.gold{
  display:block;
  background:linear-gradient(180deg,#ffd98a 0%,#ffcc66 58%,#d4a340 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.lead{
  margin:16px 0 0;
  max-width:610px;
  color:var(--muted);
  font-size:18px;
  line-height:1.58;
  font-weight:500;
}

/* ---------- BROWN INTRO BOX (same on all pages) ---------- */
.value-box,
.services-intro-box,
.brag-box{
  position:relative;
  margin:0 auto 56px;
  max-width:1200px;
  padding:30px 28px;
  border-radius:24px;
  text-align:center;
  border:1px solid rgba(255,204,102,.32);
  background:
    radial-gradient(520px 220px at 50% 10%, rgba(255,204,102,.20), rgba(42,28,8,.86) 70%),
    linear-gradient(180deg, rgba(38,25,8,.96), rgba(19,13,5,.96));
  box-shadow:0 26px 80px rgba(0,0,0,.56), 0 0 50px rgba(255,152,15,.18);
}
.value-box h2,.value-box .h2,
.services-intro-box h2,
.brag-box h2{
  margin:0;
  font-size:clamp(30px,4vw,46px);
  line-height:1.1;
  color:#fff;
}
.value-box p,.value-box .muted,
.services-intro-box p,
.brag-box p{
  margin:12px auto 0;
  max-width:900px;
  font-size:17px;
  line-height:1.6;
  color:#f2ddb0;
}

/* ---------- INDEX: 3 VIDEO CARDS ---------- */
#home .grid3{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:28px;
}

#home .grid3 .card{
  display:grid;
  grid-template-rows:190px 78px 120px;
  border-radius:20px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg,#0f1015,#0a0b10);
  box-shadow:0 24px 70px rgba(0,0,0,.42);
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
#home .grid3 .card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,204,102,.45);
  box-shadow:0 30px 85px rgba(0,0,0,.5), 0 0 22px rgba(255,166,41,.18);
}

#home .grid3 .card .card-video{
  height:190px;
  background:#000;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
#home .grid3 .card .card-video video{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
  background:#000;
}

#home .grid3 .card h3{
  margin:0;
  min-height:78px;
  padding:12px 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  font-size:clamp(20px,1.5vw,30px);
  line-height:1.05;
  font-weight:800;
  letter-spacing:-0.01em;
  color:#fff;
  background:linear-gradient(135deg,var(--orange1) 0%, var(--orange2) 55%, var(--orange3) 100%);
  text-shadow:0 2px 10px rgba(0,0,0,.18);
}
#home .grid3 .card p{
  margin:0;
  padding:12px 14px;
  min-height:100px;
  max-height:100px;
  overflow:hidden;
  font-size:clamp(13px,.95vw,16px);
  line-height:1.4;
  font-weight:600;
  color:#2a1800;
  background:linear-gradient(180deg,var(--goldCard1) 0%, var(--goldCard2) 100%);
  border-top:1px solid rgba(255,255,255,.35);
}

/* ---------- SERVICES: 6 MOSAIC CARDS ---------- */
.services-page .mosaic{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
}
.services-page .service{
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg,#121826,#141a2a);
  box-shadow:0 24px 70px rgba(0,0,0,.42);
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
  display:grid;
  grid-template-rows:220px 88px 1fr;
}
.services-page .service:hover{
  transform:translateY(-6px);
  border-color:rgba(255,204,102,.42);
  box-shadow:0 32px 90px rgba(0,0,0,.52), 0 0 24px rgba(255,166,41,.18);
}
.services-page .media{
  height:220px;
  background:#0c1018;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.services-page .media img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  display:block;
  background:#0c1018;
  padding:12px;
}
.services-page .label{
  margin:0;
  min-height:88px;
  padding:14px 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  font-size:clamp(24px,2vw,34px);
  line-height:1.05;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
  color:#fff;
  background:linear-gradient(135deg,var(--orange1) 0%, var(--orange2) 55%, var(--orange3) 100%);
  text-shadow:0 2px 10px rgba(0,0,0,.2);
}
.services-page .copy{
  margin:0;
  padding:14px 16px 16px;
  background:linear-gradient(180deg,#f4b156 0%, #eca748 100%);
  color:#2a1800;
  font-size:17px;
  line-height:1.45;
  font-weight:600;
  border-top:1px solid rgba(255,255,255,.32);
}

/* ---------- PROJECTS ---------- */
.projects-page .brag-strip{
  margin:-40px auto 0;
  max-width:var(--container);
  padding:0 24px;
  position:relative;
  z-index:2;
}
.projects-page .projects-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
}
.projects-page .project{
  border-radius:22px;
  overflow:hidden;
  border:1px solid var(--line);
  background:linear-gradient(180deg, #131826, #171d2d);
  box-shadow:0 24px 70px rgba(0,0,0,.42);
  transition:transform .4s ease, box-shadow .4s ease, border-color .4s ease;
  display:flex;
  flex-direction:column;
}
.projects-page .project:hover{
  transform:translateY(-10px);
  border-color:rgba(255,204,102,.45);
  box-shadow:0 38px 100px rgba(0,0,0,.56), 0 0 55px rgba(255,152,15,.20);
}
.projects-page .project-media{
  height:230px;
  background:#0c1018;
  position:relative;
  overflow:hidden;
}
.projects-page .project-media img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  display:block;
  transform:none;
  padding:14px;
}
.projects-page .project-title{
  background:linear-gradient(135deg,var(--orange1),var(--orange2));
  color:#fff;
  font-size:36px;
  font-weight:900;
  line-height:1.05;
  letter-spacing:.01em;
  padding:18px 20px 16px;
  text-align:center;
  text-transform:uppercase;
}
.projects-page .project-body{
  padding:18px 20px 20px;
  background:linear-gradient(180deg, #f4b156, #f0a64a);
  color:#2b1a00;
  min-height:220px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:12px;
}
.projects-page .project-role{
  display:inline-flex;
  width:max-content;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(43,26,0,.12);
  border:1px solid rgba(43,26,0,.18);
  font-size:12px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.projects-page .project-copy{
  margin:0;
  font-size:28px;
  line-height:1.42;
  font-weight:650;
}
.projects-page .project-kpis{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
  margin-top:8px;
}
.projects-page .kpi{
  padding:10px 8px;
  border-radius:12px;
  background:rgba(43,26,0,.10);
  border:1px solid rgba(43,26,0,.16);
  text-align:center;
}
.projects-page .kpi .n{
  font-size:20px;
  font-weight:900;
  line-height:1;
  display:block;
}
.projects-page .kpi .t{
  margin-top:4px;
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  opacity:.82;
}

/* ---------- FOOTER ---------- */
.footer{
  margin-top:120px;
  padding:40px 24px;
  border-top:1px solid rgba(255,255,255,.08);
}
.footer .container{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
  text-align:center;
}
.footer nav,.footer .footer-nav{
  display:flex;
  gap:16px;
  justify-content:center;
}
.footer a{
  font-size:13px;
  opacity:.8;
}
.footer a:hover{opacity:1}

/* ---------- RESPONSIVE ---------- */
@media (max-width:1060px){
  #home .grid3,
  .services-page .mosaic,
  .projects-page .projects-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width:860px){
  .menu-btn{display:inline-flex;align-items:center;justify-content:center}
  .menu{
    display:none;
    position:absolute;
    top:var(--navH);
    right:18px;
    left:18px;
    background:rgba(0,0,0,.92);
    border:1px solid var(--line);
    border-radius:18px;
    padding:16px;
    flex-direction:column;
    gap:14px;
  }
  .menu.open{display:flex}
}
@media (max-width:760px){
  .hero{min-height:64vh}
  .hero-inner{
    min-height:calc(64vh - var(--navH));
    padding:44px 20px;
  }
  .hero-card{padding:24px}
  .lead{font-size:16px}

  #home .grid3,
  .services-page .mosaic,
  .projects-page .projects-grid{
    grid-template-columns:1fr;
  }

  #home .grid3 .card{
    grid-template-rows:170px 70px 110px;
  }
  #home .grid3 .card .card-video{
    height:170px;
  }
  #home .grid3 .card p{
    min-height:110px;
    max-height:110px;
  }

  .services-page .service{grid-template-rows:200px 78px 1fr}
  .services-page .media{height:200px}
  .services-page .label{font-size:clamp(22px,6vw,30px);min-height:78px}
  .services-page .copy{font-size:15px}

  .projects-page .project-title{font-size:34px}
  .projects-page .project-copy{font-size:26px}
}
/* =========================================================
   CONTACT PAGE PROTECTION PATCH
   Paste at VERY END of css/style.css
   ========================================================= */

/* 1) Ensure ONLY index cards use .grid3 global card styling */
body:not(#home) .grid3 .card{
  display:flex !important;
  grid-template-rows:none !important;
  min-height:0 !important;
  max-height:none !important;
  overflow:visible !important;
  border-radius:22px !important;
}

body:not(#home) .grid3 .card h3{
  min-height:0 !important;
  max-height:none !important;
  font-size:inherit !important;
  line-height:inherit !important;
  padding:0 !important;
  background:none !important;
  color:inherit !important;
  text-shadow:none !important;
}

body:not(#home) .grid3 .card p{
  min-height:0 !important;
  max-height:none !important;
  overflow:visible !important;
  font-size:inherit !important;
  line-height:inherit !important;
  padding:0 !important;
  background:none !important;
  color:inherit !important;
  border-top:0 !important;
}

/* 2) Keep index styling intact */
#home .grid3 .card{
  display:grid !important;
  grid-template-rows:190px 78px 120px !important;
  overflow:hidden !important;
}
#home .grid3 .card h3{
  min-height:78px !important;
  padding:12px 16px !important;
}
#home .grid3 .card p{
  min-height:100px !important;
  max-height:100px !important;
  overflow:hidden !important;
  padding:12px 14px !important;
}

/* 3) Restore Contact card layout explicitly */
.contact-lux{
  display:block !important;
  padding:20px !important;
  border-radius:22px !important;
  border:1px solid rgba(255,204,102,.20) !important;
  background:
    radial-gradient(700px 220px at 100% 0%, rgba(255,170,60,.08), transparent 60%),
    linear-gradient(180deg,#111318,#0b0d12) !important;
  box-shadow:
    0 24px 70px rgba(0,0,0,.45),
    inset 0 0 0 1px rgba(255,255,255,.02) !important;
}

.contact-lux h3{
  margin:0 0 10px !important;
  font-size:20px !important;
  line-height:1.2 !important;
  font-weight:700 !important;
  color:#f4f5f7 !important;
}

.contact-lux p{
  margin:0 !important;
  font-size:15px !important;
  line-height:1.6 !important;
  color:rgba(236,236,238,.84) !important;
}

.contact-list{
  margin:0 !important;
  padding:0 !important;
  list-style:none !important;
  display:grid !important;
  gap:10px !important;
}

.contact-list li{
  display:grid !important;
  grid-template-columns:96px 1fr auto !important;
  align-items:center !important;
  gap:8px 10px !important;
  padding:10px 12px !important;
  border-radius:12px !important;
  border:1px solid rgba(255,255,255,.08) !important;
  background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,0)) !important;
}

.contact-list .label{
  font-size:11px !important;
  letter-spacing:.14em !important;
  text-transform:uppercase !important;
  font-weight:700 !important;
  color:rgba(255,204,102,.88) !important;
}

.contact-list a,
.contact-list .text{
  font-size:15px !important;
  line-height:1.35 !important;
  color:#f2f3f5 !important;
  word-break:break-word !important;
}

.badge-preferred{
  justify-self:start !important;
  font-size:10px !important;
  letter-spacing:.08em !important;
  text-transform:uppercase !important;
  color:#241400 !important;
  background:linear-gradient(135deg,#ffcc66,#d4a340) !important;
  border-radius:999px !important;
  padding:5px 9px !important;
  font-weight:700 !important;
}

.social-row{
  margin-top:12px !important;
  display:flex !important;
  gap:10px !important;
  flex-wrap:wrap !important;
}

.social-chip{
  display:inline-flex !important;
  align-items:center !important;
  gap:10px !important;
  padding:8px 12px !important;
  border-radius:999px !important;
  border:1px solid rgba(255,204,102,.35) !important;
  background:linear-gradient(180deg,rgba(255,204,102,.14),rgba(255,204,102,.05)) !important;
}

.social-chip img{
  width:22px !important;
  height:22px !important;
  object-fit:contain !important;
  border-radius:8px !important;
  background:#0f1116 !important;
  padding:2px !important;
}

.social-chip span{
  color:#f4f5f7 !important;
  font-size:11px !important;
  letter-spacing:.05em !important;
  text-transform:uppercase !important;
  font-weight:700 !important;
}

.contact-divider{
  height:1px !important;
  margin:14px 0 !important;
  background:linear-gradient(90deg,transparent,rgba(255,204,102,.45),transparent) !important;
}

/* 4) Mobile safety for contact */
@media (max-width:760px){
  .contact-list li{
    grid-template-columns:1fr !important;
    align-items:start !important;
  }
}
@media (max-width: 860px){
  .menu-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }

  .menu{
    display:none;
    position:absolute;
    top:var(--navH);
    right:18px;
    left:18px;
    background:rgba(0,0,0,.92);
    border:1px solid var(--line);
    border-radius:18px;
    padding:16px;
    flex-direction:column;
    gap:14px;
    z-index:1001;
  }

  .menu.open{display:flex;}
}
