@import url("/assets/css/fora.css");

/* host-specific tweaks */

:root{
  --accent: rgba(160, 210, 255, .92);
  --accent-soft: rgba(160, 210, 255, .18);
}

.loggedIn { display:none; }
.loggedOut { display:block; }
body.isLogged .loggedIn { display:block; }
body.isLogged .loggedOut { display:none; }


.brandSub strong{
  letter-spacing: .08em;
}

.viewHost{
  overflow: auto;
  padding: 18px;
}

.pageHead{
  margin-bottom: 18px;
}

.pageHead h2{
  margin: 0 0 6px 0;
}

.pageHead p{
  margin: 0;
  opacity: .85;
}

.dashGrid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.dashCard,
.stackCard,
.miniCard,
.formCard{
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: var(--shadow-sm);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  padding: 16px;
}

.stackList,
.adminList,
.miniList{
  display: grid;
  gap: 12px;
}

.stackCard{
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 16px;
}

.stackCardMain h3,
.dashCard h3,
.miniCard h4{
  margin-top: 0;
  margin-bottom: 8px;
}

.inlineMsg{
  margin-top: 10px;
  min-height: 20px;
  opacity: .88;
}

label{
  display: block;
  margin-bottom: 12px;
}

label span{
  display: block;
  margin-bottom: 6px;
  font-size: .95rem;
  opacity: .88;
}

input,
textarea,
select{
  width: 100%;
  border-radius: 12px;
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  color: var(--input-text);
  padding: 12px 14px;
  outline: none;
}

button{
  border: 1px solid var(--btn-border);
  background: var(--btn-bg);
  color: inherit;
  border-radius: 12px;
  padding: 10px 14px;
  cursor: pointer;
}

button:hover{
  background: var(--btn-bg-hover);
}

.authSection{
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
}

#auth-dropin{
  width: 100%;
  max-width: 460px;
}

.authCard{
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 22px;
  box-shadow: var(--shadow-lg);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  padding: 24px;
}

.authTitle{
  margin-top: 0;
}

.adminRow{
  display: flex;
  gap: 16px;
  justify-content: space-between;
  align-items: center;
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: var(--shadow-sm);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  padding: 14px 16px;
}

.adminRowMain h3{
  margin: 0 0 6px 0;
}

.formCard{
  max-width: 760px;
}

.supportGrid{
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 14px;
}

.customerDetailPanel{
  position: fixed;
  top: 0;
  right: -720px;
  width: 680px;
  max-width: calc(100vw - 30px);
  height: 100vh;
  z-index: 9999;
  background: color-mix(in srgb, var(--glass-strong) 100%, rgba(0,0,0,.18));
  border-left: 1px solid var(--border);
  box-shadow: -8px 0 30px rgba(0,0,0,.22);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  transition: right .25s ease;
  overflow-y: auto;
}

.customerDetailPanel.open{
  right: 0;
}

.detailPanelInner{
  padding: 22px;
}

.detailHead{
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  margin-bottom: 24px;
}

.detailSection{
  margin-bottom: 24px;
}

.detailActions{
  display: flex;
  align-items: center;
  gap: 12px;
}

.checkList{
  display: grid;
  gap: 12px;
}

.checkRow{
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.checkDot{
  width: 24px;
  height: 24px;
  border: 1px solid var(--border);
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 24px;
}

.checkRow.done .checkDot{
  border-color: var(--accent);
  color: var(--accent);
}

@media (max-width: 980px){
  .dashGrid,
  .supportGrid,
  .stackCard{
    grid-template-columns: 1fr;
  }
}

#alertDiv{
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: 10020;
  min-width: 280px;
  max-width: 440px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: var(--glass-strong);
  box-shadow: var(--shadow-md);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  display: none;
  gap: 12px;
  align-items: center;
}

#alertDiv.open{
  display: flex;
}

#alertDiv[data-kind="error"]{
  border-color: rgba(255,120,120,.35);
}

#alertDiv[data-kind="success"]{
  border-color: rgba(120,255,170,.28);
}

#closeAlert{
  margin-left: auto;
}

.navItem.active{
  border-color: color-mix(in srgb, var(--accent) 28%, rgba(0,0,0,.10));
  box-shadow:
    0 10px 24px rgba(0,0,0,.10),
    0 0 0 4px color-mix(in srgb, var(--accent-soft) 65%, transparent);
}

.inlineMsg.is-error{
  color: #ffb7b7;
}

.inlineMsg.is-success{
  color: #c5ffd8;
}

#topRightNav{
  position: fixed;
  top: 64px;
  right: 18px;
  width: 280px;
  z-index: 9990;
  display: none;
}

