
/* Mega Yapı - Premium Modern Theme
  Replace assets/hero.webp with your own high-res project photo for best results.
*/
:root{
  --bg:#070a10;
  --bg2:#0b1020;
  --card:rgba(10,14,22,.66);
  --card2:rgba(18,24,40,.62);
  --stroke:rgba(255,255,255,.12);
  --stroke2:rgba(255,255,255,.18);
  --text:#e9edf6;
  --muted:rgba(233,237,246,.72);
  --muted2:rgba(233,237,246,.58);
  --accent:#d1a84a;
  --accent2:#f4d27a;
  --shadow: 0 18px 55px rgba(0,0,0,.55);
  --shadow2: 0 10px 28px rgba(0,0,0,.38);
  --radius: 18px;
  --radius2: 26px;
  --container: 1120px;
  --focus: 0 0 0 3px rgba(209,168,74,.35);
  --page-bg: url("/assets/hero.webp");
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 25% 10%, rgba(209,168,74,.10), transparent 60%),
    radial-gradient(900px 500px at 80% 0%, rgba(65,130,255,.10), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg2));
  line-height:1.6;
  overflow-y:auto;
}

/* Debug toggles for mobile render issues (enable via html class) */
html.test-no-motion *{transition:none !important; animation:none !important;}
html.test-no-composite,
html.test-no-composite body,
html.test-no-composite main{
  transform:none !important;
  filter:none !important;
  backdrop-filter:none !important;
  will-change:auto !important;
  contain:none !important;
  backface-visibility:visible !important;
}
html.test-no-composite body::before{filter:none !important; opacity:0 !important;}
html.test-no-hero .hero{background: #0b0f18 !important;}
html.test-no-hero .hero-overlay{display:none !important;}
html.test-system-font body{font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif !important;}

body::before{
  content:'';
  position:fixed;
  inset:0;
  background: var(--page-bg) center/cover no-repeat;
  filter: blur(28px) saturate(1.1);
  opacity:.18;
  z-index:-2;
  transition: opacity .3s ease, filter .3s ease, background-image .3s ease;
}

a{color:inherit; text-decoration:none}
a:hover{opacity:.94}
img{max-width:100%; display:block}

.container{max-width:var(--container); margin:0 auto; padding:0 18px}

.skip-link{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{left:18px; top:18px; width:auto; height:auto; padding:10px 12px; background:#111827; border:1px solid var(--stroke2); border-radius:12px; box-shadow:var(--shadow2);}

.nav{
  position:sticky; top:0; z-index:100;
  backdrop-filter: blur(14px);
  background: linear-gradient(180deg, rgba(8,10,16,.86), rgba(8,10,16,.55));
  border-bottom:1px solid var(--stroke);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 0;
  gap:14px;
}
.brand{
  position:relative;
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:700;
  letter-spacing:.3px;
  min-width:0;
  width: fit-content;
  max-width:260px;
  flex:0 0 auto;
  height:72px;
  transform: translateY(-6px);
}
.brand > div{
  position:absolute;
  left:80px;
  bottom:-13px;
  display:flex;
  flex-direction:column;
  line-height:1.2;
}
.brand-mark{
  display:block;
  height:78px;
  width:250px;
  max-width:260px;
  background: url("/assets/logo2.png") left center/contain no-repeat;
  background-color: transparent;
  position:relative;
  transform: scale(2);
  transform-origin: left center;
  pointer-events:none;
}
.brand > div span{display:none;}
.brand small{
  display:block;
  font-weight:700;
  color:var(--muted2);
  margin-top:-8px;
  font-size:12.5px;
  letter-spacing:.2px;
}

@media (max-width: 680px){
  .brand{min-width:0;}
  .brand-mark{width:150px; height:48px;}
  .brand > div{display:none;}
}

.menu{
  position:relative;
  z-index:2;
  display:flex; align-items:center; gap:18px;
}
.menu a{
  color:var(--muted);
  font-weight:600;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid transparent;
}
.menu a[aria-current="page"]{
  color:var(--text);
  border-color:var(--stroke);
  background:rgba(255,255,255,.04);
}
.menu a:hover{
  color:var(--text);
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.08);
}

.nav-cta{display:flex; gap:10px; align-items:center; position:relative; z-index:2}
.nav-drawer{display:contents;}
.nav-backdrop{display:none;}

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  border-radius:14px;
  padding:11px 14px;
  font-weight:700;
  letter-spacing:.2px;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.04);
  box-shadow: 0 8px 18px rgba(0,0,0,.18);
}
.btn:hover{transform: translateY(-1px)}
.btn:active{transform: translateY(0)}
.btn.primary{
  border-color: rgba(209,168,74,.35);
  background: linear-gradient(135deg, rgba(209,168,74,.92), rgba(244,210,122,.84));
  color:#0a0f18;
  box-shadow: 0 14px 34px rgba(209,168,74,.20);
}
.btn.ghost{background:rgba(255,255,255,.03)}

.icon{width:18px; height:18px; display:inline-block}
.badge{
  display:inline-flex; gap:8px; align-items:center;
  padding:8px 10px; border-radius:999px;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.03);
  color:var(--muted);
  font-weight:600;
  font-size:13px;
}

.hero{
  position:relative;
  border-radius: var(--radius2);
  overflow:hidden;
  box-shadow: var(--shadow);
  border:1px solid rgba(255,255,255,.10);
  margin:18px 0 26px;
  min-height: 520px;
  background:
    linear-gradient(90deg, rgba(5,7,12,.75), rgba(5,7,12,.55) 40%, rgba(5,7,12,.20) 72%, rgba(5,7,12,.55)),
    url("/assets/hero.webp") center/cover no-repeat;
}
.hero-overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(700px 320px at 22% 28%, rgba(209,168,74,.22), transparent 60%),
    radial-gradient(900px 420px at 90% 10%, rgba(90,140,255,.18), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.12));
  pointer-events:none;
}
.hero-inner{
  position:relative;
  padding: 44px 34px;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 22px;
  align-items:end;
  min-height:520px;
}
.hero h1{
  margin: 10px 0 10px;
  font-size: clamp(30px, 4.2vw, 52px);
  line-height:1.08;
  letter-spacing: -.5px;
  text-shadow: 0 20px 55px rgba(0,0,0,.65);
}
.hero p{
  margin: 0 0 16px;
  color: rgba(233,237,246,.86);
  font-size: 16.5px;
  max-width: 58ch;
}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:10px}
.hero .muted.small{margin-top:8px; display:inline-block;}

.hero-card{
  align-self:stretch;
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.14);
  background: linear-gradient(180deg, rgba(12,16,26,.82), rgba(12,16,26,.55));
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow2);
  padding: 16px 16px 14px;
}
.hero-card h3{margin:0 0 6px; font-size:14px; color:var(--muted)}
.kpis{
  display:grid; gap:10px;
  grid-template-columns: repeat(2, minmax(0,1fr));
}
.kpi{
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  padding: 12px;
}
.kpi strong{display:block; font-size:16px}
.kpi span{color:var(--muted2); font-size:12.5px}
.hero-summary{
  border:1px solid rgba(255,255,255,.16);
  background: radial-gradient(140% 110% at 20% 20%, rgba(244,210,122,.18), rgba(12,16,26,.0)), linear-gradient(180deg, rgba(10,12,18,.9), rgba(10,12,18,.65));
  padding:20px 18px 18px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.hero-summary-head h3{
  margin:0 0 6px;
  font-size:20px;
  color:var(--text);
}
.hero-summary-head p{
  margin:0;
  color:var(--muted);
  font-weight:600;
}
.hero-summary-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:12px;
}
.hero-summary-item{
  position:relative;
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 12px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.14);
  background: linear-gradient(145deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
  transition: border-color .25s ease, transform .15s ease;
}
.hero-summary-item::after{
  content:'';
  position:absolute;
  inset:-1px;
  border-radius:18px;
  border:1px solid rgba(244,210,122,.32);
  opacity:0;
  transition: opacity .25s ease;
  pointer-events:none;
}
.hero-summary-item:hover{
  border-color: rgba(244,210,122,.35);
  transform: translateY(-1px);
}
.hero-summary-item:hover::after{opacity:1;}
.hero-summary-item strong{
  display:block;
  font-size:16px;
}
.hero-summary-item span{color:var(--muted2); font-size:13px}
.hero-icon{
  flex-shrink:0;
  width:52px;
  height:52px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background: radial-gradient(circle at 30% 30%, rgba(244,210,122,.35), rgba(12,16,26,.0)), linear-gradient(145deg, rgba(14,18,28,1), rgba(18,22,34,1));
  box-shadow: 0 12px 26px rgba(0,0,0,.25);
}
.hero-icon svg{width:32px; height:32px;}
.hero-summary-cta{
  margin-top:6px;
  padding:14px 12px 12px;
  border-radius:16px;
  border:1px solid rgba(244,210,122,.35);
  background: linear-gradient(180deg, rgba(244,210,122,.12), rgba(244,210,122,.04));
  text-align:center;
  display:grid;
  gap:10px;
}
.hero-summary-cta p{
  margin:0;
  font-weight:700;
  color:var(--text);
}
.hero-cta-btn{
  border-color: rgba(244,210,122,.5);
  background: rgba(0,0,0,.0);
  color: var(--accent2);
  box-shadow:none;
}
.hero-cta-btn:hover{background: rgba(244,210,122,.12); transform: translateY(-1px);}

