/* ===================== CSS VARIABLES ===================== */
:root {
  --gold:       #c9a84c;
  --gold-light: #e8cc7a;
  --gold-dim:   #8a6e2e;
  --deep:       #06040f;
  --void:       #0a0719;
  --surface:    #110d22;
  --surface2:   #1a1432;
  --mist:       #c4b8e0;
  --mist-dim:   #7b6fa0;
  --white:      #f5f0ff;
  --accent:     #9b59d8;
  --accent2:    #e05fa0;
  --radius:     12px;
  --transition: 0.4s cubic-bezier(0.25,0.46,0.45,0.94);
}

/* ===================== RESET & BASE ===================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Raleway',sans-serif;background-color:var(--void);color:var(--mist);overflow-x:hidden;cursor: auto;}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}

/* ===================== CURSOR ===================== */
.cursor{position:fixed;width:12px;height:12px;background:var(--gold);border-radius:50%;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);transition:width .3s,height .3s,background .3s;mix-blend-mode:exclusion}
.cursor-ring{position:fixed;width:36px;height:36px;border:1px solid var(--gold);border-radius:50%;pointer-events:none;z-index:99998;transform:translate(-50%,-50%);opacity:.5}

/* ===================== CURSOR — MOBILE FIX ===================== */
@media (hover: none) and (pointer: coarse) {
  /* Скрываем кастомный курсор на тач-устройствах */
  .cursor,
  .cursor-ring {
    display: none !important;
  }

  /* Возвращаем системный курсор везде */
  body,
  .btn-primary-cosmic,
  .btn-outline-cosmic,
  .btn-consult,
  a,
  button {
    cursor: auto !important;
  }

  /* Для кликабельных элементов — указатель */
  a,
  button,
  .btn-primary-cosmic,
  .btn-outline-cosmic,
  .btn-consult,
  [role="button"] {
    cursor: pointer !important;
  }
}

.btn-primary-cosmic,
.btn-outline-cosmic,
.btn-consult { cursor: pointer; }


/* ===================== NOISE OVERLAY ===================== */
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:9999;opacity:.3}

/* ===================== STAR CANVAS ===================== */
#starCanvas{position:fixed;inset:0;z-index:0;pointer-events:none}

/* ===================== PRELOADER ===================== */
#preloader{position:fixed;inset:0;background:var(--void);z-index:100000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem}
.preloader-logo{font-family:'Cinzel',serif;font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--gold-light),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:0;animation:preLogoIn 1s ease .2s forwards}
.preloader-mandala{width:120px;height:120px;position:relative}
.mandala-ring{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(201,168,76,.3);animation:mandalaSpin 3s linear infinite}
.mandala-ring:nth-child(2){inset:15%;border-color:rgba(155,89,216,.25);animation-duration:2s;animation-direction:reverse}
.mandala-ring:nth-child(3){inset:30%;border-color:rgba(201,168,76,.4);animation-duration:1.5s}
.mandala-core{position:absolute;inset:40%;border-radius:50%;background:radial-gradient(circle,var(--gold) 0%,transparent 70%);animation:glowPulse 1.5s ease-in-out infinite}
.preloader-text{font-family:'Raleway',sans-serif;font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;color:var(--mist-dim);opacity:0;animation:preLogoIn 1s ease .6s forwards}
.preloader-bar{width:200px;height:2px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden;margin-top:1rem}
.preloader-bar-fill{height:100%;background:linear-gradient(90deg,var(--gold-dim),var(--gold-light));width:0%;border-radius:2px;animation:barFill 2.2s ease forwards}
@keyframes preLogoIn{to{opacity:1}}
@keyframes mandalaSpin{to{transform:rotate(360deg)}}
@keyframes barFill{to{width:100%}}
@keyframes glowPulse{0%,100%{opacity:.6}50%{opacity:1}}

/* ===================== SCROLLBAR ===================== */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--void)}
::-webkit-scrollbar-thumb{background:var(--gold-dim);border-radius:4px}

/* ===================== TYPOGRAPHY HELPERS ===================== */
h1,h2,h3,h4,h5{font-family:'Cinzel',serif}
.section-label{font-family:'Raleway',sans-serif;font-size:.7rem;letter-spacing:.35em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:.75rem}
.gold-gradient{background:linear-gradient(135deg,var(--gold-light),var(--gold),var(--gold-dim));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.section-title{font-size:clamp(1.8rem,4vw,3rem);line-height:1.2;margin-bottom:1rem}
.section-desc{color:var(--mist-dim);font-size:.95rem;line-height:1.8;font-weight:300}
.divider{height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.3),transparent)}

