/* ============================================================
   Pinnacle Epoxy Scottsdale — Site Styles
   Fonts: Bebas Neue (display) + Manrope (body)
   ============================================================ */

/* 1. Custom Properties */
:root {
  --dark:      #090912;
  --dark-alt:  #0f0f1c;
  --dark-card: #141425;
  --accent:    #f59e0b;
  --accent-dk: #d97706;
  --white:     #ffffff;
  --head:      #f0f0fa;
  --body-c:    #9090b8;
  --muted:     #606078;
  --border:    rgba(255,255,255,0.08);
  --radius:    6px;
  --radius-lg: 12px;
  --pad:       clamp(1rem,4vw,2rem);
}

/* 2. Base Reset */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: 'Manrope', sans-serif; font-size: 16px; line-height: 1.65; background: var(--dark); color: var(--body-c); -webkit-font-smoothing: antialiased; }
body.page-page { background: #fff; color: #374151; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
h1, h2, h3, h4, h5, h6 { font-weight: 700; line-height: 1.2; color: var(--head); }
body.page-page h1, body.page-page h2, body.page-page h3, body.page-page h4 { color: #111827; }

/* 3. Shell */
.shell { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 var(--pad); }

/* 4. Header */
.site-header { position: sticky; top: 0; z-index: 100; background: rgba(9,9,18,0.97); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-bottom: 1px solid var(--border); }
.nav-wrap { height: 64px; display: flex; align-items: center; justify-content: space-between; }

/* Brand */
.brand { display: flex; align-items: baseline; gap: .3rem; text-decoration: none; flex-shrink: 0; }
.brand-mark { font-family: 'Bebas Neue', sans-serif; font-size: 1.5rem; letter-spacing: .05em; color: var(--accent); line-height: 1; }
.brand-copy { font-size: .75rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: #b0b0cc; line-height: 1; }

/* Hamburger */
.menu-toggle { display: flex; flex-direction: column; justify-content: center; gap: 5px; width: 36px; height: 36px; background: none; border: none; cursor: pointer; padding: .3rem; flex-shrink: 0; }
@media(min-width:768px) { .menu-toggle { display: none; } }
.menu-toggle span { display: block; height: 2px; width: 100%; background: #a0a0c0; border-radius: 2px; transition: background .15s; }
.menu-toggle:hover span { background: #fff; }

/* Desktop Nav */
.desktop-nav { display: none; align-items: center; gap: .1rem; }
@media(min-width:768px) { .desktop-nav { display: flex; } }
.desktop-nav > a { padding: .45rem .8rem; font-size: .875rem; font-weight: 500; color: #b8b8d0; border-radius: var(--radius); transition: color .15s, background .15s; }
.desktop-nav > a:hover { color: #fff; background: rgba(255,255,255,.07); }
.desktop-nav > a.button { color: #0a0a12; background: var(--accent); border: 2px solid var(--accent); font-weight: 800; }
.desktop-nav > a.button:hover { color: #0a0a12; background: var(--accent-dk); border-color: var(--accent-dk); }

/* Dropdown */
.nav-item { position: relative; }
.nav-item > a { display: inline-block; padding: .45rem .8rem; font-size: .875rem; font-weight: 500; color: #b8b8d0; border-radius: var(--radius); cursor: pointer; transition: color .15s, background .15s; }
.nav-item:hover > a { color: #fff; background: rgba(255,255,255,.07); }
.dropdown { position: absolute; top: 100%; left: 0; min-width: 230px; padding-top: .75rem; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .15s, visibility .15s; z-index: 200; }
.dropdown > a { display: block; padding: .65rem 1.1rem; font-size: .875rem; font-weight: 500; color: #c0c0dc; background: #16162a; border-left: 3px solid transparent; transition: color .15s, background .15s, border-color .15s; }
.dropdown > a:first-child { border-radius: var(--radius) var(--radius) 0 0; padding-top: .85rem; }
.dropdown > a:last-child { border-radius: 0 0 var(--radius) var(--radius); }
.dropdown > a:hover { color: #fff; background: #20203a; border-left-color: var(--accent); }
.nav-item:hover .dropdown { opacity: 1; visibility: visible; pointer-events: auto; }

/* Mobile Nav */
.mobile-nav { display: none; flex-direction: column; padding: .25rem var(--pad) .75rem; background: #0f0f1c; border-top: 1px solid var(--border); }
.mobile-nav.is-open { display: flex; }
@media(min-width:768px) { .mobile-nav { display: none !important; } }
.mobile-nav > a, .mobile-locations-toggle { padding: .8rem 0; font-size: .9375rem; font-weight: 500; color: #b8b8d0; border-bottom: 1px solid var(--border); background: none; border-left: none; border-right: none; border-top: none; text-align: left; width: 100%; cursor: pointer; font-family: 'Manrope', sans-serif; transition: color .15s; }
.mobile-nav > a:last-child { border-bottom: none; color: var(--accent); font-weight: 700; }
.mobile-nav > a:hover, .mobile-locations-toggle:hover { color: #fff; }
.mobile-locations-list { display: none; flex-direction: column; padding-left: .75rem; }
.mobile-locations-list.is-open { display: flex; }
.mobile-locations-list > a { padding: .6rem 0; font-size: .875rem; color: #8888a8; border-bottom: 1px solid var(--border); transition: color .15s; }
.mobile-locations-list > a:last-child { border-bottom: none; }
.mobile-locations-list > a:hover { color: #fff; }

/* 5. Buttons */
.button { display: inline-flex; align-items: center; justify-content: center; padding: .75rem 1.75rem; font-size: .875rem; font-weight: 700; letter-spacing: .03em; border-radius: var(--radius); background: var(--accent); color: #0a0a12; border: 2px solid var(--accent); cursor: pointer; text-decoration: none; white-space: nowrap; line-height: 1; font-family: 'Manrope', sans-serif; transition: background .15s, border-color .15s; }
.button:hover { background: var(--accent-dk); border-color: var(--accent-dk); color: #0a0a12; }
.button.button-small { padding: .55rem 1.15rem; font-size: .85rem; }
.button.button-ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.25); }
.button.button-ghost:hover { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.5); color: #fff; }

/* 6. Typography Helpers */
.eyebrow { display: inline-block; font-size: .68rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--accent); margin-bottom: .65rem; }
body.page-page .eyebrow { color: var(--accent-dk); }
.page-hero .eyebrow { color: var(--accent); }
.kicker { display: inline-block; font-size: .68rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin-bottom: .4rem; }
.metric-label { display: block; font-size: .68rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: #707090; margin-bottom: .35rem; }

/* 7. Homepage Hero */
.hero-section { position: relative; background: var(--dark); padding: 5rem 0 4rem; overflow: hidden; }
@media(min-width:900px) { .hero-section { padding: 7rem 0 6rem; } }
.hero-section-with-image {
  background:
    linear-gradient(100deg, rgba(4,6,16,.78) 0%, rgba(6,8,20,.58) 46%, rgba(6,8,20,.34) 100%),
    linear-gradient(rgba(6,8,20,.24), rgba(6,8,20,.34)),
    var(--hero-image) center / cover no-repeat;
}
.hero-section-with-image .hero-noise { opacity: .03; }
.hero-section-with-image .hero-copy h1 { color: #f8fbff; text-shadow: 0 2px 18px rgba(0,0,0,.55); }
.hero-section-with-image .hero-text { color: #d7ddef; text-shadow: 0 1px 10px rgba(0,0,0,.45); }
.hero-section-with-image .hero-points li { color: #c8d0e6; text-shadow: 0 1px 10px rgba(0,0,0,.4); }
.hero-noise { position: absolute; inset: 0; pointer-events: none; opacity: .06; background: repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(255,255,255,.03) 2px,rgba(255,255,255,.03) 4px); }
.hero-grid { position: relative; display: grid; grid-template-columns: 1fr; gap: 3rem; align-items: start; }
@media(min-width:900px) { .hero-grid { grid-template-columns: 1fr 380px; gap: 4rem; align-items: center; } }
.hero-copy h1 { font-size: clamp(1.9rem,4vw,3rem); font-weight: 800; line-height: 1.12; color: var(--head); margin: .4rem 0 1.25rem; }
.hero-text { font-size: 1.05rem; color: #8888a8; max-width: 56ch; margin-bottom: 2rem; line-height: 1.7; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .75rem; margin-bottom: 2rem; }
.hero-points { display: flex; flex-direction: column; gap: .4rem; }
.hero-points li { font-size: .875rem; color: #707090; padding-left: 1.25rem; position: relative; line-height: 1.5; }
.hero-points li::before { content: '\2192'; position: absolute; left: 0; color: var(--accent); font-size: .75rem; top: .35em; }

/* Hero Panel */
.hero-panel { display: flex; flex-direction: column; gap: 1rem; }
.metric-card { background: var(--dark-card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.25rem 1.5rem; }
.metric-card strong { display: block; font-size: 1.05rem; font-weight: 800; color: var(--head); margin-bottom: .5rem; }
.metric-card p { font-size: .85rem; color: #707090; line-height: 1.6; }
.metric-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .625rem; }
.metric-grid article { background: var(--dark-card); border: 1px solid var(--border); border-radius: var(--radius); padding: .875rem 1rem; }
.metric-grid article span { display: block; font-size: .67rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: #565675; margin-bottom: .3rem; }
.metric-grid article strong { font-size: .8rem; font-weight: 700; color: var(--head); line-height: 1.3; }

/* 8. Signal Bar */
.signal-bar { background: var(--dark-alt); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 3rem 0; }
.signal-grid { display: grid; grid-template-columns: 1fr; gap: 2rem; }
@media(min-width:768px) { .signal-grid { grid-template-columns: repeat(3,1fr); } }
.signal-grid article h2 { font-size: 1rem; font-weight: 700; color: var(--head); margin-bottom: .5rem; }
.signal-grid article p { font-size: .875rem; color: #707090; line-height: 1.65; }

/* 9. Homepage Sections */
.section { padding: 4.5rem 0; }
.section-contrast { background: var(--dark-alt); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.section-tight { padding-top: 2.5rem; padding-bottom: 3rem; }
.cta-section { background: var(--dark-alt); border-top: 1px solid var(--border); padding: 4rem 0; }
.section-head { text-align: center; max-width: 700px; margin: 0 auto 3rem; }
.section-head.left-align { text-align: left; margin-left: 0; }
.section-head h2 { font-size: clamp(1.5rem,3vw,2.1rem); font-weight: 800; margin-bottom: .75rem; color: var(--head); }
.section-head p { font-size: 1rem; color: #808098; line-height: 1.7; }

/* 10. Cards and Grids */
.card-grid { display: grid; gap: 1.25rem; grid-template-columns: 1fr; }
.card-grid-three, .card-grid-four { grid-template-columns: 1fr; }
@media(min-width:600px) { .card-grid-three { grid-template-columns: repeat(2,1fr); } .card-grid-four { grid-template-columns: repeat(2,1fr); } }
@media(min-width:1024px) { .card-grid-three { grid-template-columns: repeat(3,1fr); } .card-grid-four { grid-template-columns: repeat(4,1fr); } }
.card-image { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; border-radius: var(--radius); margin-bottom: 1rem; border: 1px solid rgba(255,255,255,.14); }
.feature-card { background: var(--dark-card); border: 1px solid var(--border); border-top: 3px solid rgba(255,255,255,.08); border-radius: var(--radius-lg); padding: 1.75rem 1.5rem; }
.feature-card h3 { font-size: 1rem; font-weight: 700; color: var(--head); margin-bottom: .6rem; }
.feature-card p { font-size: .875rem; color: #808098; line-height: 1.65; margin-bottom: 1rem; }
.feature-card a { font-size: .8rem; font-weight: 700; color: var(--accent); letter-spacing: .04em; transition: color .15s; }
.feature-card a:hover { color: var(--accent-dk); text-decoration: underline; }
.feature-card.accent-amber { border-top-color: #f59e0b; }
.feature-card.accent-cyan  { border-top-color: #06b6d4; }
.feature-card.accent-rose  { border-top-color: #f43f5e; }
.feature-card.accent-lime  { border-top-color: #84cc16; }
.location-card { background: var(--dark-card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.75rem 1.5rem; }
.location-card h3 { font-size: 1rem; font-weight: 700; color: var(--head); margin-bottom: .6rem; }
.location-card p { font-size: .875rem; color: #808098; line-height: 1.65; margin-bottom: 1rem; }
.location-card a { font-size: .8rem; font-weight: 700; color: var(--accent); letter-spacing: .04em; transition: color .15s; }
.location-card a:hover { color: var(--accent-dk); text-decoration: underline; }
.split-grid { display: grid; grid-template-columns: 1fr; gap: 3rem; align-items: start; }
@media(min-width:860px) { .split-grid { grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; } }
.split-grid h2 { font-size: clamp(1.4rem,2.5vw,1.9rem); font-weight: 800; margin-bottom: 1rem; color: var(--head); }
.split-grid p { font-size: .9375rem; color: #808098; line-height: 1.7; margin-bottom: 1rem; }
.check-list { display: flex; flex-direction: column; gap: .6rem; margin-top: 1.25rem; }
.check-list li { font-size: .9rem; color: #8888a8; padding-left: 1.5rem; position: relative; line-height: 1.55; }
.check-list li::before { content: '\2713'; position: absolute; left: 0; color: var(--accent); font-weight: 700; }
.stacked-cards { display: flex; flex-direction: column; gap: 1rem; }
.info-card { background: var(--dark); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.5rem; }
.info-card h3 { font-size: 1rem; font-weight: 700; color: var(--head); margin-bottom: .5rem; }
.info-card p { font-size: .875rem; color: #747494; line-height: 1.65; }
.process-grid { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media(min-width:640px) { .process-grid { grid-template-columns: repeat(2,1fr); } }
@media(min-width:1024px) { .process-grid { grid-template-columns: repeat(4,1fr); } }
.process-grid article { background: var(--dark-card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.5rem; }
.process-grid article span { display: block; font-family: 'Bebas Neue', sans-serif; font-size: 2.75rem; color: var(--accent); line-height: 1; margin-bottom: .75rem; opacity: .5; }
.process-grid article h3 { font-size: .95rem; font-weight: 700; color: var(--head); margin-bottom: .5rem; }
.process-grid article p { font-size: .85rem; color: #707090; line-height: 1.65; }
.llm-grid { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media(min-width:600px) { .llm-grid { grid-template-columns: repeat(2,1fr); } }
@media(min-width:900px) { .llm-grid { grid-template-columns: repeat(4,1fr); } }
.llm-grid article { background: var(--dark-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.25rem; }
.llm-grid article h3 { font-size: .8rem; font-weight: 700; color: var(--head); margin-bottom: .4rem; text-transform: uppercase; letter-spacing: .06em; }
.llm-grid article p { font-size: .85rem; color: #747494; line-height: 1.6; }

/* 11. FAQ */
.faq-list { display: flex; flex-direction: column; gap: .5rem; max-width: 800px; margin: 0 auto; }
.faq-list details { background: var(--dark-card); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; transition: border-color .15s; }
.faq-list details[open] { border-color: rgba(245,158,11,.3); }
.faq-list summary { padding: 1.1rem 1.5rem; font-size: .9375rem; font-weight: 600; color: var(--head); cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 1rem; -webkit-user-select: none; user-select: none; }
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary::after { content: '+'; font-size: 1.25rem; font-weight: 400; color: var(--accent); flex-shrink: 0; }
.faq-list details[open] summary::after { content: '\2212'; }
.faq-list details p { padding: 0 1.5rem 1.25rem; font-size: .9rem; color: #808098; line-height: 1.7; }

/* 12. CTA Box */
.cta-box { text-align: center; max-width: 680px; margin: 0 auto; padding: 1rem 0; }
.cta-box h2 { font-size: clamp(1.5rem,3vw,2.1rem); font-weight: 800; color: var(--head); margin-bottom: 1rem; }
.cta-box p { font-size: 1rem; color: #808098; max-width: 54ch; margin: 0 auto 2rem; line-height: 1.7; }

/* 13. Footer */
.site-footer { background: #07070f; border-top: 1px solid var(--border); padding-top: 3.5rem; }
.footer-grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; padding-bottom: 2.5rem; }
@media(min-width:540px) { .footer-grid { grid-template-columns: repeat(2,1fr); } }
@media(min-width:900px) { .footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr; } }
.footer-brand { display: flex; align-items: baseline; gap: .3rem; margin-bottom: .5rem; }
.footer-grid > div > p { font-size: .875rem; color: #565675; line-height: 1.7; margin-top: .5rem; }
.footer-grid h3 { font-size: .7rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--head); margin-bottom: .875rem; }
.footer-grid > div > a { display: block; font-size: .875rem; color: #606080; margin-bottom: .45rem; transition: color .15s; }
.footer-grid > div > a:hover { color: #c0c0d8; }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: .5rem; padding: 1.25rem 0; border-top: 1px solid var(--border); font-size: .8rem; color: #454560; }
.footer-bottom a { color: #555575; transition: color .15s; }
.footer-bottom a:hover { color: #a0a0c0; }
body.page-page .site-footer { background: #0d0d1e; border-top: 1px solid rgba(255,255,255,.06); }
body.page-page .footer-bottom { color: #707090; }
body.page-page .footer-bottom a { color: #707090; }

/* 14. Inner Page Hero */
.page-hero { background: var(--dark); padding: 3.5rem 0 3rem; border-bottom: 1px solid var(--border); }
.page-grid { display: grid; grid-template-columns: 1fr; gap: 2rem; align-items: start; }
@media(min-width:860px) { .page-grid { grid-template-columns: 1fr 340px; gap: 3rem; } }
.page-hero h1 { font-size: clamp(1.6rem,3vw,2.25rem); font-weight: 800; line-height: 1.18; color: #fff; margin-bottom: .75rem; }
.page-hero p { font-size: 1rem; color: #8888a8; line-height: 1.7; }
.page-hero-card { background: var(--dark-card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 1.5rem; }
.page-hero-image { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; border-radius: var(--radius); margin-bottom: .9rem; border: 1px solid rgba(255,255,255,.14); }
.page-hero-card strong { display: block; font-size: .9375rem; font-weight: 700; color: #fff; margin-bottom: .5rem; }
.page-hero-card p { font-size: .875rem; color: #808098; line-height: 1.65; margin-top: .5rem; }

.page-hero-with-image .page-hero-card {
  background: rgba(20,20,37,.82);
  border-color: rgba(255,255,255,.16);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

@media(min-width:860px) {
  .page-hero-with-image .page-grid {
    grid-template-columns: 1fr 460px;
  }
}

.page-hero-with-image {
  position: relative;
  background:
    linear-gradient(100deg, rgba(4,6,16,.78) 0%, rgba(5,7,18,.58) 46%, rgba(5,7,18,.34) 100%),
    linear-gradient(rgba(5,7,18,.2), rgba(5,7,18,.3)),
    var(--hero-image) center / cover no-repeat;
}

.page-hero-with-image h1 { color: #f8fbff !important; text-shadow: 0 2px 18px rgba(0,0,0,.55); }
.page-hero-with-image > .shell > div > p,
.page-hero-with-image .page-grid > div > p { color: #d7ddef; text-shadow: 0 1px 10px rgba(0,0,0,.45); }
.page-hero-with-image .eyebrow { color: var(--accent); text-shadow: 0 1px 8px rgba(0,0,0,.45); }
.page-hero-with-image .page-hero-card p { color: #cbd1e6; }

.page-hero-with-image .page-grid {
  position: relative;
  z-index: 1;
}

/* 15. Inner Page Sections */
.page-section { padding: 3rem 0; border-bottom: 1px solid #e8eaee; }
.page-section:last-of-type { border-bottom: none; }
.three-up { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media(min-width:600px) { .three-up { grid-template-columns: repeat(2,1fr); } }
@media(min-width:900px) { .three-up { grid-template-columns: repeat(3,1fr); } }
.content-card { background: #f8f9fb; border: 1px solid #e8eaed; border-radius: var(--radius-lg); padding: 2rem; }
.content-card h2 { font-size: clamp(1.2rem,2.5vw,1.65rem); font-weight: 800; color: #111827; margin-bottom: .75rem; }
.content-card h3 { font-size: 1rem; font-weight: 700; color: #111827; margin-bottom: .6rem; }
.content-card p { font-size: .9375rem; color: #4b5563; line-height: 1.75; margin-bottom: .75rem; }
.content-card p:last-child { margin-bottom: 0; }
.content-card a { color: #0369a1; text-decoration: underline; transition: color .15s; }
.content-card a:hover { color: #0c4a6e; }
.content-card ul { list-style: disc; padding-left: 1.5rem; margin: .75rem 0; }
.content-card li { font-size: .9375rem; color: #4b5563; line-height: 1.7; margin-bottom: .3rem; }
.contact-card { background: #f8f9fb; border: 1px solid #e8eaed; border-radius: var(--radius-lg); padding: 1.5rem; margin-bottom: 1rem; }
.contact-card:last-child { margin-bottom: 0; }
.contact-card h3 { font-size: 1rem; font-weight: 700; color: #111827; margin-bottom: .4rem; }
.contact-card strong { display: block; font-size: 1rem; font-weight: 700; color: #111827; word-break: break-all; margin-bottom: .4rem; }
.contact-card p { font-size: .875rem; color: #6b7280; line-height: 1.65; margin-top: .4rem; }
.contact-card a { color: #0369a1; }
.contact-card a:hover { text-decoration: underline; }

/* 16. Contact Form */
.quote-form { margin-top: 1.5rem; }
.form-grid { display: grid; grid-template-columns: 1fr; gap: 1rem; margin-bottom: 1rem; }
@media(min-width:600px) { .form-grid { grid-template-columns: 1fr 1fr; } }
.quote-form label { display: flex; flex-direction: column; gap: .3rem; }
.quote-form label span { font-size: .75rem; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; color: #374151; }
.quote-form input, .quote-form select, .quote-form textarea { padding: .65rem .875rem; font-size: .9375rem; font-family: 'Manrope', sans-serif; color: #111827; background: #fff; border: 1.5px solid #d1d5db; border-radius: var(--radius); width: 100%; outline: none; transition: border-color .15s; resize: vertical; -webkit-appearance: none; }
.quote-form input:focus, .quote-form select:focus, .quote-form textarea:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(245,158,11,.1); }
.form-actions { display: flex; align-items: center; flex-wrap: wrap; gap: 1rem; margin-top: 1.5rem; }
.form-note { font-size: .8rem; color: #9ca3af; font-style: italic; }

/* 17. Privacy / Terms */
body.page-page main > .shell { padding-top: 3rem; padding-bottom: 4rem; }
body.page-page main > .shell h1 { font-size: clamp(1.6rem,3vw,2.2rem); margin-bottom: 1.5rem; color: #111827; }
body.page-page main > .shell h2 { font-size: 1.2rem; font-weight: 700; color: #111827; margin-top: 2rem; margin-bottom: .5rem; }
body.page-page main > .shell p { font-size: .9375rem; color: #4b5563; line-height: 1.75; margin-bottom: .75rem; }
body.page-page main > .shell ul { list-style: disc; padding-left: 1.5rem; margin: .5rem 0 1rem; }
body.page-page main > .shell li { font-size: .9375rem; color: #4b5563; line-height: 1.7; margin-bottom: .3rem; }
body.page-page main > .shell a { color: #0369a1; text-decoration: underline; }