.section{padding: 26px 0}
.section h2{
  margin: 0 0 12px;
  font-size: 24px;
  letter-spacing:-.2px;
}
.section p.lead{color:var(--muted); margin:0 0 16px; max-width:70ch}

.grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}
.card{
  grid-column: span 4;
  border-radius: var(--radius);
  border: 1px solid var(--stroke);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow2);
  padding: 16px;
}
.card h3{margin: 0 0 6px; font-size: 16px}
.card p{margin:0; color:var(--muted)}
.card .meta{margin-top:10px; color:var(--muted2); font-size:13px}
.card a.more{display:inline-flex; margin-top:12px; gap:8px; align-items:center; color:var(--accent2); font-weight:700}

.split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items:start;
}
.panel{
  border-radius: var(--radius);
  border:1px solid var(--stroke);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow2);
  padding: 16px;
}
.panel h3{margin:0 0 8px}
.list{margin:0; padding-left:18px; color:var(--muted)}
.list li{margin:6px 0}

.pagehead{
  padding: 26px 0 10px;
}
.pagehead h1{margin:0 0 6px; font-size:34px; letter-spacing:-.3px}
.pagehead p{margin:0; color:var(--muted); max-width:75ch}

.breadcrumb{
  display:flex; gap:8px; align-items:center;
  color:var(--muted2);
  font-size:13px;
  margin-top:10px;
}
.breadcrumb a{color:var(--muted); font-weight:700}

.form{
  display:grid;
  gap: 12px;
  margin-top: 12px;
}
.field{
  display:grid;
  gap: 6px;
}
label{font-weight:700; color:var(--muted)}
input, textarea, select{
  width:100%;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  color: var(--text);
  padding: 12px 12px;
  outline: none;
}
textarea{min-height:120px; resize:vertical}
input:focus, textarea:focus, select:focus{box-shadow: var(--focus); border-color: rgba(209,168,74,.35)}

.notice{
  border-radius: 16px;
  border:1px solid rgba(209,168,74,.25);
  background: rgba(209,168,74,.10);
  padding: 12px 14px;
  color: rgba(233,237,246,.9);
}

.footer{
  margin-top: 26px;
  border-top: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(6,9,14,.0), rgba(6,9,14,.62));
}
.footer-inner{
  padding: 22px 0;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 16px;
}
.footer a{color:var(--muted)}
.footer a:hover{color:var(--text)}
.footer small{color:var(--muted2)}
.footer .cols{display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:10px}
.footer .cols h4{margin:0 0 8px; font-size:13px; color:var(--muted)}
.footer .cols ul{list-style:none; padding:0; margin:0; display:grid; gap:8px}
.footer .cols li{margin:0}

hr.sep{
  border:0; border-top:1px solid rgba(255,255,255,.10);
  margin: 16px 0;
}

.faq details{
  border-radius: 16px;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.03);
  padding: 12px 14px;
}
.faq details + details{margin-top:10px}
.faq summary{
  cursor:pointer;
  font-weight:800;
  list-style:none;
}
.faq summary::-webkit-details-marker{display:none}
.faq p{margin:8px 0 0; color:var(--muted)}

/* FAQ redesign */
.faq-page{padding-bottom:30px;}
.faq-hero{
  padding:32px 0 10px;
}
.faq-hero-inner{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:20px;
  align-items:start;
}
.faq-hero-copy h1{
  margin:8px 0 10px;
  font-size: clamp(28px, 3.4vw, 40px);
  line-height:1.15;
}
.faq-hero-copy .lead{
  margin:0 0 14px;
  color:var(--muted);
  max-width:60ch;
}
.faq-trust{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:10px;
}
.faq-trust-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.04);
  color:var(--text);
  font-weight:600;
}
.faq-trust-icon{
  width:28px;
  height:28px;
  border-radius:10px;
  display:grid;
  place-items:center;
  color:var(--accent2);
  background: rgba(244,210,122,.12);
}
.faq-trust-icon svg{width:16px; height:16px;}
.faq-hero-cta{
  border-radius:20px;
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(12,16,26,.82), rgba(12,16,26,.58));
  box-shadow: var(--shadow2);
  padding:20px;
  display:grid;
  gap:12px;
}
.faq-hero-cta h2{margin:0; font-size:20px;}
.faq-hero-cta p{margin:0; color:var(--muted);}
.faq-hero-actions{display:flex; gap:10px; flex-wrap:wrap;}
.faq-hero-contact{
  display:flex;
  gap:8px;
  align-items:center;
  color:var(--muted2);
  font-size:13px;
}
.faq-hero-contact a{color:var(--text); font-weight:700;}
.faq-section{padding-top:12px;}
.faq-tabs{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:16px;
}
.faq-tab{
  border-radius:999px;
  padding:8px 14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color:var(--muted);
  font-weight:700;
  cursor:pointer;
}
.faq-tab.active{
  color:var(--text);
  border-color: rgba(244,210,122,.45);
  background: rgba(244,210,122,.12);
  box-shadow: 0 10px 26px rgba(209,168,74,.2);
}
.faq-panels{display:grid; gap:12px;}
.faq-panel{display:none;}
.faq-panel.active{display:grid; gap:12px;}
.faq-card{
  border-radius:18px;
  border:1px solid rgba(244,210,122,.25);
  background: linear-gradient(180deg, rgba(12,16,26,.75), rgba(12,16,26,.52));
  padding:0;
  overflow:hidden;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.faq-card summary{
  cursor:pointer;
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 18px;
  font-weight:800;
}
.faq-card summary::-webkit-details-marker{display:none;}
.faq-card summary::after{
  content:'';
  width:18px;
  height:18px;
  border-radius:999px;
  border:1px solid rgba(244,210,122,.6);
  background: radial-gradient(circle, rgba(244,210,122,.25), transparent 60%);
  mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M6 9l6 6 6-6' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/14px no-repeat;
}
.faq-card[open]{
  box-shadow: 0 0 0 1px rgba(244,210,122,.4), 0 18px 45px rgba(0,0,0,.45);
}
.faq-card[open] summary::after{transform: rotate(180deg);}
.faq-answer{
  padding:0 18px 16px;
  color:var(--muted);
  display:grid;
  gap:10px;
  max-height:0;
  opacity:0;
  transform: translateY(-4px);
  transition: max-height .3s ease, opacity .3s ease, transform .3s ease;
}
.faq-card[open] .faq-answer{
  max-height:320px;
  opacity:1;
  transform: translateY(0);
}
.faq-answer p{margin:0;}
.faq-meta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  color:var(--muted2);
  font-size:12.5px;
  font-weight:700;
}
.faq-meta span{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
}
.faq-meta svg{width:14px; height:14px;}
.faq-cta{
  padding:26px 0 10px;
}
.faq-cta-inner{
  border-radius:22px;
  border:1px solid rgba(244,210,122,.35);
  background: linear-gradient(180deg, rgba(244,210,122,.1), rgba(12,16,26,.5));
  padding:22px;
  text-align:center;
  display:grid;
  gap:10px;
}
.faq-cta-actions{
  display:flex;
  gap:10px;
  justify-content:center;
  flex-wrap:wrap;
}