/* ===================== NAVBAR ===================== */
.navbar{background:transparent;padding:1.25rem 0;position:fixed;top:0;width:100%;z-index:1000;transition:background var(--transition),padding var(--transition)}
.navbar.scrolled{background:rgba(10,7,25,.9);backdrop-filter:blur(18px);padding:.75rem 0;border-bottom:1px solid rgba(201,168,76,.15)}
.navbar-brand{font-family:'Cinzel',serif;font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--gold-light),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.navbar-brand span{font-weight:300;-webkit-text-fill-color:var(--mist)}
.nav-link{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mist)!important;padding:.5rem 1rem!important;position:relative;transition:color var(--transition)}
.nav-link::after{content:'';position:absolute;bottom:0;left:50%;right:50%;height:1px;background:var(--gold);transition:left .3s,right .3s}
.nav-link:hover{color:var(--gold)!important}
.nav-link:hover::after{left:1rem;right:1rem}
.btn-consult{background:linear-gradient(135deg,var(--gold),var(--gold-dim));color:var(--deep)!important;font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:.12em;padding:.6rem 1.4rem!important;border-radius:30px;border:none;font-weight:700;transition:all var(--transition);box-shadow:0 0 20px rgba(201,168,76,.2);cursor:none}
.btn-consult:hover{transform:translateY(-2px);box-shadow:0 0 35px rgba(201,168,76,.45)}

/* Dropdown */
.nav-item.dropdown .dropdown-menu{background:rgba(10,7,25,.97);backdrop-filter:blur(20px);border:1px solid rgba(201,168,76,.15);border-radius:var(--radius);padding:.75rem 0;min-width:200px;box-shadow:0 20px 50px rgba(0,0,0,.5)}
.dropdown-item{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mist);padding:.6rem 1.25rem;transition:all .3s;display:flex;align-items:center;gap:.6rem}
.dropdown-item:hover{background:rgba(201,168,76,.08);color:var(--gold)}
.dropdown-item i{font-size:.9rem;color:var(--gold);opacity:.7}
.nav-item.dropdown:hover .dropdown-menu{display:block;animation:dropDown .25s ease}
@keyframes dropDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* Offcanvas */
.offcanvas{background:var(--void);border-left:1px solid rgba(201,168,76,.2);width:290px!important}
.offcanvas-header{border-bottom:1px solid rgba(201,168,76,.1)}
.offcanvas .nav-link{font-size:.95rem;padding:.85rem 0!important;border-bottom:1px solid rgba(255,255,255,.04)}
.offcanvas-acc .accordion-button{background:transparent;color:var(--mist);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;padding:.85rem 0;border:none;box-shadow:none;border-bottom:1px solid rgba(255,255,255,.04)}
.offcanvas-acc .accordion-button:not(.collapsed){color:var(--gold);background:transparent}
.offcanvas-acc .accordion-body{background:rgba(201,168,76,.03);padding:.5rem 0}
.offcanvas-acc .acc-link{display:block;font-size:.8rem;color:var(--mist-dim);padding:.5rem 1rem;transition:color .3s}
.offcanvas-acc .acc-link:hover{color:var(--gold)}
.btn-close-white{filter:invert(1) brightness(.7)}

/* ===================== BUTTONS ===================== */
.btn-primary-cosmic{display:inline-flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,var(--gold),var(--gold-dim));color:var(--deep);font-family:'Cinzel',serif;font-size:.75rem;font-weight:700;letter-spacing:.1em;padding:.9rem 2rem;border-radius:50px;border:none;cursor:none;transition:all var(--transition);box-shadow:0 4px 30px rgba(201,168,76,.25);position:relative;overflow:hidden}
.btn-primary-cosmic:hover{transform:translateY(-3px);box-shadow:0 8px 40px rgba(201,168,76,.4);color:var(--deep)}
.btn-outline-cosmic{display:inline-flex;align-items:center;gap:.75rem;background:transparent;color:var(--mist);font-family:'Cinzel',serif;font-size:.75rem;font-weight:600;letter-spacing:.1em;padding:.88rem 2rem;border-radius:50px;border:1px solid rgba(201,168,76,.4);cursor:none;transition:all var(--transition)}
.btn-outline-cosmic:hover{background:rgba(201,168,76,.08);border-color:var(--gold);color:var(--gold);transform:translateY(-3px)}

