
/* ServicePortal public website style - safe public pages only */
:root{
  --public-bg:#080f1f;
  --public-bg-2:#0d1930;
  --public-card:#12243b;
  --public-card-2:#17304d;
  --public-border:rgba(125,190,255,.22);
  --public-text:#fff7e6;
  --public-muted:#c7d4e7;
  --public-gold:#ffb84d;
  --public-blue:#38bdf8;
  --public-button:#1d4ed8;
}

body:not(.dashboard-body){
  background:radial-gradient(circle at top left, rgba(56,189,248,.16), transparent 34%), linear-gradient(180deg,var(--public-bg),var(--public-bg-2)) !important;
  color:var(--public-text) !important;
  font-family:Arial,Helvetica,sans-serif !important;
  overflow-x:hidden !important;
}

body:not(.dashboard-body) a{color:inherit;text-decoration:none;}

/* Shared public header */
.header,.site-header,.top{
  background:rgba(8,15,31,.92) !important;
  border-bottom:1px solid rgba(255,255,255,.10) !important;
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:blur(14px);
}
.nav,.header-inner,.top{
  width:min(1180px, calc(100% - 32px)) !important;
  margin:0 auto !important;
  min-height:74px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:18px !important;
}
.logo,.brand,.brand-logo,.top .brand{
  color:var(--public-gold) !important;
  font-size:28px !important;
  font-weight:950 !important;
  letter-spacing:-.6px !important;
  white-space:nowrap !important;
}
.brand span{color:var(--public-blue) !important;}
.nav-links,.site-header .nav,.top-links{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:10px !important;
  flex-wrap:wrap !important;
}
.nav-links a,.site-header .nav a,.top-links a{
  color:#eef6ff !important;
  font-weight:850 !important;
  padding:10px 12px !important;
  border-radius:999px !important;
}
.nav-links a:hover,.site-header .nav a:hover,.top-links a:hover,
.nav-links a.active,.site-header .nav a.active,.top-links a.active{
  background:rgba(56,189,248,.13) !important;
  color:#fff !important;
}

