:root { --gn-primary: #1C4ED8; --gn-primary-dark: #1540B8; --gn-primary-light: #EFF4FF; --gn-primary-rgb: 28,78,216; --gn-purple: #6D28D9; --gn-purple-light: #F3F0FF; --gn-success: #059669; --gn-success-light: #ECFDF5; --gn-warning: #D97706; --gn-warning-light: #FFFBEB; --gn-danger: #DC2626; --gn-wa: #25D366; --gn-text: #0C1527; --gn-text-md: #2D3B52; --gn-text-sm: #5C6B7E; --gn-text-xs: #8FA3B8; --gn-border: #DDE4EF; --gn-border-md: #C4CDD9; --gn-bg: #F5F7FA; --gn-white: #FFFFFF; --gn-dark: #060E1F; --gn-font: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif; --gn-fs-xs: 0.72rem; --gn-fs-sm: 0.85rem; --gn-fs-base: 0.95rem; --gn-fs-md: 1rem; --gn-fs-lg: 1.125rem; --gn-fs-xl: 1.25rem; --gn-fs-2xl: 1.5rem; --gn-fs-3xl: 1.875rem; --gn-fs-4xl: 2.5rem; --gn-fs-5xl: 3.25rem; --gn-sp-1: 4px; --gn-sp-2: 8px; --gn-sp-3: 12px; --gn-sp-4: 16px; --gn-sp-5: 20px; --gn-sp-6: 24px; --gn-sp-8: 32px; --gn-sp-10: 40px; --gn-sp-12: 48px; --gn-sp-16: 64px; --gn-sp-20: 80px; --gn-r-xs: 4px; --gn-r-sm: 6px; --gn-r-md: 8px; --gn-r-lg: 12px; --gn-r-xl: 16px; --gn-r-2xl: 24px; --gn-r-full: 9999px; --gn-shadow-xs: 0 1px 2px rgba(0,0,0,.05); --gn-shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04); --gn-shadow-md: 0 4px 6px -1px rgba(0,0,0,.08), 0 2px 4px -2px rgba(0,0,0,.04); --gn-shadow-lg: 0 10px 15px -3px rgba(0,0,0,.08), 0 4px 6px -4px rgba(0,0,0,.04); --gn-shadow-xl: 0 20px 25px -5px rgba(0,0,0,.1), 0 8px 10px -6px rgba(0,0,0,.05); --gn-ease: all .15s ease; --gn-ease3: all .25s ease; --gn-header-h: 68px; --gn-max: 1280px; --gn-pad: clamp(16px, 5vw, 40px); } *, *::before, *::after { box-sizing: border-box; } html { scroll-behavior: smooth; } body { font-family: var(--gn-font); font-size: var(--gn-fs-base); color: var(--gn-text); background: var(--gn-bg); line-height: 1.6; -webkit-font-smoothing: antialiased; } img { max-width: 100%; height: auto; display: block; } a { text-decoration: none; color: inherit; } button { cursor: pointer; font-family: inherit; } h1,h2,h3,h4,h5,h6 { margin: 0; line-height: 1.25; letter-spacing: -.02em; } p { margin: 0; } input, textarea, select { font-family: inherit; } .gnv-wrap { width: 100%; max-width: var(--gn-max); margin: 0 auto; padding: 0 var(--gn-pad); } .gnv-section { padding: var(--gn-sp-16) 0; } .gnv-section--white { background: var(--gn-white); } .gnv-section--gray { background: var(--gn-bg); } .gnv-section--dark { background: var(--gn-dark); } .gnv-section-head { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: var(--gn-sp-6); gap: var(--gn-sp-4); } .gnv-section-head h2 { font-size: var(--gn-fs-2xl); font-weight: 700; color: var(--gn-text); } .gnv-section-head p { font-size: var(--gn-fs-sm); color: var(--gn-text-sm); margin-top: 4px; } .gnv-see-all { font-size: var(--gn-fs-sm); font-weight: 600; color: var(--gn-primary); white-space: nowrap; display: inline-flex; align-items: center; gap: 4px; transition: var(--gn-ease); } .gnv-see-all:hover { gap: 8px; color: var(--gn-primary-dark); } .gnv-btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--gn-sp-2); padding: 10px 20px; border-radius: var(--gn-r-lg); font-size: var(--gn-fs-sm); font-weight: 600; border: none; cursor: pointer; text-decoration: none; transition: var(--gn-ease3); white-space: nowrap; line-height: 1; font-family: var(--gn-font); } .gnv-btn--primary { background: var(--gn-primary); color: #fff; } .gnv-btn--primary:hover { background: var(--gn-primary-dark); transform: translateY(-1px); box-shadow: var(--gn-shadow-md); color: #fff; } .gnv-btn--outline { background: transparent; color: var(--gn-primary); border: 1.5px solid var(--gn-primary); } .gnv-btn--outline:hover { background: var(--gn-primary-light); color: var(--gn-primary); } .gnv-btn--ghost { background: transparent; color: var(--gn-text-md); border: 1.5px solid var(--gn-border); } .gnv-btn--ghost:hover { background: var(--gn-bg); border-color: var(--gn-border-md); } .gnv-btn--wa { background: #25D366; color: #fff; } .gnv-btn--wa:hover { background: #128C7E; color: #fff; } .gnv-btn--white { background: #fff; color: var(--gn-primary); } .gnv-btn--white:hover { background: var(--gn-primary-light); color: var(--gn-primary); } .gnv-btn--dark { background: var(--gn-dark); color: #fff; } .gnv-btn--dark:hover { background: #1e293b; } .gnv-btn--purple { background: var(--gn-purple); color: #fff; } .gnv-btn--lg { padding: 13px 28px; font-size: var(--gn-fs-base); border-radius: var(--gn-r-xl); } .gnv-btn--sm { padding: 7px 14px; font-size: var(--gn-fs-xs); border-radius: var(--gn-r-md); } .gnv-btn--xs { padding: 5px 10px; font-size: var(--gn-fs-xs); border-radius: var(--gn-r-sm); } .gnv-btn--full { width: 100%; } .gnv-badge { display: inline-flex; align-items: center; gap: 3px; padding: 2px 9px; border-radius: var(--gn-r-full); font-size: var(--gn-fs-xs); font-weight: 700; line-height: 1.5; } .gnv-badge--blue { background: var(--gn-primary-light); color: var(--gn-primary); } .gnv-badge--green { background: var(--gn-success-light); color: var(--gn-success); } .gnv-badge--purple { background: var(--gn-purple-light); color: var(--gn-purple); } .gnv-badge--gold { background: var(--gn-warning-light); color: #B45309; } .gnv-badge--gray { background: var(--gn-bg); color: var(--gn-text-sm); border: 1px solid var(--gn-border); } .gnv-badge--premium { background: linear-gradient(135deg, var(--gn-purple), var(--gn-primary)); color: #fff; } .gnv-badge--verified { background: var(--gn-success); color: #fff; } .gnv-header { position: sticky; top: 0; z-index: 500; background: #fff; border-bottom: 1px solid var(--gn-border); box-shadow: var(--gn-shadow-sm); transition: box-shadow .2s ease; } .gnv-header.scrolled { box-shadow: var(--gn-shadow-md); } .gnv-header__inner { display: flex; align-items: center; gap: var(--gn-sp-4); height: var(--gn-header-h); } .gnv-logo { display: flex; align-items: center; flex-shrink: 0; text-decoration: none; } .gnv-logo img { height: 28px; width: auto; } .gnv-loc-btn { display: flex; align-items: center; gap: var(--gn-sp-2); background: var(--gn-bg); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-lg); padding: 7px 12px; font-size: var(--gn-fs-xs); color: var(--gn-text-md); font-weight: 500; font-family: var(--gn-font); cursor: pointer; transition: var(--gn-ease); white-space: nowrap; flex-shrink: 0; } .gnv-loc-btn:hover { border-color: var(--gn-primary); color: var(--gn-primary); background: var(--gn-primary-light); } .gnv-loc-btn .loc-icon { color: var(--gn-primary); font-size: 11px; } .gnv-loc-btn .loc-city { font-weight: 600; max-width: 120px; overflow: hidden; text-overflow: ellipsis; } .gnv-loc-btn .loc-chevron { color: var(--gn-text-xs); font-size: 9px; } .gnv-hsearch { flex: 1; max-width: 460px; position: relative; display: flex; align-items: center; background: var(--gn-bg); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-full); padding: 0 var(--gn-sp-2) 0 var(--gn-sp-4); transition: border-color .15s, box-shadow .15s; } .gnv-hsearch:focus-within { border-color: var(--gn-primary); background: #fff; box-shadow: 0 0 0 3px rgba(var(--gn-primary-rgb),.1); } .gnv-hsearch input { flex: 1; background: transparent; border: none; outline: none; font-size: var(--gn-fs-sm); color: var(--gn-text); padding: 10px 0; width: 100%; min-width: 0; } .gnv-hsearch input::placeholder { color: var(--gn-text-xs); } .gnv-hsearch__btn { background: var(--gn-primary); color: #fff; border: none; border-radius: var(--gn-r-full); width: 33px; height: 33px; display: flex; align-items: center; justify-content: center; font-size: 12px; flex-shrink: 0; transition: background .15s; } .gnv-hsearch__btn:hover { background: var(--gn-primary-dark); } .gnv-hsearch .autocomplete-results { position: absolute; top: calc(100% + 6px); left: 0; right: 0; z-index: 1000; background: #fff; border: 1px solid var(--gn-border); border-radius: var(--gn-r-lg); box-shadow: var(--gn-shadow-xl); max-height: 320px; overflow-y: auto; } .gnv-hnav { display: flex; align-items: center; list-style: none; margin: 0; padding: 0; flex-shrink: 0; } .gnv-hnav a { font-size: var(--gn-fs-sm); font-weight: 500; color: var(--gn-text-md); padding: var(--gn-sp-2) var(--gn-sp-3); border-radius: var(--gn-r-sm); transition: var(--gn-ease); white-space: nowrap; text-decoration: none; display: block; } .gnv-hnav a:hover, .gnv-hnav a.active { color: var(--gn-primary); background: var(--gn-primary-light); } .gnv-hactions { display: flex; align-items: center; gap: var(--gn-sp-2); flex-shrink: 0; } .gnv-hamburger { display: none; flex-direction: column; gap: 5px; padding: 8px; background: none; border: none; cursor: pointer; flex-shrink: 0; border-radius: var(--gn-r-md); } .gnv-hamburger span { display: block; width: 22px; height: 2px; background: var(--gn-text); border-radius: 2px; transition: var(--gn-ease3); } .gnv-mobile-nav { display: none; position: fixed; inset: 0; z-index: 490; background: rgba(15,23,42,.5); backdrop-filter: blur(2px); } .gnv-mobile-nav.open { display: block; } .gnv-mobile-nav__panel { position: absolute; top: 0; right: 0; bottom: 0; width: 290px; max-width: 85vw; background: #fff; padding: var(--gn-sp-5); overflow-y: auto; display: flex; flex-direction: column; gap: var(--gn-sp-5); box-shadow: var(--gn-shadow-xl); } .gnv-mobile-nav__close { align-self: flex-end; background: var(--gn-bg); border: none; font-size: 1.1rem; color: var(--gn-text-sm); cursor: pointer; padding: 8px; border-radius: var(--gn-r-md); line-height: 1; } .gnv-mobile-nav__search { display: flex; border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-lg); overflow: hidden; } .gnv-mobile-nav__search input { flex: 1; border: none; outline: none; padding: 10px 14px; font-size: var(--gn-fs-sm); min-width: 0; } .gnv-mobile-nav__search button { background: var(--gn-primary); color: #fff; border: none; padding: 10px 16px; font-size: 14px; } .gnv-mobile-nav__links { display: flex; flex-direction: column; border-top: 1px solid var(--gn-border); } .gnv-mobile-nav__links a { padding: 13px var(--gn-sp-2); font-size: var(--gn-fs-base); font-weight: 500; color: var(--gn-text-md); border-bottom: 1px solid var(--gn-bg); transition: var(--gn-ease); text-decoration: none; display: flex; align-items: center; gap: var(--gn-sp-2); } .gnv-mobile-nav__links a:hover { color: var(--gn-primary); padding-left: var(--gn-sp-4); } .gnv-mobile-nav__actions { display: flex; flex-direction: column; gap: var(--gn-sp-3); margin-top: auto; padding-top: var(--gn-sp-4); border-top: 1px solid var(--gn-border); } .gnv-mobile-nav__actions .gnv-btn { width: 100%; justify-content: center; } .gnv-hero { position: relative; overflow: hidden; min-height: 62vh; display: flex; align-items: center; } .gnv-hero__bg { position: absolute; inset: 0; } .gnv-hero__bg img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; } .gnv-hero__overlay { position: absolute; inset: 0; background: linear-gradient( 120deg, rgba(5,15,40,.90) 0%, rgba(10,30,75,.80) 50%, rgba(5,15,40,.70) 100% ); } .gnv-hero__inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 320px; gap: var(--gn-sp-10); align-items: center; padding: var(--gn-sp-20) var(--gn-pad); max-width: var(--gn-max); margin: 0 auto; width: 100%; } .gnv-hero__content h1 { font-size: clamp(1.75rem, 4vw, 3rem); font-weight: 900; color: #fff; line-height: 1.15; margin-bottom: var(--gn-sp-4); } .gnv-hero__city { color: #60A5FA; } .gnv-hero__content > p { color: rgba(255,255,255,.75); font-size: var(--gn-fs-lg); margin-bottom: var(--gn-sp-6); max-width: 500px; } .gnv-hero__form { margin-bottom: var(--gn-sp-6); } .gnv-hero__form-wrap { display: flex; align-items: center; background: #fff; border-radius: var(--gn-r-xl); padding: 5px; gap: 0; box-shadow: var(--gn-shadow-xl); max-width: 580px; } .gnv-hero__form-q { flex: 1; display: flex; align-items: center; gap: var(--gn-sp-3); padding: 0 var(--gn-sp-4); } .gnv-hero__form-q i { color: var(--gn-text-xs); font-size: .9rem; flex-shrink: 0; } .gnv-hero__form-q input { flex: 1; border: none; outline: none; font-size: var(--gn-fs-base); color: var(--gn-text); padding: 11px 0; background: transparent; width: 100%; min-width: 0; } .gnv-hero__form-q input::placeholder { color: var(--gn-text-xs); font-size: var(--gn-fs-sm); } .gnv-hero__form-div { width: 1px; height: 28px; background: var(--gn-border); flex-shrink: 0; } .gnv-hero__form-loc { display: flex; align-items: center; gap: var(--gn-sp-2); padding: 0 var(--gn-sp-4); color: var(--gn-text-md); font-size: var(--gn-fs-sm); font-weight: 500; white-space: nowrap; flex-shrink: 0; } .gnv-hero__form-loc i { color: var(--gn-primary); } .gnv-hero__form-btn { background: var(--gn-primary); color: #fff; border: none; border-radius: var(--gn-r-lg); padding: 12px 24px; font-size: var(--gn-fs-base); font-weight: 700; cursor: pointer; flex-shrink: 0; transition: background .15s; font-family: var(--gn-font); } .gnv-hero__form-btn:hover { background: var(--gn-primary-dark); } .gnv-hero__pills { display: flex; gap: var(--gn-sp-6); flex-wrap: wrap; } .gnv-hero__pill { display: flex; align-items: center; gap: var(--gn-sp-2); } .gnv-hero__pill i { color: #60A5FA; font-size: 16px; } .gnv-hero__pill strong { display: block; color: #fff; font-size: var(--gn-fs-sm); font-weight: 600; line-height: 1.3; } .gnv-hero__pill small { display: block; color: rgba(255,255,255,.6); font-size: var(--gn-fs-xs); } .gnv-ai-card { background: #fff; border-radius: var(--gn-r-2xl); padding: var(--gn-sp-6); box-shadow: var(--gn-shadow-xl); display: flex; flex-direction: column; gap: var(--gn-sp-4); } .gnv-ai-card__header { display: flex; align-items: center; gap: var(--gn-sp-3); } .gnv-ai-card__ico { width: 40px; height: 40px; background: var(--gn-purple-light); border-radius: var(--gn-r-lg); display: flex; align-items: center; justify-content: center; color: var(--gn-purple); font-size: 1rem; flex-shrink: 0; } .gnv-ai-card__header h3 { font-size: var(--gn-fs-base); font-weight: 700; flex: 1; color: var(--gn-text); } .gnv-ai-card__example { background: var(--gn-bg); border: 1.5px dashed var(--gn-border-md); border-radius: var(--gn-r-lg); padding: var(--gn-sp-4); font-size: var(--gn-fs-sm); color: var(--gn-text-sm); font-style: italic; line-height: 1.5; } .gnv-ai-card__note { text-align: center; font-size: var(--gn-fs-xs); color: var(--gn-text-xs); } .gnv-cats { padding: var(--gn-sp-10) 0; background: var(--gn-white); border-bottom: 1px solid var(--gn-border); } .gnv-cats__row { display: flex; gap: var(--gn-sp-3); overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch; padding-bottom: 2px; } .gnv-cats__row::-webkit-scrollbar { display: none; } .gnv-cat-chip { display: flex; flex-direction: column; align-items: center; gap: var(--gn-sp-2); padding: var(--gn-sp-4) var(--gn-sp-4); background: var(--gn-bg); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-xl); cursor: pointer; text-decoration: none; transition: var(--gn-ease3); min-width: 88px; max-width: 100px; flex-shrink: 0; text-align: center; } .gnv-cat-chip:hover { border-color: var(--gn-primary); background: var(--gn-primary-light); transform: translateY(-2px); box-shadow: var(--gn-shadow-md); } .gnv-cat-chip__ico { width: 48px; height: 48px; background: var(--gn-white); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; transition: var(--gn-ease); border: 1px solid var(--gn-border); } .gnv-cat-chip:hover .gnv-cat-chip__ico { background: rgba(var(--gn-primary-rgb),.1); border-color: rgba(var(--gn-primary-rgb),.2); } .gnv-cat-chip__name { font-size: 11px; font-weight: 600; color: var(--gn-text-md); line-height: 1.3; word-break: break-word; transition: var(--gn-ease); } .gnv-cat-chip:hover .gnv-cat-chip__name { color: var(--gn-primary); } .gnv-companies { padding: var(--gn-sp-16) 0; background: var(--gn-white); } .gnv-company-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--gn-sp-5); } .gnv-company-card { background: var(--gn-white); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-xl); overflow: hidden; transition: var(--gn-ease3); display: flex; flex-direction: column; text-decoration: none; position: relative; } .gnv-company-card:hover { border-color: rgba(var(--gn-primary-rgb),.3); box-shadow: var(--gn-shadow-lg); transform: translateY(-4px); } .gnv-company-card__thumb { aspect-ratio: 4/3; overflow: hidden; background: var(--gn-bg); position: relative; } .gnv-company-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; } .gnv-company-card:hover .gnv-company-card__thumb img { transform: scale(1.05); } .gnv-company-card__badges { position: absolute; top: 10px; left: 10px; display: flex; gap: 5px; } .gnv-company-card__body { padding: var(--gn-sp-4); flex: 1; display: flex; flex-direction: column; gap: 5px; } .gnv-company-card__cat { font-size: var(--gn-fs-xs); font-weight: 700; color: var(--gn-primary); text-transform: uppercase; letter-spacing: .07em; } .gnv-company-card__name { font-size: var(--gn-fs-base); font-weight: 700; color: var(--gn-text); line-height: 1.3; margin: 0; } .gnv-company-card__subcat { font-size: var(--gn-fs-xs); color: var(--gn-text-sm); } .gnv-company-card__loc { display: flex; align-items: center; gap: 4px; font-size: var(--gn-fs-xs); color: var(--gn-text-sm); } .gnv-company-card__loc i { color: var(--gn-text-xs); font-size: 10px; } .gnv-company-card__actions { display: flex; gap: var(--gn-sp-2); margin-top: var(--gn-sp-3); flex-wrap: wrap; } .gnv-promo-card { background: linear-gradient(145deg, #5B21B6 0%, #1D4ED8 100%); border-radius: var(--gn-r-xl); padding: var(--gn-sp-6); display: flex; flex-direction: column; gap: var(--gn-sp-4); position: relative; overflow: hidden; } .gnv-promo-card::before { content: ''; position: absolute; top: -40px; right: -40px; width: 130px; height: 130px; background: rgba(255,255,255,.06); border-radius: 50%; } .gnv-promo-card__ico { width: 46px; height: 46px; background: rgba(255,255,255,.15); border-radius: var(--gn-r-lg); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 1.2rem; } .gnv-promo-card h3 { color: #fff; font-size: var(--gn-fs-xl); font-weight: 800; } .gnv-promo-card p { color: rgba(255,255,255,.8); font-size: var(--gn-fs-sm); } .gnv-promo-card__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--gn-sp-2); } .gnv-promo-card__list li { display: flex; align-items: center; gap: var(--gn-sp-2); font-size: var(--gn-fs-xs); color: rgba(255,255,255,.85); } .gnv-promo-card__list i { color: #86EFAC; font-size: 11px; } .gnv-promo-card__cta { margin-top: auto; } .gnv-promo-card__link { display: block; text-align: center; margin-top: var(--gn-sp-3); font-size: var(--gn-fs-xs); color: rgba(255,255,255,.65); text-decoration: none; } .gnv-promo-card__link:hover { color: #fff; } .gnv-promo-card--light { background: #F0EEFF; border: 1.5px solid #E4DDFF; } .gnv-promo-card--light::before { display: none; } .gnv-promo-card--light .gnv-promo-card__ico { background: rgba(124,58,237,.12); color: var(--gn-purple); } .gnv-promo-card--light h3 { color: var(--gn-text); font-size: var(--gn-fs-lg); } .gnv-promo-card--light p { color: var(--gn-text-sm); } .gnv-promo-card--light .gnv-promo-card__list li { color: var(--gn-text-md); } .gnv-promo-card--light .gnv-promo-card__list i { color: var(--gn-purple); } .gnv-promo-card--light .gnv-promo-card__link { color: var(--gn-purple); opacity: .75; } .gnv-promo-card--light .gnv-promo-card__link:hover { opacity: 1; } .gnv-feat-layout { display: grid; grid-template-columns: 1fr 240px; gap: var(--gn-sp-5); align-items: start; } .gnv-feat-layout > .gnv-company-grid { grid-template-columns: repeat(4, 1fr); } .gnv-company-card__name a { color: inherit; text-decoration: none; } .gnv-company-card__name a:hover { color: var(--gn-primary); } .gnv-btn--icon { padding: 7px 9px; aspect-ratio: 1; flex-shrink: 0; } .gnv-ai-section { padding: var(--gn-sp-16) 0; background: var(--gn-bg); } .gnv-ai-explainer { background: var(--gn-white); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-2xl); padding: var(--gn-sp-10) var(--gn-sp-12); display: grid; grid-template-columns: 1fr 1fr; gap: var(--gn-sp-12); align-items: center; } .gnv-ai-explainer h2 { font-size: var(--gn-fs-2xl); font-weight: 800; margin-bottom: var(--gn-sp-3); } .gnv-ai-explainer__desc { color: var(--gn-text-sm); font-size: var(--gn-fs-base); margin-bottom: var(--gn-sp-6); } .gnv-ai-steps { display: flex; align-items: center; gap: var(--gn-sp-4); } .gnv-ai-step { flex: 1; text-align: center; } .gnv-ai-step__ico { width: 54px; height: 54px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.2rem; margin: 0 auto var(--gn-sp-3); } .gnv-ai-step:nth-child(1) .gnv-ai-step__ico { background: var(--gn-primary-light); color: var(--gn-primary); } .gnv-ai-step:nth-child(3) .gnv-ai-step__ico { background: var(--gn-purple-light); color: var(--gn-purple); } .gnv-ai-step:nth-child(5) .gnv-ai-step__ico { background: var(--gn-success-light); color: var(--gn-success); } .gnv-ai-step strong { display: block; font-size: var(--gn-fs-sm); font-weight: 700; margin-bottom: 4px; } .gnv-ai-step p { font-size: var(--gn-fs-xs); color: var(--gn-text-sm); } .gnv-ai-step__arr { color: var(--gn-text-xs); font-size: 1.1rem; flex-shrink: 0; } .gnv-blog { padding: var(--gn-sp-10) 0; background: var(--gn-bg); } .gnv-blog__layout { display: grid; grid-template-columns: 1fr 260px; gap: var(--gn-sp-8); align-items: start; } .gnv-blog__cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gn-sp-5); } .gnv-blog-card { background: var(--gn-white); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-xl); overflow: hidden; display: flex; flex-direction: column; text-decoration: none; transition: var(--gn-ease3); } .gnv-blog-card:hover { box-shadow: var(--gn-shadow-lg); transform: translateY(-3px); } .gnv-blog-card__thumb { aspect-ratio: 16/10; overflow: hidden; background: var(--gn-bg); position: relative; } .gnv-blog-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; } .gnv-blog-card:hover .gnv-blog-card__thumb img { transform: scale(1.05); } .gnv-blog-card__cat-pill { position: absolute; bottom: 10px; left: 10px; background: var(--gn-primary); color: #fff; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; padding: 3px 10px; border-radius: var(--gn-r-full); } .gnv-blog-card__body { padding: var(--gn-sp-4); flex: 1; display: flex; flex-direction: column; gap: var(--gn-sp-2); } .gnv-blog-card__title { font-size: var(--gn-fs-sm); font-weight: 700; color: var(--gn-text); line-height: 1.45; display: -webkit-box; -webkit-line-clamp: 3; line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; } .gnv-blog-card:hover .gnv-blog-card__title { color: var(--gn-primary); } .gnv-blog-card__meta { margin-top: auto; display: flex; align-items: center; gap: var(--gn-sp-3); font-size: var(--gn-fs-xs); color: var(--gn-text-xs); padding-top: var(--gn-sp-3); border-top: 1px solid var(--gn-bg); } .gnv-blog-card__meta i { font-size: 10px; } .gnv-sidebar { display: flex; flex-direction: column; gap: var(--gn-sp-5); } .gnv-sidebar-card { background: var(--gn-white); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-xl); padding: var(--gn-sp-5); } .gnv-sidebar-card h3 { font-size: var(--gn-fs-base); font-weight: 700; margin-bottom: var(--gn-sp-2); } .gnv-sidebar-card p { font-size: var(--gn-fs-sm); color: var(--gn-text-sm); margin-bottom: var(--gn-sp-4); } .gnv-sidebar-follow { background: #EEEAFF; border-color: #D8D1FF; text-align: center; padding: 85px 15px; } .gnv-sidebar-follow .gnv-social-row { justify-content: center; } .gnv-sidebar-follow__btn { border-color: var(--gn-purple) !important; color: var(--gn-purple) !important; } .gnv-sidebar-follow__btn:hover { background: var(--gn-purple) !important; color: #fff !important; } .gnv-social-row { display: flex; gap: var(--gn-sp-2); margin-bottom: var(--gn-sp-4); } .gnv-social-ico { width: 42px; height: 42px; border-radius: var(--gn-r-lg); display: flex; align-items: center; justify-content: center; font-size: 1rem; color: #fff; text-decoration: none; transition: var(--gn-ease); } .gnv-social-ico:hover { transform: translateY(-2px); box-shadow: var(--gn-shadow-md); } .gnv-social-ico--ig { background: linear-gradient(135deg,#E1306C,#F77737); } .gnv-social-ico--fb { background: #1877F2; } .gnv-social-ico--tt { background: #000; } .gnv-social-ico--yt { background: #FF0000; } .gnv-newsletter { background: var(--gn-white); border-top: 1px solid var(--gn-border); padding: var(--gn-sp-10) 0; } .gnv-newsletter__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--gn-sp-8); } .gnv-newsletter h3 { font-size: var(--gn-fs-lg); font-weight: 700; margin-bottom: 4px; } .gnv-newsletter p { font-size: var(--gn-fs-sm); color: var(--gn-text-sm); } .gnv-newsletter__form { display: flex; border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-lg); overflow: hidden; flex-shrink: 0; } .gnv-newsletter__form input { width: 260px; border: none; outline: none; padding: 11px var(--gn-sp-4); font-size: var(--gn-fs-sm); font-family: var(--gn-font); } .gnv-newsletter__form input::placeholder { color: var(--gn-text-xs); } .gnv-newsletter__form button { background: var(--gn-primary); color: #fff; border: none; padding: 11px 22px; font-size: var(--gn-fs-sm); font-weight: 600; cursor: pointer; transition: background .15s; font-family: var(--gn-font); white-space: nowrap; } .gnv-newsletter__form button:hover { background: var(--gn-primary-dark); } .gnv-footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: var(--gn-sp-10); margin-bottom: var(--gn-sp-10); } .gnv-footer-brand__logo img { height: 24px; width: auto; filter: brightness(0) invert(1); opacity: .85; margin-bottom: var(--gn-sp-4); } .gnv-footer-brand__desc { font-size: var(--gn-fs-sm); line-height: 1.7; margin-bottom: var(--gn-sp-5); color: rgba(255,255,255,.6); } .gnv-footer-social { display: flex; gap: var(--gn-sp-3); margin-bottom: var(--gn-sp-5); } .gnv-footer-social a { width: 36px; height: 36px; background: rgba(255,255,255,.1); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.75); text-decoration: none; font-size: 14px; transition: var(--gn-ease); } .gnv-footer-social a:hover { background: var(--gn-primary); color: #fff; } .gnv-footer-col h4 { color: #fff !important; font-size: var(--gn-fs-xs) !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: .09em !important; margin-bottom: var(--gn-sp-4) !important; } .gnv-footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--gn-sp-3); } .gnv-footer-col ul li a { color: rgba(255,255,255,.6); font-size: var(--gn-fs-sm); text-decoration: none; transition: var(--gn-ease); } .gnv-footer-col ul li a:hover { color: #fff; } .gnv-footer-bottom { padding-top: var(--gn-sp-6); border-top: 1px solid rgba(255,255,255,.1); display: flex; align-items: center; justify-content: space-between; gap: var(--gn-sp-4); flex-wrap: wrap; font-size: var(--gn-fs-xs); color: rgba(255,255,255,.35); } .gnv-footer-bottom a { color: rgba(255,255,255,.4); text-decoration: none; } .gnv-footer-bottom a:hover { color: rgba(255,255,255,.8); } .gnv-footer-bottom img { height: 16px; filter: brightness(0) invert(.4); } body > .progress-bar { position: fixed; top: 0; z-index: 600; } .box-default:first-child { margin-top: 0 !important; } @media (max-width: 1100px) { .gnv-company-grid { grid-template-columns: repeat(2, 1fr); } .gnv-promo-card { display: none; } .gnv-blog__layout { grid-template-columns: 1fr; } .gnv-sidebar { display: none; } .gnv-blog__cards { grid-template-columns: repeat(2, 1fr); } .gnv-ai-explainer { grid-template-columns: 1fr; } .gnv-ai-steps { flex-wrap: wrap; justify-content: center; } .gnv-ai-step__arr { display: none; } .gnv-footer-grid { grid-template-columns: 1fr 1fr; } .gnv-newsletter__inner { gap: var(--gn-sp-6); } } @media (max-width: 900px) { .gnv-header .gnv-hnav { display: none !important; } .gnv-header .gnv-hactions { display: none !important; } .gnv-header .gnv-hamburger { display: flex !important; } .gnv-header .gnv-hsearch { max-width: 320px; } .gnv-hero__inner { grid-template-columns: 1fr; } .gnv-ai-card { display: none; } } @media (max-width: 768px) { :root { --gn-header-h: 58px; } .gnv-header .gnv-hsearch { display: none !important; } .gnv-hero { min-height: 80vh; } .gnv-hero__content h1 { font-size: clamp(1.6rem, 6vw, 2.2rem); } .gnv-hero__form-wrap { flex-direction: column; padding: var(--gn-sp-4); border-radius: var(--gn-r-xl); gap: var(--gn-sp-3); } .gnv-hero__form-q { padding: 0; width: 100%; } .gnv-hero__form-div { display: none; } .gnv-hero__form-loc { padding: 0; } .gnv-hero__form-btn { width: 100%; border-radius: var(--gn-r-lg); } .gnv-hero__pills { display: none; } .gnv-company-grid { grid-template-columns: 1fr 1fr; } .gnv-blog__cards { grid-template-columns: 1fr; } .gnv-footer-grid { grid-template-columns: 1fr; gap: var(--gn-sp-8); } .gnv-newsletter__inner { flex-direction: column; text-align: center; } .gnv-newsletter__form { width: 100%; } .gnv-newsletter__form input { flex: 1; width: auto; min-width: 0; } .gnv-ai-explainer { padding: var(--gn-sp-6); } } @media (max-width: 480px) { .gnv-company-grid { grid-template-columns: 1fr; } .gnv-cats__row { gap: var(--gn-sp-2); } .gnv-cat-chip { min-width: 76px; padding: var(--gn-sp-3); } .gnv-cat-chip__ico { width: 42px; height: 42px; font-size: 1.1rem; } } @keyframes gnv-fade-up { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } } .gnv-fade-up { animation: gnv-fade-up .55s ease both; } .gnv-fade-up-d1 { animation-delay: .1s; } .gnv-fade-up-d2 { animation-delay: .22s; } .gnv-fade-up-d3 { animation-delay: .36s; } .gnv-fade-up-d4 { animation-delay: .5s; } .gnv-hero--abstract { background: #050F28; min-height: 72vh; align-items: center; } .gnv-hero__blob { position: absolute; border-radius: 50%; filter: blur(90px); pointer-events: none; z-index: 0; animation: gnv-float 12s ease-in-out infinite; } .gnv-hero__blob--1 { width: 700px; height: 700px; background: radial-gradient(circle, rgba(28,78,216,.38) 0%, transparent 60%); top: -200px; right: -120px; } .gnv-hero__blob--2 { width: 500px; height: 500px; background: radial-gradient(circle, rgba(109,40,217,.28) 0%, transparent 60%); bottom: -160px; left: -60px; animation-duration: 14s; animation-direction: reverse; animation-delay: -4s; } .gnv-hero__blob--3 { width: 360px; height: 360px; background: radial-gradient(circle, rgba(5,150,105,.18) 0%, transparent 60%); top: 50%; left: 48%; transform: translate(-50%, -50%); animation-duration: 10s; animation-delay: -7s; } .gnv-hero__grid { position: absolute; inset: 0; background-image: radial-gradient(circle, rgba(255,255,255,.055) 1px, transparent 1px); background-size: 40px 40px; pointer-events: none; z-index: 0; } .gnv-hero--abstract .gnv-hero__inner { grid-template-columns: 1fr; max-width: 740px; padding-top: var(--gn-sp-20); padding-bottom: var(--gn-sp-20); } .gnv-hero--abstract .gnv-hero__content { text-align: center; } .gnv-hero--abstract .gnv-hero__content > p { margin-left: auto; margin-right: auto; } .gnv-hero--abstract .gnv-hero__form-wrap { margin: 0 auto; } .gnv-hero--abstract .gnv-hero__pills { justify-content: center; } @keyframes gnv-float { 0%, 100% { transform: translateY(0) scale(1); } 50% { transform: translateY(-36px) scale(1.04); } } @media (max-width: 600px) { .gnv-header .gnv-loc-btn .loc-city { max-width: 80px; } } @media (max-width: 480px) { .gnv-header .gnv-loc-btn { display: none; } } .gnv-footer { background: var(--gn-dark); color: rgba(255,255,255,.7); padding: var(--gn-sp-16) 0 var(--gn-sp-8); } .loc-city-results { display: none; } .loc-city-results.open { display: block; } .gnv-header.scrolled { box-shadow: var(--gn-shadow-lg); } .gnv-page-banner { background: var(--gn-dark); padding: var(--gn-sp-10) 0; position: relative; overflow: hidden; } .gnv-page-banner::after { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 70% 50%, rgba(28,78,216,.18) 0%, transparent 60%); pointer-events: none; } .gnv-page-banner__inner { position: relative; z-index: 1; } .gnv-breadcrumb { display: flex; align-items: center; gap: 6px; font-size: var(--gn-fs-xs); color: rgba(255,255,255,.45); margin-bottom: var(--gn-sp-3); list-style: none; padding: 0; flex-wrap: wrap; } .gnv-breadcrumb a { color: rgba(255,255,255,.6); text-decoration: none; transition: var(--gn-ease); } .gnv-breadcrumb a:hover { color: #fff; } .gnv-breadcrumb__sep { font-size: 10px; } .gnv-page-banner__title { color: #fff; font-size: var(--gn-fs-2xl); font-weight: 800; margin-bottom: var(--gn-sp-2); line-height: 1.2; } .gnv-page-banner__sub { color: rgba(255,255,255,.55); font-size: var(--gn-fs-sm); } .gnv-layout-sidebar { display: grid; grid-template-columns: 220px 1fr; gap: var(--gn-sp-8); align-items: start; padding: var(--gn-sp-10) 0; } .gnv-cat-filter { display: flex; flex-direction: column; gap: 2px; } .gnv-cat-filter__heading { font-size: var(--gn-fs-xs); font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--gn-text-xs); padding: 0 var(--gn-sp-3); margin-bottom: var(--gn-sp-2); } .gnv-cat-filter a { display: flex; align-items: center; gap: var(--gn-sp-2); padding: 9px var(--gn-sp-3); border-radius: var(--gn-r-md); font-size: var(--gn-fs-sm); color: var(--gn-text-md); text-decoration: none; transition: var(--gn-ease); } .gnv-cat-filter a:hover, .gnv-cat-filter a.active { background: var(--gn-primary-light); color: var(--gn-primary); } .gnv-cat-filter a i { font-size: 11px; color: var(--gn-text-xs); flex-shrink: 0; } .gnv-cat-filter a:hover i, .gnv-cat-filter a.active i { color: var(--gn-primary); } .gnv-cat-pills { display: flex; gap: var(--gn-sp-2); flex-wrap: wrap; margin-bottom: var(--gn-sp-6); } .gnv-cat-pill { display: inline-flex; align-items: center; gap: 5px; padding: 6px 14px; border-radius: var(--gn-r-full); border: 1.5px solid var(--gn-border); background: var(--gn-white); font-size: var(--gn-fs-xs); font-weight: 600; color: var(--gn-text-md); text-decoration: none; transition: var(--gn-ease); } .gnv-cat-pill:hover, .gnv-cat-pill.active { border-color: var(--gn-primary); background: var(--gn-primary-light); color: var(--gn-primary); } .gnv-ads-stack { display: flex; flex-direction: column; gap: var(--gn-sp-4); } .gnv-company-row { display: flex; align-items: flex-start; gap: var(--gn-sp-4); background: var(--gn-white); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-xl); padding: var(--gn-sp-4); text-decoration: none; transition: var(--gn-ease3); position: relative; } .gnv-company-row:hover { border-color: rgba(var(--gn-primary-rgb),.3); box-shadow: var(--gn-shadow-lg); transform: translateY(-2px); } .gnv-company-row__thumb { width: 88px; height: 88px; flex-shrink: 0; border-radius: var(--gn-r-lg); overflow: hidden; background: var(--gn-bg); border: 1px solid var(--gn-border); } .gnv-company-row__thumb img { width: 100%; height: 100%; object-fit: cover; } .gnv-company-row__body { flex: 1; min-width: 0; } .gnv-company-row__cat { font-size: var(--gn-fs-xs); font-weight: 700; color: var(--gn-primary); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 4px; } .gnv-company-row__name { font-size: var(--gn-fs-base); font-weight: 700; color: var(--gn-text); margin-bottom: 4px; line-height: 1.3; } .gnv-company-row__sub { font-size: var(--gn-fs-xs); color: var(--gn-text-sm); margin-bottom: 8px; } .gnv-company-row__meta { display: flex; align-items: center; gap: var(--gn-sp-4); flex-wrap: wrap; } .gnv-company-row__meta-item { display: flex; align-items: center; gap: 4px; font-size: var(--gn-fs-xs); color: var(--gn-text-sm); } .gnv-company-row__meta-item i { color: var(--gn-text-xs); font-size: 10px; } .gnv-company-row__actions { display: flex; align-items: center; gap: var(--gn-sp-2); flex-shrink: 0; } .gnv-detail-section { padding: var(--gn-sp-10) 0; } .gnv-detail-layout { display: grid; grid-template-columns: 1fr 300px; gap: var(--gn-sp-6); align-items: start; } .gnv-detail-card { background: var(--gn-white); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-2xl); overflow: hidden; } .gnv-detail-card__cover { aspect-ratio: 16/7; background: var(--gn-bg); overflow: hidden; } .gnv-detail-card__cover img { width: 100%; height: 100%; object-fit: cover; } .gnv-detail-card__body { padding: var(--gn-sp-6); } .gnv-detail-card__name { font-size: var(--gn-fs-2xl); font-weight: 800; color: var(--gn-text); margin-bottom: var(--gn-sp-2); } .gnv-detail-card__cat { display: inline-flex; align-items: center; gap: 5px; margin-bottom: var(--gn-sp-4); } .gnv-detail-info { display: flex; flex-direction: column; gap: var(--gn-sp-3); margin-top: var(--gn-sp-4); padding-top: var(--gn-sp-4); border-top: 1px solid var(--gn-bg); } .gnv-detail-info-row { display: flex; align-items: flex-start; gap: var(--gn-sp-3); font-size: var(--gn-fs-sm); color: var(--gn-text-md); } .gnv-detail-info-row i { color: var(--gn-text-xs); width: 16px; flex-shrink: 0; margin-top: 3px; } .gnv-detail-info-row a { color: var(--gn-primary); } .gnv-detail-map { margin-top: var(--gn-sp-5); border-radius: var(--gn-r-xl); overflow: hidden; border: 1.5px solid var(--gn-border); } .gnv-detail-map iframe { display: block; width: 100%; height: 260px; border: none; } .gnv-detail-desc { margin-top: var(--gn-sp-5); background: var(--gn-white); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-xl); padding: var(--gn-sp-6); } .gnv-detail-desc h2 { font-size: var(--gn-fs-xl); font-weight: 700; margin-bottom: var(--gn-sp-4); color: var(--gn-text); } .gnv-contact-card { background: var(--gn-white); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-2xl); padding: var(--gn-sp-5); display: flex; flex-direction: column; gap: var(--gn-sp-3); position: sticky; top: calc(var(--gn-header-h) + 20px); } .gnv-contact-card h3 { font-size: var(--gn-fs-base); font-weight: 700; color: var(--gn-text); margin-bottom: var(--gn-sp-1); } .gnv-contact-card__social { display: flex; gap: var(--gn-sp-2); flex-wrap: wrap; } .gnv-contact-card__social a { width: 36px; height: 36px; border-radius: var(--gn-r-md); display: flex; align-items: center; justify-content: center; background: var(--gn-bg); border: 1px solid var(--gn-border); color: var(--gn-text-sm); font-size: 14px; text-decoration: none; transition: var(--gn-ease); } .gnv-contact-card__social a:hover { background: var(--gn-primary); color: #fff; border-color: var(--gn-primary); } .gnv-share { display: flex; align-items: center; gap: var(--gn-sp-2); flex-wrap: wrap; margin-top: var(--gn-sp-3); } .gnv-share__label { font-size: var(--gn-fs-xs); font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--gn-text-xs); } .gnv-share a { display: inline-flex; align-items: center; gap: 5px; padding: 6px 12px; border-radius: var(--gn-r-full); font-size: var(--gn-fs-xs); font-weight: 600; text-decoration: none; transition: var(--gn-ease); } .gnv-share a:hover { transform: translateY(-1px); box-shadow: var(--gn-shadow-sm); } .gnv-share a.share-wa { background: #25D366; color: #fff; } .gnv-share a.share-fb { background: #1877F2; color: #fff; } .gnv-share a.share-tw { background: #000; color: #fff; } .gnv-share a.share-copy { background: var(--gn-bg); border: 1.5px solid var(--gn-border); color: var(--gn-text-md); } .gnv-blog-list-section { padding: var(--gn-sp-10) 0; } .gnv-blog-hero { position: relative; min-height: 52vh; display: flex; align-items: flex-end; overflow: hidden; } .gnv-blog-hero__bg { position: absolute; inset: 0; } .gnv-blog-hero__bg img { width: 100%; height: 100%; object-fit: cover; } .gnv-blog-hero__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(5,10,30,.96) 0%, rgba(5,10,30,.55) 55%, rgba(5,10,30,.15) 100%); } .gnv-blog-hero__content { position: relative; z-index: 1; padding: var(--gn-sp-12) var(--gn-pad) var(--gn-sp-10); max-width: var(--gn-max); margin: 0 auto; width: 100%; } .gnv-blog-hero__cat { display: inline-flex; align-items: center; gap: 5px; background: var(--gn-primary); color: #fff; font-size: var(--gn-fs-xs); font-weight: 700; text-transform: uppercase; letter-spacing: .07em; padding: 4px 12px; border-radius: var(--gn-r-full); margin-bottom: var(--gn-sp-4); text-decoration: none; } .gnv-blog-hero__title { color: #fff; font-size: clamp(1.5rem, 3.5vw, 2.4rem); font-weight: 900; line-height: 1.2; margin-bottom: var(--gn-sp-4); max-width: 760px; } .gnv-blog-hero__meta { display: flex; align-items: center; gap: var(--gn-sp-4); font-size: var(--gn-fs-xs); color: rgba(255,255,255,.55); flex-wrap: wrap; } .gnv-blog-hero__meta i { font-size: 10px; } .gnv-article-section { padding: var(--gn-sp-10) 0; } .gnv-article-layout { display: grid; grid-template-columns: 1fr 280px; gap: var(--gn-sp-10); align-items: start; } .gnv-article { background: var(--gn-white); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-2xl); padding: var(--gn-sp-8); } .gnv-article__subtitle { font-size: var(--gn-fs-xl); font-weight: 700; color: var(--gn-text); margin-bottom: var(--gn-sp-6); line-height: 1.35; } .gnv-article__body { font-size: var(--gn-fs-base); color: var(--gn-text-md); line-height: 1.85; } .gnv-article__body p { margin-bottom: var(--gn-sp-4); } .gnv-article__body h2, .gnv-article__body h3 { color: var(--gn-text); margin: var(--gn-sp-6) 0 var(--gn-sp-3); font-size: var(--gn-fs-xl); } .gnv-article__body img { border-radius: var(--gn-r-lg); margin: var(--gn-sp-5) 0; max-width: 100%; height: auto; } .gnv-article__body a { color: var(--gn-primary); text-decoration: underline; } .gnv-article__body blockquote { border-left: 4px solid var(--gn-primary); padding: var(--gn-sp-4) var(--gn-sp-5); margin: var(--gn-sp-5) 0; background: var(--gn-primary-light); border-radius: 0 var(--gn-r-lg) var(--gn-r-lg) 0; color: var(--gn-text-md); } .gnv-article__font { margin-top: var(--gn-sp-6); padding-top: var(--gn-sp-4); border-top: 1px solid var(--gn-bg); font-size: var(--gn-fs-xs); color: var(--gn-text-xs); } .gnv-article__font a { color: var(--gn-text-sm); } .gnv-pagination { display: flex; align-items: center; justify-content: center; gap: var(--gn-sp-2); flex-wrap: wrap; padding: var(--gn-sp-8) 0; } .gnv-pagination a, .gnv-pagination span { display: inline-flex; align-items: center; justify-content: center; min-width: 38px; height: 38px; padding: 0 var(--gn-sp-3); border-radius: var(--gn-r-md); font-size: var(--gn-fs-sm); font-weight: 600; text-decoration: none; transition: var(--gn-ease); border: 1.5px solid var(--gn-border); color: var(--gn-text-md); background: var(--gn-white); } .gnv-pagination a:hover { border-color: var(--gn-primary); color: var(--gn-primary); background: var(--gn-primary-light); } .gnv-pagination a.active { background: var(--gn-primary); color: #fff; border-color: var(--gn-primary); } .gnv-pagination span { color: var(--gn-text-xs); cursor: default; } .gnv-page-content { background: var(--gn-white); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-2xl); padding: var(--gn-sp-10) var(--gn-sp-12); max-width: 820px; } .gnv-page-content h1, .gnv-page-content h2, .gnv-page-content h3 { color: var(--gn-text); margin-bottom: var(--gn-sp-3); } .gnv-page-content p { color: var(--gn-text-md); line-height: 1.8; margin-bottom: var(--gn-sp-4); font-size: var(--gn-fs-base); } .gnv-page-content a { color: var(--gn-primary); } @media (max-width: 768px) { .gnv-page-content { padding: var(--gn-sp-6) var(--gn-sp-5); } } .gnv-contact-layout { display: grid; grid-template-columns: 1fr 320px; gap: var(--gn-sp-8); align-items: start; padding: var(--gn-sp-10) 0; } .gnv-contact-info { display: flex; flex-direction: column; gap: var(--gn-sp-5); } .gnv-contact-info-row { display: flex; align-items: flex-start; gap: var(--gn-sp-4); background: var(--gn-white); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-xl); padding: var(--gn-sp-5); } .gnv-contact-info-row__ico { width: 44px; height: 44px; flex-shrink: 0; border-radius: var(--gn-r-lg); background: var(--gn-primary-light); display: flex; align-items: center; justify-content: center; color: var(--gn-primary); font-size: 1.1rem; } .gnv-contact-info-row__body h4 { font-size: var(--gn-fs-sm); font-weight: 700; color: var(--gn-text); margin-bottom: 4px; } .gnv-contact-info-row__body p, .gnv-contact-info-row__body a { font-size: var(--gn-fs-sm); color: var(--gn-text-sm); text-decoration: none; } @media (max-width: 900px) { .gnv-contact-layout { grid-template-columns: 1fr; } .gnv-contact-info { order: 2; } } .gnv-search-results-header { background: var(--gn-white); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-xl); padding: var(--gn-sp-4) var(--gn-sp-5); margin-bottom: var(--gn-sp-5); display: flex; align-items: center; gap: var(--gn-sp-3); flex-wrap: wrap; } .gnv-search-results-header strong { color: var(--gn-primary); } .gnv-ai-badge { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px; border-radius: var(--gn-r-full); background: linear-gradient(135deg, var(--gn-purple), var(--gn-primary)); color: #fff; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; } .gnv-media-section { padding: var(--gn-sp-8) 0; background: var(--gn-bg); } .gnv-media-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--gn-sp-4); } .gnv-media-card { background: var(--gn-white); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-xl); overflow: hidden; text-decoration: none; display: flex; flex-direction: column; transition: var(--gn-ease3); } .gnv-media-card:hover { box-shadow: var(--gn-shadow-lg); transform: translateY(-4px); } .gnv-media-card__poster { aspect-ratio: 2/3; overflow: hidden; background: var(--gn-dark); position: relative; } .gnv-media-card__poster img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; } .gnv-media-card:hover .gnv-media-card__poster img { transform: scale(1.06); } .gnv-media-card__badge { position: absolute; top: 8px; left: 8px; background: var(--gn-primary); color: #fff; font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: var(--gn-r-full); text-transform: uppercase; } .gnv-media-card__body { padding: var(--gn-sp-3); flex: 1; } .gnv-media-card__title { font-size: var(--gn-fs-sm); font-weight: 700; color: var(--gn-text); line-height: 1.35; margin-bottom: 4px; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; } .gnv-media-card:hover .gnv-media-card__title { color: var(--gn-primary); } .gnv-media-card__date { font-size: var(--gn-fs-xs); color: var(--gn-text-xs); } .gnv-media-hero { position: relative; min-height: 56vh; display: flex; align-items: flex-end; overflow: hidden; } .gnv-media-hero__bg { position: absolute; inset: 0; } .gnv-media-hero__bg img { width: 100%; height: 100%; object-fit: cover; } .gnv-media-hero__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(5,10,30,.98) 0%, rgba(5,10,30,.6) 55%, rgba(5,10,30,.2) 100%); } .gnv-media-hero__content { position: relative; z-index: 1; padding: var(--gn-sp-12) var(--gn-pad) var(--gn-sp-10); max-width: var(--gn-max); margin: 0 auto; width: 100%; } .gnv-media-hero__type { display: inline-flex; align-items: center; gap: 5px; background: var(--gn-primary); color: #fff; font-size: var(--gn-fs-xs); font-weight: 700; padding: 4px 12px; border-radius: var(--gn-r-full); margin-bottom: var(--gn-sp-3); } .gnv-media-hero__title { color: #fff; font-size: clamp(1.6rem, 3.5vw, 2.6rem); font-weight: 900; line-height: 1.15; margin-bottom: var(--gn-sp-3); max-width: 700px; } .gnv-media-hero__meta { display: flex; gap: var(--gn-sp-4); font-size: var(--gn-fs-xs); color: rgba(255,255,255,.55); flex-wrap: wrap; } .gnv-media-detail-section { padding: var(--gn-sp-8) 0; background: var(--gn-bg); } .gnv-media-detail-layout { display: grid; grid-template-columns: 240px 1fr; gap: var(--gn-sp-8); align-items: start; } .gnv-media-detail-poster { border-radius: var(--gn-r-2xl); overflow: hidden; border: 1.5px solid var(--gn-border); cursor: pointer; } .gnv-media-detail-poster img { width: 100%; display: block; } .gnv-media-detail-body { background: var(--gn-white); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-2xl); padding: var(--gn-sp-7); } .gnv-media-detail-body h1 { font-size: var(--gn-fs-2xl); font-weight: 900; color: var(--gn-text); margin-bottom: var(--gn-sp-2); } .gnv-media-meta-list { display: flex; flex-direction: column; gap: var(--gn-sp-3); margin: var(--gn-sp-5) 0; padding-top: var(--gn-sp-5); border-top: 1px solid var(--gn-bg); } .gnv-media-meta-row { display: flex; align-items: flex-start; gap: var(--gn-sp-3); font-size: var(--gn-fs-sm); color: var(--gn-text-md); } .gnv-media-meta-row strong { color: var(--gn-text); min-width: 100px; flex-shrink: 0; } .gnv-media-synopsis { margin-top: var(--gn-sp-5); padding-top: var(--gn-sp-5); border-top: 1px solid var(--gn-bg); } .gnv-media-synopsis h2 { font-size: var(--gn-fs-xl); font-weight: 700; color: var(--gn-text); margin-bottom: var(--gn-sp-3); } .gnv-media-synopsis p { font-size: var(--gn-fs-base); color: var(--gn-text-md); line-height: 1.8; } .gnv-trailer-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gn-sp-4); margin-top: var(--gn-sp-5); } .gnv-trailer-item { border-radius: var(--gn-r-xl); overflow: hidden; cursor: pointer; position: relative; aspect-ratio: 16/9; background: var(--gn-dark); } .gnv-trailer-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; } .gnv-trailer-item:hover img { transform: scale(1.04); } .gnv-trailer-play { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,.3); } .gnv-trailer-play i { font-size: 2rem; color: #fff; filter: drop-shadow(0 2px 6px rgba(0,0,0,.5)); } .gnv-review-card { background: var(--gn-white); border: 1.5px solid var(--gn-border); border-radius: var(--gn-r-xl); padding: var(--gn-sp-5); margin-bottom: var(--gn-sp-4); } .gnv-review-card h4 { font-size: var(--gn-fs-sm); font-weight: 700; color: var(--gn-text); margin-bottom: var(--gn-sp-2); } .gnv-review-card p { font-size: var(--gn-fs-sm); color: var(--gn-text-md); line-height: 1.7; display: -webkit-box; -webkit-line-clamp: 5; line-clamp: 5; -webkit-box-orient: vertical; overflow: hidden; } .gnv-review-card small { font-size: var(--gn-fs-xs); color: var(--gn-text-xs); margin-top: var(--gn-sp-2); display: block; } @media (max-width: 1024px) { .gnv-media-grid { grid-template-columns: repeat(3, 1fr); } .gnv-media-detail-layout { grid-template-columns: 1fr; } .gnv-media-detail-poster { max-width: 240px; } .gnv-trailer-grid { grid-template-columns: repeat(2, 1fr); } } @media (max-width: 768px) { .gnv-media-grid { grid-template-columns: repeat(2, 1fr); } .gnv-trailer-grid { grid-template-columns: 1fr; } .gnv-media-hero { min-height: 50vh; } .gnv-media-hero__title { font-size: clamp(1.3rem, 5vw, 1.8rem); } } @media (max-width: 480px) { .gnv-media-grid { grid-template-columns: repeat(2, 1fr); gap: var(--gn-sp-3); } } @media (max-width: 1024px) { .gnv-layout-sidebar { grid-template-columns: 1fr; } .gnv-layout-sidebar .gnv-cat-filter { display: none; } .gnv-detail-layout { grid-template-columns: 1fr; } .gnv-contact-card { position: static; } .gnv-article-layout { grid-template-columns: 1fr; } .gnv-article-layout .gnv-sidebar { display: none; } } @media (max-width: 768px) { .gnv-page-banner { padding: var(--gn-sp-8) 0; } .gnv-page-banner__title { font-size: var(--gn-fs-xl); } .gnv-blog-hero { min-height: 60vh; } .gnv-blog-hero__title { font-size: clamp(1.3rem, 5vw, 1.8rem); } .gnv-company-row { flex-direction: column; } .gnv-company-row__thumb { width: 100%; height: 160px; } .gnv-company-row__actions { width: 100%; } .gnv-article { padding: var(--gn-sp-5); } .gnv-layout-sidebar { padding: var(--gn-sp-6) 0; } .gnv-detail-section { padding: var(--gn-sp-6) 0; } } .gnv-media-card { position: relative; } .gnv-media-card > img { aspect-ratio: 2/3; width: 100%; display: block; object-fit: cover; transition: transform .4s ease; } .gnv-media-card:hover > img { transform: scale(1.06); } .gnv-media-card__year { font-size: var(--gn-fs-xs); color: var(--gn-text-xs); } .gnv-pagination__link { display: inline-flex; align-items: center; justify-content: center; min-width: 38px; height: 38px; padding: 0 var(--gn-sp-3); border-radius: var(--gn-r-md); font-size: var(--gn-fs-sm); font-weight: 600; text-decoration: none; transition: var(--gn-ease); border: 1.5px solid var(--gn-border); color: var(--gn-text-md); background: var(--gn-white); } .gnv-pagination__link:hover { border-color: var(--gn-primary); color: var(--gn-primary); background: var(--gn-primary-light); } .gnv-pagination__link--active { background: var(--gn-primary) !important; color: #fff !important; border-color: var(--gn-primary) !important; cursor: default; } .gnv-pagination__ellipsis { display: inline-flex; align-items: center; justify-content: center; min-width: 38px; height: 38px; color: var(--gn-text-xs); cursor: default; } .gnv-contact-info-row__body strong { display: block; font-size: var(--gn-fs-sm); font-weight: 700; color: var(--gn-text); margin-bottom: 2px; } .gnv-contact-info-row__body span { font-size: var(--gn-fs-sm); color: var(--gn-text-sm); } .gnv-ads-hero { position: relative; min-height: 360px; display: flex; align-items: flex-end; background-color: var(--gn-dark); background-size: cover; background-position: center; } .gnv-ads-hero__overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(0,0,0,.15) 0%, rgba(0,0,0,.72) 100%); } .gnv-ads-hero__content { position: relative; z-index: 1; padding: var(--gn-sp-8) 0 var(--gn-sp-6); display: flex; flex-direction: column; gap: var(--gn-sp-3); } .gnv-ads-hero__logo { width: 80px; height: 80px; border-radius: var(--gn-r-md); border: 3px solid rgba(255,255,255,.85); overflow: hidden; background: #fff; flex-shrink: 0; box-shadow: 0 4px 20px rgba(0,0,0,.3); } .gnv-ads-hero__logo img { width: 100%; height: 100%; object-fit: cover; } .gnv-ads-hero__title { font-size: var(--gn-fs-2xl); font-weight: 800; color: #fff; line-height: 1.2; text-shadow: 0 2px 8px rgba(0,0,0,.4); margin: 0; } .gnv-ads-hero__sub { font-size: var(--gn-fs-sm); color: rgba(255,255,255,.82); margin: 0; } @media (max-width: 640px) { .gnv-ads-hero { min-height: 280px; } .gnv-ads-hero__title { font-size: var(--gn-fs-xl); } }