/* ===================== HERO ===================== */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding:6rem 0 4rem}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 70% 40%,rgba(155,89,216,.12) 0%,transparent 60%),radial-gradient(ellipse 60% 80% at 20% 60%,rgba(201,168,76,.07) 0%,transparent 55%);z-index:1}
.orbit-ring{position:absolute;border-radius:50%;border:1px solid rgba(201,168,76,.12);top:50%;left:50%;transform:translate(-50%,-50%)}
.ring-1{width:380px;height:380px;animation:orbitSpin 40s linear infinite}
.ring-2{width:580px;height:580px;animation:orbitSpin 70s linear infinite reverse;border-color:rgba(155,89,216,.08)}
.ring-3{width:820px;height:820px;animation:orbitSpin 100s linear infinite;border-color:rgba(201,168,76,.06)}
@keyframes orbitSpin{to{transform:translate(-50%,-50%) rotate(360deg)}}
.orbit-dot{position:absolute;width:6px;height:6px;background:var(--gold);border-radius:50%;box-shadow:0 0 10px var(--gold)}
.ring-1 .orbit-dot{top:0;left:50%;transform:translate(-50%,-50%)}
.ring-2 .orbit-dot{top:50%;right:0;transform:translate(50%,-50%);background:var(--accent2);box-shadow:0 0 10px var(--accent2)}
.hero-content{position:relative;z-index:2}
.hero-eyebrow{font-size:.68rem;letter-spacing:.45em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem}
.hero-eyebrow::before,.hero-eyebrow::after{content:'✦';font-size:.6rem;animation:twinkle 2s ease-in-out infinite}
.hero-eyebrow::after{animation-delay:1s}
@keyframes twinkle{0%,100%{opacity:1}50%{opacity:.3}}
.hero-title{font-family:'Cinzel',serif;font-size:clamp(3rem,8vw,7rem);line-height:1.05;font-weight:700;margin-bottom:1.5rem}
.hero-title .line{overflow:hidden;display:block}
.hero-title .italic-line{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(2.5rem,7vw,6.5rem)}
.hero-subtitle{font-size:.95rem;line-height:1.8;color:var(--mist-dim);max-width:480px;margin-bottom:2.5rem;font-weight:300}
.hero-stats{display:flex;gap:2.5rem;margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(201,168,76,.1)}
.stat-val{font-family:'Cinzel',serif;font-size:1.6rem;font-weight:700;color:var(--gold)}
.stat-label{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mist-dim)}
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;height:560px}
.zodiac-wheel{width:420px;height:420px;border-radius:50%;border:1px solid rgba(201,168,76,.15);position:relative;animation:orbitSpin 60s linear infinite}
.zodiac-inner{position:absolute;inset:15%;border-radius:50%;border:1px solid rgba(201,168,76,.1);animation:orbitSpin 40s linear infinite reverse;background:radial-gradient(ellipse at center,rgba(155,89,216,.08),transparent 70%)}
.zodiac-core{position:absolute;inset:35%;border-radius:50%;background:radial-gradient(ellipse at center,rgba(201,168,76,.15),rgba(155,89,216,.1) 50%,transparent 80%);display:flex;align-items:center;justify-content:center;font-size:2.5rem;animation:orbitSpin 20s linear infinite}
.zodiac-sign{position:absolute;font-size:1.1rem;transform-origin:50% 210px;color:rgba(201,168,76,.6)}

/* ===================== SECTIONS ===================== */
.section{padding:7rem 0;position:relative;z-index:2}
.section-sm{padding:4rem 0;position:relative;z-index:2}

/* ===================== SERVICE CARD ===================== */
.service-card{background:linear-gradient(145deg,var(--surface),var(--surface2));border:1px solid rgba(201,168,76,.1);border-radius:var(--radius);padding:2.5rem 2rem;position:relative;overflow:hidden;transition:all var(--transition);height:100%;cursor:none}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0;transition:opacity var(--transition)}
.service-card:hover{transform:translateY(-6px);border-color:rgba(201,168,76,.25)}
.service-card:hover::before{opacity:1}
.service-icon{width:60px;height:60px;background:linear-gradient(135deg,rgba(201,168,76,.15),rgba(155,89,216,.1));border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin-bottom:1.5rem;border:1px solid rgba(201,168,76,.2);transition:all var(--transition)}
.service-card:hover .service-icon{transform:rotate(5deg) scale(1.05)}
.service-card h4{font-size:1.1rem;margin-bottom:.75rem;color:var(--white)}
.service-card p{font-size:.88rem;line-height:1.75;color:var(--mist-dim);font-weight:300}
.learn-more{display:inline-flex;align-items:center;gap:.5rem;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-top:1.5rem;transition:gap var(--transition)}
.service-card:hover .learn-more{gap:.9rem}

