/* Ipswich Web Solutions — section styles (ported from approved mockup) */

/* full-bleed builder content on the BB-theme Full Width template */
.fl-content-full.container{max-width:100%;width:100%;padding-left:0;padding-right:0}
.fl-content-full > .row{margin-left:0;margin-right:0}
.fl-content-full .fl-content{padding-left:0;padding-right:0;width:100%;float:none}
.fl-content-full{padding-top:0;padding-bottom:0}
.fl-builder-content .fl-row-full-width > .fl-row-content-wrap{padding-left:0;padding-right:0}
.fl-content-full article.fl-post,.fl-content-full .fl-post-content{padding:0;margin:0;border:0}
.fl-content-full .fl-post-header{display:none}
.fl-page-content{padding-top:0;padding-bottom:0}
/* every section is a single full-width column — stop flex shrink-wrap */
.fl-builder-content .fl-col-group{display:block}
.fl-builder-content .fl-col{width:100%;max-width:100%;clear:both;float:none}
.fl-builder-content .fl-col-content,.fl-builder-content .fl-module,.fl-builder-content .fl-module-content{width:100%}

:root{
  --blue:#1B6CFF; --blue-dark:#0B4FD6; --mint:#14CFA0; --pine:#0FA982;
  --ink:#0E1726; --body:#566175; --cloud:#F3F7FF; --mist:#E4EAF2; --white:#fff;
  --grad:linear-gradient(135deg,#1B6CFF,#14CFA0);
  --shadow:0 10px 30px rgba(14,23,38,.08); --shadow-lg:0 24px 60px rgba(14,23,38,.12);
  --maxw:1160px; --radius:16px;
}
.iws{font-family:'Inter',system-ui,sans-serif;color:var(--body);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased}
.iws *{box-sizing:border-box}
.iws h1,.iws h2,.iws h3,.iws h4{font-family:'Sora',sans-serif;color:var(--ink);line-height:1.12;letter-spacing:-.02em;margin:0}
.iws h1{font-size:clamp(34px,5vw,56px);font-weight:700}
.iws h2{font-size:clamp(28px,3.4vw,38px);font-weight:600}
.iws h3{font-size:21px;font-weight:600}
.iws p{margin:0}
.iws a{color:inherit;text-decoration:none}
.iws .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.iws section{padding:96px 0}
.iws .muted{color:var(--body)}
.iws .eyebrow{font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--blue)}
.iws .center{text-align:center;max-width:680px;margin:0 auto 52px}
.iws .btn{display:inline-flex;align-items:center;gap:8px;font-family:'Inter';font-weight:600;font-size:16px;padding:14px 26px;border-radius:12px;cursor:pointer;border:2px solid transparent;transition:.18s}
.iws .btn-primary{background:var(--mint);color:var(--ink)}
.iws .btn-primary:hover{background:var(--pine);transform:translateY(-1px)}
.iws .btn-ghost{background:var(--white);color:var(--blue);border-color:var(--mist)}
.iws .btn-ghost:hover{border-color:var(--blue)}
.iws .badge-grad{display:inline-block;background:var(--grad);color:#fff;font-weight:600;font-size:13px;padding:6px 14px;border-radius:999px}

/* hero */
.iws .hero{position:relative;color:#fff;padding:0;background-size:cover;background-position:center 38%;background-repeat:no-repeat}
.iws .hero-inner{position:relative;display:flex;align-items:center;min-height:570px;padding:72px 0}
.iws .hero-copy{max-width:625px}
.iws .hero h1{margin:18px 0;color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.25)}
.iws .hero .lead{font-size:19px;max-width:545px;color:rgba(255,255,255,.93)}
.iws .hero-cta{display:flex;gap:14px;margin:30px 0 22px;flex-wrap:wrap}
.iws .trustline{display:flex;gap:18px;flex-wrap:wrap;font-size:14.5px;font-weight:600;color:#fff}
.iws .trustline span{display:flex;align-items:center;gap:7px}
.iws .dot{width:7px;height:7px;border-radius:50%;background:var(--mint)}
.iws .hero-float{position:absolute;right:0;bottom:34px;width:320px;display:flex;flex-direction:column;gap:14px}
.iws .float-card{background:#fff;border:1px solid var(--mist);border-radius:16px;box-shadow:var(--shadow-lg);padding:20px}
.iws .float-card .stars{color:#FFB400;letter-spacing:2px;margin-bottom:6px}
.iws .float-card strong{font-family:'Sora';color:var(--ink);font-size:16px;display:block}
.iws .float-card p{font-size:13.5px;margin:6px 0 8px;color:var(--body)}
.iws .float-chip{align-self:flex-end;background:#fff;border:1px solid var(--mist);box-shadow:var(--shadow);border-radius:999px;padding:9px 16px;font-size:14px;font-weight:600;color:var(--ink)}
.iws .float-chip .stat-up{color:var(--pine);font-weight:700}

/* strip */
.iws .strip{background:var(--cloud);padding:26px 0}
.iws .strip .wrap{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;text-align:center}
.iws .strip b{color:var(--ink)}

/* services / generic card grid */
.iws .grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.iws .card{background:var(--white);border:1px solid var(--mist);border-radius:var(--radius);padding:30px;transition:.2s}
.iws .card:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:transparent}
.iws .ico{width:52px;height:52px;border-radius:13px;background:var(--cloud);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.iws .ico svg{width:26px;height:26px;stroke:var(--blue)}
.iws .card h3{margin-bottom:8px}
.iws .card .price{margin-top:14px;font-family:'Sora';font-weight:600;color:var(--ink);font-size:15px}
.iws .card a.more{display:inline-block;margin-top:14px;color:var(--blue);font-weight:600;font-size:15px}

/* why */
.iws .why{background:var(--cloud)}
.iws .grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.iws .feat{display:flex;gap:16px;background:var(--white);border:1px solid var(--mist);border-radius:14px;padding:22px}
.iws .feat .chk{flex:none;width:30px;height:30px;border-radius:8px;background:var(--grad);display:flex;align-items:center;justify-content:center}
.iws .feat .chk svg{width:16px;height:16px;stroke:#fff;stroke-width:3}
.iws .feat h4{font-family:'Sora';font-size:17px;color:var(--ink);margin-bottom:3px}
.iws .feat p{font-size:14.5px}

/* pricing */
.iws .price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.iws .pcard{border:1px solid var(--mist);border-radius:var(--radius);padding:30px;background:var(--white);position:relative}
.iws .pcard.feature{border:2px solid var(--blue);box-shadow:var(--shadow)}
.iws .pcard .tag{position:absolute;top:-12px;right:22px;background:var(--blue);color:#fff;font-size:12px;font-weight:600;padding:4px 12px;border-radius:999px}
.iws .pcard h3{color:var(--ink)}
.iws .pcard .from{color:var(--body);font-size:14px;margin-top:14px}
.iws .pcard .amt{font-family:'Sora';font-weight:700;font-size:34px;color:var(--ink);line-height:1.1}
.iws .pcard .amt small{font-size:15px;font-weight:500;color:var(--body)}
.iws .pcard ul{list-style:none;margin:18px 0 0;padding:0}
.iws .pcard li{padding:7px 0 7px 26px;position:relative;font-size:14.5px}
.iws .pcard li:before{content:"";position:absolute;left:0;top:13px;width:14px;height:8px;border-left:2.5px solid var(--mint);border-bottom:2.5px solid var(--mint);transform:rotate(-45deg)}

/* result */
.iws .result{color:#cdd6e4;background:var(--ink)}
.iws .result .wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.iws .result h2{color:#fff}
.iws .stat{font-family:'Sora';font-weight:700;font-size:54px;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.iws .quote{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:28px}
.iws .quote p{color:#e7ecf4;font-size:17px;font-style:italic}
.iws .quote .who{margin-top:14px;color:#9fb0c8;font-size:14px;font-style:normal}

/* reviews */
.iws .rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.iws .rev{border:1px solid var(--mist);border-radius:var(--radius);padding:26px;background:var(--white)}
.iws .stars{color:#FFB400;letter-spacing:2px;margin-bottom:12px}
.iws .rev p{font-size:15px;color:var(--ink)}
.iws .rev .who{margin-top:14px;font-size:13.5px;color:var(--body);font-weight:500}

/* area */
.iws .area{background:var(--cloud);text-align:center}
.iws .chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:26px}
.iws .chip{background:var(--white);border:1px solid var(--mist);border-radius:999px;padding:10px 20px;font-weight:500;color:var(--ink);font-size:15px}
.iws .area-img{width:100%;max-height:320px;object-fit:cover;border-radius:20px;margin-top:38px;box-shadow:var(--shadow)}

/* faq */
.iws .faq .wrap{max-width:820px}
.iws .faq details{border:1px solid var(--mist);border-radius:12px;padding:4px 22px;margin-bottom:12px;background:var(--white)}
.iws .faq summary{cursor:pointer;font-family:'Sora';font-weight:600;color:var(--ink);font-size:17px;padding:18px 0;list-style:none;display:flex;justify-content:space-between;align-items:center}
.iws .faq summary::-webkit-details-marker{display:none}
.iws .faq summary:after{content:"+";color:var(--blue);font-size:24px;font-weight:400}
.iws .faq details[open] summary:after{content:"–"}
.iws .faq details p{padding:0 0 18px;font-size:15.5px}

/* cta band */
.iws .cta-sec{padding-top:0}
.iws .cta-band{background:var(--grad);border-radius:24px;padding:56px;text-align:center;color:#fff;box-shadow:var(--shadow-lg)}
.iws .cta-band h2{color:#fff}
.iws .cta-band p{color:rgba(255,255,255,.92);max-width:520px;margin:14px auto 26px;font-size:18px}
.iws .cta-band .btn-primary{background:#fff}
.iws .cta-band .btn-ghost{background:transparent;border-color:rgba(255,255,255,.6);color:#fff}

/* prose (inner-page bodies) */
.iws-prose{font-family:'Inter',sans-serif;color:var(--body);font-size:17px;line-height:1.7;max-width:820px;margin:0 auto}
.iws-prose h2{font-family:'Sora';color:var(--ink);font-size:30px;font-weight:600;margin:42px 0 14px;letter-spacing:-.02em}
.iws-prose h3{font-family:'Sora';color:var(--ink);font-size:21px;font-weight:600;margin:30px 0 10px}
.iws-prose p{margin:0 0 16px}
.iws-prose ul,.iws-prose ol{margin:0 0 18px;padding-left:0;list-style:none}
.iws-prose ul li{position:relative;padding:6px 0 6px 28px}
.iws-prose ul li:before{content:"";position:absolute;left:2px;top:14px;width:13px;height:7px;border-left:2.5px solid var(--mint);border-bottom:2.5px solid var(--mint);transform:rotate(-45deg)}
.iws-prose ol{counter-reset:n;padding-left:0}
.iws-prose ol li{position:relative;padding:6px 0 6px 36px;counter-increment:n}
.iws-prose ol li:before{content:counter(n);position:absolute;left:0;top:6px;width:24px;height:24px;background:var(--cloud);color:var(--blue);font-weight:700;font-size:13px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Sora'}
.iws-prose a{color:var(--blue);font-weight:600}
.iws-prose strong{color:var(--ink)}
.iws-prose table{width:100%;border-collapse:collapse;margin:0 0 22px;font-size:15px}
.iws-prose th,.iws-prose td{border:1px solid var(--mist);padding:11px 14px;text-align:left}
.iws-prose th{background:var(--cloud);color:var(--ink);font-family:'Sora';font-weight:600}
.iws-prose blockquote{margin:0 0 18px;padding:16px 22px;background:var(--cloud);border-left:3px solid var(--mint);border-radius:8px}
.iws-prose details{border:1px solid var(--mist);border-radius:12px;padding:2px 20px;margin-bottom:12px;background:#fff}
.iws-prose summary{cursor:pointer;font-family:'Sora';font-weight:600;color:var(--ink);font-size:16px;padding:16px 0;list-style:none}
.iws-prose summary::-webkit-details-marker{display:none}
.iws-prose .lead-in{font-size:19px;color:var(--ink);font-weight:500;margin-bottom:22px}

/* Gravity Forms — brand styling */
.iws-prose .gform_wrapper{max-width:640px;margin:0 auto}
.iws-prose .gform_wrapper .gfield_label{font-family:'Sora',sans-serif;color:var(--ink);font-weight:600;font-size:14px;margin-bottom:6px}
.iws-prose .gform_wrapper input[type=text],.iws-prose .gform_wrapper input[type=email],.iws-prose .gform_wrapper input[type=tel],.iws-prose .gform_wrapper textarea,.iws-prose .gform_wrapper select{width:100%;border:1px solid var(--mist);border-radius:10px;padding:12px 14px;font-family:'Inter',sans-serif;font-size:15px;background:#fff;color:var(--ink)}
.iws-prose .gform_wrapper input:focus,.iws-prose .gform_wrapper textarea:focus,.iws-prose .gform_wrapper select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(27,108,255,.12)}
.iws-prose .gform_wrapper .gform_footer{margin-top:18px}
.iws-prose .gform_wrapper .gform_footer input[type=submit],.iws-prose .gform_wrapper button.gform_button{background:var(--mint);color:var(--ink);border:0;border-radius:12px;padding:14px 28px;font-family:'Inter',sans-serif;font-weight:600;font-size:16px;cursor:pointer;transition:.18s}
.iws-prose .gform_wrapper .gform_footer input[type=submit]:hover,.iws-prose .gform_wrapper button.gform_button:hover{background:var(--pine)}
.iws-prose .gform_confirmation_message{background:var(--cloud);border:1px solid var(--mist);border-radius:12px;padding:22px;color:var(--ink);font-weight:500}

/* footer */
.iws-footer{background:var(--ink);color:#9fb0c8;padding:64px 0 30px}
.iws-footer .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.iws-footer .foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:36px}
.iws-footer h4{color:#fff;font-family:'Sora',sans-serif;font-size:15px;margin:0 0 14px}
.iws-footer a{display:block;padding:5px 0;color:#9fb0c8;font-size:14.5px;text-decoration:none}
.iws-footer a:hover{color:#fff}
.iws-footer .foot-blurb{margin-top:16px;max-width:300px;font-size:14.5px;line-height:1.6}
.iws-footer .foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13.5px}
@media(max-width:900px){.iws-footer .foot-grid{grid-template-columns:1fr 1fr}}

/* responsive */
@media(max-width:900px){
  .iws .grid-3,.iws .grid-2,.iws .price-grid,.iws .rev-grid,.iws .result .wrap{grid-template-columns:1fr}
  .iws section{padding:60px 0}
  .iws .hero-inner{min-height:auto;flex-direction:column;align-items:flex-start;padding:54px 0}
  .iws .hero-float{position:static;width:100%;margin-top:26px}
  .iws .float-chip{align-self:flex-start}
  .iws .cta-band{padding:40px 24px}
}
