/* Theme Name: SahabatHewan 
Theme URI: https://sahabathewan.com 
Author: Iklanin Media Digital 
Author URI: https://iklanin.my.id 
Description: Klinik hewan terpercaya dengan dokter spesialis berpengalaman untuk kesehatan hewan kesayangan Anda.
Version: 1.0.0 
License: GNU General Public License v2 or later License 
URI: http://www.gnu.org/licenses/gpl-2.0.html 
Text Domain: sahabathewan
Tags: one-page, veterinary, clinic, one-column, custom-logo, custom-colors 

*/ /* ===== RESET & BASE ===== */ 
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; } :root { --color-primary: #1B6B4A; --color-primary-light: #2E8B63; --color-accent: #F5A623; --color-accent-dark: #D4891A; --color-dark: #1a1a2e; --color-text: #333333; --color-text-light: #666666; --color-bg: #ffffff; --color-bg-alt: #f8faf9; --color-border: #e2e8f0; --color-success: #22c55e; --font-heading: 'Poppins', sans-serif; --font-body: 'Nunito', sans-serif; --shadow-sm: 0 1px 3px rgba(0,0,0,0.08); --shadow-md: 0 4px 12px rgba(0,0,0,0.1); --shadow-lg: 0 10px 30px rgba(0,0,0,0.12); --shadow-xl: 0 20px 40px rgba(0,0,0,0.15); --radius: 16px; --radius-full: 9999px; } html { scroll-behavior: smooth; } body { font-family: var(--font-body); color: var(--color-text); background: var(--color-bg); line-height: 1.7; -webkit-font-smoothing: antialiased; } h1, h2, h3, h4, h5, h6 { font-family: var(--font-heading); font-weight: 800; line-height: 1.2; } a { text-decoration: none; color: inherit; transition: all 0.3s ease; } img { max-width: 100%; height: auto; display: block; } ul { list-style: none; } .container { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 20px; } 

/* ===== NAVBAR ===== */ 
.navbar { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; background: rgba(255,255,255,0.97); backdrop-filter: blur(12px); box-shadow: var(--shadow-sm); transition: all 0.3s ease; } .navbar .container { display: flex; align-items: center; justify-content: space-between; height: 70px; } .navbar-brand { display: flex; align-items: center; gap: 8px; font-family: var(--font-heading); font-size: 1.4rem; font-weight: 900; } .navbar-brand .emoji { font-size: 1.6rem; } .navbar-brand .brand-text { background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; } .nav-links { display: flex; align-items: center; gap: 32px; } .nav-links a { font-size: 0.9rem; font-weight: 600; color: var(--color-text-light); } .nav-links a:hover { color: var(--color-primary); } .btn-nav-cta { display: inline-flex; align-items: center; gap: 8px; background: var(--color-primary); color: #fff; padding: 10px 24px; border-radius: var(--radius-full); font-size: 0.9rem; font-weight: 700; border: none; cursor: pointer; } .btn-nav-cta:hover { background: var(--color-primary-light); color: #fff; } .mobile-toggle { display: none; background: none; border: none; font-size: 1.5rem; cursor: pointer; color: var(--color-text); padding: 8px; } .mobile-menu { display: none; flex-direction: column; gap: 0; background: var(--color-bg); border-top: 1px solid var(--color-border); padding: 16px 20px; } .mobile-menu.active { display: flex; } .mobile-menu a { font-size: 0.95rem; font-weight: 600; padding: 12px 0; color: var(--color-text-light); border-bottom: 1px solid var(--color-border); } .mobile-menu a:last-child { border-bottom: none; } @media (max-width: 768px) { .nav-links { display: none; } .mobile-toggle { display: block; } } 

/* ===== HERO ===== */ 
.hero { position: relative; min-height: 90vh; display: flex; align-items: center; padding-top: 70px; overflow: hidden; } .hero-bg { position: absolute; inset: 0; } .hero-bg img { width: 100%; height: 100%; object-fit: cover; } .hero-overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(27,107,74,0.85) 0%, rgba(26,26,46,0.75) 100%); } .hero-content { position: relative; z-index: 2; max-width: 640px; } .hero-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(245,166,35,0.2); backdrop-filter: blur(8px); color: #fff; padding: 6px 16px; border-radius: var(--radius-full); font-size: 0.85rem; font-weight: 600; margin-bottom: 24px; } .hero h1 { font-size: 3rem; color: #fff; margin-bottom: 20px; } .hero h1 .accent { color: var(--color-accent); } .hero p { color: rgba(255,255,255,0.8); font-size: 1.1rem; margin-bottom: 32px; max-width: 500px; } .hero-buttons { display: flex; flex-wrap: wrap; gap: 16px; } .btn-primary { display: inline-flex; align-items: center; gap: 8px; background: var(--color-accent); color: var(--color-dark); padding: 14px 32px; border-radius: var(--radius-full); font-weight: 700; font-size: 0.9rem; border: none; cursor: pointer; box-shadow: var(--shadow-lg); transition: transform 0.2s ease; } .btn-primary:hover { transform: scale(1.05); color: var(--color-dark); } .btn-outline { display: inline-flex; align-items: center; gap: 8px; border: 2px solid rgba(255,255,255,0.4); color: #fff; padding: 14px 32px; border-radius: var(--radius-full); font-weight: 700; font-size: 0.9rem; background: transparent; cursor: pointer; } .btn-outline:hover { background: rgba(255,255,255,0.1); color: #fff; } @media (max-width: 768px) { .hero h1 { font-size: 2rem; } } 