/* ===================== BOOK SESSIONS SECTION ===================== */
.book-section{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--void) 0%,var(--surface) 100%)}
.book-session-img{position:absolute;right:0;top:0;bottom:0;width:55%;object-fit:cover;object-position:top center}
.book-session-overlay{position:absolute;right:0;top:0;bottom:0;width:55%;background:linear-gradient(to right,var(--surface) 0%,rgba(17,13,34,.2) 60%,transparent 100%)}
.session-card{background:rgba(255,255,255,.06);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:1.75rem;transition:all var(--transition);cursor:none;height:100%}
.session-card:hover{background:rgba(201,168,76,.07);border-color:rgba(201,168,76,.3);transform:translateY(-4px)}
.session-icon{width:52px;height:52px;background:transparent;border:1px solid rgba(201,168,76,.25);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:1.2rem;transition:all var(--transition)}
.session-card:hover .session-icon{border-color:var(--gold);background:rgba(201,168,76,.1)}
.session-card h5{font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;color:var(--white);margin-bottom:.6rem}
.session-card p{font-size:.82rem;color:var(--mist-dim);line-height:1.7;font-weight:300}
.session-dots{display:flex;gap:.3rem;margin-top:1rem}
.session-dots span{width:8px;height:8px;border-radius:50%;background:var(--gold);opacity:.4}
.session-dots span:first-child{opacity:1}

/* ===================== ASTROLOGERS WORK SECTION ===================== */
.work-section{position:relative;overflow:hidden;background:var(--void)}
.work-center-img{width:100%;max-width:480px;position:relative;z-index:1}
.work-center-img img{width:100%;border-radius:var(--radius);object-fit:cover}
.work-orbit{position:absolute;inset:-10%;border:1px solid rgba(201,168,76,.1);border-radius:50%;animation:orbitSpin 20s linear infinite}
.work-orbit-2{position:absolute;inset:-25%;border:1px solid rgba(155,89,216,.08);border-radius:50%;animation:orbitSpin 35s linear infinite reverse}
.work-item{text-align:center;padding:1.5rem 1rem;cursor:none}
.work-item:hover .work-item-icon{transform:scale(1.1)}
.work-item-icon{width:70px;height:70px;background:rgba(255,255,255,.04);border:1px solid rgba(201,168,76,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 1rem;transition:all var(--transition)}
.work-item h5{font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.work-item p{font-size:.8rem;color:var(--mist-dim);line-height:1.7;font-weight:300}
.work-dots{display:flex;gap:.3rem;justify-content:center;margin-top:.75rem}
.work-dots span{width:7px;height:7px;border-radius:50%;background:var(--gold);opacity:.35}
.work-dots span:first-child{opacity:1}
.tips-bar{background:var(--gold);padding:1.5rem 2.5rem;margin-top:2rem;display:flex;align-items:center;gap:2rem;border-radius:0}
.tips-label{font-family:'Cinzel',serif;font-size:.85rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--deep);white-space:nowrap;min-width:180px}
.tips-text{font-size:.9rem;color:var(--deep);line-height:1.6;font-style:italic}
.tips-quote{font-size:2rem;color:rgba(0,0,0,.3);line-height:1;flex-shrink:0}

/* ===================== ASTROLOGER CARDS ===================== */
.astrologer-card{background:var(--surface);border:1px solid rgba(201,168,76,.1);border-radius:var(--radius);overflow:hidden;transition:all var(--transition);cursor:none}
.astrologer-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,.4);border-color:rgba(201,168,76,.25)}
.astrologer-img{height:240px;background:linear-gradient(145deg,var(--surface2),var(--void));position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.astrologer-avatar{width:110px;height:110px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.8rem;border:2px solid rgba(201,168,76,.3);box-shadow:0 0 30px rgba(201,168,76,.15)}
.astrologer-badge{position:absolute;top:1rem;right:1rem;font-family:'Cinzel',serif;font-size:.6rem;font-weight:700;letter-spacing:.1em;padding:.3rem .75rem;border-radius:20px}
.badge-online{background:linear-gradient(135deg,var(--gold),var(--gold-dim));color:var(--deep)}
.badge-busy{background:rgba(155,89,216,.25);color:var(--mist);border:1px solid rgba(155,89,216,.3)}
.astrologer-body{padding:1.5rem}
.astrologer-body h5{font-size:1rem;color:var(--white);margin-bottom:.25rem}
.astrologer-spec{font-size:.75rem;color:var(--gold);letter-spacing:.08em;margin-bottom:.75rem}
.stars{color:var(--gold);font-size:.85rem}
.astrologer-meta{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.05)}
.astrologer-meta .rate{font-family:'Cinzel',serif;font-size:.85rem;color:var(--gold)}
.btn-chat{font-size:.7rem;font-family:'Cinzel',serif;letter-spacing:.08em;padding:.45rem 1rem;border-radius:20px;border:none;cursor:none;transition:all var(--transition)}
.btn-chat-active{background:linear-gradient(135deg,var(--accent),var(--accent2));color:var(--white)}
.btn-chat-active:hover{transform:scale(1.05);box-shadow:0 4px 20px rgba(155,89,216,.4);color:var(--white)}
.btn-chat-wait{background:rgba(255,255,255,.08);color:var(--mist-dim)}