@media (max-width: 980px){
  .faq-hero-inner{grid-template-columns:1fr;}
  .faq-hero-cta{order:2;}
}
@media (max-width: 680px){
  .faq-trust{grid-template-columns:1fr;}
  .faq-meta{flex-direction:column; align-items:flex-start;}
}

/* Service grid */
.service-page .pagehead{
  text-align:center;
  margin-bottom:24px;
}
.service-hero{
  display:flex;
  justify-content:space-between;
  gap:24px;
  background:
    radial-gradient(120% 120% at 10% 20%, rgba(255,255,255,.08), transparent 60%),
    rgba(255,255,255,.04);
  backdrop-filter: blur(16px);
  border:1px solid rgba(255,255,255,.08);
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
  padding:28px;
}
.service-hero .eyebrow{
  letter-spacing:.08em;
  font-size:12px;
  text-transform:uppercase;
  color:var(--muted);
  margin:0 0 8px;
}
.service-hero h2{
  margin:0 0 8px;
  font-size:28px;
}
.service-hero .lead{
  margin:0 0 16px;
  color:var(--muted);
}
.hero-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.hero-badge{
  min-width:200px;
  max-width:240px;
  border:1px dashed rgba(255,255,255,.15);
  border-radius:14px;
  padding:14px;
  background: rgba(255,255,255,.04);
  color:var(--muted);
  display:grid;
  gap:8px;
  height:fit-content;
}

.service-grid{
  margin-top:28px;
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap:18px;
}
.service-card{
  position:relative;
  display:flex;
  gap:12px;
  padding:18px;
  border-radius:16px;
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  color:var(--text);
  text-decoration:none;
  overflow:hidden;
  box-shadow: 0 15px 40px rgba(0,0,0,.35);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  opacity:0;
  transform: translateY(18px) scale(.99);
  animation: cardFade .7s ease forwards;
  animation-delay: var(--delay, 0s);
  background-image: var(--bg-img, none);
  background-size: 160%;
  background-position: center;
  background-repeat: no-repeat;
}
.service-card::after{
  content:'';
  position:absolute;
  inset:0;
  background: radial-gradient(140% 140% at 20% 20%, rgba(255,255,255,.08), transparent 40%);
  opacity:0;
  transition: opacity .22s ease;
}
.service-card:hover{
  transform: translateY(-4px) scale(1.02);
  box-shadow: 0 20px 55px rgba(0,0,0,.45), 0 0 20px rgba(255,215,130,.2);
  border-color: rgba(255,255,255,.15);
}
.service-card:hover::after{opacity:1;}
.service-card h3{
  margin:0 0 4px;
  font-size:18px;
}
.service-card p{
  margin:0;
  color:var(--muted);
}
.service-card .icon{
  width:52px;
  height:52px;
  border-radius:14px;
  display:grid;
  place-items:center;
  font-size:22px;
  background: linear-gradient(135deg, rgba(255,215,130,.12), rgba(120,180,255,.12));
  border:1px solid rgba(255,255,255,.08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.25);
  transition: transform .22s ease;
}
.service-card:hover .icon{transform: scale(1.08);}

@keyframes cardFade{
  from{opacity:0; transform: translateY(18px) scale(.99);}
  to{opacity:1; transform: translateY(0) scale(1);}
}

/* Home enhancements */
.homepage-hero{grid-template-columns: 1.1fr .9fr; align-items:flex-start;}
.hero-copy h1{font-size:32px; margin:10px 0;}
.hero-copy p{color:var(--muted);}
.hero-copy .muted.small{font-size:13px;}
.section-head{display:flex; justify-content:space-between; align-items:flex-start; gap:10px; flex-wrap:wrap;}
.tabs{display:flex; gap:8px; flex-wrap:wrap;}
.tab-panels{margin-top:14px;}
.tab-panel{display:none; animation: fadeIn .25s ease;}
.tab-panel.active{display:block;}
@keyframes fadeIn{from{opacity:0; transform:translateY(6px);} to{opacity:1; transform:translateY(0);}}

@media (max-width: 980px){
  .homepage-hero{grid-template-columns:1fr;}
}
@media (max-width: 680px){
}

/* Landing services */
.svc-landing .section-head{margin-bottom:14px;}
.svc-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(240px,1fr));
  gap:14px;
}
.svc-card{
  position:relative;
  display:block;
  min-height:180px;
  border-radius:18px;
  overflow:hidden;
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  box-shadow: 0 16px 40px rgba(0,0,0,.35);
  color:var(--text);
  text-decoration:none;
  background-image: var(--bg);
  background-size: cover;
  background-position:center;
  background-repeat:no-repeat;
  isolation:isolate;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.svc-card::before{
  content:'';
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.38), rgba(0,0,0,.65));
  backdrop-filter: blur(2px);
  z-index:1;
}
.svc-card-body{
  position:absolute; inset:0;
  padding:16px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  z-index:2;
  backdrop-filter: blur(2px);
}
.svc-header{display:flex; align-items:center; gap:8px;}
.svc-icon{
  width:34px; height:34px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.25);
  display:grid; place-items:center;
  background: rgba(255,255,255,.08);
  font-weight:700;
  letter-spacing:0.5px;
}
.svc-card h3{margin:0 0 6px;}
.svc-card p{margin:0; color:var(--muted);}
.clamp2{display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;}
.svc-cta{
  align-self:flex-start;
  margin-top:10px;
  padding:6px 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  font-size:13px;
  transition: transform .18s ease, background-color .18s ease, border-color .18s ease;
}
.svc-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 20px 50px rgba(0,0,0,.45);
  border-color: rgba(255,255,255,.2);
}
.svc-card:hover::before{background: linear-gradient(180deg, rgba(0,0,0,.3), rgba(0,0,0,.55));}
.svc-card:hover .svc-icon{border-color: rgba(255,255,255,.4); background: rgba(255,255,255,.16);}
.svc-card:hover .svc-cta{transform: translateX(4px); background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.25);}
.svc-landing{
  position:relative;
  overflow:hidden;
  padding-bottom:26px;
  --svc-bg-img: none;
  --svc-bg-opacity: .3;
  min-height: 420px;
}
.svc-landing::before{
  content:'';
  position:absolute;
  inset:0;
  background-image: var(--svc-bg-img);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: blur(6px) saturate(1.05);
  opacity: var(--svc-bg-opacity);
  transition: opacity .35s ease, filter .35s ease, background-image .35s ease;
  z-index:0;
}
.svc-landing::after{
  content:'';
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.65), rgba(0,0,0,.78));
  z-index:0;
}
.svc-landing > .container{position:relative; z-index:1;}
.svc-card.is-dim{opacity:.65; filter:saturate(.8);}
.svc-card.is-active{
  transform: translateY(-6px);
  box-shadow: 0 24px 60px rgba(0,0,0,.55);
  border-color: rgba(255,255,255,.25);
}

