/* ===========================================================
   AuditReady CISA — Landing page system
   Built on top of style.css's shared tokens (--primary navy,
   --accent red, fonts, radii, shadows). This file adds only
   landing-page-specific layout and components.
   =========================================================== */

*{box-sizing:border-box;}
html,body{margin:0; padding:0;}
body.landing-body{
  background:var(--bg); color:var(--text); font-family:var(--font-arabic);
  -webkit-font-smoothing:antialiased;
}
body.landing-body[dir="ltr"]{font-family:var(--font-display);}
img,svg{display:block; max-width:100%;}
a{color:inherit;}
.container{max-width:1180px; margin:0 auto; padding:0 24px;}

/* ---------- Signature motif: the 5-domain dot strip ----------
   AuditReady's question bank is organized into exactly 5 CISA
   domains. This row of 5 marks (one slightly larger, accent-colored,
   to suggest "you are here" / progress) recurs across the logo,
   section dividers, and the how-it-works connector — a structural
   device that encodes something true about the product rather than
   decorating it. */
.domain-dots{display:flex; align-items:center; gap:6px;}
.domain-dots i{width:6px; height:6px; border-radius:50%; background:var(--border); display:block;}
.domain-dots i:nth-child(3){width:8px; height:8px; background:var(--accent);}
.section-divider{display:flex; align-items:center; justify-content:center; gap:6px; margin:0 0 18px;}
.section-divider i{width:6px; height:6px; border-radius:50%; background:var(--border);}
.section-divider i:nth-child(3){width:9px; height:9px; background:var(--accent);}