/* ===================== TAROT SECTION ===================== */
.tarot-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 80% at 50% 50%,rgba(155,89,216,.08),transparent 70%)}
.tarot-card-wrapper{perspective:1200px;cursor:none}
.tarot-card{width:180px;height:300px;border-radius:16px;transform-style:preserve-3d;transition:transform .8s cubic-bezier(.175,.885,.32,1.275);position:relative;margin:0 auto}
.tarot-card-wrapper:hover .tarot-card{transform:rotateY(180deg)}
.tarot-face,.tarot-back{position:absolute;inset:0;border-radius:16px;backface-visibility:hidden;display:flex;align-items:center;justify-content:center;flex-direction:column;padding:1.5rem 1rem;text-align:center}
.tarot-face{background:linear-gradient(145deg,var(--surface),var(--surface2));border:1px solid rgba(201,168,76,.2)}
.tarot-back{background:linear-gradient(145deg,var(--accent),var(--void));border:1px solid rgba(155,89,216,.3);transform:rotateY(180deg)}
.tarot-symbol{font-size:3rem;margin-bottom:.75rem}
.tarot-name{font-family:'Cinzel',serif;font-size:.78rem;letter-spacing:.1em;color:var(--gold);margin-bottom:.4rem}
.tarot-meaning{font-size:.73rem;color:var(--mist-dim);line-height:1.6}
.tarot-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1.5rem;margin-top:3rem}
@media(max-width:991px){.tarot-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:575px){.tarot-grid{grid-template-columns:repeat(2,1fr)}}

/* ===================== NUMEROLOGY ===================== */
.numerology-section{background:var(--surface)}
.num-calculator{background:linear-gradient(145deg,var(--surface2),var(--void));border:1px solid rgba(201,168,76,.15);border-radius:var(--radius);padding:2.5rem}
.num-input{background:rgba(255,255,255,.04);border:1px solid rgba(201,168,76,.2);color:var(--white);border-radius:8px;padding:.85rem 1rem;width:100%;font-family:'Raleway',sans-serif;transition:border-color var(--transition)}
.num-input:focus{outline:none;border-color:var(--gold);background:rgba(201,168,76,.05)}
.num-input::placeholder{color:var(--mist-dim)}
.num-result{background:linear-gradient(135deg,rgba(201,168,76,.08),rgba(155,89,216,.08));border:1px solid rgba(201,168,76,.2);border-radius:var(--radius);padding:2rem;text-align:center;margin-top:1.5rem;display:none}
.num-result.show{display:block;animation:fadeInUp .5s ease}
.num-big{font-family:'Cinzel',serif;font-size:4rem;font-weight:700;line-height:1;background:linear-gradient(135deg,var(--gold-light),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.num-title{font-size:1.1rem;color:var(--white);margin-top:.5rem}
.num-desc{font-size:.85rem;color:var(--mist-dim);margin-top:.5rem}

/* ===================== ZODIAC GRID ===================== */
.zodiac-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem;margin-top:2.5rem}
@media(max-width:991px){.zodiac-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:575px){.zodiac-grid{grid-template-columns:repeat(3,1fr)}}
.zodiac-item{background:linear-gradient(145deg,var(--surface),var(--surface2));border:1px solid rgba(201,168,76,.1);border-radius:var(--radius);padding:1.2rem .75rem;text-align:center;cursor:none;transition:all var(--transition);position:relative;overflow:hidden}
.zodiac-item::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at center,rgba(201,168,76,.06),transparent 70%);opacity:0;transition:opacity var(--transition)}
.zodiac-item:hover{transform:translateY(-4px);border-color:rgba(201,168,76,.3)}
.zodiac-item:hover::before{opacity:1}
.zodiac-emoji{font-size:1.8rem;margin-bottom:.4rem;display:block}
.zodiac-item h6{font-size:.72rem;letter-spacing:.08em;color:var(--gold);margin-bottom:.2rem}
.zodiac-dates{font-size:.62rem;color:var(--mist-dim)}

