/* SERVICES PAGE SPECIFIC STYLES */ .breadcrumb { background: var(--gray-100); padding: 12px 80px; font-size: 12px; color: var(--gray-600); display: flex; align-items: center; gap: 8px; margin-top: 64px; border-bottom: 1px solid var(--gray-200); } .breadcrumb a { color: var(--navy-mid); text-decoration: none; } .breadcrumb a:hover { color: var(--orange); } .breadcrumb span { color: var(--gray-400); } /* HERO */ .hero-staining { background: var(--navy); position: relative; overflow: hidden; padding: 80px 24px; } .hero-grid-bg { position: absolute; inset: 0; opacity: .035; background-image: repeating-linear-gradient(0deg, transparent, transparent 39px, rgba(255, 255, 255, .6) 39px, rgba(255, 255, 255, .6) 40px), repeating-linear-gradient(90deg, transparent, transparent 39px, rgba(255, 255, 255, .6) 39px, rgba(255, 255, 255, .6) 40px); } .hero-wood-deco { position: absolute; right: 0; top: 0; bottom: 0; width: 42%; opacity: .06; background-image: repeating-linear-gradient(-10deg, transparent 0px, transparent 12px, rgba(255, 255, 255, .7) 12px, rgba(255, 255, 255, .7) 14px, transparent 14px, transparent 30px, rgba(255, 255, 255, .4) 30px, rgba(255, 255, 255, .4) 32px); } .hero-accent-circle { position: absolute; right: -80px; bottom: -80px; width: 360px; height: 360px; border-radius: 50%; border: 56px solid var(--orange); opacity: .1; } .hero-inner { position: relative; z-index: 2; max-width: 760px; } .hero-eyebrow { display: inline-flex; align-items: center; gap: 10px; font-family: var(--fd); font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--orange); margin-bottom: 20px; } .hero-eyebrow::before { content: ''; display: block; width: 28px; height: 2px; background: var(--orange); } .hero-staining h1 { font-family: var(--fd); font-size: clamp(44px, 5.5vw, 80px); font-weight: 800; line-height: .92; color: var(--white); letter-spacing: -.01em; text-transform: uppercase; margin-bottom: 24px; } .hero-staining h1 em { color: var(--orange); font-style: normal; display: block; } .hero-desc { font-size: 17px; font-weight: 300; line-height: 1.75; color: rgba(255, 255, 255, .65); max-width: 600px; margin-bottom: 36px; } .hero-desc strong { color: rgba(255, 255, 255, .9); font-weight: 500; } .hero-badges { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 40px; } .badge { font-family: var(--fd); font-size: 12px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; padding: 7px 14px; border-radius: 4px; border: 1px solid rgba(255, 255, 255, .2); color: rgba(255, 255, 255, .8); } .badge-fill { background: var(--orange); border-color: var(--orange); color: var(--white); } .hero-stats-row { display: flex; gap: 48px; padding-top: 32px; border-top: 1px solid rgba(255, 255, 255, .1); } /* JUMP NAV */ .model-nav { background: var(--white); border-bottom: 2px solid var(--gray-200); padding: 0 80px; display: flex; gap: 0; position: sticky; top: 64px; z-index: 90; overflow-x: auto; } .model-nav-item { font-family: var(--fd); font-size: 13px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: var(--gray-600); padding: 16px 22px; border-bottom: 3px solid transparent; cursor: pointer; text-decoration: none; transition: color .2s, border-color .2s; display: block; white-space: nowrap; } .model-nav-item:hover { color: var(--orange); border-bottom-color: var(--orange); } .model-nav-item.active { color: var(--navy); border-bottom-color: var(--navy); } /* INTRO */ .intro { padding: 80px 24px; background: var(--white); } .intro-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; margin-top: 40px; } .intro-text p { font-size: 15px; line-height: 1.8; color: var(--gray-600); margin-bottom: 16px; } .intro-text p strong { color: var(--gray-800); font-weight: 600; } .check-list { list-style: none; display: flex; flex-direction: column; gap: 10px; margin-top: 8px; } .check-list li { display: flex; align-items: flex-start; gap: 12px; font-size: 14px; color: var(--gray-600); line-height: 1.5; } .check-list li::before { content: '✓'; width: 22px; height: 22px; border-radius: 50%; background: rgba(232, 87, 42, .12); color: var(--orange); font-size: 11px; font-weight: 700; flex-shrink: 0; display: flex; align-items: center; justify-content: center; margin-top: 1px; } .highlight-cards { display: flex; flex-direction: column; gap: 14px; } .hcard { background: var(--gray-100); border-radius: 10px; padding: 18px 22px; border-left: 3px solid var(--orange); } .hcard-title { font-family: var(--fd); font-size: 16px; font-weight: 700; text-transform: uppercase; color: var(--navy); letter-spacing: .02em; margin-bottom: 5px; } .hcard-desc { font-size: 13px; color: var(--gray-600); line-height: 1.6; } /* SERVICE SECTIONS */ .model-section { padding: 80px 24px; position: relative; overflow: hidden; } .model-section.bg-white { background: var(--white); } .model-section.bg-gray { background: var(--gray-100); } .model-section.bg-navy { background: var(--navy); } .model-section.bg-cream { background: var(--cream); } .model-label { display: inline-flex; align-items: center; gap: 8px; font-family: var(--fd); font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--orange); margin-bottom: 10px; } .model-label::before { content: ''; display: block; width: 20px; height: 2px; background: var(--orange); } .model-label.dim { color: rgba(255, 255, 255, .5); } .model-label.dim::before { background: rgba(255, 255, 255, .3); } .model-name { font-family: var(--fd); font-size: clamp(36px, 5vw, 64px); font-weight: 800; text-transform: uppercase; color: var(--navy); letter-spacing: -.02em; line-height: .9; margin-bottom: 6px; } .model-name.white { color: var(--white); } .model-tagline { font-family: var(--fd); font-size: 16px; font-weight: 500; text-transform: uppercase; letter-spacing: .06em; color: var(--orange); margin-bottom: 24px; } .model-desc { font-size: 15px; color: var(--gray-600); line-height: 1.8; margin-bottom: 28px; max-width: 480px; } .model-desc.white { color: rgba(255, 255, 255, .65); } .model-accent-strip { height: 4px; background: var(--orange); border-radius: 2px; width: 48px; margin-bottom: 20px; } .model-image-col { display: flex; flex-direction: column; } .photo-area { background: var(--gray-200); border-radius: 12px; border: 2px dashed var(--gray-400); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; position: relative; overflow: hidden; } .photo-area.dark-placeholder { background: rgba(255, 255, 255, .05); border-color: rgba(255, 255, 255, .2); } .photo-icon { opacity: .35; } .photo-label { font-family: var(--fd); font-size: 13px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--gray-400); } .photo-sub { font-size: 12px; color: var(--gray-400); } .photo-area.dark-placeholder .photo-label { color: rgba(255, 255, 255, .35); } .photo-area.dark-placeholder .photo-sub { color: rgba(255, 255, 255, .25); } .model-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: stretch; /* Key for matching height */ margin-top: 40px; } .photo-area-large { flex: 1; min-height: 300px; } .photo-area-small { min-height: 180px; } .photo-area img { width: 100%; height: 100%; object-fit: cover; display: block; } .model-layout.reverse { direction: rtl; } .model-layout.reverse>* { direction: ltr; } .photo-row-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 12px; flex-shrink: 0; } .specs-block { margin-top: 24px; } .specs-title { font-family: var(--fd); font-size: 13px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--gray-400); margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--gray-200); } .specs-title.white { color: rgba(255, 255, 255, .35); border-bottom-color: rgba(255, 255, 255, .1); } .spec-row { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid var(--gray-100); gap: 12px; } .spec-row.white-row { border-bottom-color: rgba(255, 255, 255, .08); } .spec-row:last-child { border-bottom: none; } .spec-key { font-size: 13px; color: var(--gray-600); } .spec-key.white { color: rgba(255, 255, 255, .55); } .spec-val { font-family: var(--fd); font-size: 14px; font-weight: 700; color: var(--navy); letter-spacing: .02em; text-align: right; } .spec-val.white { color: var(--white); } .spec-val.orange { color: var(--orange); } /* PROCESS */ .process-section { padding: 80px 24px; background: var(--navy); } .process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-top: 48px; } .process-step { text-align: center; padding: 24px 18px; } .step-num { font-family: var(--fd); font-size: 52px; font-weight: 800; color: var(--orange); line-height: 1; margin-bottom: 12px; } .step-title { font-family: var(--fd); font-size: 18px; font-weight: 700; text-transform: uppercase; color: var(--white); letter-spacing: .03em; margin-bottom: 10px; } .step-desc { font-size: 13px; color: rgba(255, 255, 255, .55); line-height: 1.7; } /* WOOD CONDITION CARDS */ .condition-section { padding: 80px 24px; background: var(--cream); } .condition-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 48px; } .condition-card { background: var(--white); border: 1px solid var(--gray-200); border-radius: 10px; padding: 24px 20px; transition: border-color .2s, transform .2s; } .condition-card:hover { border-color: var(--orange); transform: translateY(-3px); } .condition-tag { display: inline-block; font-family: var(--fd); font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 4px 10px; border-radius: 3px; margin-bottom: 14px; } .tag-new { background: rgba(15, 36, 68, .08); color: var(--navy-mid); } .tag-recent { background: rgba(42, 82, 152, .1); color: var(--navy-light); } .tag-aged { background: rgba(232, 87, 42, .12); color: var(--orange-dark); } .tag-damaged { background: rgba(232, 87, 42, .2); color: var(--orange-dark); } .condition-title { font-family: var(--fd); font-size: 17px; font-weight: 700; text-transform: uppercase; color: var(--navy); letter-spacing: .02em; margin-bottom: 8px; line-height: 1.1; } .condition-desc { font-size: 13px; color: var(--gray-600); line-height: 1.65; margin-bottom: 10px; } .condition-action { font-family: var(--fd); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--orange); } /* FAQ + SEO */ .faq-section { padding: 80px 24px; background: var(--white); } .faq-seo-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; margin-top: 48px; } .faq { display: flex; flex-direction: column; gap: 0; } .faq-item { border-bottom: 1px solid var(--gray-200); } .faq-q { font-family: var(--fd); font-size: 15px; font-weight: 700; text-transform: uppercase; color: var(--navy); letter-spacing: .02em; padding: 18px 0; cursor: pointer; display: flex; align-items: center; justify-content: space-between; transition: color .2s; user-select: none; } .faq-q:hover { color: var(--orange); } .faq-icon { width: 22px; height: 22px; border-radius: 50%; background: rgba(232, 87, 42, .1); color: var(--orange); display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; transition: transform .3s; } .faq-item.open .faq-icon { transform: rotate(45deg); } .faq-a { font-size: 14px; color: var(--gray-600); line-height: 1.75; max-height: 0; overflow: hidden; transition: max-height .35s ease, padding .3s; } .faq-item.open .faq-a { max-height: 500px; padding-bottom: 18px; } .content-block h3 { font-family: var(--fd); font-size: 19px; font-weight: 700; text-transform: uppercase; color: var(--navy); letter-spacing: .03em; margin-bottom: 10px; margin-top: 28px; } .content-block h3:first-child { margin-top: 0; } .content-block p { font-size: 14px; color: var(--gray-600); line-height: 1.8; margin-bottom: 14px; } /* TERRITORY RE-STYLING FOR SERVICE PAGE */ .territory-service { padding: 80px 24px; background: var(--navy); } .territory-service .sh-white { color: var(--white); margin-bottom: 0; } .territory-intro { font-size: 15px; color: rgba(255, 255, 255, .6); line-height: 1.7; max-width: 600px; margin-top: 14px; margin-bottom: 48px; } .region-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; } .region-block { background: rgba(255, 255, 255, .05); border: 1px solid rgba(255, 255, 255, .1); border-radius: 10px; padding: 20px; transition: background .2s, border-color .2s; } .region-block:hover { background: rgba(232, 87, 42, .1); border-color: rgba(232, 87, 42, .3); } .region-name { font-family: var(--fd); font-size: 13px; font-weight: 700; text-transform: uppercase; color: var(--orange); letter-spacing: .06em; margin-bottom: 12px; padding-bottom: 10px; border-bottom: 1px solid rgba(255, 255, 255, .1); } .region-cities { list-style: none; display: flex; flex-direction: column; gap: 5px; } .region-cities li { font-size: 12px; color: rgba(255, 255, 255, .55); } .region-cities li.primary { color: rgba(255, 255, 255, .9); font-weight: 500; } .region-cities a { color: inherit; text-decoration: none; transition: color .2s; } .region-cities a:hover { color: var(--orange); } /* QUOTE CTA */ .quote-cta { padding: 80px 24px; background: var(--orange); } .quote-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; } .quote-left h2 { font-family: var(--fd); font-size: clamp(38px, 4vw, 60px); font-weight: 800; text-transform: uppercase; color: var(--white); line-height: .92; letter-spacing: -.01em; margin-bottom: 16px; } .quote-left p { font-size: 16px; color: rgba(255, 255, 255, .8); line-height: 1.7; } .quote-form-card { background: rgba(255, 255, 255, .12); border: 1px solid rgba(255, 255, 255, .2); border-radius: 12px; padding: 32px; } .ql { display: block; font-size: 11px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: rgba(255, 255, 255, .6); margin-bottom: 6px; } .qi { width: 100%; /* background: var(--navy); */ border: 1px solid rgba(255, 255, 255, .2); border-radius: 6px; padding: 11px 14px; font-family: var(--fb); font-size: 14px; color: var(--white); outline: none; transition: border-color .2s; margin-bottom: 12px; appearance: none; } .qi::placeholder { color: rgba(255, 255, 255, .4); } .qi:focus { border-color: rgba(255, 255, 255, .7); } .qrow { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; } .qbtn { width: 100%; background: var(--white); color: var(--orange); font-family: var(--fd); font-size: 16px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 14px; border: none; border-radius: 6px; cursor: pointer; margin-top: 4px; transition: background .2s; } .qbtn:hover { background: var(--cream); } @media(max-width:900px) { .breadcrumb, .intro, .model-section, .process-section, .condition-section, .faq-section, .territory-service, .quote-cta { padding-left: 24px; padding-right: 24px; } .intro-grid, .model-layout, .faq-seo-grid, .quote-inner { grid-template-columns: 1fr; gap: 28px; } .process-grid, .condition-grid, .region-grid { grid-template-columns: 1fr 1fr; } .qrow { grid-template-columns: 1fr; } .model-nav { padding: 0 24px; } .photo-row-grid { grid-template-columns: 1fr; } } @media(max-width:600px) { .process-grid, .condition-grid, .region-grid { grid-template-columns: 1fr; } } @media (max-width: 768px) { .hero-staining, .intro, .model-section, .process-section, .condition-section, .faq-section, .territory-service, .quote-cta { padding-top: 60px !important; padding-bottom: 60px !important; } }