/* ===================================
   DR. AYŞE YILMAZ - PSİKOLOG WEB SİTESİ
   Hızlı Müdahale CSS Dosyası
   =================================== */

/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

/* Genel Stiller */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Inter', sans-serif;
    background-color: #f9fafb;
    color: #1f2937;
    line-height: 1.6;
    overflow-x: hidden;
}
/* ===================================
   THERAPY PREMIUM LOADER
   =================================== */
#therapy-loader{
    position: fixed;
    inset: 0;
    display:flex;
    align-items:center;
    justify-content:center;
    background:
      radial-gradient(circle at top, rgba(196,181,253,0.18), transparent 34%),
      linear-gradient(180deg, #fbfaf8 0%, #f4f2ee 48%, #edf2f5 100%);
    z-index: 99999;
    overflow: hidden;
    transition: opacity .75s ease, visibility .75s ease;
}
#therapy-loader.is-hidden{
    opacity:0;
    visibility:hidden;
    pointer-events:none;
}
.therapy-loader__ambient{
    position:absolute;
    border-radius:999px;
    filter: blur(70px);
    opacity:.55;
    animation: therapyFloat 8s ease-in-out infinite;
}
.therapy-loader__ambient--one{
    width: 320px;
    height: 320px;
    background: rgba(167, 139, 250, 0.26);
    top: 10%;
    left: 12%;
}
.therapy-loader__ambient--two{
    width: 280px;
    height: 280px;
    background: rgba(125, 211, 252, 0.18);
    right: 14%;
    bottom: 12%;
    animation-delay: -4s;
}
.therapy-loader__inner{
    position:relative;
    z-index:2;
    text-align:center;
    padding: 36px 38px;
    border: 1px solid rgba(255,255,255,.62);
    background: rgba(255,255,255,.44);
    box-shadow: 0 20px 60px rgba(60, 72, 88, 0.10);
    backdrop-filter: blur(18px);
    border-radius: 28px;
    min-width: min(92vw, 420px);
}
.therapy-loader__mark{
    width: 62px;
    height: 62px;
    margin: 0 auto 18px;
    border-radius: 50%;
    position: relative;
    border: 1px solid rgba(147, 51, 234, .18);
    background: linear-gradient(180deg, rgba(255,255,255,.9), rgba(255,255,255,.45));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.75), 0 12px 30px rgba(139,92,246,.12);
}
.therapy-loader__mark::before,
.therapy-loader__mark::after{
    content:"";
    position:absolute;
    left:50%;
    top:50%;
    border-radius:999px;
    transform: translate(-50%, -50%);
}
.therapy-loader__mark::before{
    width: 26px;
    height: 26px;
    border: 2px solid rgba(147,51,234,.55);
    border-top-color: transparent;
    animation: therapySpin 2.2s linear infinite;
}
.therapy-loader__mark::after{
    width: 8px;
    height: 8px;
    background: rgba(147,51,234,.5);
    box-shadow: 0 0 0 8px rgba(147,51,234,.08);
}
.therapy-loader__name{
    font-family: Georgia, serif;
    font-size: clamp(1.8rem, 3vw, 2.5rem);
    font-weight: 500;
    letter-spacing: .02em;
    color: #334155;
    margin-bottom: 6px;
}
.therapy-loader__title{
    font-size: .78rem;
    letter-spacing: .28em;
    text-transform: uppercase;
    color: #7c8a98;
    margin-bottom: 22px;
}
.therapy-loader__line{
    width: min(250px, 62vw);
    height: 3px;
    border-radius:999px;
    overflow:hidden;
    margin: 0 auto 14px;
    background: rgba(148,163,184,.18);
}
.therapy-loader__line span{
    display:block;
    height:100%;
    width:0;
    border-radius:999px;
    background: linear-gradient(90deg, #c4b5fd 0%, #a78bfa 45%, #7dd3fc 100%);
    animation: therapyLoad 1.9s ease forwards;
}
.therapy-loader__text{
    font-size: .95rem;
    color: #64748b;
}
@keyframes therapyLoad{
    from{ width: 0; }
    to{ width: 100%; }
}
@keyframes therapySpin{
    from{ transform: translate(-50%, -50%) rotate(0deg); }
    to{ transform: translate(-50%, -50%) rotate(360deg); }
}
@keyframes therapyFloat{
    0%,100%{ transform: translate3d(0,0,0); }
    50%{ transform: translate3d(12px,-18px,0); }
}
@media (max-width: 640px){
    .therapy-loader__inner{
        padding: 28px 22px;
        border-radius: 24px;
        min-width: min(92vw, 340px);
    }
    .therapy-loader__title{
        letter-spacing: .18em;
    }
}
/* Scrollbar */
::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: #f1f1f1;
}