/* Public buttons */
.btn,.button,button.btn,a.btn,a.button,input[type="submit"]{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:8px !important;
  min-height:44px !important;
  border-radius:999px !important;
  border:1px solid rgba(147,197,253,.35) !important;
  background:linear-gradient(180deg,#3b82f6,#1d4ed8) !important;
  color:#fff !important;
  font-weight:900 !important;
  padding:12px 18px !important;
  cursor:pointer !important;
  text-align:center !important;
}
.btn.secondary,.button-secondary,.button-outline,a.btn.secondary{
  background:rgba(255,255,255,.08) !important;
  border-color:rgba(255,255,255,.18) !important;
  color:var(--public-text) !important;
}
.button-light{background:linear-gradient(180deg,#ffd98d,#ffb84d) !important;color:#152036 !important;border-color:rgba(255,216,141,.55) !important;}
.button-primary{background:linear-gradient(180deg,#3b82f6,#1d4ed8) !important;color:#fff !important;}
.button-success{background:linear-gradient(180deg,#22c55e,#16a34a) !important;color:#fff !important;}

/* Public hero and sections */
.hero{
  background:transparent !important;
  padding:72px 0 48px !important;
}
.hero-inner,.section,.container{
  width:min(1180px, calc(100% - 32px)) !important;
  margin-left:auto !important;
  margin-right:auto !important;
}
.hero-inner{
  display:grid !important;
  grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr) !important;
  gap:28px !important;
  align-items:center !important;
}
.hero h1,.section-title,h1{
  color:var(--public-text) !important;
  font-size:clamp(34px,5vw,62px) !important;
  line-height:1.02 !important;
  letter-spacing:-1.2px !important;
  font-weight:950 !important;
  margin:0 0 16px !important;
}
.section-title,h1.section-title{font-size:clamp(30px,3.5vw,46px) !important;}
.hero p,.section-subtitle,p,.sub,.small-links,.links,.help{
  color:var(--public-muted) !important;
  line-height:1.6 !important;
}
.hero p{font-size:18px !important;max-width:740px;}
.section{padding:42px 0 !important;}
.section-headline-row{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  margin-bottom:18px;
}

/* Cards and grids */
.card,.hero-card,.panel,.stat-card,.business-card,.worker-card,.feature,.benefit,.login-shell .card,.brand-panel{
  background:linear-gradient(180deg,var(--public-card),var(--public-card-2)) !important;
  color:var(--public-text) !important;
  border:1px solid var(--public-border) !important;
  border-radius:24px !important;
  box-shadow:0 22px 55px rgba(0,0,0,.30) !important;
}
.card,.hero-card,.panel,.stat-card,.business-card,.worker-card,.feature,.benefit{padding:22px !important;}
.card h3,.hero-card h3,.panel h2,.business-name,.worker-name{color:var(--public-text) !important;}
.grid{display:grid !important;gap:18px !important;}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
.grid.three{grid-template-columns:repeat(3,minmax(0,1fr)) !important;}
.grid.four{grid-template-columns:repeat(4,minmax(0,1fr)) !important;}
.stats{display:grid !important;grid-template-columns:repeat(4,minmax(0,1fr)) !important;gap:16px !important;}
.business-grid,.worker-grid{display:grid !important;grid-template-columns:repeat(2,minmax(0,1fr)) !important;gap:18px !important;}

/* Pricing cards on homepage */
.home-pricing-section{padding-top:18px !important;}
.pricing-grid{align-items:stretch !important;}
.price-card{display:flex !important;flex-direction:column !important;gap:14px !important;}
.price-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;}
.price-badge{display:inline-flex;align-items:center;justify-content:center;background:rgba(255,184,77,.16);color:#ffd98d;border:1px solid rgba(255,184,77,.34);border-radius:999px;padding:6px 10px;font-size:12px;font-weight:950;white-space:nowrap;}
.price-wrap{display:flex;align-items:flex-end;gap:8px;flex-wrap:wrap;margin:2px 0 6px;}
.old-price{color:#93a4bc;text-decoration:line-through;font-size:18px;font-weight:850;}
.sale-price{color:#fff;font-size:46px;line-height:.95;font-weight:950;letter-spacing:-1px;}
.per-month{color:var(--public-muted);font-weight:800;margin-bottom:5px;}
.plan-details{background:rgba(8,15,31,.42);border:1px solid rgba(255,255,255,.10);border-radius:18px;padding:12px 14px;}
.plan-details summary{cursor:pointer;color:#ffd98d;font-weight:950;list-style:none;}
.plan-details summary::-webkit-details-marker{display:none;}
.plan-details summary::after{content:' +';float:right;color:var(--public-blue);}
.plan-details[open] summary::after{content:' −';}
.plan-details ul{margin:12px 0 0;padding-left:20px;color:var(--public-muted);line-height:1.85;}
.price-card .btn{margin-top:auto;width:100%;}

/* Forms */
.form-page{min-height:calc(100vh - 74px);display:flex !important;align-items:center !important;justify-content:center !important;padding:42px 16px !important;}
.form-box{width:min(100%,460px) !important;background:linear-gradient(180deg,var(--public-card),var(--public-card-2)) !important;border:1px solid var(--public-border) !important;border-radius:24px !important;box-shadow:0 22px 55px rgba(0,0,0,.30) !important;padding:28px !important;color:var(--public-text) !important;}
.form-box h1{font-size:34px !important;}
label{color:var(--public-text) !important;font-weight:900 !important;}
input,select,textarea{
  background:rgba(8,15,31,.56) !important;
  color:var(--public-text) !important;
  border:1px solid rgba(148,163,184,.34) !important;
  border-radius:14px !important;
  padding:13px 14px !important;
}
input::placeholder,textarea::placeholder{color:#94a3b8 !important;}

.badge,.badge-featured,.badge-verified,.badge-category,.service-tag,.tag{
  border-radius:999px !important;
  border:1px solid rgba(56,189,248,.22) !important;
  background:rgba(56,189,248,.12) !important;
  color:#dbeafe !important;
  font-weight:850 !important;
}
.footer{color:#9fb0c5 !important;text-align:center !important;padding:34px 16px !important;border-top:1px solid rgba(255,255,255,.09) !important;margin-top:30px !important;}

/* Mobile: public pages only */
@media(max-width:900px){
  .nav,.header-inner,.top{width:calc(100% - 24px) !important;min-height:auto !important;padding:14px 0 !important;align-items:flex-start !important;flex-direction:column !important;gap:12px !important;}
  .logo,.brand,.top .brand{font-size:27px !important;}
  .nav-links,.site-header .nav,.top-links{width:100% !important;display:grid !important;grid-template-columns:1fr 1fr !important;gap:8px !important;}
  .nav-links a,.site-header .nav a,.top-links a{width:100% !important;text-align:center !important;background:rgba(255,255,255,.055) !important;border:1px solid rgba(255,255,255,.08) !important;padding:11px 10px !important;font-size:14px !important;}
  .nav-links a.btn{grid-column:1 / -1;}
  .hero{padding:38px 0 22px !important;}
  .hero-inner{grid-template-columns:1fr !important;gap:18px !important;}
  .hero h1,.section-title,h1{font-size:34px !important;letter-spacing:-.7px !important;}
  .hero p{font-size:16px !important;}
  .section,.container,.hero-inner{width:calc(100% - 24px) !important;}
  .section{padding:28px 0 !important;}
  .section-headline-row{align-items:stretch;flex-direction:column;}
  .grid,.grid.two,.grid.three,.grid.four,.stats,.business-grid,.worker-grid{grid-template-columns:1fr !important;}
  .card,.hero-card,.panel,.stat-card,.business-card,.worker-card{border-radius:20px !important;padding:18px !important;}
  .sale-price{font-size:40px;}
  .form-page{padding:24px 12px !important;align-items:flex-start !important;}
  .form-box{padding:22px !important;border-radius:20px !important;}
  .form-box h1{font-size:30px !important;}
  .filters,.lead-grid,.form-grid{grid-template-columns:1fr !important;display:grid !important;gap:12px !important;}
  .business-actions,.worker-actions,.hero-actions{display:grid !important;grid-template-columns:1fr !important;gap:10px !important;}
  .btn,.button,a.btn,a.button,button.btn{width:100%;}
}


/* Controlled public update: desktop + mobile menu */
.public-menu-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  width:46px;
  height:42px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.08);
  color:#fff7e6;
  font-size:24px;
  font-weight:950;
  cursor:pointer;
}
.nav .logo, .header-inner .brand{margin-right:auto;}

@media(min-width:901px){
  .nav-links,.site-header .nav,.top-links{display:flex !important;}
}

@media(max-width:900px){
  .nav,.header-inner,.top{
    position:relative !important;
    flex-direction:row !important;
    align-items:center !important;
    justify-content:space-between !important;
    flex-wrap:wrap !important;
    padding:14px 0 !important;
  }
  .public-menu-toggle{display:inline-flex !important;}
  .nav-links,
  .site-header .nav,
  .top-links{
    display:none !important;
    width:100% !important;
    grid-template-columns:1fr !important;
    gap:8px !important;
    padding-top:10px !important;
  }
  .nav-links.is-open,
  .site-header .nav.is-open,
  .top-links.is-open{
    display:grid !important;
  }
  .nav-links a,
  .site-header .nav a,
  .top-links a{
    width:100% !important;
    text-align:left !important;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    padding:13px 14px !important;
    border-radius:16px !important;
  }
  .nav-links a.btn,
  .top-links a.btn{justify-content:center !important;text-align:center !important;}
}


/* Controlled fix: desktop uses normal tabs, mobile only uses 3-line menu */
@media (min-width:901px){
  .public-menu-toggle{display:none !important; visibility:hidden !important;}
  .nav,.header-inner,.top{flex-direction:row !important; align-items:center !important;}
  .nav-links,.site-header .nav,.top-links{display:flex !important; width:auto !important; padding-top:0 !important;}
}
@media (max-width:900px){
  .public-menu-toggle{display:inline-flex !important; visibility:visible !important;}
}


/* Homepage top summary card - replaces video */
.public-hero-summary-card{
  background:linear-gradient(180deg,var(--public-card),var(--public-card-2)) !important;
  color:var(--public-text) !important;
  border:1px solid var(--public-border) !important;
  border-radius:28px !important;
  box-shadow:0 24px 60px rgba(0,0,0,.36) !important;
  padding:22px !important;
}
.public-hero-summary-card h3{
  margin:12px 0 10px !important;
  font-size:28px !important;
  line-height:1.08 !important;
  color:#fff !important;
}
.public-hero-summary-card p{
  color:var(--public-muted) !important;
  font-weight:750 !important;
  line-height:1.6 !important;
  margin:0 0 16px !important;
}
.public-hero-mini-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.public-hero-mini-grid div{
  padding:13px;
  border-radius:16px;
  background:rgba(8,15,31,.48);
  border:1px solid rgba(255,255,255,.10);
}
.public-hero-mini-grid strong{
  display:block;
  color:#ffd98d;
  font-size:14px;
  margin-bottom:5px;
}
.public-hero-mini-grid span{
  display:block;
  color:#dce7f5;
  font-size:13px;
  line-height:1.35;
  font-weight:750;
}
@media(max-width:900px){
  .public-hero-summary-card{border-radius:22px !important;padding:17px !important;}
  .public-hero-summary-card h3{font-size:22px !important;}
  .public-hero-mini-grid{grid-template-columns:1fr;}
}

/* Fix homepage category cards so desktop cards stay wide, not skinny columns */
.public-category-grid{
  display:grid !important;
  grid-template-columns:repeat(4,minmax(210px,1fr)) !important;
  gap:18px !important;
  width:100% !important;
}
.public-category-card{
  min-width:0 !important;
  width:auto !important;
  min-height:150px !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  overflow-wrap:normal !important;
  word-break:normal !important;
  hyphens:none !important;
}
.public-category-card h3{
  white-space:normal !important;
  word-break:normal !important;
  overflow-wrap:normal !important;
  line-height:1.12 !important;
  margin:0 0 10px !important;
}
.public-category-card p{
  white-space:normal !important;
  word-break:normal !important;
  overflow-wrap:normal !important;
  line-height:1.5 !important;
  margin:0 !important;
}
/* Safety for older uploaded homepage markup that had a grid nested inside another grid */
.section > .grid.four > .grid.three{
  grid-column:1 / -1 !important;
  display:grid !important;
  grid-template-columns:repeat(4,minmax(210px,1fr)) !important;
  width:100% !important;
}
@media(max-width:1100px){
  .public-category-grid,
  .section > .grid.four > .grid.three{
    grid-template-columns:repeat(2,minmax(220px,1fr)) !important;
  }
}
@media(max-width:650px){
  .public-category-grid,
  .section > .grid.four > .grid.three{
    grid-template-columns:1fr !important;
  }
  .public-category-card{min-height:auto !important;}
}
