@import "https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&family=Dancing+Script:wght@700&display=swap";@import "https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&family=Dancing+Script:wght@700&family=Pacifico&family=Quicksand:wght@500;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&family=Pacifico&display=swap";@import "https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400;1,600&family=Nunito:wght@400;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&family=Caveat:wght@500;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,600;1,400;1,600&family=Nunito:wght@400;600;700&display=swap";.modal-overlay{z-index:500;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#1a0a2e8c;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.auth-modal{background:var(--bg-card);border-radius:var(--radius-xl);width:100%;max-width:420px;padding:40px 36px;animation:.3s slideUp;position:relative;box-shadow:0 20px 60px #1a0a2e40}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.modal-close{background:var(--bg-subtle);width:32px;height:32px;color:var(--text-secondary);transition:all var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;display:flex;position:absolute;top:16px;right:16px}.modal-close:hover{background:var(--border-color);color:var(--primary)}.auth-header{text-align:center;margin-bottom:28px}.auth-logo{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;font-size:1.5rem;display:flex}.auth-header h2{margin-bottom:8px;font-size:1.6rem}.auth-header p{color:var(--text-muted);font-size:.9rem}.auth-options{flex-direction:column;gap:12px;display:flex}.auth-google-btn,.auth-email-btn{border-radius:var(--radius-md);transition:all var(--transition);cursor:pointer;font-size:.95rem;font-weight:700;font-family:var(--font-main);border:none;justify-content:center;align-items:center;gap:12px;padding:14px 20px;display:flex}.auth-google-btn{background:var(--bg-card);border:2px solid var(--border-color);color:var(--text-primary)}.auth-google-btn:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.auth-email-btn{background:var(--bg-subtle);color:var(--primary);border:2px solid var(--primary)}.auth-email-btn:hover{background:var(--primary);color:#fff}.auth-divider{color:var(--text-muted);align-items:center;gap:12px;font-size:.85rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border-color);flex:1;height:1px}.auth-email-form{flex-direction:column;gap:14px;display:flex}.email-hint{color:var(--text-muted);text-align:center;font-size:.875rem}.back-btn{color:var(--text-muted);text-align:center;font-size:.875rem;font-weight:600}.back-btn:hover{color:var(--primary)}.email-sent{text-align:center;padding:8px 0}.sent-icon{margin-bottom:12px;font-size:3rem}.email-sent h3{margin-bottom:8px;font-size:1.3rem}.email-sent p{color:var(--text-muted);margin-bottom:20px;font-size:.9rem}.auth-terms{text-align:center;color:var(--text-muted);margin-top:20px;font-size:.78rem}.auth-terms a{color:var(--primary);font-weight:600}@media (width<=480px){.modal-overlay{align-items:flex-end;padding:0}.auth-modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-width:100%;max-height:95vh;padding:28px 20px 36px;overflow-y:auto}.auth-header h2{font-size:1.4rem}}.navbar{z-index:100;height:var(--navbar-h);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1.5px solid var(--border-color);background:#fff8fbd9;position:sticky;top:0}.navbar-inner{justify-content:space-between;align-items:center;gap:20px;height:100%;display:flex}.navbar-logo{color:var(--text-primary);white-space:nowrap;align-items:center;gap:8px;font-size:1.1rem;font-weight:900;display:flex}.logo-icon{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;display:flex}.logo-text span{color:var(--primary)}.navbar-links{gap:8px;display:flex}.nav-link{border-radius:var(--radius-full);color:var(--text-secondary);transition:all var(--transition);padding:8px 16px;font-size:.9rem;font-weight:600}.nav-link:hover{background:var(--bg-subtle);color:var(--primary)}.navbar-actions{align-items:center;gap:12px;display:flex}.user-menu{cursor:pointer;position:relative}.user-avatar{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border:2px solid var(--primary-light);border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:1rem;font-weight:800;display:flex;overflow:hidden}.user-avatar img{object-fit:cover;width:100%;height:100%}.auth-skeleton{background:linear-gradient(90deg, var(--border-color) 25%, #ffffff14 50%, var(--border-color) 75%);cursor:default;background-size:200% 100%;animation:1.4s infinite skeleton-shimmer}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.user-dropdown{background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:200;min-width:200px;padding:12px;animation:.2s fadeSlideIn;position:absolute;top:calc(100% + 10px);right:0}.dropdown-name{padding:4px 8px;font-size:.95rem;font-weight:800}.dropdown-email{color:var(--text-muted);padding:0 8px 8px;font-size:.8rem}.dropdown-divider{background:var(--border-color);height:1px;margin:8px 0}.user-dropdown button{border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:all var(--transition);align-items:center;gap:10px;padding:10px 12px;font-size:.9rem;font-weight:600;display:flex}.user-dropdown button:hover{background:var(--bg-subtle)}.logout-btn{color:var(--primary)!important}.admin-panel-btn{color:#7c3aed!important;border-radius:var(--radius-md)!important;background:#7c3aed0f!important;border:1px solid #7c3aed2e!important;font-weight:700!important}.admin-panel-btn:hover{background:#7c3aed1f!important}.mobile-admin-link{color:#7c3aed!important;background:#7c3aed0f!important;border:1px solid #7c3aed2e!important;font-weight:700!important}.hamburger{color:var(--text-primary);padding:6px;font-size:1.4rem;display:none}.mobile-menu{border-top:1.5px solid var(--border-color);background:var(--bg-card,#fff);flex-direction:column;gap:4px;padding:12px 16px 16px;display:flex;box-shadow:0 8px 24px #0000001a}.mobile-menu a,.mobile-menu button{border-radius:var(--radius-md);color:var(--text-secondary);text-align:left;align-items:center;gap:10px;width:100%;padding:12px 16px;font-size:.95rem;font-weight:600;display:flex}.mobile-menu a:hover,.mobile-menu button:hover{background:var(--bg-subtle);color:var(--primary)}@media (width<=640px){.navbar-links{display:none}.hamburger{display:block}.navbar{background:var(--bg-card,#fff);-webkit-backdrop-filter:none;backdrop-filter:none}}.footer{background:var(--text-primary);color:#ffffffb3;margin-top:auto;padding:40px 0}.footer-inner{text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.footer-brand{color:#fff;align-items:center;gap:8px;font-weight:800;display:flex}.footer-logo-icon{color:var(--primary)}.footer-tagline{font-size:.875rem}.footer-links{flex-wrap:wrap;justify-content:center;gap:20px;display:flex}.footer-links a{color:#fff9;transition:color var(--transition);font-size:.85rem}.footer-links a:hover{color:var(--primary)}.footer-copy{color:#fff6;font-size:.78rem}@media (width<=480px){.footer{padding:32px 0}.footer-links{gap:14px}.footer-links a{font-size:.8rem}}.template-card{background:var(--bg-card);border-radius:var(--radius-lg);border:2px solid var(--border-color);aspect-ratio:1;flex-direction:column;transition:all .25s;display:flex;overflow:hidden}.template-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-light);transform:translateY(-4px)}.card-thumb{background:linear-gradient(135deg,#fde1ef,#f3d8ff);flex:0 0 55%;position:relative;overflow:hidden}.card-thumb img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.template-card:hover .card-thumb img{transform:scale(1.05)}.thumb-placeholder{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.thumb-placeholder span{color:#ff1b6b33;font-size:2.8rem;font-weight:900;font-family:var(--font-fun)}.price-badge{border-radius:var(--radius-full);letter-spacing:.4px;align-items:center;gap:2px;padding:3px 8px;font-size:.7rem;font-weight:800;display:flex;position:absolute;top:8px;right:8px}.badge-paid{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;box-shadow:0 2px 8px #ff1b6b66}.card-category{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-full);color:var(--secondary);letter-spacing:.5px;text-transform:uppercase;background:#ffffffe0;padding:3px 8px;font-size:.64rem;font-weight:700;position:absolute;bottom:6px;left:8px}.card-body{flex-direction:column;flex:1;gap:4px;min-height:0;padding:10px 12px;display:flex;overflow:hidden}.card-name{text-transform:uppercase;letter-spacing:.3px;color:var(--text-primary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.8rem;font-weight:800;line-height:1.2;display:-webkit-box;overflow:hidden}.card-desc{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;min-height:0;font-size:.72rem;line-height:1.4;display:-webkit-box;overflow:hidden}.card-actions{grid-template-columns:1fr 1fr;gap:6px;margin-top:auto;padding-top:6px;display:grid}.card-actions .btn{width:100%;min-height:unset;justify-content:center;gap:4px;padding:6px 8px;font-size:.72rem}@media (width<=640px){.card-body{gap:3px;padding:8px 10px}.card-name{font-size:.72rem}.card-desc{-webkit-line-clamp:2;font-size:.66rem}.card-actions{gap:5px;padding-top:5px}.card-actions .btn{gap:3px;padding:5px 4px;font-size:.66rem}.thumb-placeholder span{font-size:2rem}.price-badge{padding:3px 6px;font-size:.62rem}.card-category{padding:2px 6px;font-size:.56rem}}.home-page{overflow-x:hidden}.hero{min-height:calc(100vh - var(--navbar-h));grid-template-columns:1fr 1fr;align-items:center;gap:40px;max-width:1200px;margin:0 auto;padding:80px 20px;display:grid;position:relative;overflow:hidden}.hero-bg-blobs{pointer-events:none;z-index:0;position:absolute;inset:0}.blob{filter:blur(80px);opacity:.45;border-radius:50%;position:absolute}.blob-1{background:radial-gradient(circle,#ff6b9d,#0000);width:500px;height:500px;top:-100px;left:-100px}.blob-2{background:radial-gradient(circle,#b86ef7,#0000);width:400px;height:400px;bottom:-80px;right:-80px}.blob-3{background:radial-gradient(circle,gold,#0000);width:300px;height:300px;top:40%;left:40%}.hero-content{z-index:1;position:relative}.hero-badge{background:var(--bg-subtle);border:2px solid var(--primary-light);border-radius:var(--radius-full);color:var(--primary);align-items:center;gap:8px;margin-bottom:24px;padding:8px 18px;font-size:.85rem;font-weight:700;display:inline-flex}.badge-icon{color:var(--primary);animation:2s infinite pulse-glow}.hero-title{color:var(--text-primary);margin-bottom:20px;font-size:clamp(2.2rem,5vw,3.8rem);line-height:1.1}.hero-subtitle{color:var(--text-secondary);max-width:500px;margin-bottom:32px;font-size:1.1rem;line-height:1.7}.hero-cta{flex-wrap:wrap;gap:12px;margin-bottom:40px;display:flex}.hero-stats{flex-wrap:wrap;align-items:center;gap:20px;display:flex}.stat{flex-direction:column;gap:2px;display:flex}.stat strong{color:var(--primary);font-size:1.3rem;font-weight:900}.stat span{color:var(--text-muted);font-size:.78rem;font-weight:600}.stat-div{background:var(--border-color);width:1px;height:32px}.hero-preview-wrap{z-index:1;justify-content:center;display:flex;position:relative}.hero-preview-card{background:#fff;border:2px solid #fde1ef;border-radius:24px;width:300px;transition:transform .4s;overflow:hidden;transform:rotate(3deg);box-shadow:0 20px 60px #ff1b6b33,0 4px 20px #00000014}.hero-preview-card:hover{transform:rotate(0)scale(1.02)}.preview-header{border-bottom:1px solid #fde1ef;gap:6px;padding:14px 16px 10px;display:flex}.preview-dot{background:#e5e7eb;border-radius:50%;width:10px;height:10px}.preview-dot.pink{background:var(--primary)}.preview-content{background:linear-gradient(135deg,#fff8fb,#fde1ef);min-height:200px;padding:28px 24px}.preview-tag{color:var(--text-muted);margin-bottom:8px;font-size:.78rem}.preview-title{color:var(--text-primary);margin-bottom:12px;font-size:1.5rem;font-weight:900;line-height:1.2}.preview-title em{color:var(--primary);font-family:var(--font-cursive);font-style:normal}.preview-text{color:var(--text-secondary);margin-bottom:20px;font-size:.85rem}.preview-btn{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-radius:var(--radius-full);padding:8px 16px;font-size:.8rem;font-weight:700;display:inline-block}.how-section{background:var(--bg-subtle)}.section-label{background:linear-gradient(135deg, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;letter-spacing:1.5px;text-transform:uppercase;-webkit-background-clip:text;margin-bottom:8px;font-size:.85rem;font-weight:800;display:inline-block}.how-section h2{margin-bottom:40px}.steps-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.step-card{text-align:center;padding:32px 28px}.step-num{color:var(--primary);letter-spacing:2px;text-transform:uppercase;margin-bottom:12px;font-size:.75rem;font-weight:900}.step-icon{margin-bottom:14px;font-size:2.5rem;display:block}.step-card h3{margin-bottom:8px;font-size:1.1rem}.step-card p{font-size:.875rem}.cta-section{padding:80px 0}.cta-card{background:linear-gradient(135deg, var(--primary), var(--secondary));border-radius:var(--radius-xl);text-align:center;padding:60px 40px;position:relative;overflow:hidden}.cta-card:before{content:"";background: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.05'%3E%3Ccircle cx='30' cy='30' r='4'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");position:absolute;inset:0}.cta-deco{z-index:1;margin-bottom:16px;font-size:3rem;display:block;position:relative}.cta-card h2,.cta-card p{color:#fff;z-index:1;position:relative}.cta-card p{opacity:.85;margin:12px 0 28px;font-size:1rem}.cta-card .btn{z-index:1;color:var(--primary);background:#fff;position:relative}.cta-card .btn:hover{background:#ffffffe6}@media (width<=900px){.hero{text-align:center;grid-template-columns:1fr;min-height:auto;padding:48px 20px}.hero-preview-wrap{display:none}.hero-cta,.hero-stats{justify-content:center}.steps-grid,.templates-grid{grid-template-columns:repeat(2,1fr)}.cta-card{padding:48px 28px}}@media (width<=640px){.hero{gap:24px;padding:36px 16px}.hero-title{font-size:clamp(1.8rem,8vw,2.6rem)}.hero-subtitle{font-size:.95rem}.hero-cta{flex-direction:column;align-items:center}.hero-cta .btn{justify-content:center;width:100%;max-width:280px}.hero-stats{gap:14px}.steps-grid{grid-template-columns:1fr;gap:16px}.templates-grid{grid-template-columns:1fr}.cta-card{border-radius:var(--radius-lg);padding:36px 20px}.cta-card h2{font-size:1.6rem}.section-label{font-size:.78rem}}.templates-page{min-height:100vh;padding-bottom:80px}.tpl-header{text-align:center;border-bottom:1.5px solid var(--border-color);background:linear-gradient(160deg,#fff8fb 0%,#ede9ff 60%,#ffd6ec 100%);padding:44px 0 32px}.tpl-eyebrow{letter-spacing:1.2px;text-transform:uppercase;color:var(--primary);margin-bottom:8px;font-size:.8rem;font-weight:800}.tpl-title{color:var(--text-primary);margin-bottom:22px;font-size:clamp(1.5rem,5vw,2.4rem);font-weight:900;line-height:1.2}.tpl-search-wrap{max-width:440px;margin:0 auto 18px;position:relative}.tpl-search-icon{color:var(--text-muted);pointer-events:none;font-size:1rem;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.tpl-search-input{border:2px solid var(--border-color);border-radius:var(--radius-full);width:100%;font-size:.93rem;font-family:var(--font-main);color:var(--text-primary);background:#fff;padding:13px 48px 13px 46px;transition:border-color .2s,box-shadow .2s;box-shadow:0 2px 16px #0000000f}.tpl-search-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #ff1b6b1a}.tpl-search-input::placeholder{color:var(--text-muted)}.tpl-search-clear{color:var(--text-muted);border-radius:50%;align-items:center;padding:4px;font-size:1rem;transition:all .18s;display:flex;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.tpl-search-clear:hover{color:var(--primary);background:var(--bg-subtle)}.tpl-tabs{border:1.5px solid var(--border-color);border-radius:var(--radius-full);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffbf;gap:3px;padding:4px;display:inline-flex;box-shadow:0 2px 12px #0000000f}.tpl-tab{border-radius:var(--radius-full);color:var(--text-muted);white-space:nowrap;letter-spacing:.2px;padding:8px 20px;font-size:.85rem;font-weight:700;transition:all .2s}.tpl-tab.active{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;box-shadow:0 3px 12px #ff1b6b59}.tpl-tab:not(.active):hover{background:var(--bg-subtle);color:var(--text-primary)}.tpl-result-count{color:var(--text-muted);padding:14px 0 6px;font-size:.82rem;font-weight:600}.cat-section{padding:32px 0 20px}.cat-section-title{color:var(--text-primary);margin-bottom:18px;font-size:1.1rem;font-weight:800}.cat-cards-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.cat-card{aspect-ratio:1;cursor:pointer;background:var(--cat-grad,linear-gradient(135deg, #ff6b9d, #9333ea));font-family:var(--font-main);text-align:center;border:none;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:0;transition:transform .22s,box-shadow .22s;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #0000001f}.cat-card:before{content:"";border-radius:inherit;opacity:0;background:#ffffff14;transition:opacity .2s;position:absolute;inset:0}.cat-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #0003}.cat-card:hover:before{opacity:1}.cat-card:active{transform:translateY(-2px)}.cat-card-all{background:linear-gradient(135deg,#1a0a2e,#3d1460);border:2px solid #ff1b6b4d}.cat-card-emoji{filter:drop-shadow(0 2px 4px #0003);font-size:clamp(1.6rem,4vw,2.2rem);line-height:1}.cat-card-name{color:#fff;letter-spacing:.3px;text-shadow:0 1px 4px #0000004d;padding:0 8px;font-size:clamp(.7rem,1.8vw,.88rem);font-weight:800;line-height:1.2}.cat-card-count{color:#ffffffbf;font-size:clamp(.6rem,1.4vw,.72rem);font-weight:600}.grid-topbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:20px 0 12px;display:flex}.grid-back-btn{color:var(--text-secondary);border-radius:var(--radius-full);border:1.5px solid var(--border-color);background:var(--bg-card);align-items:center;gap:6px;padding:7px 14px;font-size:.85rem;font-weight:700;transition:all .18s;display:inline-flex}.grid-back-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--bg-subtle)}.grid-meta{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.grid-cat-badge{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;align-items:center;gap:6px;padding:5px 10px 5px 12px;font-size:.78rem;font-weight:700;display:inline-flex}.grid-cat-badge button{color:#fffc;border-radius:50%;align-items:center;padding:2px;transition:all .15s;display:flex}.grid-cat-badge button:hover{color:#fff;background:#fff3}.grid-count{color:var(--text-muted);font-size:.8rem;font-weight:600}.templates-grid-wrap{padding-top:8px}.templates-grid{grid-template-columns:repeat(3,1fr);gap:18px;display:grid}.templates-loading,.templates-empty{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:80px 20px;display:flex}.templates-empty span{font-size:3rem}.templates-empty h3{color:var(--text-primary)}@media (width<=900px){.cat-cards-grid{grid-template-columns:repeat(3,1fr);gap:14px}.templates-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.tpl-header{padding:28px 0 22px}.tpl-title{margin-bottom:14px;font-size:clamp(1.3rem,6vw,1.8rem)}.tpl-search-wrap{max-width:100%;margin-bottom:14px}.tpl-tabs{border-radius:var(--radius-lg);width:100%}.tpl-tab{text-align:center;flex:1;padding:9px 4px;font-size:.72rem}.cat-section{padding:20px 0 14px}.cat-section-hint{margin-bottom:12px;font-size:.8rem}.cat-cards-grid{grid-template-columns:repeat(2,1fr);gap:12px}.cat-card{border-radius:16px;gap:6px}.cat-card-emoji{font-size:1.8rem}.cat-card-name{font-size:.72rem}.cat-card-count{font-size:.62rem}.templates-grid{grid-template-columns:repeat(2,1fr);gap:12px}.grid-topbar{flex-wrap:wrap;gap:8px;padding:14px 0 10px}.grid-back-btn{padding:6px 12px;font-size:.78rem}.grid-count{font-size:.76rem}}@media (width<=380px){.cat-cards-grid,.templates-grid{grid-template-columns:repeat(2,1fr);gap:10px}.tpl-tab{font-size:.66rem}}.editor-page{height:calc(100vh - var(--navbar-h));background:var(--bg-page);flex-direction:column;display:flex;overflow:hidden}.editor-loader{height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.editor-topbar{background:var(--bg-card);border-bottom:1.5px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;min-height:56px;padding:10px 16px;display:flex}.ed-back-btn{border:1.5px solid var(--border-color);width:36px;height:36px;color:var(--text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .18s;display:flex}.ed-back-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--bg-subtle)}.editor-template-name{color:var(--primary);text-align:center;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.95rem;font-weight:800;overflow:hidden}.editor-actions{flex-shrink:0;gap:8px;display:flex}.editor-actions .btn{align-items:center;gap:6px;display:flex}.ed-tabs-bar{scrollbar-width:none;-webkit-overflow-scrolling:touch;background:var(--bg-card);border-bottom:1.5px solid var(--border-color);flex-shrink:0;gap:4px;padding:0 12px;display:flex;overflow-x:auto}.ed-tabs-bar::-webkit-scrollbar{display:none}.ed-tab{white-space:nowrap;color:var(--text-muted);border-bottom:3px solid #0000;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;padding:10px 14px;transition:all .18s;display:flex}.ed-tab:hover{color:var(--primary)}.ed-tab.active{border-bottom-color:var(--primary);color:var(--primary)}.ed-tab-icon{font-size:1.1rem;line-height:1}.ed-tab-label{text-transform:uppercase;letter-spacing:.6px;font-size:.68rem;font-weight:700}.editor-fields{-webkit-overflow-scrolling:touch;flex:1;padding:20px 20px 16px;overflow-y:auto}.ed-section-header{background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius-lg);align-items:center;gap:14px;margin-bottom:22px;padding:14px 16px;display:flex}.ed-section-icon{background:linear-gradient(135deg,#ff1b6b1a,#9b5de51a);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.8rem;display:flex}.ed-section-num{color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:2px;font-size:.72rem;font-weight:700}.ed-section-title{color:var(--primary);letter-spacing:.3px;font-size:.95rem;font-weight:900}.fields-list{flex-direction:column;gap:20px;max-width:600px;display:flex}.field-group{flex-direction:column;gap:8px;display:flex}.field-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);justify-content:space-between;align-items:center;font-size:.8rem;font-weight:700;display:flex}.required{color:var(--primary);margin-left:2px}.char-count{color:var(--text-muted);font-size:.72rem;font-weight:500}.field-hint{color:var(--text-muted);margin-top:2px;font-size:.78rem}.input-field{border:1.5px solid var(--border-color);border-radius:var(--radius-md);width:100%;font-size:.9rem;font-family:var(--font-main);background:var(--bg-card);color:var(--text-primary);resize:vertical;padding:12px 14px;transition:border-color .18s,box-shadow .18s}.input-field:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #ff1b6b1a}.media-upload-wrap{flex-direction:column;gap:10px;display:flex}.upload-btn{border:2px dashed var(--border-color);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;transition:all var(--transition);justify-content:center;align-items:center;gap:8px;padding:14px;font-size:.9rem;font-weight:700;display:flex}.upload-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--bg-subtle)}.upload-hint{color:var(--text-muted);font-size:.75rem}.upload-preview{border-radius:var(--radius-md);max-width:200px;position:relative;overflow:hidden}.upload-preview img{border-radius:var(--radius-md);width:100%;height:auto}.remove-media{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;display:flex;position:absolute;top:6px;right:6px}.color-wrap{align-items:center;gap:10px;display:flex}.color-wrap input{border:2px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;width:48px;height:36px;padding:2px}.color-hex{color:var(--text-muted);font-size:.85rem;font-weight:600}.ed-footer{background:var(--bg-card);border-top:1.5px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.ed-nav-btn{border-radius:var(--radius-full);letter-spacing:.5px;border:1.5px solid var(--border-color);color:var(--text-secondary);background:var(--bg-card);justify-content:center;align-items:center;gap:6px;min-width:88px;padding:10px 20px;font-size:.82rem;font-weight:800;transition:all .18s;display:flex}.ed-nav-btn:not(.disabled):hover{border-color:var(--primary);color:var(--primary);background:var(--bg-subtle)}.ed-next:not(.disabled){background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-color:#0000;box-shadow:0 3px 12px #ff1b6b59}.ed-next:not(.disabled):hover{opacity:.9}.ed-nav-btn.disabled{opacity:.35;cursor:not-allowed}.ed-page-dots{flex:1;justify-content:center;align-items:center;gap:6px;display:flex}.ed-dot{background:var(--border-color);border-radius:50%;flex-shrink:0;width:7px;height:7px;transition:all .2s}.ed-dot.active{background:var(--primary);border-radius:4px;width:18px}.ed-page-label{color:var(--text-muted);white-space:nowrap;margin-left:8px;font-size:.78rem;font-weight:700}@media (width<=640px){.editor-topbar{min-height:50px;padding:8px 12px}.editor-template-name{font-size:.85rem}.editor-actions .btn{gap:4px;padding:7px 10px;font-size:.78rem}.editor-actions .btn span{display:none}.editor-fields{padding:14px 14px 12px}.ed-section-header{gap:10px;margin-bottom:16px;padding:12px}.ed-section-icon{width:40px;height:40px;font-size:1.4rem}.ed-section-title{font-size:.85rem}.fields-list{gap:16px;max-width:100%}.input-field{padding:10px 12px;font-size:.85rem}.ed-footer{padding:10px 12px}.ed-nav-btn{min-width:76px;padding:9px 16px;font-size:.78rem}}@media (width<=380px){.ed-dot{width:6px;height:6px}.ed-dot.active{width:14px}.ed-page-label{font-size:.72rem}.ed-nav-btn{min-width:64px;padding:8px 12px;font-size:.72rem}}.publish-page{padding:60px 0}.publish-container{max-width:600px}.pub-title{color:var(--text-primary);margin-bottom:32px;font-size:clamp(1.4rem,3vw,2rem)}.pub-title em{color:var(--primary);font-style:normal}.pub-card{flex-direction:column;gap:16px;padding:32px;display:flex}.pub-section-title{letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);font-size:.75rem;font-weight:900}.link-opt{border-radius:var(--radius-md);border:2px solid var(--border-color);cursor:pointer;transition:all var(--transition);align-items:flex-start;gap:14px;padding:16px;display:flex}.link-opt.sel{border-color:var(--primary);background:#fff8fb}.link-opt input{accent-color:var(--primary);margin-top:3px}.link-opt-head{align-items:center;gap:8px;margin-bottom:4px;font-size:.9rem;font-weight:700;display:flex}.link-example{color:var(--text-muted);font-size:.8rem}.subdomain-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.sub-input{flex:1;min-width:120px}.sub-suffix{color:var(--text-secondary);white-space:nowrap;font-size:.875rem;font-weight:700}.slug-msg{font-size:.8rem;font-weight:700}.slug-msg.ok{color:#16a34a}.slug-msg.err{color:var(--primary)}.price-box{border:1.5px solid var(--border-color);border-radius:var(--radius-md);flex-direction:column;gap:10px;padding:16px;display:flex}.price-row{color:var(--text-secondary);justify-content:space-between;font-size:.9rem;display:flex}.total-row{border-top:1.5px solid var(--border-color);padding-top:10px;font-weight:700}.total-val{color:var(--primary);font-size:1.2rem;font-weight:900}.secured{color:var(--text-muted);align-items:center;gap:5px;font-size:.75rem;display:flex}.pub-cta{width:100%;padding:16px;font-size:1rem}.go-back{text-align:center;color:var(--text-muted);font-size:.875rem;font-weight:600}.go-back:hover{color:var(--primary)}.pub-support{text-align:center;color:var(--text-muted);margin-top:20px;font-size:.8rem}.pub-support a{color:var(--primary);font-weight:600}.publish-loader{justify-content:center;padding:80px;display:flex}@media (width<=640px){.publish-page{padding:36px 0 60px}.publish-container{max-width:100%}.pub-card{gap:14px;padding:20px 16px}.pub-title{text-align:center;font-size:1.2rem}.link-opt{padding:12px}.link-opt-head{font-size:.85rem}.link-example{font-size:.75rem}.subdomain-row{flex-wrap:wrap;gap:8px}.sub-suffix{font-size:.8rem}.coupon-row{flex-direction:column}.coupon-btn{width:100%}.price-box{padding:12px}.price-row{font-size:.85rem}.total-val{font-size:1.05rem}.pub-cta{padding:14px;font-size:.95rem}}.coupon-section{background:var(--surface-raised,#fafafa);border:1.5px dashed var(--border-color);border-radius:var(--radius-md);flex-direction:column;gap:12px;padding:16px;display:flex}.coupon-row{align-items:center;gap:10px;display:flex}.coupon-input-wrap{flex:1;align-items:center;display:flex;position:relative}.coupon-icon{color:var(--text-muted);font-size:.9rem;position:absolute;left:12px}.coupon-input{text-transform:uppercase;letter-spacing:.08em;width:100%;font-size:.9rem;font-weight:700;padding-left:36px!important}.coupon-btn{white-space:nowrap;padding:10px 18px;font-size:.875rem}.coupon-applied{border-radius:var(--radius-sm);background:#16a34a0f;border:1.5px solid #16a34a4d;justify-content:space-between;align-items:center;gap:10px;padding:10px 14px;display:flex}.coupon-applied-left{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.coupon-tag{color:#fff;letter-spacing:.08em;background:#16a34a;border-radius:20px;padding:3px 10px;font-family:monospace;font-size:.875rem;font-weight:800}.coupon-desc{color:#16a34a;font-size:.82rem;font-weight:600}.coupon-remove{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:.78rem;transition:all .15s}.coupon-remove:hover{color:#ef4444;background:#ef44441a}.coupon-error{color:#ef4444;margin:0;font-size:.8rem;font-weight:600}.discount-row{color:#16a34a!important}.discount-val{font-weight:700;color:#16a34a!important}.original-price{color:var(--text-muted);margin-right:6px;font-size:1rem;font-weight:400;text-decoration:line-through}.dashboard-page{padding:48px 0 80px}.dash-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:32px;display:flex}.dash-header h1{margin-bottom:4px}.dash-header p{color:var(--text-muted)}.dash-tabs{border-bottom:2px solid var(--border-color);gap:4px;margin-bottom:28px;padding-bottom:4px;display:flex}.dash-tab{border-radius:var(--radius-full) var(--radius-full) 0 0;color:var(--text-muted);transition:all var(--transition);padding:10px 20px;font-size:.9rem;font-weight:700}.dash-tab.active{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff}.dash-loading{justify-content:center;padding:60px;display:flex}.dash-empty{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:80px 20px;display:flex}.dash-empty span{font-size:3rem}.dash-empty h3{color:var(--text-primary)}.sites-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.site-card{flex-direction:column;display:flex;overflow:hidden}.site-card-thumb{justify-content:center;align-items:center;height:100px;display:flex;position:relative}.site-thumb-initial{color:#ffffffb3;font-size:2.5rem;font-weight:900;font-family:var(--font-fun)}.site-status-dot{background:#ccc;border-radius:50%;width:10px;height:10px;position:absolute;top:10px;right:10px}.site-status-dot.live{background:#22c55e;box-shadow:0 0 0 3px #22c55e40}.site-card-body{flex-direction:column;gap:6px;padding:16px;display:flex}.site-card-body h3{font-size:1rem;font-weight:800}.site-card-body>p{color:var(--text-muted);font-size:.8rem}.site-meta{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.status-badge{border-radius:var(--radius-full);background:var(--bg-subtle);padding:3px 10px;font-size:.75rem;font-weight:700}.status-badge.live{color:#16a34a;background:#dcfce7}.pub-date{color:var(--text-muted);align-items:center;gap:4px;font-size:.75rem;display:flex}.site-actions{gap:6px;margin-top:4px;display:flex}.icon-btn{border-radius:var(--radius-sm);background:var(--bg-subtle);width:32px;height:32px;color:var(--text-secondary);transition:all var(--transition);justify-content:center;align-items:center;font-size:.9rem;display:flex}.icon-btn:hover{background:var(--bg-subtle);color:var(--primary)}.icon-btn.danger:hover{color:#ef4444;background:#fee2e2}.payments-table{overflow-x:auto}.payments-table table{border-collapse:collapse;background:var(--bg-card);border-radius:var(--radius-lg);border:1.5px solid var(--border-color);width:100%;overflow:hidden}.payments-table th{background:var(--bg-subtle);text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:14px 16px;font-size:.78rem;font-weight:800}.payments-table td{border-top:1px solid var(--border-color);vertical-align:middle;padding:14px 16px;font-size:.875rem}.payments-table td code{background:var(--bg-subtle);border-radius:4px;padding:2px 6px;font-size:.75rem}.pay-status{border-radius:var(--radius-full);padding:3px 10px;font-size:.75rem;font-weight:700;display:inline-flex}.pay-status.success{color:#16a34a;background:#dcfce7}.pay-status.pending{color:#ca8a04;background:#fef9c3}.pay-status.failed{color:#ef4444;background:#fee2e2}@media (width<=900px){.sites-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.dashboard-page{padding:28px 0 60px}.sites-grid{grid-template-columns:1fr}.dash-header{flex-direction:column;align-items:flex-start;gap:12px}.dash-header .btn{justify-content:center;width:100%}.dash-tabs{scrollbar-width:none;flex-wrap:nowrap;padding-bottom:0;overflow-x:auto}.dash-tabs::-webkit-scrollbar{display:none}.dash-tab{white-space:nowrap;padding:8px 14px;font-size:.82rem}.payments-table th:nth-child(3),.payments-table td:nth-child(3){display:none}}@media (width<=480px){.payments-table th:nth-child(4),.payments-table td:nth-child(4){display:none}}.ss-page{background:linear-gradient(160deg,#fff0f8 0%,#fce7ff 50%,#fff0f8 100%);min-height:100vh;font-family:Nunito,sans-serif;position:relative;overflow-x:hidden}.ss-deco{pointer-events:none;z-index:0;animation:4s ease-in-out infinite alternate ssFloat;position:fixed}@keyframes ssFloat{0%{transform:translateY(0)rotate(-8deg)}to{transform:translateY(-18px)rotate(8deg)}}.ss-hero{text-align:center;z-index:1;padding:80px 24px 60px;position:relative}.ss-pretitle{color:#b882d4;letter-spacing:1px;margin-bottom:12px;font-size:.9rem;font-weight:700}.ss-title{margin-bottom:24px}.ss-title-1{color:#1a0a2e;font-size:clamp(2.5rem,7vw,5rem);font-weight:900;line-height:1;display:block}.ss-title-2{background:linear-gradient(135deg,#ff1b6b,#9333ea);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-family:Dancing Script,cursive;font-size:clamp(2rem,6vw,4rem);font-weight:900;display:block}.ss-hero-img-wrap{border:4px solid #fff;border-radius:50%;max-width:280px;margin:24px auto;overflow:hidden;box-shadow:0 8px 32px #ff1b6b40}.ss-hero-img{width:100%;height:auto}.ss-subtitle{color:#7c4d9e;margin-top:16px;font-size:1.05rem}.ss-message{z-index:1;justify-content:center;padding:0 24px 60px;display:flex;position:relative}.ss-message-card{text-align:center;background:#fff;border:2px solid #fde1ef;border-radius:28px;width:100%;max-width:560px;padding:40px 36px;box-shadow:0 8px 32px #ff1b6b1f}.ss-message-icon{margin-bottom:16px;font-size:2.5rem}.ss-msg-title{color:#1a0a2e;margin-bottom:16px;font-size:1.4rem;font-weight:800}.ss-msg-body{color:#5c3d7a;white-space:pre-wrap;font-size:1rem;line-height:1.8}.ss-ending{text-align:center;z-index:1;padding:0 24px 60px;position:relative}.ss-ending-img-wrap{border-radius:20px;max-width:200px;margin:0 auto 20px;overflow:hidden}.ss-ending-img{width:100%}.ss-signoff{color:#7c4d9e;margin-bottom:6px;font-size:1rem}.ss-sender{color:#ff1b6b;font-family:Dancing Script,cursive;font-size:1.6rem;font-weight:900}.ss-footer{text-align:center;background:#fff9;border-top:1px solid #fde1ef;padding:24px}.ss-footer p{color:#b882d4;font-size:.8rem}.ss-footer a{color:#ff1b6b;font-weight:700}.fy-page{background:var(--fy-bg,#fff0f5);min-height:100vh;position:relative;overflow-x:hidden}.fy-deco{pointer-events:none;z-index:0;animation:5s ease-in-out infinite alternate fyFloat;position:fixed}@keyframes fyFloat{0%{transform:translateY(0)rotate(-6deg)scale(1)}to{transform:translateY(-20px)rotate(6deg)scale(1.05)}}.fy-hero{text-align:center;z-index:1;padding:80px 24px 48px;position:relative}.fy-pretitle{color:#9c6fa8;letter-spacing:1px;margin-bottom:10px;font-size:.85rem;font-weight:700}.fy-title{margin-bottom:28px}.fy-t1{font-family:Dancing Script,cursive;font-size:clamp(2.5rem,8vw,5.5rem);font-weight:900;line-height:1;animation:3s ease-in-out infinite shimmer;display:block}@keyframes shimmer{0%,to{opacity:1}50%{opacity:.7;text-shadow:0 0 20px #ff1b6b80}}.fy-t2{color:#1a0a2e;font-size:clamp(1.8rem,5vw,3.5rem);font-weight:900;display:block}.fy-hero-img{border-radius:24px;max-width:240px;margin:0 auto;overflow:hidden;box-shadow:0 8px 32px #0000001f}.fy-hero-img img{width:100%}.fy-section{z-index:1;max-width:800px;margin:0 auto;padding:60px 24px;position:relative}.fy-sec-title{text-align:center;color:#1a0a2e;margin-bottom:28px;font-size:1.4rem;font-weight:800}.fy-meter-sec{text-align:center}.fy-meter-bar-wrap{align-items:center;gap:12px;max-width:480px;margin:0 auto 12px;display:flex}.fy-meter-bar{background:#fde1ef;border-radius:9px;flex:1;height:18px;overflow:hidden}.fy-meter-fill{height:100%;width:var(--fy-meter-w,99%);background:linear-gradient(90deg, var(--fy-accent,#ff1b6b), #9333ea);border-radius:9px;transition:width 1s;animation:1.5s ease-out meterGrow}@keyframes meterGrow{0%{width:0}}.fy-meter-pct{color:var(--fy-accent,#ff1b6b);min-width:48px;font-size:1.1rem;font-weight:900}.fy-meter-label{color:#7c4d9e;font-size:.95rem}.fy-stickies{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.fy-sticky{color:#3d2052;border-radius:4px 16px 16px 4px;padding:20px;font-size:.9rem;line-height:1.6;position:relative;transform:rotate(-1deg);box-shadow:4px 4px 12px #00000014}.fy-sticky:nth-child(2n){transform:rotate(1deg)}.fy-sticky-0{background:#fff9c4}.fy-sticky-1{background:#fce4ec}.fy-sticky-2{background:#e8f5e9}.fy-sticky-3{background:#e3f2fd}.fy-polaroids{flex-wrap:wrap;justify-content:center;gap:20px;display:flex}.fy-polaroid{background:#fff;border-radius:4px;max-width:180px;padding:12px 12px 40px;transition:transform .3s;box-shadow:0 4px 16px #0000001a}.fy-polaroid:hover{transform:rotate(0)scale(1.04)!important}.fy-pol-0{transform:rotate(-2deg)}.fy-pol-1{transform:rotate(2deg)}.fy-pol-2{transform:rotate(-1.5deg)}.fy-pol-3{transform:rotate(1.5deg)}.fy-pol-img{aspect-ratio:1;border-radius:2px;margin-bottom:12px;overflow:hidden}.fy-pol-img img{object-fit:cover;width:100%;height:100%}.fy-pol-cap{color:#5c3d7a;text-align:center;font-family:Dancing Script,cursive;font-size:1rem}.fy-letter-card{background:#fff;border:2px solid #fde1ef;border-radius:20px;padding:40px 36px;position:relative;box-shadow:0 8px 32px #ff1b6b1a}.fy-letter-stamp{margin-bottom:20px;font-size:2.5rem;display:block}.fy-letter-greeting{color:var(--fy-accent,#ff1b6b);margin-bottom:16px;font-family:Dancing Script,cursive;font-size:1.4rem}.fy-letter-body{color:#3d2052;white-space:pre-wrap;margin-bottom:24px;font-size:1rem;line-height:1.9}.fy-letter-signoff{color:#7c4d9e;margin-bottom:4px;font-family:Dancing Script,cursive;font-size:1.2rem}.fy-letter-name{font-family:Dancing Script,cursive;font-size:1.6rem;font-weight:700}.fy-ending-sec{text-align:center;padding-bottom:80px}.fy-ending-img{border-radius:20px;max-width:220px;margin:0 auto 24px;overflow:hidden}.fy-ending-img img{width:100%}.fy-ending-title{margin-bottom:12px;font-family:Dancing Script,cursive;font-size:2.5rem}.fy-ending-msg{color:#7c4d9e;max-width:400px;margin:0 auto;font-size:.95rem;line-height:1.7}.fy-footer{text-align:center;background:#ffffff80;border-top:1px solid #fde1ef;padding:24px}.fy-footer p{color:#b882d4;font-size:.8rem}.fy-footer a{color:var(--fy-accent,#ff1b6b);font-weight:700}@media (width<=480px){.fy-stickies{grid-template-columns:1fr}.fy-polaroids{gap:12px}.fy-polaroid{max-width:140px}}.bb-page{background:linear-gradient(135deg,#fff4e6 0%,#fff0fa 50%,#e8f4fd 100%);min-height:100vh;font-family:Nunito,sans-serif;position:relative;overflow-x:hidden}.confetti-wrap{pointer-events:none;z-index:0;height:100vh;position:fixed;top:0;left:0;right:0;overflow:hidden}.confetti-piece{opacity:.85;animation:linear infinite confetti-fall;position:absolute;top:-20px}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-20px)rotate(0)}to{opacity:0;transform:translateY(110vh)rotate(720deg)}}.bb-balloons{pointer-events:none;position:absolute;top:0;left:0;right:0}.bb-balloon{font-size:2.5rem;animation:4s ease-in-out infinite balloon-float;position:absolute}@keyframes balloon-float{0%,to{transform:translateY(0)rotate(-5deg)}50%{transform:translateY(-20px)rotate(5deg)}}.bb-hero{text-align:center;z-index:1;flex-direction:column;justify-content:center;align-items:center;gap:24px;min-height:100vh;padding:80px 24px 60px;display:flex;position:relative}.bb-hero-img{object-fit:cover;border:6px solid #fff;border-radius:50%;width:180px;height:180px;animation:.6s cubic-bezier(.34,1.56,.64,1) hero-pop;box-shadow:0 8px 40px #ff6b6b4d}@keyframes hero-pop{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.bb-hero-name{color:#ff6b6b;text-transform:uppercase;letter-spacing:.15em;font-size:1rem;font-weight:700}.bb-hero-title{color:#2d2d2d;margin:0;font-family:Pacifico,cursive;font-size:clamp(2.4rem,8vw,5rem);line-height:1.1}.bb-hero-subtitle{color:#666;max-width:500px;font-size:1.1rem}.bb-countdown{text-align:center;z-index:1;background:#fff;border-radius:24px;margin:0 24px 60px;padding:40px 32px;position:relative;box-shadow:0 8px 40px #00000014}.bb-countdown-label{text-transform:uppercase;letter-spacing:.12em;color:#ff6b6b;margin-bottom:24px;font-size:.9rem;font-weight:700}.bb-countdown-units{flex-wrap:wrap;justify-content:center;gap:20px;display:flex}.bb-unit{color:#fff;background:linear-gradient(135deg,#ff6b6b,#ffd93d);border-radius:16px;min-width:80px;padding:18px 24px}.bb-unit-val{font-size:2.8rem;font-weight:900;line-height:1;display:block}.bb-unit-label{text-transform:uppercase;letter-spacing:.1em;opacity:.9;margin-top:4px;font-size:.72rem;display:block}.bb-wishes{text-align:center;z-index:1;padding:60px 24px;position:relative}.bb-section-title{color:#2d2d2d;margin-bottom:36px;font-family:Pacifico,cursive;font-size:clamp(1.6rem,4vw,2.4rem)}.bb-wishes-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;max-width:900px;margin:0 auto;display:grid}.bb-wish-card{animation:wish-appear .4s ease var(--delay,0s) both;background:#fff;border-radius:20px;padding:28px 20px;transition:transform .2s;box-shadow:0 4px 20px #00000012}.bb-wish-card:hover{transform:translateY(-4px)}@keyframes wish-appear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.bb-wish-icon{margin-bottom:12px;font-size:2rem;display:block}.bb-wish-card p{color:#555;font-size:.95rem;line-height:1.6}.bb-message{z-index:1;padding:60px 24px;position:relative}.bb-message-card{text-align:center;background:#fff;border-top:6px solid #ff6b6b;border-radius:28px;max-width:680px;margin:0 auto;padding:48px 40px;box-shadow:0 12px 60px #ff6b6b1f}.bb-message-heading{color:#ff6b6b;margin-bottom:20px;font-family:Pacifico,cursive;font-size:1.5rem}.bb-message-body{color:#555;white-space:pre-line;font-size:1.05rem;line-height:1.85}.bb-sender{color:#333;margin-top:24px;font-size:1.05rem;font-weight:700}.bb-photos{text-align:center;z-index:1;padding:60px 24px;position:relative}.bb-photos-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;max-width:900px;margin:0 auto;display:grid}.bb-photo-frame{aspect-ratio:4/3;border-radius:20px;transition:transform .25s;overflow:hidden;box-shadow:0 8px 30px #0000001f}.bb-photo-frame:hover{transform:scale(1.02)}.bb-photo-frame img{object-fit:cover;width:100%;height:100%}.bb-footer{text-align:center;color:#999;z-index:1;padding:32px;font-size:.85rem;position:relative}@media (width<=600px){.bb-message-card{padding:32px 24px}.bb-countdown-units{gap:12px}.bb-unit{min-width:64px;padding:14px 16px}.bb-unit-val{font-size:2rem}}.ar-page{--accent:#c9184a;min-height:100vh;font-family:Nunito,sans-serif;overflow-x:hidden}.ar-hero{text-align:center;color:#fff;flex-direction:column;justify-content:center;align-items:center;height:100vh;display:flex;position:relative;overflow:hidden}.ar-hero-bg{object-fit:cover;z-index:0;filter:brightness(.45);width:100%;height:100%;position:absolute;inset:0}.ar-hero-overlay{z-index:1;position:absolute;inset:0}.ar-hero-content{z-index:2;flex-direction:column;align-items:center;gap:16px;padding:24px;display:flex;position:relative}.ar-hero-date{text-transform:uppercase;letter-spacing:.2em;opacity:.8;font-size:.85rem}.ar-years-badge{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff1a;border:2px solid;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:120px;height:120px;animation:1s years-appear;display:flex}@keyframes years-appear{0%{opacity:0;transform:scale(.5)rotate(-10deg)}to{opacity:1;transform:scale(1)rotate(0)}}.ar-years-num{font-size:3rem;font-weight:900;line-height:1}.ar-years-label{text-transform:uppercase;letter-spacing:.1em;color:#fff;opacity:.9;font-size:.6rem}.ar-hero-title{text-shadow:0 2px 20px #0006;margin:0;font-family:Cormorant Garamond,serif;font-size:clamp(2.5rem,8vw,5.5rem);font-style:italic;line-height:1}.ar-hero-sub{opacity:.85;max-width:500px;font-size:1rem}.ar-scroll-hint{opacity:.6;letter-spacing:.1em;z-index:2;font-size:.8rem;animation:2s infinite hint-bounce;position:absolute;bottom:32px}@keyframes hint-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}.ar-section-title{text-align:center;color:#2d2d2d;margin-bottom:40px;font-family:Cormorant Garamond,serif;font-size:clamp(1.8rem,4vw,3rem);font-style:italic}.ar-timeline-section{max-width:860px;margin:0 auto;padding:80px 24px}.ar-timeline{padding:20px 0;position:relative}.ar-tl-line{opacity:.3;width:2px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.ar-tl-item{opacity:0;justify-content:flex-end;margin-bottom:40px;padding-right:calc(50% + 32px);transition:all .5s;display:flex;transform:translate(-30px)}.ar-tl-item.right{justify-content:flex-start;padding-left:calc(50% + 32px);padding-right:0;transform:translate(30px)}.ar-tl-item.visible{opacity:1;transform:translate(0)}.ar-tl-dot{border-radius:50%;width:14px;height:14px;position:absolute;top:16px;left:50%;transform:translate(-50%);box-shadow:0 0 0 4px #fff}.ar-tl-card{background:#fff;border-radius:14px;max-width:280px;padding:16px 20px;box-shadow:0 4px 20px #00000014}.ar-tl-date{text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;font-size:.78rem;font-weight:700;display:block}.ar-tl-label{color:#444;font-size:.95rem;line-height:1.5}.ar-reel-section{background:#fff;padding:60px 0}.ar-reel-section .ar-section-title{padding:0 24px}.ar-reel{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:16px;padding:0 32px 20px;display:flex;overflow-x:auto}.ar-reel::-webkit-scrollbar{height:4px}.ar-reel::-webkit-scrollbar-thumb{background:var(--accent);border-radius:2px}.ar-reel-item{scroll-snap-align:center;border-radius:20px;flex:0 0 320px;height:420px;overflow:hidden;box-shadow:0 8px 30px #0000001f}.ar-reel-item img{object-fit:cover;width:100%;height:100%}.ar-letter-section{justify-content:center;padding:80px 24px;display:flex}.ar-letter-card{background:#fff;border-radius:24px;width:100%;max-width:640px;display:flex;overflow:hidden;box-shadow:0 16px 60px #0000001a}.ar-letter-border{flex-shrink:0;width:5px}.ar-letter-inner{padding:44px 40px;font-family:Cormorant Garamond,serif}.ar-letter-to{color:#888;margin-bottom:20px;font-size:1.2rem;font-style:italic}.ar-letter-body{color:#333;white-space:pre-line;margin-bottom:28px;font-size:1.1rem;line-height:1.9}.ar-letter-from{color:#888;margin-bottom:4px;font-size:1.1rem;font-style:italic}.ar-letter-name{font-size:1.4rem;font-weight:600}.ar-promise-section{background:linear-gradient(135deg,#fff5f7,#fff);padding:80px 24px}.ar-promises{flex-direction:column;gap:24px;max-width:640px;margin:0 auto;display:flex}.ar-promise-item{animation:promise-in .5s ease calc(var(--i) * .1s) both;background:#fff;border-radius:16px;align-items:flex-start;gap:20px;padding:24px;display:flex;box-shadow:0 4px 16px #0000000f}@keyframes promise-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.ar-promise-num{flex-shrink:0;font-family:Cormorant Garamond,serif;font-size:2.5rem;font-weight:600;line-height:1}.ar-promise-item p{color:#555;padding-top:10px;font-size:1rem;line-height:1.6}.ar-footer{text-align:center;color:#999;padding:40px;font-size:.85rem}.ar-footer a{color:var(--accent)}@media (width<=640px){.ar-tl-line{left:20px}.ar-tl-item{justify-content:flex-start;padding-left:52px;padding-right:0;transform:translate(0)}.ar-tl-item.right{padding-left:52px}.ar-tl-dot{left:20px}.ar-tl-card{max-width:100%}.ar-letter-inner{padding:28px 24px}.ar-reel-item{flex:0 0 260px;height:320px}}.bff-page{background:linear-gradient(160deg,#fff9e6 0%,#fffde8 40%,#f0fff4 100%);min-height:100vh;font-family:Nunito,sans-serif;position:relative;overflow-x:hidden}.bff-floaters{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.bff-floater{opacity:.7;font-size:1.6rem;animation:linear infinite float-up;position:absolute;bottom:-60px}@keyframes float-up{0%{opacity:.7;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(-110vh)rotate(360deg)}}.bff-hero{text-align:center;z-index:1;flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:100vh;padding:80px 24px 60px;display:flex;position:relative}.bff-hero-img{object-fit:cover;border:6px solid #ffd93d;border-radius:50%;width:200px;height:200px;animation:.6s cubic-bezier(.34,1.56,.64,1) bff-pop;box-shadow:0 0 0 12px #ffd93d26,0 12px 40px #0000001f}@keyframes bff-pop{0%{opacity:0;transform:scale(.3)rotate(-10deg)}to{opacity:1;transform:scale(1)rotate(0)}}.bff-friends-since{text-transform:uppercase;letter-spacing:.15em;color:#f9844a;font-size:.85rem;font-weight:700}.bff-title{color:#2d2d2d;margin:0;font-family:Caveat,cursive;font-size:clamp(3rem,10vw,6rem);line-height:1}.bff-for{color:#ffd93d;background:#2d2d2d;border-radius:30px;padding:6px 20px;font-size:1.1rem;font-weight:700;display:inline-block}.bff-subtitle{color:#666;max-width:500px;font-size:1rem}.bff-section-title{color:#2d2d2d;text-align:center;margin-bottom:36px;font-family:Caveat,cursive;font-size:clamp(2rem,5vw,3rem)}.bff-memories{z-index:1;padding:70px 24px;position:relative}.bff-memories-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;max-width:900px;margin:0 auto;display:grid}.bff-memory-card{animation:mem-in .4s ease var(--delay,0s) both;background:#fff;border-radius:20px;transition:transform .25s;overflow:hidden;box-shadow:0 8px 30px #0000001a}.bff-memory-card:hover{transform:rotate(-1deg)scale(1.02)}@keyframes mem-in{0%{opacity:0;transform:scale(.9)rotate(-2deg)}to{opacity:1;transform:scale(1)rotate(0)}}.bff-memory-img{aspect-ratio:4/3;object-fit:cover;width:100%}.bff-memory-caption{color:#444;text-align:center;padding:12px 16px;font-family:Caveat,cursive;font-size:1.1rem}.bff-jokes{z-index:1;background:#fff9e6;padding:70px 24px;position:relative}.bff-jokes-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;max-width:900px;margin:0 auto;display:grid}.bff-joke-bubble{animation:joke-pop .4s ease calc(var(--idx) * .1s) both;background:#fff;border-radius:20px 20px 20px 4px;padding:24px;position:relative;box-shadow:0 4px 20px #00000012}@keyframes joke-pop{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.bff-joke-quote{color:#ffd93d;font-family:serif;font-size:3rem;line-height:1;position:absolute;top:8px;left:14px}.bff-joke-bubble p{color:#444;padding-top:24px;font-family:Caveat,cursive;font-size:1.15rem;line-height:1.5}.bff-letter{z-index:1;justify-content:center;padding:70px 24px;display:flex;position:relative}.bff-letter-card{text-align:center;background:#fff;border:3px dashed #ffd93d;border-radius:28px;width:100%;max-width:640px;padding:48px 44px;box-shadow:0 16px 60px #ffd93d33}.bff-letter-deco{margin-bottom:20px;font-size:3rem}.bff-letter-body{color:#444;white-space:pre-line;margin-bottom:24px;font-family:Caveat,cursive;font-size:1.2rem;line-height:1.8}.bff-letter-sig{color:#f9844a;font-family:Caveat,cursive;font-size:1.1rem;font-weight:700}.bff-footer{text-align:center;color:#999;z-index:1;padding:32px;font-size:.85rem;position:relative}.bff-footer a{color:#f9844a}@media (width<=600px){.bff-letter-card{padding:32px 24px}}.sfmh-page{background:linear-gradient(160deg,#fff5f5 0%,#fdf0f8 50%,#f5f0ff 100%);min-height:100vh;font-family:Nunito,sans-serif;position:relative;overflow-x:hidden}.sfmh-roses-bg{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.sfmh-rose{animation:linear infinite rose-fall;position:absolute;top:-60px}@keyframes rose-fall{0%{opacity:0;transform:translateY(-60px)rotate(0)scale(1)}10%{opacity:1}90%{opacity:.8}to{opacity:0;transform:translateY(110vh)rotate(180deg)scale(.8)}}.sfmh-hero{text-align:center;z-index:1;flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:100vh;padding:80px 24px 60px;display:flex;position:relative}.sfmh-hero-img{object-fit:cover;border:5px solid #ffb3c1;border-radius:50%;width:200px;height:200px;animation:.8s sfmh-appear;box-shadow:0 0 0 12px #ffb3c126,0 12px 50px #c9184a1f}@keyframes sfmh-appear{0%{opacity:0;transform:translateY(20px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}.sfmh-to{text-transform:uppercase;letter-spacing:.2em;color:#c9184a;font-size:.85rem;font-weight:700}.sfmh-hero-title{color:#2d1a1f;margin:0;font-family:Lora,serif;font-size:clamp(3rem,10vw,6rem);font-style:italic;line-height:1.1}.sfmh-hero-sub{color:#888;max-width:460px;font-size:1rem;line-height:1.7}.sfmh-rose-divider{letter-spacing:8px;margin-top:8px;font-size:1.5rem}.sfmh-apology{z-index:1;justify-content:center;padding:60px 24px;display:flex;position:relative}.sfmh-apology-card{opacity:0;background:#fff;border-top:4px solid #c9184a;border-radius:28px;width:100%;max-width:640px;padding:48px 44px;transition:all .6s;transform:translateY(30px);box-shadow:0 12px 60px #c9184a1a}.sfmh-apology-card.visible{opacity:1;transform:translateY(0)}.sfmh-apology-title{color:#c9184a;margin-bottom:20px;font-family:Lora,serif;font-size:1.4rem;font-style:italic}.sfmh-apology-body{color:#555;white-space:pre-line;font-size:1.05rem;line-height:1.9}.sfmh-promises{z-index:1;background:#fff;padding:60px 24px;position:relative}.sfmh-section-title{color:#2d1a1f;text-align:center;margin-bottom:36px;font-family:Lora,serif;font-size:clamp(1.6rem,4vw,2.4rem);font-style:italic}.sfmh-promises-list{flex-direction:column;gap:20px;max-width:560px;margin:0 auto;display:flex}.sfmh-promise-row{animation:promise-slide .4s ease calc(var(--i) * .15s) both;background:#fff5f7;border-left:4px solid #ffb3c1;border-radius:16px;align-items:flex-start;gap:16px;padding:20px 24px;display:flex}@keyframes promise-slide{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.sfmh-promise-icon{flex-shrink:0;margin-top:2px;font-size:1.4rem}.sfmh-promise-row p{color:#555;font-size:1rem;line-height:1.6}.sfmh-ending{z-index:1;justify-content:center;padding:60px 24px;display:flex;position:relative}.sfmh-ending-card{text-align:center;background:linear-gradient(135deg,#fff5f7,#fff);border-radius:28px;max-width:500px;padding:48px 32px;box-shadow:0 8px 40px #c9184a1a}.sfmh-ending-heart{margin-bottom:20px;font-size:3.5rem;animation:1.5s ease-in-out infinite heart-pulse;display:block}@keyframes heart-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.sfmh-ending-msg{color:#555;white-space:pre-line;margin-bottom:20px;font-family:Lora,serif;font-size:1.1rem;font-style:italic;line-height:1.85}.sfmh-ending-from{color:#c9184a;font-size:1.1rem;font-weight:700}.sfmh-footer{text-align:center;color:#bbb;z-index:1;padding:32px;font-size:.85rem;position:relative}.sfmh-footer a{color:#c9184a}@media (width<=600px){.sfmh-apology-card{padding:28px 24px}.sfmh-ending-card{padding:32px 24px}}.site-loader,.site-not-found{text-align:center;background:#fff8fb;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.site-loader-heart{font-size:4rem;animation:1.2s ease-in-out infinite heartbeat}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.site-loader p{color:var(--text-muted);font-weight:600}.site-not-found span{font-size:3.5rem}.site-not-found h2{color:var(--text-primary)}.site-not-found p{color:var(--text-muted);margin-bottom:16px}:root{--admin-sidebar-w:240px;--admin-bg:#0f0f13;--admin-sidebar-bg:#16161e;--admin-border:#ffffff12;--admin-accent:#9b5de5;--admin-accent-soft:#9b5de51f;--admin-text:#e4e4f0;--admin-muted:#88a;--admin-card:#1c1c26;--admin-success:#22c55e;--admin-danger:#ef4444;--admin-warning:#f59e0b;--admin-info:#3b82f6}*{box-sizing:border-box;margin:0;padding:0}.admin-shell{background:var(--admin-bg);min-height:100vh;color:var(--admin-text);font-family:Inter,sans-serif;display:flex}.admin-sidebar{width:var(--admin-sidebar-w);background:var(--admin-sidebar-bg);border-right:1px solid var(--admin-border);z-index:100;flex-direction:column;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0;transform:translate(0)}.admin-shell.sidebar-closed .admin-sidebar{transform:translateX(calc(-1 * var(--admin-sidebar-w)))}.admin-brand{border-bottom:1px solid var(--admin-border);cursor:pointer;color:var(--admin-text);align-items:center;gap:10px;padding:22px 20px;font-size:1.1rem;font-weight:700;display:flex}.brand-icon{font-size:1.4rem}.admin-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex}.admin-nav-item{color:var(--admin-muted);border-radius:10px;align-items:center;gap:10px;padding:11px 14px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .18s;display:flex}.admin-nav-item:hover{background:var(--admin-accent-soft);color:var(--admin-text)}.admin-nav-item.active{background:var(--admin-accent-soft);color:var(--admin-accent);font-weight:600}.admin-sidebar-footer{border-top:1px solid var(--admin-border);padding:16px 12px}.admin-back-btn{border:1px solid var(--admin-border);width:100%;color:var(--admin-muted);cursor:pointer;background:0 0;border-radius:10px;padding:10px 14px;font-size:.85rem;transition:all .18s}.admin-back-btn:hover{background:var(--admin-accent-soft);color:var(--admin-text);border-color:var(--admin-accent)}.admin-main{margin-left:var(--admin-sidebar-w);flex-direction:column;flex:1;min-height:100vh;transition:margin-left .28s cubic-bezier(.4,0,.2,1);display:flex}.admin-shell.sidebar-closed .admin-main{margin-left:0}.admin-topbar{border-bottom:1px solid var(--admin-border);background:var(--admin-sidebar-bg);z-index:50;align-items:center;gap:16px;padding:14px 24px;display:flex;position:sticky;top:0}.sidebar-toggle{color:var(--admin-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:1.2rem;transition:color .18s}.sidebar-toggle:hover{color:var(--admin-text)}.admin-topbar-title{color:var(--admin-muted);letter-spacing:.05em;text-transform:uppercase;font-size:.95rem;font-weight:600}.admin-content{flex:1;padding:28px 32px}.admin-loading{color:#888;justify-content:center;align-items:center;min-height:100vh;display:flex}.admin-page-title{color:var(--admin-text);margin-bottom:6px;font-size:1.6rem;font-weight:700}.admin-page-subtitle{color:var(--admin-muted);margin-bottom:28px;font-size:.9rem}.admin-stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:32px;display:grid}.admin-stat-card{background:var(--admin-card);border:1px solid var(--admin-border);border-radius:14px;flex-direction:column;gap:8px;padding:20px;display:flex}.stat-label{text-transform:uppercase;letter-spacing:.07em;color:var(--admin-muted);font-size:.78rem}.stat-value{color:var(--admin-text);font-size:2rem;font-weight:800;line-height:1}.stat-sub{color:var(--admin-success);font-size:.78rem}.admin-table-card{background:var(--admin-card);border:1px solid var(--admin-border);border-radius:14px;overflow:hidden}.admin-table-header{border-bottom:1px solid var(--admin-border);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.admin-table-title{font-size:1rem;font-weight:600}.admin-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.875rem}.admin-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--admin-muted);border-bottom:1px solid var(--admin-border);padding:12px 16px;font-size:.75rem}.admin-table td{color:var(--admin-text);vertical-align:middle;border-bottom:1px solid #ffffff0a;padding:14px 16px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#ffffff05}.badge{letter-spacing:.04em;border-radius:20px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-block}.badge-green{color:#22c55e;background:#22c55e26}.badge-red{color:#ef4444;background:#ef444426}.badge-yellow{color:#f59e0b;background:#f59e0b26}.badge-purple{color:#9b5de5;background:#9b5de526}.badge-blue{color:#3b82f6;background:#3b82f626}.badge-gray{color:var(--admin-muted);background:#ffffff14}.btn-admin-primary{background:var(--admin-accent);color:#fff;cursor:pointer;border:none;border-radius:9px;padding:9px 18px;font-size:.875rem;font-weight:600;transition:opacity .18s}.btn-admin-primary:hover{opacity:.85}.btn-admin-ghost{border:1px solid var(--admin-border);color:var(--admin-muted);cursor:pointer;background:0 0;border-radius:9px;padding:7px 14px;font-size:.8rem;transition:all .18s}.btn-admin-ghost:hover{border-color:var(--admin-accent);color:var(--admin-text)}.btn-admin-danger{color:#ef4444;cursor:pointer;background:#ef44441a;border:1px solid #ef44444d;border-radius:9px;padding:7px 14px;font-size:.8rem;transition:all .18s}.btn-admin-danger:hover{background:#ef444433}.btn-row{gap:8px;display:flex}.admin-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.admin-modal{background:var(--admin-card);border:1px solid var(--admin-border);border-radius:16px;width:100%;max-width:640px;max-height:90vh;padding:28px;overflow-y:auto}.admin-modal-title{margin-bottom:20px;font-size:1.2rem;font-weight:700}.admin-form-grid{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px;display:grid}.admin-form-grid.full{grid-template-columns:1fr}.admin-field{flex-direction:column;gap:6px;display:flex}.admin-field label{text-transform:uppercase;letter-spacing:.06em;color:var(--admin-muted);font-size:.78rem}.admin-field input,.admin-field select,.admin-field textarea{background:var(--admin-bg);border:1px solid var(--admin-border);color:var(--admin-text);border-radius:8px;outline:none;width:100%;padding:9px 12px;font-family:inherit;font-size:.875rem;transition:border-color .18s}.admin-field input:focus,.admin-field select:focus,.admin-field textarea:focus{border-color:var(--admin-accent)}.admin-field textarea{resize:vertical;min-height:100px}.admin-modal-actions{border-top:1px solid var(--admin-border);justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;display:flex}.admin-search{background:var(--admin-bg);border:1px solid var(--admin-border);color:var(--admin-text);border-radius:9px;outline:none;width:220px;padding:8px 14px;font-size:.875rem;transition:border-color .18s}.admin-search:focus{border-color:var(--admin-accent)}.admin-pagination{justify-content:center;gap:8px;padding:16px;display:flex}.admin-pagination button{background:var(--admin-bg);border:1px solid var(--admin-border);color:var(--admin-muted);cursor:pointer;border-radius:7px;padding:6px 12px;transition:all .18s}.admin-pagination button.active,.admin-pagination button:hover{border-color:var(--admin-accent);color:var(--admin-text)}.toggle-switch{width:40px;height:22px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background:#ffffff1a;border-radius:22px;transition:background .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;bottom:3px;left:3px}.toggle-switch input:checked+.toggle-slider{background:var(--admin-accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}@media (width<=900px){.admin-content{padding:20px}.admin-form-grid{grid-template-columns:1fr}.admin-stats-grid{grid-template-columns:repeat(2,1fr)}.admin-search{width:160px}}@media (width<=768px){.admin-sidebar{z-index:300;box-shadow:none;transform:translateX(calc(-1 * var(--admin-sidebar-w)))!important}.admin-shell.sidebar-open .admin-sidebar{box-shadow:4px 0 24px #0006;transform:translate(0)!important}.admin-main{margin-left:0!important}.admin-content{padding:16px}.admin-topbar{padding:12px 16px}.admin-stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-value{font-size:1.6rem}.admin-table-header{flex-direction:column;align-items:flex-start;gap:10px}.admin-search{width:100%}.admin-modal{padding:20px}.admin-modal-actions{flex-direction:column-reverse}.admin-modal-actions button{width:100%}}@media (width<=480px){.admin-stats-grid{grid-template-columns:1fr 1fr;gap:10px}.admin-stat-card{padding:14px}.stat-value{font-size:1.4rem}.admin-page-title{font-size:1.3rem}.btn-row{flex-wrap:wrap}}.admin-sidebar-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:299;cursor:pointer;background:#0000008c;display:none;position:fixed;inset:0}@media (width<=768px){.admin-shell.sidebar-open .admin-sidebar-backdrop{display:block}}.au-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:36px;height:36px}.au-avatar-initials{background:var(--admin-accent,#9b5de5);color:#fff;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.au-user-cell{align-items:center;gap:10px;display:flex}.au-display-name{font-weight:500}.au-email{color:#aaa;font-size:.85rem}.au-date{color:#888;font-size:.8rem}.au-providers{flex-wrap:wrap;gap:4px;display:flex}.au-loading,.au-empty{color:#888;text-align:center;padding:40px 20px;font-size:.9rem}.au-search-form{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.au-table-view{display:none}.au-card-view{grid-template-columns:repeat(3,1fr);gap:14px;padding:16px;display:grid}.au-user-card{background:var(--admin-bg,#0f0f13);border:1px solid #ffffff17;border-radius:14px;flex-direction:column;gap:12px;padding:16px;transition:border-color .18s;display:flex}.au-user-card:hover{border-color:#9b5de559}.au-card-top{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.au-card-identity{align-items:center;gap:10px;min-width:0;display:flex}.au-card-identity>div{min-width:0}.au-card-name{color:var(--admin-text,#e4e4f0);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.au-card-email{color:#888;white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:.75rem;overflow:hidden}.au-card-meta{background:#ffffff08;border-radius:8px;flex-direction:column;gap:6px;padding:10px 12px;display:flex}.au-meta-row{align-items:center;gap:8px;font-size:.82rem;display:flex}.au-meta-label{color:#555;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;width:58px;font-size:.72rem}.au-card-actions{display:flex}.au-action-btn{text-align:center;justify-content:center;border-radius:8px!important;flex:1!important;padding:9px 12px!important;font-size:.82rem!important}@media (width<=900px){.au-card-view{grid-template-columns:repeat(2,1fr);gap:12px}}@media (width<=640px){.au-card-view{grid-template-columns:repeat(2,1fr);gap:10px;padding:12px}.au-user-card{gap:10px;padding:12px}.au-avatar{width:30px;height:30px;font-size:.78rem}.au-card-name{font-size:.82rem}.au-card-email{font-size:.7rem}.au-card-meta{padding:8px 10px}.au-meta-label{width:52px;font-size:.68rem}.au-action-btn{padding:8px!important;font-size:.75rem!important}.au-search-form{width:100%}.au-search-form .admin-search{flex:1;width:auto}.au-search-form .btn-admin-ghost{white-space:nowrap}}@media (width<=380px){.au-card-view{grid-template-columns:repeat(2,1fr);gap:8px;padding:10px}.au-card-meta{display:none}}:root{--primary:#ff1b6b;--primary-light:#ff6b9d;--primary-dark:#cc1456;--secondary:#9333ea;--secondary-light:#b86ef7;--accent:gold;--accent-2:#ff9f1c;--bg-base:#fff8fb;--bg-card:#fff;--bg-subtle:#fff0f5;--bg-dark:#12001f;--text-primary:#1a0a2e;--text-secondary:#6b4f72;--text-muted:#a08aac;--text-on-dark:#fff;--border-color:#f0d6e8;--border-focus:#ff1b6b;--radius-sm:10px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;--radius-full:9999px;--shadow-sm:0 2px 8px #ff1b6b14;--shadow-md:0 4px 20px #ff1b6b24;--shadow-lg:0 8px 40px #ff1b6b2e;--shadow-card:0 2px 12px #1a0a2e14;--transition:.22s ease;--font-main:"Nunito", sans-serif;--font-cursive:"Dancing Script", cursive;--font-fun:"Pacifico", cursive;--navbar-h:68px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-main);background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.6}img,video{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{border:none;outline:none;font-family:inherit}#root{flex-direction:column;min-height:100vh;display:flex}h1,h2,h3,h4,h5,h6{font-weight:800;line-height:1.2}h1{font-size:clamp(2rem,5vw,3.5rem)}h2{font-size:clamp(1.5rem,4vw,2.5rem)}h3{font-size:clamp(1.2rem,3vw,1.8rem)}p{color:var(--text-secondary);font-size:1rem}.text-gradient{background:linear-gradient(135deg, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.text-gradient-gold{background:linear-gradient(135deg, var(--accent), var(--accent-2));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.btn{border-radius:var(--radius-full);letter-spacing:.3px;transition:all var(--transition);cursor:pointer;font-size:.95rem;font-weight:700;font-family:var(--font-main);border:none;justify-content:center;align-items:center;gap:8px;padding:12px 28px;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;box-shadow:0 4px 16px #ff1b6b59}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #ff1b6b73}.btn-primary:active{transform:translateY(0)}.btn-outline{border:2px solid var(--primary);color:var(--primary);background:0 0}.btn-outline:hover{background:var(--bg-subtle);transform:translateY(-1px)}.btn-ghost{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;background:#ffffff26;border:1.5px solid #ffffff4d}.btn-ghost:hover{background:#ffffff40}.btn-sm{padding:8px 18px;font-size:.85rem}.btn-lg{padding:16px 36px;font-size:1.05rem}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1.5px solid var(--border-color);box-shadow:var(--shadow-card);transition:all var(--transition)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.card-glass{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);background:#ffffffb3;border:1.5px solid #ffffff80}.input-field{border:2px solid var(--border-color);border-radius:var(--radius-md);width:100%;font-size:.95rem;font-family:var(--font-main);color:var(--text-primary);background:var(--bg-card);transition:border-color var(--transition);padding:12px 16px}.input-field:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #ff1b6b1a}.input-field::placeholder{color:var(--text-muted)}textarea.input-field{resize:vertical;min-height:100px}.container{max-width:1200px;margin:0 auto;padding:0 20px}.section{padding:80px 0}.section-sm{padding:48px 0}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.grid-2{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.badge{border-radius:var(--radius-full);letter-spacing:.3px;align-items:center;gap:4px;padding:4px 12px;font-size:.78rem;font-weight:700;display:inline-flex}.badge-free{color:#16a34a;background:#dcfce7}.badge-paid{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff}.badge-new{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff}.spinner{border:3px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.page-enter{animation:.35s both fadeSlideIn}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.deco-float{pointer-events:none;-webkit-user-select:none;user-select:none;animation:4s ease-in-out infinite alternate floatAnim;position:absolute}@keyframes floatAnim{0%{transform:translateY(0)rotate(-5deg)}to{transform:translateY(-14px)rotate(5deg)}}@keyframes floatAnim2{0%{transform:translateY(0)rotate(5deg)}to{transform:translateY(-10px)rotate(-5deg)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #ff1b6b4d}50%{box-shadow:0 0 0 12px #ff1b6b00}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--primary-light);border-radius:3px}.Toastify__toast{border-radius:var(--radius-md)!important;font-family:var(--font-main)!important}.pill{border-radius:var(--radius-full);border:2px solid var(--border-color);cursor:pointer;transition:all var(--transition);background:var(--bg-card);color:var(--text-secondary);padding:8px 18px;font-size:.875rem;font-weight:600}.pill:hover,.pill.active{border-color:var(--primary);background:var(--primary);color:#fff}@media (width<=1024px){.grid-4{grid-template-columns:repeat(3,1fr)}}@media (width<=768px){.grid-2{grid-template-columns:1fr}.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}.section{padding:48px 0}.section-sm{padding:32px 0}.container{padding:0 16px}.btn-lg{padding:14px 28px;font-size:1rem}}@media (width<=480px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.section{padding:36px 0}.container{padding:0 14px}.btn{min-height:44px}.btn-sm{min-height:36px}}