#topRightNav.open{
  display: block;
}

#topRightNav-inset{
  background: var(--glass-strong);
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: var(--shadow-md);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  padding: 14px;
}

.authSection,
.backMat {
    background: url('/images/fabric-host-bg.jpg');
    background-size: cover;
    background-position: center 30%;
}

.hostOver {
    position:absolute;
    top:0; left:0; right: 0; bottom:0;
    background: #e9cfb761;
}

#auth-dropin {
    transform: translateX(0%);
    width: 100%;
    max-width: 100%;
    background:#e9cfb761;
}

.logo {
    position: absolute;
    z-index: 999999;
    width: 200px;
    left: 23px;
    top: 17px;
}

.logo img {
    width:100%;
}

#dashboard.layer-personal .brandMark, 
#dashboard.layer-org .brandMark,
#dashboard.layer-account .brandMark, 
#dashboard.layer-settings .brandMark {
    border-right: 0;
    box-shadow: none;
    width: 100%;
    filter: none;
}

#dashboard.layer-personal .brandMark img, 
#dashboard.layer-org .brandMark img, 
#dashboard.layer-account .brandMark img, 
#dashboard.layer-settings .brandMark img {
    filter: brightness(1);
}

.welcomeOnlyGrid{
  display: block;
  padding: 20px;
}

.welcomeShell{
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  gap: 18px;
}

.welcomeHero{
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 14px;
  align-items: start;
}

.welcomeHero.single{
  grid-template-columns: 1fr;
}

.welcomeCard{
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 22px;
  box-shadow: var(--shadow-sm);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  padding: 20px;
}

.welcomeHeroMain{
  display: flex;
  gap: 18px;
  align-items: flex-start;
  min-height: 180px;
}

.welcomeIcon{
  width: 54px;
  height: 54px;
  border-radius: 999px;
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  flex: 0 0 54px;
}

.eyebrow{
  margin: 0 0 8px 0;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .82rem;
  opacity: .72;
}

.welcomeHeroMain h1{
  margin: 0 0 10px 0;
  font-size: clamp(2rem, 4vw, 3.5rem);
  line-height: .95;
}

.welcomeHeroMain p,
.welcomeSummary p{
  color: var(--muted);
}

.welcomeSummary h3{
  margin-top: 0;
}

.welcomeAsideNote{
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--border-soft);
}

.welcomeFlow{
  display: grid;
  gap: 14px;
}