.mini-services{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(160px,1fr));
  gap:10px;
  margin-top:10px;
}
.mini-card{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.03);
  color:var(--text);
  text-decoration:none;
  box-shadow: 0 8px 20px rgba(0,0,0,.25);
}
.mini-card:hover{background: rgba(255,255,255,.08);}
/* Portfolio / Projects */
.portfolio-page .pagehead{
  text-align:left;
  margin-bottom:20px;
}
.portfolio-surface{
  position:relative;
  background: linear-gradient(135deg, rgba(255,255,255,.02), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.08);
  border-radius: 20px;
  padding: 18px;
  box-shadow: 0 18px 50px rgba(0,0,0,.45);
  overflow:hidden;
}
.portfolio-surface::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(800px 600px at 20% 10%, rgba(255,255,255,.05), transparent 60%),
    radial-gradient(700px 500px at 80% 0%, rgba(65,130,255,.05), transparent 60%),
    repeating-linear-gradient(90deg, rgba(255,255,255,.02) 0 1px, transparent 1px 20px),
    rgba(0,0,0,.18);
  opacity:.55;
  pointer-events:none;
}
.filter-bar{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:14px;
}
.filter-buttons{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.filter-bar .chip{
  cursor:pointer;
}
.chip.active{
  background: linear-gradient(135deg, rgba(209,168,74,.25), rgba(244,210,122,.25));
  color: var(--text);
  border-color: rgba(209,168,74,.45);
}

.featured-card{
  position:relative;
  overflow:hidden;
  border-radius:18px;
  min-height:260px;
  display:flex;
  align-items:flex-end;
  padding:20px;
  background: var(--card);
  background-image: var(--bg);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  border:1px solid rgba(255,255,255,.08);
  box-shadow: 0 18px 50px rgba(0,0,0,.45);
  margin-bottom:16px;
  isolation:isolate;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.featured-overlay{
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.65));
  z-index:-1;
}
.featured-content{
  display:flex;
  justify-content:space-between;
  gap:16px;
  width:100%;
  align-items:flex-end;
}
.featured-content h2{margin:0 0 6px;}
.featured-content .lead{margin:0 0 8px; color:var(--muted);}
.featured-tags{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-self:flex-start;
}
.featured-cta{
  position:absolute;
  right:16px;
  bottom:16px;
  background: rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.18);
  padding:8px 12px;
  border-radius:12px;
  opacity:0;
  transition: opacity .2s ease;
}
.featured-card:hover{
  transform: translateY(-6px) scale(1.02);
  box-shadow: 0 22px 60px rgba(0,0,0,.55), 0 0 18px rgba(209,168,74,.25);
  border-color: rgba(255,255,255,.15);
}
.featured-card:hover .featured-cta{opacity:1;}

.project-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap:14px;
}
.project-card{
  position:relative;
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  min-height:260px;
  box-shadow: 0 12px 32px rgba(0,0,0,.38);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  backdrop-filter: blur(10px);
}
.proj-img{
  position:relative;
  padding-top:62%;
  background-color: rgba(0,0,0,.2);
  background-image: var(--bg);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  overflow:hidden;
}
.proj-body{
  position:relative;
  padding:14px;
  display:flex;
  flex-direction:column;
  gap:8px;
  flex:1;
}
.proj-body h3{margin:0;}
.proj-body p{margin:0; color:var(--muted);}
.proj-meta{
  color:var(--muted2);
  font-size:13px;
  display:flex;
  gap:8px;
  align-items:center;
}
.meta-tag{
  padding:4px 8px;
  border-radius:10px;
  background: rgba(255,255,255,.08);
  font-size:12px;
}
.proj-cta{
  position:absolute;
  right:12px;
  bottom:12px;
  padding:6px 10px;
  border-radius:10px;
  background: rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.12);
  opacity:0;
  transition: opacity .2s ease;
  font-size:13px;
}
.project-card:hover{
  transform: translateY(-4px) scale(1.03);
  box-shadow: 0 20px 50px rgba(0,0,0,.48), 0 0 16px rgba(209,168,74,.22);
  border-color: rgba(255,255,255,.16);
}
.project-card:hover .proj-cta{opacity:1;}
.project-card.is-hidden{
  opacity:0;
  transform: translateY(8px) scale(.98);
  pointer-events:none;
  transition: opacity .2s ease, transform .2s ease;
}

/* About page */
.about-hero{
  position:relative;
  overflow:hidden;
  padding:72px 0 64px;
  background:
    linear-gradient(180deg, rgba(7,10,16,.78), rgba(7,10,16,.82)),
    linear-gradient(90deg, rgba(0,0,0,.35), rgba(0,0,0,.55)),
    var(--page-bg) center/cover no-repeat;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.about-hero-inner{
  position:relative;
  z-index:1;
  max-width:820px;
}
.about-hero .eyebrow{
  color: var(--muted);
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:12px;
  margin-bottom:6px;
}
.about-hero h1{
  margin:0 0 8px;
  font-size:42px;
  letter-spacing:-.4px;
}
.about-hero .lead{margin:0 0 10px;}
.about-hero .muted{max-width:70ch;}
.cta-pills{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(135deg, rgba(209,168,74,.16), rgba(255,255,255,.04));
  color:var(--text);
  font-weight:700;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}
.pill:hover{border-color:rgba(255,255,255,.22);}
.about-hero .grain{
  position:absolute;
  inset:0;
  background:
    radial-gradient(120% 120% at 20% 20%, rgba(244,210,122,.08), transparent 60%),
    radial-gradient(140% 120% at 80% 0%, rgba(90,140,255,.08), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.65));
  mix-blend-mode: screen;
  opacity:.55;
  pointer-events:none;
}

.about-body{
  background: linear-gradient(180deg, rgba(7,10,16,.9), rgba(7,10,16,.96));
  padding:32px 0 46px;
}
.about-grid{
  display:grid;
  gap:18px;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  align-items:start;
}
.about-text h3{margin:0 0 10px;}
.about-text p{margin:0 0 10px; color:var(--muted);}
.about-text .highlight{color:var(--accent2); font-weight:800;}

.about-process{
  border-radius:20px;
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(145deg, rgba(255,255,255,.06), rgba(0,0,0,.24));
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
  padding:16px;
}
.process-head{
  font-weight:800;
  margin-bottom:10px;
  letter-spacing:.1px;
}
.process-band{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(120px,1fr));
  gap:12px;
}
.process-step{
  position:relative;
  padding:12px 10px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background: radial-gradient(120% 120% at 50% 20%, rgba(209,168,74,.08), rgba(255,255,255,.02));
  color:var(--text);
  text-align:center;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.02), 0 10px 24px rgba(0,0,0,.35);
}
.process-step .icon-step{
  width:42px; height:42px;
  margin:0 auto 8px;
  border-radius:12px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(209,168,74,.18), rgba(255,255,255,.06));
  border:1px solid rgba(255,255,255,.16);
  color:var(--accent2);
}
.process-step svg{width:22px; height:22px;}
.process-step .step-title{font-weight:700;}
.process-step:hover{border-color: rgba(244,210,122,.35); box-shadow: 0 14px 40px rgba(0,0,0,.45);}

.about-lists{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(260px,1fr));
  gap:14px;
  margin-top:18px;
}
.check-list{
  list-style:none;
  padding:0;
  margin:10px 0 0;
  display:grid;
  gap:8px;
}
.check-list li{
  position:relative;
  padding-left:22px;
  color:var(--muted);
}
.check-list li:before{
  content:'✓';
  position:absolute;
  left:0; top:0;
  color:var(--accent2);
  font-weight:800;
}

.about-segments{
  margin-top:18px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  padding:16px;
  background: linear-gradient(135deg, rgba(255,255,255,.04), rgba(0,0,0,.25));
  box-shadow: 0 20px 50px rgba(0,0,0,.45);
}
.segments-head{font-weight:800; margin-bottom:10px;}
.segments-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(260px,1fr));
  gap:10px;
}
.segment-card{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.04);
  box-shadow: 0 12px 32px rgba(0,0,0,.35);
  color:var(--text);
}
.segment-card:hover{border-color: rgba(244,210,122,.3); box-shadow: 0 16px 40px rgba(0,0,0,.45);}
.segment-icon{font-size:18px;}
.segment-title{font-weight:800;}
.segment-desc{color:var(--muted2); font-size:13px;}
.segment-arrow{margin-left:auto; color:var(--accent2); font-weight:800;}

.about-cta{
  margin-top:18px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(135deg, rgba(209,168,74,.18), rgba(0,0,0,.4));
  padding:16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  box-shadow: 0 16px 44px rgba(0,0,0,.45);
}
.about-cta .cta-label{font-weight:800;}

