:root{
  --pine: #0D2B52;
  --pine-deep: #081D38;
  --sage: #9FB6D1;
  --sage-deep: #2F4A6B;
  --paper: #F6F4EC;
  --amber: #96BFE6;
  --amber-light: #6FA3D9;
  --ink: #2B2A28;
  --white: #FFFFFF;
}

*{box-sizing:border-box; margin:0; padding:0;}

body{
  font-family:'Figtree', sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}

a{color:inherit;}

.wrap{max-width:1080px; margin:0 auto; padding:0 28px;}

.skip-link{
  position:absolute; left:-999px; top:0; background:var(--pine); color:var(--white);
  padding:10px 16px; z-index:100;
}
.skip-link:focus{left:12px; top:12px;}

header{
  background:var(--pine);
  color:var(--paper);
  padding:20px 0;
}
.nav{display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px;}
.brand{
  font-family:'Source Serif 4', serif;
  font-weight:600;
  font-size:1.35rem;
  letter-spacing:0.01em;
  display:flex;
  align-items:baseline;
  gap:10px;
  text-decoration:none;
}
.brand .cross{
  display:inline-block;
  width:20px; height:20px;
  position:relative;
}
.brand .cross::before, .brand .cross::after{
  content:"";
  position:absolute;
  background:var(--amber-light);
}
.brand .cross::before{ left:8px; top:0; width:4px; height:20px; }
.brand .cross::after{ left:0; top:8px; width:20px; height:4px; }

nav.links{display:flex; gap:6px; font-size:0.95rem; flex-wrap:wrap;}
nav.links a{
  text-decoration:none;
  color:rgba(246,244,236,0.85);
  padding:8px 16px;
  border-radius:6px;
  border:1px solid transparent;
  transition:background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
nav.links a:hover, nav.links a:focus-visible{
  color:var(--paper);
  background:rgba(246,244,236,0.08);
}
nav.links a[aria-current="page"]{
  color:var(--pine-deep);
  background:var(--amber-light);
  font-weight:600;
}

/* Hero (homepage) */
.hero{padding:76px 0 64px; position:relative; overflow:hidden;}
.hero .wrap{display:grid; grid-template-columns:1.15fr 0.85fr; gap:56px; align-items:center;}

.eyebrow{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.78rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--pine);
  background:rgba(13,43,82,0.08);
  display:inline-block;
  padding:6px 12px;
  border-radius:2px;
  margin-bottom:22px;
}
h1{
  font-family:'Source Serif 4', serif;
  font-weight:600;
  font-size:clamp(2.3rem, 4.2vw, 3.4rem);
  line-height:1.08;
  color:var(--pine-deep);
  margin-bottom:20px;
  letter-spacing:-0.01em;
}
.hero p.lede{
  font-size:1.12rem;
  color:#4A4944;
  max-width:46ch;
  margin-bottom:32px;
}
.hero-ctas{display:flex; gap:14px; flex-wrap:wrap;}

.btn{
  font-family:'Figtree', sans-serif;
  font-weight:600;
  font-size:0.95rem;
  padding:13px 24px;
  border-radius:3px;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition:transform 0.15s ease, box-shadow 0.15s ease;
}
.btn-primary{background:var(--pine); color:var(--paper);}
.btn-primary:hover, .btn-primary:focus-visible{transform:translateY(-1px); box-shadow:0 6px 16px rgba(13,43,82,0.25);}
.btn-ghost{background:transparent; color:var(--pine); border:1.5px solid var(--pine);}
.btn-ghost:hover, .btn-ghost:focus-visible{background:rgba(13,43,82,0.06);}