::-webkit-scrollbar-thumb {
    background: linear-gradient(135deg, #9333ea, #ec4899);
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(135deg, #7c3aed, #db2777);
}

/* Smooth Scroll */
html {
    scroll-behavior: smooth;
}

/* Navigation */
.nav-fixed {
    position: fixed;
    top: 0;
    width: 100%;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(20px);
    z-index: 1000;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.nav-shadow {
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
}

/* Hero Section */
.hero-gradient {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    position: relative;
    overflow: hidden;
}

.hero-pattern {
    background-image: 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.1'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

/* Cards */
.card {
    background: white;
    border-radius: 24px;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    overflow: hidden;
    position: relative;
}

.card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, #9333ea, #ec4899, #3b82f6, #10b981);
    background-size: 300% 100%;
    animation: gradientShift 3s ease infinite;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.card:hover::before {
    opacity: 1;
}

.card:hover {
    transform: translateY(-12px) scale(1.02);
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

.card-icon {
    width: 64px;
    height: 64px;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 24px;
    margin-bottom: 24px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.card:hover .card-icon {
    transform: rotate(5deg) scale(1.1);
    box-shadow: 0 10px 25px rgba(102, 126, 234, 0.4);
}

/* Buttons */
.btn {
    padding: 14px 36px;
    border-radius: 12px;
    font-weight: 600;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
    border: none;
    font-size: 16px;
    position: relative;
    overflow: hidden;
}

.btn::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.2);
    transform: translate(-50%, -50%);
    transition: width 0.6s, height 0.6s;
}

.btn:hover::before {
    width: 300px;
    height: 300px;
}

.btn-primary {
    background: linear-gradient(135deg, #9333ea 0%, #ec4899 100%);
    color: white;
    box-shadow: 0 4px 15px rgba(147, 51, 234, 0.3);
}

.btn-primary:hover {
    transform: translateY(-3px);
    box-shadow: 0 15px 35px rgba(147, 51, 234, 0.4);
}

.btn-secondary {
    background: transparent;
    color: #9333ea;
    border: 2px solid #9333ea;
}

.btn-secondary:hover {
    background: #9333ea;
    color: white;
    transform: translateY(-3px);
    box-shadow: 0 15px 35px rgba(147, 51, 234, 0.3);
}

.btn-white {
    background: white;
    color: #9333ea;
    box-shadow: 0 4px 15px rgba(255, 255, 255, 0.3);
}

.btn-white:hover {
    background: #f3f4f6;
    transform: translateY(-3px);
    box-shadow: 0 15px 35px rgba(255, 255, 255, 0.4);
}

/* Forms */
.form-input {
    width: 100%;
    padding: 14px 18px;
    border: 2px solid #e5e7eb;
    border-radius: 12px;
    font-size: 16px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    background: white;
}

.form-input:focus {
    outline: none;
    border-color: #9333ea;
    box-shadow: 0 0 0 4px rgba(147, 51, 234, 0.1), 0 4px 15px rgba(147, 51, 234, 0.1);
    transform: translateY(-2px);
}

.form-input.error {
    border-color: #ef4444;
    box-shadow: 0 0 0 4px rgba(239, 68, 68, 0.1);
}

.form-input.success {
    border-color: #10b981;
    box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.1);
}

.form-textarea {
    resize: vertical;
    min-height: 120px;
}

/* Animasyonlar */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(40px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeInLeft {
    from {
        opacity: 0;
        transform: translateX(-40px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes fadeInRight {
    from {
        opacity: 0;
        transform: translateX(40px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes pulse {
    0%, 100% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.05);
    }
}

@keyframes float {
    0%, 100% {
        transform: translateY(0px);
    }
    50% {
        transform: translateY(-20px);
    }
}

@keyframes gradientShift {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}

@keyframes shimmer {
    0% {
        background-position: -200% center;
    }
    100% {
        background-position: 200% center;
    }
}

.fade-in-up {
    animation: fadeInUp 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.fade-in-left {
    animation: fadeInLeft 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.fade-in-right {
    animation: fadeInRight 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.pulse {
    animation: pulse 2s infinite;
}

.float {
    animation: float 3s ease-in-out infinite;
}

/* Gradient Text */
.gradient-text {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Loading Spinner */
.spinner {
    width: 40px;
    height: 40px;
    border: 4px solid #f3f4f6;
    border-top: 4px solid #9333ea;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Notification */
.notification {
    position: fixed;
    top: 20px;
    right: 20px;
    padding: 18px 24px;
    border-radius: 12px;
    color: white;
    font-weight: 500;
    z-index: 9999;
    transform: translateX(400px);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    max-width: 400px;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
}

.notification.show {
    transform: translateX(0);
}

.notification.success {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
}

.notification.error {
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
}

.notification.info {
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
}

/* Mobile Menu */
.mobile-menu {
    position: fixed;
    top: 0;
    right: -100%;
    width: 80%;
    max-width: 400px;
    height: 100vh;
    background: white;
    box-shadow: -10px 0 25px rgba(0, 0, 0, 0.1);
    transition: right 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 999;
    overflow-y: auto;
}

.mobile-menu.active {
    right: 0;
}

.mobile-menu-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: rgba(0, 0, 0, 0.5);
    z-index: 998;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.mobile-menu-overlay.active {
    opacity: 1;
    visibility: visible;
}

/* Blog Cards */
.blog-card {
    background: white;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.blog-card:hover {
    transform: translateY(-8px) scale(1.02);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
}

.blog-card img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.blog-card:hover img {
    transform: scale(1.1);
}

/* Contact Info Cards */
.contact-card {
    background: white;
    padding: 32px;
    border-radius: 20px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    border-left: 4px solid #9333ea;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.contact-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 25px rgba(147, 51, 234, 0.15);
}

.contact-icon {
    width: 48px;
    height: 48px;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    margin-bottom: 16px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.contact-card:hover .contact-icon {
    transform: scale(1.1) rotate(5deg);
}

/* Social Media Icons */
.social-icon {
    width: 44px;
    height: 44px;
    background: #374151;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.social-icon:hover {
    transform: translateY(-4px) rotate(5deg);
    box-shadow: 0 10px 25px rgba(147, 51, 234, 0.3);
}

/* Footer */
footer {
    background: linear-gradient(135deg, #111827 0%, #000000 100%);
    color: #9ca3af;
}

/* Process Timeline */
.process-step {
    position: relative;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.process-step:hover {
    transform: translateY(-8px);
}

.process-icon {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.process-step:hover .process-icon {
    transform: scale(1.1) rotate(5deg);
    box-shadow: 0 15px 35px rgba(147, 51, 234, 0.3);
}

/* Testimonial Cards */
.testimonial-card {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.testimonial-card:hover {
    transform: translateY(-6px);
}

.testimonial-avatar {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.testimonial-card:hover .testimonial-avatar {
    transform: scale(1.05);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
}

/* Utility Classes */
.text-shadow {
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.backdrop-blur {
    backdrop-filter: blur(20px);
}

/* Enhanced Day Selection Styles */
.day-checkbox:checked + .day-label {
    background: linear-gradient(135deg, #f3e8ff, #e9d5ff);
    border-color: #9333ea;
    color: #9333ea;
}

.day-checkbox:checked + .day-label i {
    color: #9333ea;
}

.time-radio:checked + .time-label {
    background: linear-gradient(135deg, #f3e8ff, #e9d5ff);
    border-color: #9333ea;
}

/* Selection Summary Animation */
#selectionSummary {
    animation: slideInUp 0.3s ease-out;
}

@keyframes slideInUp {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Calendar Hover Effects */
.calendar-day {
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.calendar-day:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(147, 51, 234, 0.15);
}

.calendar-day.selected {
    background: linear-gradient(135deg, #9333ea, #ec4899);
    color: white;
    border-color: #9333ea;
}

.calendar-day.selected i {
    color: white;
}

/* Time Slot Styles */
.time-slot {
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.time-slot:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(147, 51, 234, 0.15);
}

.time-slot.selected {
    background: linear-gradient(135deg, #9333ea, #ec4899);
    color: white;
    border-color: #9333ea;
}

/* FAQ Accordion Styles */
details {
    transition: all 0.3s ease;
}

summary {
    list-style: none;
    user-select: none;
}

details[open] > summary {
    background-color: #f3e8ff;
    border-color: #9333ea;
}

details[open] > summary i {
    transform: rotate(180deg);
}

/* Location Map Styles */
.location-map {
    background: linear-gradient(135deg, #f8fafc, #e2e8f0);
    position: relative;
    overflow: hidden;
}

.location-map::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%239333ea' fill-opacity='0.1'%3E%3Cpath d='M20 20c0-5.5-4.5-10-10-10S0 14.5 0 20s10 4.5 10 10 10-4.5 10-10 10zm0 3c-3.9 0-7-3.1-7-7s3.1-7 7-7 7 3.1 7 7-7 7 3.1 7 7-7 7z'/%3E%3C/g%3E%3C/svg%3E");
    background-size: 40px 40px;
    animation: float 6s ease-in-out infinite;
}

/* Emergency Section Styles */
.emergency-section {
    background: linear-gradient(135deg, #dc2626, #b91c1c);
    position: relative;
    overflow: hidden;
}

.emergency-section::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: repeating-linear-gradient(
        45deg,
        transparent,
        transparent 10px,
        rgba(255, 255, 255, 0.05) 10px,
        rgba(255, 255, 255, 0.05) 20px
    );
    animation: shimmer 3s linear infinite;
}

.emergency-card {
    backdrop-filter: blur(10px);
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    transition: all 0.3s ease;
}

.emergency-card:hover {
    background: rgba(255, 255, 255, 0.15);
    transform: translateY(-2px);
}

/* Transport Icons */
.transport-icon {
    transition: all 0.3s ease;
}

.transport-icon:hover {
    transform: scale(1.1);
    color: #9333ea;
}

/* Enhanced Button Styles */
.btn-emergency {
    background: rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    transition: all 0.3s ease;
}

.btn-emergency:hover {
    background: rgba(255, 255, 255, 0.3);
    transform: translateY(-2px);
    box-shadow: 0 10px 25px rgba(255, 255, 255, 0.2);
}

/* FAQ Animation */
@keyframes slideDown {
    from {
        opacity: 0;
        max-height: 0;
    }
    to {
        opacity: 1;
        max-height: 200px;
    }
}

details[open] > div {
    animation: slideDown 0.3s ease-out;
}

/* Location Section Styles */
.location-section {
    background: linear-gradient(135deg, #f9fafb, #ffffff);
}

.map-container {
    position: relative;
    overflow: hidden;
    border-radius: 12px;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
}

.map-container iframe {
    border: none;
    width: 100%;
    height: 400px;
    transition: all 0.3s ease;
}

.location-info {
    background: linear-gradient(135deg, #f3e8ff, #e9d5ff);
    border: 1px solid #9333ea;
    border-radius: 12px;
    transition: all 0.3s ease;
}

.location-info:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(147, 51, 234, 0.15);
}

.transport-icon-large {
    transition: all 0.3s ease;
}

.transport-icon-large:hover {
    transform: scale(1.1);
    color: #9333ea;
}

/* Responsive Design */
@media (max-width: 768px) {
    .hero-title {
        font-size: 2.5rem;
        line-height: 1.2;
    }

.card {
margin-bottom: 24px;
}

.btn {
width: 100%;
margin-bottom: 12px;
}

.mobile-menu {
width: 100%;
}

.notification {
right: 10px;
left: 10px;
max-width: none;
}
}

@media (max-width: 480px) {
.hero-title {
font-size: 2rem;
}

.section-padding {
padding: 48px 16px;
}

.form-input {
font-size: 16px; /* Prevents zoom on iOS */
}
    }
    
    .section-padding {
        padding: 48px 16px;
    }
    
    .form-input {
        font-size: 16px; /* Prevents zoom on iOS */
    }


/* Dark Mode Support */
@media (prefers-color-scheme: dark) {
    body {
        background-color: #111827;
        color: #f9fafb;
    }
    
    .card {
        background: #1f2937;
        color: #f9fafb;
    }
    
    .form-input {
        background: #374151;
        border-color: #4b5563;
        color: #f9fafb;
    }
    
    .nav-fixed {
        background: rgba(17, 24, 39, 0.95);
    }
}

/* Print Styles */
@media print {
    .nav-fixed,
    .mobile-menu,
    .notification,
    .social-icon,
    footer {
        display: none !important;
    }
    
    body {
        background: white !important;
        color: black !important;
    }
    
    .card {
        box-shadow: none !important;
        border: 1px solid #e5e7eb !important;
    }
}

/* Accessibility */
.keyboard-nav *:focus {
    outline: 2px solid #9333ea;
    outline-offset: 2px;
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
    .btn {
        border: 2px solid currentColor;
    }
    
    .card {
        border: 2px solid currentColor;
    }
}

/* Reduced Motion */
@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;
    }
}

/* Custom Scroll Animations */
.scroll-animate {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.scroll-animate.visible {
    opacity: 1;
    transform: translateY(0);
}

/* Shimmer Effect */
.shimmer {
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
}

/* Glow Effect */
.glow {
    box-shadow: 0 0 20px rgba(147, 51, 234, 0.3);
    transition: box-shadow 0.3s ease;
}

.glow:hover {
    box-shadow: 0 0 30px rgba(147, 51, 234, 0.5);
}


/* Premium appointment form refresh */
.premium-appointment-form {
    position: relative;
}

.premium-option-group {
    position: relative;
    border: 1px solid rgba(147, 51, 234, 0.08);
    background:
        radial-gradient(circle at top right, rgba(216, 180, 254, 0.18), transparent 35%),
        linear-gradient(180deg, rgba(255,255,255,0.96), rgba(250,245,255,0.96));
    box-shadow: 0 18px 45px rgba(88, 28, 135, 0.06);
}

.premium-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #7e22ce;
    background: rgba(147, 51, 234, 0.08);
    border: 1px solid rgba(147, 51, 234, 0.12);
}

.premium-time-card {
    position: relative;
    overflow: hidden;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease, background .25s ease;
}

.premium-time-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(147, 51, 234, 0.08), rgba(236, 72, 153, 0.06));
    opacity: 0;
    transition: opacity .25s ease;
    pointer-events: none;
}

.premium-time-card:hover,
.premium-time-card.selected {
    transform: translateY(-3px);
    box-shadow: 0 14px 35px rgba(147, 51, 234, 0.14);
}

.premium-time-card:hover::before,
.premium-time-card.selected::before {
    opacity: 1;
}

.premium-time-card input[type="radio"] {
    accent-color: #9333ea;
    transform: scale(1.1);
}

.premium-selection-summary {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at top right, rgba(216, 180, 254, 0.28), transparent 30%),
        linear-gradient(180deg, #faf5ff 0%, #ffffff 100%);
    box-shadow: 0 20px 40px rgba(147, 51, 234, 0.08);
}

.premium-selection-summary::after {
    content: '';
    position: absolute;
    top: -60px;
    right: -40px;
    width: 160px;
    height: 160px;
    background: radial-gradient(circle, rgba(216, 180, 254, 0.22), transparent 65%);
    pointer-events: none;
}

.premium-summary-intro {
    opacity: .85;
}

.premium-summary-item {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.8rem 0.9rem;
    border-radius: 1rem;
    background: rgba(255,255,255,0.8);
    border: 1px solid rgba(147, 51, 234, 0.1);
    box-shadow: 0 8px 20px rgba(147, 51, 234, 0.06);
}

.premium-summary-item strong,
.premium-summary-item span {
    display: block;
}

.premium-summary-item strong {
    color: #581c87;
    margin-bottom: 0.15rem;
}

.premium-summary-item span {
    color: #6b21a8;
}

.premium-summary-icon {
    width: 2.4rem;
    height: 2.4rem;
    min-width: 2.4rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    color: #7e22ce;
    background: rgba(147, 51, 234, 0.12);
}

.premium-submit-btn {
    position: relative;
    overflow: hidden;
    box-shadow: 0 16px 35px rgba(147, 51, 234, 0.25);
}

.premium-submit-btn::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.22), transparent);
    transform: translateX(-100%);
    transition: transform .7s ease;
}

.premium-submit-btn:hover::before {
    transform: translateX(100%);
}

.premium-submit-btn.is-submitting {
    opacity: .92;
    pointer-events: none;
}

@media (max-width: 640px) {
    .premium-badge {
        display: none;
    }
}


/* Summary fixes */
.premium-selection-summary .summary-content {
    display: grid;
    gap: 0.75rem;
}

.premium-summary-item {
    display: grid;
    grid-template-columns: 2.75rem minmax(0, 1fr);
    align-items: start;
}

.premium-summary-item > div {
    min-width: 0;
}

.premium-summary-item strong,
.premium-summary-item span {
    white-space: normal;
    word-break: break-word;
}

.premium-summary-icon {
    align-self: start;
    margin-top: 0.1rem;
}

@media (max-width: 480px) {
    .premium-selection-summary {
        padding: 1rem;
    }

    .premium-summary-item {
        grid-template-columns: 2.5rem minmax(0, 1fr);
        padding: 0.75rem;
        gap: 0.7rem;
    }

    .premium-summary-icon {
        width: 2.5rem;
        height: 2.5rem;
        min-width: 2.5rem;
    }
}


/* Final mobile alignment fixes for summary icons */
.premium-summary-item {
    display: flex !important;
    align-items: center !important;
    gap: 0.85rem;
}

.premium-summary-item > div {
    flex: 1 1 auto;
    min-width: 0;
}

.premium-summary-icon {
    position: relative;
    flex: 0 0 2.75rem;
    width: 2.75rem;
    height: 2.75rem;
    min-width: 2.75rem;
    min-height: 2.75rem;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    align-self: center !important;
    margin: 0 !important;
    line-height: 1;
}

.premium-summary-icon i {
    display: block;
    line-height: 1;
    margin: 0;
    transform: translateY(0);
}

@media (max-width: 480px) {
    .premium-summary-item {
        align-items: center !important;
        gap: 0.75rem;
    }

    .premium-summary-icon {
        flex-basis: 2.6rem;
        width: 2.6rem;
        height: 2.6rem;
        min-width: 2.6rem;
        min-height: 2.6rem;
    }
}


/* ===== Ultra Premium Upgrade ===== */
:root {
    --ultra-bg: #080d19;
    --ultra-card: rgba(255,255,255,0.72);
    --ultra-border: rgba(255,255,255,0.55);
    --ultra-shadow: 0 25px 60px rgba(14, 18, 38, 0.16);
    --ultra-shadow-soft: 0 14px 32px rgba(91, 33, 182, 0.12);
    --ultra-purple: #7c3aed;
    --ultra-pink: #ec4899;
    --ultra-text: #0f172a;
}

html { scroll-behavior: smooth; }
body.ultra-site {
    color: var(--ultra-text);
    background:
        radial-gradient(circle at top left, rgba(147,51,234,0.08), transparent 28%),
        radial-gradient(circle at 90% 8%, rgba(59,130,246,0.07), transparent 20%),
        #f8fafc;
}

.nav-ultra {
    background: rgba(255,255,255,0.76);
    backdrop-filter: blur(18px);
    border-bottom: 1px solid rgba(255,255,255,0.72);
    box-shadow: 0 14px 30px rgba(15,23,42,.07);
}

.nav-ultra .container { max-width: 1280px; }
.nav-ultra a { position: relative; }
.nav-ultra a::after {
    content: '';
    position: absolute;
    left: 0; bottom: -8px;
    width: 0; height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--ultra-purple), var(--ultra-pink));
    transition: width .3s ease;
}
.nav-ultra a:hover::after { width: 100%; }

.hero-ultra { background: var(--ultra-bg); }
.hero-grid {
    position: absolute; inset: 0; z-index: 0;
    background-image:
      linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
      linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
    background-size: 70px 70px;
    mask-image: linear-gradient(180deg, rgba(255,255,255,0.25), transparent 85%);
}
.hero-orb {
    position: absolute; border-radius: 999px; filter: blur(70px); opacity: .55; z-index: 0;
}
.hero-orb-1 { width: 320px; height: 320px; background: rgba(147,51,234,.38); left: -90px; top: 120px; }
.hero-orb-2 { width: 300px; height: 300px; background: rgba(236,72,153,.28); right: -80px; top: 80px; }
.hero-badge,
.hero-glass-card,
.hero-floating-card,
.hero-metric-card,
.trust-ribbon,
.ultra-location-panel,
.ultra-map-shell {
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}
.hero-badge {
    background: linear-gradient(135deg, rgba(255,255,255,.15), rgba(255,255,255,.08));
    border: 1px solid rgba(255,255,255,.16);
    box-shadow: 0 14px 40px rgba(0,0,0,.12);
}
.hero-cta .btn { border-radius: 18px; box-shadow: 0 12px 30px rgba(0,0,0,.12); }
.ultra-primary-btn {
    color: #180d32;
    background: linear-gradient(180deg, #ffffff, #f5edff);
}
.ultra-primary-btn:hover { transform: translateY(-2px) scale(1.01); }
.ultra-outline-btn {
    color: #fff;
    border: 1px solid rgba(255,255,255,.28);
    background: linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
}
.ultra-outline-btn:hover { background: rgba(255,255,255,.16); transform: translateY(-2px); }
.hero-trust-grid { align-items: stretch; }
.hero-metric-card {
    display: flex; flex-direction: column; gap: 8px;
    padding: 18px 18px;
    border-radius: 22px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: 0 18px 40px rgba(0,0,0,.15);
}
.hero-metric-card strong { color: #fff; font-size: 1rem; }
.hero-metric-card span { color: rgba(255,255,255,.72); font-size: .92rem; line-height: 1.5; }
.hero-showcase { position: relative; min-height: 520px; }
.hero-glass-card {
    position: relative;
    border-radius: 34px;
    padding: 26px;
    background: linear-gradient(145deg, rgba(255,255,255,.17), rgba(255,255,255,.08));
    border: 1px solid rgba(255,255,255,.16);
    box-shadow: 0 30px 60px rgba(0,0,0,.2);
}
.hero-main-card { margin-top: 60px; }
.hero-card-top { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 28px; }
.hero-chip {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 14px; border-radius: 999px;
    background: rgba(255,255,255,.12); color: #fff; font-size: .9rem;
    border: 1px solid rgba(255,255,255,.12);
}
.hero-mini-profile { display: flex; gap: 18px; align-items: center; margin-bottom: 28px; }
.hero-mini-avatar {
    width: 74px; height: 74px; border-radius: 24px;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, rgba(167,139,250,.95), rgba(236,72,153,.72));
    color: #fff; font-size: 1.7rem; box-shadow: 0 12px 28px rgba(167,139,250,.36);
}
.hero-mini-label { color: rgba(255,255,255,.68); font-size: .9rem; margin-bottom: 4px; }
.hero-mini-profile h3 { color: #fff; font-size: 1.5rem; font-weight: 700; line-height: 1.25; }
.hero-benefit-list { display: grid; gap: 14px; }
.hero-benefit-list div {
    display: flex; gap: 12px; align-items: center; color: rgba(255,255,255,.88);
    padding: 14px 16px; border-radius: 18px; background: rgba(255,255,255,.08);
}
.hero-benefit-list i { color: #c4b5fd; font-size: 1.05rem; }
.hero-floating-card {
    position: absolute; display: flex; gap: 12px; align-items: flex-start;
    padding: 14px 16px; border-radius: 22px; min-width: 220px;
    background: rgba(255,255,255,.92); color: #0f172a; box-shadow: var(--ultra-shadow);
}
.hero-floating-card i {
    width: 42px; height: 42px; display: inline-flex; align-items: center; justify-content: center;
    border-radius: 14px; color: #fff; background: linear-gradient(135deg, var(--ultra-purple), var(--ultra-pink));
}
.hero-floating-card strong { display: block; font-weight: 700; margin-bottom: 3px; }
.hero-floating-card span { font-size: .9rem; color: #475569; line-height: 1.4; }
.hero-floating-card-left { left: -12px; bottom: 110px; }
.hero-floating-card-right { right: -10px; bottom: 26px; }
.hero-bottom-fade {
    position: absolute; left: 0; right: 0; bottom: 0; height: 140px;
    background: linear-gradient(180deg, rgba(248,250,252,0), #f8fafc 92%);
}

.trust-ribbon-section { position: relative; margin-top: -38px; z-index: 3; }
.trust-ribbon {
    display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 14px;
    padding: 18px; border-radius: 28px; background: rgba(255,255,255,.8);
    border: 1px solid rgba(255,255,255,.85); box-shadow: var(--ultra-shadow);
}
.trust-ribbon-item {
    display: flex; align-items: center; gap: 12px; padding: 14px 16px; border-radius: 20px;
    background: linear-gradient(180deg, rgba(255,255,255,.78), rgba(249,245,255,.88));
    color: #334155; font-weight: 600;
}
.trust-ribbon-item i {
    width: 42px; height: 42px; display: flex; align-items: center; justify-content: center;
    border-radius: 14px; color: var(--ultra-purple); background: rgba(124,58,237,.10);
}

.section-kicker {
    display: inline-flex; align-items: center; gap: 8px;
    margin-bottom: 16px; padding: 8px 14px;
    border-radius: 999px; background: rgba(124,58,237,.08); color: var(--ultra-purple); font-weight: 700; font-size: .9rem;
}

.card, .bg-white.p-8.rounded-3xl.shadow-lg, .blog-card, .contact-card {
    border: 1px solid rgba(255,255,255,.72);
    box-shadow: var(--ultra-shadow-soft);
}
.card:hover, .blog-card:hover, .bg-white.p-8.rounded-3xl.shadow-lg:hover {
    transform: translateY(-6px);
    box-shadow: 0 25px 50px rgba(15,23,42,.12);
}
.form-input {
    border-radius: 18px !important;
    border-color: rgba(148, 163, 184, .25) !important;
    background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(249,250,251,.98));
}
.form-input:focus {
    box-shadow: 0 0 0 4px rgba(124,58,237,.10), 0 14px 34px rgba(124,58,237,.12) !important;
}
#selectionSummary {
    border-radius: 24px; overflow: hidden;
    border: 1px solid rgba(255,255,255,.75);
    box-shadow: var(--ultra-shadow-soft);
}

.location-ultra-section { position: relative; overflow: hidden; }
.ultra-location-panel,
.ultra-map-shell {
    position: relative; border-radius: 34px; overflow: hidden; padding: 28px;
    background: linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,255,255,.76));
    border: 1px solid rgba(255,255,255,.78); box-shadow: var(--ultra-shadow);
}
.location-panel-glow {
    position: absolute; inset: auto -50px -70px auto; width: 180px; height: 180px;
    background: radial-gradient(circle, rgba(167,139,250,.24), transparent 70%); filter: blur(10px);
}
.location-panel-head {
    position: relative; display: flex; align-items: center; gap: 18px; margin-bottom: 28px;
}
.location-main-icon {
    width: 76px; height: 76px; border-radius: 24px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center; color: #fff; font-size: 1.9rem;
    background: linear-gradient(135deg, var(--ultra-purple), #a855f7 50%, var(--ultra-pink));
    box-shadow: 0 18px 38px rgba(147,51,234,.24);
}
.location-mini-label { display: block; font-size: .85rem; text-transform: uppercase; letter-spacing: .08em; color: #7c3aed; margin-bottom: 6px; }
.location-panel-head h3 { font-size: 1.9rem; line-height: 1.2; font-weight: 800; color: #0f172a; }
.location-address-card {
    display: flex; justify-content: space-between; gap: 24px; align-items: flex-start;
    padding: 22px; border-radius: 24px; margin-bottom: 24px;
    background: linear-gradient(135deg, rgba(248,245,255,.95), rgba(255,255,255,.85));
    border: 1px solid rgba(124,58,237,.10);
}
.address-title { font-size: .92rem; color: #7c3aed; font-weight: 700; margin-bottom: 8px; text-transform: uppercase; letter-spacing: .05em; }
.address-text { font-size: 1.15rem; color: #1e293b; line-height: 1.7; font-weight: 500; }
.location-action-stack { display: flex; flex-direction: column; gap: 12px; min-width: 210px; }
.location-action-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 10px;
    padding: 14px 18px; border-radius: 16px; font-weight: 700; transition: .3s ease; text-decoration: none;
}
.location-action-btn.primary {
    color: #fff; background: linear-gradient(135deg, #7c3aed, #a855f7); box-shadow: 0 14px 28px rgba(124,58,237,.22);
}
.location-action-btn.secondary {
    color: #166534; background: rgba(34,197,94,.10); border: 1px solid rgba(34,197,94,.15);
}
.location-action-btn:hover { transform: translateY(-2px); }
.location-features-grid {
    display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; margin-bottom: 22px;
}
.location-feature-card {
    display: flex; gap: 14px; align-items: flex-start; padding: 18px; border-radius: 22px;
    background: #fff; border: 1px solid rgba(226,232,240,.8); box-shadow: 0 12px 22px rgba(15,23,42,.05);
}
.feature-icon {
    width: 46px; height: 46px; border-radius: 16px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    color: var(--ultra-purple); background: rgba(124,58,237,.10);
}
.location-feature-card strong { display: block; color: #0f172a; margin-bottom: 4px; }
.location-feature-card p { color: #64748b; font-size: .94rem; line-height: 1.55; }
.location-note {
    display: flex; gap: 10px; align-items: center; padding: 16px 18px; border-radius: 18px;
    color: #475569; background: rgba(248,250,252,.9); border: 1px dashed rgba(124,58,237,.24);
}
.location-note i { color: var(--ultra-purple); }
.map-shell-top {
    display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-bottom: 18px;
}
.map-label { display: inline-block; color: #7c3aed; text-transform: uppercase; letter-spacing: .07em; font-size: .84rem; font-weight: 700; margin-bottom: 8px; }
.map-shell-top h3 { font-size: 1.5rem; font-weight: 800; color: #0f172a; }
.map-open-link {
    display: inline-flex; align-items: center; gap: 10px; white-space: nowrap; text-decoration: none;
    padding: 12px 16px; border-radius: 14px; color: #7c3aed; background: rgba(124,58,237,.08); font-weight: 700;
}
.map-frame-wrap {
    position: relative; overflow: hidden; border-radius: 28px; min-height: 560px;
    border: 1px solid rgba(255,255,255,.9); box-shadow: 0 18px 30px rgba(15,23,42,.08);
}
.map-frame-wrap iframe { position: absolute; inset: 0; width: 100%; height: 100%; }
.map-frost-card {
    position: absolute; z-index: 2; display: inline-flex; align-items: center; gap: 10px;
    padding: 12px 14px; border-radius: 16px; color: #fff; font-weight: 700;
    background: rgba(15,23,42,.56); border: 1px solid rgba(255,255,255,.12); backdrop-filter: blur(10px);
}
.map-frost-card-top { top: 16px; left: 16px; }
.map-frost-card-bottom { left: 16px; bottom: 16px; }

.reveal-up {
    opacity: 0; transform: translateY(32px); transition: opacity .8s ease, transform .8s cubic-bezier(.22,1,.36,1);
}
.reveal-up.is-visible,
.reveal-up.fade-in,
section.fade-in.reveal-up { opacity: 1; transform: translateY(0); }

@media (max-width: 1024px) {
    .hero-showcase { min-height: unset; }
    .hero-main-card { margin-top: 0; }
    .hero-floating-card { position: static; margin-top: 16px; }
    .trust-ribbon { grid-template-columns: repeat(2, minmax(0,1fr)); }
    .location-address-card { flex-direction: column; }
    .location-action-stack { width: 100%; min-width: unset; }
    .map-frame-wrap { min-height: 420px; }
}

@media (max-width: 768px) {
    .hero-ultra { padding-bottom: 72px; }
    .hero-badge { font-size: .85rem; }
    .hero-metric-card { border-radius: 18px; }
    .trust-ribbon-section { margin-top: -10px; }
    .trust-ribbon { grid-template-columns: 1fr; border-radius: 22px; }
    .hero-floating-card { min-width: unset; }
    .location-panel-head { align-items: flex-start; }
    .location-panel-head h3 { font-size: 1.45rem; }
    .location-features-grid { grid-template-columns: 1fr; }
    .ultra-location-panel, .ultra-map-shell { padding: 22px; border-radius: 26px; }
    .map-shell-top { flex-direction: column; align-items: flex-start; }
    .map-open-link, .location-action-btn { width: 100%; }
    .map-frame-wrap { min-height: 340px; }
}


/* Premium Blog Section v2 */
#blog {
    position: relative;
    overflow: hidden;
}
#blog::before,
#blog::after {
    content: "";
    position: absolute;
    border-radius: 999px;
    filter: blur(80px);
    opacity: .55;
    pointer-events: none;
}
#blog::before {
    width: 360px;
    height: 360px;
    left: -120px;
    top: 120px;
    background: rgba(192,132,252,.22);
}
#blog::after {
    width: 320px;
    height: 320px;
    right: -90px;
    bottom: 40px;
    background: rgba(59,130,246,.16);
}

.premium-blog-shell {
    position: relative;
    max-width: 1280px;
    margin: 0 auto;
    padding: 40px;
    border-radius: 40px;
    background: linear-gradient(180deg, rgba(255,255,255,.88), rgba(249,245,255,.76));
    border: 1px solid rgba(255,255,255,.92);
    box-shadow: 0 30px 90px rgba(15,23,42,.08);
}

.section-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: .8rem 1.2rem;
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(124,58,237,.10), rgba(192,132,252,.18));
    color: #7c3aed;
    font-weight: 700;
    letter-spacing: .02em;
    border: 1px solid rgba(147, 51, 234, 0.12);
    box-shadow: 0 10px 30px rgba(124, 58, 237, 0.10);
}

.premium-blog-feature,
.premium-blog-mini,
.premium-blog-cta {
    position: relative;
    background: rgba(255, 255, 255, 0.88);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border: 1px solid rgba(255, 255, 255, 0.86);
    box-shadow: 0 22px 70px rgba(17, 24, 39, 0.08);
}

.premium-blog-feature {
    border-radius: 34px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-height: 100%;
    transition: transform .35s ease, box-shadow .35s ease;
}

.premium-blog-feature:hover,
.premium-blog-mini:hover,
.premium-blog-cta:hover {
    transform: translateY(-8px);
    box-shadow: 0 34px 90px rgba(124, 58, 237, 0.16);
}

.premium-blog-image-wrap {
    position: relative;
    min-height: 390px;
    overflow: hidden;
}

.premium-blog-image {
    width: 100%;
    height: 100%;
    min-height: 390px;
    object-fit: cover;
    display: block;
    transform: scale(1.01);
    transition: transform .5s ease;
}
.premium-blog-feature:hover .premium-blog-image { transform: scale(1.05); }

.premium-blog-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(17,24,39,0.05) 0%, rgba(17,24,39,0.16) 55%, rgba(17,24,39,0.72) 100%);
}

.premium-blog-floating-badge {
    position: absolute;
    top: 1.35rem;
    left: 1.35rem;
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    padding: .82rem 1.05rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    color: #6d28d9;
    font-weight: 800;
    box-shadow: 0 16px 44px rgba(17,24,39,0.14);
}

.premium-blog-content { padding: 2rem 2rem 2.1rem; }

.premium-blog-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    align-items: center;
    margin-bottom: 1rem;
}

.premium-blog-chip,
.premium-blog-date,
.premium-blog-read,
.premium-blog-mini-meta {
    display: inline-flex;
    align-items: center;
    gap: .42rem;
    font-size: .92rem;
    font-weight: 700;
}

.premium-blog-chip {
    padding: .48rem .82rem;
    border-radius: 999px;
    background: rgba(147, 51, 234, 0.10);
    color: #7c3aed;
}
.premium-blog-date,
.premium-blog-read,
.premium-blog-mini-meta { color: #6b7280; }

.premium-blog-title {
    font-size: clamp(1.8rem, 3vw, 2.55rem);
    line-height: 1.12;
    font-weight: 800;
    color: #111827;
    margin-bottom: 1rem;
    letter-spacing: -.02em;
}

.premium-blog-excerpt {
    color: #4b5563;
    font-size: 1.04rem;
    line-height: 1.9;
    margin-bottom: 1.6rem;
}

.premium-blog-actions {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    flex-wrap: wrap;
}

.premium-blog-link,
.premium-blog-mini-content a,
.premium-blog-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    font-weight: 700;
    transition: all .3s ease;
}
.premium-blog-link,
.premium-blog-mini-content a { color: #7c3aed; }
.premium-blog-link:hover,
.premium-blog-mini-content a:hover {
    color: #5b21b6;
    transform: translateX(4px);
}

.premium-blog-author {
    display: flex;
    align-items: center;
    gap: .9rem;
}
.premium-author-avatar {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: linear-gradient(135deg, #7c3aed, #c084fc);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    box-shadow: 0 12px 24px rgba(124, 58, 237, 0.30);
}
.premium-author-name { font-weight: 700; color: #111827; }
.premium-author-role { color: #6b7280; font-size: .92rem; }

.premium-blog-side {
    display: flex;
    flex-direction: column;
    gap: 1.35rem;
}

.premium-blog-mini {
    border-radius: 28px;
    padding: 1rem;
    display: grid;
    grid-template-columns: 150px 1fr;
    gap: 1rem;
    align-items: center;
    transition: transform .35s ease, box-shadow .35s ease;
}
.premium-blog-mini-image {
    width: 100%;
    height: 150px;
    object-fit: cover;
    border-radius: 22px;
    display: block;
}
.premium-blog-mini-content h3 {
    font-size: 1.15rem;
    font-weight: 800;
    color: #111827;
    line-height: 1.4;
    margin: .4rem 0 .5rem;
}
.premium-blog-mini-content p {
    color: #6b7280;
    line-height: 1.7;
    margin-bottom: .8rem;
}

.premium-blog-cta {
    border-radius: 30px;
    padding: 1.6rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    background: linear-gradient(180deg, rgba(124,58,237,.92), rgba(147,51,234,.85));
    color: #fff;
}
.premium-blog-cta-icon {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,.15);
    color: #fff;
    font-size: 1.35rem;
}
.premium-blog-cta h4 {
    font-size: 1.28rem;
    font-weight: 800;
    color: #fff;
    margin: 0;
}
.premium-blog-cta p {
    color: rgba(255,255,255,.84);
    line-height: 1.7;
    margin: 0;
}
.premium-blog-cta-btn {
    justify-content: center;
    padding: 1rem 1.2rem;
    border-radius: 16px;
    background: #fff;
    color: #6d28d9;
    box-shadow: 0 16px 36px rgba(17,24,39,.16);
}
.premium-blog-cta-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 20px 42px rgba(17,24,39,.18);
}

@media (max-width: 1024px) {
    .premium-blog-shell { padding: 30px 24px; }
    .premium-blog-mini { grid-template-columns: 120px 1fr; }
    .premium-blog-mini-image { height: 120px; }
}

@media (max-width: 768px) {
    .premium-blog-shell { padding: 22px 14px; border-radius: 26px; }
    .premium-blog-content { padding: 1.35rem; }
    .premium-blog-image-wrap,
    .premium-blog-image { min-height: 240px; }
    .premium-blog-mini { grid-template-columns: 1fr; }
    .premium-blog-mini-image { height: 210px; }
    .premium-blog-actions { align-items: flex-start; flex-direction: column; }
}


/* Footer Ultra */
.footer-ultra {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at top left, rgba(124,58,237,.22), transparent 28%),
        radial-gradient(circle at bottom right, rgba(59,130,246,.16), transparent 26%),
        linear-gradient(180deg, #08101f 0%, #050814 55%, #04060f 100%);
    padding: 84px 0 28px;
    border-top: 1px solid rgba(255,255,255,.08);
}
.footer-orb {
    position: absolute;
    width: 320px;
    height: 320px;
    border-radius: 999px;
    filter: blur(90px);
    opacity: .35;
    pointer-events: none;
}
.footer-orb-left {
    left: -120px;
    top: -80px;
    background: rgba(124,58,237,.45);
}
.footer-orb-right {
    right: -110px;
    bottom: -100px;
    background: rgba(59,130,246,.24);
}
.footer-top-shell {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0,1.05fr) minmax(0,.95fr);
    gap: 28px;
    padding: 34px;
    border-radius: 36px;
    background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 30px 80px rgba(0,0,0,.28);
    backdrop-filter: blur(18px);
}
.footer-brand-panel {
    padding: 8px 6px 8px 2px;
}
.footer-kicker {
    display: inline-flex;
    align-items: center;
    padding: .7rem 1rem;
    border-radius: 999px;
    background: rgba(255,255,255,.08);
    color: #c4b5fd;
    border: 1px solid rgba(196,181,253,.16);
    font-size: .86rem;
    font-weight: 700;
    letter-spacing: .03em;
    margin-bottom: 1.1rem;
}
.footer-brand-panel h3 {
    font-size: clamp(2rem, 3vw, 3rem);
    line-height: 1.08;
    font-weight: 800;
    color: #fff;
    margin-bottom: 1rem;
    max-width: 14ch;
}
.footer-brand-panel p {
    color: rgba(226,232,240,.78);
    font-size: 1.03rem;
    line-height: 1.9;
    max-width: 60ch;
}
.footer-cta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 1.6rem;
}
.footer-primary-btn,
.footer-secondary-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .7rem;
    min-height: 54px;
    padding: 0 1.2rem;
    border-radius: 16px;
    text-decoration: none;
    font-weight: 700;
    transition: .3s ease;
}
.footer-primary-btn {
    background: linear-gradient(135deg, #7c3aed, #a855f7);
    color: #fff;
    box-shadow: 0 18px 34px rgba(124,58,237,.22);
}
.footer-secondary-btn {
    background: rgba(255,255,255,.06);
    color: #fff;
    border: 1px solid rgba(255,255,255,.1);
}
.footer-primary-btn:hover,
.footer-secondary-btn:hover {
    transform: translateY(-2px);
}
.footer-trust-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: 12px;
    margin-top: 1.8rem;
}
.footer-trust-item {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: 14px 15px;
    border-radius: 18px;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.06);
    color: #dbe4f0;
    font-size: .93rem;
}
.footer-trust-item i {
    color: #c4b5fd;
}
.footer-links-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 18px;
}
.footer-card {
    padding: 24px;
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.04));
    border: 1px solid rgba(255,255,255,.08);
    min-height: 100%;
}
.footer-card h4 {
    font-size: 1.08rem;
    font-weight: 800;
    color: #fff;
    margin-bottom: 1rem;
}
.footer-card ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.footer-card li + li {
    margin-top: .85rem;
}
.footer-card a {
    display: inline-flex;
    align-items: center;
    gap: .65rem;
    color: rgba(226,232,240,.76);
    text-decoration: none;
    transition: .25s ease;
}
.footer-card a i {
    color: #a78bfa;
    font-size: .78rem;
}
.footer-card a:hover {
    color: #fff;
    transform: translateX(4px);
}
.footer-contact-card {
    grid-column: span 2;
}
.footer-contact-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 14px;
}
.footer-contact-item {
    display: flex;
    gap: .85rem;
    align-items: flex-start;
    padding: 16px;
    border-radius: 20px;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.06);
}
.footer-contact-icon {
    width: 42px;
    height: 42px;
    flex-shrink: 0;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(124,58,237,.16);
    color: #c4b5fd;
}
.footer-contact-item strong {
    display: block;
    color: #fff;
    margin-bottom: .25rem;
}
.footer-contact-item p {
    color: rgba(226,232,240,.74);
    line-height: 1.7;
    font-size: .94rem;
}
.footer-newsletter {
    margin-top: 18px;
    padding: 18px;
    border-radius: 22px;
    background: linear-gradient(135deg, rgba(124,58,237,.18), rgba(255,255,255,.04));
    border: 1px solid rgba(196,181,253,.14);
}
.footer-newsletter h5 {
    color: #fff;
    font-size: 1rem;
    font-weight: 800;
    margin-bottom: .4rem;
}
.footer-newsletter p {
    color: rgba(226,232,240,.76);
    line-height: 1.7;
    margin-bottom: .9rem;
}
.footer-newsletter-form {
    display: flex;
    gap: 0;
}
.footer-newsletter-form input {
    width: 100%;
    min-height: 52px;
    border: 1px solid rgba(255,255,255,.08);
    border-right: none;
    border-radius: 16px 0 0 16px;
    background: rgba(2,6,23,.38);
    color: #fff;
    padding: 0 1rem;
    outline: none;
}
.footer-newsletter-form button {
    width: 54px;
    min-height: 52px;
    border: none;
    border-radius: 0 16px 16px 0;
    background: linear-gradient(135deg, #7c3aed, #9333ea);
    color: #fff;
    cursor: pointer;
}
.footer-bottom-bar {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: center;
    margin-top: 24px;
    padding-top: 18px;
    border-top: 1px solid rgba(255,255,255,.08);
}
.footer-bottom-left,
.footer-bottom-links a {
    color: rgba(226,232,240,.62);
    font-size: .92rem;
}
.footer-bottom-left a {
    color: #c4b5fd;
    text-decoration: none;
}
.footer-bottom-links {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}
.footer-bottom-links a {
    text-decoration: none;
    transition: .25s ease;
}
.footer-bottom-links a:hover {
    color: #fff;
}

@media (max-width: 1024px) {
    .footer-top-shell,
    .footer-links-grid {
        grid-template-columns: 1fr;
    }
    .footer-contact-card {
        grid-column: span 1;
    }
    .footer-trust-row,
    .footer-contact-list {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 768px) {
    .footer-ultra {
        padding: 68px 0 24px;
    }
    .footer-top-shell {
        padding: 22px;
        border-radius: 28px;
    }
    .footer-brand-panel h3 {
        max-width: none;
    }
    .footer-cta-row {
        flex-direction: column;
    }
    .footer-primary-btn,
    .footer-secondary-btn {
        width: 100%;
    }
    .footer-bottom-bar {
        flex-direction: column;
        align-items: flex-start;
    }
}

.location-ultra-section .reveal-up{opacity:1;transform:none;}


/* final footer social strip fix */
.footer-social-strip{
    margin-top: 18px;
    width: 100%;
    max-width: 760px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding: 20px 24px;
    border-radius: 22px;
    background: linear-gradient(135deg, rgba(124,58,237,0.12), rgba(255,255,255,0.03));
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.footer-social-strip__text{
    min-width: 0;
}
.footer-social-strip__eyebrow{
    display:inline-flex;
    margin-bottom: 8px;
    color:#c4b5fd;
    font-size:12px;
    font-weight:700;
    letter-spacing:.04em;
    text-transform:uppercase;
}
.footer-social-strip h4{
    margin:0 0 6px;
    color:#fff;
    font-size:22px;
    line-height:1.15;
}
.footer-social-strip p{
    margin:0;
    color:rgba(255,255,255,.72);
    font-size:14px;
    line-height:1.6;
}
.footer-social-strip__icons{
    display:flex;
    gap:12px;
    flex-shrink:0;
    flex-wrap:wrap;
    justify-content:flex-end;
}
.footer-social-strip__icons a{
    width:40px;
    height:40px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background:rgba(255,255,255,0.08);
    border:1px solid rgba(255,255,255,0.08);
    border-radius:50%;
    color:#fff;
    font-size:16px;
    text-decoration:none;
    transition:transform .25s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease;
}
.footer-social-strip__icons a:hover{
    transform:translateY(-3px);
    background:linear-gradient(135deg, #7c3aed, #a78bfa);
    border-color:transparent;
    box-shadow:0 14px 28px rgba(124,58,237,0.35);
}
.footer-social-strip__icons svg{
    width:10px;
    height:10px;
    display:block;
}
.footer-social-strip__icons svg,
.footer-social-strip__icons svg *{
    fill:currentColor;
    stroke:none;
}
.footer-social-strip__icons .play{
    fill:#0b1020;
}
@media (max-width: 900px){
    .footer-social-strip{
        flex-direction:column;
        align-items:flex-start;
        max-width:none;
    }
    .footer-social-strip__icons{
        justify-content:flex-start;
    }
}

/* FIX: make social section horizontal */
.footer-social-strip{
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    max-width: 100% !important;
}

.footer-social-strip__text{
    max-width: 60%;
}

.footer-social-strip__icons{
    display:flex !important;
    flex-direction: row !important;
    gap:14px;
}

@media (max-width: 768px){
    .footer-social-strip{
        flex-direction: column !important;
        align-items: flex-start !important;
    }
    .footer-social-strip__text{
        max-width: 100%;
    }
}


/* clean footer social final */
.footer-brand-panel{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
}
.footer-social-strip{
    margin-top: 22px !important;
    width: 100%;
    max-width: 760px;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 24px;
    padding: 22px 24px;
    border-radius: 24px;
    background: linear-gradient(135deg, rgba(124,58,237,0.14), rgba(255,255,255,0.03));
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.footer-social-strip__text{
    max-width: 60%;
    min-width: 0;
}
.footer-social-strip__text h4{
    margin: 0 0 6px;
    font-size: 24px;
    line-height: 1.15;
    color: #fff;
}
.footer-social-strip__text p{
    margin: 0;
    font-size: 14px;
    line-height: 1.6;
    color: rgba(255,255,255,.72);
}
.footer-social-strip__icons{
    display:flex !important;
    flex-direction:row !important;
    gap:14px;
    flex-wrap:nowrap;
    justify-content:flex-end;
    align-items:center;
    flex-shrink:0;
}
.footer-social-strip__icons a{
    width:52px;
    height:52px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:16px;
    background:rgba(255,255,255,0.05);
    border:1px solid rgba(255,255,255,0.08);
    color:#fff;
    text-decoration:none;
    transition:all .25s ease;
}
.footer-social-strip__icons a:hover{
    transform:translateY(-3px);
    background:linear-gradient(135deg,#7c3aed,#a78bfa);
    border-color:transparent;
    box-shadow:0 14px 28px rgba(124,58,237,0.35);
}
.footer-social-strip__icons svg{
    width:20px;
    height:20px;
    display:block;
}
.footer-social-strip__icons svg,
.footer-social-strip__icons svg *{
    fill:currentColor;
    stroke:none;
}
.footer-social-strip__icons .play{
    fill:#0b1020;
}
@media (max-width: 768px){
    .footer-social-strip{
        flex-direction:column !important;
        align-items:flex-start !important;
    }
    .footer-social-strip__text{
        max-width:100%;
    }
    .footer-social-strip__icons{
        flex-wrap:wrap;
        justify-content:flex-start;
    }
}


/* footer structure repair */
.footer-top-shell{
    display:grid !important;
    grid-template-columns:minmax(0, 1.15fr) minmax(340px, .85fr) !important;
    gap:32px !important;
    align-items:start !important;
}
.footer-brand-panel{
    display:flex !important;
    flex-direction:column !important;
    align-items:flex-start !important;
    min-width:0 !important;
}
.footer-links-grid{
    display:grid !important;
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
    gap:20px !important;
    align-self:start !important;
}
.footer-social-strip{
    width:100% !important;
    max-width:760px !important;
}
@media (max-width: 1024px){
    .footer-top-shell{
        grid-template-columns:1fr !important;
    }
}
