/* ============================================================ Gestoria LP -- Main Stylesheet Professional immigration services site Color scheme: Dark (#0a0a0a) + Silver/Platinum (#c0c0c0) Premium luxury aesthetic matching logo identity ============================================================ */ /* ----- CSS Custom Properties ----- */ :root { /* Brand colors -- Dark & Silver */ --color-primary: #0a0a0a; --color-primary-dark: #000000; --color-primary-light: #1a1a1a; --color-accent: #c0c0c0; --color-accent-dark: #999999; --color-accent-light: #e0e0e0; /* Metallic gradients */ --gradient-silver: linear-gradient(135deg, #b8b8b8 0%, #e8e8e8 25%, #c0c0c0 50%, #d4d4d4 75%, #b0b0b0 100%); --gradient-dark: linear-gradient(135deg, #0a0a0a 0%, #1a1a1a 50%, #111111 100%); --gradient-hero: linear-gradient(135deg, #000000 0%, #1a1a1a 40%, #0d0d0d 100%); /* Neutrals */ --color-white: #FFFFFF; --color-off-white: #111111; --color-gray-100: #1a1a1a; --color-gray-200: #2a2a2a; --color-gray-300: #3a3a3a; --color-gray-400: #555555; --color-gray-500: #777777; --color-gray-600: #999999; --color-gray-700: #bbbbbb; --color-gray-800: #d4d4d4; --color-gray-900: #e8e8e8; /* Semantic */ --color-success: #28A745; --color-danger: #DC3545; --color-warning: #FFC107; --color-info: #17A2B8; /* Typography */ --font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; --font-size-xs: 0.75rem; --font-size-sm: 0.875rem; --font-size-base: 1rem; --font-size-md: 1.125rem; --font-size-lg: 1.25rem; --font-size-xl: 1.5rem; --font-size-2xl: 2rem; --font-size-3xl: 2.5rem; --font-size-4xl: 3rem; --font-size-5xl: 3.5rem; --line-height-tight: 1.2; --line-height-normal: 1.6; --line-height-loose: 1.8; /* Spacing */ --space-xs: 0.25rem; --space-sm: 0.5rem; --space-md: 1rem; --space-lg: 1.5rem; --space-xl: 2rem; --space-2xl: 3rem; --space-3xl: 4rem; --space-4xl: 6rem; /* Shadows -- silver glow for dark theme */ --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.3); --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4); --shadow-lg: 0 8px 30px rgba(0, 0, 0, 0.5); --shadow-xl: 0 16px 48px rgba(0, 0, 0, 0.6); --shadow-silver: 0 0 20px rgba(192, 192, 192, 0.08); /* Borders */ --radius-sm: 4px; --radius-md: 8px; --radius-lg: 12px; --radius-xl: 16px; --radius-full: 9999px; /* Transitions */ --transition-fast: 150ms ease; --transition-base: 250ms ease; --transition-slow: 400ms ease; /* Layout */ --navbar-height: 72px; --container-max: 1280px; --container-narrow: 800px; } /* ============================================================ CSS Reset (Modern) ============================================================ */ *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; } html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; scroll-padding-top: var(--navbar-height); } body { font-family: var(--font-family); font-size: var(--font-size-base); line-height: var(--line-height-normal); color: var(--color-gray-800); background-color: var(--color-primary); -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; overflow-x: hidden; } img, picture, video, canvas, svg { display: block; max-width: 100%; } input, button, textarea, select { font: inherit; color: inherit; } a { color: inherit; text-decoration: none; } ul, ol { list-style: none; } h1, h2, h3, h4, h5, h6 { line-height: var(--line-height-tight); font-weight: 700; color: var(--color-gray-900); } p { margin-bottom: var(--space-md); } p:last-child { margin-bottom: 0; } /* ============================================================ Utility: Container ============================================================ */ .container { width: 100%; max-width: var(--container-max); margin-left: auto; margin-right: auto; padding-left: var(--space-lg); padding-right: var(--space-lg); } /* ============================================================ Buttons ============================================================ */ .btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--space-sm); padding: 0.7rem 1.6rem; font-size: var(--font-size-base); font-weight: 600; border: 2px solid transparent; border-radius: var(--radius-md); cursor: pointer; transition: all var(--transition-base); text-align: center; white-space: nowrap; line-height: 1.4; } .btn:hover { transform: translateY(-2px); } .btn:active { transform: translateY(0); } /* Primary button -- silver metallic gradient with dark text */ .btn--primary { background: var(--gradient-silver); color: #0a0a0a; border-color: rgba(192, 192, 192, 0.3); } .btn--primary:hover { background: linear-gradient(135deg, #c8c8c8 0%, #f0f0f0 25%, #d0d0d0 50%, #e0e0e0 75%, #c0c0c0 100%); border-color: rgba(192, 192, 192, 0.5); box-shadow: 0 4px 20px rgba(192, 192, 192, 0.2); } /* Secondary button -- dark with silver border */ .btn--secondary { background-color: var(--color-primary-light); color: var(--color-accent-light); border-color: var(--color-accent-dark); } .btn--secondary:hover { background-color: var(--color-accent); color: var(--color-primary); border-color: var(--color-accent); box-shadow: 0 4px 20px rgba(192, 192, 192, 0.15); } /* Outline button -- silver border, silver text */ .btn--outline { background-color: transparent; color: var(--color-accent-light); border-color: var(--color-accent); } .btn--outline:hover { background: var(--gradient-silver); color: var(--color-primary); box-shadow: 0 4px 20px rgba(192, 192, 192, 0.2); } .btn--outline-primary { background-color: transparent; color: var(--color-accent); border-color: var(--color-accent); } .btn--outline-primary:hover { background: var(--gradient-silver); color: var(--color-primary); } .btn--sm { padding: 0.45rem 1rem; font-size: var(--font-size-sm); } .btn--lg { padding: 0.9rem 2rem; font-size: var(--font-size-md); } .btn--block { display: flex; width: 100%; } /* WhatsApp button -- keep green, styled for dark theme */ .btn--whatsapp { background-color: #25D366; color: var(--color-white); border-color: #25D366; } .btn--whatsapp:hover { background-color: #1DA851; border-color: #1DA851; box-shadow: 0 4px 20px rgba(37, 211, 102, 0.25); } /* ============================================================ Navigation Bar ============================================================ */ .navbar { position: fixed; top: 0; left: 0; width: 100%; height: var(--navbar-height); background-color: rgba(10, 10, 10, 0.95); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); z-index: 1000; transition: box-shadow var(--transition-base), background-color var(--transition-base); border-bottom: 1px solid rgba(192, 192, 192, 0.06); } .navbar--scrolled { background-color: rgba(0, 0, 0, 0.98); box-shadow: 0 2px 20px rgba(0, 0, 0, 0.5); border-bottom-color: rgba(192, 192, 192, 0.1); } .navbar__inner { display: flex; align-items: center; justify-content: space-between; height: 100%; } .navbar__brand { display: flex; align-items: center; gap: var(--space-sm); font-size: var(--font-size-xl); color: var(--color-accent-light); font-weight: 600; transition: color var(--transition-fast); text-decoration: none; flex-shrink: 0; } .navbar__brand i { font-size: 1.6rem; color: var(--color-accent); } .navbar__logo { height: 55px; width: auto; border-radius: 4px; } .footer__logo { height: 35px; width: auto; border-radius: 4px; vertical-align: middle; margin-right: 4px; } .contact__grid--centered { display: block; } .navbar__brand strong { font-weight: 800; color: var(--color-white); } .navbar__list { display: flex; align-items: center; gap: var(--space-xs); } .navbar__link { display: flex; align-items: center; gap: 0.3rem; padding: 0.5rem 1rem; font-size: var(--font-size-sm); font-weight: 500; color: var(--color-accent); border-radius: var(--radius-md); transition: color var(--transition-fast), background-color var(--transition-fast); text-decoration: none; } .navbar__link:hover { color: var(--color-white); background-color: rgba(192, 192, 192, 0.08); } .navbar__link--dropdown i { font-size: 0.6rem; transition: transform var(--transition-fast); } /* Dropdown */ .navbar__item--dropdown { position: relative; } .navbar__dropdown { position: absolute; top: 100%; left: 0; min-width: 260px; background-color: #141414; border: 1px solid rgba(192, 192, 192, 0.12); border-radius: var(--radius-lg); box-shadow: 0 8px 30px rgba(0, 0, 0, 0.6); opacity: 0; visibility: hidden; transform: translateY(8px); transition: all var(--transition-base); padding: var(--space-sm); z-index: 100; } .navbar__item--dropdown:hover .navbar__dropdown, .navbar__item--dropdown.active .navbar__dropdown { opacity: 1; visibility: visible; transform: translateY(0); } .navbar__item--dropdown:hover .navbar__link--dropdown i, .navbar__item--dropdown.active .navbar__link--dropdown i { transform: rotate(180deg); } .navbar__dropdown-link { display: flex; align-items: center; gap: var(--space-sm); padding: 0.65rem 1rem; font-size: var(--font-size-sm); color: var(--color-accent); border-radius: var(--radius-md); transition: all var(--transition-fast); text-decoration: none; } .navbar__dropdown-link:hover { background-color: rgba(192, 192, 192, 0.08); color: var(--color-white); } .navbar__dropdown-link i { width: 20px; text-align: center; color: var(--color-accent); } /* Hamburger Toggle */ .navbar__toggle { display: none; flex-direction: column; justify-content: center; align-items: center; gap: 5px; width: 40px; height: 40px; background: none; border: none; cursor: pointer; padding: 0; z-index: 1001; } .navbar__toggle-bar { display: block; width: 24px; height: 2.5px; background-color: var(--color-accent); border-radius: 2px; transition: all var(--transition-base); transform-origin: center; } .navbar__toggle.active .navbar__toggle-bar:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); } .navbar__toggle.active .navbar__toggle-bar:nth-child(2) { opacity: 0; transform: scaleX(0); } .navbar__toggle.active .navbar__toggle-bar:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); } /* ============================================================ Hero Section ============================================================ */ .hero { position: relative; display: flex; align-items: center; justify-content: flex-start; min-height: 70vh; padding: calc(var(--navbar-height) + var(--space-2xl)) var(--space-lg) var(--space-2xl); background: var(--gradient-hero); overflow: hidden; } .hero__overlay { position: absolute; inset: 0; background-image: radial-gradient(ellipse at 20% 80%, rgba(192, 192, 192, 0.04) 0%, transparent 50%), radial-gradient(ellipse at 80% 20%, rgba(192, 192, 192, 0.03) 0%, transparent 50%); pointer-events: none; } .hero__overlay::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' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Ccircle cx='30' cy='30' r='1'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"); } .hero__content { position: relative; z-index: 1; text-align: left; max-width: 780px; } .hero__title { font-size: var(--font-size-4xl); font-weight: 800; color: var(--color-white); margin-bottom: var(--space-lg); letter-spacing: -0.02em; line-height: 1.15; } .hero__subtitle { font-size: var(--font-size-lg); color: rgba(192, 192, 192, 0.8); margin-bottom: var(--space-2xl); line-height: var(--line-height-loose); max-width: 620px; } .hero__actions { display: flex; align-items: center; justify-content: flex-start; gap: var(--space-md); flex-wrap: wrap; } /* Hero stats row */ .hero__stats { display: flex; gap: var(--space-2xl); margin-top: var(--space-2xl); padding-top: var(--space-xl); border-top: 1px solid rgba(192, 192, 192, 0.12); } .hero__stat-value { font-size: var(--font-size-2xl); font-weight: 800; color: var(--color-white); line-height: 1; margin-bottom: var(--space-xs); } .hero__stat-label { font-size: var(--font-size-xs); color: rgba(192, 192, 192, 0.6); text-transform: uppercase; letter-spacing: 0.05em; } /* ============================================================ Section Defaults ============================================================ */ .section { padding: 72px 0; background-color: var(--color-primary); } .section:nth-child(even) { background-color: var(--color-off-white); } .section__header { text-align: center; margin-bottom: 48px; max-width: 660px; margin-left: auto; margin-right: auto; } .section__badge { display: inline-block; padding: 0.35rem 1rem; font-size: var(--font-size-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-accent-light); background-color: rgba(192, 192, 192, 0.08); border: 1px solid rgba(192, 192, 192, 0.15); border-radius: var(--radius-full); margin-bottom: var(--space-md); } .section__title { font-size: var(--font-size-2xl); font-weight: 800; color: var(--color-white); margin-bottom: var(--space-md); letter-spacing: -0.01em; } .section__subtitle { font-size: var(--font-size-md); color: var(--color-gray-600); line-height: var(--line-height-loose); } /* ============================================================ Services Grid & Cards ============================================================ */ .services__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; } .card--service { background-color: #141414; border: 1px solid rgba(192, 192, 192, 0.1); border-radius: var(--radius-lg); padding: 32px; display: flex; align-items: flex-start; gap: var(--space-lg); text-align: left; transition: all var(--transition-base); position: relative; overflow: hidden; } .card--service::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--gradient-silver); transform: scaleX(0); transform-origin: left; transition: transform var(--transition-base); } .card--service:hover { transform: translateY(-6px); box-shadow: 0 8px 30px rgba(0, 0, 0, 0.4), 0 0 20px rgba(192, 192, 192, 0.05); border-color: rgba(192, 192, 192, 0.2); } .card--service:hover::before { transform: scaleX(1); } .card__icon { display: inline-flex; align-items: center; justify-content: center; width: 56px; height: 56px; min-width: 56px; border-radius: var(--radius-lg); background: rgba(192, 192, 192, 0.08); border: 1px solid rgba(192, 192, 192, 0.12); color: var(--color-accent); font-size: 1.4rem; transition: all var(--transition-base); } .card__body { flex: 1; min-width: 0; } .card--service:hover .card__icon { transform: scale(1.08); background: rgba(192, 192, 192, 0.12); border-color: rgba(192, 192, 192, 0.2); } .card__title { font-size: var(--font-size-lg); font-weight: 700; color: var(--color-white); margin-bottom: var(--space-sm); } .card__text { font-size: var(--font-size-sm); color: var(--color-gray-600); line-height: var(--line-height-loose); margin-bottom: var(--space-lg); } .card__link { display: inline-flex; align-items: center; gap: 0.4rem; font-size: var(--font-size-sm); font-weight: 600; color: var(--color-accent); transition: color var(--transition-fast), gap var(--transition-fast); text-decoration: none; } .card__link:hover { color: var(--color-accent-light); gap: 0.7rem; } /* ============================================================ Value Propositions ============================================================ */ .values__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; } .value-card { display: flex; align-items: flex-start; gap: var(--space-lg); text-align: left; padding: 28px; background-color: #141414; border: 1px solid rgba(192, 192, 192, 0.08); border-radius: var(--radius-lg); transition: all var(--transition-base); } .value-card:hover { border-color: rgba(192, 192, 192, 0.18); box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3); } .value-card__content { flex: 1; min-width: 0; } .value-card__icon { display: inline-flex; align-items: center; justify-content: center; width: 48px; height: 48px; min-width: 48px; border-radius: var(--radius-md); background-color: rgba(192, 192, 192, 0.06); border: 1px solid rgba(192, 192, 192, 0.12); color: var(--color-accent); font-size: 1.2rem; transition: all var(--transition-base); } .value-card:hover .value-card__icon { background: var(--gradient-silver); color: #0a0a0a; border-color: transparent; transform: scale(1.1); box-shadow: 0 0 20px rgba(192, 192, 192, 0.15); } .value-card__title { font-size: var(--font-size-md); font-weight: 700; color: var(--color-white); margin-bottom: var(--space-sm); } .value-card__text { font-size: var(--font-size-sm); color: var(--color-gray-600); line-height: var(--line-height-loose); } /* ============================================================ Testimonials ============================================================ */ .testimonials { background-color: var(--color-primary); } .testimonials__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; } .testimonial-card { background-color: #141414; border: 1px solid rgba(192, 192, 192, 0.1); border-radius: var(--radius-lg); padding: 32px; transition: all var(--transition-base); opacity: 0; transform: translateY(24px); } .testimonial-card.animate-in { opacity: 1; transform: translateY(0); transition: opacity 0.5s ease, transform 0.5s ease; } .testimonial-card:hover { box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4), 0 0 15px rgba(192, 192, 192, 0.04); border-color: rgba(192, 192, 192, 0.18); } .testimonial-card__stars { display: flex; gap: 3px; margin-bottom: var(--space-md); font-size: var(--font-size-sm); } .testimonial-card__star--active { color: var(--color-accent); } .testimonial-card__star--inactive { color: var(--color-gray-300); } .testimonial-card__text { font-size: var(--font-size-sm); font-style: italic; color: var(--color-gray-700); line-height: 1.6; margin-bottom: var(--space-md); border: none; padding: 0; } .testimonial-card__author { display: flex; align-items: center; gap: var(--space-sm); } .testimonial-card__avatar { display: flex; align-items: center; justify-content: center; width: 32px; height: 32px; border-radius: 50%; background: var(--gradient-silver); color: #0a0a0a; font-size: var(--font-size-xs); flex-shrink: 0; } .testimonial-card__name { font-weight: 600; color: var(--color-white); font-size: var(--font-size-sm); } /* ============================================================ Contact Section ============================================================ */ .contact__grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2xl); align-items: start; } .contact__info { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; } .contact__info-card { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-md); padding: 32px var(--space-lg); background-color: #141414; border: 1px solid rgba(192, 192, 192, 0.08); border-radius: var(--radius-lg); transition: all var(--transition-base); } .contact__info-card > div { text-align: center; } .contact__info-card:hover { background-color: #1a1a1a; border-color: rgba(192, 192, 192, 0.15); box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3); } .contact__info-icon { display: flex; align-items: center; justify-content: center; width: 48px; height: 48px; border-radius: var(--radius-md); background: rgba(192, 192, 192, 0.08); border: 1px solid rgba(192, 192, 192, 0.12); color: var(--color-accent); font-size: var(--font-size-lg); flex-shrink: 0; } .contact__info-card h4 { font-size: var(--font-size-sm); font-weight: 700; color: var(--color-white); margin-bottom: 0.2rem; } .contact__info-card a, .contact__info-card p { font-size: var(--font-size-sm); color: var(--color-gray-600); transition: color var(--transition-fast); margin-bottom: 0; } .contact__info-card a:hover { color: var(--color-accent-light); } .contact__map { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md); min-height: 350px; border: 1px solid rgba(192, 192, 192, 0.1); } .contact__map iframe { display: block; } /* ============================================================ Footer ============================================================ */ .footer { background-color: #050505; color: rgba(192, 192, 192, 0.65); padding: 48px 0 0; border-top: 1px solid rgba(192, 192, 192, 0.06); } .footer__grid { display: grid; grid-template-columns: 1.3fr 1fr 0.8fr; gap: 32px; padding-bottom: var(--space-xl); border-bottom: 1px solid rgba(192, 192, 192, 0.08); } .footer__heading { font-size: var(--font-size-md); font-weight: 700; color: var(--color-white); margin-bottom: var(--space-md); } .footer__heading i { color: var(--color-accent); } .footer__heading--mt { margin-top: var(--space-xl); } .footer__text { font-size: var(--font-size-sm); line-height: var(--line-height-loose); color: rgba(192, 192, 192, 0.55); } .footer__contact-list { display: flex; flex-direction: column; gap: var(--space-md); } .footer__contact-list li { display: flex; align-items: center; gap: var(--space-sm); font-size: var(--font-size-sm); } .footer__contact-list li i { width: 18px; text-align: center; color: var(--color-accent); flex-shrink: 0; } .footer__contact-list a { color: rgba(192, 192, 192, 0.65); transition: color var(--transition-fast); text-decoration: none; } .footer__contact-list a:hover { color: var(--color-accent-light); } .footer__social { display: flex; gap: var(--space-sm); } .footer__social-link { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: 50%; background-color: rgba(192, 192, 192, 0.08); border: 1px solid rgba(192, 192, 192, 0.1); color: var(--color-accent); font-size: var(--font-size-md); transition: all var(--transition-base); text-decoration: none; } .footer__social-link:hover { background: var(--gradient-silver); color: #0a0a0a; border-color: transparent; transform: translateY(-2px); box-shadow: 0 0 15px rgba(192, 192, 192, 0.15); } .footer__bottom { text-align: center; padding: var(--space-lg) 0; font-size: var(--font-size-xs); color: rgba(192, 192, 192, 0.35); } /* ============================================================ Forms (for use in service pages and admin) ============================================================ */ .form-group { margin-bottom: var(--space-md); } .form-label { display: block; font-size: var(--font-size-sm); font-weight: 600; color: var(--color-accent-light); margin-bottom: var(--space-xs); } .form-label .required { color: var(--color-danger); margin-left: 2px; } .form-control { width: 100%; padding: 0.7rem 1rem; font-size: var(--font-size-base); color: var(--color-gray-800); background-color: #1a1a1a; border: 1.5px solid rgba(192, 192, 192, 0.15); border-radius: var(--radius-md); transition: border-color var(--transition-fast), box-shadow var(--transition-fast); outline: none; } .form-control:focus { border-color: var(--color-accent); box-shadow: 0 0 0 3px rgba(192, 192, 192, 0.1); } .form-control::placeholder { color: var(--color-gray-500); } textarea.form-control { resize: vertical; min-height: 100px; } select.form-control { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23999999' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1rem center; background-size: 12px; padding-right: 2.5rem; } .form-heading { font-size: 1.1rem; font-weight: 600; color: var(--color-accent); margin-top: var(--space-lg); margin-bottom: var(--space-md); padding-bottom: var(--space-xs); border-bottom: 1px solid rgba(192, 192, 192, 0.2); } .form-radio-group { display: flex; flex-wrap: wrap; gap: var(--space-sm) var(--space-md); padding-top: var(--space-xs); } .form-radio-label { display: inline-flex; align-items: center; gap: 0.4rem; font-size: var(--font-size-sm); color: var(--color-gray-700); cursor: pointer; } .form-radio-label input[type="radio"] { accent-color: var(--color-accent); width: 16px; height: 16px; cursor: pointer; } .form-error { font-size: var(--font-size-xs); color: var(--color-danger); margin-top: var(--space-xs); } .form-success { font-size: var(--font-size-sm); color: var(--color-success); padding: var(--space-md); background-color: rgba(40, 167, 69, 0.1); border: 1px solid rgba(40, 167, 69, 0.2); border-radius: var(--radius-md); margin-bottom: var(--space-md); } /* ============================================================ Alerts ============================================================ */ .alert { padding: var(--space-md) var(--space-lg); border-radius: var(--radius-md); font-size: var(--font-size-sm); margin-bottom: var(--space-md); border: 1px solid transparent; } .alert--success { background-color: rgba(40, 167, 69, 0.1); border-color: rgba(40, 167, 69, 0.25); color: #7dcea0; } .alert--danger { background-color: rgba(220, 53, 69, 0.1); border-color: rgba(220, 53, 69, 0.25); color: #f1948a; } .alert--warning { background-color: rgba(255, 193, 7, 0.1); border-color: rgba(255, 193, 7, 0.25); color: #f9e79f; } .alert--info { background-color: rgba(23, 162, 184, 0.1); border-color: rgba(23, 162, 184, 0.25); color: #85c1e9; } /* ============================================================ Service Page -- Hero ============================================================ */ .service-hero { background: var(--gradient-hero); padding: calc(var(--navbar-height) + var(--space-3xl)) 0 var(--space-3xl); text-align: center; color: var(--color-white); border-bottom: 1px solid rgba(192, 192, 192, 0.06); } .service-hero__icon { display: inline-flex; align-items: center; justify-content: center; width: 72px; height: 72px; border-radius: 50%; background: rgba(192, 192, 192, 0.06); border: 2px solid rgba(192, 192, 192, 0.15); color: var(--color-accent); font-size: 1.8rem; margin-bottom: var(--space-md); } .service-hero h1 { font-size: var(--font-size-2xl); font-weight: 800; color: var(--color-white); margin-bottom: var(--space-md); letter-spacing: -0.01em; } .service-hero__price { font-size: var(--font-size-lg); color: rgba(192, 192, 192, 0.75); margin-bottom: 0; } .service-hero__price strong { color: var(--color-accent-light); } .service-hero__price i { color: var(--color-accent); margin-right: var(--space-xs); } /* ============================================================ Service Page -- Detail Layout ============================================================ */ .service-detail { display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; align-items: start; } .service-detail__info { padding-right: var(--space-xl); } .service-detail__desc { font-size: var(--font-size-md); color: var(--color-gray-700); line-height: var(--line-height-loose); margin-bottom: var(--space-2xl); } .service-detail__info h2 { font-size: var(--font-size-xl); font-weight: 700; color: var(--color-white); margin-bottom: var(--space-lg); margin-top: var(--space-2xl); } .service-detail__info h2:first-of-type { margin-top: 0; } .service-detail__info h2 i { color: var(--color-accent); margin-right: var(--space-sm); } /* ============================================================ Service Page -- Requirements List ============================================================ */ .requirements-list { display: flex; flex-direction: column; gap: var(--space-md); } .requirements-list li { display: flex; align-items: flex-start; gap: var(--space-sm); font-size: var(--font-size-base); color: var(--color-gray-700); line-height: var(--line-height-normal); } .requirements-list li i { color: var(--color-success); font-size: var(--font-size-md); flex-shrink: 0; margin-top: 2px; } /* ============================================================ Service Page -- Process Steps ============================================================ */ .process-list { display: flex; flex-direction: column; gap: var(--space-lg); counter-reset: none; } .process-list li { display: flex; align-items: center; gap: var(--space-md); font-size: var(--font-size-base); color: var(--color-gray-700); line-height: var(--line-height-normal); } .step-number { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 50%; background: var(--gradient-silver); color: #0a0a0a; font-size: var(--font-size-sm); font-weight: 700; flex-shrink: 0; } /* ============================================================ Service Page -- Form Card ============================================================ */ .service-detail__form { background-color: #141414; border: 1px solid rgba(192, 192, 192, 0.1); border-radius: var(--radius-lg); padding: 32px; box-shadow: var(--shadow-md); position: sticky; top: calc(var(--navbar-height) + var(--space-lg)); } .service-detail__form h2 { font-size: var(--font-size-xl); font-weight: 700; color: var(--color-white); margin-bottom: var(--space-xl); text-align: center; } .service-detail__form label { display: block; font-size: var(--font-size-sm); font-weight: 600; color: var(--color-accent-light); margin-bottom: var(--space-xs); } /* -- Expanded layout: full-width form with 2-column fields -- */ .service-detail--expanded { grid-template-columns: 1fr; } .service-detail--expanded .service-detail__info { padding-right: 0; } .service-detail--expanded .service-detail__form { position: static; } .service-detail--expanded .service-detail__form form { display: grid; grid-template-columns: 1fr 1fr; gap: 0 var(--space-xl); } .service-detail--expanded .form-heading, .service-detail--expanded .service-detail__form form > button { grid-column: 1 / -1; } .service-detail--expanded .form-group:has(textarea) { grid-column: 1 / -1; } .service-detail--expanded .form-group { margin-bottom: var(--space-sm); } .service-detail--expanded .form-heading { margin-top: var(--space-md); } /* ============================================================ Confirmation Page ============================================================ */ .confirmation-section { display: flex; align-items: center; justify-content: center; min-height: 60vh; padding-top: 120px; } .confirmation-card { text-align: center; max-width: 500px; margin: 0 auto; padding: var(--space-3xl); background: #141414; border: 1px solid rgba(192, 192, 192, 0.1); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); } .confirmation-card__icon { font-size: 4rem; color: var(--color-success); margin-bottom: var(--space-lg); } .confirmation-card h1 { color: var(--color-white); margin-bottom: var(--space-md); } .confirmation-card p { color: var(--color-gray-600); margin-bottom: var(--space-sm); } .confirmation-card__actions { margin-top: var(--space-xl); display: flex; flex-direction: column; gap: var(--space-md); align-items: center; } /* ============================================================ Scroll Animations ============================================================ */ .fade-up { opacity: 0; transform: translateY(30px); transition: opacity 0.6s ease, transform 0.6s ease; } .fade-up.visible { opacity: 1; transform: translateY(0); } /* ============================================================ Responsive -- Tablet (768px) ============================================================ */ @media (max-width: 1024px) { .services__grid { grid-template-columns: 1fr; } .testimonials__grid { grid-template-columns: repeat(2, 1fr); } .footer__grid { grid-template-columns: 1fr 1fr; } } @media (max-width: 768px) { :root { --navbar-height: 64px; } /* Navbar mobile */ .navbar__toggle { display: flex; } .navbar__menu { position: fixed; top: 0; right: -100%; width: 85%; max-width: 360px; height: 100vh; background-color: #0a0a0a; box-shadow: var(--shadow-xl); padding: calc(var(--navbar-height) + var(--space-lg)) var(--space-xl) var(--space-xl); transition: right var(--transition-slow); overflow-y: auto; z-index: 999; border-left: 1px solid rgba(192, 192, 192, 0.08); } .navbar__menu.active { right: 0; } .navbar__list { flex-direction: column; align-items: stretch; gap: 0; } .navbar__link { padding: 0.85rem 0; font-size: var(--font-size-base); border-bottom: 1px solid rgba(192, 192, 192, 0.06); } .navbar__link:hover { background-color: transparent; } .navbar__dropdown { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; border: none; padding: 0 0 0 var(--space-md); max-height: 0; overflow: hidden; transition: max-height var(--transition-base); background-color: transparent; } .navbar__item--dropdown.active .navbar__dropdown { max-height: 400px; } .navbar__dropdown-link { padding: 0.6rem 0; border-bottom: 1px solid rgba(192, 192, 192, 0.06); } /* Mobile overlay */ .navbar__overlay { position: fixed; inset: 0; background-color: rgba(0, 0, 0, 0.6); z-index: 998; opacity: 0; visibility: hidden; transition: all var(--transition-base); } .navbar__overlay.active { opacity: 1; visibility: visible; } /* Hero mobile */ .hero { min-height: auto; padding: calc(var(--navbar-height) + var(--space-2xl)) var(--space-lg) var(--space-2xl); justify-content: center; } .hero__content { text-align: center; } .hero__subtitle { margin-left: auto; margin-right: auto; } .hero__actions { justify-content: center; flex-direction: column; } .hero__actions .btn { width: 100%; justify-content: center; } .hero__title { font-size: var(--font-size-2xl); } .hero__subtitle { font-size: var(--font-size-base); } .hero__stats { justify-content: center; gap: var(--space-xl); text-align: center; } /* Sections */ .section { padding: var(--space-3xl) 0; } .section__title { font-size: var(--font-size-2xl); } .section__header { margin-bottom: var(--space-2xl); } /* Services */ .services__grid { grid-template-columns: 1fr; gap: var(--space-md); } /* Values */ .values__grid { grid-template-columns: 1fr; gap: var(--space-md); } /* Testimonials */ .testimonials__grid { grid-template-columns: 1fr; } /* Contact */ .contact__grid { grid-template-columns: 1fr; } .contact__info { grid-template-columns: 1fr; } /* Service page */ .service-hero h1 { font-size: var(--font-size-2xl); } .service-detail { grid-template-columns: 1fr; gap: var(--space-2xl); } .service-detail__info { padding-right: 0; } .service-detail__form { position: static; } .service-detail--expanded .service-detail__form form { grid-template-columns: 1fr; } /* Footer */ .footer__grid { grid-template-columns: 1fr; gap: var(--space-xl); } /* Logo smaller on mobile */ .navbar__logo { height: 45px; } } /* ============================================================ Responsive -- Small Mobile (480px) ============================================================ */ @media (max-width: 480px) { .container { padding-left: var(--space-md); padding-right: var(--space-md); } .hero__title { font-size: 1.75rem; } .hero__subtitle { font-size: var(--font-size-sm); } .hero__stats { flex-direction: column; gap: var(--space-md); align-items: center; } .section__title { font-size: var(--font-size-xl); } /* Stack service cards vertically on small mobile */ .card--service { flex-direction: column; text-align: center; padding: var(--space-xl) var(--space-lg); } .card__icon { margin: 0 auto; } .card__body { text-align: center; } /* Stack value cards vertically on small mobile */ .value-card { flex-direction: column; text-align: center; align-items: center; } .value-card__content { text-align: center; } .testimonial-card { padding: var(--space-xl); } .btn--lg { padding: 0.75rem 1.5rem; font-size: var(--font-size-base); } /* Service page small mobile */ .service-hero { padding: calc(var(--navbar-height) + var(--space-2xl)) var(--space-md) var(--space-2xl); } .service-hero__icon { width: 60px; height: 60px; font-size: 1.5rem; } .service-hero h1 { font-size: var(--font-size-xl); } .service-detail__form { padding: var(--space-xl) var(--space-lg); } } /* ============================================================ Desktop large (1200px+) ============================================================ */ @media (min-width: 1200px) { .hero__title { font-size: var(--font-size-5xl); } } /* ============================================================ Print Styles ============================================================ */ @media print { .navbar, .hero__actions, .footer__social, .navbar__toggle { display: none !important; } .hero { min-height: auto; padding: var(--space-xl) 0; background: none; color: #212529; } .hero__title, .hero__subtitle { color: #212529; } .section { padding: var(--space-xl) 0; background-color: #fff; } body { font-size: 12pt; color: #212529; background-color: #fff; } h1, h2, h3, h4, h5, h6 { color: #212529; } .section__title { color: #212529; } } /* ============================================================ Accessibility ============================================================ */ @media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; } .testimonial-card { opacity: 1; transform: none; } } :focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; } .sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border-width: 0; }