/* Signature element: the prescription-label hours card */
.label-card{
  background:var(--white);
  border:1px solid rgba(13,43,82,0.14);
  border-radius:4px;
  box-shadow:0 18px 40px -12px rgba(8,29,56,0.18);
  position:relative;
  overflow:hidden;
}
.label-card::before{
  content:"";
  position:absolute;
  top:0; left:0; right:0;
  height:8px;
  background:var(--amber);
}
.label-inner{padding:32px 28px 26px;}
.label-rx{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.72rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--sage-deep);
  margin-bottom:6px;
}
.label-title{
  font-family:'Source Serif 4', serif;
  font-weight:600;
  font-size:1.3rem;
  color:var(--pine-deep);
  margin-bottom:18px;
}
.hours-row{
  display:flex;
  justify-content:space-between;
  gap:16px;
  font-family:'IBM Plex Mono', monospace;
  font-size:0.92rem;
  padding:10px 0;
  border-bottom:1px dashed rgba(13,43,82,0.15);
}
.hours-row:last-of-type{border-bottom:none;}
.hours-row .day{color:var(--ink); font-weight:500;}
.hours-row .time{color:var(--pine);}
.hours-row.closed .time{color:#A0968A;}
.hours-row.today{
  background:rgba(150,191,230,0.08);
  margin:0 -14px;
  padding:10px 14px;
  border-radius:2px;
  border-bottom:1px dashed transparent;
}
.hours-note{margin-top:16px; font-size:0.82rem; color:#6b6a63; font-style:italic;}

/* Info strip */
.info-strip{
  background:var(--white);
  border-top:1px solid rgba(13,43,82,0.1);
  border-bottom:1px solid rgba(13,43,82,0.1);
  padding:48px 0;
}
.info-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:36px;}
.info-item .icon{
  width:38px; height:38px;
  border-radius:50%;
  background:var(--pine);
  color:var(--paper);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:16px;
  font-family:'Source Serif 4', serif;
  font-weight:600;
}
.info-item h3{
  font-family:'Source Serif 4', serif;
  font-size:1.08rem;
  font-weight:600;
  color:var(--pine-deep);
  margin-bottom:8px;
}
.info-item p, .info-item address{font-style:normal; color:#4A4944; font-size:0.96rem;}
.info-item a{text-decoration:underline; text-decoration-color:rgba(150,191,230,0.5); text-underline-offset:3px;}
.info-item a:hover{color:var(--amber);}

/* Services (shared component: list on homepage + services page) */
.services{padding:64px 0;}
.services h2{
  font-family:'Source Serif 4', serif;
  font-weight:600;
  font-size:1.9rem;
  color:var(--pine-deep);
  margin-bottom:12px;
}
.services > .wrap > p.intro{color:#4A4944; max-width:56ch; margin-bottom:36px;}
.service-list{
  list-style:none;
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:1px;
  background:rgba(13,43,82,0.14);
  border:1px solid rgba(13,43,82,0.14);
  border-radius:4px;
  overflow:hidden;
}
.service-list li{
  background:var(--white);
  padding:20px 22px;
  font-size:0.96rem;
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.service-list li .dot{width:6px; height:6px; border-radius:50%; background:var(--amber); margin-top:8px; flex-shrink:0;}

/* Page banner for interior pages */
.page-banner{padding:56px 0 44px;}
.page-banner .eyebrow{margin-bottom:18px;}
.page-banner h1{font-size:clamp(2rem, 3.4vw, 2.7rem); margin-bottom:14px;}
.page-banner p.lede{font-size:1.05rem; color:#4A4944; max-width:60ch; margin-bottom:0;}

/* Generic content section */
.content{padding:8px 0 64px;}
.content h2{
  font-family:'Source Serif 4', serif;
  font-weight:600;
  font-size:1.6rem;
  color:var(--pine-deep);
  margin:44px 0 14px;
}
.content h2:first-of-type{margin-top:0;}
.content p{color:#4A4944; max-width:68ch; margin-bottom:14px;}
.content ul, .content ol{color:#4A4944; max-width:68ch; margin:0 0 16px 22px;}
.content li{margin-bottom:8px;}

/* Card grid (services detail, values, team) */
.card-grid{display:grid; grid-template-columns:repeat(2, 1fr); gap:20px; margin:24px 0 44px;}
.card{
  background:var(--white);
  border:1px solid rgba(13,43,82,0.14);
  border-radius:6px;
  padding:26px 24px;
}
.card h3{
  font-family:'Source Serif 4', serif;
  font-weight:600;
  font-size:1.1rem;
  color:var(--pine-deep);
  margin-bottom:10px;
}
.card p{color:#4A4944; font-size:0.95rem; margin-bottom:0;}

/* Numbered steps (refills / transfers) */
.steps{list-style:none; counter-reset:step; margin:24px 0 44px; max-width:68ch;}
.steps li{
  counter-increment:step;
  display:flex;
  gap:18px;
  padding:18px 0;
  border-bottom:1px dashed rgba(13,43,82,0.15);
}
.steps li:last-child{border-bottom:none;}
.steps li::before{
  content:counter(step);
  font-family:'IBM Plex Mono', monospace;
  font-weight:600;
  font-size:0.9rem;
  color:var(--amber);
  background:rgba(150,191,230,0.1);
  width:32px; height:32px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.steps h3{
  font-family:'Source Serif 4', serif;
  font-weight:600;
  font-size:1.02rem;
  color:var(--pine-deep);
  margin-bottom:4px;
}
.steps p{color:#4A4944; font-size:0.95rem; margin-bottom:0;}

/* Provider detail rows (for-providers page) */
.provider-grid{display:grid; grid-template-columns:1fr 1fr; gap:20px; margin:24px 0 44px;}
.provider-card{
  background:var(--white);
  border:1px solid rgba(13,43,82,0.14);
  border-radius:6px;
  padding:24px;
}
.provider-card .label{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.74rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--sage-deep);
  margin-bottom:8px;
}
.provider-card .value{
  font-family:'Source Serif 4', serif;
  font-weight:600;
  font-size:1.15rem;
  color:var(--pine-deep);
}
.provider-card .value a{text-decoration:none;}
.provider-card .value a:hover{color:var(--amber);}
.provider-card p.note{color:#4A4944; font-size:0.9rem; margin-top:8px;}

/* Map / contact split */
.map-split{display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:start; margin:24px 0 44px;}
.map-embed{
  border:1px solid rgba(13,43,82,0.14);
  border-radius:6px;
  overflow:hidden;
  min-height:340px;
  background:var(--white);
}
.map-embed iframe{width:100%; height:100%; min-height:340px; border:0; display:block;}

/* Footer */
footer{background:var(--pine-deep); color:var(--paper); padding:48px 0 28px;}
.footer-grid{display:grid; grid-template-columns:1.2fr 1fr 1fr 1fr; gap:32px; margin-bottom:36px;}
footer h4{
  font-family:'IBM Plex Mono', monospace;
  font-size:0.78rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--sage);
  margin-bottom:14px;
}
footer .brand-foot{font-family:'Source Serif 4', serif; font-weight:600; font-size:1.2rem; margin-bottom:10px;}
footer p{color:rgba(246,244,236,0.75); font-size:0.92rem; max-width:34ch;}
footer address{font-style:normal; color:rgba(246,244,236,0.85); font-size:0.92rem; line-height:1.7;}
footer ul{list-style:none;}
footer ul li{margin-bottom:9px;}
footer a{color:var(--amber-light); text-decoration:none;}
footer a:hover{text-decoration:underline;}
footer nav a{color:rgba(246,244,236,0.85);}
footer nav a:hover{color:var(--amber-light);}
.foot-bottom{
  border-top:1px solid rgba(246,244,236,0.14);
  padding-top:20px;
  font-size:0.82rem;
  color:rgba(246,244,236,0.55);
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:10px;
}

/* Screen-reader-only text */
.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* Contact form */
.contact-form{max-width:520px;}
.form-row{margin-bottom:20px;}
.form-row label{
  display:block;
  font-family:'Figtree', sans-serif;
  font-weight:600;
  font-size:0.92rem;
  color:var(--pine-deep);
  margin-bottom:6px;
}
.form-row .required-mark{color:var(--amber); margin-left:2px;}
.form-row input,
.form-row textarea{
  width:100%;
  font-family:'Figtree', sans-serif;
  font-size:0.96rem;
  color:var(--ink);
  background:var(--white);
  border:1.5px solid rgba(13,43,82,0.25);
  border-radius:4px;
  padding:11px 14px;
}
.form-row input:focus-visible,
.form-row textarea:focus-visible{
  outline:2px solid var(--amber);
  outline-offset:1px;
  border-color:var(--pine);
}
.form-row textarea{resize:vertical; min-height:120px;}
.form-hint{font-size:0.82rem; color:#6b6a63; margin-top:6px;}
.form-status{
  margin-top:18px;
  padding:14px 16px;
  border-radius:4px;
  font-size:0.92rem;
  display:none;
}
.form-status.visible{display:block;}
.form-status.success{background:rgba(13,43,82,0.08); color:var(--pine-deep); border:1px solid rgba(13,43,82,0.2);}
.form-status.error{background:rgba(166,60,20,0.08); color:#8a3d12; border:1px solid rgba(166,60,20,0.25);}
.hp-field{position:absolute; left:-9999px; top:-9999px;}

@media (max-width: 860px){
  .hero .wrap{grid-template-columns:1fr;}
  .hero{padding:52px 0 44px;}
  .info-grid{grid-template-columns:1fr; gap:28px;}
  .service-list{grid-template-columns:1fr;}
  .card-grid{grid-template-columns:1fr;}
  .provider-grid{grid-template-columns:1fr;}
  .map-split{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr; gap:28px;}

  nav.links{
    display:flex;
    width:100%;
    order:3;
    gap:8px;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    padding-top:10px;
    margin-top:6px;
    border-top:1px solid rgba(246,244,236,0.18);
  }
  nav.links::-webkit-scrollbar{display:none;}
  nav.links a{white-space:nowrap; flex-shrink:0;}
}

@media (prefers-reduced-motion: reduce){ *{transition:none !important;} }

:focus-visible{outline:2px solid var(--amber); outline-offset:2px;}