.welcomeProgress{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

.welcomeProgressStep{
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: var(--shadow-sm);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  padding: 12px 14px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.welcomeProgressStep span{
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid var(--border);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 28px;
}

.welcomeProgressStep p{
  margin: 0;
  font-weight: 600;
}

.welcomeProgressStep.active{
  border-color: color-mix(in srgb, var(--accent) 30%, var(--border));
}

.welcomeProgressStep.done span{
  border-color: var(--accent);
  color: var(--accent);
}

.welcomeStepCard{
  min-height: 420px;
}

.welcomeStepInner{
  max-width: 760px;
}

.welcomeStepInner h2{
  margin-top: 0;
}

.welcomeStepInner label{
  display: block;
  margin-bottom: 14px;
}

.welcomeStepInner label span{
  display: block;
  margin-bottom: 6px;
  opacity: .88;
}

.welcomeStepInner input,
.welcomeStepInner select,
.welcomeStepInner textarea{
  width: 100%;
  box-sizing: border-box;
}

.welcomeNav{
  margin-top: 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.ghostBtn{
  background: transparent;
}

@media (max-width: 980px){
  .welcomeHero,
  .welcomeProgress{
    grid-template-columns: 1fr;
  }
}

.checkoutPageWrap{
  max-width: 1240px;
  margin: 0 auto;
  padding: 20px;
}

.checkoutTopBar{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  margin-bottom: 18px;
  padding: 14px 18px;
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 20px;
  box-shadow: var(--shadow-sm);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
}

.checkoutBrand{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: inherit;
}

.checkoutBrand img{
  width: 160px;
  height: 44px;
  object-fit: contain;
}

.checkoutTopNav{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.checkoutTopNav a{
  text-decoration: none;
  border: 1px solid var(--btn-border);
  background: var(--btn-bg);
  border-radius: 999px;
  padding: 10px 14px;
}

.checkoutShell{
  display: grid;
  gap: 16px;
}

.checkoutGrid{
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 16px;
  align-items: start;
  color: #000;
}

.checkoutCard{
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 22px;
  box-shadow: var(--shadow-sm);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  padding: 20px;
}

.checkoutLeft,
.checkoutRight{
  min-width: 0;
}

.checkoutPlanSub{
  color: var(--muted);
  margin-bottom: 18px;
}

.checkoutPriceRow{
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: end;
  margin-bottom: 18px;
}

.checkoutPriceMain{
  display: flex;
  align-items: end;
  gap: 10px;
  flex-wrap: wrap;
}

.checkoutPriceMain strong{
  font-size: 2.4rem;
  line-height: 1;
}

.checkoutCompareAt{
  opacity: .74;
}

.checkoutCadenceSwitch{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.checkoutCadenceBtn{
  border: 1px solid var(--btn-border);
  background: var(--btn-bg);
  color: inherit;
  border-radius: 999px;
  padding: 10px 14px;
  cursor: pointer;
}

.checkoutCadenceBtn.active{
  border-color: color-mix(in srgb, var(--accent) 30%, var(--border));
  box-shadow:
    0 10px 24px rgba(0,0,0,.10),
    0 0 0 4px color-mix(in srgb, var(--accent-soft) 65%, transparent);
}

.checkoutFeatures{
  display: grid;
  gap: 8px;
  margin-bottom: 18px;
}

.checkoutFeatures p{
  margin: 0;
  padding-left: 18px;
  position: relative;
}

.checkoutFeatures p::before{
  content: "•";
  position: absolute;
  left: 0;
  opacity: .7;
}

.checkoutComparePlans{
  margin-top: 12px;
}

.checkoutActions{
  margin-top: 18px;
}

.planCtaWrap{
  margin-top: 16px;
}

.planChooseBtn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: inherit;
  border: 1px solid var(--btn-border);
  background: var(--btn-bg);
  border-radius: 14px;
  padding: 12px 16px;
}

@media (max-width: 980px){
  .checkoutGrid{
    grid-template-columns: 1fr;
  }

  .checkoutTopBar{
    flex-direction: column;
    align-items: stretch;
  }
}

/* -----------------------------
   Shared section structure
----------------------------- */
.infoSection {
  position: relative;
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 120px 40px;
  box-sizing: border-box;
}

.sectionAnchor {
  position: absolute;
  top: -120px;
  left: 0;
  width: 1px;
  height: 1px;
}

.sectionHead {
  max-width: 760px;
  margin: 0 0 40px 0;
}

.sectionHead h2 {
  margin: 0 0 14px 0;
}

.sectionHead p {
  margin: 0;
}

/* -----------------------------
   Grid systems
----------------------------- */
.infoGrid {
  display: grid;
  gap: 24px;
  width: 100%;
}

.infoGrid.threeUp {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.infoGrid.twoUp {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* -----------------------------
   Generic content card
----------------------------- */
.infoCard {
  position: relative;
  width: 100%;
  min-height: 100%;
  box-sizing: border-box;
  padding: 24px;
}

.infoCard h3 {
  margin: 0 0 12px 0;
}

.infoCard p:last-child {
  margin-bottom: 0;
}

.infoNo {
  margin-bottom: 16px;
}

/* -----------------------------
   Split section
----------------------------- */
.splitSection {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
  gap: 30px;
  align-items: start;
}

.splitCol {
  min-width: 0;
}

/* -----------------------------
   FAQ
----------------------------- */
.faqWrap {
  display: grid;
  gap: 18px;
  width: 100%;
}

.faqItem {
  width: 100%;
  box-sizing: border-box;
  padding: 20px 24px;
}

.faqItem h3 {
  margin: 0 0 10px 0;
}

.faqItem p:last-child {
  margin-bottom: 0;
}

/* -----------------------------
   CTA
----------------------------- */
.finalCtaSection {
  padding-bottom: 140px;
}

.ctaRow {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
}

.bigCta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0 22px;
  box-sizing: border-box;
  text-decoration: none;
}

.secondaryCta {
  display: inline-flex;
}

/* -----------------------------
   Contact
----------------------------- */
.contactWrap {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
  width: 100%;
}

.contactBlock {
  min-width: 0;
}

.contactBlock h3 {
  margin: 0 0 10px 0;
}

/* -----------------------------
   Optional spacing helpers
----------------------------- */
#howItWorks {
  margin-top: 40px;
}

#finalCta {
  margin-top: 40px;
}

/* -----------------------------
   Simple tablet collapse
----------------------------- */
@media (max-width: 980px) {
  .infoGrid.threeUp,
  .infoGrid.twoUp,
  .contactWrap,
  .splitSection {
    grid-template-columns: 1fr;
  }

  .infoSection {
    padding: 90px 24px;
  }
}