/* City Choice — Free Tools
   Brand palette pulled from citychoice-home/assets/home.css:
   - Primary green:    --green-900 #1f6a48 / --green-700 #229a67
   - CTA orange/coral: --orange-700 #C7461F → --orange-600 #E55E30 gradient
   - Ink + surfaces:   --ink #1a1a1a / --bg-warm #F7F7F7 / --bg-cream #faf6ec
*/
.cct-tool{
    --cct-green-900:#1f6a48;
    --cct-green-800:#23805a;
    --cct-green-700:#229a67;
    --cct-green-600:#2BA972;
    --cct-green-500:#3BC084;
    --cct-green-100:#e7f4ec;
    --cct-green-grad:linear-gradient(225deg,#3BC084 0%,#1F6A48 100%);
    --cct-green-grad-hov:linear-gradient(225deg,#2BA972 0%,#155236 100%);
    --cct-orange-700:#C7461F;
    --cct-orange-600:#E55E30;
    --cct-orange-grad:linear-gradient(225deg,#D17A1F 0%,#B14418 100%);
    --cct-orange-grad-hov:linear-gradient(225deg,#B16210 0%,#8B3210 100%);
    --cct-radius:6px;
    --cct-radius-lg:10px;
    --cct-ink:#1a1a1a;
    --cct-ink-2:#474747;
    --cct-muted:#7a7a7a;
    --cct-line:#e6e6e6;
    --cct-bg:#fff;
    --cct-bg-warm:#F7F7F7;

    font-family:'Poppins',system-ui,sans-serif;
    color:var(--cct-ink);
    line-height:1.6;
}
.cct-container{max-width:1200px;margin:0 auto;padding:0 24px}

/* Page head — sits directly under the cinematic banner. No background,
   just typography in the warm-bg body color, so the banner reads as the
   hero and the title/breadcrumbs feel like the start of the article. */
.cct-pagehead{background:var(--cct-bg-warm);padding:40px 0 8px}
.cct-pagehead h1{font-size:clamp(28px,4vw,44px);font-weight:800;line-height:1.15;margin:8px 0 12px;color:var(--cct-green-900);letter-spacing:-0.015em}
.cct-kicker{text-transform:uppercase;letter-spacing:.14em;font-size:12px;font-weight:600;margin:0;color:var(--cct-orange-700)}
.cct-subhead{font-size:18px;font-weight:400;max-width:760px;margin:0;color:var(--cct-ink-2);line-height:1.55}
.cct-crumbs{margin-top:18px;font-size:13px;color:var(--cct-muted)}
.cct-crumbs a{color:var(--cct-green-800);text-decoration:underline;text-underline-offset:2px}
.cct-crumbs a:hover{color:var(--cct-orange-700)}

/* Hero banner — mirrors the .why-cinematic full-bleed band from the
   services/why pages. No padding, no radius, edge-to-edge, 350px desktop
   / 240px mobile. <img> instead of background-image so it's crawlable. */
.cct-hero-banner{margin:0;padding:0;background:#000;line-height:0}
.cct-hero-banner img{display:block;width:100%;height:350px;object-fit:cover;border-radius:0;margin:0;padding:0}
@media(max-width:760px){.cct-hero-banner img{height:240px}}

.cct-body{padding:24px 0 80px;background:var(--cct-bg-warm)}
.cct-grid{display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:start}
@media(max-width:960px){.cct-grid{grid-template-columns:1fr}}

.cct-article{background:#fff;padding:40px;border-radius:14px;box-shadow:0 2px 12px rgba(31,106,72,.07)}
.cct-article h2{font-size:24px;font-weight:700;margin:32px 0 12px;color:var(--cct-green-900);letter-spacing:-0.01em}
.cct-article h2:first-child{margin-top:0}
.cct-article h3{font-size:18px;font-weight:600;margin:24px 0 10px;color:var(--cct-green-900)}
.cct-article p{margin:0 0 14px;color:var(--cct-ink-2)}
.cct-article ul{margin:0 0 16px 20px}
.cct-article li{margin-bottom:6px;color:var(--cct-ink-2)}

/* "Who this is for" — cream/green accent */
.cct-audience{margin-top:32px;padding:22px 26px;background:var(--cct-green-100);border-left:4px solid var(--cct-green-700);border-radius:0 8px 8px 0}
.cct-audience h2{margin-top:0;color:var(--cct-green-900)}
.cct-audience ul{margin-bottom:0}

.cct-faq{margin-top:36px}
.cct-faq h2{color:var(--cct-green-900)}
.cct-faq details{border-bottom:1px solid var(--cct-line);padding:14px 0}
.cct-faq summary{font-weight:600;cursor:pointer;font-size:16px;color:var(--cct-green-900)}
.cct-faq-a{padding-top:8px;color:var(--cct-ink-2)}

/* Final CTA — deep green, ties back to footer */
.cct-final-cta{margin-top:40px;padding:36px;background:var(--cct-green-grad);color:#fff;border-radius:var(--cct-radius-lg);text-align:center;box-shadow:0 10px 30px rgba(31,106,72,.20)}
.cct-final-cta h2{color:#fff;margin:0 0 8px}
.cct-final-cta p{color:#d8efe2;max-width:560px;margin:0 auto 18px}

/* Sidebar lead gate — the site nav is position:sticky;top:0, so we offset
   the form by the nav's intrinsic height (~110px desktop, ~90px mobile)
   plus a small gap. Without this the form slides under the nav. */
.cct-sidebar{position:sticky;top:calc(var(--cct-nav-offset, 110px) + 16px);display:flex;flex-direction:column;gap:20px}
@media(max-width:880px){.cct-sidebar{top:calc(var(--cct-nav-offset, 90px) + 12px)}}
@media(max-width:960px){.cct-sidebar{position:static}}

.cct-recaptcha-note{margin-top:10px;font-size:11.5px;color:var(--cct-muted);line-height:1.4}
.cct-recaptcha-note a{color:var(--cct-green-800);text-decoration:underline}

/* Related services — internal-link equity into service pages. Reads as a
   recommendation list (title + arrow) rather than a row of pill buttons. */
.cct-related-services{margin-top:32px;padding:28px 32px;background:#fff;border:1px solid var(--cct-line);border-radius:var(--cct-radius-lg)}
.cct-related-services h2{color:var(--cct-green-900);margin:0 0 6px;font-size:20px}
.cct-related-services p{color:var(--cct-ink-2);margin:0 0 16px;font-size:14.5px}
.cct-related-services__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0}
.cct-related-services__list li{margin:0}
.cct-related-services__list a{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 4px;color:var(--cct-green-900);font-weight:600;text-decoration:none;border-bottom:1px solid var(--cct-line);transition:color .15s,padding .15s}
.cct-related-services__list li:last-child a{border-bottom:0}
.cct-related-services__list a::after{content:"→";font-weight:400;color:var(--cct-orange-700);transition:transform .15s;font-size:18px}
.cct-related-services__list a:hover{color:var(--cct-orange-700);padding-left:8px}
.cct-related-services__list a:hover::after{transform:translateX(4px)}
@media(max-width:560px){.cct-related-services{padding:22px}}

/* Inline service autolinks — subtle, not blue. */
.cct-article a.cct-service-link{color:var(--cct-green-800);text-decoration:underline;text-underline-offset:2px}
.cct-article a.cct-service-link:hover{color:var(--cct-orange-700)}
.cct-leadgate{background:#fff;border-radius:14px;padding:24px;box-shadow:0 4px 20px rgba(31,106,72,.10);border-top:4px solid var(--cct-orange-600)}

/* File preview block — tells the user precisely what they're getting */
.cct-filepreview{display:flex;gap:12px;align-items:center;padding:12px;background:var(--cct-green-100);border-radius:10px;margin-bottom:14px}
.cct-filepreview__icon{flex-shrink:0;width:48px;height:60px;background:#fff;border:1px solid #cfe2d5;border-radius:6px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:6px;position:relative;box-shadow:0 1px 2px rgba(31,106,72,.08)}
.cct-filepreview__icon::before{content:"";position:absolute;top:0;right:0;width:12px;height:12px;background:linear-gradient(225deg,#cfe2d5 50%,transparent 50%);border-bottom-left-radius:3px}
.cct-filepreview__badge{font-size:10px;font-weight:700;letter-spacing:.06em;color:var(--cct-green-800);text-transform:uppercase}
.cct-filepreview__body{display:flex;flex-direction:column;min-width:0}
.cct-filepreview__title{font-size:14px;line-height:1.3;color:var(--cct-green-900);font-weight:700}
.cct-filepreview__meta{font-size:12px;color:var(--cct-muted);margin-top:2px}

/* Pitch bullets above the form */
.cct-leadgate__pitch{list-style:none;padding:0;margin:0 0 16px;display:flex;flex-direction:column;gap:6px}
.cct-leadgate__pitch li{position:relative;padding-left:22px;font-size:13.5px;color:var(--cct-ink-2);line-height:1.45}
.cct-leadgate__pitch li::before{content:"";position:absolute;left:0;top:6px;width:14px;height:14px;background:var(--cct-green-100) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23229a67' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center/9px no-repeat;border-radius:50%}
.cct-leadgate__title{font-size:22px;margin:0 0 8px;color:var(--cct-green-900);font-weight:700;letter-spacing:-0.01em}
.cct-leadgate__intro{font-size:14px;color:var(--cct-muted);margin:0 0 16px}
.cct-leadgate form label{display:block;font-size:13px;font-weight:600;color:var(--cct-green-900);margin-bottom:12px}
.cct-leadgate form input[type=text],
.cct-leadgate form input[type=email],
.cct-leadgate form input[type=tel],
.cct-leadgate form select{display:block;width:100%;padding:10px 12px;border:1px solid #d6dad7;border-radius:var(--cct-radius);font:inherit;font-weight:400;margin-top:4px;background:#fff;color:var(--cct-ink)}
.cct-leadgate form input:focus,
.cct-leadgate form select:focus{outline:2px solid var(--cct-green-700);outline-offset:1px;border-color:var(--cct-green-700)}
.cct-consent{display:flex !important;gap:10px;align-items:flex-start;font-weight:400 !important;font-size:12.5px;color:var(--cct-ink-2);line-height:1.45;margin-top:6px}
.cct-consent input{flex-shrink:0;margin-top:3px;accent-color:var(--cct-green-700)}
.cct-consent a{color:var(--cct-green-800);text-decoration:underline}

/* CTAs — gradient orange, mirrors the home plugin's .btn-orange.
   color:#fff is forced because some themes set a darker default <button> color
   that wins over our base rule and makes white text on orange unreadable. */
.cct-tool .cct-btn-primary,
.cct-tool button.cct-btn-primary,
.cct-tool a.cct-btn-primary,
.cct-btn-primary,
.cct-btn-primary:visited{
    display:inline-block;width:100%;
    background:var(--cct-orange-grad) !important;
    color:#fff !important;
    border:0 !important;padding:14px 28px;
    font:600 15px 'Poppins',sans-serif;
    border-radius:var(--cct-radius-lg) !important;
    cursor:pointer;text-align:center;text-decoration:none;
    margin-top:14px;transition:background .2s,transform .1s;
    letter-spacing:.01em;
    box-shadow:0 2px 0 rgba(0,0,0,.08);
}
.cct-btn-primary:hover{background:var(--cct-orange-grad-hov);color:#fff !important}
.cct-btn-primary:active{transform:translateY(1px)}
.cct-btn-secondary,
.cct-btn-secondary:visited{display:inline-block;background:#fff;color:var(--cct-green-900) !important;padding:12px 26px;font-weight:600;border-radius:var(--cct-radius-lg);text-decoration:none;transition:background .15s;border:0;box-shadow:0 2px 0 rgba(0,0,0,.08)}
.cct-btn-secondary:hover{background:var(--cct-green-100)}

.cct-error{color:#b14418;font-size:13px;margin:8px 0 0}
.cct-leadgate__success{text-align:center;padding:8px 0}
.cct-leadgate__success h2{color:var(--cct-green-700);margin-top:0}
.cct-leadgate__note{margin-top:12px;font-size:13px;color:var(--cct-muted)}

.cct-sidebar-help{background:var(--cct-green-grad);color:#cfe9d6;padding:22px;border-radius:var(--cct-radius-lg);box-shadow:0 6px 20px rgba(31,106,72,.18)}
.cct-sidebar-help h3{margin:0 0 6px;color:#fff;font-size:16px}
.cct-sidebar-help p{margin:0;font-size:14px}
.cct-sidebar-help a{color:#ffd998;font-weight:600;text-decoration:underline}

/* Archive grid — head gets a little more breathing room since there's no banner above it */
.cct-pagehead--archive{padding:56px 0 32px}
.cct-tool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.cct-card{background:#fff;border-radius:var(--cct-radius-lg);box-shadow:0 2px 10px rgba(31,106,72,.06);display:flex;flex-direction:column;border-top:3px solid var(--cct-green-700);transition:transform .15s,box-shadow .15s;overflow:hidden}
.cct-card__thumb{display:block;line-height:0}
.cct-card__thumb img{display:block;width:100%;height:140px;object-fit:cover}
.cct-card__body{padding:20px 24px 24px;display:flex;flex-direction:column;flex:1}
.cct-card:hover{transform:translateY(-2px);box-shadow:0 6px 22px rgba(31,106,72,.12)}
.cct-card__kicker{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--cct-green-700);margin:0 0 6px;font-weight:600}
.cct-card__title{font-size:18px;margin:0 0 10px;font-weight:700;line-height:1.3}
.cct-card__title a{color:var(--cct-green-900);text-decoration:none}
.cct-card__title a:hover{color:var(--cct-orange-700)}
.cct-card__excerpt{flex:1;font-size:14px;color:var(--cct-ink-2);margin:0 0 12px}
.cct-card__cta{color:var(--cct-orange-700);font-weight:600;text-decoration:none;font-size:14px}
.cct-card__cta:hover{color:var(--cct-orange-600)}
