/* Poorna Constructions and Design — shared styles */
:root {
  --ink: #0F172A;
  --ink2: #1E293B;
  --slate: #475569;
  --muted: #64748B;
  --line: #E2E8F0;
  --soft: #F8FAFC;
  --cream: #FFF8F0;
  --orange: #EA580C;
  --orange-light: #F97316;
  --orange-lighter: #FDBA74;
  --orange-dark: #C2410C;
  --amber: #F59E0B;
  --green: #16A34A;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Plus Jakarta Sans', ui-sans-serif, system-ui, sans-serif;
  color: var(--ink);
  background: #fff;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

/* Utility */
.wrap { max-width: 1200px; margin: 0 auto; padding: 0 16px; }
@media (min-width: 768px) { .wrap { padding: 0 32px; } }
.hidden { display: none !important; }
.grad-orange { background: linear-gradient(135deg, #EA580C 0%, #F59E0B 100%); -webkit-background-clip: text; background-clip: text; color: transparent; }
.eyebrow { font-size: 13px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--orange); }

/* Top contact bar */
.topbar { background: var(--ink); color: rgba(255,255,255,0.9); font-size: 14px; }
.topbar .row { max-width: 1200px; margin: 0 auto; padding: 10px 16px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.topbar .items { display: none; gap: 24px; }
@media (min-width: 768px) { .topbar .items { display: flex; } .topbar .row { padding: 10px 32px; } }
.topbar .items span { display: inline-flex; align-items: center; gap: 8px; }
.topbar .tagline { color: var(--orange-lighter); font-weight: 600; display: inline-flex; align-items: center; gap: 8px; }

/* Header */
.header { position: sticky; top: 0; z-index: 40; background: rgba(255,255,255,0.95); backdrop-filter: blur(8px); border-bottom: 1px solid var(--line); }
.header .row { max-width: 1200px; margin: 0 auto; padding: 14px 16px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
@media (min-width: 768px) { .header .row { padding: 14px 32px; } }
.brand { display: flex; align-items: center; gap: 10px; }
.brand-svg { height: 40px; width: auto; }
.brand-name { line-height: 1; display: none; }
.brand-name .n { font-weight: 800; font-size: 18px; letter-spacing: -0.01em; }
.brand-name .t { font-size: 10px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); margin-top: 3px; }
.nav-desktop { display: none; gap: 28px; font-size: 15px; align-items: center; }
@media (min-width: 1024px) { .nav-desktop { display: flex; } }
.navlink { position: relative; padding: 8px 0; font-weight: 500; color: var(--slate); transition: color .2s; }
.navlink:hover { color: var(--orange); }
.navlink[aria-current="page"] { color: var(--ink); font-weight: 600; }
.navlink[aria-current="page"]::after { content: ''; position: absolute; left: 0; right: 0; bottom: -2px; height: 3px; background: var(--orange); border-radius: 3px; }
.header-right { display: flex; align-items: center; gap: 10px; }
.call-btn { display: none; align-items: center; gap: 6px; font-size: 14px; font-weight: 600; color: var(--ink); transition: color .2s; }
@media (min-width: 768px) { .call-btn { display: inline-flex; } }
.call-btn:hover { color: var(--orange); }
.hamburger { display: inline-flex; padding: 8px; background: transparent; border: none; cursor: pointer; color: var(--ink); }
@media (min-width: 1024px) { .hamburger { display: none; } }

/* Mobile menu */
.menu-mobile { display: none; border-top: 1px solid var(--line); background: #fff; padding: 12px 16px; }
.menu-mobile.open { display: block; }
.menu-mobile a { display: block; padding: 10px 0; font-size: 15px; font-weight: 500; color: var(--slate); }
.menu-mobile a[aria-current="page"] { color: var(--ink); font-weight: 700; }

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 14px 26px; border-radius: 12px; font-weight: 600; font-size: 15px; font-family: inherit; border: 1.5px solid transparent; cursor: pointer; transition: transform .2s, box-shadow .2s, background .2s, color .2s, border-color .2s; text-decoration: none; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: var(--orange); color: #fff; box-shadow: 0 8px 20px -8px rgba(234,88,12,0.6); }
.btn-primary:hover { background: var(--orange-dark); box-shadow: 0 12px 28px -8px rgba(234,88,12,0.7); }
.btn-dark { background: var(--ink); color: #fff; }
.btn-dark:hover { background: var(--ink2); }
.btn-outline { border-color: var(--line); color: var(--ink); background: #fff; }
.btn-outline:hover { border-color: var(--ink); }
.btn-sm { padding: 10px 18px; font-size: 14px; border-radius: 10px; }
.btn-full { width: 100%; padding-top: 16px; padding-bottom: 16px; }

/* Sections */
.section { padding: 72px 0; }
@media (min-width: 768px) { .section { padding: 96px 0; } }
.section-title { text-align: center; max-width: 720px; margin: 0 auto 56px; }
.section-title h2 { font-size: clamp(28px, 4vw, 44px); font-weight: 800; letter-spacing: -0.015em; margin: 12px 0 12px; line-height: 1.1; }
.section-title p { font-size: 17px; color: var(--slate); margin: 0; line-height: 1.5; }
.section.soft { background: var(--soft); }
.section.dark { background: var(--ink); color: #fff; }
.section.dark .section-title p { color: rgba(255,255,255,0.7); }
.section.dark .eyebrow { color: var(--orange-lighter); }

/* Page hero */
.page-hero { background: radial-gradient(60% 60% at 100% 0%, rgba(234,88,12,0.10) 0%, transparent 60%), radial-gradient(50% 50% at 0% 100%, rgba(234,88,12,0.06) 0%, transparent 60%), linear-gradient(180deg, #FFF8F0 0%, #FFFFFF 60%); border-bottom: 1px solid var(--line); padding: 72px 0; }
@media (min-width: 768px) { .page-hero { padding: 96px 0; } }
.page-hero h1 { font-size: clamp(36px, 6vw, 60px); font-weight: 800; letter-spacing: -0.02em; line-height: 1.05; max-width: 900px; margin: 12px 0 0; }
.page-hero .lead { font-size: 18px; color: var(--slate); margin: 24px 0 0; max-width: 640px; line-height: 1.6; }

/* Card */
.card { background: #fff; border: 1px solid var(--line); border-radius: 20px; transition: box-shadow .3s, border-color .3s, transform .3s; }
.card:hover { box-shadow: 0 12px 40px -12px rgba(15,23,42,0.15); border-color: rgba(234,88,12,0.4); transform: translateY(-3px); }
.card-featured { background: linear-gradient(160deg, #0F172A 0%, #1E293B 100%); color: #fff; border-color: var(--ink); box-shadow: 0 20px 50px -20px rgba(15,23,42,0.5); }
.card-featured:hover { border-color: var(--orange); }

/* Form */
.field { display: block; width: 100%; padding: 13px 16px; border: 1.5px solid var(--line); border-radius: 12px; font-size: 15px; background: #fff; font-family: inherit; transition: border-color .2s, box-shadow .2s; }
.field:focus { outline: none; border-color: var(--orange); box-shadow: 0 0 0 4px rgba(234,88,12,0.12); }
.field-label { display: block; font-size: 13px; font-weight: 600; color: var(--ink); margin-bottom: 6px; }

/* Grids */
.grid { display: grid; gap: 20px; }
.grid-2 { grid-template-columns: 1fr; }
.grid-3 { grid-template-columns: 1fr; }
.grid-4 { grid-template-columns: 1fr; }
@media (min-width: 640px) { .grid-2 { grid-template-columns: repeat(2, 1fr); } .grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .grid-3 { grid-template-columns: repeat(3, 1fr); } .grid-4 { grid-template-columns: repeat(4, 1fr); } }

/* Marquee */
@keyframes scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.marquee-wrap { padding: 40px 0; background: #fff; border-block: 1px solid var(--line); overflow: hidden; }
.marquee-wrap p { text-align: center; font-size: 13px; font-weight: 700; color: var(--muted); letter-spacing: .16em; text-transform: uppercase; margin: 0 0 24px; }
.marquee { display: flex; gap: 60px; animation: scroll 40s linear infinite; width: max-content; font-size: 22px; font-weight: 700; color: rgba(71,85,105,0.6); }
@media (min-width: 768px) { .marquee { font-size: 30px; } }

/* Spec table */
.spec-table { width: 100%; min-width: 900px; border-collapse: collapse; }
.spec-table th, .spec-table td { padding: 16px 18px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; font-size: 14px; }
.spec-table th { background: var(--soft); font-weight: 700; color: var(--ink); font-size: 13px; letter-spacing: 0.02em; }
.spec-table td { color: var(--slate); }
.spec-table .label { font-weight: 600; color: var(--ink); }
.spec-table tr:hover td { background: var(--cream); }
.spec-scroll { border-radius: 20px; border: 1px solid var(--line); background: #fff; overflow-x: auto; }

/* Pkg tag */
.pkg-tag { display: inline-block; padding: 4px 12px; border-radius: 999px; font-size: 11px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; }

/* Reveal */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { transition: none; opacity: 1; transform: none; } .marquee { animation: none; } }

/* Focus */
a:focus-visible, button:focus-visible, .field:focus-visible { outline: 2px solid var(--orange); outline-offset: 3px; }

/* Prose (blog posts) */
.prose { max-width: 720px; margin: 0 auto; }
.prose h2 { font-size: 24px; font-weight: 800; margin: 40px 0 12px; color: var(--ink); }
.prose h3 { font-size: 20px; font-weight: 700; margin: 32px 0 8px; }
.prose p { margin: 0 0 16px; color: #334155; line-height: 1.7; font-size: 17px; }
.prose ol, .prose ul { padding-left: 24px; margin: 16px 0; }
.prose li { margin-bottom: 8px; color: #334155; line-height: 1.7; font-size: 17px; }
.prose strong { color: var(--ink); }

/* Whatsapp float */
.whatsapp { position: fixed; bottom: 24px; right: 24px; z-index: 50; width: 56px; height: 56px; background: #22C55E; color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 0 12px 32px -8px rgba(34,197,94,0.6); transition: transform .2s, background .2s; }
.whatsapp:hover { background: #16A34A; transform: scale(1.08); }

/* Footer */
.footer { background: var(--ink); color: rgba(255,255,255,0.75); padding: 64px 0 24px; }
.footer .top { display: grid; grid-template-columns: 1fr; gap: 40px; padding-bottom: 40px; border-bottom: 1px solid rgba(255,255,255,0.1); }
@media (min-width: 768px) { .footer .top { grid-template-columns: 2fr 1fr 1fr; } }
.footer .brand-name .n { color: #fff; }
.footer .brand-name .t { color: rgba(255,255,255,0.5); }
.footer p { line-height: 1.6; font-size: 14px; margin: 0 0 20px; max-width: 420px; }
.footer .badges { display: flex; gap: 10px; flex-wrap: wrap; }
.footer .badge { font-size: 12px; font-weight: 700; padding: 6px 12px; border-radius: 999px; background: rgba(255,255,255,0.1); color: #fff; }
.footer h4 { color: rgba(255,255,255,0.5); font-size: 12px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; margin: 0 0 16px; }
.footer ul { list-style: none; padding: 0; margin: 0; }
.footer ul li { margin-bottom: 10px; font-size: 14px; }
.footer ul a:hover { color: var(--orange-light); }
.footer .bottom { padding-top: 24px; display: flex; flex-direction: column; gap: 8px; justify-content: space-between; font-size: 12px; color: rgba(255,255,255,0.5); }
@media (min-width: 768px) { .footer .bottom { flex-direction: row; } }
