/* ============================================================
   Costa Construction & Remodeling - bespoke design system
   Coastal-craftsman: Fraunces serif display + Manrope UI,
   teal-forward palette pulled from the SWFL sailfish logo.
   Class prefix: .cc-  (kept distinct from the GLink base kit)
   ============================================================ */

:root{
  /* brand - sampled from the logo */
  --navy:#0C2A3A;        /* deepest - header text, footer, headings */
  --navy-2:#0F3548;
  --ocean:#15718F;       /* mid ocean blue - primary buttons */
  --aqua:#2A9CB8;        /* bright aqua - accents, links, icons */
  --aqua-soft:#E4F2F4;   /* aqua tint bg */
  --gold:#E0913B;        /* sunset - eyebrows, fine accents only */
  --gold-deep:#C9772A;
  --sand:#F4ECDD;        /* warm section bg */
  --cream:#FBF8F2;       /* page bg */
  --ink:#1A2A33;         /* body text */
  --muted:#5C6B73;       /* secondary text */
  --line:#E7DECF;        /* hairlines on light */
  --line-2:#1E4356;      /* hairlines on dark */
  --white:#ffffff;

  --maxw:1180px;
  --radius:14px;
  --radius-lg:22px;
  --shadow-sm:0 1px 3px rgba(12,42,58,.06), 0 6px 18px rgba(12,42,58,.06);
  --shadow-md:0 10px 30px rgba(12,42,58,.10), 0 2px 8px rgba(12,42,58,.06);
  --shadow-lg:0 30px 70px rgba(12,42,58,.18);

  --ff-display:"Fraunces", Georgia, "Times New Roman", serif;
  --ff-body:"Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  --fs-h1:clamp(2.4rem, 5.2vw, 4rem);
  --fs-h2:clamp(1.9rem, 3.6vw, 2.85rem);
  --fs-h3:clamp(1.25rem, 2vw, 1.5rem);
  --fs-lead:clamp(1.075rem, 1.5vw, 1.28rem);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;font-family:var(--ff-body);color:var(--ink);background:var(--cream);
  font-size:1.0625rem;line-height:1.7;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--ocean);text-decoration:none}