.fade-up{
  opacity:0;
  transform: translateY(12px);
  transition: opacity .4s ease, transform .4s ease;
}
.fade-up.is-visible{
  opacity:1;
  transform: translateY(0);
}

.tip{
  position:fixed;
  pointer-events:none;
  z-index:2000;
  background: rgba(7,10,16,.92);
  border:1px solid rgba(255,255,255,.12);
  color:var(--text);
  padding:8px 10px;
  border-radius:12px;
  font-size:13px;
  box-shadow: 0 12px 30px rgba(0,0,0,.45);
  max-width:260px;
  opacity:0;
  transform: translateY(6px);
  transition: opacity .16s ease, transform .16s ease;
}
.tip.is-active{
  opacity:1;
  transform: translateY(0);
}

@media (max-width: 980px){
  .about-grid{grid-template-columns: 1fr;}
  .about-cta{flex-direction:column; align-items:flex-start;}
}

@media (max-width: 980px){
  .hero-inner{grid-template-columns:1fr; min-height: 520px}
  .kpis{grid-template-columns: repeat(3, minmax(0,1fr))}
  .card{grid-column: span 6}
  .footer-inner{grid-template-columns:1fr}
}
@media (max-width: 680px){
  .card{grid-column: span 12}
  .split{grid-template-columns:1fr}
  .kpis{grid-template-columns: repeat(2, minmax(0,1fr))}
  .hero{min-height: 540px}
  .service-hero{flex-direction:column}
  .featured-content{flex-direction:column; align-items:flex-start;}
  .project-grid{grid-template-columns:1fr;}
}

/* Projects page */
.projects-hero{
  position:relative;
  padding:50px 0 28px;
  background:
    linear-gradient(180deg, rgba(7,10,16,.7), rgba(7,10,16,.8)),
    var(--page-bg) center/cover no-repeat;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.projects-hero-inner{
  position:relative;
  z-index:1;
}
.projects-hero h1{
  margin:0 0 6px;
  font-size:36px;
}
.projects-hero .lead{margin:0 0 14px; max-width:72ch;}
.projects-filter .chip{
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
  padding:10px 14px;
  border-radius:14px;
  color:var(--text);
}
.projects-filter .chip.active{
  background: linear-gradient(135deg, rgba(209,168,74,.22), rgba(255,255,255,.06));
  border-color: rgba(244,210,122,.35);
}

/* References section (Projects) */
.references-block{
  margin:18px 0 14px;
  padding:16px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(140% 120% at 10% 20%, rgba(244,210,122,.08), transparent 55%),
    rgba(8,10,16,.55);
  box-shadow: 0 18px 55px rgba(0,0,0,.45);
  position:relative;
}
.references-block h2{
  margin:0 0 10px;
  font-size:20px;
}
.references-note{
  margin:6px 0 12px;
  color:var(--muted2);
  font-size:13px;
  text-align:center;
}
.references-rail{
  position:relative;
  display:flex;
  align-items:center;
  gap:10px;
  overflow:hidden;
  padding:0 44px;
}
.ref-track{
  display:flex;
  gap:14px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding:10px 6px;
  flex:0 0 auto;
  scrollbar-width:none;
}
.ref-track::-webkit-scrollbar{display:none;}
.ref-track.ref-loop{
  overflow:hidden;
  scroll-snap-type:none;
  width:max-content;
  animation: refLoop 28s linear infinite;
  will-change: transform;
}
.references-rail:hover .ref-track.ref-loop{
  animation-play-state: paused;
}
.ref-item{
  scroll-snap-align:center;
  min-width:140px;
  height:56px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--text);
  font-weight:800;
  letter-spacing:.3px;
  text-transform:uppercase;
  box-shadow: 0 10px 28px rgba(0,0,0,.35);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.ref-item:hover{
  transform: translateY(-2px) scale(1.03);
  border-color: rgba(244,210,122,.45);
  box-shadow: 0 12px 32px rgba(0,0,0,.45), 0 0 16px rgba(244,210,122,.18);
}
.ref-logo{
  font-size:15px;
  color:var(--text);
  opacity:.9;
}
.ref-img{
  max-height:40px;
  max-width:140px;
  filter: brightness(1.05);
  opacity:.9;
}
.ref-arrow{
  width:36px;
  height:36px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(10,12,18,.7);
  color:var(--text);
  cursor:pointer;
  position:absolute;
  top:50%;
  transform: translateY(-50%);
  z-index:2;
}
.ref-arrow[data-ref-prev]{left:6px;}
.ref-arrow[data-ref-next]{right:6px;}
@keyframes refLoop{
  from{transform: translateX(0);}
  to{transform: translateX(-50%);}
}

.testimonials-block{
  margin-top:14px;
}
.testimonials-rail{
  display:flex;
  align-items:center;
  gap:10px;
}
.test-track{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns: calc((100% - 24px) / 3);
  gap:12px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding:8px 4px 12px;
  flex:1;
  scrollbar-width:none;
}
.test-track::-webkit-scrollbar{display:none;}
.test-card{
  scroll-snap-align:start;
  border-radius:16px;
  border:1px solid rgba(244,210,122,.25);
  background: rgba(12,16,26,.7);
  box-shadow: 0 14px 34px rgba(0,0,0,.4);
  padding:14px;
  display:grid;
  gap:8px;
}
.test-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  font-weight:800;
}
.test-sub{
  color:var(--muted2);
  font-size:12.5px;
}
.test-stars{
  color:var(--accent2);
  letter-spacing:1px;
  font-size:13px;
}
.test-arrow{
  width:36px;
  height:36px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(10,12,18,.7);
  color:var(--text);
  cursor:pointer;
}
.test-dots{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:6px;
}
.test-dot{
  width:6px;
  height:6px;
  border-radius:999px;
  background: rgba(255,255,255,.2);
}
.test-dot.active{background: rgba(244,210,122,.7);}

@media (max-width: 980px){
  .ref-item{min-width:120px; height:52px;}
  .test-track{grid-auto-columns: calc((100% - 12px) / 2);}
}
@media (max-width: 680px){
  .ref-item{min-width:110px; height:48px;}
  .ref-arrow,
  .test-arrow{display:none;}
  .references-block{padding:12px;}
}
@media (max-width: 480px){
  .ref-item{min-width:100px; height:46px;}
  .test-track{grid-auto-columns: 100%;}
  .references-block{padding:10px;}
}
.projects-section{
  background: linear-gradient(180deg, rgba(7,10,16,.94), rgba(7,10,16,.98));
  padding:24px 0 40px;
}
.projects-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(280px,1fr));
  gap:14px;
}
.references-text{
  background: linear-gradient(180deg, rgba(7,10,16,.92), rgba(7,10,16,.98));
}
.references-text-card{
  border-radius:20px;
  border:1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(140% 120% at 10% 15%, rgba(244,210,122,.12), transparent 55%),
    rgba(10,12,18,.6);
  box-shadow: 0 18px 55px rgba(0,0,0,.45);
  padding:18px;
}
.references-text-head{
  text-align:center;
}
.references-text-head h2{
  margin:0 0 6px;
  font-size:22px;
}
.references-text-head p{
  margin:0;
  color:var(--muted);
}
.references-text-list{
  margin-top:14px;
  display:grid;
  gap:10px;
}
.references-text-note{
  margin:6px 0 0;
  text-align:center;
  color:var(--muted2);
  font-size:12.5px;
}
.reference-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(244,210,122,.25);
  background: rgba(12,16,26,.65);
}
.reference-main{
  display:grid;
  gap:4px;
}
.reference-main strong{
  font-size:15px;
}
.reference-main span{
  color:var(--muted2);
  font-size:12.5px;
}
.reference-meta{
  color:var(--accent2);
  font-weight:800;
  font-size:13px;
}
@media (max-width: 680px){
  .reference-row{
    flex-direction:column;
    align-items:flex-start;
  }
  .references-text-card{padding:14px;}
}
.project-card.v2{
  position:relative;
  overflow:hidden;
  border-radius:18px;
  min-height:240px;
  background: #0c0f18;
  background-image: var(--bg);
  background-size: cover;
  background-position:center;
  border:1px solid rgba(255,255,255,.08);
  box-shadow: 0 16px 46px rgba(0,0,0,.46), inset 0 0 0 1px rgba(255,255,255,.04);
  transition: border-color .2s ease, box-shadow .2s ease;
  display:flex;
  align-items:flex-end;
  isolation:isolate;
}
.project-card.v2 .project-overlay{
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.15), rgba(0,0,0,.65));
  z-index:1;
}
.project-card.v2 .project-content{
  position:relative;
  z-index:2;
  padding:16px;
  display:grid;
  gap:8px;
}
.project-card.v2 h3{margin:0; font-size:20px; letter-spacing:-.2px;}
.project-card.v2 .project-meta{margin:0; color:var(--muted2); font-weight:700; font-size:13px;}
.project-card.v2 .project-desc{margin:0; color:var(--muted); font-size:14px;}
.project-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.tag{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:10px;
  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  font-size:12px;
  font-weight:700;
}
.project-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.project-note{color:var(--muted2); font-size:13px;}
.project-card.v2:hover{
  border-color: rgba(244,210,122,.3);
  box-shadow: 0 22px 60px rgba(0,0,0,.55), 0 0 18px rgba(209,168,74,.18);
}
.project-card.v2:hover .project-overlay{
  background: linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.5));
}

