
:root{
  --ink:#0a1320; --text:#0f172a; --paper:#ffffff; --muted:#667085;
  --brand:#1e3a8a; --brand-2:#2563eb; --accent:#dc2626; --accent-2:#ef4444;
  --bg-grad:linear-gradient(180deg, #f9fbff, #f3f7ff);
  --shadow:0 18px 40px rgba(2,12,27,.12);
}
*{box-sizing:border-box} html,body{margin:0;padding:0;max-width:100%;overflow-x:hidden}
body{font-family:Poppins, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial; color:var(--text); background:var(--bg-grad); line-height:1.6}
.container{max-width:1120px;margin:0 auto;padding:0 20px}
.section{padding:72px 0} .section.alt{background:#f6f8ff}
h1,h2,h3{line-height:1.2;margin:0 0 16px;color:var(--ink);font-family:'Playfair Display', Georgia, serif}
h1{font-size: clamp(32px, 5vw, 56px);font-weight:800}
h2{font-size: clamp(24px, 4vw, 36px);font-weight:800}
h3{font-size:20px;font-weight:700}
.muted{color:#667085} .small{font-size:12px} .center{text-align:center}

.btn{display:inline-block;padding:12px 18px;border-radius:14px;text-decoration:none;border:2px solid transparent;font-weight:700;transition:.2s ease;box-shadow:var(--shadow)}
.btn.small{padding:8px 12px;font-size:14px}
.btn.primary{background:linear-gradient(135deg,var(--accent), var(--accent-2)); color:#fff}
.btn.secondary{background:linear-gradient(135deg,var(--brand), var(--brand-2)); color:#fff}
.btn.outline{border-color:var(--brand-2); color:var(--brand-2); background:#fff}
.btn.white{background:#fff;color:var(--brand-2);border-color:#e6eef9}
.btn:hover{transform:translateY(-1px)}

.site-header{position:sticky; top:0; z-index:1000; backdrop-filter:saturate(140%) blur(8px); background:rgba(255,255,255,.9); border-bottom:3px solid var(--accent)}
.nav{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:18px 0}
.brand{display:flex;align-items:baseline;gap:10px;font-weight:800}
.brand .brand-name{font-size:20px;color:var(--brand-2)}
.brand .brand-sub{font-size:12px;color:#5b6b7a;letter-spacing:.4px}
.brand.mini .brand-name{font-size:16px}
.logo-sparkle{filter:drop-shadow(0 4px 10px rgba(37,99,235,.5))}
.site-header .brand{flex-direction:column;align-items:center;gap:8px;text-align:center}
.site-header .nav nav{margin-top:16px;display:flex;flex-wrap:wrap;justify-content:center;gap:18px}
nav a{margin-left:0;color:#0f172a;text-decoration:none;font-weight:700}
nav a:hover{color:var(--brand-2)} nav a[aria-current="page"]{color:var(--brand-2)}

.hero{position:relative;overflow:hidden;padding:72px 0 96px;background:linear-gradient(135deg,#fff1f2 0%,#ffe4e6 35%,#f3f7ff 100%);
border-bottom: 6px solid #e6eef9}
.hero-inner{display:grid;grid-template-columns: 1.1fr .9fr;gap:32px;align-items:center}
.hero-copy .accent{text-decoration:underline; text-decoration-color: var(--accent); text-decoration-thickness: 6px; text-underline-offset: 6px}
.hero-highlights{display:flex;gap:16px;flex-wrap:wrap;padding:0;margin:14px 0 0;list-style:none;color:#334155}
.hero-highlights li{background:#fff;border:2px solid #e6eef9;padding:8px 12px;border-radius:999px;box-shadow:var(--shadow)}
@media (max-width: 960px){ .hero-inner{grid-template-columns:1fr} }

/* New hero image grid (not stacked cards) */
.hero-grid{display:grid;grid-template-columns: repeat(2, minmax(140px, 1fr)); grid-auto-rows: 150px; gap:16px; align-items:stretch}
.hero-grid .tile{position:relative;margin:0;padding:0;border-radius:18px;overflow:hidden;background:#fff;border:6px solid #fff;box-shadow:var(--shadow)}
.hero-grid img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.05) contrast(1.03)}
.hero-grid figcaption{position:absolute;left:10px;bottom:10px;background:rgba(0,0,0,.45);color:#fff;padding:4px 8px;border-radius:10px;font-size:12px}
@media (max-width: 960px){ .hero-grid{grid-template-columns: repeat(3, 1fr); grid-auto-rows: 110px; order:-1; margin-bottom:18px} }
@media (max-width: 560px){ .hero-grid{grid-template-columns: repeat(2, 1fr); grid-auto-rows: 120px} }

/* Gallery grid */
.masonry{display:grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap:16px; justify-items:center}
.mason{break-inside: avoid; margin:0; width:100%; max-width:420px}
.mason img{width:100%; display:block; border-radius:18px;box-shadow: 0 20px 38px rgba(2,12,27,.18);border:6px solid #fff;filter: saturate(1.05) contrast(1.02); background:#fff}
.mason.media .media-frame{position:relative; aspect-ratio:4/5; border-radius:18px; border:6px solid #fff; overflow:hidden; box-shadow:0 20px 38px rgba(2,12,27,.18); background:#0b1220}
.mason.media video{position:absolute; inset:0; width:100%; height:100%; object-fit:contain; background:#000}
.mason.featured{grid-column: 1 / -1; max-width:640px; justify-self:center}
@media (max-width: 960px){ .masonry{grid-template-columns: repeat(auto-fit, minmax(200px, 1fr))} }
@media (max-width: 560px){ .mason.featured{grid-column: span 1} }

/* Services grid for services.html */
.services-grid{display:grid;grid-template-columns: repeat(4, 1fr);gap:20px}
@media (max-width: 960px){.services-grid{grid-template-columns: repeat(2, 1fr)}}
@media (max-width: 560px){.services-grid{grid-template-columns:1fr}}
.card{background:#fff;border:2px solid #e6eef9;border-radius:16px;padding:20px;box-shadow: var(--shadow)}
.card .icon{font-size:28px;margin-bottom:6px}
.ribbon{display:inline-flex;align-items:center;gap:8px;background: linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff;border-radius:999px;padding:6px 12px;font-weight:800}
.bundle{display:flex;align-items:center;justify-content:space-between;gap:20px;background:linear-gradient(135deg, #fff, #f5f6ff);border:2px solid #dbe7fb; border-radius:16px; padding:24px 28px;box-shadow: var(--shadow)}
.bundle-price{font-size:40px;font-weight:900;background: linear-gradient(135deg,var(--brand-2),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}
.bundle-price span{display:block;font-size:13px;color:#64748b}

.contact-grid{display:grid;grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));gap:24px;align-items:start}
.contact-card, .contact-form{background:#fff;border:2px solid #e6eef9;border-radius:16px;box-shadow: var(--shadow);padding:20px}
.contact-card .cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px}
.contact-card a.btn{flex:1 1 140px;text-align:center}
.contact-form label{display:block;margin-bottom:12px;font-weight:700;color:var(--ink)}
.contact-form input,.contact-form textarea{width:100%;margin-top:6px;padding:12px 14px;border-radius:12px;border:2px solid #dbe7fb;font-size:14px;font-family:inherit}
.contact-form button{margin-top:6px}
.contact-form .muted{margin-top:10px;display:block}

/* Shop / Cart */
#shop .grid{display:grid;grid-template-columns: repeat(4, 1fr);gap:18px;align-items:stretch}
@media (max-width: 960px){#shop .grid{grid-template-columns: repeat(2, 1fr)}}
@media (max-width: 560px){#shop .grid{grid-template-columns: 1fr}}
.product{background:#fff;border:2px solid #e6eef9;border-radius:16px;box-shadow:var(--shadow);padding:16px;display:grid;grid-template-rows:auto auto 1fr auto;align-items:start;text-align:center;gap:10px;height:100%}
.product h4{margin:4px 0 2px}
.product .price{font-weight:900;color:var(--brand-2);font-size:20px;margin-bottom:4px}
.product img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:12px;border:6px solid #fff;box-shadow:var(--shadow)}
.product button{justify-self:center;min-width:140px}
.cart{position: fixed; right: 20px; bottom: 20px; z-index: 2000;background: #fff; border:3px solid var(--brand-2); border-radius: 16px; padding: 12px 14px; width: 320px; box-shadow: var(--shadow)}
.cart h4{margin:0 0 8px;color:var(--brand-2)} .cart .line{display:flex;align-items:center;justify-content:space-between;margin:6px 0}
.cart .qty{display:flex;align-items:center;gap:8px} .cart button{margin-top:8px}

/* CV side video decorations */
.side-video{position: fixed; top: 64px; bottom: 0; width: min(24vw, 320px); pointer-events: none; opacity:.35; z-index: 0; filter: saturate(1.05) contrast(1.02)}
.side-video.left{left:0}
.side-video.right{right:0; transform: scaleX(-1)}
.side-video:after{content:"🫧 ✨ 🫧 ✨ 🫧"; position:absolute; inset:10% 0 auto 0; text-align:center; font-size:24px; color:rgba(37,99,235,.25); letter-spacing: 18px}
.side-video .sv, .side-video .sv-fallback{width:100%; height:100%; object-fit: cover; display:block; mask-image: linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,0)); -webkit-mask-image: linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,0)); filter: blur(.4px) saturate(1.05)}
.side-video.right .sv, .side-video.right .sv-fallback{mask-image: linear-gradient(270deg, rgba(0,0,0,.9), rgba(0,0,0,0)); -webkit-mask-image: linear-gradient(270deg, rgba(0,0,0,.9), rgba(0,0,0,0))}
.site-header, main, .cv, footer{ position: relative; z-index: 1 }
@media (max-width: 960px){ .side-video{display:none} }

.site-footer{background:#0b1220; color:#e6eef9; padding:28px 0; border-top: 6px solid var(--accent)}
.footer-grid{display:flex;align-items:center;justify-content:space-between;gap:18px}
.footer-contact a{display:block;color:#dbe7fb;text-decoration:none;margin:4px 0}
.footer-contact a:hover{color:#fff}
h2{position:relative}
h2:after{content:"";display:block;height:6px;margin-top:8px;border-radius:999px;background: linear-gradient(90deg, var(--brand-2), var(--accent), #60a5fa);opacity:.25}

/* Injected: logo + hero gradient */
.brand-logo{height:56px;width:auto;display:inline-block;vertical-align:middle}
.brand.mini .brand-logo{height:48px}
.site-header .brand-logo{height:352px}

/*
  Home landing: make the sticky header act as a full-height landing section on Home only
*/
body.home .site-header{
  position: static;              /* disable sticky for the landing */
  min-height: 100vh;             /* fill the viewport height */
  display: flex;
  align-items: center;
  border-bottom: 6px solid var(--accent); /* emphasizes the red divider */
}
body.home .nav{ padding: 48px 0; }
/* Optional: keep the logo large on Home; already sized via .site-header .brand-logo */
