/* =====================================================================
   Ashcroft Pharmacy CMS replica — theme
   Palette + tokens captured from the live site (sofia-pro, pill buttons).
   ===================================================================== */
:root{
  --primary-color:#3EBCD6; --secondary-color:#DD2772;
  --teal-green:#0B3B3C; --deep-aqua:#0A8EA9; --mid-primary:#40adc4;
  --sky-blue:#26ACC8; --aqua-blue:#52BCD5; --light-sky-blue:#47A3D6;
  --dark-sky-blue:#2E94CC; --cerulean-blue:#357EC1; --powder-blue:#599EDE;
  --powder-blue-dark:#2572B6; --cornflower-blue:#629AE1; --cornflower-blue-dark:#2F75D5;
  --royal-blue:#1D69C9; --charcoal-gray:#414B53; --light-gray:#F0F0F0;
  --soft-gray:#D9D9D9; --vivid-pink:#EC65D6; --mint-green:#BCF0D2;
  --ice-blue:#E9F6F9; --light-cyan:#BCE4EC; --dark-cyan:#2C6DAC; --light-aqua:#5C9DDF;
  --ink:#414B53; --radius:14px; --container:1648px;
  --font:"sofia-pro","Helvetica Neue",Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font);font-size:16px;line-height:1.3;color:var(--ink);background:#fff;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--dark-sky-blue);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{font-weight:400;color:var(--teal-green);margin:0 0 .4em}
h1{font-size:70px;line-height:1.2;letter-spacing:-.0296em}
h2{font-size:36px;font-weight:300;line-height:1.33}
h3{font-size:22px}
p{margin:0 0 1em}
.container{max-width:var(--container);margin:0 auto;padding:0 20px}
.text-center{text-align:center}

/* ---- Buttons (pill, captured radius 52px) ---- */
.btn{display:inline-flex;align-items:center;gap:.5em;border:0;cursor:pointer;
  border-radius:52px;padding:16px 27px;font:400 18px/1 var(--font);text-decoration:none;transition:.15s}