a:hover{color:var(--aqua)}
h1,h2,h3,h4{font-family:var(--ff-display);color:var(--navy);font-weight:600;line-height:1.08;margin:0 0 .5em;letter-spacing:-.01em}
h1{font-size:var(--fs-h1);font-weight:500}
h2{font-size:var(--fs-h2)}
h3{font-size:var(--fs-h3)}
p{margin:0 0 1.1rem}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:clamp(56px,8vw,104px) 0}
.section--sand{background:var(--sand)}
.section--navy{background:var(--navy);color:#D6E4EA}
.section--navy h2,.section--navy h3,.section--navy h4{color:#fff}
.center{text-align:center}
.cc-eyebrow{
  font-family:var(--ff-body);font-weight:800;font-size:.78rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--gold-deep);display:inline-flex;align-items:center;gap:.55rem;margin-bottom:1rem;
}
.cc-eyebrow::before{content:"";width:26px;height:2px;background:var(--gold);display:inline-block}
.section--navy .cc-eyebrow{color:var(--gold)}
.cc-head{max-width:680px;margin:0 0 2.6rem}
.cc-head.center{margin-left:auto;margin-right:auto}
.cc-head p{font-size:var(--fs-lead);color:var(--muted);margin-bottom:0}
.section--navy .cc-head p{color:#A9C2CC}

/* ---------- buttons ---------- */
.cc-btn{
  display:inline-flex;align-items:center;gap:.55rem;font-family:var(--ff-body);font-weight:700;
  font-size:1rem;padding:.92rem 1.5rem;border-radius:999px;border:2px solid transparent;cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease;white-space:nowrap;
}
.cc-btn svg{width:1.05em;height:1.05em}
.cc-btn--primary{background:var(--ocean);color:#fff;box-shadow:0 8px 20px rgba(21,113,143,.32)}
.cc-btn--primary:hover{background:var(--navy);color:#fff;transform:translateY(-2px);box-shadow:0 12px 26px rgba(12,42,58,.34)}
.cc-btn--gold{background:var(--gold);color:var(--navy);box-shadow:0 8px 20px rgba(224,145,59,.32)}
.cc-btn--gold:hover{background:var(--gold-deep);color:#fff;transform:translateY(-2px)}
.cc-btn--ghost{background:transparent;border-color:rgba(255,255,255,.55);color:#fff}
.cc-btn--ghost:hover{background:rgba(255,255,255,.12);color:#fff;border-color:#fff}
.cc-btn--outline{background:transparent;border-color:var(--navy);color:var(--navy)}
.cc-btn--outline:hover{background:var(--navy);color:#fff;transform:translateY(-2px)}
.cc-btn--white{background:#fff;color:var(--navy)}
.cc-btn--white:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.cc-btn-row{display:flex;flex-wrap:wrap;gap:.9rem}

/* ---------- header / nav ---------- */
.cc-header{position:sticky;top:0;z-index:50;background:rgba(251,248,242,.92);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
.cc-nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:74px}
.cc-brand{display:flex;align-items:center;gap:.7rem;line-height:1}
.cc-brand img{height:50px;width:auto}
.cc-brand-txt{font-family:var(--ff-display);font-weight:600;font-size:1.18rem;color:var(--navy);letter-spacing:-.01em}
.cc-brand-txt small{display:block;font-family:var(--ff-body);font-weight:700;font-size:.56rem;letter-spacing:.22em;color:var(--aqua);text-transform:uppercase;margin-top:2px}
.cc-menu{display:flex;align-items:center;gap:.35rem;list-style:none;margin:0;padding:0}
.cc-menu>li{position:relative}
.cc-menu a,.cc-menu .cc-parent{display:flex;align-items:center;gap:.3rem;padding:.55rem .8rem;font-weight:600;font-size:.97rem;color:var(--navy);border-radius:8px;cursor:pointer}
.cc-menu a:hover,.cc-menu .cc-parent:hover{color:var(--ocean);background:rgba(42,156,184,.08)}
.cc-caret{width:14px;height:14px;transition:transform .2s}
.cc-drop{position:absolute;top:calc(100% + 8px);left:0;min-width:248px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-md);padding:.5rem;opacity:0;visibility:hidden;transform:translateY(6px);transition:.18s}
.cc-has-children:hover .cc-drop,.cc-has-children:focus-within .cc-drop{opacity:1;visibility:visible;transform:translateY(0)}
.cc-has-children:hover .cc-caret{transform:rotate(180deg)}
.cc-drop a{padding:.6rem .8rem;border-radius:8px;font-size:.94rem}
.cc-nav-phone{font-weight:800!important;color:var(--ocean)!important}
.cc-nav-cta{background:var(--gold);color:var(--navy)!important;border-radius:999px;font-weight:800!important;padding:.6rem 1.15rem!important}
.cc-nav-cta:hover{background:var(--gold-deep);color:#fff!important}
.cc-burger{display:none;background:none;border:0;color:var(--navy);padding:.4rem;cursor:pointer}
.cc-burger svg{width:30px;height:30px}

/* ---------- hero ---------- */
.cc-hero{position:relative;background:var(--navy);color:#fff;overflow:hidden}
.cc-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:0;align-items:stretch;min-height:min(86vh,720px)}
.cc-hero-copy{padding:clamp(48px,7vw,92px) clamp(24px,4vw,64px);display:flex;flex-direction:column;justify-content:center;max-width:680px;margin-left:auto;width:100%}
.cc-hero-copy h1{color:#fff}
.cc-hero-copy h1 .accent{color:var(--gold);font-style:italic}
.cc-hero-sub{font-size:var(--fs-lead);color:#B6CCD5;margin:1.1rem 0 1.9rem;max-width:38ch}
.cc-hero-media{position:relative}
.cc-hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cc-hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--navy) 0%,rgba(12,42,58,.35) 22%,rgba(12,42,58,0) 55%)}
.cc-hero-badges{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:2rem}
.cc-pill{display:inline-flex;align-items:center;gap:.45rem;font-size:.85rem;font-weight:700;color:#DCEAEF;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);padding:.45rem .85rem;border-radius:999px}
.cc-pill svg{width:1.05em;height:1.05em;color:var(--gold)}

/* ---------- trust strip ---------- */
.cc-trust{background:var(--navy);border-top:1px solid var(--line-2)}
.cc-trust .container{display:flex;flex-wrap:wrap;justify-content:center;gap:1.2rem 2.6rem;padding-top:20px;padding-bottom:20px;align-items:center}
.cc-trust span{color:#9FBAC4;font-weight:700;font-size:.92rem;display:inline-flex;align-items:center;gap:.5rem}
.cc-trust svg{width:18px;height:18px;color:var(--aqua)}

/* ---------- stats ---------- */
.cc-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;text-align:center}
.cc-stat .n{font-family:var(--ff-display);font-size:clamp(2rem,4vw,2.9rem);color:var(--ocean);font-weight:600;line-height:1}
.cc-stat .l{font-weight:600;color:var(--muted);font-size:.95rem;margin-top:.4rem}
.section--navy .cc-stat .n{color:var(--gold)}
.section--navy .cc-stat .l{color:#A9C2CC}

/* ---------- service cards ---------- */
.cc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.cc-grid--2{grid-template-columns:repeat(2,1fr)}
.cc-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform .2s ease, box-shadow .2s ease}
a.cc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.cc-card-img{aspect-ratio:16/11;overflow:hidden}
.cc-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
a.cc-card:hover .cc-card-img img{transform:scale(1.06)}
.cc-card-body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;flex:1}
.cc-card-body h3{margin-bottom:.4rem}
.cc-card-body p{color:var(--muted);font-size:.97rem;margin-bottom:1rem}
.cc-card-link{margin-top:auto;font-weight:800;color:var(--ocean);display:inline-flex;align-items:center;gap:.4rem;font-size:.95rem}
.cc-card-link svg{width:1.1em;height:1.1em;transition:transform .2s}
a.cc-card:hover .cc-card-link svg{transform:translateX(4px)}

/* ---------- feature row (why us) ---------- */
.cc-feats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.cc-feat{padding:1.6rem 1.4rem;background:#fff;border-radius:var(--radius);border:1px solid var(--line)}
.section--navy .cc-feat{background:rgba(255,255,255,.04);border-color:var(--line-2)}
.cc-feat-ic{width:48px;height:48px;border-radius:12px;background:var(--aqua-soft);color:var(--ocean);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.section--navy .cc-feat-ic{background:rgba(42,156,184,.16);color:var(--aqua)}
.cc-feat-ic svg{width:24px;height:24px}
.cc-feat h4{font-size:1.12rem;margin-bottom:.35rem}
.cc-feat p{color:var(--muted);font-size:.94rem;margin:0}
.section--navy .cc-feat p{color:#A9C2CC}

/* ---------- split / about ---------- */
.cc-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.cc-split--media-first .cc-split-media{order:-1}
.cc-split-media{position:relative}
.cc-split-media img{border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;aspect-ratio:4/3;object-fit:cover}
.cc-split-media .cc-badge-float{position:absolute;bottom:-22px;left:-22px;background:var(--gold);color:var(--navy);padding:1rem 1.3rem;border-radius:14px;box-shadow:var(--shadow-md);font-family:var(--ff-display);font-weight:600;line-height:1.1;max-width:200px}
.cc-split-media .cc-badge-float small{display:block;font-family:var(--ff-body);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;opacity:.8;margin-top:.2rem}
.cc-lead{font-size:var(--fs-lead);color:var(--ink);font-weight:500}
.cc-checks{list-style:none;padding:0;margin:1.4rem 0 0;display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.cc-checks li{display:flex;gap:.6rem;align-items:flex-start;font-weight:600;color:var(--navy);font-size:.97rem}
.cc-checks svg{width:20px;height:20px;color:var(--aqua);flex:0 0 auto;margin-top:2px}

/* ---------- process steps ---------- */
.cc-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;counter-reset:step}
.cc-step{position:relative;padding:1.6rem 1.3rem;background:#fff;border-radius:var(--radius);border:1px solid var(--line)}
.cc-step .num{font-family:var(--ff-display);font-size:2.4rem;color:var(--aqua);font-weight:600;line-height:1;margin-bottom:.5rem}
.cc-step h4{font-size:1.1rem;margin-bottom:.3rem}
.cc-step p{color:var(--muted);font-size:.93rem;margin:0}

/* ---------- gallery ---------- */
.cc-gallery{columns:3;column-gap:1rem}
.cc-gallery img{width:100%;margin-bottom:1rem;border-radius:12px;break-inside:avoid;box-shadow:var(--shadow-sm)}

/* ---------- before/after slider ---------- */
.cc-ba{position:relative;max-width:840px;margin:0 auto;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:3/2;user-select:none;touch-action:none;cursor:ew-resize}
.cc-ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.cc-ba .after{clip-path:inset(0 0 0 50%)}
.cc-ba .cc-ba-divider{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;transform:translateX(-50%);box-shadow:0 0 0 1px rgba(12,42,58,.2)}
.cc-ba .cc-ba-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:999px;background:#fff;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;color:var(--ocean)}
.cc-ba-tag{position:absolute;bottom:12px;padding:.3rem .7rem;border-radius:999px;font-size:.74rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;background:rgba(12,42,58,.75);color:#fff}
.cc-ba-tag.b{left:12px}.cc-ba-tag.a{right:12px;background:var(--ocean)}

/* ---------- FAQ ---------- */
.cc-faq{max-width:820px;margin:0 auto}
.cc-faq details{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:.8rem;overflow:hidden}
.cc-faq summary{padding:1.1rem 1.3rem;font-weight:700;color:var(--navy);cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.cc-faq summary::-webkit-details-marker{display:none}
.cc-faq summary::after{content:"+";font-size:1.5rem;color:var(--aqua);font-weight:400;line-height:1}
.cc-faq details[open] summary::after{content:"\2013"}
.cc-faq details>div{padding:0 1.3rem 1.2rem;color:var(--muted)}

/* ---------- banner / breadcrumb hero ---------- */
.cc-banner{position:relative;background:var(--navy);color:#fff;padding:clamp(40px,7vw,84px) 0 clamp(36px,6vw,64px);overflow:hidden}
.cc-banner::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 140% at 80% 0%, rgba(42,156,184,.28), transparent 55%)}
.cc-banner .container{position:relative}
.cc-banner h1{color:#fff;max-width:18ch}
.cc-crumbs{font-size:.85rem;color:#9FBAC4;margin-bottom:1rem;display:flex;gap:.5rem;flex-wrap:wrap}
.cc-crumbs a{color:#9FBAC4}.cc-crumbs a:hover{color:#fff}
.cc-banner-sub{color:#B6CCD5;font-size:var(--fs-lead);max-width:60ch;margin:.6rem 0 0}

/* ---------- service/area page layout ---------- */
.cc-layout{display:grid;grid-template-columns:1fr 320px;gap:clamp(2rem,4vw,3.4rem);align-items:start}
.cc-prose>h2{margin-top:2rem}
.cc-prose>h2:first-child{margin-top:0}
.cc-prose ul{padding-left:0;list-style:none;margin:1.2rem 0}
.cc-prose ul li{position:relative;padding-left:1.9rem;margin-bottom:.6rem}
.cc-prose ul li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;border-radius:3px;background:var(--aqua);transform:rotate(45deg)}
.cc-aside{position:sticky;top:96px;background:var(--navy);color:#fff;border-radius:var(--radius-lg);padding:1.8rem;box-shadow:var(--shadow-md)}
.cc-aside h3{color:#fff}
.cc-aside p{color:#B6CCD5;font-size:.95rem}
.cc-aside .cc-btn{width:100%;justify-content:center;margin-top:.5rem}
.cc-aside-phone{font-family:var(--ff-display);font-size:1.6rem;color:var(--gold);font-weight:600;display:block;margin:.3rem 0 1rem}

/* related chips */
.cc-related{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.4rem}
.cc-related a{display:inline-flex;align-items:center;gap:.4rem;background:#fff;border:1px solid var(--line);padding:.5rem .9rem;border-radius:999px;font-weight:700;font-size:.9rem;color:var(--navy)}
.cc-related a:hover{border-color:var(--aqua);color:var(--ocean)}

/* ---------- big CTA band ---------- */
.cc-cta-band{background:linear-gradient(120deg,var(--navy),var(--ocean));color:#fff;text-align:center}
.cc-cta-band h2{color:#fff}
.cc-cta-band p{color:#CFE2E8;max-width:60ch;margin:0 auto 1.6rem;font-size:var(--fs-lead)}

/* ---------- contact ---------- */
.cc-contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,4vw,3.2rem);align-items:start}
.cc-info-card{background:var(--navy);color:#fff;border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-md)}
.cc-info-card h3{color:#fff}
.cc-info-row{display:flex;gap:.9rem;align-items:flex-start;padding:1rem 0;border-bottom:1px solid var(--line-2)}
.cc-info-row:last-child{border-bottom:0}
.cc-info-row svg{width:22px;height:22px;color:var(--aqua);flex:0 0 auto;margin-top:3px}
.cc-info-row a{color:#fff}
.cc-info-row .lbl{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:#8FAEB9;font-weight:700}
.cc-embed{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:.5rem;box-shadow:var(--shadow-sm)}
.cc-embed iframe{width:100%;border:none;border-radius:12px;min-height:640px;display:block}

/* ---------- footer ---------- */
.cc-footer{background:#08202C;color:#9FBAC4;padding:clamp(48px,6vw,72px) 0 2rem}
.cc-footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2rem}
.cc-footer h4{color:#fff;font-size:1.05rem;margin-bottom:1rem}
.cc-footer p{font-size:.93rem;line-height:1.7}
.cc-footer-links{list-style:none;padding:0;margin:0}
.cc-footer-links li{margin-bottom:.5rem}
.cc-footer-links a{color:#9FBAC4;font-size:.93rem}
.cc-footer-links a:hover{color:var(--aqua)}
.cc-footer-brand{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.cc-footer-brand img{height:52px}
.cc-footer-brand .cc-brand-txt{color:#fff}
.cc-footer-bottom{border-top:1px solid var(--line-2);margin-top:2.4rem;padding-top:1.6rem;display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;font-size:.85rem;color:#6F8C97}
.cc-footer-bottom a{color:#9FBAC4}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .cc-hero-grid{grid-template-columns:1fr}
  .cc-hero-media{min-height:300px;order:-1}
  .cc-hero-media::after{background:linear-gradient(0deg,var(--navy) 0%,rgba(12,42,58,.2) 60%)}
  .cc-hero-copy{margin:0 auto;max-width:760px}
  .cc-grid,.cc-feats,.cc-steps{grid-template-columns:repeat(2,1fr)}
  .cc-split{grid-template-columns:1fr}
  .cc-split--media-first .cc-split-media{order:0}
  .cc-layout{grid-template-columns:1fr}
  .cc-aside{position:static}
  .cc-contact-grid{grid-template-columns:1fr}
  .cc-footer-grid{grid-template-columns:1fr 1fr}
  .cc-gallery{columns:2}
}
@media (max-width:760px){
  .cc-burger{display:block}
  .cc-menu{position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;background:var(--cream);border-bottom:1px solid var(--line);padding:1rem;gap:.2rem;box-shadow:var(--shadow-md);transform:translateY(-130%);transition:transform .28s ease;max-height:calc(100vh - 74px);overflow:auto}
  .cc-menu.open{transform:translateY(0)}
  .cc-menu a,.cc-menu .cc-parent{padding:.85rem .6rem;font-size:1.05rem}
  .cc-drop{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-left:2px solid var(--line);border-radius:0;margin:0 0 .4rem .6rem;padding:0}
  .cc-caret{display:none}
  .cc-nav-cta{text-align:center;justify-content:center}
  body.nav-open{overflow:hidden}
}
@media (max-width:560px){
  .cc-stats,.cc-grid,.cc-feats,.cc-steps,.cc-grid--2{grid-template-columns:1fr}
  .cc-checks{grid-template-columns:1fr}
  .cc-gallery{columns:1}
  .cc-split-media .cc-badge-float{left:50%;transform:translateX(-50%);bottom:-18px}
}