@media (max-width: 680px){
  .projects-hero h1{font-size:30px;}
  .projects-grid{grid-template-columns:1fr;}
}
/* Services page */
.services-hero{
  position:relative;
  padding:46px 0 30px;
  background:
    linear-gradient(180deg, rgba(7,10,16,.75), rgba(7,10,16,.82)),
    var(--page-bg) center/cover no-repeat;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.services-hero-inner{position:relative; z-index:1;}
.services-hero h1{margin:0 0 6px; font-size:34px;}
.services-hero .lead{margin:0; max-width:70ch;}

.services-panel{
  background: linear-gradient(180deg, rgba(7,10,16,.94), rgba(7,10,16,.98));
  padding:24px 0 34px;
}
.services-panel-inner{
  display:grid;
  grid-template-columns: 1fr;
  gap:14px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(135deg, rgba(255,255,255,.04), rgba(0,0,0,.3));
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
  padding:18px;
}
.panel-left h2{margin:0 0 8px;}
.panel-left p{margin:0 0 12px; color:var(--muted);}
.pill-row{display:flex; flex-wrap:wrap; gap:10px;}
.panel-right{
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  padding:12px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.panel-head{font-weight:800; margin-bottom:10px;}
.panel-form{display:grid; gap:10px;}
.select-row{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:10px; border-radius:12px; border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.25);
}
.select-row input{width:18px; height:18px; accent-color: var(--accent);}
.icon-slot{\n  width:32px;\n  height:32px;\n  display:grid;\n  place-items:center;\n  border-radius:10px;\n  border:1px solid rgba(255,255,255,.14);\n  background: rgba(255,255,255,.06);\n  font-weight:800;\n  font-size:12px;\n  letter-spacing:.3px;\n}\n
.btn.full{width:100%;}

.services-finder{
  background: linear-gradient(180deg, rgba(7,10,16,.96), rgba(7,10,16,.98));
  padding:24px 0 30px;
}
.finder-grid{margin-top:10px; display:grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); gap:12px;}
.finder-card{
  position:relative; overflow:hidden; border-radius:16px; min-height:180px;
  background:#0c0f18; background-image: var(--bg); background-size: cover; background-position:center;
  border:1px solid rgba(255,255,255,.1); box-shadow: 0 16px 44px rgba(0,0,0,.45);
  display:flex; align-items:flex-end; isolation:isolate;
}
.finder-overlay{position:absolute; inset:0; background: linear-gradient(180deg, rgba(0,0,0,.15), rgba(0,0,0,.65)); z-index:1;}
.finder-body{position:relative; z-index:2; padding:14px; display:grid; gap:8px;}
.finder-body h3{margin:0; font-size:18px;}
.finder-body p{margin:0; color:var(--muted);}
.finder-actions{display:flex; gap:10px; flex-wrap:wrap;}
.finder-card:hover{border-color: rgba(244,210,122,.3); box-shadow: 0 20px 55px rgba(0,0,0,.5), 0 0 16px rgba(209,168,74,.2);}

.services-process{background: linear-gradient(180deg, rgba(7,10,16,.98), rgba(7,10,16,1));}
.services-process h2{margin:0 0 12px;}
.services-process .process-band{
  display:grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); gap:12px; padding:14px;
  border-radius:18px; border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(135deg, rgba(255,255,255,.04), rgba(0,0,0,.35));
  box-shadow: 0 18px 50px rgba(0,0,0,.5);
}
.services-process .process-step{
  text-align:center; padding:10px; border-radius:12px; border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02); box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.services-process .icon-step{
  display:inline-flex; align-items:center; justify-content:center;
  width:42px; height:42px; border-radius:12px;
  background: linear-gradient(135deg, rgba(209,168,74,.18), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.16); margin-bottom:6px;
}
.services-process .step-title{font-weight:800; margin-bottom:4px;}
.services-process .step-desc{color:var(--muted2); font-size:13px; margin:0;}

.services-faq{background: linear-gradient(180deg, rgba(7,10,16,.98), rgba(7,10,16,1)); padding-bottom:44px;}
.faq-grid{display:grid; grid-template-columns: 1.2fr .8fr; gap:14px;}
.faq-links{list-style:none; margin:8px 0 0; padding:0; display:grid; gap:8px;}
.faq-links a{display:flex; align-items:center; justify-content:space-between; padding:10px 12px; border-radius:12px; border:1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.03); color:var(--text);}
.faq-links a:hover{border-color: rgba(244,210,122,.3);}
.faq-cta{
  position:relative; overflow:hidden;
  border-radius:16px; border:1px solid rgba(255,255,255,.14);
  background: linear-gradient(135deg, rgba(209,168,74,.22), rgba(0,0,0,.55));
  padding:20px; display:flex; align-items:stretch; justify-content:space-between; gap:16px;
  box-shadow: 0 18px 46px rgba(0,0,0,.5);
}
.faq-cta::before{
  content:""; position:absolute; right:-40px; top:-60px; width:220px; height:220px;
  background: radial-gradient(circle, rgba(244,210,122,.45), rgba(244,210,122,0) 70%);
  filter: blur(1px); opacity:.7;
}
.faq-cta::after{
  content:""; position:absolute; left:-80px; bottom:-120px; width:300px; height:300px;
  background: radial-gradient(circle, rgba(255,255,255,.12), rgba(255,255,255,0) 70%);
  opacity:.6;
}
.faq-cta-content{position:relative; z-index:1; display:flex; flex-direction:column; gap:8px;}
.faq-cta-pill{
  align-self:flex-start; font-size:11px; letter-spacing:.8px; text-transform:uppercase;
  padding:6px 10px; border-radius:999px;
  background: rgba(244,210,122,.18); border:1px solid rgba(244,210,122,.4);
  color:#f4d27a; font-weight:700;
}
.faq-cta h4{margin:0 0 2px;}
.faq-cta p{margin:0; color:var(--muted);}
.faq-cta-points{list-style:none; margin:6px 0 0; padding:0; display:grid; gap:6px;}
.faq-cta-points li{display:flex; align-items:center; gap:8px; color:var(--muted);}
.faq-cta-points li::before{
  content:""; width:6px; height:6px; border-radius:50%;
  background: rgba(244,210,122,.85); box-shadow: 0 0 10px rgba(244,210,122,.4);
}
.faq-cta-actions{
  position:relative; z-index:1; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:8px; text-align:center;
}
.faq-cta-actions .btn{min-width:120px; box-shadow: 0 12px 30px rgba(0,0,0,.4);}
.faq-cta-note{font-size:12px; color:var(--muted2);}