/* ---------- Logo ---------- */
.lg-logo{display:flex; align-items:center; gap:10px; text-decoration:none;}
.lg-logo-mark{color:#fff; flex-shrink:0;}
.lg-logo-mark.is-dark{color:var(--primary);}
.lg-logo-word{font-family:var(--font-display); font-weight:800; font-size:18px; letter-spacing:-.01em; color:inherit;}
.lg-logo-word b{color:var(--accent); font-weight:800;}

/* ---------- Nav ---------- */
.lg-nav{
  position:sticky; top:0; z-index:50; background:rgba(13,27,61,.92); backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.lg-nav-inner{display:flex; align-items:center; justify-content:space-between; height:68px; gap:20px;}
.lg-nav-links{display:flex; align-items:center; gap:28px; color:#fff;}
.lg-nav-links a{font-size:14px; font-weight:600; opacity:.85; text-decoration:none;}
.lg-nav-links a:hover{opacity:1;}
.lg-nav-right{display:flex; align-items:center; gap:10px;}
.lg-lang-switch{display:flex; gap:4px; background:rgba(255,255,255,.08); border-radius:999px; padding:3px;}
.lg-lang-switch a{
  padding:6px 13px; border-radius:999px; font-size:12.5px; font-weight:700; color:#fff; opacity:.6; text-decoration:none;
}
.lg-lang-switch a.is-active{background:#fff; color:var(--primary); opacity:1;}
.lg-btn-login{
  padding:9px 18px; border-radius:999px; background:#fff; color:var(--primary); font-weight:700;
  font-size:13.5px; text-decoration:none; white-space:nowrap;
}
.lg-burger{display:none; width:38px; height:38px; border-radius:9px; border:1px solid rgba(255,255,255,.2); background:transparent; color:#fff; align-items:center; justify-content:center; cursor:pointer;}
.lg-mobile-menu{display:none;}

/* ---------- Hero ---------- */
.lg-hero{
  background:linear-gradient(165deg, var(--primary) 0%, #14254F 55%, var(--primary) 100%);
  color:#fff; padding:64px 0 0; position:relative; overflow:hidden;
}
.lg-hero-inner{
  display:grid; grid-template-columns:1.15fr .85fr; gap:48px; align-items:center;
  padding-bottom:64px; position:relative; z-index:2;
}
.lg-hero-eyebrow{
  display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.16); padding:6px 14px; border-radius:999px;
  font-size:12.5px; font-weight:700; color:#D7DCEA; margin-bottom:20px;
}
.lg-hero h1{
  font-family:var(--font-display); font-weight:800; font-size:44px; line-height:1.12; margin:0 0 14px; letter-spacing:-.015em;
}
.lg-hero h1 b{color:var(--accent);}
.lg-hero-headline{font-size:19px; font-weight:600; color:#E8EAF1; margin:0 0 14px;}
.lg-hero-desc{font-size:15.5px; line-height:1.85; color:#B9BFD2; max-width:520px; margin:0 0 30px;}
.lg-hero-ctas{display:flex; flex-wrap:wrap; gap:12px;}
.lg-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 24px; border-radius:11px; font-size:14.5px; font-weight:700;
  text-decoration:none; border:1.5px solid transparent; cursor:pointer; transition:.15s transform, .15s box-shadow;
}
.lg-btn:active{transform:scale(.98);}
.lg-btn-primary{background:var(--accent); color:#fff; box-shadow:0 10px 24px rgba(227,24,55,.28);}
.lg-btn-primary:hover{background:var(--accent-dark);}
.lg-btn-outline{background:transparent; color:#fff; border-color:rgba(255,255,255,.35);}
.lg-btn-outline:hover{border-color:#fff; background:rgba(255,255,255,.06);}
.lg-btn-whatsapp{background:#fff; color:#0D1B3D;}
.lg-btn-whatsapp:hover{background:#E7E9F0;}

/* Readiness-ring visual: ties the hero directly to the product's
   actual "measure your readiness" feature instead of generic art. */
.lg-hero-visual{position:relative; display:flex; align-items:center; justify-content:center;}
.lg-ring-card{
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); border-radius:24px;
  padding:30px; width:100%; max-width:330px; backdrop-filter:blur(6px);
}
.lg-ring-wrap{position:relative; width:180px; height:180px; margin:0 auto 18px;}
.lg-ring-center{position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center;}
.lg-ring-pct{font-family:var(--font-mono); font-size:32px; font-weight:700; color:#fff;}
.lg-ring-label{font-size:11.5px; color:#B9BFD2; margin-top:2px;}
.lg-ring-domains{display:flex; flex-direction:column; gap:9px;}
.lg-ring-domain-row{display:flex; align-items:center; gap:10px; font-size:12px; color:#D7DCEA;}
.lg-ring-domain-bar{flex:1; height:5px; border-radius:99px; background:rgba(255,255,255,.12); overflow:hidden;}
.lg-ring-domain-fill{height:100%; border-radius:99px; background:var(--accent);}
.lg-ring-domain-name{width:96px; flex-shrink:0; font-weight:600;}

@media (max-width:980px){
  .lg-hero-inner{grid-template-columns:1fr; padding-bottom:48px;}
  .lg-hero-visual{order:-1;}
  .lg-ring-card{margin:0 auto;}
  .lg-hero h1{font-size:34px;}
}

/* ---------- Generic section scaffolding ---------- */
.lg-section{padding:76px 0;}
.lg-section-alt{background:var(--panel);}
.lg-section-head{text-align:center; max-width:620px; margin:0 auto 44px;}
.lg-eyebrow{font-size:12.5px; font-weight:800; letter-spacing:.04em; color:var(--accent); text-transform:uppercase; margin:0 0 10px;}
[dir="rtl"] .lg-eyebrow{letter-spacing:0;}
.lg-section-title{font-family:var(--font-display); font-size:30px; font-weight:800; color:var(--primary); margin:0 0 12px; letter-spacing:-.01em;}
.lg-section-sub{font-size:15px; color:var(--text-dim); line-height:1.8; margin:0;}

/* ---------- Features ---------- */
.lg-features-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
.lg-feature-card{
  background:#fff; border:1px solid var(--border); border-radius:18px; padding:26px;
  transition:.18s border-color, .18s transform, .18s box-shadow;
}
.lg-feature-card:hover{border-color:var(--primary); transform:translateY(-2px); box-shadow:var(--shadow);}
.lg-feature-icon{
  width:44px; height:44px; border-radius:12px; background:var(--primary-tint); color:var(--primary);
  display:flex; align-items:center; justify-content:center; margin-bottom:16px;
}
.lg-feature-title{font-size:15.5px; font-weight:800; color:var(--text); margin:0 0 7px;}
.lg-feature-desc{font-size:13.5px; line-height:1.75; color:var(--text-dim); margin:0;}

@media (max-width:900px){.lg-features-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:600px){.lg-features-grid{grid-template-columns:1fr;}}

/* ---------- How it works ---------- */
.lg-steps{display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:0; counter-reset:step;}
.lg-step{position:relative; padding:0 14px; text-align:center;}
.lg-step-num{
  width:38px; height:38px; border-radius:50%; background:var(--primary); color:#fff;
  display:flex; align-items:center; justify-content:center; font-family:var(--font-mono); font-weight:700;
  font-size:14px; margin:0 auto 14px; position:relative; z-index:2;
}
.lg-step:nth-child(3) .lg-step-num{background:var(--accent);}
.lg-step-connector{
  position:absolute; top:19px; inset-inline-start:50%; width:100%; height:2px; background:var(--border); z-index:1;
}
.lg-step:last-child .lg-step-connector{display:none;}
.lg-step-title{font-size:13.5px; font-weight:700; color:var(--text); margin:0 0 4px;}
.lg-step-desc{font-size:12px; color:var(--text-dim); margin:0; line-height:1.6;}

@media (max-width:840px){
  .lg-steps{grid-template-columns:1fr; gap:22px;}
  .lg-step{display:flex; align-items:center; gap:14px; text-align:start; padding:0;}
  .lg-step-num{margin:0;}
  .lg-step-connector{display:none;}
}

/* ---------- Pricing ---------- */
.lg-pricing-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px;}
.lg-price-card{
  background:#fff; border:1.5px solid var(--border); border-radius:18px; padding:26px 22px;
  display:flex; flex-direction:column; position:relative;
}
.lg-price-card.is-featured{border-color:var(--accent); box-shadow:0 14px 30px rgba(227,24,55,.12);}
.lg-price-badge{
  position:absolute; top:-12px; inset-inline-start:22px; background:var(--accent); color:#fff;
  font-size:11px; font-weight:800; padding:4px 12px; border-radius:999px;
}
.lg-price-name{font-size:15px; font-weight:800; color:var(--primary); margin:0 0 6px;}
.lg-price-desc{font-size:12.5px; color:var(--text-dim); line-height:1.6; margin:0 0 12px;}
.lg-price-value{font-family:var(--font-mono); font-size:18px; font-weight:700; color:var(--text); margin:0 0 4px;}
.lg-price-note{font-size:12px; color:var(--text-dim); margin:0 0 18px;}
.lg-price-features{list-style:none; margin:0 0 22px; padding:0; display:flex; flex-direction:column; gap:9px; flex:1;}
.lg-price-features li{font-size:13px; color:var(--text); display:flex; gap:8px; align-items:flex-start; line-height:1.6;}
.lg-price-features li svg{flex-shrink:0; margin-top:2px; color:var(--success);}
.lg-price-cta{
  display:block; text-align:center; padding:11px; border-radius:10px; font-size:13.5px; font-weight:700;
  text-decoration:none; border:1.5px solid var(--primary); color:var(--primary);
}
.lg-price-card.is-featured .lg-price-cta{background:var(--accent); border-color:var(--accent); color:#fff;}
.lg-price-cta:hover{opacity:.88;}

@media (max-width:980px){.lg-pricing-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.lg-pricing-grid{grid-template-columns:1fr;}}

/* ---------- Account protection ---------- */
.lg-protect{
  display:grid; grid-template-columns:auto 1fr; gap:28px; align-items:center;
  background:var(--primary); color:#fff; border-radius:24px; padding:38px;
}
.lg-protect-icon{
  width:64px; height:64px; border-radius:16px; background:rgba(255,255,255,.1); color:#fff;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.lg-protect-title{font-size:17px; font-weight:800; margin:0 0 8px;}
.lg-protect-text{font-size:14px; line-height:1.85; color:#C9CEDE; margin:0;}
@media (max-width:640px){.lg-protect{grid-template-columns:1fr; text-align:center;} .lg-protect-icon{margin:0 auto;}}

/* ---------- Disclaimer ---------- */
.lg-disclaimer{
  border:1.5px dashed var(--border); border-radius:16px; padding:20px 24px; display:flex; gap:14px; align-items:flex-start;
  background:var(--panel);
}
.lg-disclaimer svg{flex-shrink:0; color:var(--text-dim); margin-top:2px;}
.lg-disclaimer p{font-size:13px; line-height:1.85; color:var(--text-dim); margin:0;}

/* ---------- FAQ ---------- */
.lg-faq-list{max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:10px;}
.lg-faq-item{border:1px solid var(--border); border-radius:14px; background:#fff; overflow:hidden;}
.lg-faq-q{
  width:100%; text-align:inherit; background:none; border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:17px 20px; font-size:14.5px; font-weight:700; color:var(--text); font-family:inherit;
}
.lg-faq-q .chev{flex-shrink:0; transition:transform .2s ease; color:var(--text-dim);}
.lg-faq-item.is-open .lg-faq-q .chev{transform:rotate(180deg);}
.lg-faq-a{max-height:0; overflow:hidden; transition:max-height .25s ease;}
.lg-faq-a-inner{padding:0 20px 18px; font-size:13.5px; line-height:1.85; color:var(--text-dim);}
.lg-faq-item.is-open .lg-faq-a{max-height:240px;}

/* ---------- Footer ---------- */
.lg-footer{background:var(--primary); color:#C9CEDE; padding:48px 0 28px;}
.lg-footer-top{display:flex; flex-wrap:wrap; gap:24px; align-items:center; justify-content:space-between; padding-bottom:28px; border-bottom:1px solid rgba(255,255,255,.1); margin-bottom:20px;}
.lg-footer-links{display:flex; gap:22px; flex-wrap:wrap;}
.lg-footer-links a{font-size:13px; text-decoration:none; color:#C9CEDE; opacity:.85;}
.lg-footer-links a:hover{opacity:1;}
.lg-footer-disclaimer{font-size:12px; line-height:1.8; color:#9CA3B8; max-width:760px; margin:0 0 14px;}
.lg-footer-bottom{display:flex; flex-wrap:wrap; justify-content:space-between; gap:10px; font-size:12px; color:#8B91A8;}

/* ---------- Section heading responsiveness ---------- */
@media (max-width:640px){
  .lg-section{padding:54px 0;}
  .lg-section-title{font-size:24px;}
  .lg-hero h1{font-size:28px;}
  .lg-hero-headline{font-size:16px;}
  .container{padding:0 18px;}
}

/* ---------- Mobile nav ---------- */
@media (max-width:780px){
  .lg-nav-links{display:none;}
  .lg-burger{display:flex;}
  .lg-mobile-menu{
    display:none; flex-direction:column; gap:2px; background:var(--primary); border-top:1px solid rgba(255,255,255,.1);
    padding:10px 0;
  }
  .lg-mobile-menu.is-open{display:flex;}
  .lg-mobile-menu a{padding:13px 24px; color:#fff; text-decoration:none; font-size:14.5px; font-weight:600;}
  .lg-nav-right .lg-btn-login{display:none;}
}
