:root{--bg:#f5f2ed;--text:#3d2b1f;--accent:#b8926c;--accent-dark:#a07d5a;--input-border:#d4ccc4;--focus:#c9b59b;--card-bg:#f0ede8;--card-bg-light:#f5f2ef;}
*{box-sizing:border-box}
body{margin:0;background:linear-gradient(135deg, #e8e4dd 0%, #dfd9d1 100%);color:var(--text);font-family:Montserrat,sans-serif}

/* ===== ГЛАВНЫЙ ЭКРАН С ФОТО ===== */
.hero{
    position:relative;
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
    margin-bottom:40px;
}
.hero-bg-img{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center;
    z-index:0;
}
.hero-overlay{
    position:absolute;
    top:0;
    left:0;
    right:0;
    bottom:0;
    background:linear-gradient(135deg, rgba(0,0,0,0.5), rgba(0,0,0,0.35));
    z-index:1;
}
.hero-inner{
    position:relative;
    z-index:2;
    text-align:center;
    max-width:900px;
    padding:40px 30px;
    background:rgba(255,255,255,0.12);
    backdrop-filter:blur(8px);
    border-radius:60px;
    margin:20px;
    border:1px solid rgba(255,255,255,0.25);
    animation:fadeInUp 1s ease;
}
@keyframes fadeInUp{
    from{opacity:0;transform:translateY(30px)}
    to{opacity:1;transform:translateY(0)}
}
h1,h2{font-family:'Cormorant Garamond',serif}
h1{font-size:80px;margin:10px 0;color:white;text-shadow:2px 2px 15px rgba(0,0,0,0.4);letter-spacing:3px}
.hero-subtitle{font-size:24px;color:white;text-shadow:1px 1px 8px rgba(0,0,0,0.4);font-family:'Cormorant Garamond',serif;font-weight:400;letter-spacing:1px;margin:25px 0;line-height:1.5}
.date-top{letter-spacing:5px;font-size:14px;color:white;text-shadow:1px 1px 4px rgba(0,0,0,0.3);font-weight:300}
.btn{background:var(--accent);color:white;border:none;padding:16px 36px;border-radius:50px;text-decoration:none;cursor:pointer;font-family:Montserrat;font-weight:500;transition:all .3s;display:inline-block;margin-top:15px}
.btn:hover{background:var(--accent-dark);transform:scale(1.03);box-shadow:0 10px 25px rgba(0,0,0,0.2)}
.btn:active{transform:scale(0.97);}

/* ===== СЕКЦИИ ===== */
section{
    max-width:1100px;
    margin:50px auto;
    padding:60px 30px;
    background:var(--card-bg);
    border-radius:40px;
    box-shadow:0 15px 35px rgba(0,0,0,0.08);
    transition:all 0.3s;
    border:1px solid rgba(255,255,255,0.4);
}
section:hover{
    box-shadow:0 20px 45px rgba(0,0,0,0.1);
    background:var(--card-bg-light);
}
h2{
    font-size:48px;
    text-align:center;
    margin-bottom:45px;
    color:#3d2b1f;
    letter-spacing:-0.5px;
}

/* ===== ТАЙМЕР ===== */
.countdown{display:flex;justify-content:center;gap:25px;flex-wrap:wrap}
.countdown .card{background:#e8e4dd;padding:25px 20px;min-width:130px;border-radius:28px;box-shadow:0 10px 20px rgba(0,0,0,0.05);text-align:center;transition:all 0.3s ease;border-bottom:4px solid var(--accent);cursor:default}
.countdown .card:hover{transform:translateY(-8px);box-shadow:0 20px 30px rgba(0,0,0,0.1);background:#ede9e2}
.countdown .card{font-size:56px;font-weight:700;color:var(--accent);font-family:'Montserrat',sans-serif;line-height:1.2}
.countdown .card span{display:block;font-size:13px;font-weight:600;color:#7a6b5d;margin-top:10px;letter-spacing:1.5px;text-transform:uppercase}
.countdown .card::before{content:'⏰';display:block;font-size:24px;margin-bottom:10px;background:linear-gradient(135deg,#b8926c,#9a7a58);background-clip:text;-webkit-background-clip:text;color:transparent}

/* ===== ТАЙМЕР ДО ДЕДЛАЙНА ===== */
.deadline-timer {
    display: flex;
    justify-content: center;
    gap: 25px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}
.deadline-timer .deadline-card {
    background: #e8e4dd;
    padding: 20px 25px;
    min-width: 120px;
    border-radius: 28px;
    text-align: center;
    box-shadow: 0 10px 20px rgba(0,0,0,0.05);
    border-bottom: 4px solid var(--accent);
    transition: all 0.3s;
}
.deadline-timer .deadline-card:hover {
    transform: translateY(-5px);
    background: #ede9e2;
}
.deadline-timer .deadline-card .number {
    font-size: 48px;
    font-weight: 700;
    color: var(--accent);
    font-family: 'Montserrat', sans-serif;
}
.deadline-timer .deadline-card .label {
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: #7a6b5d;
    margin-top: 10px;
    display: block;
    font-weight: 500;
}
.deadline-note {
    text-align: center;
    font-size: 14px;
    color: #7a6b5d;
    margin-top: 15px;
}

/* ===== ТАЙМИНГ ДНЯ ===== */
.timeline-container {
    position: relative;
    max-width: 750px;
    margin: 0 auto;
    padding: 20px 0;
}
.timeline-bg-decor {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    overflow: hidden;
    z-index: 0;
}
.decor-circle {
    position: absolute;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(184,146,108,0.08) 0%, rgba(184,146,108,0) 70%);
}
.decor-circle-1 {
    width: 250px;
    height: 250px;
    top: -50px;
    right: -80px;
    animation: floatCircle 8s ease-in-out infinite;
}
.decor-circle-2 {
    width: 180px;
    height: 180px;
    bottom: -30px;
    left: -60px;
    animation: floatCircle 6s ease-in-out infinite reverse;
}
.decor-dots {
    position: absolute;
    background-image: radial-gradient(#b8926c 2px, transparent 2px);
    background-size: 20px 20px;
    opacity: 0.15;
}
.decor-dots-1 {
    width: 200px;
    height: 200px;
    top: 20%;
    right: 10%;
}
.decor-dots-2 {
    width: 150px;
    height: 150px;
    bottom: 15%;
    left: 5%;
}
@keyframes floatCircle {
    0%, 100% { transform: translate(0, 0); }
    50% { transform: translate(15px, -15px); }
}
.timeline {
    position: relative;
    padding-left: 45px;
}
.timeline::before {
    content: '';
    position: absolute;
    left: 28px;
    top: 15px;
    bottom: 15px;
    width: 3px;
    background: linear-gradient(180deg, 
        rgba(184,146,108,0.6) 0%, 
        rgba(184,146,108,0.9) 30%,
        rgba(184,146,108,0.9) 70%,
        rgba(184,146,108,0.4) 100%);
    border-radius: 3px;
}
.timeline-item {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 25px;
    margin-bottom: 55px;
    opacity: 0;
    transform: translateX(-20px);
    animation: slideInItem 0.6s ease forwards;
}
.timeline-item:nth-child(1) { animation-delay: 0.1s; }
.timeline-item:nth-child(2) { animation-delay: 0.2s; }
.timeline-item:nth-child(3) { animation-delay: 0.3s; }
.timeline-item:nth-child(4) { animation-delay: 0.4s; }
@keyframes slideInItem {
    to {
        opacity: 1;
        transform: translateX(0);
    }
}
.timeline-item:hover {
    transform: translateX(8px);
    transition: transform 0.3s ease;
}
.timeline-icon-wrapper {
    flex-shrink: 0;
    position: relative;
    z-index: 2;
}
.timeline-icon-bg {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, #fff, #f5f2ef);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
    border: 2px solid white;
    transition: all 0.3s ease;
    position: relative;
}
.timeline-icon-bg::after {
    content: '';
    position: absolute;
    top: -3px;
    left: -3px;
    right: -3px;
    bottom: -3px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(184,146,108,0.3), rgba(184,146,108,0));
    z-index: -1;
}
.timeline-item:hover .timeline-icon-bg {
    transform: scale(1.08);
    background: linear-gradient(135deg, #fff, #ede9e2);
    box-shadow: 0 12px 25px rgba(0, 0, 0, 0.15);
}
.timeline-icon {
    font-size: 32px;
    transition: transform 0.3s ease;
    background: linear-gradient(135deg, #b8926c, #9a7a58);
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
}
.timeline-item:hover .timeline-icon {
    transform: scale(1.1);
    background: linear-gradient(135deg, #c9a87e, #b8926c);
    background-clip: text;
    -webkit-background-clip: text;
}
.timeline-content {
    flex: 1;
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(4px);
    padding: 15px 20px;
    border-radius: 24px;
    transition: all 0.3s ease;
    border: 1px solid rgba(255, 255, 255, 0.5);
}
.timeline-item:hover .timeline-content {
    background: rgba(255, 255, 255, 0.9);
    transform: translateX(5px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.05);
}
.timeline-time {
    font-size: 32px;
    font-weight: 700;
    font-family: 'Cormorant Garamond', serif;
    color: var(--accent);
    line-height: 1;
    margin-bottom: 8px;
    letter-spacing: 1px;
}
.timeline-title {
    font-size: 20px;
    font-weight: 600;
    color: #4a3729;
    margin-bottom: 6px;
}
.timeline-desc {
    font-size: 14px;
    color: #8b7a6a;
    line-height: 1.4;
}
.timeline-sparkle {
    position: absolute;
    right: -15px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 14px;
    opacity: 0;
    transition: opacity 0.3s ease, transform 0.3s ease;
    pointer-events: none;
}
.timeline-item:hover .timeline-sparkle {
    opacity: 1;
    transform: translateY(-50%) scale(1.2);
}
.timeline-item::before {
    content: '';
    position: absolute;
    left: 24px;
    top: 28px;
    width: 12px;
    height: 12px;
    background: var(--accent);
    border-radius: 50%;
    border: 2px solid white;
    box-shadow: 0 0 0 3px rgba(184,146,108,0.2);
    z-index: 2;
    transition: all 0.3s ease;
}
.timeline-item:hover::before {
    transform: scale(1.3);
    background: var(--accent-dark);
    box-shadow: 0 0 0 5px rgba(184,146,108,0.3);
}
@media (max-width: 768px) {
    .timeline {
        padding-left: 25px;
    }
    .timeline::before {
        left: 15px;
    }
    .timeline-item::before {
        left: 11px;
        width: 10px;
        height: 10px;
    }
    .timeline-icon-bg {
        width: 48px;
        height: 48px;
    }
    .timeline-icon {
        font-size: 26px;
    }
    .timeline-content {
        padding: 12px 16px;
    }
    .timeline-time {
        font-size: 24px;
    }
    .timeline-title {
        font-size: 17px;
    }
    .timeline-desc {
        font-size: 12px;
    }
    .timeline-item {
        gap: 15px;
        margin-bottom: 40px;
    }
    .timeline-sparkle {
        display: none;
    }
}

/* ===== ЛОКАЦИИ (НАСЫЩЕННЫЕ КАРТОЧКИ, 3D КНОПКИ) ===== */
.locations-container {
    position: relative;
    max-width: 1000px;
    margin: 0 auto;
    padding: 20px 0;
}
.locations-decor {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    overflow: hidden;
    z-index: 0;
}
.loc-decor-circle {
    position: absolute;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(184,146,108,0.06) 0%, rgba(184,146,108,0) 70%);
}
.loc-decor-circle-1 {
    width: 300px;
    height: 300px;
    top: -100px;
    right: -80px;
    animation: floatCircleLoc 10s ease-in-out infinite;
}
.loc-decor-circle-2 {
    width: 200px;
    height: 200px;
    bottom: -50px;
    left: -50px;
    animation: floatCircleLoc 7s ease-in-out infinite reverse;
}
.loc-decor-dots {
    position: absolute;
    width: 250px;
    height: 250px;
    top: 30%;
    left: 20%;
    background-image: radial-gradient(#b8926c 2px, transparent 2px);
    background-size: 25px 25px;
    opacity: 0.1;
    border-radius: 50%;
}
@keyframes floatCircleLoc {
    0%, 100% { transform: translate(0, 0); }
    50% { transform: translate(20px, -20px); }
}
.locations-photos {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 30px;
    margin-bottom: 50px;
    position: relative;
    z-index: 2;
}
.loc-photo-wrapper {
    flex: 1;
    min-width: 300px;
    max-width: 450px;
    transition: all 0.4s ease;
}
.loc-photo-inner {
    position: relative;
    border-radius: 32px;
    overflow: hidden;
    box-shadow: 0 20px 35px rgba(0, 0, 0, 0.15);
    transition: all 0.4s ease;
    border: 3px solid white;
    cursor: pointer;
}
.loc-photo-inner:hover {
    transform: translateY(-8px);
    box-shadow: 0 30px 45px rgba(0, 0, 0, 0.2);
}
.loc-photo {
    width: 100%;
    height: 280px;
    object-fit: cover;
    display: block;
    transition: transform 0.5s ease;
}
.loc-photo-inner:hover .loc-photo {
    transform: scale(1.05);
}
.loc-photo-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.7));
    color: white;
    padding: 18px 25px;
    text-align: center;
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 1px;
    font-family: 'Cormorant Garamond', serif;
    transform: translateY(100%);
    transition: transform 0.3s ease;
}
.loc-photo-inner:hover .loc-photo-overlay {
    transform: translateY(0);
}
.locations-cards {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 30px;
    position: relative;
    z-index: 2;
}
.location-card {
    flex: 1;
    min-width: 280px;
    background: linear-gradient(145deg, #f5f2ef, #e8e4dd);
    backdrop-filter: blur(8px);
    border-radius: 40px;
    padding: 35px 25px;
    text-align: center;
    transition: all 0.4s ease;
    border: 1px solid rgba(255, 255, 255, 0.6);
    box-shadow: 12px 12px 25px rgba(0, 0, 0, 0.08), -5px -5px 12px rgba(255, 255, 255, 0.5);
    position: relative;
    overflow: hidden;
}
.location-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
    transition: left 0.6s ease;
    pointer-events: none;
}
.location-card:hover::before {
    left: 100%;
}
.location-card:hover {
    transform: translateY(-10px);
    background: linear-gradient(145deg, #ede9e2, #e0dbd3);
    box-shadow: 18px 18px 30px rgba(0, 0, 0, 0.12), -8px -8px 15px rgba(255, 255, 255, 0.6);
}
.location-card-icon {
    font-size: 56px;
    margin-bottom: 18px;
    transition: all 0.3s ease;
    display: inline-block;
    background: linear-gradient(135deg, #b8926c, #9a7a58);
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.05);
}
.location-card:hover .location-card-icon {
    transform: scale(1.1);
    background: linear-gradient(135deg, #c9a87e, #b8926c);
    background-clip: text;
    -webkit-background-clip: text;
}
.location-title {
    font-size: 32px;
    font-family: 'Cormorant Garamond', serif;
    color: #4a3729;
    margin-bottom: 18px;
    letter-spacing: 2px;
    font-weight: 600;
    position: relative;
    display: inline-block;
}
.location-title::after {
    content: '';
    position: absolute;
    bottom: -8px;
    left: 50%;
    transform: translateX(-50%);
    width: 50px;
    height: 2px;
    background: var(--accent);
    border-radius: 2px;
    transition: width 0.3s ease;
}
.location-card:hover .location-title::after {
    width: 80px;
}
.location-address {
    font-size: 16px;
    color: #6b5a4a;
    line-height: 1.6;
    margin-bottom: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    flex-wrap: wrap;
    background: rgba(255, 255, 255, 0.4);
    padding: 12px 15px;
    border-radius: 60px;
    font-weight: 500;
}
.loc-icon {
    font-size: 18px;
    filter: drop-shadow(0 2px 2px rgba(0, 0, 0, 0.1));
    background: linear-gradient(135deg, #b8926c, #9a7a58);
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
}
.location-buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 15px;
    margin-bottom: 20px;
}
.loc-copy-btn, .loc-map-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 24px;
    font-size: 15px;
    font-weight: 600;
    border-radius: 50px;
    cursor: pointer;
    transition: all 0.2s ease;
    border: none;
    letter-spacing: 0.5px;
    box-shadow: 0 5px 0 rgba(0, 0, 0, 0.15);
    position: relative;
    top: 0;
}
.loc-copy-btn {
    background: linear-gradient(135deg, #d4ccc4, #c4b8ac);
    color: #4a3729;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.3);
}
.loc-copy-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 7px 0 rgba(0, 0, 0, 0.15);
    background: linear-gradient(135deg, #dcd4cc, #ccc0b4);
}
.loc-copy-btn:active {
    transform: translateY(3px);
    box-shadow: 0 2px 0 rgba(0, 0, 0, 0.15);
}
.loc-map-btn {
    background: linear-gradient(135deg, #b8926c, #9a7a58);
    color: white;
    text-shadow: 0 1px 0 rgba(0, 0, 0, 0.2);
}
.loc-map-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 7px 0 rgba(0, 0, 0, 0.15);
    background: linear-gradient(135deg, #c9a07a, #a88864);
}
.loc-map-btn:active {
    transform: translateY(3px);
    box-shadow: 0 2px 0 rgba(0, 0, 0, 0.15);
}
.location-hint {
    font-size: 12px;
    color: #9a8a7a;
    opacity: 0;
    transition: opacity 0.3s ease;
    font-style: italic;
    letter-spacing: 0.5px;
}
.location-card:hover .location-hint {
    opacity: 1;
}
.location-card::after {
    content: '✦';
    position: absolute;
    bottom: 15px;
    right: 20px;
    font-size: 20px;
    color: var(--accent);
    opacity: 0;
    transition: opacity 0.3s ease, transform 0.3s ease;
}
.location-card:hover::after {
    opacity: 0.3;
    transform: rotate(15deg);
}
@media (max-width: 768px) {
    .locations-photos {
        gap: 20px;
        margin-bottom: 35px;
    }
    .loc-photo-wrapper {
        min-width: 260px;
        max-width: 100%;
    }
    .loc-photo {
        height: 220px;
    }
    .loc-photo-overlay {
        font-size: 14px;
        padding: 12px;
    }
    .location-card {
        padding: 25px 20px;
    }
    .location-title {
        font-size: 26px;
    }
    .location-address {
        font-size: 14px;
        padding: 10px 12px;
    }
    .loc-copy-btn, .loc-map-btn {
        padding: 12px 18px;
        font-size: 13px;
        gap: 8px;
    }
    .location-buttons {
        gap: 10px;
    }
}

/* ===== ДРЕСС-КОД ===== */
.dresscode-img-container{position:relative;max-width:400px;margin:20px auto;overflow:hidden;border-radius:28px;cursor:pointer}
.dresscode-img{width:100%;display:block;transition:transform 0.4s ease, box-shadow 0.3s ease;border-radius:28px;box-shadow:0 15px 30px rgba(0,0,0,0.1)}
.dresscode-img-container:hover .dresscode-img{transform:scale(1.08);box-shadow:0 25px 45px rgba(0,0,0,0.2)}
.img-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent, rgba(0,0,0,0.7));color:white;text-align:center;padding:15px;font-size:12px;opacity:0;transition:opacity 0.3s ease;border-radius:0 0 28px 28px}
.dresscode-img-container:hover .img-overlay{opacity:1}
.dresscode-text{font-size:20px;line-height:1.7;text-align:center;margin-top:25px;font-weight:400;color:#5a4a3a}
.palette{display:flex;justify-content:center;gap:15px;flex-wrap:wrap;margin:30px 0}
.palette div{width:70px;height:70px;border-radius:50%;transition:all 0.3s ease;cursor:pointer;box-shadow:0 5px 12px rgba(0,0,0,0.1);border:2px solid white}
.palette div:hover{transform:scale(1.1);box-shadow:0 8px 20px rgba(0,0,0,0.15)}

/* ===== СЛАЙДЕР ПОЖЕЛАНИЙ ===== */
.wish-container{display:flex;align-items:center;justify-content:center;gap:20px;max-width:700px;margin:0 auto}
.wish-card{flex:1;background:#e8e4dd;border-radius:32px;padding:50px 35px;text-align:center;box-shadow:0 15px 30px rgba(0,0,0,0.05);min-height:200px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,0.5)}
.wish-text{font-size:24px;line-height:1.5;color:#5a4a3a;font-family:'Cormorant Garamond',serif;font-weight:500;transition:opacity 0.4s ease-in-out}
.wish-text::before{content:'✨';display:inline-block;margin-right:8px;background:linear-gradient(135deg,#b8926c,#9a7a58);background-clip:text;-webkit-background-clip:text;color:transparent;animation:sparkle 2s ease-in-out infinite}
@keyframes sparkle{0%,100%{opacity:0.6;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}
.wish-arrow{background:var(--accent);border:none;width:48px;height:48px;border-radius:50%;font-size:20px;cursor:pointer;color:white;transition:all 0.3s;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,0.1)}
.wish-arrow:hover{background:var(--accent-dark);transform:scale(1.05)}
.wish-dots{display:flex;justify-content:center;gap:10px;margin-top:25px}
.wish-dot{width:8px;height:8px;border-radius:50%;background:#c0b8ae;cursor:pointer;transition:all 0.3s ease}
.wish-dot.active{background:var(--accent);width:28px;border-radius:12px}

/* ===== ПОГОДА ===== */
.weather-card{background:linear-gradient(135deg, #e8e4dd, #e0dbd3);border-radius:32px;padding:30px 25px;text-align:center;max-width:450px;margin:0 auto;box-shadow:0 15px 30px rgba(0,0,0,0.08);border:1px solid rgba(255,255,255,0.5);transition:all 0.3s}
.weather-card:hover{transform:translateY(-3px);box-shadow:0 20px 35px rgba(0,0,0,0.1)}
.weather-icon{font-size:52px;margin-bottom:15px;background:linear-gradient(135deg,#b8926c,#9a7a58);background-clip:text;-webkit-background-clip:text;color:transparent;display:inline-block}
.weather-temp{font-size:36px;font-weight:600;color:var(--accent);font-family:'Cormorant Garamond',serif}
.weather-desc{font-size:18px;color:#5a4a3a;margin:10px 0;font-weight:500}
.weather-details{font-size:14px;color:#7a6b5d;margin-top:8px;line-height:1.5}
.weather-note{font-size:11px;color:#9a8a7a;margin-top:15px;display:block;font-style:italic}

/* ===== СВЯЗЬ С ВЕДУЩИМ ===== */
.host-container {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 30px;
    flex-wrap: wrap;
    max-width: 1100px;
    margin: 0 auto;
    padding: 20px 0;
}
.host-photo {
    flex: 1;
    min-width: 180px;
    max-width: 260px;
    text-align: center;
    transition: all 0.3s ease;
}
.host-photo img {
    width: 100%;
    aspect-ratio: 3/4;
    object-fit: cover;
    border-radius: 30px;
    box-shadow: 0 20px 35px rgba(0, 0, 0, 0.15);
    transition: all 0.4s ease;
    border: 3px solid white;
}
.host-photo:hover img {
    transform: scale(1.03);
    box-shadow: 0 25px 45px rgba(0, 0, 0, 0.2);
}
.host-photo-caption {
    margin-top: 12px;
    font-size: 14px;
    font-weight: 500;
    color: #7a6b5d;
    letter-spacing: 1px;
}
.host-info {
    flex: 2;
    min-width: 280px;
    background: #e8e4dd;
    border-radius: 40px;
    padding: 35px 30px;
    text-align: center;
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.5);
    transition: all 0.3s ease;
}
.host-info:hover {
    transform: translateY(-5px);
    background: #ede9e2;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.12);
}
.host-badge {
    display: inline-block;
    background: var(--accent);
    color: white;
    padding: 6px 18px;
    border-radius: 40px;
    font-size: 12px;
    letter-spacing: 1.5px;
    margin-bottom: 20px;
    font-weight: 500;
}
.host-badge::before{content:'🎤';margin-right:6px;background:linear-gradient(135deg,#fff,#f5f2ef);background-clip:text;-webkit-background-clip:text;color:transparent}
.host-name {
    font-size: 32px;
    font-family: 'Cormorant Garamond', serif;
    color: #4a3729;
    margin-bottom: 15px;
}
.host-desc {
    font-size: 16px;
    line-height: 1.6;
    color: #6b5a4a;
    margin-bottom: 25px;
}
.host-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: #4a76a8;
    color: white;
    text-decoration: none;
    padding: 12px 32px;
    border-radius: 50px;
    font-weight: 500;
    transition: all 0.3s ease;
    font-size: 16px;
    margin-bottom: 20px;
}
.host-btn:hover {
    background: #3a5a80;
    transform: scale(1.03);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
}
.host-btn span{font-size:18px}
.host-quote {
    font-size: 18px;
    font-style: italic;
    font-family: 'Cormorant Garamond', serif;
    color: var(--accent);
    padding-top: 15px;
    border-top: 1px solid rgba(184, 146, 108, 0.3);
}
.host-quote::before,.host-quote::after{content:'"';font-size:24px;background:linear-gradient(135deg,#b8926c,#9a7a58);background-clip:text;-webkit-background-clip:text;color:transparent;font-family:'Cormorant Garamond',serif}

/* ===== АНКЕТА ===== */
.deadline-wrapper{text-align:center;margin-bottom:40px}
.deadline-text{display:inline-block;font-size:24px;font-family:'Cormorant Garamond',serif;color:#7a6b5d;letter-spacing:1px;padding:18px 35px;background:linear-gradient(135deg, #e8e4dd, #e0dbd3);border-radius:60px;box-shadow:0 8px 20px rgba(0,0,0,0.05);border:1px solid rgba(255,255,255,0.6);margin:0}
.deadline-text strong{color:var(--accent);font-weight:700;font-size:28px}

.existing-guest-info{margin-bottom:30px}
.existing-guest-card{background:#e8e4dd;border-radius:28px;padding:25px;text-align:center;border-left:4px solid var(--accent)}
.existing-guest-card h3{color:#4a3729;margin-bottom:10px}
.existing-guest-card p{color:#7a6b5d;margin-bottom:15px}
.edit-btn{background:var(--accent);color:white;border:none;padding:10px 24px;border-radius:40px;cursor:pointer;font-size:14px;transition:all .3s}
.edit-btn:hover{background:var(--accent-dark);transform:scale(1.02)}

form{display:flex;flex-direction:column;gap:24px;max-width:700px;margin:auto}
.input-group{display:flex;flex-direction:column;gap:8px}
label{font-weight:600;color:#7a6b5d;font-size:14px;letter-spacing:1.5px;text-transform:uppercase}
input,textarea,select{padding:16px 20px;border-radius:24px;border:1.5px solid #d4ccc4;font-family:'Montserrat',sans-serif;background:#f5f2ef;transition:all 0.3s ease;font-size:16px;color:#4a3729}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(184,146,108,0.15);background:#faf7f4;transform:translateY(-2px)}
input:hover,textarea:hover,select:hover{border-color:#c9b59b}
textarea{resize:vertical;min-height:80px}
.checkbox-group{display:flex;flex-wrap:wrap;gap:12px;background:#e8e4dd;padding:18px;border-radius:28px;border:1px solid rgba(255,255,255,0.5)}
.checkbox-group.two-columns{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.checkbox-group label{display:flex;align-items:center;gap:12px;font-weight:normal;cursor:pointer;padding:10px 18px;background:#f5f2ef;border-radius:40px;border:1px solid #d4ccc4;transition:all 0.2s;font-size:14px;text-transform:none;color:#5a4a3a}
.checkbox-group label:hover{background:#ede9e2;border-color:var(--accent);transform:translateY(-1px)}
.checkbox-group input[type="checkbox"]{width:18px;height:18px;margin:0;cursor:pointer;accent-color:var(--accent)}
select{appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23b8926c' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 20px center;background-size:16px}
.fade{opacity:0;transform:translateY(40px);transition:opacity 0.8s,transform 0.8s}
.fade.show{opacity:1;transform:none}
#formStatus{margin-top:15px;padding:12px;border-radius:24px;text-align:center}
button[type="submit"]{background:var(--accent);color:white;border:none;padding:16px 32px;border-radius:50px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s;margin-top:10px}
button[type="submit"]:hover{background:var(--accent-dark);transform:scale(1.02)}

@keyframes pulseGlow{0%{transform:scale(1);opacity:0.6}100%{transform:scale(1.5);opacity:0}}

@media(max-width:768px){
    h1{font-size:48px}
    h2{font-size:34px}
    .countdown .card{font-size:36px;min-width:80px;padding:15px 10px}
    .countdown .card span{font-size:10px}
    .deadline-timer .deadline-card .number{font-size:32px}
    .deadline-timer .deadline-card{min-width:80px;padding:12px 15px}
    .wish-card{padding:30px 20px;min-height:160px}
    .wish-text{font-size:18px}
    .wish-arrow{width:40px;height:40px;font-size:16px}
    .dresscode-text{font-size:16px}
    .weather-temp{font-size:28px}
    .weather-desc{font-size:15px}
    .weather-card{padding:20px}
    .deadline-text{font-size:18px;padding:12px 20px}
    .deadline-text strong{font-size:22px}
    input,textarea,select{padding:14px 16px;font-size:14px}
    section{padding:40px 20px;margin:30px 15px}
    .hero-subtitle{font-size:18px}
    .hero-inner{padding:30px 20px}
    label{font-size:11px}
    .host-container {
        flex-direction: column;
    }
    .host-photo {
        max-width: 220px;
    }
    .host-photo img {
        aspect-ratio: 3/4;
    }
    .host-name {
        font-size: 26px;
    }
    .host-desc {
        font-size: 14px;
    }
    .host-btn {
        padding: 10px 24px;
        font-size: 14px;
    }
}