@media (max-width: 980px){
  .services-panel-inner{grid-template-columns:1fr;}
  .faq-grid{grid-template-columns:1fr;}
  .faq-cta{flex-direction:column; align-items:flex-start;}
  .faq-cta-actions{align-items:flex-start;}
}
@media (max-width: 680px){
  .services-hero h1{font-size:30px;}
}/* Blog page */
.blog-hero{`n  position:relative;`n  padding:48px 0 28px;`n  background:`n    linear-gradient(180deg, rgba(4,6,10,.92), rgba(6,10,18,.86) 55%, rgba(10,14,24,.8)),`n    var(--page-bg) center/cover no-repeat;`n  border-bottom:1px solid rgba(255,255,255,.08);`n}
.blog-hero-inner{position:relative; z-index:1; max-width:900px;}
.blog-hero h1{margin:4px 0 6px; font-size:38px; letter-spacing:-.3px;}
.blog-hero .lead{margin:0 0 14px; max-width:72ch;}
.blog-search{display:flex; gap:10px; flex-wrap:wrap; margin:10px 0 14px;}
.blog-search input{flex:1; min-width:200px; border-radius:12px; border:1px solid rgba(255,255,255,.14); background: rgba(0,0,0,.24); color:var(--text); padding:10px 12px;}
.blog-chips{display:flex; gap:8px; flex-wrap:wrap;}
.blog-chips .chip{`n  background: linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.02));`n  border:1px solid rgba(255,255,255,.14);`n  border-radius:12px;`n  box-shadow: 0 8px 20px rgba(0,0,0,.35);`n  color:var(--muted);`n  padding:8px 12px;`n}
.blog-chips .chip.active{`n  background: linear-gradient(135deg, rgba(209,168,74,.38), rgba(244,210,122,.28));`n  border-color: rgba(244,210,122,.45);`n  color:#0a0f18;`n  font-weight:800;`n  box-shadow: 0 10px 28px rgba(209,168,74,.22);`n}