.btn-primary{background:var(--secondary-color);color:#fff}
.btn-primary:hover{background:#c31f62;text-decoration:none}
.btn-secondary{background:var(--primary-color);color:#fff}
.btn-secondary:hover{background:var(--deep-aqua);text-decoration:none}
.btn-outline{background:#fff;color:var(--dark-sky-blue);border:2px solid var(--primary-color)}

/* ---- Top promo bar ---- */
.promo-bar{background:var(--secondary-color);color:#fff;text-align:center;font-size:13px;
  font-weight:600;letter-spacing:.02em;padding:9px 12px}

/* ---- Header ---- */
.site-header{background:#fff;padding:14px 0}
.site-header .container{display:flex;align-items:center;gap:24px}
.logo{font-weight:800;font-size:26px;color:var(--cerulean-blue);letter-spacing:.02em;white-space:nowrap}
.logo .heart{color:var(--secondary-color)}
.logo small{display:block;font-size:13px;letter-spacing:.32em;color:var(--primary-color)}
.search{flex:1}
.search form{display:flex;align-items:center;border:2px solid var(--light-cyan);border-radius:40px;
  padding:8px 8px 8px 22px;background:#fff}
.search input{flex:1;border:0;outline:0;height:38px;font:400 16px var(--font);color:#4b555e;background:transparent}
.search button{background:var(--primary-color);border:0;color:#fff;border-radius:50%;width:42px;height:42px;cursor:pointer;font-size:18px}
.header-actions{display:flex;align-items:center;gap:22px;white-space:nowrap}
.header-actions .phone{color:var(--secondary-color);font-weight:700}
.header-actions a{color:var(--cerulean-blue);font-weight:600}

/* ---- Primary nav (teal gradient) ---- */
.main-nav{background:linear-gradient(90deg,var(--sky-blue) 0%,var(--cornflower-blue) 100%);}
.main-nav .container{display:flex;justify-content:center;gap:2px;flex-wrap:wrap;position:relative}
.main-nav .nav-toggle{display:none;width:100%;background:none;border:0;color:#fff;font:600 16px var(--font);
  padding:14px;cursor:pointer;text-align:left}
.main-nav .nav-item{position:relative}
.main-nav .nav-item>a{color:#fff;font-size:20px;font-weight:500;padding:17.5px 22px;display:inline-block}
.main-nav .nav-item>a:hover{background:rgba(255,255,255,.12);text-decoration:none}
.main-nav .nav-dropdown{position:absolute;top:100%;left:0;min-width:230px;background:#fff;
  border:1px solid var(--light-cyan);border-radius:0 0 12px 12px;box-shadow:0 14px 30px rgba(11,59,60,.18);
  padding:8px 0;opacity:0;visibility:hidden;transform:translateY(6px);transition:.15s;z-index:30}
.main-nav .nav-item.has-children:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.main-nav .nav-dropdown a{display:block;color:var(--teal-green);font-size:15px;padding:9px 18px}
.main-nav .nav-dropdown a:hover{background:var(--ice-blue);text-decoration:none;color:var(--secondary-color)}
/* Grouped mega-menu (Treatments): columns of conditions, matches production */
.main-nav .nav-item.has-children.mega-parent{position:static}
.main-nav .nav-dropdown.mega{left:0;right:0;width:100%;min-width:0;display:grid;
  grid-template-columns:repeat(7,1fr);gap:4px 18px;padding:22px 28px;border-radius:0 0 12px 12px}
.main-nav .nav-dropdown.mega .mega-col{display:flex;flex-direction:column}
.main-nav .nav-dropdown.mega .mega-head{font-weight:700;color:var(--secondary-color);font-size:14px;
  padding:2px 0 8px;margin-bottom:4px;border-bottom:1px solid var(--light-cyan)}
.main-nav .nav-dropdown.mega .mega-head:hover{background:none;color:var(--primary-color);text-decoration:none}
.main-nav .nav-dropdown.mega a{padding:5px 0;font-size:14px}
.main-nav .nav-dropdown.mega a:hover{background:none;color:var(--secondary-color);text-decoration:underline}
.main-nav .nav-dropdown.mega .mega-cond{font-weight:600;color:#3a4149;padding-top:7px}
.main-nav .nav-dropdown.mega .mega-prod{padding:2px 0 2px 12px;font-size:13px;color:#6b757c}
@media(max-width:1100px){ .main-nav .nav-dropdown.mega{grid-template-columns:repeat(3,1fr)} }

/* ---- Trust badge strip ---- */
.trust-strip{background:var(--ice-blue);border-top:1px solid var(--light-cyan);border-bottom:1px solid var(--light-cyan)}
.trust-strip .container{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:14px 20px}
.trust-strip .item{display:flex;align-items:center;gap:10px;color:var(--teal-green);font-weight:600;font-size:14px}
.trust-strip .item .tick{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;
  border-radius:50%;background:var(--primary-color);color:#fff;font-size:13px}

/* ---- Hero ---- */
.hero{background:linear-gradient(120deg,var(--ice-blue),#fff);position:relative;overflow:hidden}
.hero .container{display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:center;padding:48px 20px}
.hero .gphc{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--light-cyan);
  border-radius:10px;padding:8px 12px;color:var(--deep-aqua);font-weight:700;font-size:13px;margin-bottom:18px}
.hero h1{color:#000}
.hero h1 span{color:var(--secondary-color)}
.hero p{font-size:18px;max-width:30em;color:#4b5560}
.hero-img{border-radius:var(--radius)}

/* ---- Section ---- */
.section{padding:54px 0}
.section.alt{background:var(--ice-blue)}
.section h2{text-align:center;margin-bottom:.2em;color:#000}
.section .lead{text-align:center;max-width:60em;margin:0 auto 36px;color:#4b5560}

/* ---- Conditions grid ---- */
.cond-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cond-card{background:#fff;border:1px solid #e6f1f4;border-radius:var(--radius);box-shadow:0 4px 16px rgba(11,59,60,.05);
  padding:26px 22px;text-align:center;transition:.15s;color:var(--teal-green);font-weight:600;font-size:18px}
.cond-card:hover{box-shadow:0 10px 26px rgba(62,188,214,.18);transform:translateY(-3px);text-decoration:none}
.cond-card .ico{font-size:34px;margin-bottom:10px;color:var(--primary-color)}

/* ---- Steps ---- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.step{background:#fff;border-radius:var(--radius);padding:26px;border:1px solid var(--light-cyan)}
.step .n{display:inline-block;background:var(--secondary-color);color:#fff;border-radius:30px;
  padding:5px 14px;font-weight:700;font-size:14px;margin-bottom:12px}

/* ---- Product cards ---- */
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.product-card{background:#fff;border:1px solid #e6f1f4;border-radius:var(--radius);padding:16px;text-align:center;
  box-shadow:0 4px 16px rgba(11,59,60,.05);transition:.15s}
.product-card:hover{box-shadow:0 12px 28px rgba(62,188,214,.16);transform:translateY(-3px)}
.product-card img{margin:0 auto 12px;max-height:160px}
.product-card .name{font-weight:600;color:var(--ink);min-height:2.6em}
.product-card .price{color:var(--secondary-color);font-weight:700;margin:8px 0 12px}

/* ---- Accreditations ---- */
.accred{display:flex;justify-content:center;gap:40px;flex-wrap:wrap;align-items:center}
.accred .a{max-width:230px;text-align:center;color:#4b5560;font-size:13px}

/* ---- Shipping banner (Discreet Packaging) ---- */
.ship-banner{background:linear-gradient(90deg,var(--cornflower-blue),var(--sky-blue));color:#fff;padding:56px 0}
.ship-banner .container{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.ship-banner h2{color:#fff;text-align:left;font-weight:300;margin:0 0 18px}
.ship-banner ul{list-style:none;padding:0;margin:0 0 26px}
.ship-banner li{position:relative;padding:6px 0 6px 30px;font-size:17px}
.ship-banner li::before{content:"\2611";position:absolute;left:0;top:5px;font-size:18px;color:#fff}
.ship-art{display:flex;justify-content:center}
.ship-art .parcel{width:300px;height:200px;background:linear-gradient(160deg,#d8b187,#c79a68);border-radius:8px;
  box-shadow:0 18px 40px rgba(0,0,0,.22);position:relative}
.ship-art .rm-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;color:#1c2b30;
  font-weight:700;font-size:14px;padding:14px 22px;border-radius:4px;box-shadow:0 4px 12px rgba(0,0,0,.15)}
@media(max-width:860px){.ship-banner .container{grid-template-columns:1fr}.ship-art{order:2}}

/* ---- Footer ---- */
.site-footer{background:linear-gradient(rgba(0,0,0,.2),rgba(0,0,0,.2)),#19B3DE;color:#fff;padding:50px 0 26px;margin-top:30px}
.site-footer .cols{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.site-footer h4{color:#fff;font-size:16px;font-weight:700;margin:0 0 16px}
.site-footer a{color:#fff;display:block;padding:4px 0;font-size:16px;line-height:20px}
.site-footer a:hover{color:#fff;opacity:.85}
.site-footer .bottom{border-top:1px solid rgba(255,255,255,.25);margin-top:30px;padding-top:18px;
  font-size:13px;color:rgba(255,255,255,.85);text-align:center}
.site-footer .socials{display:flex;gap:10px;margin-top:14px}
.site-footer .socials a{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;
  border-radius:50%;background:var(--secondary-color);color:#fff;padding:0}
.site-footer .socials a:hover{opacity:.9}
.site-footer .trust-badges{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.site-footer .trust-badges .tb{background:#fff;border-radius:8px;padding:8px 10px;font-size:12px;font-weight:700;
  color:var(--dark-sky-blue);text-align:center;line-height:1.3;min-width:74px}
.site-footer .trust-badges .tb small{font-weight:400;color:#6b757c;font-size:10px}
.site-footer .trust-badges .tb-cross{color:var(--primary-color)}
.site-footer .trust-badges .tb-ls{color:#0B3B3C}
.site-footer .trust-badges .tb-tp{color:#00b67a}
.site-footer .trust-badges .tb-tp small{color:#6b757c}

/* ---- Responsive ---- */
@media(max-width:980px){
  .hero .container{grid-template-columns:1fr}
  .cond-grid,.steps{grid-template-columns:repeat(2,1fr)}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  h1{font-size:46px}
  .site-footer .cols{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .main-nav .nav-toggle{display:block}
  .main-nav .container{display:none;flex-direction:column;align-items:stretch}
  .main-nav.open .container{display:flex}
  .main-nav .nav-item>a{display:block;padding:12px 18px;border-top:1px solid rgba(255,255,255,.12)}
  .main-nav .nav-dropdown{position:static;box-shadow:none;border:0;background:rgba(255,255,255,.08);opacity:1;visibility:visible;transform:none;border-radius:0}
  .main-nav .nav-dropdown a{color:#eafafd}
}
@media(max-width:600px){
  .cond-grid,.steps,.product-grid{grid-template-columns:1fr}
  .site-header .container{flex-wrap:wrap;gap:10px}
  .search{order:3;flex-basis:100%}
  h1{font-size:38px}
  .hero .container{padding:30px 20px}
  .hero p{font-size:16px}
  .section{padding:36px 0}
  .ship-banner{padding:36px 0}
  .btn{padding:13px 22px;font-size:16px}
  /* keep wide data tables usable on small screens */
  .section table{display:block;overflow-x:auto;white-space:nowrap}
}