/* ===== SECTIONS ===== */ .section { padding: 80px 0; } .section-alt { background: var(--color-bg-alt); } .section-header { text-align: center; margin-bottom: 56px; } .section-header .label { display: inline-block; color: var(--color-primary); font-weight: 700; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 2px; margin-bottom: 8px; } .section-header h2 { font-size: 2.2rem; } 

/* ===== ABOUT ===== */ .about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; } .about-image { border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-lg); } .about-image img { width: 100%; height: 400px; object-fit: cover; } .about-content h2 { font-size: 2rem; margin-bottom: 16px; } .about-content p { color: var(--color-text-light); margin-bottom: 24px; } .about-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; } .stat-box { text-align: center; padding: 20px 12px; background: var(--color-bg-alt); border-radius: 12px; } .stat-box .number { font-family: var(--font-heading); font-size: 1.8rem; font-weight: 900; background: linear-gradient(135deg, var(--color-primary), var(--color-accent)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; } .stat-box .label { font-size: 0.8rem; color: var(--color-text-light); margin-top: 4px; } @media (max-width: 768px) { .about-grid { grid-template-columns: 1fr; } } 

/* ===== SERVICES ===== */ .services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; } .service-card { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius); padding: 32px; transition: all 0.3s ease; } .service-card:hover { border-color: rgba(27,107,74,0.3); box-shadow: var(--shadow-xl); transform: translateY(-4px); } .service-icon { width: 56px; height: 56px; border-radius: 12px; background: rgba(27,107,74,0.1); display: flex; align-items: center; justify-content: center; margin-bottom: 20px; font-size: 1.6rem; color: var(--color-primary); transition: all 0.3s ease; } .service-card:hover .service-icon { background: var(--color-primary); color: #fff; } .service-card h3 { font-size: 1.1rem; margin-bottom: 8px; } .service-card p { font-size: 0.9rem; color: var(--color-text-light); line-height: 1.6; } @media (max-width: 992px) { .services-grid { grid-template-columns: repeat(2, 1fr); } } @media (max-width: 576px) { .services-grid { grid-template-columns: 1fr; } } 

/* ===== PRICING ===== */ 
/* VET PRICING */ 
.vet-pricing{ padding:120px 20px; background:linear-gradient(135deg,#a8e6cf,#1abc9c); color:white; } 
/* GRID */ 
.vet-pricing-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:30px; margin-top:60px; } 
/* CARD */ 
.vet-card{ background:white; color:#333; padding:35px; border-radius:20px; box-shadow:0 20px 50px rgba(0,0,0,.15); transition:all .35s ease; position:relative; overflow:hidden; } 
/* HOVER */ 
.vet-card:hover{ transform:translateY(-12px) scale(1.03); box-shadow:0 35px 70px rgba(0,0,0,.25); } 
/* ICON */ 
.vet-icon{ font-size:40px; margin-bottom:15px; animation:iconBounce 3s infinite; } 
/* ICON ANIMATION */ 
@keyframes iconBounce{ 0%{transform:translateY(0)} 50%{transform:translateY(-6px)} 100%{transform:translateY(0)} } /* TITLE */ .vet-card h3{ margin-bottom:15px; font-size:20px; } 
/* LIST */ 
.vet-card ul{ list-style:none; padding:0; margin:0; } .vet-card li{ display:flex; justify-content:space-between; padding:8px 0; border-bottom:1px solid #eee; font-size:14px; } .vet-card span{ font-weight:700; color:#16a085; } 
/* ENTRANCE ANIMATION */ 
.reveal{ opacity:0; transform:translateY(50px); transition:all .8s ease; } .reveal.active{ opacity:1; transform:translateY(0); } } 

/* ===== EMBED TIKTOK ===== */ 

/* ===== GALLERY SECTION ===== */ 
#gallery{ margin-top:50px; /* jarak dari section atas */ padding:80px 20px; background:white; } 
/* TITLE */ #gallery h2{ /*jarak dari section atas */ padding:80px; text-align:center; font-size:42px; font-weight:700; margin-bottom:50px; } 
/* GRID CONTAINER */ .tiktok-feed{ display:grid; grid-template-columns:repeat(3,1fr); gap:5px; max-width:1200px; margin:auto; } 
/* VIDEO */ .tiktok-embed{ width:100% !important; max-width:auto; margin:auto; } 

/* ===== TABLET ===== */ 
@media (max-width:1000px){ .tiktok-feed{ grid-template-columns:repeat(2,1fr); } } 

/* ===== MOBILE ===== */ 
@media (max-width:600px){ #gallery{ margin-top:50px; } .tiktok-feed{ grid-template-columns:repeat(2,1fr); gap:5px; } #gallery h2{ font-size:34px; } } 

/* ===== MAP / LOCATION ===== */ 
.locations-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px; } .location-card { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-lg); } .location-card iframe { width: 100%; height: 250px; border: 0; } .location-info { padding: 24px; } .location-info h3 { font-size: 1.1rem; margin-bottom: 12px; } .location-detail { display: flex; align-items: flex-start; gap: 8px; font-size: 0.9rem; color: var(--color-text-light); margin-bottom: 8px; } .location-detail .icon { color: var(--color-primary); flex-shrink: 0; margin-top: 2px; } @media (max-width: 768px) { .locations-grid { grid-template-columns: 1fr; } } 

/* ===== FOOTER ===== */ 
.footer { background: var(--color-dark); color: rgba(255,255,255,0.7); padding: 64px 0 0; } .footer-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; margin-bottom: 40px; } .footer-brand { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; font-family: var(--font-heading); font-size: 1.3rem; font-weight: 900; color: #fff; } .footer h4 { color: #fff; font-size: 1rem; margin-bottom: 16px; } .footer ul li { font-size: 0.9rem; padding: 4px 0; } .footer-contact li { display: flex; align-items: center; gap: 8px; padding: 6px 0; } .footer-bottom { border-top: 1px solid rgba(255,255,255,0.1); padding: 20px 0; text-align: center; font-size: 0.8rem; opacity: 0.5; } @media (max-width: 768px) { .footer-grid { grid-template-columns: 1fr; } } 

/* ===== UTILITY ===== */ 
.text-gradient { background: linear-gradient(135deg, var(--color-primary), var(--color-accent)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }

