/* ===== Anglian shared base: real homepage palette + shared chrome ===== */
:root {
  --navy: #001489;       /* live --fl-heading-text */
  --navy-2: #0a1489;
  --navy-deep: #00104f;
  --blue: #2b7bb9;       /* live --fl-accent */
  --blue-deep: #1f5e90;
  --amber: #f0b323;      /* live CTA bg */
  --amber-ink: #001489;  /* live CTA text */
  --grey: #75787b;       /* live body text */
  --ink: #1b2235;
  --muted: #5f6678;
  --line: #e2e7f2;
  --wash: #f4f7fb;
  --paper: #ffffff;
  --font: "Manrope", system-ui, sans-serif;
  --serif: "Fraunces", Georgia, serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--paper); color: var(--ink); font-family: var(--font); font-size: 17px; line-height: 1.6; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
h1, h2, h3 { margin: 0; font-weight: 800; letter-spacing: -0.02em; line-height: 1.08; color: var(--ink); }
p { margin: 0; }
:focus-visible { outline: 2px solid var(--amber); outline-offset: 3px; }
.shell { width: min(1180px, calc(100% - 44px)); margin: 0 auto; }
.eyebrow { font-size: 12.5px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--blue); }
@media (prefers-reduced-motion: reduce){ *, *::before, *::after { animation: none !important; transition: none !important; } html { scroll-behavior: auto; } }

.btn { display: inline-flex; align-items: center; gap: 9px; font-family: var(--font); font-weight: 700; font-size: 15.5px; padding: 13px 24px; border-radius: 40px; border: 2px solid transparent; cursor: pointer; transition: transform .15s ease, box-shadow .15s ease, background .15s ease; }
.btn.amber { background: var(--amber); color: var(--amber-ink); }
.btn.amber:hover { transform: translateY(-2px); box-shadow: 0 14px 30px -12px rgba(240,179,35,.55); }
.btn.line { background: transparent; border-color: var(--line); color: var(--ink); }
.btn.line:hover { background: var(--wash); }
.btn.on-dark { border-color: rgba(255,255,255,.5); color: #fff; }
.btn.on-dark:hover { background: rgba(255,255,255,.1); }

/* preview note + design switcher */
.pnote { background: var(--navy); color: #cdd5ff; font-size: 12.5px; }
.pnote .shell { padding: 9px 22px; display: flex; gap: 16px; flex-wrap: wrap; align-items: center; justify-content: space-between; }
.pnote b { color: #fff; }
.pnote .switch { display: flex; gap: 6px; }
.pnote .switch a { color: #cdd5ff; border: 1px solid rgba(255,255,255,.3); border-radius: 30px; padding: 4px 12px; font-weight: 700; }
.pnote .switch a.on, .pnote .switch a:hover { background: var(--amber); color: var(--navy); border-color: var(--amber); }

/* nav (shared) */
.nav-wrap { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.92); border-bottom: 1px solid var(--line); }
.nav { width: min(1180px, calc(100% - 44px)); margin: 0 auto; display: flex; align-items: center; gap: 24px; min-height: 72px; }
.nav .logo .chip { display: inline-flex; background: var(--navy); padding: 7px 10px; border-radius: 6px; }
.nav .logo img { width: 150px; }
.nav .links { display: flex; gap: 24px; margin-left: 6px; font-size: 14.5px; color: var(--muted); font-weight: 600; }
.nav .links a:hover { color: var(--ink); }
.nav .right { margin-left: auto; display: flex; align-items: center; gap: 18px; }
.nav .tel { font-weight: 800; color: var(--navy); }
@media (max-width: 940px){ .nav .links, .nav .tel { display: none; } }

/* marquee (shared) */
.marq { overflow: hidden; padding: 20px 0; background: var(--wash); border-bottom: 1px solid var(--line); -webkit-mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent); mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent); }
.marq .track { display: flex; gap: 12px; width: max-content; animation: marq 38s linear infinite; }
.marq:hover .track { animation-play-state: paused; }
@keyframes marq { to { transform: translateX(-50%); } }
.marq .chip { display: inline-flex; align-items: center; gap: 9px; padding: 10px 17px; border: 1px solid var(--line); border-radius: 10px; background: var(--paper); color: var(--ink); font-weight: 600; font-size: 14px; white-space: nowrap; }
.marq .chip i { width: 6px; height: 6px; border-radius: 50%; background: var(--amber); }

/* contact (shared) */
.contact { background: var(--wash); border-top: 1px solid var(--line); padding: 76px 0; }
.contact .shell { display: grid; grid-template-columns: 1.1fr .9fr; gap: 44px; }
.contact h2 { font-size: clamp(25px, 3vw, 36px); color: var(--navy); margin-bottom: 22px; max-width: 18ch; }
.contact form { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.contact .full { grid-column: 1 / -1; }
.contact input, .contact textarea { width: 100%; padding: 12px 14px; font: inherit; font-size: 16px; background: var(--paper); border: 1px solid var(--line); border-radius: 8px; color: var(--ink); }
.contact textarea { min-height: 110px; resize: vertical; }
.contact .info { background: var(--paper); border: 1px solid var(--line); border-radius: 12px; padding: 26px; }
.contact .info .blk { margin-bottom: 18px; }
.contact .info .lab { font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--blue); font-weight: 700; }
@media (max-width: 900px){ .contact .shell { grid-template-columns: 1fr; } .contact form { grid-template-columns: 1fr; } }

/* footer (shared) */
footer.ft { background: var(--navy); color: #c7cdf2; padding: 46px 0 40px; }
footer.ft .shell { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 30px; }
footer.ft .logo img { width: 170px; margin-bottom: 14px; }
footer.ft h4 { color: #fff; font-size: 13px; letter-spacing: .1em; text-transform: uppercase; margin: 0 0 12px; }
footer.ft a { display: block; color: #c7cdf2; font-size: 14.5px; padding: 4px 0; }
footer.ft a:hover { color: #fff; }
footer.ft .accr { grid-column: 1/-1; margin-top: 24px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.16); display: flex; gap: 22px; flex-wrap: wrap; align-items: center; font-size: 13px; color: #aab3e0; }
footer.ft .accr b { color: #fff; }
@media (max-width: 760px){ footer.ft .shell { grid-template-columns: 1fr 1fr; } }
