/* ============================================
   eHostingServer - Consolidated Pages CSS
============================================ */

/* --- 1. FRONT PAGE --- */
.ehs-hero { background: var(--ehs-gradient); position: relative; overflow: hidden; padding: 120px 0 80px; margin-top: -72px; padding-top: 180px; }
.ehs-hero::before { content: ''; position: absolute; top: -40%; right: -10%; width: 600px; height: 600px; background: radial-gradient(circle, rgba(255,107,53,0.12) 0%, transparent 70%); border-radius: 50%; pointer-events: none; }
.ehs-hero::after { content: ''; position: absolute; bottom: -30%; left: -5%; width: 500px; height: 500px; background: radial-gradient(circle, rgba(23,70,162,0.25) 0%, transparent 70%); border-radius: 50%; pointer-events: none; }
.ehs-hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; position: relative; z-index: 2; }
.ehs-hero-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,0.1); backdrop-filter: blur(10px); color: rgba(255,255,255,0.9); padding: 8px 18px; border-radius: var(--ehs-radius-full); font-size: 13px; font-weight: 600; margin-bottom: 24px; border: 1px solid rgba(255,255,255,0.15); }
.ehs-hero-badge svg { color: var(--ehs-accent); }
.ehs-hero h1 { font-size: clamp(32px, 5vw, 52px); font-weight: 800; color: #fff; margin-bottom: 20px; line-height: 1.15; }
.ehs-hero h1 em { font-style: normal; background: var(--ehs-gradient-accent); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.ehs-hero-desc { font-size: 17px; color: rgba(255,255,255,0.75); line-height: 1.7; margin-bottom: 32px; max-width: 520px; }
.ehs-hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 32px; }
.ehs-hero-trust { display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.ehs-hero-trust-item { display: flex; align-items: center; gap: 8px; color: rgba(255,255,255,0.7); font-size: 14px; font-weight: 500; }
.ehs-hero-trust-item svg { color: var(--ehs-success); flex-shrink: 0; }
.ehs-hero-visual { display: flex; justify-content: center; align-items: center; position: relative; }
.ehs-hero-visual::before { content: ''; position: absolute; width: 80%; height: 80%; background: radial-gradient(circle, rgba(255,107,53,0.12) 0%, rgba(23,70,162,0.08) 40%, transparent 70%); border-radius: 50%; pointer-events: none; }
.ehs-hero-visual img { max-width: 110%; height: auto; filter: drop-shadow(0 20px 50px rgba(0,0,0,0.35)); position: relative; z-index: 1; }
.ehs-partner-strip { display: flex; align-items: center; gap: 20px; padding: 20px 0 0; margin-top: 28px; border-top: 1px solid rgba(255,255,255,0.1); flex-wrap: nowrap; overflow-x: auto; }
.ehs-partner-strip img { height: 22px; width: auto; opacity: 0.55; filter: brightness(0) invert(1); transition: var(--ehs-transition); flex-shrink: 0; }
.ehs-partner-strip img:hover { opacity: 1; }
.ehs-products { padding: 90px 0; background: var(--ehs-bg); }
.ehs-products-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.ehs-product-card { background: var(--ehs-white); border-radius: var(--ehs-radius-lg); padding: 36px 28px; text-align: center; transition: var(--ehs-transition); border: 1px solid var(--ehs-border); position: relative; }
.ehs-product-card:hover { transform: translateY(-6px); box-shadow: var(--ehs-shadow-lg); border-color: transparent; }
.ehs-product-card.featured { border-color: var(--ehs-primary); box-shadow: var(--ehs-shadow-md); }
.ehs-product-card.featured::before { content: 'Most Popular'; position: absolute; top: -1px; left: 50%; transform: translateX(-50%); background: var(--ehs-primary); color: #fff; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; padding: 4px 16px; border-radius: 0 0 8px 8px; }
.ehs-product-icon { width: 72px; height: 72px; margin: 0 auto 20px; display: flex; align-items: center; justify-content: center; }
.ehs-product-icon img { max-width: 100%; max-height: 100%; }
.ehs-product-card h3 { font-size: 20px; font-weight: 700; margin-bottom: 10px; }
.ehs-product-card > p { font-size: 14px; color: var(--ehs-text-light); margin-bottom: 24px; line-height: 1.6; min-height: 44px; }
.ehs-product-price { margin-bottom: 20px; }
.ehs-product-price .lbl { font-size: 12px; color: var(--ehs-text-light); text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600; display: block; margin-bottom: 4px; }
.ehs-product-price .amt { font-family: var(--ehs-font-heading); font-size: 28px; font-weight: 700; color: var(--ehs-dark); }
.ehs-product-price .per { font-size: 14px; color: var(--ehs-text-light); font-weight: 500; }
.ehs-stats { padding: 60px 0; background: var(--ehs-white); }
.ehs-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; text-align: center; }
.ehs-stat-number { font-family: var(--ehs-font-heading); font-size: 42px; font-weight: 800; color: var(--ehs-primary); margin-bottom: 6px; line-height: 1; }
.ehs-stat-label { font-size: 15px; color: var(--ehs-text-light); font-weight: 500; }
.ehs-domain { padding: 80px 0; background: var(--ehs-gradient); position: relative; overflow: hidden; }
.ehs-domain::before { content: ''; position: absolute; inset: 0; background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"); pointer-events: none; }
.ehs-domain-inner { position: relative; z-index: 2; text-align: center; }
.ehs-domain h2 { font-size: clamp(28px, 4vw, 38px); font-weight: 800; color: #fff; margin-bottom: 10px; }
.ehs-domain-sub { font-size: 16px; color: rgba(255,255,255,0.7); margin-bottom: 36px; }
.ehs-domain-form { max-width: 680px; margin: 0 auto 28px; display: flex; align-items: center; background: #fff; border-radius: 60px; padding: 5px 5px 5px 8px; box-shadow: var(--ehs-shadow-xl); }
.ehs-domain-form input[type="text"] { flex: 1; border: none; padding: 14px 20px; font-size: 16px; font-family: var(--ehs-font-body); background: transparent; outline: none; color: var(--ehs-dark); border-radius: 60px; height: 52px; }
.ehs-domain-form input[type="text"]::placeholder { color: var(--ehs-text-light); }
.ehs-domain-form button { background: var(--ehs-accent); color: #fff; border: none; padding: 0 36px; height: 52px; border-radius: 60px; font-family: var(--ehs-font-heading); font-weight: 700; font-size: 15px; cursor: pointer; transition: var(--ehs-transition); white-space: nowrap; flex-shrink: 0; }
.ehs-domain-form button:hover { background: var(--ehs-accent-hover); }
.ehs-domain-tlds { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; }
.ehs-domain-tlds span { color: rgba(255,255,255,0.85); font-weight: 600; font-size: 15px; padding: 8px 20px; background: rgba(255,255,255,0.08); border-radius: var(--ehs-radius-full); border: 1px solid rgba(255,255,255,0.1); transition: var(--ehs-transition); }
.ehs-domain-tlds span:hover { background: rgba(255,255,255,0.15); }
.ehs-features { padding: 90px 0; background: var(--ehs-white); }
.ehs-features-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.ehs-feature-card { padding: 32px; border-radius: var(--ehs-radius-lg); background: var(--ehs-bg); border: 1px solid transparent; transition: var(--ehs-transition); }
.ehs-feature-card:hover { background: var(--ehs-white); border-color: var(--ehs-border); box-shadow: var(--ehs-shadow-md); transform: translateY(-3px); }
.ehs-feature-icon { width: 52px; height: 52px; border-radius: 14px; display: flex; align-items: center; justify-content: center; margin-bottom: 20px; background: var(--ehs-primary-light); color: var(--ehs-primary); }
.ehs-feature-card h3 { font-size: 18px; font-weight: 700; margin-bottom: 10px; }
.ehs-feature-card p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.7; margin: 0; }
.ehs-tech { padding: 90px 0; background: var(--ehs-bg); }
.ehs-tech-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.ehs-tech-list { display: flex; flex-direction: column; gap: 20px; }
.ehs-tech-item { display: flex; gap: 20px; padding: 24px; background: var(--ehs-white); border-radius: var(--ehs-radius); border: 1px solid var(--ehs-border); transition: var(--ehs-transition); }
.ehs-tech-item:hover { box-shadow: var(--ehs-shadow-md); border-color: var(--ehs-primary-light); }
.ehs-tech-item-icon { width: 48px; height: 48px; flex-shrink: 0; border-radius: 12px; background: var(--ehs-primary-light); display: flex; align-items: center; justify-content: center; font-size: 22px; }
.ehs-tech-item h4 { font-size: 16px; font-weight: 700; margin-bottom: 4px; }
.ehs-tech-item p { font-size: 13px; color: var(--ehs-text-light); line-height: 1.5; margin: 0; }
.ehs-tech-visual { background: var(--ehs-gradient); border-radius: var(--ehs-radius-lg); padding: 48px; color: #fff; position: relative; overflow: hidden; }
.ehs-tech-visual::before { content: ''; position: absolute; top: -50%; right: -30%; width: 300px; height: 300px; background: radial-gradient(circle, rgba(255,107,53,0.15) 0%, transparent 70%); border-radius: 50%; }
.ehs-tech-visual h3 { font-size: 26px; font-weight: 800; color: #fff; margin-bottom: 16px; position: relative; }
.ehs-tech-visual > p { font-size: 15px; color: rgba(255,255,255,0.75); line-height: 1.7; margin-bottom: 32px; position: relative; }
.ehs-tech-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; position: relative; }
.ehs-tech-stat { background: rgba(255,255,255,0.08); border-radius: var(--ehs-radius); padding: 20px; border: 1px solid rgba(255,255,255,0.1); }
.ehs-tech-stat .num { font-family: var(--ehs-font-heading); font-size: 28px; font-weight: 800; color: #fff; display: block; }
.ehs-tech-stat .lbl-s { font-size: 12px; color: rgba(255,255,255,0.6); text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600; }
.ehs-support { padding: 90px 0; background: var(--ehs-white); }
.ehs-support-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.ehs-support-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.ehs-support-card { background: var(--ehs-bg); border-radius: var(--ehs-radius); padding: 32px 24px; text-align: center; transition: var(--ehs-transition); border: 1px solid transparent; }
.ehs-support-card:hover { border-color: var(--ehs-border); box-shadow: var(--ehs-shadow-md); transform: translateY(-4px); background: var(--ehs-white); }
.ehs-support-card-icon { width: 56px; height: 56px; margin: 0 auto 16px; border-radius: 14px; display: flex; align-items: center; justify-content: center; }
.ehs-support-card-icon svg { width: 28px; height: 28px; }
.ehs-support-card-icon.icon-blue { background: var(--ehs-primary-light); color: var(--ehs-primary); }
.ehs-support-card-icon.icon-orange { background: #FFF0E9; color: var(--ehs-accent); }
.ehs-support-card-icon.icon-green { background: #ECFDF5; color: var(--ehs-success); }
.ehs-support-card-icon.icon-purple { background: #F3EEFF; color: #7C3AED; }
.ehs-support-card h4 { font-size: 16px; font-weight: 700; margin-bottom: 6px; }
.ehs-support-card p { font-size: 13px; color: var(--ehs-text-light); margin: 0; }
.ehs-clients { padding: 70px 0; background: var(--ehs-bg); }
.ehs-clients-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 24px; align-items: center; }
.ehs-client-logo { display: flex; align-items: center; justify-content: center; padding: 20px; background: var(--ehs-white); border-radius: var(--ehs-radius); border: 1px solid var(--ehs-border); transition: var(--ehs-transition); min-height: 80px; }
.ehs-client-logo:hover { box-shadow: var(--ehs-shadow-sm); border-color: var(--ehs-primary-light); }
.ehs-client-logo img { max-width: 120px; max-height: 40px; opacity: 0.5; filter: grayscale(100%); transition: var(--ehs-transition); }
.ehs-client-logo:hover img { opacity: 1; filter: grayscale(0%); }
.ehs-testimonials { padding: 90px 0; background: var(--ehs-white); }
.ehs-testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.ehs-testimonial-card { background: var(--ehs-bg); border-radius: var(--ehs-radius-lg); padding: 36px; transition: var(--ehs-transition); border: 1px solid transparent; }
.ehs-testimonial-card:hover { border-color: var(--ehs-border); box-shadow: var(--ehs-shadow-md); background: var(--ehs-white); }
.ehs-testimonial-text { font-size: 15px; line-height: 1.75; color: var(--ehs-text); margin-bottom: 24px; font-style: italic; }
.ehs-testimonial-author { display: flex; align-items: center; gap: 14px; }
.ehs-testimonial-avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--ehs-primary-light); display: flex; align-items: center; justify-content: center; color: var(--ehs-primary); font-weight: 700; font-size: 16px; flex-shrink: 0; }
.ehs-testimonial-name { font-family: var(--ehs-font-heading); font-weight: 700; font-size: 15px; color: var(--ehs-dark); }
.ehs-cta { padding: 90px 0; background: var(--ehs-bg); }
.ehs-cta-box { background: var(--ehs-gradient); border-radius: var(--ehs-radius-lg); padding: 64px; text-align: center; position: relative; overflow: hidden; }
.ehs-cta-box::before { content: ''; position: absolute; top: -50%; left: -20%; width: 400px; height: 400px; background: radial-gradient(circle, rgba(255,107,53,0.15) 0%, transparent 70%); border-radius: 50%; }
.ehs-cta-box h2 { font-size: clamp(28px, 4vw, 38px); font-weight: 800; color: #fff; margin-bottom: 16px; position: relative; z-index: 2; }
.ehs-cta-box > p { font-size: 17px; color: rgba(255,255,255,0.75); margin-bottom: 36px; max-width: 500px; margin-left: auto; margin-right: auto; position: relative; z-index: 2; }
.ehs-cta-actions { display: flex; justify-content: center; gap: 14px; flex-wrap: wrap; position: relative; z-index: 2; }
.ehs-how { padding: 90px 0; background: var(--ehs-white); }
.ehs-how-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; max-width: 900px; margin: 0 auto; position: relative; }
.ehs-how-grid::before { content: ''; position: absolute; top: 36px; left: 15%; right: 15%; height: 2px; background: linear-gradient(90deg, var(--ehs-primary-light) 0%, var(--ehs-primary) 50%, var(--ehs-primary-light) 100%); z-index: 0; }
.ehs-how-step { text-align: center; position: relative; z-index: 1; }
.ehs-how-num { width: 72px; height: 72px; border-radius: 50%; background: var(--ehs-white); border: 3px solid var(--ehs-primary); display: flex; align-items: center; justify-content: center; font-family: var(--ehs-font-heading); font-size: 28px; font-weight: 800; color: var(--ehs-primary); margin: 0 auto 20px; box-shadow: 0 4px 15px rgba(23,70,162,0.12); }
.ehs-how-step h3 { font-size: 18px; font-weight: 700; margin-bottom: 8px; }
.ehs-how-step p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.6; margin: 0; }
.ehs-trust-strip { padding: 40px 0; background: var(--ehs-gradient); }
.ehs-trust-inner { display: flex; align-items: center; justify-content: center; gap: 40px; flex-wrap: wrap; }
.ehs-trust-item { display: flex; align-items: center; gap: 12px; color: rgba(255,255,255,0.85); font-size: 14px; font-weight: 600; }
.ehs-trust-item-icon { width: 40px; height: 40px; border-radius: 10px; background: rgba(255,255,255,0.1); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ehs-trust-item-icon img { height: 22px; width: auto; filter: brightness(0) invert(1); opacity: 0.8; }
.ehs-trust-sep { width: 1px; height: 30px; background: rgba(255,255,255,0.12); }
.ehs-blog-section { padding: 90px 0; background: var(--ehs-bg); }
.ehs-blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.ehs-blog-card { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius-lg); overflow: hidden; transition: var(--ehs-transition); }
.ehs-blog-card:hover { transform: translateY(-5px); box-shadow: var(--ehs-shadow-lg); border-color: var(--ehs-primary); }
.ehs-blog-card-img { height: 180px; overflow: hidden; }
.ehs-blog-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s ease; }
.ehs-blog-card:hover .ehs-blog-card-img img { transform: scale(1.05); }
.ehs-blog-card-placeholder { width: 100%; height: 100%; background: var(--ehs-gradient); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.2); font-size: 48px; }
.ehs-blog-card-body { padding: 24px; }
.ehs-blog-card-meta { font-size: 12px; color: var(--ehs-text-light); margin-bottom: 10px; display: flex; align-items: center; gap: 10px; }
.ehs-blog-card-meta a { color: var(--ehs-primary); text-decoration: none; font-weight: 600; }
.ehs-blog-card h3 { font-size: 17px; font-weight: 700; margin-bottom: 10px; line-height: 1.4; }
.ehs-blog-card h3 a { color: var(--ehs-dark); text-decoration: none; transition: color 0.2s; }
.ehs-blog-card h3 a:hover { color: var(--ehs-primary); }
.ehs-blog-card-excerpt { font-size: 14px; color: var(--ehs-text-light); line-height: 1.6; margin-bottom: 16px; }
.ehs-blog-card-read { font-size: 13px; font-weight: 700; color: var(--ehs-primary); text-decoration: none; display: inline-flex; align-items: center; gap: 6px; transition: gap 0.2s; }
.ehs-blog-card-read:hover { gap: 10px; }
.ehs-blog-more { text-align: center; margin-top: 36px; }

/* Front Page Responsive */
@media (max-width: 1024px) {
    .ehs-hero-grid { grid-template-columns: 1fr; gap: 40px; text-align: center; }
    .ehs-hero-desc { margin: 0 auto 32px; }
    .ehs-hero-actions { justify-content: center; }
    .ehs-hero-trust { justify-content: center; }
    .ehs-partner-strip { justify-content: center; flex-wrap: wrap; }
    .ehs-hero-visual { order: -1; }
    .ehs-hero-visual img { max-width: 85%; }
    .ehs-products-grid { grid-template-columns: repeat(2, 1fr); }
    .ehs-features-grid { grid-template-columns: repeat(2, 1fr); }
    .ehs-tech-grid { grid-template-columns: 1fr; }
    .ehs-support-grid { grid-template-columns: 1fr; }
    .ehs-clients-grid { grid-template-columns: repeat(4, 1fr); }
    .ehs-testimonials-grid { grid-template-columns: 1fr; }
    .ehs-how-grid::before { display: none; }
}
@media (max-width: 768px) {
    .ehs-hero { padding-top: 140px; }
    .ehs-products-grid { grid-template-columns: 1fr; max-width: 400px; margin: 0 auto; }
    .ehs-features-grid { grid-template-columns: 1fr; }
    .ehs-stats-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
    .ehs-clients-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
    .ehs-support-cards { grid-template-columns: 1fr; }
    .ehs-cta-box { padding: 40px 24px; }
    .ehs-domain-form { flex-direction: column; border-radius: var(--ehs-radius); padding: 8px; }
    .ehs-domain-form input[type="text"] { border-radius: var(--ehs-radius); }
    .ehs-domain-form button { border-radius: var(--ehs-radius); width: 100%; }
    .ehs-how-grid { grid-template-columns: 1fr; max-width: 320px; }
    .ehs-blog-grid { grid-template-columns: 1fr; max-width: 400px; margin: 0 auto; }
    .ehs-trust-inner { gap: 20px; }
    .ehs-trust-sep { display: none; }
}

/* --- 2. DOMAIN TRANSFER --- */
.dt-hero { background: var(--ehs-gradient); padding: 160px 0 100px; margin-top: -72px; text-align: center; position: relative; overflow: hidden; }
.dt-hero::before { content: ''; position: absolute; top: -30%; left: -10%; width: 500px; height: 500px; background: radial-gradient(circle, rgba(255,107,53,0.1) 0%, transparent 70%); border-radius: 50%; }
.dt-hero h1 { font-size: clamp(30px, 5vw, 48px); font-weight: 800; color: #fff; margin-bottom: 16px; position: relative; }
.dt-hero h1 span { color: var(--ehs-accent); }
.dt-hero-sub { font-size: 17px; color: rgba(255,255,255,0.7); max-width: 600px; margin: 0 auto 40px; line-height: 1.7; position: relative; }
.dt-card { background: #fff; padding: 40px; border-radius: var(--ehs-radius-lg); box-shadow: 0 25px 50px rgba(0,0,0,0.3); max-width: 850px; margin: 0 auto; position: relative; z-index: 10; }
.dt-form-row { display: flex; gap: 15px; align-items: flex-start; flex-wrap: nowrap; }
.dt-input { width: 100%; border: 2px solid var(--ehs-border); border-radius: 8px; padding: 0 20px; height: 60px; font-size: 18px; font-family: var(--ehs-font-body); color: var(--ehs-dark); transition: var(--ehs-transition); outline: none; }
.dt-input:focus { border-color: var(--ehs-primary); }
.dt-check-btn { background: var(--ehs-accent); color: #fff; border: none; padding: 0 36px; height: 60px; font-size: 16px; font-weight: 700; border-radius: 8px; cursor: pointer; transition: var(--ehs-transition); white-space: nowrap; flex-shrink: 0; font-family: var(--ehs-font-heading); box-shadow: 0 5px 15px rgba(255,107,53,0.3); }
.dt-check-btn:hover { background: var(--ehs-accent-hover); transform: translateY(-2px); }
.dt-epp-section { display: none; margin-top: 16px; }
.dt-status { margin-top: 16px; padding: 14px 18px; border-radius: 8px; font-size: 14px; font-weight: 600; display: none; }
.dt-status.success { color: #0f5132; background: #d1e7dd; border: 1px solid #badbcc; display: block; }
.dt-status.error { color: #842029; background: #f8d7da; border: 1px solid #f5c6cb; display: block; }
.dt-hero-trust { display: flex; justify-content: center; gap: 24px; flex-wrap: wrap; margin-top: 24px; position: relative; z-index: 2; }
.dt-hero-trust span { color: rgba(255,255,255,0.8); font-size: 14px; display: flex; align-items: center; gap: 8px; }
.dt-hero-trust span svg { color: var(--ehs-success); }
.dt-steps { padding: 80px 0; background: var(--ehs-white); }
.dt-steps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.dt-step { text-align: center; padding: 32px; background: var(--ehs-bg); border-radius: var(--ehs-radius-lg); border: 1px solid var(--ehs-border); transition: var(--ehs-transition); }
.dt-step:hover { transform: translateY(-4px); box-shadow: var(--ehs-shadow-md); border-color: var(--ehs-primary); background: var(--ehs-white); }
.dt-step-num { width: 44px; height: 44px; border-radius: 50%; background: var(--ehs-primary); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 18px; margin: 0 auto 20px; font-family: var(--ehs-font-heading); }
.dt-step h3 { font-size: 18px; font-weight: 700; margin-bottom: 8px; }
.dt-step p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.6; margin: 0; }
.dt-why { padding: 80px 0; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.dt-why-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }
.dt-why-card { display: flex; gap: 20px; padding: 28px; background: var(--ehs-white); border-radius: var(--ehs-radius); border: 1px solid var(--ehs-border); transition: var(--ehs-transition); }
.dt-why-card:hover { box-shadow: var(--ehs-shadow-md); border-color: var(--ehs-primary); }
.dt-why-icon { flex-shrink: 0; width: 52px; height: 52px; border-radius: 14px; background: var(--ehs-primary-light); color: var(--ehs-primary); display: flex; align-items: center; justify-content: center; }
.dt-why-card h4 { font-size: 16px; font-weight: 700; margin-bottom: 6px; }
.dt-why-card p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.5; margin: 0; }
.dt-faq { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.dt-faq-grid { display: grid; grid-template-columns: 1fr; gap: 12px; max-width: 800px; margin: 0 auto; }
.dt-faq-item { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: 8px; overflow: hidden; }
.dt-faq-item.active { border-left: 4px solid var(--ehs-primary); }
.dt-faq-q { width: 100%; text-align: left; padding: 18px 20px; font-size: 15px; font-weight: 700; color: var(--ehs-dark); background: transparent; border: none; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 12px; font-family: var(--ehs-font-heading); line-height: 1.4; }
.dt-faq-q svg { flex-shrink: 0; color: var(--ehs-text-light); transition: var(--ehs-transition); }
.dt-faq-item.active .dt-faq-q svg { transform: rotate(45deg); color: var(--ehs-accent); }
.dt-faq-item.active .dt-faq-q { color: var(--ehs-primary); }
.dt-faq-a { display: none; padding: 0 20px 18px; font-size: 14px; color: var(--ehs-text-light); line-height: 1.7; }
.dt-faq-item.active .dt-faq-a { display: block; }

@media (max-width: 768px) { .dt-form-row { flex-direction: column; } .dt-check-btn { width: 100%; } .dt-steps-grid { grid-template-columns: 1fr; } .dt-why-grid { grid-template-columns: 1fr; } }

/* --- 3. DOMAINS PAGE --- */
.dom-hero { background: var(--ehs-gradient); padding: 160px 0 80px; margin-top: -72px; text-align: center; position: relative; overflow: hidden; }
.dom-hero::before { content: ''; position: absolute; top: -30%; right: -10%; width: 500px; height: 500px; background: radial-gradient(circle, rgba(255,107,53,0.1) 0%, transparent 70%); border-radius: 50%; }
.dom-hero h1 { font-size: clamp(30px, 5vw, 48px); font-weight: 800; color: #fff; margin-bottom: 16px; position: relative; }
.dom-hero h1 span { color: var(--ehs-accent); }
.dom-hero-sub { font-size: 17px; color: rgba(255,255,255,0.7); max-width: 650px; margin: 0 auto 36px; line-height: 1.7; position: relative; }
.dom-search-form { max-width: 680px; margin: 0 auto 28px; display: flex; align-items: center; background: #fff; border-radius: 60px; padding: 5px 5px 5px 8px; box-shadow: 0 20px 60px rgba(0,0,0,0.15); position: relative; z-index: 2; }
.dom-search-form input { flex: 1; border: none; padding: 14px 20px; font-size: 16px; background: transparent; outline: none; color: var(--ehs-dark); border-radius: 60px; height: 52px; font-family: var(--ehs-font-body); }
.dom-search-form input::placeholder { color: var(--ehs-text-light); }
.dom-search-form button { background: var(--ehs-accent); color: #fff; border: none; padding: 0 36px; height: 52px; border-radius: 60px; font-family: var(--ehs-font-heading); font-weight: 700; font-size: 15px; cursor: pointer; transition: var(--ehs-transition); white-space: nowrap; flex-shrink: 0; }
.dom-search-form button:hover { background: var(--ehs-accent-hover); }
.dom-hero-features { display: flex; justify-content: center; gap: 24px; flex-wrap: wrap; position: relative; z-index: 2; }
.dom-hero-features span { color: rgba(255,255,255,0.8); font-size: 14px; display: flex; align-items: center; gap: 8px; }
.dom-hero-features span svg { color: var(--ehs-success); }
.dom-tlds { padding: 80px 0; background: var(--ehs-bg); }
.dom-tlds-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.dom-tld-card { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius-lg); padding: 32px 24px; text-align: center; transition: var(--ehs-transition); }
.dom-tld-card:hover { transform: translateY(-5px); box-shadow: var(--ehs-shadow-lg); border-color: var(--ehs-primary); }
.dom-tld-card h3 { font-size: 32px; font-weight: 800; color: var(--ehs-primary); margin-bottom: 8px; }
.dom-tld-card .desc { font-size: 14px; color: var(--ehs-text-light); margin-bottom: 16px; }
.dom-tld-card .price { font-family: var(--ehs-font-heading); font-size: 24px; font-weight: 700; color: var(--ehs-dark); margin-bottom: 20px; }
.dom-tld-card .price small { font-size: 14px; color: #999; font-weight: 400; }
.dom-features { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.dom-features-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.dom-feat { background: var(--ehs-bg); border-radius: var(--ehs-radius-lg); padding: 32px; border: 1px solid transparent; transition: var(--ehs-transition); }
.dom-feat:hover { background: var(--ehs-white); border-color: var(--ehs-border); box-shadow: var(--ehs-shadow-md); transform: translateY(-3px); }
.dom-feat-icon { width: 52px; height: 52px; border-radius: 14px; background: var(--ehs-primary-light); color: var(--ehs-primary); display: flex; align-items: center; justify-content: center; margin-bottom: 20px; }
.dom-feat h3 { font-size: 18px; font-weight: 700; margin-bottom: 8px; }
.dom-feat p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.6; margin: 0; }
.dom-faq { padding: 80px 0; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.dom-faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; max-width: 960px; margin: 0 auto; align-items: start; }
.dom-faq-item { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: 8px; overflow: hidden; }
.dom-faq-item.active { border-left: 4px solid var(--ehs-primary); }
.dom-faq-q { width: 100%; text-align: left; padding: 18px 20px; font-size: 15px; font-weight: 700; color: var(--ehs-dark); background: transparent; border: none; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 12px; font-family: var(--ehs-font-heading); line-height: 1.4; }
.dom-faq-q svg { flex-shrink: 0; color: var(--ehs-text-light); transition: var(--ehs-transition); }
.dom-faq-item.active .dom-faq-q svg { transform: rotate(45deg); color: var(--ehs-accent); }
.dom-faq-item.active .dom-faq-q { color: var(--ehs-primary); }
.dom-faq-a { display: none; padding: 0 20px 18px; font-size: 14px; color: var(--ehs-text-light); line-height: 1.7; }
.dom-faq-item.active .dom-faq-a { display: block; }

@media (max-width: 1024px) { .dom-tlds-grid { grid-template-columns: repeat(2, 1fr); } .dom-features-grid { grid-template-columns: 1fr; } .dom-faq-grid { grid-template-columns: 1fr; } }
@media (max-width: 768px) { .dom-tlds-grid { grid-template-columns: 1fr; max-width: 350px; margin: 0 auto; } .dom-search-form { flex-direction: column; border-radius: var(--ehs-radius); padding: 8px; } .dom-search-form input { border-radius: var(--ehs-radius); } .dom-search-form button { border-radius: var(--ehs-radius); width: 100%; } }


/* --- 4. ARCHIVE / BLOG LISTING --- */
.archive-hero { background: var(--ehs-gradient); padding: 140px 0 60px; text-align: center; position: relative; overflow: hidden; }
.archive-hero::before { content: ''; position: absolute; top: -30%; right: -10%; width: 500px; height: 500px; background: radial-gradient(circle, rgba(255,107,53,0.08) 0%, transparent 70%); border-radius: 50%; }
.archive-hero h1 { font-size: clamp(28px, 4vw, 42px); font-weight: 800; color: #fff; margin-bottom: 10px; position: relative; }
.archive-hero h1 span { color: var(--ehs-accent); }
.archive-hero-sub { font-size: 16px; color: rgba(255,255,255,0.6); position: relative; margin-bottom: 28px; }
.archive-search { max-width: 520px; margin: 0 auto; display: flex; background: rgba(255,255,255,0.1); border-radius: 60px; padding: 4px; border: 1px solid rgba(255,255,255,0.12); position: relative; z-index: 2; }
.archive-search input { flex: 1; border: none; padding: 12px 20px; font-size: 15px; background: transparent; outline: none; color: #fff; border-radius: 60px; font-family: var(--ehs-font-body); }
.archive-search input::placeholder { color: rgba(255,255,255,0.35); }
.archive-search button { background: var(--ehs-accent); color: #fff; border: none; padding: 0 28px; height: 44px; border-radius: 60px; font-family: var(--ehs-font-heading); font-weight: 700; font-size: 14px; cursor: pointer; white-space: nowrap; flex-shrink: 0; transition: background 0.2s; }
.archive-search button:hover { background: var(--ehs-accent-hover); }
.archive-content { padding: 60px 0 80px; background: var(--ehs-bg); }
.archive-posts { max-width: 860px; margin: 0 auto; display: flex; flex-direction: column; gap: 28px; }
.post-card { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius-lg); overflow: hidden; transition: var(--ehs-transition); display: flex; }
.post-card:hover { box-shadow: var(--ehs-shadow-lg); border-color: var(--ehs-primary); transform: translateY(-3px); }
.post-card-img { width: 280px; flex-shrink: 0; overflow: hidden; }
.post-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s ease; }
.post-card:hover .post-card-img img { transform: scale(1.05); }
.post-card-img-placeholder { width: 100%; height: 100%; min-height: 180px; background: var(--ehs-gradient); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.3); font-size: 48px; }
.post-card-body { padding: 28px; display: flex; flex-direction: column; flex: 1; min-width: 0; }
.post-card-meta { font-size: 12px; color: var(--ehs-text-light); margin-bottom: 10px; display: flex; align-items: center; gap: 12px; }
.post-card-meta a { color: var(--ehs-primary); text-decoration: none; font-weight: 600; }
.post-card h2 { font-size: 20px; font-weight: 700; margin-bottom: 10px; line-height: 1.35; }
.post-card h2 a { color: var(--ehs-dark); text-decoration: none; transition: color 0.2s; }
.post-card h2 a:hover { color: var(--ehs-primary); }
.post-card-excerpt { font-size: 14px; color: var(--ehs-text-light); line-height: 1.65; margin-bottom: 16px; flex: 1; }
.post-card-read { font-size: 13px; font-weight: 700; color: var(--ehs-primary); text-decoration: none; display: inline-flex; align-items: center; gap: 6px; transition: gap 0.2s; }
.post-card-read:hover { gap: 10px; }
.archive-pagination { margin-top: 40px; display: flex; justify-content: center; gap: 6px; }
.archive-pagination a, .archive-pagination span { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 8px; font-size: 14px; font-weight: 600; text-decoration: none; transition: var(--ehs-transition); }
.archive-pagination a { color: var(--ehs-text); background: var(--ehs-white); border: 1px solid var(--ehs-border); }
.archive-pagination a:hover { background: var(--ehs-primary); color: #fff; border-color: var(--ehs-primary); }
.archive-pagination .current { background: var(--ehs-primary); color: #fff; border: 1px solid var(--ehs-primary); }
.archive-pagination .prev, .archive-pagination .next { width: auto; padding: 0 16px; }

@media (max-width: 768px) {
    .post-card { flex-direction: column; }
    .post-card-img { width: 100%; height: 200px; }
    .archive-search { flex-direction: column; border-radius: var(--ehs-radius); padding: 8px; }
    .archive-search input { border-radius: var(--ehs-radius); }
    .archive-search button { border-radius: var(--ehs-radius); width: 100%; }
}

/* --- 5. WEB HOSTING / SHARED --- */
.wh-hero { background: var(--ehs-gradient); padding: 180px 0 100px; margin-top: -80px; text-align: center; position: relative; overflow: hidden; }
.wh-hero-orb { position: absolute; border-radius: 50%; pointer-events: none; }
.wh-hero-orb-1 { width: 500px; height: 500px; top: -20%; right: -8%; background: radial-gradient(circle, rgba(255,107,53,0.12) 0%, transparent 70%); animation: wh-float-1 8s ease-in-out infinite; }
.wh-hero-orb-2 { width: 400px; height: 400px; bottom: -25%; left: -5%; background: radial-gradient(circle, rgba(23,70,162,0.2) 0%, transparent 70%); animation: wh-float-2 10s ease-in-out infinite; }
.wh-hero-orb-3 { width: 200px; height: 200px; top: 20%; left: 15%; background: radial-gradient(circle, rgba(16,185,129,0.08) 0%, transparent 70%); animation: wh-float-3 6s ease-in-out infinite; }
@keyframes wh-float-1 { 0%, 100% { transform: translate(0, 0) scale(1); } 50% { transform: translate(-30px, 20px) scale(1.05); } }
@keyframes wh-float-2 { 0%, 100% { transform: translate(0, 0) scale(1); } 50% { transform: translate(25px, -15px) scale(1.08); } }
@keyframes wh-float-3 { 0%, 100% { transform: translate(0, 0); } 50% { transform: translate(15px, -20px); } }
.wh-hero-shapes { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.wh-hero-shape { position: absolute; border: 1px solid rgba(255,255,255,0.06); border-radius: 4px; }
.wh-hero-shape-1 { width: 60px; height: 60px; top: 18%; right: 12%; transform: rotate(20deg); animation: wh-spin-slow 20s linear infinite; }
.wh-hero-shape-2 { width: 40px; height: 40px; top: 60%; right: 25%; border-radius: 50%; border-color: rgba(255,107,53,0.1); animation: wh-spin-slow 15s linear infinite reverse; }
.wh-hero-shape-3 { width: 80px; height: 80px; top: 30%; left: 8%; transform: rotate(-15deg); border-color: rgba(255,255,255,0.04); animation: wh-spin-slow 25s linear infinite; }
.wh-hero-shape-4 { width: 30px; height: 30px; bottom: 25%; left: 20%; border-radius: 50%; border-color: rgba(16,185,129,0.1); animation: wh-spin-slow 12s linear infinite reverse; }
.wh-hero-shape-5 { width: 50px; height: 50px; top: 15%; left: 30%; transform: rotate(45deg); border-color: rgba(255,255,255,0.05); animation: wh-spin-slow 18s linear infinite; }
@keyframes wh-spin-slow { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.wh-hero-grid-pattern { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px); background-size: 60px 60px; pointer-events: none; mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, black 20%, transparent 70%); -webkit-mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, black 20%, transparent 70%); }
.wh-hero-content { position: relative; z-index: 2; }
.wh-hero-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,0.08); backdrop-filter: blur(10px); color: rgba(255,255,255,0.85); padding: 8px 18px; border-radius: 50px; font-size: 13px; font-weight: 600; margin-bottom: 24px; border: 1px solid rgba(255,255,255,0.1); animation: wh-fade-up 0.6s ease-out both; }
.wh-hero h1 { font-size: clamp(32px, 5vw, 52px); font-weight: 800; color: #fff; margin-bottom: 20px; position: relative; animation: wh-fade-up 0.6s 0.1s ease-out both; }
.wh-hero h1 span { color: var(--ehs-accent); }
.wh-hero-sub { font-size: 17px; color: rgba(255,255,255,0.65); max-width: 620px; margin: 0 auto 32px; line-height: 1.75; position: relative; animation: wh-fade-up 0.6s 0.2s ease-out both; }
.wh-hero-actions { display: flex; justify-content: center; gap: 14px; flex-wrap: wrap; animation: wh-fade-up 0.6s 0.3s ease-out both; }
.wh-hero-stats { display: flex; justify-content: center; gap: 40px; margin-top: 48px; animation: wh-fade-up 0.6s 0.4s ease-out both; }
.wh-hero-stat { text-align: center; }
.wh-hero-stat-num { font-family: var(--ehs-font-heading); font-size: 28px; font-weight: 800; color: #fff; line-height: 1; margin-bottom: 4px; }
.wh-hero-stat-label { font-size: 12px; color: rgba(255,255,255,0.45); text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600; }
@keyframes wh-fade-up { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }

/* Shared Plans formatting (Web Hosting) */
.wh-plans { padding: 90px 0 60px; background: var(--ehs-bg); }
.wh-plans-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; align-items: start; }
.wh-plan { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius-lg); overflow: hidden; transition: var(--ehs-transition); display: flex; flex-direction: column; }
.wh-plan:hover { transform: translateY(-5px); box-shadow: var(--ehs-shadow-lg); border-color: var(--ehs-primary); }
.wh-plan.popular { border: 2px solid var(--ehs-primary); transform: scale(1.02); z-index: 2; box-shadow: 0 10px 40px rgba(23,70,162,0.15); }
.wh-plan-ribbon { background: var(--ehs-accent); color: #fff; text-align: center; padding: 6px 0; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; }
.wh-plan-header { padding: 28px 24px 0; text-align: center; }
.wh-plan-header h3 { font-size: 22px; font-weight: 700; margin-bottom: 8px; }
.wh-plan-header p { font-size: 13px; color: var(--ehs-text-light); line-height: 1.5; min-height: 40px; margin-bottom: 16px; }
.wh-plan-price { font-family: var(--ehs-font-heading); font-size: 28px; font-weight: 600; color: #444; margin-bottom: 16px; }
.wh-plan-price small { font-size: 14px; font-weight: 400; color: #999; }
.wh-plan-btn { padding: 0 24px 20px; text-align: center; }
.wh-specs { background: var(--ehs-bg); margin: 0 16px 16px; padding: 10px 16px; border-radius: 8px; text-align: center; }
.wh-specs-label { font-size: 11px; text-transform: uppercase; color: var(--ehs-text-light); letter-spacing: 0.05em; font-weight: 600; }
.wh-specs-value { font-size: 14px; color: var(--ehs-primary); font-weight: 700; }
.wh-plan-features { list-style: none; padding: 16px 24px; margin: 0; border-top: 1px solid var(--ehs-border); flex: 1; }
.wh-plan-features li { padding: 8px 0; font-size: 14px; color: var(--ehs-text); display: flex; align-items: center; gap: 10px; border-bottom: 1px solid #f8f8f8; }
.wh-plan-features li:last-child { border-bottom: none; }
.wh-plan-features li svg { color: var(--ehs-success); flex-shrink: 0; width: 16px; height: 16px; }
.wh-plan-features strong { color: var(--ehs-dark); font-weight: 700; }
.wh-partners { display: flex; align-items: center; justify-content: center; gap: 10px; padding: 24px 0 0; flex-wrap: wrap; }
.wh-partners-label { font-size: 13px; color: #888; font-weight: 600; margin-right: 8px; }
.wh-partners img { height: 26px; width: auto; opacity: 0.6; filter: brightness(0); transition: var(--ehs-transition); }
.wh-partners img:hover { opacity: 0.9; }
.wh-partners-divider { width: 1px; height: 20px; background: #bbb; margin: 0 6px; }

.wh-reviews { padding: 80px 0; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.wh-reviews-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.wh-review-card { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius); padding: 24px; transition: var(--ehs-transition); }
.wh-review-card:hover { transform: translateY(-4px); box-shadow: var(--ehs-shadow-md); border-color: var(--ehs-primary); }
.wh-review-card .stars { color: #FBBF24; margin-bottom: 12px; display: flex; gap: 2px; }
.wh-review-title { font-weight: 700; font-size: 15px; margin-bottom: 10px; color: var(--ehs-dark); }
.wh-review-text { font-size: 14px; color: var(--ehs-text-light); font-style: italic; margin-bottom: 12px; line-height: 1.6; }
.wh-review-author { font-size: 13px; font-weight: 700; color: var(--ehs-primary); }
.wh-features { padding: 90px 0; background: var(--ehs-white); }
.wh-features-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.wh-feature { background: var(--ehs-white); padding: 28px 24px; border-radius: var(--ehs-radius); border: 1px solid var(--ehs-border); display: flex; gap: 20px; transition: var(--ehs-transition); }
.wh-feature:hover { transform: translateY(-4px); box-shadow: var(--ehs-shadow-md); border-color: var(--ehs-primary); }
.wh-feature-icon { flex-shrink: 0; width: 48px; height: 48px; background: var(--ehs-primary-light); color: var(--ehs-primary); border-radius: 10px; display: flex; align-items: center; justify-content: center; }
.wh-feature:hover .wh-feature-icon { background: var(--ehs-primary); color: #fff; }
.wh-feature h3 { font-size: 16px; font-weight: 700; margin-bottom: 6px; }
.wh-feature p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.5; margin: 0; }
.wh-alt { padding: 80px 0; }
.wh-alt.bg-grey { background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.wh-alt.bg-white { background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.wh-alt-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.wh-alt-img { border-radius: var(--ehs-radius); box-shadow: var(--ehs-shadow-lg); transition: var(--ehs-transition); width: 100%; }
.wh-alt-img:hover { transform: translateY(-4px); }
.wh-alt-logo { max-width: 220px; margin-bottom: 24px; }
.wh-info-list { list-style: none; }
.wh-info-list li { padding: 14px 0; font-size: 15px; color: var(--ehs-text); display: flex; align-items: flex-start; gap: 14px; border-bottom: 1px solid #f0f0f0; }
.wh-info-list li:last-child { border-bottom: none; }
.wh-info-list li svg { color: var(--ehs-success); flex-shrink: 0; margin-top: 3px; }
.wh-info-list strong { color: var(--ehs-dark); }
.wh-text-block strong { color: var(--ehs-dark); }
.wh-text-block p { color: var(--ehs-text-light); line-height: 1.7; }
.wh-apps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.wh-app-card { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius); padding: 20px 12px; text-align: center; transition: var(--ehs-transition); }
.wh-app-card:hover { transform: translateY(-3px); box-shadow: var(--ehs-shadow-sm); border-color: var(--ehs-primary); }
.wh-app-card-icon { font-size: 36px; margin-bottom: 8px; }
.wh-app-card h5 { font-size: 14px; font-weight: 700; color: var(--ehs-text); margin: 0; }
.wh-backup-features { display: flex; flex-direction: column; gap: 14px; margin-top: 24px; }
.wh-backup-item { display: flex; align-items: center; gap: 14px; font-size: 15px; color: var(--ehs-text); }
.wh-backup-item-icon { width: 36px; height: 36px; border-radius: 50%; background: #FFF0E9; color: var(--ehs-accent); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

.wh-faq { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.wh-faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; max-width: 960px; margin: 0 auto; align-items: start; }
.wh-faq-item { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: 8px; overflow: hidden; }
.wh-faq-item.active { border-left: 4px solid var(--ehs-primary); }
.wh-faq-q { width: 100%; text-align: left; padding: 18px 20px; font-size: 15px; font-weight: 700; color: var(--ehs-dark); background: transparent; border: none; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 12px; font-family: var(--ehs-font-heading); line-height: 1.4; }
.wh-faq-q svg { flex-shrink: 0; color: var(--ehs-text-light); transition: var(--ehs-transition); }
.wh-faq-item.active .wh-faq-q svg { transform: rotate(45deg); color: var(--ehs-accent); }
.wh-faq-item.active .wh-faq-q { color: var(--ehs-primary); }
.wh-faq-a { display: none; padding: 0 20px 18px; font-size: 14px; color: var(--ehs-text-light); line-height: 1.7; }
.wh-faq-item.active .wh-faq-a { display: block; }

@media (max-width: 1024px) {
    .wh-plans-grid { grid-template-columns: repeat(2, 1fr); }
    .wh-plan.popular { transform: scale(1); }
    .wh-reviews-grid { grid-template-columns: repeat(2, 1fr); }
    .wh-features-grid { grid-template-columns: repeat(2, 1fr); }
    .wh-alt-grid { grid-template-columns: 1fr; }
    .wh-faq-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
    .wh-hero { padding: 150px 0 70px; }
    .wh-hero-stats { gap: 24px; }
    .wh-hero-stat-num { font-size: 22px; }
    .wh-hero-shapes { display: none; }
    .wh-plans-grid { grid-template-columns: 1fr; max-width: 420px; margin: 0 auto; }
    .wh-reviews-grid { grid-template-columns: 1fr; }
    .wh-features-grid { grid-template-columns: 1fr; }
    .wh-apps-grid { grid-template-columns: repeat(2, 1fr); }
}


/* --- 6. VPS (Linux & Windows) --- */
.vps-hero { background: var(--ehs-gradient); padding: 160px 0 80px; margin-top: -72px; position: relative; overflow: hidden; }
.vps-hero::before { content: ''; position: absolute; top: -30%; right: -10%; width: 500px; height: 500px; background: radial-gradient(circle, rgba(255,107,53,0.1) 0%, transparent 70%); border-radius: 50%; }
.vps-hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; position: relative; z-index: 2; }
.vps-hero h1 { font-size: clamp(30px, 5vw, 48px); font-weight: 800; color: #fff; margin-bottom: 16px; }
.vps-hero h1 span { color: var(--ehs-accent); }
.vps-hero-desc { font-size: 17px; color: rgba(255,255,255,0.7); line-height: 1.7; margin-bottom: 24px; }
.vps-hero-list { list-style: none; margin-bottom: 32px; }
.vps-hero-list li { color: rgba(255,255,255,0.8); font-size: 15px; padding: 6px 0; display: flex; align-items: center; gap: 10px; }
.vps-hero-list li svg { color: var(--ehs-success); flex-shrink: 0; }
.vps-hero-price { font-size: 16px; color: rgba(255,255,255,0.6); margin-bottom: 20px; }
.vps-hero-price strong { color: #fff; font-size: 20px; }
.vps-plans { padding: 90px 0 60px; background: var(--ehs-bg); }
.vps-plans-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; align-items: start; }
.vps-plan { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius-lg); overflow: hidden; transition: var(--ehs-transition); display: flex; flex-direction: column; }
.vps-plan:hover { transform: translateY(-5px); box-shadow: var(--ehs-shadow-lg); border-color: var(--ehs-primary); }
.vps-plan.popular { border: 2px solid var(--ehs-primary); box-shadow: 0 10px 40px rgba(23,70,162,0.15); }
.vps-plan-ribbon { background: var(--ehs-accent); color: #fff; text-align: center; padding: 6px 0; font-size: 12px; font-weight: 700; text-transform: uppercase; }
.vps-plan-header { padding: 28px 24px 0; text-align: center; }
.vps-plan-header h3 { font-size: 20px; font-weight: 700; margin-bottom: 6px; }
.vps-plan-header .ideal { font-size: 12px; color: var(--ehs-text-light); margin-bottom: 14px; }
.vps-plan-price { font-family: var(--ehs-font-heading); font-size: 28px; font-weight: 600; color: #444; margin-bottom: 16px; }
.vps-plan-price small { font-size: 14px; font-weight: 400; color: #999; }
.vps-plan-btn { padding: 0 24px 20px; text-align: center; }
.vps-plan-features { list-style: none; padding: 16px 24px; margin: 0; border-top: 1px solid var(--ehs-border); flex: 1; }
.vps-plan-features li { padding: 7px 0; font-size: 13px; color: var(--ehs-text); display: flex; align-items: center; gap: 10px; border-bottom: 1px solid #f8f8f8; }
.vps-plan-features li:last-child { border-bottom: none; }
.vps-plan-features li svg { color: var(--ehs-success); flex-shrink: 0; width: 14px; height: 14px; }
.vps-plan-features strong { color: var(--ehs-dark); font-weight: 700; }
.vps-faq { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.vps-faq-grid { display: grid; grid-template-columns: 1fr; gap: 12px; max-width: 800px; margin: 0 auto; }
.vps-faq-item { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: 8px; overflow: hidden; }
.vps-faq-item.active { border-left: 4px solid var(--ehs-primary); }
.vps-faq-q { width: 100%; text-align: left; padding: 18px 20px; font-size: 15px; font-weight: 700; color: var(--ehs-dark); background: transparent; border: none; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 12px; font-family: var(--ehs-font-heading); line-height: 1.4; }
.vps-faq-q svg { flex-shrink: 0; color: var(--ehs-text-light); transition: var(--ehs-transition); }
.vps-faq-item.active .vps-faq-q svg { transform: rotate(45deg); color: var(--ehs-accent); }
.vps-faq-item.active .vps-faq-q { color: var(--ehs-primary); }
.vps-faq-a { display: none; padding: 0 20px 18px; font-size: 14px; color: var(--ehs-text-light); line-height: 1.7; }
.vps-faq-item.active .vps-faq-a { display: block; }

@media (max-width: 1024px) {
    .vps-hero-grid { grid-template-columns: 1fr; }
    .vps-plans-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    .vps-plans-grid { grid-template-columns: 1fr; max-width: 420px; margin: 0 auto; }
}


/* --- 6b. WINDOWS VPS SPECIFIC --- */
.vps-hero-rdp { background: #1a1a2e; border-radius: var(--ehs-radius); overflow: hidden; box-shadow: var(--ehs-shadow-xl); }
.vps-hero-rdp-bar { background: #0078d4; padding: 8px 16px; display: flex; align-items: center; gap: 8px; }
.vps-hero-rdp-bar span { color: #fff; font-size: 12px; font-weight: 600; }
.vps-hero-rdp-bar .dots { margin-left: auto; display: flex; gap: 6px; }
.vps-hero-rdp-bar .dot { width: 10px; height: 10px; border-radius: 50%; }
.vps-hero-rdp-bar .dot.min { background: rgba(255,255,255,0.3); }
.vps-hero-rdp-bar .dot.max { background: rgba(255,255,255,0.3); }
.vps-hero-rdp-bar .dot.close { background: #e81123; }
.vps-hero-rdp-body { padding: 20px; color: rgba(255,255,255,0.6); font-size: 13px; line-height: 1.8; font-family: 'Courier New', monospace; min-height: 140px; display: flex; align-items: center; justify-content: center; }
.vps-hero-rdp-body .status { text-align: center; }
.vps-hero-rdp-body .online { color: var(--ehs-success); font-weight: 700; font-size: 16px; display: block; margin-bottom: 4px; }
.win-usecases { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.win-usecases-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.win-usecase { background: var(--ehs-bg); border-radius: var(--ehs-radius-lg); padding: 36px 28px; text-align: center; border: 1px solid transparent; transition: var(--ehs-transition); }
.win-usecase:hover { border-color: var(--ehs-border); box-shadow: var(--ehs-shadow-md); transform: translateY(-3px); background: var(--ehs-white); }
.win-usecase-icon { font-size: 40px; margin-bottom: 16px; }
.win-usecase h3 { font-size: 18px; font-weight: 700; margin-bottom: 8px; }
.win-usecase p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.6; margin: 0; }
.win-os-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; max-width: 700px; margin: 40px auto 0; }
.win-os-badge { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius); padding: 16px; text-align: center; font-weight: 700; font-size: 14px; color: var(--ehs-dark); transition: var(--ehs-transition); }
.win-os-badge:hover { border-color: var(--ehs-primary); box-shadow: var(--ehs-shadow-sm); }
.win-control { padding: 80px 0; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.win-control-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.win-control h2 { font-size: clamp(24px, 3vw, 32px); font-weight: 800; margin-bottom: 20px; }
.win-control h2 span { color: var(--ehs-primary); }
.win-control-list { list-style: none; }
.win-control-list li { padding: 12px 0; font-size: 15px; color: var(--ehs-text); display: flex; align-items: flex-start; gap: 14px; border-bottom: 1px solid var(--ehs-border); }
.win-control-list li:last-child { border-bottom: none; }
.win-control-list li svg { color: var(--ehs-success); flex-shrink: 0; margin-top: 3px; }
.win-control-list strong { color: var(--ehs-dark); }
.win-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 24px; }
.win-stat { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius); padding: 16px; text-align: center; }
.win-stat-label { font-size: 11px; text-transform: uppercase; color: var(--ehs-text-light); font-weight: 600; margin-bottom: 4px; }
.win-stat-value { font-family: var(--ehs-font-heading); font-size: 18px; font-weight: 800; color: var(--ehs-primary); }
.win-ecosystem { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.win-ecosystem-inner { max-width: 800px; margin: 0 auto; text-align: center; }
.win-ecosystem h2 { font-size: clamp(24px, 3vw, 32px); font-weight: 800; margin-bottom: 12px; }
.win-ecosystem h2 span { color: var(--ehs-primary); }
.win-ecosystem > p { color: var(--ehs-text-light); margin-bottom: 36px; }
.win-eco-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; text-align: left; }
.win-eco-card { background: var(--ehs-bg); border-radius: var(--ehs-radius); padding: 28px; transition: var(--ehs-transition); }
.win-eco-card:hover { box-shadow: var(--ehs-shadow-md); background: var(--ehs-white); }
.win-eco-card h4 { font-size: 16px; font-weight: 700; margin-bottom: 8px; }
.win-eco-card p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.6; margin: 0; }
.win-notice { padding: 60px 0; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.win-notice-box { background: #FFF7ED; border: 1px solid #FED7AA; border-radius: var(--ehs-radius); padding: 24px 32px; max-width: 800px; margin: 0 auto; display: flex; gap: 16px; align-items: flex-start; }
.win-notice-box svg { color: var(--ehs-accent); flex-shrink: 0; margin-top: 2px; }
.win-notice-box p { font-size: 14px; color: var(--ehs-text); line-height: 1.6; margin: 0; }
.win-notice-box strong { color: var(--ehs-dark); }

@media (max-width: 1024px) {
    .win-usecases-grid { grid-template-columns: 1fr; max-width: 500px; margin: 0 auto; }
    .win-control-grid { grid-template-columns: 1fr; }
    .win-eco-grid { grid-template-columns: 1fr; }
    .win-os-grid { grid-template-columns: repeat(2, 1fr); }
}


/* --- 6c. LINUX VPS SPECIFIC --- */
.vps-hero-terminal { background: #1a1a2e; border-radius: var(--ehs-radius); padding: 24px; text-align: left; font-family: 'Courier New', monospace; font-size: 13px; color: #10B981; line-height: 1.8; box-shadow: var(--ehs-shadow-xl); position: relative; }
.vps-hero-terminal::before { content: '● ● ●'; position: absolute; top: 10px; left: 16px; font-size: 10px; letter-spacing: 4px; color: rgba(255,255,255,0.3); }
.vps-hero-terminal code { display: block; margin-top: 20px; white-space: pre-wrap; }
.vps-hero-terminal .prompt { color: #FF6B35; }
.vps-hero-terminal .output { color: rgba(255,255,255,0.5); }
.vps-table-section { padding: 40px 0 80px; background: var(--ehs-bg); }
.vps-table-wrap { overflow-x: auto; }
.vps-table { width: 100%; border-collapse: collapse; background: var(--ehs-white); border-radius: var(--ehs-radius); overflow: hidden; box-shadow: var(--ehs-shadow-sm); font-size: 14px; }
.vps-table th { background: var(--ehs-dark); color: #fff; padding: 14px 16px; text-align: left; font-weight: 700; font-size: 13px; text-transform: uppercase; }
.vps-table td { padding: 12px 16px; border-bottom: 1px solid var(--ehs-border); }
.vps-table tr:last-child td { border-bottom: none; }
.vps-table tr:hover td { background: var(--ehs-bg); }
.vps-table .plan-name { font-weight: 700; color: var(--ehs-primary); }
.vps-table .price-cell { font-weight: 700; color: var(--ehs-dark); }
.vps-addons { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.vps-addons-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.vps-addon { background: var(--ehs-bg); border-radius: var(--ehs-radius); padding: 28px 20px; text-align: center; border: 1px solid var(--ehs-border); transition: var(--ehs-transition); }
.vps-addon:hover { transform: translateY(-3px); box-shadow: var(--ehs-shadow-md); border-color: var(--ehs-primary); }
.vps-addon-icon { font-size: 32px; margin-bottom: 14px; }
.vps-addon h4 { font-size: 16px; font-weight: 700; margin-bottom: 6px; }
.vps-addon p { font-size: 13px; color: var(--ehs-text-light); line-height: 1.5; margin-bottom: 12px; }
.vps-addon-badge { font-size: 11px; font-weight: 700; color: var(--ehs-accent); text-transform: uppercase; }
.vps-upgrade { padding: 80px 0; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.vps-upgrade-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.vps-upgrade-card { background: var(--ehs-white); border-radius: var(--ehs-radius-lg); padding: 36px 28px; border: 1px solid var(--ehs-border); transition: var(--ehs-transition); }
.vps-upgrade-card:hover { transform: translateY(-3px); box-shadow: var(--ehs-shadow-md); }
.vps-upgrade-card .num { font-family: var(--ehs-font-heading); font-size: 36px; font-weight: 800; color: var(--ehs-primary-light); margin-bottom: 12px; }
.vps-upgrade-card h3 { font-size: 18px; font-weight: 700; margin-bottom: 10px; }
.vps-upgrade-card p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.6; margin: 0; }
.vps-compare { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.vps-compare-table { width: 100%; max-width: 800px; margin: 0 auto; border-collapse: collapse; background: var(--ehs-white); border-radius: var(--ehs-radius); overflow: hidden; box-shadow: var(--ehs-shadow-sm); }
.vps-compare-table th { background: var(--ehs-dark); color: #fff; padding: 14px 20px; text-align: center; font-size: 14px; }
.vps-compare-table th:first-child { text-align: left; }
.vps-compare-table td { padding: 12px 20px; border-bottom: 1px solid var(--ehs-border); font-size: 14px; text-align: center; }
.vps-compare-table td:first-child { text-align: left; font-weight: 600; color: var(--ehs-dark); }
.vps-compare-cta { text-align: center; padding: 32px; background: var(--ehs-bg); border-radius: var(--ehs-radius); max-width: 800px; margin: 32px auto 0; }
.vps-compare-cta h4 { font-size: 18px; margin-bottom: 8px; }
.vps-compare-cta p { color: var(--ehs-text-light); font-size: 14px; margin-bottom: 16px; }
.vps-infra { padding: 80px 0; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.vps-infra-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.vps-infra-card { background: var(--ehs-white); border-radius: var(--ehs-radius-lg); padding: 32px 24px; border: 1px solid var(--ehs-border); transition: var(--ehs-transition); }
.vps-infra-card:hover { transform: translateY(-3px); box-shadow: var(--ehs-shadow-md); }
.vps-infra-card-icon { font-size: 36px; margin-bottom: 16px; }
.vps-infra-card h3 { font-size: 18px; font-weight: 700; margin-bottom: 8px; }
.vps-infra-card p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.6; margin: 0; }
.vps-vmware { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.vps-vmware-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.vps-vmware-card { background: var(--ehs-bg); border-radius: var(--ehs-radius-lg); padding: 32px 24px; border: 1px solid transparent; transition: var(--ehs-transition); }
.vps-vmware-card:hover { border-color: var(--ehs-border); box-shadow: var(--ehs-shadow-md); background: var(--ehs-white); }
.vps-vmware-card h3 { font-size: 18px; font-weight: 700; margin-bottom: 8px; }
.vps-vmware-card p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.6; margin: 0; }
.vps-os { padding: 80px 0; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.vps-os-grid { display: flex; justify-content: center; gap: 20px; flex-wrap: wrap; }
.vps-os-badge { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius); padding: 16px 28px; font-weight: 700; font-size: 15px; color: var(--ehs-dark); transition: var(--ehs-transition); }
.vps-os-badge:hover { border-color: var(--ehs-primary); box-shadow: var(--ehs-shadow-sm); }

@media (max-width: 1024px) {
    .vps-addons-grid { grid-template-columns: repeat(2, 1fr); }
    .vps-upgrade-grid, .vps-infra-grid, .vps-vmware-grid { grid-template-columns: 1fr; max-width: 500px; margin: 0 auto; }
}
@media (max-width: 768px) {
    .vps-addons-grid { grid-template-columns: 1fr; }
}


/* --- 7. MANAGED VPS --- */
.mvps-hero { background: var(--ehs-gradient); padding: 180px 0 100px; margin-top: -80px; text-align: center; position: relative; overflow: hidden; }
.mvps-hero-shield { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 600px; height: 600px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.03); pointer-events: none; animation: mvps-shield-pulse 4s ease-in-out infinite; }
.mvps-hero-shield-2 { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 450px; height: 450px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.04); pointer-events: none; animation: mvps-shield-pulse 4s 0.8s ease-in-out infinite; }
.mvps-hero-shield-3 { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 300px; height: 300px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.05); pointer-events: none; animation: mvps-shield-pulse 4s 1.6s ease-in-out infinite; }
@keyframes mvps-shield-pulse { 0%, 100% { transform: translate(-50%,-50%) scale(1); opacity: 0.5; } 50% { transform: translate(-50%,-50%) scale(1.08); opacity: 1; } }
.mvps-hero-orb { position: absolute; border-radius: 50%; pointer-events: none; }
.mvps-hero-orb-1 { width: 400px; height: 400px; top: -15%; right: -8%; background: radial-gradient(circle, rgba(16,185,129,0.1) 0%, transparent 70%); animation: mvps-float-1 10s ease-in-out infinite; }
.mvps-hero-orb-2 { width: 350px; height: 350px; bottom: -20%; left: -6%; background: radial-gradient(circle, rgba(255,107,53,0.1) 0%, transparent 70%); animation: mvps-float-2 8s ease-in-out infinite; }
@keyframes mvps-float-1 { 0%, 100% { transform: translate(0,0) scale(1); } 50% { transform: translate(-20px,15px) scale(1.05); } }
@keyframes mvps-float-2 { 0%, 100% { transform: translate(0,0) scale(1); } 50% { transform: translate(15px,-20px) scale(1.06); } }
.mvps-hero-dots { position: absolute; inset: 0; pointer-events: none; }
.mvps-hero-dot { position: absolute; width: 4px; height: 4px; border-radius: 50%; background: rgba(16,185,129,0.4); animation: mvps-blink 2s ease-in-out infinite; }
.mvps-hero-dot-1 { top: 25%; left: 10%; animation-delay: 0s; }
.mvps-hero-dot-2 { top: 18%; right: 15%; animation-delay: 0.4s; }
.mvps-hero-dot-3 { bottom: 30%; left: 20%; animation-delay: 0.8s; }
.mvps-hero-dot-4 { top: 40%; right: 8%; animation-delay: 1.2s; }
.mvps-hero-dot-5 { bottom: 20%; right: 25%; animation-delay: 0.6s; }
.mvps-hero-dot-6 { top: 55%; left: 8%; animation-delay: 1.0s; }
.mvps-hero-dot-7 { bottom: 35%; right: 12%; animation-delay: 1.4s; }
.mvps-hero-dot-8 { top: 15%; left: 30%; animation-delay: 0.2s; }
@keyframes mvps-blink { 0%, 100% { opacity: 0.2; } 50% { opacity: 1; } }
.mvps-hero-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px); background-size: 60px 60px; pointer-events: none; mask-image: radial-gradient(ellipse 65% 65% at 50% 50%, black 20%, transparent 70%); -webkit-mask-image: radial-gradient(ellipse 65% 65% at 50% 50%, black 20%, transparent 70%); }
.mvps-hero-content { position: relative; z-index: 2; }
.mvps-hero-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,0.08); backdrop-filter: blur(10px); color: rgba(255,255,255,0.85); padding: 8px 18px; border-radius: 50px; font-size: 13px; font-weight: 600; margin-bottom: 24px; border: 1px solid rgba(255,255,255,0.1); animation: mvps-fade-up 0.6s ease-out both; }
.mvps-hero h1 { font-size: clamp(32px, 5vw, 48px); font-weight: 800; color: #fff; margin-bottom: 20px; position: relative; animation: mvps-fade-up 0.6s 0.1s ease-out both; }
.mvps-hero-desc { font-size: 17px; color: rgba(255,255,255,0.65); max-width: 660px; margin: 0 auto 32px; line-height: 1.75; position: relative; animation: mvps-fade-up 0.6s 0.2s ease-out both; }
.mvps-hero-actions { display: flex; justify-content: center; gap: 14px; flex-wrap: wrap; animation: mvps-fade-up 0.6s 0.3s ease-out both; }
.mvps-hero-stats { display: flex; justify-content: center; gap: 40px; margin-top: 48px; animation: mvps-fade-up 0.6s 0.4s ease-out both; }
.mvps-hero-stat { text-align: center; }
.mvps-hero-stat-num { font-family: var(--ehs-font-heading); font-size: 28px; font-weight: 800; color: #fff; line-height: 1; margin-bottom: 4px; }
.mvps-hero-stat-label { font-size: 12px; color: rgba(255,255,255,0.45); text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600; }
@keyframes mvps-fade-up { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.mvps-plans { padding: 90px 0 60px; background: var(--ehs-bg); }
.mvps-plans-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; align-items: start; }
.mvps-plan { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius-lg); overflow: hidden; transition: var(--ehs-transition); display: flex; flex-direction: column; }
.mvps-plan:hover { transform: translateY(-5px); box-shadow: var(--ehs-shadow-lg); border-color: var(--ehs-primary); }
.mvps-plan.popular { border: 2px solid var(--ehs-primary); box-shadow: 0 10px 40px rgba(23,70,162,0.15); }
.mvps-plan-ribbon { background: var(--ehs-accent); color: #fff; text-align: center; padding: 6px 0; font-size: 12px; font-weight: 700; text-transform: uppercase; }
.mvps-plan-header { padding: 28px 24px 0; text-align: center; }
.mvps-plan-header h3 { font-size: 20px; font-weight: 700; margin-bottom: 4px; }
.mvps-plan-header .ideal { font-size: 12px; color: var(--ehs-accent); font-weight: 600; margin-bottom: 14px; line-height: 1.4; }
.mvps-plan-price { font-family: var(--ehs-font-heading); font-size: 28px; font-weight: 600; color: #444; margin-bottom: 16px; }
.mvps-plan-price small { font-size: 14px; font-weight: 400; color: #999; }
.mvps-plan-btn { padding: 0 24px 16px; text-align: center; }
.mvps-plan-specs { list-style: none; padding: 16px 24px; margin: 0; border-top: 1px solid var(--ehs-border); }
.mvps-plan-specs li { padding: 7px 0; font-size: 13px; color: var(--ehs-text); display: flex; align-items: center; gap: 10px; border-bottom: 1px solid #f8f8f8; }
.mvps-plan-specs li:last-child { border-bottom: none; }
.mvps-plan-specs li svg { color: var(--ehs-success); flex-shrink: 0; width: 14px; height: 14px; }
.mvps-plan-specs strong { color: var(--ehs-dark); font-weight: 700; }
.mvps-plan-pack { padding: 16px 24px; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.mvps-plan-pack-label { font-size: 11px; font-weight: 700; text-transform: uppercase; color: var(--ehs-primary); letter-spacing: 0.04em; margin-bottom: 8px; }
.mvps-plan-pack ul { list-style: none; padding: 0; margin: 0; }
.mvps-plan-pack ul li { font-size: 12px; color: var(--ehs-text-light); padding: 3px 0; display: flex; align-items: center; gap: 8px; }
.mvps-plan-pack ul li svg { width: 12px; height: 12px; color: var(--ehs-success); }
.mvps-infra { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.mvps-infra-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.mvps-infra-card { background: var(--ehs-bg); border-radius: var(--ehs-radius-lg); padding: 36px 28px; text-align: center; border: 1px solid transparent; transition: var(--ehs-transition); }
.mvps-infra-card:hover { border-color: var(--ehs-border); box-shadow: var(--ehs-shadow-md); transform: translateY(-3px); background: var(--ehs-white); }
.mvps-infra-card-icon { font-size: 40px; margin-bottom: 16px; }
.mvps-infra-card h3 { font-size: 18px; font-weight: 700; margin-bottom: 8px; }
.mvps-infra-card p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.6; margin: 0; }
.mvps-managed { padding: 80px 0; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.mvps-managed-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.mvps-managed h2 { font-size: clamp(24px, 3vw, 32px); font-weight: 800; margin-bottom: 12px; }
.mvps-managed h2 span { color: var(--ehs-primary); }
.mvps-managed > div > p { color: var(--ehs-text-light); margin-bottom: 28px; line-height: 1.7; }
.mvps-managed-list { list-style: none; }
.mvps-managed-list li { padding: 10px 0; font-size: 15px; color: var(--ehs-text); display: flex; align-items: center; gap: 12px; }
.mvps-managed-list li svg { color: var(--ehs-success); flex-shrink: 0; }
.mvps-managed-visual { text-align: center; }
.mvps-managed-icon { font-size: 120px; opacity: 0.15; }
.mvps-software { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.mvps-software-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.mvps-sw-card { text-align: center; padding: 28px 16px; background: var(--ehs-bg); border-radius: var(--ehs-radius); border: 1px solid var(--ehs-border); transition: var(--ehs-transition); }
.mvps-sw-card:hover { transform: translateY(-3px); box-shadow: var(--ehs-shadow-md); border-color: var(--ehs-primary); }
.mvps-sw-icon { font-size: 36px; margin-bottom: 12px; }
.mvps-sw-card h4 { font-size: 16px; font-weight: 700; margin-bottom: 4px; }
.mvps-sw-card p { font-size: 13px; color: var(--ehs-text-light); margin: 0; }
.mvps-faq { padding: 80px 0; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.mvps-faq-grid { display: grid; grid-template-columns: 1fr; gap: 12px; max-width: 800px; margin: 0 auto; }
.mvps-faq-item { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: 8px; overflow: hidden; }
.mvps-faq-item.active { border-left: 4px solid var(--ehs-primary); }
.mvps-faq-q { width: 100%; text-align: left; padding: 18px 20px; font-size: 15px; font-weight: 700; color: var(--ehs-dark); background: transparent; border: none; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 12px; font-family: var(--ehs-font-heading); line-height: 1.4; }
.mvps-faq-q svg { flex-shrink: 0; color: var(--ehs-text-light); transition: var(--ehs-transition); }
.mvps-faq-item.active .mvps-faq-q svg { transform: rotate(45deg); color: var(--ehs-accent); }
.mvps-faq-item.active .mvps-faq-q { color: var(--ehs-primary); }
.mvps-faq-a { display: none; padding: 0 20px 18px; font-size: 14px; color: var(--ehs-text-light); line-height: 1.7; }
.mvps-faq-item.active .mvps-faq-a { display: block; }

@media (max-width: 1024px) {
    .mvps-plans-grid { grid-template-columns: repeat(2, 1fr); }
    .mvps-infra-grid { grid-template-columns: 1fr; max-width: 500px; margin: 0 auto; }
    .mvps-managed-grid { grid-template-columns: 1fr; }
    .mvps-software-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    .mvps-hero { padding: 150px 0 70px; }
    .mvps-hero-stats { gap: 24px; }
    .mvps-hero-stat-num { font-size: 22px; }
    .mvps-hero-shield, .mvps-hero-shield-2, .mvps-hero-shield-3, .mvps-hero-dots { display: none; }
    .mvps-plans-grid { grid-template-columns: 1fr; max-width: 420px; margin: 0 auto; }
    .mvps-software-grid { grid-template-columns: 1fr; }
}


/* --- 8. EMAIL HOSTING --- */
.em-hero { background: var(--ehs-gradient); padding: 160px 0 80px; margin-top: -72px; text-align: center; position: relative; overflow: hidden; }
.em-hero::before { content: ''; position: absolute; top: -30%; right: -10%; width: 500px; height: 500px; background: radial-gradient(circle, rgba(255,107,53,0.1) 0%, transparent 70%); border-radius: 50%; }
.em-hero h1 { font-size: clamp(30px, 5vw, 44px); font-weight: 800; color: #fff; margin-bottom: 16px; position: relative; }
.em-hero h1 span { color: var(--ehs-accent); }
.em-hero-sub { font-size: 17px; color: rgba(255,255,255,0.7); max-width: 650px; margin: 0 auto; line-height: 1.7; position: relative; }
.em-plans { padding: 90px 0; background: var(--ehs-bg); }
.em-plans-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; max-width: 700px; margin: 0 auto; }
.em-plan { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius-lg); padding: 36px 28px; text-align: center; transition: var(--ehs-transition); display: flex; flex-direction: column; }
.em-plan:hover { transform: translateY(-5px); box-shadow: var(--ehs-shadow-lg); border-color: var(--ehs-primary); }
.em-plan h3 { font-size: 22px; font-weight: 700; margin-bottom: 4px; }
.em-plan .desc { font-size: 13px; color: var(--ehs-text-light); margin-bottom: 4px; }
.em-plan .per { font-size: 13px; color: var(--ehs-text-light); margin-bottom: 20px; }
.em-plan .price { font-family: var(--ehs-font-heading); font-size: 36px; font-weight: 700; color: var(--ehs-dark); margin-bottom: 20px; }
.em-plan-features { list-style: none; padding: 20px 0 24px; margin: 0; text-align: left; border-top: 1px solid var(--ehs-border); flex: 1; }
.em-plan-features li { padding: 8px 0; font-size: 14px; color: var(--ehs-text); display: flex; align-items: center; gap: 10px; }
.em-plan-features li svg { color: var(--ehs-success); flex-shrink: 0; width: 16px; height: 16px; }
.em-plan-features strong { color: var(--ehs-dark); }
.em-benefits { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.em-benefits-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.em-benefit { background: var(--ehs-bg); border-radius: var(--ehs-radius-lg); padding: 32px; text-align: center; border: 1px solid transparent; transition: var(--ehs-transition); }
.em-benefit:hover { background: var(--ehs-white); border-color: var(--ehs-border); box-shadow: var(--ehs-shadow-md); transform: translateY(-3px); }
.em-benefit-icon { width: 52px; height: 52px; border-radius: 14px; background: var(--ehs-primary-light); color: var(--ehs-primary); display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; }
.em-benefit h3 { font-size: 18px; font-weight: 700; margin-bottom: 8px; }
.em-benefit p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.6; margin: 0; }
.em-faq { padding: 80px 0; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.em-faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; max-width: 960px; margin: 0 auto; align-items: start; }
.em-faq-item { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: 8px; overflow: hidden; }
.em-faq-item.active { border-left: 4px solid var(--ehs-primary); }
.em-faq-q { width: 100%; text-align: left; padding: 18px 20px; font-size: 14px; font-weight: 700; color: var(--ehs-dark); background: transparent; border: none; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 10px; font-family: var(--ehs-font-heading); line-height: 1.4; }
.em-faq-q svg { flex-shrink: 0; color: var(--ehs-text-light); transition: var(--ehs-transition); }
.em-faq-item.active .em-faq-q svg { transform: rotate(45deg); color: var(--ehs-accent); }
.em-faq-item.active .em-faq-q { color: var(--ehs-primary); }
.em-faq-a { display: none; padding: 0 20px 18px; font-size: 13px; color: var(--ehs-text-light); line-height: 1.7; }
.em-faq-item.active .em-faq-a { display: block; }

@media (max-width: 768px) {
    .em-plans-grid { grid-template-columns: 1fr; max-width: 400px; }
    .em-benefits-grid { grid-template-columns: 1fr; }
    .em-faq-grid { grid-template-columns: 1fr; }
}


/* --- 9. SSL CERTIFICATES --- */
.ssl-hero { background: var(--ehs-gradient); padding: 160px 0 80px; margin-top: -72px; text-align: center; position: relative; overflow: hidden; }
.ssl-hero::before { content: ''; position: absolute; top: -30%; left: -10%; width: 500px; height: 500px; background: radial-gradient(circle, rgba(255,107,53,0.1) 0%, transparent 70%); border-radius: 50%; }
.ssl-hero h1 { font-size: clamp(30px, 5vw, 48px); font-weight: 800; color: #fff; margin-bottom: 16px; position: relative; }
.ssl-hero h1 span { color: var(--ehs-accent); }
.ssl-hero-sub { font-size: 17px; color: rgba(255,255,255,0.7); max-width: 650px; margin: 0 auto; line-height: 1.7; position: relative; }
.ssl-hero-trust { display: flex; justify-content: center; gap: 24px; flex-wrap: wrap; margin-top: 24px; position: relative; }
.ssl-hero-trust span { color: rgba(255,255,255,0.8); font-size: 14px; display: flex; align-items: center; gap: 8px; }
.ssl-hero-trust span svg { color: var(--ehs-success); }
.ssl-plans { padding: 90px 0; background: var(--ehs-bg); }
.ssl-plans-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px; max-width: 800px; margin: 0 auto; }
.ssl-plan { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius-lg); overflow: hidden; transition: var(--ehs-transition); display: flex; flex-direction: column; }
.ssl-plan:hover { transform: translateY(-5px); box-shadow: var(--ehs-shadow-lg); border-color: var(--ehs-primary); }
.ssl-plan-badge { background: var(--ehs-primary); color: #fff; text-align: center; padding: 8px; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; }
.ssl-plan-badge.popular { background: var(--ehs-accent); }
.ssl-plan-header { padding: 32px 28px 0; text-align: center; }
.ssl-plan-icon { font-size: 48px; margin-bottom: 16px; }
.ssl-plan-header h3 { font-size: 24px; font-weight: 700; margin-bottom: 6px; }
.ssl-plan-header .type { font-size: 13px; color: var(--ehs-text-light); margin-bottom: 20px; }
.ssl-plan-price { font-family: var(--ehs-font-heading); font-size: 36px; font-weight: 700; color: var(--ehs-dark); margin-bottom: 4px; }
.ssl-plan-price small { font-size: 14px; color: #999; font-weight: 400; }
.ssl-plan-period { font-size: 13px; color: var(--ehs-text-light); margin-bottom: 24px; }
.ssl-plan-btn { padding: 0 28px 24px; text-align: center; }
.ssl-plan-features { list-style: none; padding: 20px 28px 28px; margin: 0; border-top: 1px solid var(--ehs-border); flex: 1; }
.ssl-plan-features li { padding: 10px 0; font-size: 14px; color: var(--ehs-text); display: flex; align-items: center; gap: 10px; border-bottom: 1px solid #f8f8f8; }
.ssl-plan-features li:last-child { border-bottom: none; }
.ssl-plan-features li svg { color: var(--ehs-success); flex-shrink: 0; width: 16px; height: 16px; }
.ssl-plan-features strong { color: var(--ehs-dark); font-weight: 700; }
.ssl-free { padding: 60px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.ssl-free-box { max-width: 800px; margin: 0 auto; background: #ECFDF5; border: 1px solid #A7F3D0; border-radius: var(--ehs-radius-lg); padding: 32px 36px; display: flex; gap: 24px; align-items: flex-start; }
.ssl-free-icon { width: 48px; height: 48px; border-radius: 12px; background: #10B981; color: #fff; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ssl-free-box h3 { font-size: 18px; font-weight: 700; margin-bottom: 8px; color: #065F46; }
.ssl-free-box p { font-size: 14px; color: #047857; line-height: 1.6; margin: 0; }
.ssl-why { padding: 80px 0; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.ssl-why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.ssl-why-card { background: var(--ehs-white); border-radius: var(--ehs-radius-lg); padding: 32px; border: 1px solid var(--ehs-border); transition: var(--ehs-transition); text-align: center; }
.ssl-why-card:hover { transform: translateY(-3px); box-shadow: var(--ehs-shadow-md); border-color: var(--ehs-primary); }
.ssl-why-icon { width: 56px; height: 56px; border-radius: 14px; display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; font-size: 28px; }
.ssl-why-icon.green { background: #ECFDF5; color: #10B981; }
.ssl-why-icon.blue { background: var(--ehs-primary-light); color: var(--ehs-primary); }
.ssl-why-icon.orange { background: #FFF0E9; color: var(--ehs-accent); }
.ssl-why-card h3 { font-size: 18px; font-weight: 700; margin-bottom: 8px; }
.ssl-why-card p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.6; margin: 0; }
.ssl-compare { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.ssl-compare-table { width: 100%; max-width: 800px; margin: 0 auto; border-collapse: collapse; background: var(--ehs-white); border-radius: var(--ehs-radius); overflow: hidden; box-shadow: var(--ehs-shadow-sm); }
.ssl-compare-table th { background: var(--ehs-dark); color: #fff; padding: 14px 20px; font-size: 14px; text-align: center; }
.ssl-compare-table th:first-child { text-align: left; }
.ssl-compare-table td { padding: 12px 20px; border-bottom: 1px solid var(--ehs-border); font-size: 14px; text-align: center; }
.ssl-compare-table td:first-child { text-align: left; font-weight: 600; color: var(--ehs-dark); }
.ssl-compare-table tr:last-child td { border-bottom: none; }
.ssl-compare-table tr:hover td { background: var(--ehs-bg); }
.ssl-how { padding: 80px 0; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.ssl-how-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; max-width: 900px; margin: 0 auto; }
.ssl-how-step { text-align: center; position: relative; }
.ssl-how-num { width: 44px; height: 44px; border-radius: 50%; background: var(--ehs-primary); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 18px; margin: 0 auto 16px; font-family: var(--ehs-font-heading); }
.ssl-how-step h4 { font-size: 15px; font-weight: 700; margin-bottom: 6px; }
.ssl-how-step p { font-size: 13px; color: var(--ehs-text-light); line-height: 1.5; margin: 0; }
.ssl-faq { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.ssl-faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; max-width: 960px; margin: 0 auto; align-items: start; }
.ssl-faq-item { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: 8px; overflow: hidden; }
.ssl-faq-item.active { border-left: 4px solid var(--ehs-primary); }
.ssl-faq-q { width: 100%; text-align: left; padding: 18px 20px; font-size: 15px; font-weight: 700; color: var(--ehs-dark); background: transparent; border: none; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 12px; font-family: var(--ehs-font-heading); line-height: 1.4; }
.ssl-faq-q svg { flex-shrink: 0; color: var(--ehs-text-light); transition: var(--ehs-transition); }
.ssl-faq-item.active .ssl-faq-q svg { transform: rotate(45deg); color: var(--ehs-accent); }
.ssl-faq-item.active .ssl-faq-q { color: var(--ehs-primary); }
.ssl-faq-a { display: none; padding: 0 20px 18px; font-size: 14px; color: var(--ehs-text-light); line-height: 1.7; }
.ssl-faq-item.active .ssl-faq-a { display: block; }

@media (max-width: 768px) {
    .ssl-plans-grid { grid-template-columns: 1fr; max-width: 400px; }
    .ssl-why-grid { grid-template-columns: 1fr; }
    .ssl-how-grid { grid-template-columns: repeat(2, 1fr); }
    .ssl-faq-grid { grid-template-columns: 1fr; }
    .ssl-free-box { flex-direction: column; }
}


/* --- 10. GOOGLE WORKSPACE --- */
.gw-hero { background: var(--ehs-gradient); padding: 160px 0 80px; margin-top: -72px; text-align: center; position: relative; overflow: hidden; }
.gw-hero::before { content: ''; position: absolute; top: -30%; right: -10%; width: 500px; height: 500px; background: radial-gradient(circle, rgba(255,107,53,0.1) 0%, transparent 70%); border-radius: 50%; }
.gw-hero h1 { font-size: clamp(30px, 5vw, 44px); font-weight: 800; color: #fff; margin-bottom: 16px; position: relative; }
.gw-hero h1 span { color: var(--ehs-accent); }
.gw-hero-sub { font-size: 17px; color: rgba(255,255,255,0.7); max-width: 700px; margin: 0 auto; line-height: 1.7; position: relative; }
.gw-plans { padding: 90px 0; background: var(--ehs-bg); }
.gw-plans-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; max-width: 960px; margin: 0 auto; }
.gw-plan { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius-lg); padding: 36px 28px; text-align: center; transition: var(--ehs-transition); display: flex; flex-direction: column; }
.gw-plan:hover { transform: translateY(-5px); box-shadow: var(--ehs-shadow-lg); border-color: var(--ehs-primary); }
.gw-plan h3 { font-size: 22px; font-weight: 700; margin-bottom: 4px; }
.gw-plan .per { font-size: 13px; color: var(--ehs-text-light); margin-bottom: 20px; }
.gw-plan .price { font-family: var(--ehs-font-heading); font-size: 36px; font-weight: 700; color: var(--ehs-dark); margin-bottom: 20px; }
.gw-plan .price small { font-size: 14px; color: #999; font-weight: 400; }
.gw-plan-features { list-style: none; padding: 20px 0 24px; margin: 0; text-align: left; border-top: 1px solid var(--ehs-border); flex: 1; }
.gw-plan-features li { padding: 8px 0; font-size: 14px; color: var(--ehs-text); display: flex; align-items: center; gap: 10px; }
.gw-plan-features li svg { color: var(--ehs-success); flex-shrink: 0; width: 16px; height: 16px; }
.gw-plan-features strong { color: var(--ehs-dark); }
.gw-apps { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.gw-apps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; max-width: 700px; margin: 0 auto; }
.gw-app { text-align: center; padding: 24px 16px; background: var(--ehs-bg); border-radius: var(--ehs-radius); border: 1px solid var(--ehs-border); transition: var(--ehs-transition); }
.gw-app:hover { transform: translateY(-3px); box-shadow: var(--ehs-shadow-sm); border-color: var(--ehs-primary); }
.gw-app img { height: 32px; margin: 0 auto 10px; }
.gw-app h5 { font-size: 14px; font-weight: 700; color: var(--ehs-dark); margin: 0; }
.gw-faq { padding: 80px 0; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.gw-faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; max-width: 960px; margin: 0 auto; align-items: start; }
.gw-faq-item { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: 8px; overflow: hidden; }
.gw-faq-item.active { border-left: 4px solid var(--ehs-primary); }
.gw-faq-q { width: 100%; text-align: left; padding: 18px 20px; font-size: 14px; font-weight: 700; color: var(--ehs-dark); background: transparent; border: none; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 10px; font-family: var(--ehs-font-heading); line-height: 1.4; }
.gw-faq-q svg { flex-shrink: 0; color: var(--ehs-text-light); transition: var(--ehs-transition); }
.gw-faq-item.active .gw-faq-q svg { transform: rotate(45deg); color: var(--ehs-accent); }
.gw-faq-item.active .gw-faq-q { color: var(--ehs-primary); }
.gw-faq-a { display: none; padding: 0 20px 18px; font-size: 13px; color: var(--ehs-text-light); line-height: 1.7; }
.gw-faq-item.active .gw-faq-a { display: block; }

@media (max-width: 768px) { .gw-plans-grid { grid-template-columns: 1fr; max-width: 400px; } .gw-apps-grid { grid-template-columns: repeat(3, 1fr); } .gw-faq-grid { grid-template-columns: 1fr; } }


/* --- 11. DEFAULT PAGE --- */
.page-hero { background: var(--ehs-gradient); padding: 140px 0 60px; text-align: center; position: relative; overflow: hidden; }
.page-hero::before { content: ''; position: absolute; top: -30%; right: -10%; width: 500px; height: 500px; background: radial-gradient(circle, rgba(255,107,53,0.08) 0%, transparent 70%); border-radius: 50%; }
.page-hero h1 { font-size: clamp(28px, 4vw, 42px); font-weight: 800; color: #fff; position: relative; margin-bottom: 0; }
.page-content { padding: 60px 0 80px; background: var(--ehs-white); }
.page-container { max-width: 860px; margin: 0 auto; }
.page-body { font-size: 16px; line-height: 1.85; color: var(--ehs-text); }
.page-body h2 { font-size: 24px; font-weight: 700; margin: 36px 0 14px; color: var(--ehs-dark); }
.page-body h3 { font-size: 20px; font-weight: 700; margin: 28px 0 12px; color: var(--ehs-dark); }
.page-body h4 { font-size: 17px; font-weight: 700; margin: 24px 0 10px; color: var(--ehs-dark); }
.page-body p { margin-bottom: 18px; }
.page-body a { color: var(--ehs-primary); text-decoration: underline; }
.page-body a:hover { color: var(--ehs-accent); }
.page-body ul, .page-body ol { margin: 0 0 18px 20px; }
.page-body li { margin-bottom: 8px; }
.page-body blockquote { border-left: 4px solid var(--ehs-primary); margin: 24px 0; padding: 16px 24px; background: var(--ehs-bg); border-radius: 0 var(--ehs-radius) var(--ehs-radius) 0; font-style: italic; color: var(--ehs-text-light); }
.page-body img { max-width: 100%; height: auto; border-radius: var(--ehs-radius); margin: 20px 0; }
.page-body table { width: 100%; border-collapse: collapse; margin: 20px 0; }
.page-body th, .page-body td { border: 1px solid var(--ehs-border); padding: 10px 14px; text-align: left; font-size: 14px; }
.page-body th { background: var(--ehs-bg); font-weight: 700; }
.page-body pre { background: #1a1a2e; color: #10B981; padding: 20px; border-radius: var(--ehs-radius); overflow-x: auto; font-size: 14px; margin: 20px 0; }
.page-body code { background: var(--ehs-bg); padding: 2px 6px; border-radius: 4px; font-size: 14px; }
.page-body pre code { background: transparent; padding: 0; }
.page-body hr { border: none; border-top: 1px solid var(--ehs-border); margin: 32px 0; }
.page-body .wp-block-image { margin: 24px 0; }
.page-body .wp-block-image img { border-radius: var(--ehs-radius); }
.page-body .wp-block-gallery { margin: 24px 0; }
.page-body .wp-block-button .wp-block-button__link { background: var(--ehs-primary); color: #fff; border-radius: var(--ehs-radius-full); padding: 12px 28px; text-decoration: none; font-weight: 700; font-size: 15px; transition: var(--ehs-transition); display: inline-block; }
.page-body .wp-block-button .wp-block-button__link:hover { background: var(--ehs-primary-dark); }
.page-body .wp-block-columns { gap: 28px; margin: 24px 0; }
.page-body .wp-block-separator { border-top: 1px solid var(--ehs-border); margin: 32px 0; }
.page-body .has-text-align-center { text-align: center; }
.page-featured-img { margin: -30px auto 36px; max-width: 860px; position: relative; z-index: 3; }
.page-featured-img img { width: 100%; height: auto; border-radius: var(--ehs-radius-lg); box-shadow: var(--ehs-shadow-xl); }
@media (max-width: 768px) { .page-container { padding: 0 20px; } }


/* --- 12. 404 ERROR PAGE --- */
.error-page { background: var(--ehs-gradient); min-height: 100vh; display: flex; align-items: center; justify-content: center; text-align: center; padding: 140px 24px 80px; position: relative; overflow: hidden; }
.error-page::before { content: ''; position: absolute; top: 20%; left: 50%; transform: translateX(-50%); width: 600px; height: 600px; background: radial-gradient(circle, rgba(255,107,53,0.08) 0%, transparent 70%); border-radius: 50%; }
.error-inner { position: relative; z-index: 2; max-width: 520px; }
.error-code { font-family: var(--ehs-font-heading); font-size: clamp(80px, 15vw, 140px); font-weight: 800; color: rgba(255,255,255,0.08); line-height: 1; margin-bottom: -20px; }
.error-title { font-size: clamp(24px, 4vw, 36px); font-weight: 800; color: #fff; margin-bottom: 16px; }
.error-desc { font-size: 16px; color: rgba(255,255,255,0.6); line-height: 1.7; margin-bottom: 36px; }
.error-search { max-width: 420px; margin: 0 auto 32px; display: flex; background: rgba(255,255,255,0.08); border-radius: 60px; padding: 4px; border: 1px solid rgba(255,255,255,0.1); }
.error-search input { flex: 1; border: none; padding: 12px 18px; font-size: 14px; background: transparent; outline: none; color: #fff; border-radius: 60px; font-family: var(--ehs-font-body); }
.error-search input::placeholder { color: rgba(255,255,255,0.35); }
.error-search button { background: var(--ehs-accent); color: #fff; border: none; padding: 0 24px; height: 42px; border-radius: 60px; font-weight: 700; font-size: 13px; cursor: pointer; font-family: var(--ehs-font-heading); }
.error-links { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; }
.error-links a { color: rgba(255,255,255,0.7); font-size: 14px; padding: 8px 20px; border: 1px solid rgba(255,255,255,0.15); border-radius: 8px; text-decoration: none; transition: all 0.2s; }
.error-links a:hover { color: #fff; background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.3); }


/* --- 13. SINGLE POST --- */
.blog-hero { background: var(--ehs-gradient); padding: 140px 0 60px; text-align: center; position: relative; overflow: hidden; }
.blog-hero::before { content: ''; position: absolute; top: -30%; right: -10%; width: 500px; height: 500px; background: radial-gradient(circle, rgba(255,107,53,0.08) 0%, transparent 70%); border-radius: 50%; }
.blog-hero-inner { position: relative; z-index: 2; max-width: 760px; margin: 0 auto; }
.blog-hero-cat { display: inline-block; background: rgba(255,255,255,0.1); color: rgba(255,255,255,0.85); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; padding: 6px 16px; border-radius: 20px; margin-bottom: 16px; border: 1px solid rgba(255,255,255,0.12); }
.blog-hero-cat a { color: inherit; text-decoration: none; }
.blog-hero h1 { font-size: clamp(26px, 4vw, 40px); font-weight: 800; color: #fff; line-height: 1.25; margin-bottom: 16px; }
.blog-hero-meta { display: flex; justify-content: center; align-items: center; gap: 20px; flex-wrap: wrap; color: rgba(255,255,255,0.55); font-size: 13px; }
.blog-content { padding: 60px 0 80px; background: var(--ehs-white); }
.blog-article { max-width: 760px; margin: 0 auto; }
.blog-featured-img { margin: -40px 0 36px; position: relative; z-index: 3; }
.blog-featured-img img { width: 100%; height: auto; border-radius: var(--ehs-radius-lg); box-shadow: var(--ehs-shadow-xl); }
.blog-body { font-size: 16px; line-height: 1.85; color: var(--ehs-text); }
.blog-body h2 { font-size: 24px; font-weight: 700; margin: 36px 0 14px; color: var(--ehs-dark); }
.blog-body h3 { font-size: 20px; font-weight: 700; margin: 28px 0 12px; color: var(--ehs-dark); }
.blog-body h4 { font-size: 17px; font-weight: 700; margin: 24px 0 10px; color: var(--ehs-dark); padding-left: 0; }
.blog-body p { margin-bottom: 18px; }
.blog-body a { color: var(--ehs-primary); text-decoration: underline; }
.blog-body ul, .blog-body ol { margin: 0 0 18px 20px; }
.blog-body li { margin-bottom: 8px; }
.blog-body blockquote { border-left: 4px solid var(--ehs-primary); margin: 24px 0; padding: 16px 24px; background: var(--ehs-bg); border-radius: 0 var(--ehs-radius) var(--ehs-radius) 0; font-style: italic; color: var(--ehs-text-light); }
.blog-body blockquote p:last-child { margin-bottom: 0; }
.blog-body img { max-width: 100%; height: auto; border-radius: var(--ehs-radius); margin: 20px 0; box-shadow: 0 4px 20px rgba(0,0,0,0.08); }
.blog-body .wp-block-image img, .blog-body .wp-caption img { box-shadow: 0 4px 20px rgba(0,0,0,0.08); }
.blog-body .wp-caption-text { font-size: 13px; color: var(--ehs-text-light); text-align: center; margin-top: 8px; font-style: italic; }
.blog-body pre { background: #0d1117; color: #e6edf3; padding: 0; border-radius: var(--ehs-radius); overflow: hidden; font-size: 14px; margin: 24px 0; position: relative; border: 1px solid #30363d; }
.blog-body pre::before { content: ''; display: block; padding: 10px 16px; background: #161b22; border-bottom: 1px solid #30363d; font-family: var(--ehs-font-body); font-size: 12px; color: #8b949e; }
.blog-body pre code { display: block; padding: 16px 20px; overflow-x: auto; background: transparent; font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace; font-size: 13px; line-height: 1.7; color: #e6edf3; border-radius: 0; }
.blog-code-wrap { position: relative; }
.blog-code-wrap .copy-btn { position: absolute; top: 6px; right: 8px; background: #30363d; color: #8b949e; border: 1px solid #484f58; padding: 4px 10px; border-radius: 6px; font-size: 11px; font-weight: 600; cursor: pointer; font-family: var(--ehs-font-body); transition: all 0.2s; z-index: 2; }
.blog-code-wrap .copy-btn:hover { background: #484f58; color: #e6edf3; }
.blog-code-wrap .copy-btn.copied { background: #238636; color: #fff; border-color: #238636; }
.blog-body code { background: #f0f2f5; padding: 2px 7px; border-radius: 5px; font-size: 0.88em; font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace; color: #d63384; border: 1px solid #e2e6ea; white-space: nowrap; }
.blog-body pre code { background: transparent; padding: 16px 20px; color: #e6edf3; border: none; white-space: pre; }
.blog-body table { width: 100%; border-collapse: collapse; margin: 24px 0; border-radius: var(--ehs-radius); overflow: hidden; border: 1px solid var(--ehs-border); }
.blog-body th, .blog-body td { border: 1px solid var(--ehs-border); padding: 12px 16px; text-align: left; font-size: 14px; }
.blog-body th { background: var(--ehs-dark); color: #fff; font-weight: 700; font-size: 13px; }
.blog-body tr:nth-child(even) td { background: var(--ehs-bg); }
.blog-body .wp-block-quote.is-style-plain { border-left-color: var(--ehs-accent); background: #FFF7ED; }
.blog-body .wp-block-quote.is-style-plain cite { color: var(--ehs-accent); }
.blog-tags { margin-top: 36px; padding-top: 24px; border-top: 1px solid var(--ehs-border); display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.blog-tags-label { font-size: 13px; font-weight: 700; color: var(--ehs-dark); margin-right: 8px; }
.blog-tags a { font-size: 12px; color: var(--ehs-primary); background: var(--ehs-primary-light); padding: 5px 12px; border-radius: 20px; text-decoration: none; transition: var(--ehs-transition); }
.blog-tags a:hover { background: var(--ehs-primary); color: #fff; }
.blog-author { margin-top: 36px; padding: 28px; background: var(--ehs-bg); border-radius: var(--ehs-radius-lg); display: flex; gap: 20px; align-items: center; }
.blog-author-avatar { width: 60px; height: 60px; border-radius: 50%; background: var(--ehs-primary-light); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 22px; color: var(--ehs-primary); flex-shrink: 0; }
.blog-author-name { font-weight: 700; font-size: 16px; color: var(--ehs-dark); margin-bottom: 4px; }
.blog-author-bio { font-size: 14px; color: var(--ehs-text-light); line-height: 1.5; margin: 0; }
.blog-nav { margin-top: 36px; display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.blog-nav-link { padding: 20px; background: var(--ehs-bg); border-radius: var(--ehs-radius); text-decoration: none; transition: var(--ehs-transition); border: 1px solid var(--ehs-border); }
.blog-nav-link:hover { box-shadow: var(--ehs-shadow-md); border-color: var(--ehs-primary); }
.blog-nav-label { font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--ehs-text-light); font-weight: 600; margin-bottom: 6px; display: block; }
.blog-nav-title { font-size: 14px; font-weight: 700; color: var(--ehs-dark); line-height: 1.4; }
.blog-nav-link.next { text-align: right; }
.blog-comments { margin-top: 48px; padding-top: 36px; border-top: 1px solid var(--ehs-border); }
@media (max-width: 768px) { .blog-nav { grid-template-columns: 1fr; } }


/* --- 14. DOMAIN WHOIS (Scoped properly for template) --- */
.page-template-domain-whois .wh-hero { padding: 160px 0 80px; margin-top: -72px; }
.wh-search-form { max-width: 680px; margin: 0 auto; display: flex; align-items: center; background: #fff; border-radius: 60px; padding: 5px 5px 5px 8px; box-shadow: 0 20px 60px rgba(0,0,0,0.15); position: relative; z-index: 2; }
.wh-search-form input { flex: 1; border: none; padding: 14px 20px; font-size: 16px; background: transparent; outline: none; color: var(--ehs-dark); border-radius: 60px; height: 52px; font-family: var(--ehs-font-body); }
.wh-search-form button { background: var(--ehs-accent); color: #fff; border: none; padding: 0 36px; height: 52px; border-radius: 60px; font-family: var(--ehs-font-heading); font-weight: 700; font-size: 15px; cursor: pointer; transition: var(--ehs-transition); white-space: nowrap; flex-shrink: 0; }
.wh-search-form button:hover { background: var(--ehs-accent-hover); }
.wh-results { padding: 60px 0 80px; background: var(--ehs-bg); }
.wh-results-container { max-width: 900px; margin: 0 auto; }
.wh-available { background: #d1e7dd; border: 1px solid #badbcc; border-radius: var(--ehs-radius); padding: 24px 32px; text-align: center; margin-bottom: 28px; }
.wh-available h3 { color: #0f5132; font-size: 20px; margin-bottom: 8px; }
.wh-available p { color: #0f5132; margin-bottom: 16px; }
.wh-error { background: #f8d7da; border: 1px solid #f5c6cb; border-radius: var(--ehs-radius); padding: 20px 28px; color: #842029; margin-bottom: 28px; font-weight: 600; }
.wh-info-card { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius); margin-bottom: 20px; overflow: hidden; }
.wh-info-head { padding: 16px 24px; background: var(--ehs-bg); border-bottom: 1px solid var(--ehs-border); display: flex; align-items: center; gap: 10px; }
.wh-info-head h3 { font-size: 16px; font-weight: 700; margin: 0; }
.wh-info-head svg { color: var(--ehs-primary); }
.wh-table { width: 100%; }
.wh-table td { padding: 10px 24px; border-bottom: 1px solid #f5f5f5; font-size: 14px; }
.wh-table td:first-child { font-weight: 600; color: var(--ehs-dark); width: 180px; }
.wh-table tr:last-child td { border-bottom: none; }
.wh-raw { padding: 20px 24px; }
.wh-raw pre { background: #1a1a2e; color: #10B981; padding: 20px; border-radius: 8px; font-size: 12px; overflow-x: auto; white-space: pre-wrap; word-break: break-all; max-height: 400px; overflow-y: auto; }
.wh-raw-toggle { cursor: pointer; user-select: none; }
.wh-faq-section { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
@media (max-width: 768px) { .wh-search-form { flex-direction: column; border-radius: var(--ehs-radius); padding: 8px; } .wh-search-form input { border-radius: var(--ehs-radius); } .wh-search-form button { border-radius: var(--ehs-radius); width: 100%; } .wh-table td:first-child { width: 120px; } }


/* --- 15. RESELLER HOSTING --- */
.rh-hero { background: var(--ehs-gradient); padding: 180px 0 100px; margin-top: -80px; text-align: center; position: relative; overflow: hidden; }
.rh-hero-orb { position: absolute; border-radius: 50%; pointer-events: none; }
.rh-hero-orb-1 { width: 450px; height: 450px; top: -15%; left: -8%; background: radial-gradient(circle, rgba(255,107,53,0.12) 0%, transparent 70%); animation: rh-float-1 9s ease-in-out infinite; }
.rh-hero-orb-2 { width: 350px; height: 350px; bottom: -20%; right: -5%; background: radial-gradient(circle, rgba(23,70,162,0.18) 0%, transparent 70%); animation: rh-float-2 11s ease-in-out infinite; }
.rh-hero-orb-3 { width: 180px; height: 180px; top: 25%; right: 18%; background: radial-gradient(circle, rgba(124,58,237,0.08) 0%, transparent 70%); animation: rh-float-3 7s ease-in-out infinite; }
@keyframes rh-float-1 { 0%, 100% { transform: translate(0,0) scale(1); } 50% { transform: translate(25px,15px) scale(1.06); } }
@keyframes rh-float-2 { 0%, 100% { transform: translate(0,0) scale(1); } 50% { transform: translate(-20px,-20px) scale(1.08); } }
@keyframes rh-float-3 { 0%, 100% { transform: translate(0,0); } 50% { transform: translate(-15px,18px); } }
.rh-hero-network { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.rh-hero-node { position: absolute; width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,0.08); box-shadow: 0 0 12px rgba(255,255,255,0.04); }
.rh-hero-node::after { content: ''; position: absolute; top: 50%; left: 50%; width: 3px; height: 3px; border-radius: 50%; background: rgba(255,255,255,0.15); transform: translate(-50%, -50%); animation: rh-pulse 3s ease-in-out infinite; }
.rh-hero-node-1 { top: 20%; left: 12%; animation-delay: 0s; }
.rh-hero-node-2 { top: 35%; right: 15%; animation-delay: 0.5s; }
.rh-hero-node-3 { bottom: 30%; left: 22%; animation-delay: 1s; }
.rh-hero-node-4 { top: 15%; right: 30%; animation-delay: 1.5s; }
.rh-hero-node-5 { bottom: 25%; right: 10%; animation-delay: 0.8s; }
.rh-hero-node-6 { top: 55%; left: 8%; animation-delay: 1.2s; }
@keyframes rh-pulse { 0%, 100% { opacity: 0.3; transform: translate(-50%,-50%) scale(1); } 50% { opacity: 1; transform: translate(-50%,-50%) scale(2); } }
.rh-hero-shapes { position: absolute; inset: 0; pointer-events: none; }
.rh-hero-shape { position: absolute; border: 1px solid rgba(255,255,255,0.05); }
.rh-hero-shape-1 { width: 50px; height: 50px; top: 22%; right: 8%; border-radius: 4px; transform: rotate(25deg); animation: rh-spin 22s linear infinite; }
.rh-hero-shape-2 { width: 35px; height: 35px; bottom: 35%; left: 15%; border-radius: 50%; border-color: rgba(255,107,53,0.08); animation: rh-spin 16s linear infinite reverse; }
.rh-hero-shape-3 { width: 65px; height: 65px; top: 45%; right: 22%; border-radius: 4px; transform: rotate(-10deg); border-color: rgba(255,255,255,0.03); animation: rh-spin 28s linear infinite; }
@keyframes rh-spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.rh-hero-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,0.015) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.015) 1px, transparent 1px); background-size: 50px 50px; pointer-events: none; mask-image: radial-gradient(ellipse 60% 60% at 50% 50%, black 20%, transparent 70%); -webkit-mask-image: radial-gradient(ellipse 60% 60% at 50% 50%, black 20%, transparent 70%); }
.rh-hero-content { position: relative; z-index: 2; }
.rh-hero-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,0.08); backdrop-filter: blur(10px); color: rgba(255,255,255,0.85); padding: 8px 18px; border-radius: 50px; font-size: 13px; font-weight: 600; margin-bottom: 24px; border: 1px solid rgba(255,255,255,0.1); animation: rh-fade-up 0.6s ease-out both; }
.rh-hero h1 { font-size: clamp(32px, 5vw, 52px); font-weight: 800; color: #fff; margin-bottom: 20px; position: relative; animation: rh-fade-up 0.6s 0.1s ease-out both; }
.rh-hero h1 span { color: var(--ehs-accent); }
.rh-hero-sub { font-size: 17px; color: rgba(255,255,255,0.65); max-width: 640px; margin: 0 auto 32px; line-height: 1.75; position: relative; animation: rh-fade-up 0.6s 0.2s ease-out both; }
.rh-hero-actions { display: flex; justify-content: center; gap: 14px; flex-wrap: wrap; animation: rh-fade-up 0.6s 0.3s ease-out both; }
.rh-hero-stats { display: flex; justify-content: center; gap: 40px; margin-top: 48px; animation: rh-fade-up 0.6s 0.4s ease-out both; }
.rh-hero-stat { text-align: center; }
.rh-hero-stat-num { font-family: var(--ehs-font-heading); font-size: 28px; font-weight: 800; color: #fff; line-height: 1; margin-bottom: 4px; }
.rh-hero-stat-label { font-size: 12px; color: rgba(255,255,255,0.45); text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600; }
@keyframes rh-fade-up { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.rh-plans { padding: 90px 0 60px; background: var(--ehs-bg); }
.rh-plans-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; align-items: start; }
.rh-plan { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius-lg); overflow: hidden; transition: var(--ehs-transition); display: flex; flex-direction: column; }
.rh-plan:hover { transform: translateY(-5px); box-shadow: var(--ehs-shadow-lg); border-color: var(--ehs-primary); }
.rh-plan.popular { border: 2px solid var(--ehs-primary); transform: scale(1.02); z-index: 2; box-shadow: 0 10px 40px rgba(23,70,162,0.15); }
.rh-plan-ribbon { background: var(--ehs-accent); color: #fff; text-align: center; padding: 6px 0; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; }
.rh-plan-header { padding: 28px 24px 0; text-align: center; }
.rh-plan-header h3 { font-size: 22px; font-weight: 700; margin-bottom: 8px; }
.rh-plan-header p { font-size: 13px; color: var(--ehs-text-light); line-height: 1.5; min-height: 40px; margin-bottom: 16px; }
.rh-plan-price { font-family: var(--ehs-font-heading); font-size: 28px; font-weight: 600; color: #444; margin-bottom: 16px; }
.rh-plan-price small { font-size: 14px; font-weight: 400; color: #999; }
.rh-plan-btn { padding: 0 24px 20px; text-align: center; }
.rh-specs { background: var(--ehs-bg); margin: 0 16px 16px; padding: 10px 16px; border-radius: 8px; text-align: center; }
.rh-specs-label { font-size: 11px; text-transform: uppercase; color: var(--ehs-text-light); letter-spacing: 0.05em; font-weight: 600; }
.rh-specs-value { font-size: 14px; color: var(--ehs-primary); font-weight: 700; }
.rh-plan-features { list-style: none; padding: 16px 24px; margin: 0; border-top: 1px solid var(--ehs-border); flex: 1; }
.rh-plan-features li { padding: 8px 0; font-size: 14px; color: var(--ehs-text); display: flex; align-items: center; gap: 10px; border-bottom: 1px solid #f8f8f8; }
.rh-plan-features li:last-child { border-bottom: none; }
.rh-plan-features li svg { color: var(--ehs-success); flex-shrink: 0; width: 16px; height: 16px; }
.rh-plan-features strong { color: var(--ehs-dark); font-weight: 700; }
.rh-partners { display: flex; align-items: center; justify-content: center; gap: 10px; padding: 24px 0 0; flex-wrap: wrap; }
.rh-partners-label { font-size: 13px; color: #888; font-weight: 600; margin-right: 8px; }
.rh-partners img { height: 26px; width: auto; opacity: 0.6; filter: brightness(0); transition: var(--ehs-transition); }
.rh-partners img:hover { opacity: 0.9; }
.rh-partners-divider { width: 1px; height: 20px; background: #bbb; margin: 0 6px; }
.rh-features { padding: 90px 0; background: var(--ehs-white); }
.rh-features-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.rh-feature { background: var(--ehs-white); padding: 28px 24px; border-radius: var(--ehs-radius); border: 1px solid var(--ehs-border); display: flex; gap: 20px; transition: var(--ehs-transition); }
.rh-feature:hover { transform: translateY(-4px); box-shadow: var(--ehs-shadow-md); border-color: var(--ehs-primary); }
.rh-feature-icon { flex-shrink: 0; width: 48px; height: 48px; background: var(--ehs-primary-light); color: var(--ehs-primary); border-radius: 10px; display: flex; align-items: center; justify-content: center; }
.rh-feature:hover .rh-feature-icon { background: var(--ehs-primary); color: #fff; }
.rh-feature h3 { font-size: 16px; font-weight: 700; margin-bottom: 6px; }
.rh-feature p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.5; margin: 0; }
.rh-alt { padding: 80px 0; }
.rh-alt.bg-grey { background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.rh-alt.bg-white { background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.rh-alt-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.rh-alt-img { border-radius: var(--ehs-radius); box-shadow: var(--ehs-shadow-lg); transition: var(--ehs-transition); width: 100%; }
.rh-alt-img:hover { transform: translateY(-4px); }
.rh-alt-logo { max-width: 220px; margin-bottom: 24px; }
.rh-info-list { list-style: none; }
.rh-info-list li { padding: 14px 0; font-size: 15px; color: var(--ehs-text); display: flex; align-items: flex-start; gap: 14px; border-bottom: 1px solid #f0f0f0; }
.rh-info-list li:last-child { border-bottom: none; }
.rh-info-list li svg { color: var(--ehs-success); flex-shrink: 0; margin-top: 3px; }
.rh-info-list strong { color: var(--ehs-dark); }
.rh-backup-features { display: flex; flex-direction: column; gap: 14px; margin-top: 24px; }
.rh-backup-item { display: flex; align-items: center; gap: 14px; font-size: 15px; color: var(--ehs-text); }
.rh-backup-item-icon { width: 36px; height: 36px; border-radius: 50%; background: #FFF0E9; color: var(--ehs-accent); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.rh-checklist { padding: 80px 0; background: var(--ehs-bg); border-top: 1px solid var(--ehs-border); }
.rh-checklist-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; max-width: 900px; margin: 0 auto; }
.rh-checklist-item { display: flex; align-items: center; gap: 12px; font-size: 15px; font-weight: 600; color: var(--ehs-dark); padding: 16px 20px; background: var(--ehs-white); border-radius: var(--ehs-radius); border: 1px solid var(--ehs-border); }
.rh-checklist-item svg { color: var(--ehs-success); flex-shrink: 0; }
.rh-faq { padding: 80px 0; background: var(--ehs-white); border-top: 1px solid var(--ehs-border); }
.rh-faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; max-width: 960px; margin: 0 auto; align-items: start; }
.rh-faq-item { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: 8px; overflow: hidden; }
.rh-faq-item.active { border-left: 4px solid var(--ehs-primary); }
.rh-faq-q { width: 100%; text-align: left; padding: 18px 20px; font-size: 15px; font-weight: 700; color: var(--ehs-dark); background: transparent; border: none; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 12px; font-family: var(--ehs-font-heading); line-height: 1.4; }
.rh-faq-q svg { flex-shrink: 0; color: var(--ehs-text-light); transition: var(--ehs-transition); }
.rh-faq-item.active .rh-faq-q svg { transform: rotate(45deg); color: var(--ehs-accent); }
.rh-faq-item.active .rh-faq-q { color: var(--ehs-primary); }
.rh-faq-a { display: none; padding: 0 20px 18px; font-size: 14px; color: var(--ehs-text-light); line-height: 1.7; }
.rh-faq-item.active .rh-faq-a { display: block; }

@media (max-width: 1024px) {
    .rh-plans-grid { grid-template-columns: repeat(2, 1fr); }
    .rh-plan.popular { transform: scale(1); }
    .rh-features-grid { grid-template-columns: repeat(2, 1fr); }
    .rh-alt-grid { grid-template-columns: 1fr; }
    .rh-faq-grid { grid-template-columns: 1fr; }
    .rh-checklist-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    .rh-hero { padding: 150px 0 70px; }
    .rh-hero-stats { gap: 24px; }
    .rh-hero-stat-num { font-size: 22px; }
    .rh-hero-network, .rh-hero-shapes { display: none; }
    .rh-plans-grid { grid-template-columns: 1fr; max-width: 420px; margin: 0 auto; }
    .rh-features-grid { grid-template-columns: 1fr; }
    .rh-checklist-grid { grid-template-columns: 1fr; }
}

/* --- 16. SEARCH RESULTS --- */
.search-hero { background: var(--ehs-gradient); padding: 140px 0 60px; text-align: center; position: relative; overflow: hidden; }
.search-hero h1 { font-size: clamp(26px, 4vw, 38px); font-weight: 800; color: #fff; margin-bottom: 16px; position: relative; }
.search-hero h1 span { color: var(--ehs-accent); }
.search-hero-form { max-width: 600px; margin: 0 auto; display: flex; background: #fff; border-radius: 60px; padding: 5px 5px 5px 8px; box-shadow: 0 20px 60px rgba(0,0,0,0.15); position: relative; z-index: 2; }
.search-hero-form input { flex: 1; border: none; padding: 14px 20px; font-size: 16px; background: transparent; outline: none; color: var(--ehs-dark); border-radius: 60px; height: 48px; font-family: var(--ehs-font-body); }
.search-hero-form button { background: var(--ehs-accent); color: #fff; border: none; padding: 0 28px; height: 48px; border-radius: 60px; font-family: var(--ehs-font-heading); font-weight: 700; font-size: 14px; cursor: pointer; white-space: nowrap; flex-shrink: 0; }
.search-hero-count { font-size: 14px; color: rgba(255,255,255,0.5); margin-top: 14px; position: relative; }
.search-content { padding: 50px 0 80px; background: var(--ehs-bg); }
.search-results-list { max-width: 800px; margin: 0 auto; display: flex; flex-direction: column; gap: 16px; }
.search-result { background: var(--ehs-white); border: 1px solid var(--ehs-border); border-radius: var(--ehs-radius); padding: 24px 28px; transition: var(--ehs-transition); text-decoration: none; display: block; }
.search-result:hover { box-shadow: var(--ehs-shadow-md); border-color: var(--ehs-primary); transform: translateY(-2px); }
.search-result-type { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: var(--ehs-primary); margin-bottom: 6px; }
.search-result h2 { font-size: 18px; font-weight: 700; color: var(--ehs-dark); margin-bottom: 8px; line-height: 1.35; }
.search-result p { font-size: 14px; color: var(--ehs-text-light); line-height: 1.6; margin: 0; }
.search-result-url { font-size: 12px; color: var(--ehs-success); margin-top: 8px; display: block; }
.search-no-results { text-align: center; padding: 60px 0; max-width: 500px; margin: 0 auto; }
.search-no-results h2 { margin-bottom: 12px; }
.search-no-results p { color: var(--ehs-text-light); margin-bottom: 24px; }
.search-pagination { margin-top: 36px; display: flex; justify-content: center; gap: 6px; }
.search-pagination a, .search-pagination span { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 8px; font-size: 14px; font-weight: 600; text-decoration: none; transition: var(--ehs-transition); }
.search-pagination a { color: var(--ehs-text); background: var(--ehs-white); border: 1px solid var(--ehs-border); }
.search-pagination a:hover { background: var(--ehs-primary); color: #fff; border-color: var(--ehs-primary); }
.search-pagination .current { background: var(--ehs-primary); color: #fff; border: 1px solid var(--ehs-primary); }

@media (max-width: 768px) { .search-hero-form { flex-direction: column; border-radius: var(--ehs-radius); padding: 8px; } .search-hero-form input { border-radius: var(--ehs-radius); } .search-hero-form button { border-radius: var(--ehs-radius); width: 100%; } }

/* ============================================
   GLOBAL MOBILE HERO FIX
   Overrides all hero margin-top on mobile
   since header is solid dark (not transparent)
============================================ */
@media (max-width: 1024px) {
    .ehs-hero,
    .wh-hero,
    .rh-hero,
    .vps-hero,
    .mvps-hero,
    .dom-hero,
    .dt-hero,
    .em-hero,
    .ssl-hero,
    .gw-hero,
    .blog-hero,
    .archive-hero,
    .search-hero,
    .page-hero,
    .error-page {
        margin-top: 0 !important;
    }
}

/* ============================================
   GLOBAL FAQ SHARED STYLES
   Common styles for all FAQ sections
============================================ */
[class$="-faq-item"],
[class*="-faq-item "] {
    background: var(--ehs-white);
    border: 1px solid var(--ehs-border);
    border-radius: 8px;
    overflow: hidden;
}
[class$="-faq-item"].active,
[class*="-faq-item "].active {
    border-left: 4px solid var(--ehs-primary);
}