/* ===================== TESTIMONIALS ===================== */
.testimonial-card{background:var(--surface);border:1px solid rgba(201,168,76,.1);border-radius:var(--radius);padding:2rem;height:100%;transition:all var(--transition);cursor:none;position:relative}
.testimonial-card::before{content:'"';position:absolute;top:1rem;right:1.5rem;font-family:'Cormorant Garamond',serif;font-size:5rem;color:rgba(201,168,76,.1);line-height:1}
.testimonial-card:hover{border-color:rgba(201,168,76,.2);transform:translateY(-4px)}
.testimonial-text{font-size:.9rem;line-height:1.8;color:var(--mist-dim);font-style:italic;margin-bottom:1.5rem}
.testimonial-author{display:flex;align-items:center;gap:1rem}
.author-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;border:1px solid rgba(201,168,76,.2)}
.author-name{font-size:.85rem;color:var(--white);font-weight:600}
.author-sign{font-size:.7rem;color:var(--gold)}

/* ===================== CTA ===================== */
.cta-section{position:relative;overflow:hidden;text-align:center;padding:8rem 0}
.cta-bg{position:absolute;inset:0;background:radial-gradient(ellipse 70% 70% at 50% 50%,rgba(155,89,216,.12),transparent 70%),radial-gradient(ellipse 40% 40% at 30% 40%,rgba(201,168,76,.07),transparent 60%)}
@keyframes glow-pulse{0%,100%{box-shadow:0 0 20px rgba(201,168,76,.2)}50%{box-shadow:0 0 40px rgba(201,168,76,.5)}}

