* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: 'Hanken Grotesk', system-ui, sans-serif; color: #1B2330; background: #F6F3EC; overflow-x: hidden; -webkit-font-smoothing: antialiased; }
a { text-decoration: none; color: inherit; }
input, select, textarea, button { font-family: inherit; }
img { max-width: 100%; }

/* ---------- keyframes ---------- */
@keyframes w0l-marqL { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes w0l-marqR { from { transform: translateX(-50%); } to { transform: translateX(0); } }
@keyframes w0l-spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes w0l-spinrev { from { transform: rotate(0deg); } to { transform: rotate(-360deg); } }
@keyframes w0l-pulse { 0%,100% { opacity: .35; transform: scale(1); } 50% { opacity: .7; transform: scale(1.05); } }
@keyframes w0l-float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-4px); } }
@keyframes w0l-nodeglow { 0%,100% { box-shadow: 0 8px 20px rgba(0,0,0,0.3); } 50% { box-shadow: 0 8px 20px rgba(0,0,0,0.3), 0 0 22px 3px rgba(201,169,97,0.55); } }

/* ---------- reveal-on-scroll ---------- */
[data-reveal] { opacity: 0; transform: translateY(26px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
[data-reveal].in-view { opacity: 1; transform: none; }

/* ---------- header ---------- */
.site-header { position: sticky; top: 0; z-index: 60; background: rgba(12,24,48,0.86); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid rgba(140,120,80,0.28); }
.header-inner { max-width: 1180px; margin: 0 auto; padding: 13px clamp(18px,5vw,48px); display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.brand-badge { display: inline-flex; align-items: center; justify-content: center; background: #F6F3EC; border: 1px solid rgba(140,120,80,0.22); border-radius: 18px; padding: 12px 18px; box-shadow: 0 2px 10px rgba(0,0,0,0.18); }
.brand-badge img { height: clamp(42px,7vw,56px); width: auto; display: block; }
.nav { display: flex; align-items: center; gap: clamp(14px,2.4vw,30px); }
.nav-links { display: none; align-items: center; gap: clamp(14px,2.4vw,30px); }
.nav-links a { font-size: 14px; color: rgba(255,255,255,0.78); font-weight: 500; }
@media (min-width: 1024px) { .nav-links { display: flex; } }

/* ---------- buttons ---------- */
.btn { font-family: 'Space Grotesk', sans-serif; font-weight: 600; display: inline-flex; align-items: center; gap: 9px; transition: background .25s, transform .25s, border-color .25s, box-shadow .25s; }
.btn-gold-pill { font-size: 14px; color: #0c1830; background: #C9A961; padding: 9px 18px; border-radius: 999px; }
.btn-gold-pill:hover { background: #E8C77A; }
.btn-gold-solid { font-size: 15px; color: #0c1830; background: #C9A961; padding: 14px 26px; border-radius: 999px; }
.btn-gold-solid:hover { background: #E8C77A; transform: translateY(-2px); }
.btn-outline-light { font-size: 15px; color: #FFFFFF; background: transparent; border: 1px solid rgba(255,255,255,0.28); padding: 14px 26px; border-radius: 999px; }
.btn-outline-light:hover { border-color: #C9A961; background: rgba(201,169,97,0.1); }
.btn-navy-pill { font-size: clamp(15px,1.7vw,17px); color: #F6F3EC; background: #142850; padding: 16px 30px; border-radius: 999px; box-shadow: 0 12px 28px rgba(12,24,48,0.28); }
.btn-navy-pill:hover { background: #0c1830; transform: translateY(-2px); }
.btn-small-gold { font-size: 14px; color: #0c1830; background: #C9A961; padding: 11px 20px; border-radius: 999px; }
.btn-small-gold:hover { background: #E8C77A; }
.btn-footer-gold { font-size: 13.5px; color: #0c1830; background: #C9A961; padding: 10px 20px; border-radius: 999px; }
.btn-footer-gold:hover { background: #E8C77A; }
.btn-submit { width: 100%; font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 16px; color: #fff; background: #142850; border: none; padding: 16px; border-radius: 11px; cursor: pointer; }
.btn-submit:hover { background: #1c3a6b; }

/* ---------- hero ---------- */
.hero { position: relative; background: radial-gradient(120% 90% at 70% -10%, #1c3a6b 0%, #142850 38%, #0c1830 100%); color: #FFFFFF; overflow: hidden; }
.hero-grid-overlay { position: absolute; inset: 0; background-image: linear-gradient(rgba(140,120,80,0.06) 1px, transparent 1px), linear-gradient(90deg, rgba(140,120,80,0.06) 1px, transparent 1px); background-size: 64px 64px; mask-image: radial-gradient(80% 70% at 50% 30%, #000 30%, transparent 80%); }
.hero-inner { position: relative; max-width: 1180px; margin: 0 auto; padding: clamp(48px,8vw,84px) clamp(18px,5vw,48px) clamp(34px,5vw,52px); display: flex; flex-direction: column; align-items: center; gap: clamp(28px,5vw,56px); }
@media (min-width: 1024px) { .hero-inner { flex-direction: row; } }
.hero-copy { flex: 1 1 360px; min-width: 0; text-align: center; }
@media (min-width: 1024px) { .hero-copy { text-align: left; } }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 9px; font-family: 'JetBrains Mono', monospace; font-size: 11.5px; letter-spacing: 0.2em; text-transform: uppercase; color: #C9A961; border: 1px solid rgba(201,169,97,0.4); border-radius: 999px; padding: 6px 14px; margin-bottom: 22px; }
.hero-eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: #C9A961; box-shadow: 0 0 10px #C9A961; }
.hero h1 { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: clamp(40px,8vw,82px); line-height: 0.98; letter-spacing: -0.03em; margin: 0 0 20px; }
.hero h1 .highlight { position: relative; white-space: nowrap; color: #E8C77A; }
.hero h1 .highlight::after { content: ""; position: absolute; left: 0; right: 0; bottom: 6px; height: clamp(7px,1.4vw,13px); background: rgba(201,169,97,0.22); z-index: -1; }
.hero p { font-size: clamp(16px,1.9vw,19px); line-height: 1.6; color: rgba(255,255,255,0.78); max-width: 30em; margin: 0 auto 30px; }
@media (min-width: 1024px) { .hero p { margin-left: 0; margin-right: 0; } }
.hero-cta-row { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }
@media (min-width: 1024px) { .hero-cta-row { justify-content: flex-start; } }

/* ---------- orbit ---------- */
.orbit-wrap { flex: 0 1 520px; width: 100%; display: grid; place-items: center; }
.orbit-desktop { display: none; }
@media (min-width: 760px) { .orbit-desktop { display: grid; } }
.orbit-circle { position: relative; width: clamp(360px,82vw,500px); aspect-ratio: 1; }
.orbit-glow { position: absolute; inset: 16%; border-radius: 50%; background: radial-gradient(circle, rgba(201,169,97,0.16), transparent 68%); animation: w0l-pulse 6s ease-in-out infinite; }
.orbit-ring { position: absolute; border-radius: 50%; }
.orbit-ring-outer { border: 1px dashed rgba(201,169,97,0.28); left: 10.00%; top: 10.00%; right: 10.00%; bottom: 10.00%; }
.orbit-ring-inner { border: 1px dashed rgba(255,255,255,0.18); left: 27.00%; top: 27.00%; right: 27.00%; bottom: 27.00%; }
.orbit-rotator-outer { position: absolute; inset: 0; animation: w0l-spin 46s linear infinite; }
.orbit-rotator-inner { position: absolute; inset: 0; animation: w0l-spinrev 36s linear infinite; }
.orbit-node { position: absolute; width: 14%; height: 14%; transform: translate(-50%,-50%); }
.orbit-node-inner { width: 13%; height: 13%; }
.orbit-node-spin { width: 100%; height: 100%; animation: w0l-spinrev 46s linear infinite; }
.orbit-node-inner .orbit-node-spin { animation: w0l-spin 36s linear infinite; }
.orbit-fill { display: grid; place-items: center; width: 100%; height: 100%; border-radius: 50%; box-shadow: 0 8px 22px rgba(0,0,0,0.35); overflow: hidden; animation: w0l-nodeglow 5s ease-in-out infinite; }
.orbit-fill img { width: 100%; height: 100%; object-fit: cover; display: block; }
.orbit-fill svg, .orbit-fill .f-glyph { width: 56%; height: 56%; }
/* orbit + hero-row icons must always be perfect circles, regardless of the
   rounded-square shape chip-instagram/chip-tiktok use in the social/footer sections */
.orbit-fill.chip-instagram, .orbit-fill.chip-tiktok,
.hero-node.chip-instagram, .hero-node.chip-tiktok { border-radius: 50%; }
.orbit-text-node { display: grid; place-items: center; text-align: center; width: 100%; height: 100%; border-radius: 50%; background: #1c3a6b; color: #E8C77A; border: 1px solid rgba(201,169,97,0.5); font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: clamp(10.5px,1.35vw,12.5px); line-height: 1.14; letter-spacing: -0.01em; padding: 7%; box-shadow: 0 8px 22px rgba(0,0,0,0.35); animation: w0l-nodeglow 5s ease-in-out infinite; }
.orbit-center { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); display: flex; flex-direction: column; align-items: center; justify-content: center; width: 24%; height: 24%; border-radius: 50%; background: linear-gradient(160deg, #1c3a6b, #0c1830); border: 1.5px solid rgba(201,169,97,0.55); box-shadow: 0 0 0 8px rgba(201,169,97,0.06), 0 20px 50px rgba(0,0,0,0.5); text-align: center; }
.orbit-center .wm { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: clamp(26px,6.4vw,38px); letter-spacing: -0.03em; color: #FFFFFF; line-height: 1; }
.orbit-center .wm span { color: #E8C77A; }
.orbit-center .eco { font-family: 'JetBrains Mono', monospace; font-size: clamp(6.5px,1.2vw,9px); letter-spacing: 0.2em; color: rgba(201,169,97,0.85); margin-top: 4px; }

.orbit-mobile { display: flex; flex-direction: column; align-items: center; gap: 20px; padding: 6px 0 4px; }
@media (min-width: 760px) { .orbit-mobile { display: none; } }
.orbit-mobile-badge { display: flex; flex-direction: column; align-items: center; justify-content: center; width: 124px; height: 124px; border-radius: 50%; background: linear-gradient(160deg, #1c3a6b, #0c1830); border: 1.5px solid rgba(201,169,97,0.55); box-shadow: 0 0 0 8px rgba(201,169,97,0.06), 0 18px 40px rgba(0,0,0,0.5); animation: w0l-nodeglow 5s ease-in-out infinite; text-align: center; }
.orbit-mobile-badge .wm { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 40px; letter-spacing: -0.03em; color: #FFFFFF; line-height: 1; }
.orbit-mobile-badge .wm span { color: #E8C77A; }
.orbit-mobile-badge .eco { font-family: 'JetBrains Mono', monospace; font-size: 8px; letter-spacing: 0.22em; color: rgba(201,169,97,0.85); margin-top: 4px; }
.orbit-mobile-chips { display: flex; flex-wrap: wrap; justify-content: center; gap: 9px; max-width: 300px; }
.orbit-mobile-chips span { display: inline-flex; align-items: center; padding: 8px 15px; border-radius: 999px; background: #1c3a6b; color: #E8C77A; border: 1px solid rgba(201,169,97,0.5); font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 13px; letter-spacing: -0.01em; }
.orbit-mobile-socials { display: flex; justify-content: center; align-items: center; gap: 14px; flex-wrap: wrap; }

/* brand social glyph chips */
.chip { display: grid; place-items: center; box-shadow: 0 4px 12px rgba(20,40,80,0.12); flex-shrink: 0; overflow: hidden; }
.chip svg, .chip .f-glyph { width: 56%; height: 56%; }
.chip-instagram { background: radial-gradient(circle at 28% 106%, #fed576 0%, #f47133 26%, #bc3081 61%, #4c63d2 90%); border-radius: 13px; }
.chip-tiktok { background: #010101; border-radius: 13px; }
.chip-pinterest { background: #E60023; border-radius: 50%; }
.chip-facebook { background: #1877F2; border-radius: 13px; }
.f-glyph { color: #fff; font-family: Georgia, 'Times New Roman', serif; font-weight: 700; display: grid; place-items: center; line-height: 1; }
.hero-node { width: clamp(70px,16.5vw,86px); height: clamp(70px,16.5vw,86px); animation: w0l-nodeglow 5s ease-in-out infinite; }
.hero-node svg, .hero-node .f-glyph { width: 56%; height: 56%; font-size: clamp(30px,7vw,40px); }
.social-node { width: 46px; height: 46px; }
.social-node svg, .social-node .f-glyph { width: 54%; height: 54%; font-size: 23px; }
.footer-node { width: 32px; height: 32px; }
.footer-node svg, .footer-node .f-glyph { width: 54%; height: 54%; font-size: 16px; }

/* ---------- marquee ---------- */
.marquee-row { position: relative; overflow: hidden; }
.marquee-row.row1 { border-top: 1px solid rgba(201,169,97,0.3); border-bottom: 1px solid rgba(201,169,97,0.3); background: rgba(12,24,48,0.5); padding: 14px 0; }
.marquee-row.row2 { background: #0c1830; padding: 11px 0; border-bottom: 1px solid rgba(201,169,97,0.18); }
.marquee-track { display: flex; width: max-content; }
.marquee-track.l { animation: w0l-marqL 34s linear infinite; }
.marquee-track.r { animation: w0l-marqR 40s linear infinite; }
.marquee-track:hover { animation-play-state: paused; }
.marquee-seq { display: flex; align-items: center; font-family: 'JetBrains Mono', monospace; white-space: nowrap; }
.row1 .marquee-seq { font-size: clamp(13px,1.6vw,16px); letter-spacing: 0.04em; color: rgba(255,255,255,0.92); }
.row1 .marquee-seq span.item { padding: 0 22px; }
.row1 .marquee-seq span.dot { color: #C9A961; }
.row2 .marquee-seq { font-size: clamp(12px,1.4vw,14px); letter-spacing: 0.06em; color: rgba(201,169,97,0.85); }
.row2 .marquee-seq span.item { padding: 0 26px; }

/* ---------- lead magnet ---------- */
.leadmagnet { background: linear-gradient(120deg, #C9A961 0%, #8C7850 100%); padding: clamp(26px,4vw,40px) clamp(18px,5vw,48px); position: relative; overflow: hidden; }
.leadmagnet-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(20,40,80,0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(20,40,80,0.05) 1px, transparent 1px); background-size: 46px 46px; }
.leadmagnet-inner { position: relative; max-width: 1180px; margin: 0 auto; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: clamp(20px,3vw,40px); }
.leadmagnet-copy { flex: 1 1 440px; min-width: 0; }
.leadmagnet-eyebrow { display: inline-flex; align-items: center; gap: 9px; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: #142850; background: rgba(255,255,255,0.55); border-radius: 999px; padding: 6px 13px; margin-bottom: 14px; }
.leadmagnet-eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: #142850; }
.leadmagnet h2 { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: clamp(23px,3.6vw,36px); line-height: 1.08; letter-spacing: -0.025em; color: #0c1830; margin: 0 0 8px; text-wrap: balance; }
.leadmagnet p { font-size: clamp(15px,1.8vw,18px); line-height: 1.5; color: #2a2f22; margin: 0; font-weight: 500; }
.leadmagnet .btn-navy-pill { flex-shrink: 0; }

/* ---------- section shells ---------- */
.section { padding: clamp(64px,9vw,118px) clamp(18px,5vw,48px); }
.section-tight { padding: clamp(56px,8vw,104px) clamp(18px,5vw,48px); }
.section-light { background: #F6F3EC; }
.section-white { background: #FFFFFF; border-top: 1px solid rgba(20,40,80,0.08); }
.section-navy-grad { background: linear-gradient(160deg, #142850, #0c1830); color: #FFFFFF; }
.section-navy-grad2 { background: linear-gradient(160deg, #0c1830, #142850); color: #fff; }
.wrap { max-width: 1180px; margin: 0 auto; }
.eyebrow { font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: #8C7850; margin-bottom: 18px; }
.eyebrow.on-navy { color: #C9A961; }
h2.section-title { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: clamp(28px,4.4vw,46px); line-height: 1.05; letter-spacing: -0.025em; color: #142850; margin: 0; }
h2.section-title.on-navy { color: #fff; }

/* ---------- about ---------- */
.about-grid { display: grid; grid-template-columns: 1fr; gap: clamp(28px,5vw,64px); align-items: start; }
@media (min-width: 1024px) { .about-grid { grid-template-columns: 0.9fr 1.1fr; } }
.about-grid p { font-size: clamp(16px,1.8vw,18.5px); line-height: 1.7; color: #3a4252; margin: 0 0 18px; }
.tag-pill { font-family: 'JetBrains Mono', monospace; font-size: 12.5px; color: #142850; background: rgba(20,40,80,0.06); border: 1px solid rgba(20,40,80,0.1); border-radius: 999px; padding: 8px 15px; }
.tag-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 26px; }

/* ---------- products ---------- */
.products-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%,280px),1fr)); gap: clamp(16px,2.5vw,26px); }
.product-card { display: flex; flex-direction: column; background: #FFFFFF; border: 1px solid rgba(20,40,80,0.12); border-radius: 18px; overflow: hidden; transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s, border-color .35s; }
.product-card:hover { transform: translateY(-8px); box-shadow: 0 22px 50px rgba(20,40,80,0.16); border-color: rgba(140,120,80,0.55); }
.product-media { position: relative; aspect-ratio: 4/5; overflow: hidden; background: #0f2547; display: grid; place-items: center; }
.product-media img.cover { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.product-comingsoon { position: absolute; inset: 0; display: grid; place-items: center; background: radial-gradient(120% 90% at 50% 18%, #1c3a6b, #0c1830); text-align: center; padding: 20px; }
.product-comingsoon img { height: clamp(64px,16vw,84px); width: auto; margin: 0 auto 14px; display: block; filter: drop-shadow(0 8px 18px rgba(0,0,0,0.45)); }
.product-comingsoon .ed { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(201,169,97,0.85); }
.product-tag { position: absolute; top: 14px; left: 14px; z-index: 2; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; border-radius: 999px; padding: 6px 12px; }
.product-hover-overlay { position: absolute; inset: 0; z-index: 2; display: grid; place-items: center; background: linear-gradient(160deg, rgba(20,40,80,0.86), rgba(12,24,48,0.9)); opacity: 0; transition: opacity .35s; }
.product-card:hover .product-hover-overlay { opacity: 1; }
.product-hover-overlay span { font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 16px; color: #E8C77A; display: inline-flex; align-items: center; gap: 9px; }
.product-body { padding: 22px 22px 24px; display: flex; flex-direction: column; flex: 1; }
.product-body h3 { font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 20px; letter-spacing: -0.01em; color: #142850; margin: 0 0 8px; }
.product-body p { font-size: 14.5px; line-height: 1.6; color: #5a6273; margin: 0 0 18px; flex: 1; }
.product-price-row { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; padding-top: 16px; border-top: 1px solid rgba(20,40,80,0.1); }
.price-old { font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 15px; color: #adb3c0; text-decoration: line-through; }
.price-now { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 22px; color: #142850; }
.price-note { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: #8a93a6; display: block; margin-top: 3px; }
.link-label { font-family: 'JetBrains Mono', monospace; font-size: 12.5px; font-weight: 500; color: #8C7850; white-space: nowrap; }

/* ---------- storefronts ---------- */
.storefronts-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%,300px),1fr)); gap: clamp(16px,2.5vw,24px); max-width: 760px; margin: 0 auto; }
.storefront-card { display: flex; align-items: center; justify-content: space-between; gap: 16px; background: rgba(255,255,255,0.04); border: 1px solid rgba(201,169,97,0.3); border-radius: 16px; padding: 24px 26px; transition: background .3s, border-color .3s, transform .3s; }
.storefront-card:hover { background: rgba(201,169,97,0.1); border-color: #C9A961; transform: translateY(-3px); }
.storefront-logo { display: flex; align-items: center; height: 34px; margin-bottom: 7px; }
.storefront-logo .plate { display: inline-flex; align-items: center; background: #F6F3EC; border-radius: 10px; padding: 8px 14px; }
.storefront-logo .plate img { height: 26px; width: auto; display: block; }
.storefront-sub { font-family: 'JetBrains Mono', monospace; font-size: 12px; }
.storefront-arrow { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 50%; border: 1px solid rgba(201,169,97,0.4); color: #C9A961; font-family: 'JetBrains Mono', monospace; flex-shrink: 0; }

/* ---------- services ---------- */
.services-head { display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: clamp(34px,5vw,56px); }
.services-head .copy { max-width: 30em; }
.callout-badge { display: inline-flex; align-items: center; gap: 12px; background: #142850; color: #fff; border-radius: 14px; padding: 14px 20px; max-width: 320px; }
.callout-badge .mark { font-size: 22px; line-height: 1; }
.callout-badge .txt { font-size: 13.5px; line-height: 1.45; }
.services-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%,290px),1fr)); gap: clamp(16px,2.5vw,24px); }
.service-card { background: #FFFFFF; border: 1px solid rgba(20,40,80,0.1); border-radius: 18px; padding: 28px 26px; display: flex; flex-direction: column; }
.service-kicker { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 8px; }
.service-card h3 { font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 20px; letter-spacing: -0.01em; color: #142850; margin: 0 0 18px; }
.service-items { display: flex; flex-direction: column; gap: 14px; }
.service-item { display: flex; gap: 12px; align-items: flex-start; }
.service-dot { flex-shrink: 0; margin-top: 6px; width: 7px; height: 7px; border-radius: 2px; transform: rotate(45deg); }
.service-item .name { font-size: 15px; font-weight: 600; color: #1B2330; line-height: 1.35; }
.service-item .note { font-size: 13px; color: #6a7283; line-height: 1.5; margin-top: 3px; }
.services-framing { font-size: 15px; font-weight: 600; color: #142850; line-height: 1.6; margin: 26px auto 0; padding: 14px 0; max-width: 60em; text-align: center; border-top: 1px solid rgba(20,40,80,0.14); border-bottom: 1px solid rgba(20,40,80,0.14); }

.how-we-work { margin-top: clamp(40px,6vw,72px); background: #142850; border-radius: 22px; padding: clamp(28px,4vw,48px); color: #fff; }
.how-we-work-head { text-align: center; margin-bottom: clamp(26px,3.5vw,40px); }
.how-we-work-head .kicker { font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: #C9A961; margin-bottom: 12px; }
.how-we-work-head h3 { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: clamp(22px,3.2vw,34px); letter-spacing: -0.02em; margin: 0; }
.steps-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%,220px),1fr)); gap: clamp(16px,2.5vw,28px); }
.step { text-align: center; padding: 8px; }
.step-icon { display: flex; justify-content: center; margin-bottom: 12px; }
.step-num { margin: 0 auto 18px; display: grid; place-items: center; width: 52px; height: 52px; border-radius: 50%; border: 1.5px solid rgba(201,169,97,0.5); background: rgba(201,169,97,0.08); font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 20px; color: #E8C77A; }
.step h4 { font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 18px; margin: 0 0 8px; }
.step p { font-size: 14px; line-height: 1.6; color: rgba(255,255,255,0.72); margin: 0; max-width: 22em; margin-inline: auto; }
.step-badge { position: relative; display: inline-block; width: 60px; height: 60px; }
.step-badge .check { position: absolute; top: -9px; right: -9px; width: 22px; height: 22px; border-radius: 50%; background: #37C871; display: grid; place-items: center; box-shadow: 0 3px 8px rgba(0,0,0,0.35); border: 2px solid #142850; }

/* ---------- social ---------- */
.social-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%,250px),1fr)); gap: clamp(14px,2.2vw,22px); }
.social-card { display: flex; flex-direction: column; gap: 12px; background: #F6F3EC; border: 1px solid rgba(20,40,80,0.1); border-radius: 16px; padding: 24px; transition: transform .3s, border-color .3s, background .3s; }
.social-card:hover { transform: translateY(-4px); border-color: rgba(140,120,80,0.5); background: #fff; }
.social-card-head { display: flex; align-items: center; justify-content: space-between; }
.status-pill { font-family: 'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; border-radius: 999px; padding: 4px 10px; border: 1px solid; }
.social-card .name { font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 18px; color: #142850; margin-bottom: 5px; }
.social-card .desc { font-size: 13.5px; line-height: 1.55; color: #5a6273; }
.social-card .handle { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: #8C7850; margin-top: auto; padding-top: 8px; }

/* ---------- proof ---------- */
.proof-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%,260px),1fr)); gap: clamp(14px,2.2vw,22px); }
.proof-top { grid-column: 1 / -1; display: grid; grid-template-columns: 1fr; gap: clamp(14px,2.2vw,22px); }
@media (min-width: 720px) { .proof-top { grid-template-columns: 1.4fr 1fr; } }
.review-card { background: rgba(255,255,255,0.04); border: 1px solid rgba(201,169,97,0.28); border-radius: 18px; padding: 28px; }
.stars { display: flex; gap: 5px; margin-bottom: 14px; color: rgba(201,169,97,0.35); font-size: 20px; }
.review-card p { font-size: 15px; line-height: 1.6; color: rgba(255,255,255,0.78); margin: 0 0 16px; }
.portfolio-card { background: rgba(201,169,97,0.08); border: 1px solid rgba(201,169,97,0.28); border-radius: 18px; padding: 28px; display: flex; flex-direction: column; justify-content: center; }
.portfolio-card p { font-size: 16px; line-height: 1.55; color: #fff; margin: 0 0 18px; font-family: 'Space Grotesk', sans-serif; font-weight: 500; }

/* ---------- contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr; gap: clamp(32px,5vw,64px); align-items: start; }
@media (min-width: 1024px) { .contact-grid { grid-template-columns: 0.85fr 1.15fr; } }
.contact-grid > .copy p { font-size: clamp(16px,1.8vw,18px); line-height: 1.65; color: #3a4252; margin: 0 0 26px; max-width: 30em; }
.contact-email-pill { display: flex; align-items: center; gap: 12px; font-family: 'JetBrains Mono', monospace; font-size: 13.5px; color: #142850; background: #fff; border: 1px solid rgba(20,40,80,0.1); border-radius: 12px; padding: 14px 18px; width: fit-content; }
.contact-email-pill .mark { color: #8C7850; }
.contact-form { background: #fff; border: 1px solid rgba(20,40,80,0.1); border-radius: 18px; padding: clamp(24px,3vw,34px); box-shadow: 0 18px 44px rgba(20,40,80,0.07); }
.form-row { display: grid; grid-template-columns: 1fr; gap: 16px; margin-bottom: 16px; }
@media (min-width: 720px) { .form-row { grid-template-columns: 1fr 1fr; } }
.form-field { display: block; margin-bottom: 16px; }
.form-field.tight { margin-bottom: 22px; }
.form-field .lbl { display: block; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: #8C7850; margin-bottom: 7px; }
.form-field input, .form-field select, .form-field textarea { width: 100%; padding: 13px 15px; border: 1px solid rgba(20,40,80,0.16); border-radius: 11px; font-size: 15px; color: #142850; background: #FAFAF7; outline: none; }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus { border-color: #8C7850; }
.form-field textarea { resize: vertical; }
.form-success { background: #142850; color: #fff; border-radius: 18px; padding: 40px 32px; text-align: center; }
.form-success .check { font-size: 40px; margin-bottom: 14px; }
.form-success h3 { font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 22px; margin: 0 0 10px; }
.form-success p { font-size: 15px; line-height: 1.6; color: rgba(255,255,255,0.75); margin: 0; }
.form-error { color: #b3352c; font-size: 13.5px; margin-top: 10px; display: none; }
.form-error.show { display: block; }
.hidden { display: none !important; }

/* ---------- footer ---------- */
footer.site-footer { background: #0c1830; color: #fff; padding: clamp(48px,7vw,80px) clamp(18px,5vw,48px) 30px; border-top: 1px solid rgba(201,169,97,0.25); }
.footer-grid { display: grid; grid-template-columns: 1fr; gap: clamp(28px,4vw,48px); padding-bottom: clamp(34px,4vw,48px); border-bottom: 1px solid rgba(255,255,255,0.1); }
@media (min-width: 720px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .footer-grid { grid-template-columns: 1.6fr 1fr 1fr 1fr; } }
.footer-brand-link { display: inline-flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.footer-brand-badge { display: grid; place-items: center; width: 48px; height: 48px; border-radius: 12px; background: #F6F3EC; border: 1px solid rgba(140,120,80,0.3); }
.footer-brand-badge img { height: 34px; width: auto; display: block; }
.footer-brand-name { font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 18px; }
.footer-brand-name span { color: #C9A961; }
.footer-col p.desc { font-size: 14px; line-height: 1.65; color: rgba(255,255,255,0.6); margin: 0 0 18px; max-width: 26em; }
.footer-socials-row { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.footer-socials-row a { display: inline-flex; transition: transform .2s; }
.footer-socials-row a:hover { transform: translateY(-2px); }
.footer-location { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: rgba(201,169,97,0.8); margin: 0; }
.footer-col-title { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: #C9A961; margin-bottom: 16px; }
.footer-links { display: flex; flex-direction: column; gap: 11px; }
.footer-links a { font-size: 14px; color: rgba(255,255,255,0.72); transition: color .2s; }
.footer-links a:hover { color: #E8C77A; }
.footer-bottom { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 14px; padding-top: 24px; }
.footer-copyright { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: rgba(255,255,255,0.45); }

/* ---------- sticky cta ---------- */
.sticky-cta { position: fixed; right: clamp(16px,3vw,28px); bottom: clamp(16px,3vw,28px); z-index: 80; display: inline-flex; align-items: center; gap: 9px; font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 15px; color: #0c1830; background: #C9A961; padding: 14px 22px; border-radius: 999px; box-shadow: 0 12px 30px rgba(12,24,48,0.4); animation: w0l-float 4s ease-in-out infinite; }
.sticky-cta:hover { background: #E8C77A; box-shadow: 0 16px 38px rgba(12,24,48,0.5); }
.sticky-cta .dot { width: 9px; height: 9px; border-radius: 50%; background: #142850; }