.blog-body{`n  background: linear-gradient(180deg, rgba(6,9,14,.97), rgba(8,12,20,.92), rgba(10,14,24,.88));`n  padding:26px 0 36px;`n}
.blog-layout{display:grid; grid-template-columns: minmax(0,1.4fr) minmax(280px, .6fr); gap:16px; align-items:start;}

.blog-featured{position:relative; overflow:hidden; border-radius:18px; min-height:260px; background: rgba(0,0,0,.4); background-image: var(--bg, none); background-size: cover; background-position:center; border:1px solid rgba(255,255,255,.1); box-shadow: 0 20px 60px rgba(0,0,0,.5); isolation:isolate;}
.blog-featured-overlay{position:absolute; inset:0; background: linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.65)); z-index:1;}
.blog-featured-body{position:relative; z-index:2; padding:18px; display:grid; gap:10px; max-width:720px;}
.blog-featured h2{margin:0; font-size:26px; letter-spacing:-.2px;}
.blog-featured .excerpt{margin:0; color:var(--muted);} 
.blog-featured .meta-line{color:var(--muted2); font-size:13px;}

.blog-grid{margin-top:14px; display:grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap:12px;}
.blog-card{border:1px solid rgba(255,255,255,.1); border-radius:14px; background: rgba(255,255,255,.03); box-shadow: 0 12px 32px rgba(0,0,0,.4); padding:14px; display:grid; gap:8px;}
.blog-card h3{margin:0; font-size:18px;}
.blog-card .excerpt{margin:0; color:var(--muted);} 
.meta-line{color:var(--muted2); font-size:13px;}
.category-badge{display:inline-flex; align-items:center; gap:6px; padding:6px 10px; border-radius:10px; background: rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); font-size:12px; font-weight:700;}
.read-link{color:var(--accent2); font-weight:700;}
.read-link:hover{text-decoration:underline;}

.blog-sidebar{display:grid; gap:12px;}
.sidebar-card{border:1px solid rgba(255,255,255,.1); border-radius:14px; background: rgba(255,255,255,.03); padding:14px; box-shadow: 0 12px 32px rgba(0,0,0,.4);}
.sidebar-card h3{margin:0 0 8px;}
.sidebar-list{list-style:none; margin:0; padding:0; display:grid; gap:8px;}
.sidebar-list a{color:var(--text);} 
.sidebar-list a:hover{color:var(--accent2);} 
.sidebar-tags{list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:8px;}
.sidebar-tags li{padding:6px 10px; border-radius:10px; border:1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.04);}
.sidebar-card.cta{background: linear-gradient(135deg, rgba(209,168,74,.18), rgba(0,0,0,.4));}
.sidebar-card.cta p{margin:6px 0 10px; color:var(--muted);} 

.blog-faq{background: linear-gradient(180deg, rgba(7,10,16,.98), rgba(7,10,16,1)); padding-bottom:44px;}
.blog-faq h2{margin:0 0 12px;}
.blog-hero .breadcrumb{color:var(--muted2);} 
.blog-hero .breadcrumb span{opacity:.8;}

@media (max-width: 980px){
  .blog-layout{grid-template-columns:1fr;}
}
@media (max-width: 680px){
  .blog-hero h1{font-size:32px;}
  .blog-search{flex-direction:column; align-items:stretch;}
}/* Service detail: Ev/Daire */
.blog-post-hero{
  position:relative;
  padding:38px 0 22px;
  background:
    linear-gradient(180deg, rgba(5,7,12,.85), rgba(5,7,12,.55) 60%, rgba(5,7,12,.35)),
    var(--cover) center/cover no-repeat;
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow: var(--shadow);
}
.blog-post-hero-inner{
  max-width:900px;
  display:grid;
  gap:8px;
}
.blog-post-hero h1{
  margin:0;
  font-size: clamp(30px, 3.6vw, 44px);
  letter-spacing:-.3px;
  text-shadow: 0 20px 50px rgba(0,0,0,.65);
}
.blog-post-hero .lead{
  margin:0;
  color:rgba(233,237,246,.86);
  max-width:70ch;
}
.blog-post-body{
  background: linear-gradient(180deg, rgba(6,9,14,.95), rgba(8,12,20,.92), rgba(10,14,24,.86));
  padding:28px 0 10px;
}
.blog-post-content{
  max-width:900px;
  display:grid;
  gap:14px;
}
.blog-post-content h2{
  margin:12px 0 4px;
  font-size:24px;
}
.blog-post-content h3{
  margin:10px 0 4px;
  font-size:18px;
}
.blog-post-content p{margin:0; color:var(--muted)}
.blog-post-content a{
  color:var(--accent2);
  font-weight:700;
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1.5px;
}
.blog-post-content ul{margin:0; padding-left:18px; color:var(--muted)}
.blog-post-content li{margin:6px 0;}
.blog-inline-row{
  display:grid;
  grid-template-columns: 1fr 260px;
  gap:16px;
  align-items:center;
  padding:10px 0;
}
.blog-inline-row.reverse{
  grid-template-columns: 260px 1fr;
}
.blog-inline-card{
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.14);
  box-shadow: 0 16px 36px rgba(0,0,0,.45);
}
.blog-inline-card.is-small{
  max-width:220px;
  justify-self:start;
}
.blog-inline-card.is-tiny{
  max-width:200px;
  justify-self:start;
}
.blog-inline-card img{width:100%; height:100%; object-fit:cover; display:block;}
.blog-callout{
  display:flex;
  gap:12px;
  align-items:flex-start;
  border-radius:16px;
  border:1px solid rgba(244,210,122,.3);
  background: rgba(244,210,122,.08);
  padding:14px;
}
.blog-callout strong{display:block; margin-bottom:4px;}
.blog-callout p{margin:0; color:var(--muted);}
.callout-icon{
  width:34px;
  height:34px;
  border-radius:10px;
  display:grid;
  place-items:center;
  color:var(--accent2);
  background: rgba(244,210,122,.16);
}
.callout-icon svg{width:18px; height:18px;}
.blog-post-cta{
  padding:22px 0 10px;
}
.blog-post-cta-inner{
  max-width:900px;
  border-radius:20px;
  border:1px solid rgba(244,210,122,.35);
  background: linear-gradient(180deg, rgba(244,210,122,.1), rgba(12,16,26,.55));
  padding:20px;
  text-align:center;
  display:grid;
  gap:8px;
}
.blog-related{
  padding:18px 0 36px;
}
.blog-related h2{margin:0 0 12px;}
.blog-related-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:12px;
}
.blog-related-card{
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  box-shadow: 0 14px 34px rgba(0,0,0,.4);
  display:grid;
}
.blog-related-cover{
  min-height:140px;
  background: var(--bg) center/cover no-repeat;
}
.blog-related-body{padding:12px; display:grid; gap:6px;}
.blog-related-body h3{margin:0; font-size:16px;}

@media (max-width: 980px){
  .blog-inline-row,
  .blog-inline-row.reverse{
    grid-template-columns:1fr;
  }
  .blog-related-grid{grid-template-columns: repeat(2, minmax(0,1fr));}
}
@media (max-width: 680px){
  .blog-related-grid{grid-template-columns:1fr;}
}
.svc-detail-hero{
  position:relative;
  padding:48px 0 30px;
  background:
    linear-gradient(180deg, rgba(7,10,16,.78), rgba(7,10,16,.84)),
    var(--page-bg) center/cover no-repeat;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.svc-detail-hero-inner{position:relative; z-index:1; max-width:960px;}
.svc-detail-hero h1{margin:6px 0 8px; font-size:36px; letter-spacing:-.3px;}
.svc-detail-hero .lead{margin:0 0 14px; color:var(--muted);}
.svc-hero-img{
  margin-top:12px;
  width:100%;
  min-height:280px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.1);
  background: var(--page-bg) center/cover no-repeat;
  background-image: var(--bg, var(--page-bg));
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}

.svc-detail-body{background: linear-gradient(180deg, rgba(7,10,16,.95), rgba(7,10,16,.98));}
.svc-detail-grid{display:grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap:14px;}
.svc-detail-card{
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(135deg, rgba(255,255,255,.04), rgba(0,0,0,.32));
  padding:16px;
  box-shadow: 0 16px 44px rgba(0,0,0,.45);
  display:grid; gap:10px;
}
.svc-detail-card .card-head{display:flex; gap:10px; align-items:flex-start;}
.icon-tile{
  width:40px; height:40px; border-radius:12px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(209,168,74,.2), rgba(255,255,255,.06));
  border:1px solid rgba(255,255,255,.16);
  font-size:18px;
}

.svc-cta-band{background: linear-gradient(180deg, rgba(6,9,14,.98), rgba(6,10,16,.9)); text-align:center;}
.svc-cta-band h2{margin:0 0 8px;}
.svc-cta-band .muted{margin:0 0 12px;}
.svc-steps{display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin:12px 0;}
.svc-step{
  display:grid; gap:6px; place-items:center;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  min-width:120px;
}
.svc-step .icon-step{
  width:42px; height:42px; border-radius:50%;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(209,168,74,.2), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.16);
  color:var(--accent2);
}
.cta-actions{display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-top:10px;}

@media (max-width: 680px){
  .svc-hero-img{min-height:200px;}
  .svc-step{min-width:46%;}
}
.finder-actions{display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-start;}
.extra-services{
  max-height:0;
  opacity:0;
  transform: translateY(12px);
  overflow:hidden;
  transition: max-height .5s ease, opacity .45s ease, transform .5s ease;
}
.extra-services.show{
  max-height: 1600px;
  opacity:1;
  transform: translateY(0);
}


.nav-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border-radius:12px;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.04);
  color:var(--text);
  cursor:pointer;
}
.nav-toggle span{
  display:block;
  width:18px;
  height:2px;
  background: var(--text);
  border-radius:999px;
}
.nav-toggle span + span{margin-top:4px;}




/* 420px mobile guard */
@media (max-width: 420px){
  html, body{overflow-x:hidden;}
body.nav-locked{overflow:hidden;}
main [id]{scroll-margin-top: calc(var(--nav-h, 72px) + 12px);}
  img, svg, video{max-width:100%; height:auto;}
  .container,
  .section,
  .hero,
  .hero-inner,
  .footer-inner,
  .grid,
  .split,
  .svc-grid,
  .service-grid,
  .projects-grid,
  .blog-layout{max-width:100%; min-width:0;}
  .card,
  .hero-card,
  .hero-summary,
  .service-card,
  .project-card,
  .finder-card,
  .blog-card,
  .sidebar-card,
  .faq-card{max-width:100%; min-width:0;}

  .nav-toggle{
    display:inline-flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:4px;
    width:36px;
    height:36px;
    border-radius:10px;
    border:1px solid var(--stroke);
    background: rgba(255,255,255,.04);
    color:var(--text);
    cursor:pointer;
    margin-left:auto;
  }
  .nav-toggle span{
    display:block;
    width:20px;
    height:2px;
    background: var(--text);
    border-radius:999px;
    transition: transform .2s ease, opacity .2s ease;
  }
  .nav-toggle span + span{margin-top:0;}
  .nav.is-open .nav-toggle span:nth-child(1){transform: translateY(6px) rotate(45deg);}
  .nav.is-open .nav-toggle span:nth-child(2){opacity:0;}
  .nav.is-open .nav-toggle span:nth-child(3){transform: translateY(-6px) rotate(-45deg);}
  .nav-inner{padding:10px 0; gap:10px; align-items:center;}
  .brand{position:relative; z-index:1;}
  .nav-toggle{z-index:3;}
  .brand-mark{width:160px; height:48px; transform: scale(1.5); pointer-events:none;}

  .nav-drawer{
    position:fixed;
    inset:0 0 0 auto;
    width:min(280px, 82vw);
    min-height: calc(var(--vh, 1vh) * 100);
    min-height: 100dvh;
    padding:84px 18px 20px;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:14px;
    background: rgba(8,10,16,.98);
    border-left:1px solid var(--stroke);
    box-shadow: var(--shadow);
    transform: translateX(110%);
    transition: transform .2s ease;
    z-index:220;
  }
  .menu{
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:12px;
    width:100%;
  }
  .menu a{width:100%; text-align:center;}
  .nav-cta{width:100%; display:flex; justify-content:center;}
  .nav-cta .btn{width:auto;}
  .nav-open .nav-drawer{
    transform: translateX(0);
  }

  .nav-backdrop{
    display:none;
    position:fixed;
    inset:0;
    background: rgba(5,7,12,.6);
    backdrop-filter: blur(4px);
    opacity:0;
    pointer-events:none;
    transition: opacity .2s ease;
    z-index:210;
  }
  .nav-open .nav-backdrop{display:block; opacity:1; pointer-events:auto;}

  .nav-noanim .nav-drawer,
  .nav-noanim .nav-backdrop{
    transition: none !important;
  }

  .hero-summary-grid{grid-template-columns:repeat(2, minmax(0, 1fr));}
  .hero-summary-item{padding:10px; gap:8px;}
  .hero-summary-item span{display:none;}
  .hero-summary-item strong{
    font-size:14px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .footer .container{padding-left:16px; padding-right:16px;}
  .footer .cols{grid-template-columns:1fr; gap:12px;}
}

/* 360px mobile fixes */
@media (max-width: 360px){
  .nav-inner{padding:10px 0;}
  .brand{position:relative; z-index:1;}
  .nav-toggle{z-index:3;}
  .brand-mark{width:160px; height:46px; transform: scale(1.4); pointer-events:none;}
  .btn{width:100%; padding:10px 12px; font-size:14px;}

  .hero-inner,
  .footer-inner,
  .split,
  .faq-hero-inner,
  .faq-grid,
  .blog-layout,
  .blog-related-grid,
  .projects-grid,
  .service-grid,
  .svc-grid,
  .finder-grid,
  .services-panel-inner{grid-template-columns:1fr;}

  .section{padding:16px 0;}
  .hero-actions{flex-direction:column; align-items:stretch;}
  .hero-actions .btn{width:100%;}
}