/* ===================== FOOTER ===================== */
footer{background:var(--deep);border-top:1px solid rgba(201,168,76,.1);padding:5rem 0 2rem;position:relative;z-index:2}
.footer-brand{font-family:'Cinzel',serif;font-size:1.6rem;background:linear-gradient(135deg,var(--gold-light),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem}
.footer-desc{font-size:.85rem;color:var(--mist-dim);line-height:1.8;font-weight:300;margin-bottom:1.5rem}
.footer-heading{font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:1.25rem}
.footer-links{list-style:none}
.footer-links li{margin-bottom:.65rem}
.footer-links a{font-size:.85rem;color:var(--mist-dim);transition:color var(--transition)}
.footer-links a:hover{color:var(--gold)}
.social-links{display:flex;gap:.75rem}
.social-link{width:40px;height:40px;background:rgba(255,255,255,.04);border:1px solid rgba(201,168,76,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--mist-dim);font-size:1rem;transition:all var(--transition);cursor:none}
.social-link:hover{background:rgba(201,168,76,.12);border-color:var(--gold);color:var(--gold);transform:translateY(-3px)}
.footer-bottom{margin-top:4rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-copy{font-size:.78rem;color:var(--mist-dim)}

/* ===================== INNER PAGE HERO ===================== */
.page-hero{padding:9rem 0 5rem;text-align:center;position:relative;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 40%,rgba(155,89,216,.12),transparent 70%),radial-gradient(ellipse 50% 50% at 80% 60%,rgba(201,168,76,.07),transparent 60%)}
.breadcrumb-cosmic{display:flex;justify-content:center;gap:.5rem;font-size:.75rem;letter-spacing:.1em;color:var(--mist-dim);text-transform:uppercase;margin-top:1rem}
.breadcrumb-cosmic a{color:var(--gold)}
.breadcrumb-cosmic span{color:var(--mist-dim)}

/* ===================== ABOUT PAGE ===================== */
.about-img-wrap{position:relative;padding:1.5rem}
.about-img-wrap img{border-radius:var(--radius);width:100%;object-fit:cover;max-height:480px}
.about-img-wrap::before{content:'';position:absolute;top:0;left:0;right:1.5rem;bottom:1.5rem;border:1px solid rgba(201,168,76,.2);border-radius:var(--radius);z-index:0}
.about-img-wrap img{position:relative;z-index:1}
.about-badge{position:absolute;bottom:0;right:0;background:linear-gradient(135deg,var(--gold),var(--gold-dim));color:var(--deep);font-family:'Cinzel',serif;font-size:.85rem;font-weight:700;padding:1.25rem 1.75rem;border-radius:var(--radius);z-index:2;text-align:center}
.about-badge .num{font-size:2rem;line-height:1;display:block}

/* ===================== CONTACT PAGE ===================== */
.contact-form-wrap{background:linear-gradient(145deg,var(--surface),var(--surface2));border:1px solid rgba(201,168,76,.12);border-radius:var(--radius);padding:3rem}
.form-label-cosmic{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mist);display:block;margin-bottom:.5rem}
.form-control-cosmic{background:rgba(255,255,255,.04);border:1px solid rgba(201,168,76,.2);color:var(--white);border-radius:8px;padding:.85rem 1rem;width:100%;font-family:'Raleway',sans-serif;transition:border-color var(--transition);resize:vertical}
.form-control-cosmic:focus{outline:none;border-color:var(--gold);background:rgba(201,168,76,.04);color:var(--white)}
.form-control-cosmic::placeholder{color:var(--mist-dim)}
.contact-info-card{background:linear-gradient(145deg,var(--surface),var(--surface2));border:1px solid rgba(201,168,76,.1);border-radius:var(--radius);padding:2rem}
.contact-icon{width:50px;height:50px;border:1px solid rgba(201,168,76,.25);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:1rem;color:var(--gold)}

/* ===================== BLOG CARD ===================== */
.blog-card{background:var(--surface);border:1px solid rgba(201,168,76,.1);border-radius:var(--radius);overflow:hidden;transition:all var(--transition);cursor:none;height:100%}
.blog-card:hover{transform:translateY(-6px);border-color:rgba(201,168,76,.25);box-shadow:0 20px 50px rgba(0,0,0,.4)}
.blog-img{height:200px;background:linear-gradient(145deg,var(--surface2),var(--void));display:flex;align-items:center;justify-content:center;font-size:3.5rem;position:relative;overflow:hidden}
.blog-cat{position:absolute;top:1rem;left:1rem;background:rgba(201,168,76,.15);border:1px solid rgba(201,168,76,.3);color:var(--gold);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;padding:.3rem .75rem;border-radius:20px}
.blog-body{padding:1.5rem}
.blog-date{font-size:.7rem;color:var(--mist-dim);letter-spacing:.1em;margin-bottom:.75rem}
.blog-body h5{font-size:1rem;color:var(--white);margin-bottom:.75rem;line-height:1.4}
.blog-body p{font-size:.85rem;color:var(--mist-dim);line-height:1.7;font-weight:300}
.blog-footer{padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:center}
.blog-read{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}

/* ===================== ANIMATIONS ===================== */
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

/* ===================== RESPONSIVE ===================== */
@media(max-width:991px){
  .hero-visual{height:380px}
  .zodiac-wheel{width:300px;height:300px}
  .ring-1{width:260px;height:260px}
  .ring-2{width:380px;height:380px}
  .ring-3{width:520px;height:520px}
  .hero-stats{gap:1.5rem}
  .book-session-img,.book-session-overlay{display:none}
  .tips-bar{flex-direction:column;text-align:center;gap:.75rem}
  .tips-label{min-width:auto}
}
@media(max-width:767px){
  .hero-visual{display:none}
  .tarot-grid{grid-template-columns:repeat(2,1fr)}
  .contact-form-wrap{padding:2rem 1.5rem}
  .work-center-img{max-width:300px}
}
@media(max-width:575px){
  .hero-stats{flex-wrap:wrap;gap:1rem}
}
