code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.btn-link{background:none;border:none;cursor:pointer;font-family:inherit;font-size:inherit;padding:0;text-decoration:none}.btn-link:hover{text-decoration:underline}:root{--color-social:#92400e}.modern-layout{background:#f8fafc;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh}.modern-sidebar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);-webkit-backdrop-filter:var(--blur-glass);backdrop-filter:var(--blur-glass);background:linear-gradient(180deg,#fff,#f8fafc);border-right:1px solid #e2e8f0;box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;transition:transform .3s cubic-bezier(.4,0,.2,1);width:280px;z-index:1000}.modern-sidebar-header{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);border-bottom:1px solid #f1f5f9;color:#fff;overflow:hidden;padding:32px 24px 24px;position:relative}.modern-sidebar-header:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cpattern id='a' width='100' height='100' patternUnits='userSpaceOnUse'%3E%3Ccircle cx='20' cy='20' r='1' fill='%23fff' opacity='.1'/%3E%3Ccircle cx='80' cy='40' r='1' fill='%23fff' opacity='.1'/%3E%3Ccircle cx='40' cy='80' r='1' fill='%23fff' opacity='.1'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.header-brand{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px;position:relative;z-index:1}.modern-app-title{-webkit-text-fill-color:#0000;background:linear-gradient(45deg,#fff,#f0f9ff);-webkit-background-clip:text;background-clip:text;font-size:24px;font-weight:700;margin:0}.modern-user-card{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #fff3;border-radius:16px;display:flex;gap:12px;padding:16px;position:relative;z-index:1}.user-avatar-large{align-items:center;background:#fff3;border:2px solid #ffffff4d;border-radius:12px;color:#fff;display:flex;font-size:18px;font-weight:700;height:48px;justify-content:center;width:48px}.user-details{flex:1 1}.user-name{font-size:16px;font-weight:600;margin-bottom:2px}.user-role{align-items:center;display:flex;font-size:12px;gap:4px;opacity:.9}.modern-nav{flex:1 1;padding:24px 16px}.modern-nav-menu{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.modern-nav-item{margin:0}.modern-nav-link{align-items:center;border:1px solid #0000;border-radius:16px;color:#64748b;display:flex;font-size:15px;gap:16px;overflow:hidden;padding:16px 20px;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.modern-nav-link:hover{border-color:#ffffff80}.modern-nav-link.active,.modern-nav-link:hover{box-shadow:0 8px 25px #0000001f;box-shadow:var(--shadow-medium);transform:translateY(-2px)}.modern-nav-link.active{border-color:#ffffff4d}.nav-icon{align-items:center;border-radius:8px;display:flex;height:24px;justify-content:center;transition:all .3s;width:24px}.nav-label{flex:1 1;font-weight:600}.nav-indicator{border-radius:50%;height:6px;opacity:0;transition:all .3s;width:6px}.modern-nav-link{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;color:#374151;font-weight:500;position:relative}.modern-nav-link:hover{background:linear-gradient(135deg,#e0e7ff,#ede9fe);border-color:#6366f133;box-shadow:0 4px 12px #6366f126;color:#6366f1;font-weight:600;transform:translateY(-1px)}.modern-nav-link.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea80;box-shadow:0 6px 20px #667eea4d;color:#fff;font-weight:600;transform:translateY(-1px)}.modern-nav-link.active:before{background:#fbbf24;border-radius:0 2px 2px 0;content:"";height:70%;left:-2px;position:absolute;top:50%;transform:translateY(-50%);width:4px}.modern-nav-link .nav-indicator{background:#667eea}.modern-nav-link.active .nav-indicator{background:#fbbf24;opacity:1;transform:scale(1.2)}.modern-nav-link.social{background:linear-gradient(135deg,#fef3c7,#fde68a);background:var(--gradient-social);color:#92400e;color:var(--color-social)}.modern-nav-link.social.active,.modern-nav-link.social:hover{background:linear-gradient(135deg,#fde68a,#fcd34d);color:#78350f}.modern-nav-link.social .nav-indicator{background:#92400e;background:var(--color-social)}.modern-sidebar-footer{background:#f8fafccc;border-top:1px solid #f1f5f9;padding:24px}.modern-premium-banner{background:linear-gradient(135deg,#ff9a9e,#fecfef);background:var(--gradient-premium);border-radius:16px;color:#fff;cursor:pointer;margin-bottom:16px;overflow:hidden;padding:20px;position:relative;transition:transform .3s}.modern-premium-banner:hover{transform:translateY(-2px)}.premium-glow{animation:glow 3s ease-in-out infinite;background:radial-gradient(circle,#ffffff1a 0,#0000 70%);height:200%;left:-50%;position:absolute;top:-50%;width:200%}@keyframes glow{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}.premium-content{z-index:1}.premium-title{font-size:14px;font-weight:700;margin-bottom:4px}.premium-subtitle{font-size:12px;opacity:.9}.premium-icon{opacity:.3;position:absolute;right:16px;top:16px}.modern-restrictions-card{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border:1px solid #ffd93d;border-radius:12px;margin-bottom:16px;padding:16px}.restrictions-title{color:#856404;font-size:13px;font-weight:600;margin-bottom:8px}.restrictions-list{color:#856404;font-size:12px}.restriction-item{margin-bottom:4px;opacity:.8}.modern-logout-btn{align-items:center;background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca;border-radius:12px;color:#dc2626;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:12px;padding:14px 20px;transition:all .3s;width:100%}.modern-logout-btn:hover{background:linear-gradient(135deg,#fee2e2,#fecaca);box-shadow:0 4px 12px #dc262626;transform:translateY(-1px)}.modern-mobile-header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);-webkit-backdrop-filter:var(--blur-glass);backdrop-filter:var(--blur-glass);background:#fffffff2;border-bottom:1px solid #e2e8f0;display:none;left:0;position:fixed;right:0;top:0;transition:all .3s;z-index:1001}.mobile-header-content{align-items:center;display:flex;justify-content:space-between;padding:16px 20px}.modern-menu-toggle{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);border:none;border-radius:12px;box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow-soft);color:#fff;cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .3s;width:44px}.modern-menu-toggle:hover{transform:scale(1.05)}.mobile-user-badge{align-items:center;display:flex;gap:8px}.user-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);border-radius:10px;color:#fff;display:flex;font-size:14px;font-weight:700;height:36px;justify-content:center;width:36px}.modern-menu-overlay{animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0006;bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.modern-main-content{background:#f8fafc;flex:1 1;margin-left:280px;min-height:100vh;transition:margin-left .3s}.nav-icon-container{position:relative}.notification-badge{animation:bounce 2s infinite;right:-8px;top:-8px}@keyframes bounce{0%,20%,53%,80%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1);transform:translateZ(0)}40%,43%{animation-timing-function:cubic-bezier(.755,.05,.855,.06);transform:translate3d(0,-8px,0)}70%{animation-timing-function:cubic-bezier(.755,.05,.855,.06);transform:translate3d(0,-4px,0)}90%{transform:translate3d(0,-2px,0)}}.loading-content{align-items:center;color:#64748b;display:flex;flex-direction:column;height:100vh;justify-content:center}.spinner{border:3px solid #f1f5f9;border-top-color:linear-gradient(135deg,#667eea,#764ba2);border-top:3px solid var(--gradient-primary);height:40px;margin-bottom:16px;width:40px}.spinner.small{border-width:2px;height:16px;margin-bottom:0;width:16px}.loading-permissions{align-items:center;display:flex;font-size:12px;gap:8px;opacity:.8}@media (max-width:768px){.modern-mobile-header{display:block}.modern-main-content{margin-left:0;padding-top:76px}.modern-sidebar{transform:translateX(-100%);width:280px}.modern-sidebar.open{transform:translateX(0)}.notification-badge{font-size:9px;height:18px;min-width:18px}}.role-parent{color:#f59e0b!important}.role-nounou{color:#10b981!important}.role-accompagnateur{color:#6366f1!important}.crown-icon{color:#fbbf24;filter:drop-shadow(0 1px 3px rgba(251,191,36,.5))}.dashboard-container{background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.modern-header{background:linear-gradient(135deg,#667eea,#764ba2);margin-bottom:32px;overflow:hidden;padding:40px 32px;position:relative}.header-bg-pattern{background-image:radial-gradient(circle at 25px 25px,#fff 2px,#0000 0);background-size:50px 50px;inset:0;opacity:.1;position:absolute}.header-content{margin:0 auto;max-width:1200px}.greeting-section{align-items:center;display:flex;gap:20px}.greeting-avatar{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:50%;display:flex;font-size:24px;height:60px;justify-content:center;width:60px}.greeting-avatar,.greeting-title{color:#fff;font-weight:700;text-shadow:0 2px 4px #0000001a}.greeting-title{font-size:32px;margin:0 0 8px}.greeting-subtitle{color:#ffffffe6;font-size:16px;margin:0}.modern-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;border-radius:12px;color:#fff;display:inline-flex;font-weight:600;gap:8px;padding:12px 24px;text-decoration:none;transition:all .3s ease}.modern-btn:hover{background:#ffffff4d;box-shadow:0 8px 16px #00000026;transform:translateY(-2px)}.modern-stats-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:0 auto 32px;max-width:1200px;padding:0 32px}.modern-stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden;padding:24px;position:relative;transition:all .3s ease}.modern-stat-card:hover{box-shadow:0 20px 25px -5px #0000001a;transform:translateY(-4px)}.stat-gradient{height:4px;left:0;position:absolute;right:0;top:0}.stat-content{align-items:center;display:flex;gap:20px}.stat-icon{border-radius:14px;flex-shrink:0;height:60px;width:60px}.stat-info{flex:1 1}.stat-value{font-size:32px;font-weight:800;line-height:1;margin-bottom:4px}.stat-label{color:#64748b;line-height:1.3}.modern-enfants-selector{margin:0 auto 32px;max-width:1200px;padding:0 32px}.selector-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.selector-header h3{color:#1f2937;font-size:22px;font-weight:700;margin:0}.navigation-controls{align-items:center;display:flex;gap:16px}.nav-button{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .3s ease;width:40px}.nav-button:hover:not([disabled]){border-color:#3b82f6;box-shadow:0 4px 12px #3b82f633;color:#3b82f6;transform:scale(1.1)}.nav-button:disabled{cursor:not-allowed;opacity:.4}.page-indicator{color:#6b7280;font-size:14px;font-weight:600;min-width:40px;text-align:center}.enfants-carousel{overflow:hidden;padding:8px 0}.enfants-track{display:flex;gap:16px;transition:transform .5s cubic-bezier(.25,.46,.45,.94)}.modern-enfant-card{align-items:center;background:#fff;border:2px solid #f1f5f9;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;cursor:pointer;display:flex;flex-direction:column;min-width:180px;padding:20px;text-align:center;transition:all .3s ease}.modern-enfant-card:hover{border-color:#e2e8f0;box-shadow:0 20px 25px -5px #0000001a;transform:translateY(-4px)}.modern-enfant-card.active{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-color:#3b82f6;box-shadow:0 20px 25px -5px #3b82f61a}.enfant-avatar-container{margin-bottom:12px;position:relative}.enfant-avatar{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 6px 12px #667eea4d;z-index:2}.active-ring{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;inset:-4px;position:absolute;z-index:1}.enfant-info{width:100%}.enfant-nom{color:#1f2937;font-size:16px;font-weight:700;margin-bottom:2px}.enfant-age{color:#64748b;font-size:13px;font-weight:500}.modern-dashboard-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px;padding:0 32px 32px}.modern-card{background:#fff;border:1px solid #e5e7eb;border-radius:20px;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden;transition:all .3s ease}.modern-card:hover{box-shadow:0 20px 25px -5px #0000001a;transform:translateY(-2px)}.card-header{align-items:center;display:flex;justify-content:space-between;padding:24px 24px 16px}.card-title{color:#1f2937}.view-all-link{transition:all .2s}.card-body{padding:24px}.actions-content{width:100%}.enfant-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;gap:16px;margin-bottom:20px;padding-bottom:16px}.enfant-header .enfant-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 4px 8px #667eea4d;color:#fff;display:flex;font-size:18px;font-weight:700;height:48px;justify-content:center;width:48px}.enfant-details .enfant-nom{color:#1f2937;font-size:16px;font-weight:700;margin-bottom:2px}.enfant-details .enfant-age{color:#64748b;font-size:14px}.empty-icon{margin-bottom:16px;opacity:.5}.empty-state h4{color:#374151;font-weight:600;margin:0 0 8px}.empty-state p{margin:0}.modern-toast{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;box-shadow:0 10px 15px -3px #0000001a;display:flex;font-weight:500;gap:8px;max-width:320px;padding:16px 20px;position:fixed;right:24px;top:24px;z-index:1000}.toast-success{background:#10b9811a;border:1px solid #10b98133}.toast-error{background:#ef44441a;border:1px solid #ef444433;color:#dc2626}.toast-icon{flex-shrink:0}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;z-index:1000}.modal-container{animation:modalSlideIn .3s ease-out;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a;max-height:80vh;max-width:400px;padding:24px}@media (max-width:968px){.modern-dashboard-grid{grid-template-columns:1fr;padding:0 20px 20px}.header-content{flex-direction:column;gap:20px;text-align:center}.modern-enfants-selector,.modern-stats-grid{padding:0 20px}.modern-header{padding:32px 20px}.greeting-title{font-size:24px}.modern-stats-grid{grid-template-columns:1fr}.enfants-track{transform:none!important;width:100%!important}.modern-enfant-card{min-width:calc(100% - 16px)}}@media (max-width:640px){.modern-header{padding:24px 16px}.greeting-section{flex-direction:column;gap:16px;text-align:center}.greeting-title{font-size:20px}.greeting-subtitle{font-size:14px}.modern-enfants-selector,.modern-stats-grid{padding:0 16px}.modern-dashboard-grid{gap:20px;padding:0 16px 16px}.stat-content{flex-direction:column;gap:12px;text-align:center}.stat-icon{height:48px;width:48px}.stat-value{font-size:24px}.selector-header{align-items:flex-start;flex-direction:column;gap:12px}.navigation-controls{align-self:center}}.photo-item{border-radius:12px}.photo-item:hover{transform:translateY(-2px)}.photo-item-small{max-width:220px}.photo-item-medium{max-width:180px}.photo-item-large{max-width:240px}.photo-container{border-radius:12px}.photo-container:hover{box-shadow:0 8px 32px #0000001f,0 0 0 1px #00000005}.photo-container.blurred .photo-image{transform:scale(1.05)}.photo-blur-overlay{gap:6px}.photo-blur-overlay:before{height:50px;width:50px}.photo-overlay{background:linear-gradient(180deg,#000c 0,#0000 30%,#0000 70%,#000c);padding:12px}.photo-info{gap:4px}.photo-enfant{font-size:11px}.photo-time{font-size:10px}.photo-actions{gap:6px}.photo-action-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#fffffff2,#ffffffd9);border-radius:8px;box-shadow:0 2px 8px #00000026;color:#6366f1;height:32px;transition:all .3s cubic-bezier(.4,0,.2,1);width:32px}.photo-action-btn:hover:not(:disabled){background:#fff;box-shadow:0 4px 12px #0003;transform:scale(1.05)}.photo-action-btn.zoom:hover{color:#4338ca}.photo-action-btn.download:hover{color:#059669}.photo-action-btn.share:hover{color:#dc2626}.photo-action-btn.disabled{background:#ffffff4d;color:#ffffffb3}.photo-action-btn:disabled{cursor:not-allowed;opacity:.6}.photo-action-btn.downloading{pointer-events:none}.spinner-small{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;height:14px;width:14px}.photo-caption{font-size:12px;line-height:1.4;padding:8px 4px 0}.photo-message{align-items:center;animation:slideIn .3s ease;border-radius:6px;display:flex;font-size:11px;font-weight:600;gap:6px;margin-top:4px;padding:6px 8px}.photo-message.error{background:#fef2f2;border:1px solid #fca5a5;color:#dc2626}.photo-message.success{background:#f0fdf4;border:1px solid #86efac;color:#16a34a}.photo-zoom-modal-overlay{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.photo-zoom-modal{animation:zoomIn .3s cubic-bezier(.34,1.56,.64,1);background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000080;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;overflow:hidden}.photo-zoom-header{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px}.photo-zoom-info h3{color:#1f2937;font-size:18px;font-weight:700;margin:0 0 4px}.photo-zoom-info span{color:#6b7280;font-size:14px}.photo-zoom-actions{align-items:center;display:flex;gap:8px}.zoom-action-btn{align-items:center;background:#f3f4f6;border:none;border-radius:10px;color:#6b7280;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s ease;width:40px}.zoom-action-btn:hover:not(:disabled){background:#e5e7eb;transform:scale(1.05)}.zoom-action-btn.download:hover{background:#d1fae5;color:#059669}.zoom-action-btn.share:hover{background:#fef2f2;color:#dc2626}.zoom-action-btn.close:hover{background:#fee2e2;color:#dc2626}.zoom-action-btn:disabled{cursor:not-allowed;opacity:.5}.photo-zoom-content{align-items:center;display:flex;flex:1 1;justify-content:center;overflow:auto;padding:10px}.photo-zoom-image{max-height:80vh;max-width:100%;object-fit:contain}.photo-zoom-image-container{align-items:center;display:flex;justify-content:center;width:100%}.photo-zoom-caption{background:#f9fafb;border-top:1px solid #e5e7eb;color:#374151;font-size:14px;line-height:1.5;padding:16px 24px}.photo-grid{grid-gap:16px;display:grid;gap:16px}.photo-grid-auto{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.photo-grid-2{grid-template-columns:repeat(2,1fr)}.photo-grid-3{grid-template-columns:repeat(3,1fr)}.photo-grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width:768px){.photo-item-small{max-width:100px}.photo-item-medium{max-width:140px}.photo-item-large{max-width:180px}.photo-grid-auto{gap:12px;grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.photo-grid-3,.photo-grid-4{grid-template-columns:repeat(2,1fr)}.photo-action-btn{height:28px;width:28px}.photo-zoom-modal{max-height:95vh;max-width:95vw}.photo-zoom-header{padding:16px 20px}.zoom-action-btn{height:36px;width:36px}}@media (max-width:480px){.photo-item-small{max-width:80px}.photo-grid-auto{gap:8px;grid-template-columns:repeat(auto-fit,minmax(80px,1fr))}.photo-grid-2,.photo-grid-3,.photo-grid-4{grid-template-columns:repeat(2,1fr)}.photo-zoom-modal{border-radius:0;height:100vh;max-height:100vh;width:100vw}.photo-zoom-content{padding:0}.photo-zoom-header{align-items:flex-start;flex-direction:column;gap:12px}.photo-zoom-actions{align-self:flex-end}}.dashboard-container .photo-zoom-modal-overlay,.photos-recentes-card .photo-zoom-modal-overlay{position:fixed!important;z-index:999999!important}.photos-recentes-card{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #fffc;border-radius:20px;box-shadow:0 12px 40px #00000014,0 0 0 1px #00000005;overflow:hidden;position:relative;transition:transform .3s ease,box-shadow .3s ease}.photos-recentes-card .card-header{background:linear-gradient(135deg,#fefefe,#f9fafb);border-bottom:1px solid #f1f5f9;padding:28px 28px 20px}.photos-recentes-card .card-body{padding:28px}.photos-header{justify-content:space-between}.photos-header h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1e293b,#475569);-webkit-background-clip:text;background-clip:text;color:#1e293b;font-size:20px;font-weight:700;margin:0}.photos-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:20px}.photo-item{border-radius:16px;display:flex;flex-direction:column;transition:transform .3s ease}.photo-item:hover{transform:scale(1.02)}.photo-container{aspect-ratio:1;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-radius:16px;box-shadow:0 4px 20px #00000014,0 0 0 1px #00000005;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.photo-container:hover{box-shadow:0 12px 32px #0000001f,0 0 0 1px #00000005;transform:translateY(-2px)}.photo-image{transition:all .4s ease}.photo-container.blurred .photo-image{filter:blur(8px) brightness(.7);transform:scale(1.1)}.photo-blur-overlay{animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:linear-gradient(135deg,#000000b3,#00000080);font-size:14px;font-weight:700;gap:8px}.photo-blur-overlay:before{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #ffffff4d;border-radius:50%;content:"";height:60px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:60px;z-index:-1}.photo-overlay{background:linear-gradient(180deg,#000c 0,#0000 40%,#0000 60%,#000c);padding:16px}.photo-container:hover .photo-overlay{opacity:1}.photo-info{gap:6px}.photo-enfant{font-size:13px;font-weight:700;text-shadow:0 2px 4px #00000080}.photo-time{font-weight:600;text-shadow:0 1px 2px #00000080}.photo-share-btn{align-items:center;align-self:flex-end;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#fffffff2,#ffffffd9);border:none;border-radius:12px;box-shadow:0 4px 12px #00000026;color:#6366f1;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);width:40px}.photo-share-btn:hover{box-shadow:0 8px 20px #0003;color:#4338ca;transform:scale(1.1) translateY(-2px)}.photo-share-blocked{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:12px;color:#ffffffb3;display:flex;height:40px;justify-content:center;width:40px}.photo-caption{color:#64748b;font-weight:500;padding:12px 6px 0;word-break:break-word}.photos-empty-state{color:#64748b;padding:60px 20px;text-align:center}.photos-empty-state svg{filter:drop-shadow(0 4px 8px rgba(0,0,0,.1));margin-bottom:24px;opacity:.3}.photos-empty-state p{font-size:16px;font-weight:500;line-height:1.6;margin:0}.photos-empty-state small{font-size:14px;font-style:italic;opacity:.7}.photos-quota-message{align-items:center;background:linear-gradient(135deg,#fef3c7,#fbbf24 8%,#fef3c7);border:1px solid #f59e0b;border-radius:12px;box-shadow:0 4px 12px #f59e0b26;display:flex;font-size:14px;gap:12px;margin-top:16px;overflow:hidden;padding:16px 20px;position:relative}.photos-quota-message:before{background:linear-gradient(90deg,#f59e0b,#d97706,#f59e0b);content:"";height:2px;left:0;position:absolute;right:0;top:0}.photos-quota-message span{color:#92400e;flex:1 1;font-weight:600}.photos-quota-message .upgrade-link{background:#3b82f61a;border:1px solid #3b82f633;border-radius:8px;color:#3b82f6;font-size:13px;font-weight:700;padding:8px 16px;text-decoration:none;transition:all .3s ease}.photos-quota-message .upgrade-link:hover{background:#3b82f633;box-shadow:0 4px 8px #3b82f64d;transform:translateY(-1px)}.photos-limitation-info{background:linear-gradient(135deg,#e0f2fe,#7dd3fc 8%,#e0f2fe);border:1px solid #0ea5e9;border-radius:10px;color:#0369a1;font-size:13px;font-weight:600;margin-top:12px;padding:12px 16px;text-align:center}.view-all-photos{border-top:1px solid #f1f5f9;margin-top:24px;padding-top:20px}.view-all-link{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:12px;color:#6366f1;display:block;font-weight:600;padding:16px 20px;text-align:center;transition:all .3s ease}.view-all-link:hover{background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 8px 20px #6366f14d;color:#fff;transform:translateY(-2px)}.view-all-link small{font-weight:500;margin-top:4px;opacity:.8}.share-modal-overlay{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#0009}.share-modal{animation:modalSlideIn .4s cubic-bezier(.34,1.56,.64,1);box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff1a;max-height:90vh;max-width:520px;overflow:hidden;position:relative;z-index:10000}body.modal-open{overflow:hidden;position:fixed;width:100%}.share-modal-header{background:linear-gradient(135deg,#fefefe,#f9fafb);border-bottom:1px solid #e5e7eb;padding:28px 28px 20px;position:sticky;top:0;z-index:10001}.share-modal-header h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1f2937,#4b5563);-webkit-background-clip:text;background-clip:text;color:#1f2937}.close-btn{align-items:center;background:#f3f4f6;border-radius:12px;color:#6b7280;display:flex;height:40px;justify-content:center;transition:all .3s ease;width:40px}.close-btn:hover{background:#e5e7eb;color:#374151;transform:scale(1.05)}.share-modal-body{max-height:calc(90vh - 180px);overflow-y:auto;padding:28px;scrollbar-color:#d1d5db #f9fafb;scrollbar-width:thin}.share-modal-body::-webkit-scrollbar{width:6px}.share-modal-body::-webkit-scrollbar-track{background:#f9fafb}.share-modal-body::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.photo-preview{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;margin-bottom:28px}.preview-image{border-radius:12px;box-shadow:0 8px 20px #0000001f;height:88px;object-fit:cover;width:88px}.preview-info strong{color:#1f2937;font-size:16px;font-weight:700;margin-bottom:6px}.preview-info span{color:#6b7280;font-weight:500}.form-label{font-size:15px;margin-bottom:10px}.form-control{border:2px solid #e5e7eb;font-family:inherit;padding:14px 16px;transition:all .3s ease}.form-control:focus{box-shadow:0 0 0 4px #6366f11a;transform:translateY(-1px)}.char-count{color:#6b7280;font-size:12px;font-weight:500}.quota-indicator{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border:1px solid #d1d5db;border-radius:10px;color:#6b7280;font-size:14px;font-weight:600;margin-top:20px;padding:16px;text-align:center}.share-modal-footer{background:linear-gradient(135deg,#fafbfc,#f3f4f6);border-top:1px solid #e5e7eb;bottom:0;gap:16px;padding:20px 28px;position:sticky}.btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);height:100%;left:-100%;top:0;transition:left .5s;width:100%}.btn:hover:before{left:100%}.btn-primary{box-shadow:0 4px 16px #4f46e54d}.btn-primary:hover:not(:disabled){box-shadow:0 8px 24px #4f46e566;transform:translateY(-3px)}.btn-secondary{background:#f8fafc;color:#4b5563}.btn-secondary:hover{background:#f1f5f9;border-color:#cbd5e1}@media (max-width:768px){.photos-grid{gap:16px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.photos-recentes-card .card-body,.photos-recentes-card .card-header{padding:20px}.photos-header{align-items:flex-start;flex-direction:column;gap:16px}.photos-quota-message{flex-direction:column;gap:12px;padding:16px;text-align:center}.share-modal{border-radius:0;margin:0;max-height:100vh}.share-modal-overlay{padding:0}.photo-preview{align-items:center;text-align:center}.photo-preview,.share-modal-footer{flex-direction:column}.share-modal-footer .btn{justify-content:center;width:100%}.view-all-link{padding:12px 16px}}@media (max-width:480px){.photos-grid{gap:12px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.photos-recentes-card .card-body,.photos-recentes-card .card-header{padding:16px}.photo-share-btn{height:36px;width:36px}.photo-overlay{padding:12px}}.dashboard-container{background:#f8fafc;margin:0 auto;max-width:1200px;min-height:100vh;padding:24px}.stats-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(4,1fr);margin-bottom:32px}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 20px #00000014;gap:16px;padding:24px;transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 8px 25px #0000001f;transform:translateY(-2px)}.stat-card.photos{background:linear-gradient(135deg,#fce7f3,#fbcfe8);color:#be185d}.stat-icon{background:#fff3;border-radius:12px}.stat-number{font-size:28px}.stat-label{opacity:.8}.content-grid,.section-full{margin-bottom:32px}.content-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}.content-section{background:#fff;border-radius:16px;overflow:hidden}.social-cta{background:linear-gradient(135deg,#4facfe,#00f2fe);border-radius:20px;box-shadow:0 8px 32px #4facfe4d;margin-bottom:32px;padding:32px}.social-content{align-items:center;color:#fff;display:flex;justify-content:space-between}.social-text h3{font-size:24px;font-weight:700;margin:0 0 8px}.social-text p{font-size:16px;margin:0 0 16px;opacity:.9}.social-features{display:flex;font-size:14px;gap:20px;opacity:.8}.social-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;border-radius:12px;color:#fff;display:flex;font-weight:600;gap:8px;padding:16px 24px;text-decoration:none;transition:all .3s}.social-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.welcome-section{background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;padding:48px;text-align:center}.welcome-emoji{font-size:64px;margin-bottom:24px}.welcome-content h3{color:#6366f1;font-size:24px;font-weight:700;margin-bottom:16px}.welcome-content p{color:#6b7280;font-size:16px;margin-bottom:32px}.welcome-actions{display:flex;gap:16px;justify-content:center}.btn-primary:hover{box-shadow:0 6px 20px #ff9a9e66}@media (max-width:1024px){.content-grid{gap:20px;grid-template-columns:1fr}.social-content{flex-direction:column;gap:24px;text-align:center}.social-features{justify-content:center}}@media (max-width:768px){.dashboard-container{padding:16px}.stats-grid{gap:16px;grid-template-columns:repeat(2,1fr)}.dashboard-header{padding:24px}.header-content{flex-direction:column;gap:20px;text-align:center}.header-text h1{font-size:24px}.header-text p{font-size:16px}.welcome-actions{align-items:center;flex-direction:column}.toast{left:16px;min-width:auto;right:16px}}:root{--shadow-toast:0 10px 40px #00000026}.enfants-list-container{background:#f8fafc;margin:0 auto;max-width:1200px;min-height:100vh;padding:24px}.toast{animation:simpleSlideIn .3s ease-out forwards;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow-toast);gap:12px;opacity:0;transform:translateX(20px)}.toast-success{background:var(--gradient-success)}@keyframes simpleSlideIn{to{opacity:1;transform:translateX(0)}}.enfants-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(380px,1fr))}.enfant-card{background:linear-gradient(135deg,#fff,#f8fafc);background:var(--gradient-card);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:16px;border-radius:var(--border-radius);box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow-soft);overflow:hidden;position:relative;transition:transform .2s ease,box-shadow .2s ease}.enfant-card:before{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);content:"";height:4px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .2s ease}.enfant-card:hover{box-shadow:0 12px 40px #667eea26;box-shadow:var(--shadow-hover);transform:translateY(-4px)}.enfant-card:hover:before{opacity:1}.enfant-card-header{align-items:center;background:linear-gradient(135deg,#fafbfc,#fff);border-bottom:2px solid #f1f5f9;display:flex;gap:20px;padding:28px 28px 20px}.enfant-avatar{border:3px solid #fffc;border-radius:16px;box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow-soft);height:72px;transition:transform .2s ease;width:72px}.enfant-card:hover .enfant-avatar{transform:scale(1.03)}.enfant-info{flex:1 1;min-width:0}.enfant-info h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:#1f2937;color:var(--text-primary);font-size:22px;font-weight:700;margin:0 0 12px}.enfant-meta{display:flex;flex-wrap:wrap;gap:16px}.meta-item{align-items:center;background:#667eea0d;border:1px solid #667eea1a;border-radius:8px;color:#6b7280;color:var(--text-secondary);display:flex;font-size:14px;font-weight:500;gap:6px;padding:4px 8px}.meta-item svg{color:#667eea}.enfant-card-body{padding:20px 28px}.info-section{margin-bottom:20px}.info-section:last-child{margin-bottom:0}.info-label{align-items:center;color:#6b7280;color:var(--text-secondary);display:flex;font-size:14px;font-weight:600;gap:8px;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.info-label svg{color:#667eea}.info-value{color:#1f2937;color:var(--text-primary);font-size:14px;line-height:1.5}.accompagnateur-tag{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border:1px solid #4338ca33;border-radius:12px;color:#4338ca;display:inline-block;font-size:12px;font-weight:600;margin-bottom:8px;margin-right:8px;padding:6px 12px;transition:background .2s ease}.accompagnateur-tag:hover{background:linear-gradient(135deg,#c7d2fe,#a5b4fc)}.more-count{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:12px;color:#6b7280;color:var(--text-secondary);display:inline-block;font-size:12px;font-weight:600;padding:6px 12px}.notes-preview{-webkit-line-clamp:2;-webkit-box-orient:vertical;background:linear-gradient(135deg,#fef7ff,#f3e8ff);border-left:3px solid #8b5cf6;border-radius:8px;border-radius:var(--border-radius-small);color:#7c2d92;display:-webkit-box;font-style:italic;line-height:1.6;overflow:hidden;padding:12px 16px;text-overflow:ellipsis}.text-muted{color:#9ca3af;font-size:13px;font-style:italic}.enfant-card-actions{background:linear-gradient(135deg,#fafbfc,#fff);border-top:2px solid #f1f5f9;display:flex;gap:12px;padding:20px 28px 28px}.empty-state-card{background:linear-gradient(135deg,#fff,#f8fafc);background:var(--gradient-card);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:20px;border-radius:var(--border-radius-large);box-shadow:0 8px 25px #0000001f;box-shadow:var(--shadow-medium);overflow:hidden;padding:64px 40px;position:relative;text-align:center}.empty-state-card:before{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);content:"";height:4px;left:0;position:absolute;right:0;top:0}.empty-state-content{margin:0 auto;max-width:500px}.empty-state-icon{color:#9ca3af;color:var(--text-muted);margin-bottom:28px}.empty-state-content h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:#1f2937;color:var(--text-primary);font-size:28px;font-weight:700;margin:0 0 16px}.empty-state-content p{color:#6b7280;color:var(--text-secondary);font-size:16px;line-height:1.6;margin:0 0 32px}.btn{transition:transform .2s ease,box-shadow .2s ease}.btn-primary:hover{box-shadow:0 6px 20px #ff9a9e4d;transform:translateY(-1px)}.btn-small{padding:10px 16px}.btn svg:last-child{transition:transform .2s ease}.btn:hover svg:last-child{transform:translateX(2px)}@media (max-width:1024px){.enfants-grid{gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.enfant-card-header{padding:24px 24px 16px}.enfant-card-body{padding:16px 24px}.enfant-card-actions{padding:16px 24px 24px}}@media (max-width:768px){.enfants-list-container{padding:16px}.dashboard-header{padding:24px}.header-content{flex-direction:column;gap:20px;text-align:center}.header-text h1{font-size:24px}.header-text p{font-size:16px}.header-actions{flex-direction:column;gap:12px;width:100%}.header-actions .btn{justify-content:center;width:100%}.enfants-grid{gap:16px;grid-template-columns:1fr}.enfant-card-header{flex-direction:column;gap:16px;padding:20px;text-align:center}.enfant-avatar{height:64px;width:64px}.enfant-info h3{font-size:20px}.enfant-meta{justify-content:center}.enfant-card-body{padding:16px 20px}.enfant-card-actions{flex-direction:column;padding:16px 20px 20px}.toast{left:16px;min-width:auto;right:16px}.empty-state-card{padding:40px 24px}.empty-state-content h3{font-size:24px}.empty-state-content p{font-size:15px}}@media (max-width:480px){.enfants-list-container{padding:12px}.dashboard-header{padding:20px}.header-text h1{font-size:20px}.header-text p{font-size:14px}.enfant-card-header{padding:16px}.enfant-avatar{height:56px;width:56px}.enfant-info h3{font-size:18px}.enfant-card-body{padding:12px 16px}.enfant-card-actions{padding:12px 16px 16px}.btn{padding:10px 16px}.btn,.meta-item{font-size:13px}.accompagnateur-tag{font-size:11px;padding:4px 8px}}.btn:focus-visible,.enfant-card:focus-visible{outline:2px solid #667eea;outline-offset:2px}:root{--gradient-secondary:linear-gradient(135deg,#4facfe,#00f2fe);--gradient-premium:linear-gradient(135deg,#ff9a9e,#fecfef);--gradient-social:linear-gradient(135deg,#fef3c7,#fde68a);--shadow-premium:0 8px 32px #ff9a9e4d;--blur-glass:blur(20px);--border-light:#f1f5f9;--bg-card:#fff;--primary-light:#667eea1a}.page-container{background:#f8fafc;background:var(--bg-light);margin:0 auto;max-width:1200px;min-height:100vh;padding:32px 24px}.page-container .header{background:linear-gradient(135deg,#667eea,#764ba2)!important;background:var(--gradient-primary)!important;color:#fff!important}.header{align-items:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);border-radius:20px;box-shadow:0 8px 32px #667eea4d;color:#fff;display:flex;justify-content:space-between;margin-bottom:32px;overflow:hidden;padding:32px;position:relative}.header:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cpattern id='a' width='100' height='100' patternUnits='userSpaceOnUse'%3E%3Ccircle cx='20' cy='20' r='1' fill='%23fff' opacity='.1'/%3E%3Ccircle cx='80' cy='40' r='1' fill='%23fff' opacity='.1'/%3E%3Ccircle cx='40' cy='80' r='1' fill='%23fff' opacity='.1'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.header h1{font-size:32px;font-weight:700;margin:0 0 8px}.header h1,.header p{position:relative;z-index:1}.header p{font-size:16px;margin:0;opacity:.9}.header-actions{gap:12px}.header .d-flex.align-items-center.gap-3,.header-actions{position:relative;z-index:1}.btn-primary{background:var(--gradient-premium);box-shadow:0 4px 15px #ff9a9e66}.btn-primary:hover{box-shadow:0 8px 32px #ff9a9e4d;box-shadow:var(--shadow-premium)}.btn-secondary:hover{transform:translateY(-1px)}.btn-ghost{background:#ffffff1a;border:1px solid #fff3;color:#fff}.btn-ghost:hover{background:#fff3}.btn-icon{height:44px;justify-content:center;padding:12px;width:44px}.btn-small{border-radius:8px;padding:8px 14px}.btn:disabled{transform:none!important}.card{background:var(--bg-card);border:1px solid #f1f5f9;border:1px solid var(--border-light);border-radius:20px;box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow-soft);transition:all .3s}.card:hover{box-shadow:0 8px 25px #0000001f;box-shadow:var(--shadow-medium);transform:translateY(-2px)}.card-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--border-light);padding:24px 32px}.card-title{color:#1e293b;color:var(--text-primary);font-size:20px;font-weight:700}.card-body{padding:32px}.avatar{align-items:center;border:2px solid #fffc;border-radius:16px;box-shadow:0 4px 12px #0000001a;display:flex;flex-shrink:0;height:48px;justify-content:center;margin-right:16px;width:48px}.avatar-girl{background:linear-gradient(135deg,#fce4ec,#f8bbd9);color:#ad1457}.avatar-boy{background:linear-gradient(135deg,#e3f2fd,#90caf9);color:#1565c0}.avatar-neutral{background:linear-gradient(135deg,#f5f5f5,#e0e0e0);color:#616161}.form-group{margin-bottom:24px}.form-label{color:#1e293b;color:var(--text-primary);font-weight:600;margin-bottom:8px}.form-label.required:after{color:#ef4444;color:var(--error-color);content:" *"}.form-control{background:#fff;background:var(--bg-white);border:2px solid #e2e8f0;border:2px solid var(--border-color);border-radius:12px;color:#1e293b;color:var(--text-primary);padding:16px 20px;transition:all .3s}.form-control:focus{background:#fafbff;border-color:#667eea;border-color:var(--primary-color);box-shadow:0 0 0 4px #667eea1a;box-shadow:0 0 0 4px var(--primary-light)}.form-control::placeholder{color:#64748b;color:var(--text-muted)}textarea.form-control{line-height:1.5;min-height:120px;resize:vertical}.form-text{color:#64748b;color:var(--text-muted);font-size:12px;line-height:1.4;margin-top:6px}.radio-group{grid-gap:12px;display:grid;gap:12px;margin-top:8px}.radio-option{align-items:flex-start;background:#fff;background:var(--bg-white);border:2px solid #e2e8f0;border:2px solid var(--border-color);border-radius:16px;cursor:pointer;display:flex;gap:16px;overflow:hidden;padding:20px;position:relative;transition:all .3s ease}.radio-option:before{background:linear-gradient(135deg,#0000,#667eea05);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s}.radio-option:hover:before{opacity:1}.radio-option:hover{border-color:#667eea;border-color:var(--primary-color);box-shadow:0 4px 12px #667eea1a;transform:translateY(-1px)}.radio-option input[type=radio]{accent-color:#667eea;accent-color:var(--primary-color);cursor:pointer;height:20px;margin:0;width:20px}.radio-option:has(input[type=radio]:checked){background:#667eea1a;background:var(--primary-light);border-color:#667eea;border-color:var(--primary-color);box-shadow:0 4px 12px #667eea26}.radio-option:has(input[type=radio]:checked):before{background:linear-gradient(135deg,#667eea0d,#764ba20d);opacity:1}.radio-content{flex:1 1;position:relative;z-index:1}.radio-title{color:#1e293b;color:var(--text-primary);font-size:15px;font-weight:600;margin-bottom:4px}.radio-description{color:#64748b;color:var(--text-muted);font-size:13px;line-height:1.4}.radio-option input[type=radio]:checked+.radio-content .radio-title{color:#667eea;color:var(--primary-color)}.grid{grid-gap:24px}.gap-6,.grid{gap:24px}.meta-info{align-items:center;color:#64748b;color:var(--text-muted);display:flex;font-size:14px;font-weight:500;gap:6px}.notes-section{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-left:4px solid #667eea;border-left:4px solid var(--primary-color);border-radius:12px;margin-bottom:20px;padding:16px}.notes-title{align-items:center;color:#475569;color:var(--text-secondary);display:flex;font-size:14px;font-weight:600;gap:6px;margin-bottom:6px}.notes-content{color:#64748b;color:var(--text-muted);font-size:14px;line-height:1.5}.form-actions{border-top:1px solid #f1f5f9;border-top:1px solid var(--border-light);display:flex;gap:16px;justify-content:flex-end;margin-top:40px;padding-top:32px}.empty-state{padding:64px 32px}.empty-state-icon{margin-bottom:24px;opacity:.6}.empty-state h3{font-size:24px;margin-bottom:16px}.empty-state p{margin-bottom:32px;margin-left:auto;margin-right:auto;max-width:480px}.tips-grid{grid-gap:20px;display:grid;gap:20px;margin-top:20px}.tip{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:16px;padding:20px;transition:transform .2s}.tip:hover{box-shadow:0 4px 12px #0ea5e91a;transform:translateY(-2px)}.tip strong{color:#0c4a6e;display:block;font-size:14px;font-weight:700;margin-bottom:6px}.tip p{color:#0369a1;font-size:14px;line-height:1.5;margin:0}.alert{align-items:center;border-radius:12px;display:flex;font-weight:500;gap:12px;margin-bottom:24px;padding:16px 20px}.alert-success{background:linear-gradient(135deg,#ecfdf5,#d1fae5);color:#047857}.alert-error{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca;color:#dc2626}.alert svg{flex-shrink:0}.gap-3{gap:12px}.text-muted{color:#64748b;color:var(--text-muted)}@media (max-width:768px){.page-container{padding:20px 16px}.header{flex-direction:column;gap:20px;padding:24px;text-align:center}.header h1{font-size:24px}.header-actions{flex-wrap:wrap;justify-content:center}.grid-2{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions .btn{justify-content:center;width:100%}.tips-grid{gap:16px}.tip{padding:16px}.card-body{padding:24px}.card-header{padding:20px 24px}.empty-state{padding:48px 20px}.empty-state h3{font-size:20px}}:root{--gradient-card:linear-gradient(135deg,#fff,#f8fafc);--gradient-hero:linear-gradient(135deg,#4facfe,#00f2fe);--gradient-success:linear-gradient(135deg,#d1fae5,#a7f3d0);--gradient-warning:linear-gradient(135deg,#fef3c7,#fde68a);--gradient-girl:linear-gradient(135deg,#fce7f3,#fbcfe8);--gradient-boy:linear-gradient(135deg,#dbeafe,#bfdbfe);--gradient-nounou:linear-gradient(135deg,#d1fae5,#a7f3d0);--shadow-hover:0 12px 40px #667eea26;--shadow-premium:0 8px 32px #667eea4d;--border-radius-small:8px;--border-radius-large:20px;--text-primary:#1f2937;--text-secondary:#6b7280;--text-muted:#9ca3af;--border-light:#e2e8f0}.enfant-detail-container{background:#f8fafc;margin:0 auto;max-width:1200px;min-height:100vh;padding:24px}.dashboard-header{background:var(--gradient-primary);border-radius:var(--border-radius-large);box-shadow:var(--shadow-premium);position:relative}.dashboard-header:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cpattern id='a' width='20' height='20' patternUnits='userSpaceOnUse'%3E%3Ccircle cx='10' cy='10' r='1' fill='%23fff' opacity='.1'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.dashboard-header>*{position:relative;z-index:1}.header-text{align-items:center;display:flex;gap:16px}.header-text h1{-webkit-text-fill-color:#0000;background:linear-gradient(45deg,#fff,#f0f9ff);-webkit-background-clip:text;background-clip:text}.back-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;border-radius:50%;color:#fff;display:flex;height:44px;justify-content:center;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);width:44px}.back-btn:hover{background:#ffffff4d;box-shadow:0 8px 25px #fff3;transform:translateX(-3px) scale(1.05)}.enfant-content-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:400px 1fr}.enfant-left-column,.enfant-right-column{display:flex;flex-direction:column;gap:24px}.profil-card{background:linear-gradient(135deg,#fff,#f8fafc);background:var(--gradient-card);border:1px solid var(--border-light);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);overflow:hidden;padding:32px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.profil-card:hover{border-color:#667eea33;box-shadow:0 8px 25px #0000001f;box-shadow:var(--shadow-medium);transform:translateY(-2px)}.profil-card:before{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);content:"";height:4px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s}.profil-card:hover:before{opacity:1}.profil-card-header{border-bottom:2px solid #f1f5f9;margin-bottom:24px;padding-bottom:16px}.profil-card-header h3{align-items:center;color:#1f2937;color:var(--text-primary);display:flex;font-size:20px;font-weight:700;gap:12px}.profil-card-header h3 svg{color:#667eea}.profil-hero-content{gap:32px}.profil-avatar-section{flex-direction:column;gap:20px;text-align:center}.profil-avatar{border:4px solid #fffc;box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow-soft);height:120px;overflow:hidden;transition:all .3s;width:120px}.profil-avatar:hover{box-shadow:0 12px 40px #667eea26;box-shadow:var(--shadow-hover);transform:scale(1.05)}.profil-avatar img{height:100%;object-fit:cover;width:100%}.profil-user-info h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:#1f2937;color:var(--text-primary);font-size:28px;margin:0 0 12px}.profil-user-badges{justify-content:center}.profil-role-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #fff3;font-size:13px;padding:6px 16px}.profil-contact-grid{gap:20px}.profil-contact-item{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #f1f5f9;border-radius:8px;border-radius:var(--border-radius-small);gap:16px;padding:16px;transition:all .3s}.profil-contact-item:hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-color:#667eea33;transform:translateX(4px)}.profil-contact-icon{background:#667eea1a;border-radius:12px;color:#667eea;flex-shrink:0;height:48px;width:48px}.profil-contact-label{color:#9ca3af;color:var(--text-muted);font-size:13px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.profil-contact-value{color:#1f2937;color:var(--text-primary);font-weight:600;line-height:1.4}.profile-notes{background:linear-gradient(135deg,#fef7ff,#f3e8ff);border:1px solid #e9d5ff;border-radius:8px;border-radius:var(--border-radius-small);padding:20px}.profile-notes h3{align-items:center;color:#6b21a8;display:flex;font-size:16px;font-weight:600;gap:8px;margin:0 0 12px}.profile-notes h3:before{content:"💡";font-size:18px}.profile-notes p{color:#7c2d92;font-weight:500;line-height:1.6;margin:0}.quick-actions-grid{display:flex;flex-direction:column;gap:16px}.quick-action-card{align-items:center;background:linear-gradient(135deg,#fff,#f8fafc);background:var(--gradient-card);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--border-radius-small);color:inherit;cursor:pointer;display:flex;gap:16px;overflow:hidden;padding:20px;position:relative;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.quick-action-card:before{background:linear-gradient(90deg,#0000,#667eea0d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.quick-action-card:hover:before{left:100%}.quick-action-card:hover{border-color:#667eea4d;box-shadow:0 12px 40px #667eea26;box-shadow:var(--shadow-hover);transform:translateY(-3px) scale(1.02)}.action-icon{align-items:center;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border-radius:14px;color:#4f46e5;display:flex;flex-shrink:0;height:56px;justify-content:center;transition:all .3s;width:56px}.quick-action-card:hover .action-icon{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;transform:rotate(5deg) scale(1.1)}.action-content{flex:1 1}.action-content h4{color:#1f2937;color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 6px}.action-content p{color:#6b7280;color:var(--text-secondary);font-size:14px;line-height:1.4;margin:0}.action-arrow{color:#9ca3af;color:var(--text-muted);flex-shrink:0;transition:all .3s}.quick-action-card:hover .action-arrow{color:#667eea;transform:translateX(4px)}.people-list{display:flex;flex-direction:column;gap:16px}.person-item{align-items:center;background:linear-gradient(135deg,#fafbfc,#f8fafc);border:1px solid #f1f5f9;border-radius:8px;border-radius:var(--border-radius-small);display:flex;gap:16px;padding:20px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.person-item:hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-color:#667eea33;box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow-soft);transform:translateY(-1px)}.person-item.nounou-item{background:linear-gradient(135deg,#d1fae5,#a7f3d0);background:var(--gradient-nounou);border-color:#86efac}.person-item.nounou-item:hover{background:linear-gradient(135deg,#a7f3d0,#86efac);box-shadow:0 4px 20px #10b98133}.person-avatar{border:2px solid #fffc;border-radius:14px;box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow-soft);flex-shrink:0;height:56px;overflow:hidden;transition:all .3s;width:56px}.person-item:hover .person-avatar{box-shadow:0 8px 25px #0000001f;box-shadow:var(--shadow-medium);transform:scale(1.05)}.person-avatar img{height:100%;object-fit:cover;width:100%}.avatar-placeholder{align-items:center;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#4f46e5;display:flex;font-size:20px;font-weight:700;height:100%;justify-content:center;width:100%}.person-avatar.nounou .avatar-placeholder{background:linear-gradient(135deg,#fef3c7,#fde68a);background:var(--gradient-warning);color:#92400e}.person-info{flex:1 1}.person-info h4{color:#1f2937;color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 8px}.person-role{align-items:center;border-radius:20px;display:inline-flex;font-size:12px;font-weight:600;gap:4px;margin-bottom:8px;padding:4px 12px}.person-role.parent{background:linear-gradient(135deg,#fef3c7,#fde68a);background:var(--gradient-warning);color:#92400e}.person-role.nounou{background:linear-gradient(135deg,#d1fae5,#a7f3d0);background:var(--gradient-success);color:#047857}.person-role.accompagnateur{background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#5b21b6}.date-ajout,.horaires{color:#6b7280;color:var(--text-secondary);display:block;font-size:12px;font-weight:500;margin-bottom:4px}.permissions-summary{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.permission-badge{background:#667eea1a;border:1px solid #667eea33;border-radius:12px;color:#667eea;font-size:11px;font-weight:600;padding:3px 8px}.person-actions{align-items:center;display:flex;gap:8px}.statut-badge{border:1px solid;border-radius:16px;font-size:12px;font-weight:600;padding:6px 12px}.statut-badge.actif{background:linear-gradient(135deg,#d1fae5,#a7f3d0);background:var(--gradient-success);border-color:#86efac;color:#047857}.statut-badge.nounou-actif{background:linear-gradient(135deg,#fef3c7,#fde68a);background:var(--gradient-warning);border-color:#fcd34d;color:#92400e}.empty-state{background:linear-gradient(135deg,#fafbfc,#f8fafc);border:2px dashed #e2e8f0;border-radius:8px;border-radius:var(--border-radius-small);color:#6b7280;color:var(--text-secondary);padding:48px 24px}.empty-icon{display:block;font-size:56px;margin-bottom:20px;opacity:.6}.empty-state p{color:#6b7280;color:var(--text-secondary);font-size:16px;font-weight:600;margin:0 0 8px}.empty-state small{color:#9ca3af;color:var(--text-muted);display:block;font-size:13px;margin-bottom:20px}.btn{border-radius:8px;border-radius:var(--border-radius-small);overflow:hidden;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn:before{background:#fff3;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s;width:0}.btn:hover:before{height:300px;width:300px}.btn-primary{background:linear-gradient(135deg,#ff9a9e,#fecfef);box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow-soft)}.btn-primary:hover{box-shadow:0 8px 32px #ff9a9e66}.btn-secondary:hover{box-shadow:0 8px 25px #fff3}.btn-small{font-size:13px;padding:8px 16px}.error-container,.loading-container{align-items:center;display:flex;flex-direction:column;gap:20px;justify-content:center;min-height:60vh}.spin{animation:spin 2s linear infinite;color:#667eea}.error-card{background:linear-gradient(135deg,#fff,#f8fafc);background:var(--gradient-card);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:20px;border-radius:var(--border-radius-large);box-shadow:0 8px 25px #0000001f;box-shadow:var(--shadow-medium);max-width:400px;padding:48px;text-align:center}.error-icon{color:#ef4444;margin-bottom:24px}.error-card h3{color:#1f2937;color:var(--text-primary);font-size:24px;font-weight:700;margin:0 0 16px}.error-card p{color:#6b7280;color:var(--text-secondary);font-size:16px;line-height:1.5;margin:0 0 32px}@media (max-width:1024px){.enfant-content-grid{gap:24px;grid-template-columns:1fr}.enfant-left-column{order:1}.enfant-right-column{order:2}.profil-card{padding:24px}}@media (max-width:768px){.enfant-detail-container{padding:16px}.dashboard-header{padding:24px}.header-content{flex-direction:column;gap:20px;text-align:center}.header-text{flex-direction:column;gap:12px}.header-text h1{font-size:24px}.header-text p{font-size:16px}.header-actions{flex-direction:column;gap:12px;width:100%}.header-actions .btn{justify-content:center;width:100%}.profil-card{padding:20px}.profil-card-header{align-items:flex-start;flex-direction:column;gap:16px}.profil-card-header h3{font-size:18px}.profil-avatar{height:100px;width:100px}.profil-user-info h2{font-size:24px}.person-item{flex-direction:column;padding:16px}.person-info,.person-item{text-align:center}.permissions-summary,.person-actions{justify-content:center}.quick-action-card{padding:16px}.action-icon{height:48px;width:48px}.action-content h4{font-size:15px}.action-content p{font-size:13px}}@media (max-width:480px){.enfant-detail-container{padding:12px}.dashboard-header{padding:20px}.header-text h1{font-size:20px}.header-text p{font-size:14px}.profil-card{padding:16px}.profil-avatar{height:80px;width:80px}.profil-user-info h2{font-size:20px}.person-avatar{height:48px;width:48px}.avatar-placeholder{font-size:16px}.quick-actions-grid{gap:12px}.action-icon{height:40px;width:40px}.btn{font-size:13px;padding:10px 16px}}.profil-card{transition:transform .2s ease,box-shadow .2s ease}.profil-card:first-child{animation-delay:.1s}.profil-card:nth-child(2){animation-delay:.2s}.profil-card:nth-child(3){animation-delay:.3s}.profil-card:nth-child(4){animation-delay:.4s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.person-item:hover .person-info h4,.quick-action-card:hover .action-content h4{color:#667eea}.back-btn:focus-visible,.btn:focus-visible,.quick-action-card:focus-visible{outline:2px solid #667eea;outline-offset:2px}@media print{.btn,.dashboard-header,.header-actions,.quick-action-card{display:none!important}.enfant-detail-container{background:#fff;padding:0}.profil-card{border:1px solid #ddd;box-shadow:none;break-inside:avoid;page-break-inside:avoid}}.activites-page{--gradient-primary:linear-gradient(135deg,#667eea,#764ba2);--gradient-premium:linear-gradient(135deg,#ff9a9e,#fecfef);--shadow-soft:0 4px 20px #00000014;--shadow-medium:0 8px 25px #0000001f;--border-radius:16px;--border-color:#e2e8f0;--text-primary:#1e293b;--text-secondary:#475569;--text-muted:#64748b;--bg-white:#fff;--bg-light:#f8fafc;--primary-color:#667eea;--success-color:#10b981;--error-color:#ef4444;--warning-color:#f59e0b}.activites-page .header-left{align-items:center;display:flex;gap:20px}.activites-page .date-selector{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);margin-bottom:24px;padding:20px 24px}.activites-page .date-content{align-items:center;display:flex;flex-wrap:wrap;gap:20px}.activites-page .date-label{align-items:center;color:var(--text-secondary);display:flex;font-size:15px;font-weight:600;gap:8px}.activites-page .date-input{background:var(--bg-white);border:2px solid var(--border-color);border-radius:12px;font-size:15px;font-weight:500;padding:12px 16px;transition:all .3s ease}.activites-page .date-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 4px #667eea1a;outline:none}.activites-page .date-summary{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px;color:var(--text-muted);font-size:14px;font-weight:500;margin-left:auto;padding:8px 16px}.activites-page .view-selector{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);margin-bottom:24px;padding:24px}.activites-page .view-header h3{color:var(--text-primary);font-size:20px;font-weight:700;margin:0 0 20px}.activites-page .view-controls{display:flex;flex-direction:column;gap:24px}.activites-page .child-selector,.activites-page .mode-selector{display:flex;flex-direction:column;gap:12px}.activites-page .selector-label{color:var(--text-secondary);font-size:14px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.activites-page .selector-buttons{display:flex;flex-wrap:wrap;gap:12px}.activites-page .selector-btn{align-items:center;background:var(--bg-white);border:2px solid var(--border-color);border-radius:12px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:10px;padding:12px 20px;transition:all .3s ease}.activites-page .selector-btn:hover{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-color:var(--primary-color);transform:translateY(-1px)}.activites-page .selector-btn.active{background:var(--primary-color);border-color:var(--primary-color);box-shadow:0 4px 12px #667eea4d;color:#fff}.activites-page .child-avatar{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:28px;justify-content:center;width:28px}.activites-page .global-summary{border-top:1px solid var(--border-color);margin-top:20px;padding-top:20px}.activites-page .summary-label{color:var(--text-secondary);font-size:14px;font-weight:600;letter-spacing:.5px;margin-bottom:16px;text-transform:uppercase}.activites-page .summary-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.activites-page .summary-card{border:1px solid;border-radius:12px;padding:20px;transition:all .3s ease}.activites-page .summary-card:hover{box-shadow:0 8px 24px #0000001a;transform:translateY(-2px)}.activites-page .summary-header{align-items:center;display:flex;gap:12px;margin-bottom:8px}.activites-page .summary-avatar{align-items:center;border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:700;height:32px;justify-content:center;width:32px}.activites-page .summary-count{color:var(--text-muted);font-size:14px;font-weight:500}.activites-page .timeline-container{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);overflow:hidden}.activites-page .timeline-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid var(--border-color);padding:24px}.activites-page .timeline-header h3{color:var(--text-primary);font-size:20px;font-weight:700;margin:0}.activites-page .timeline-header span{color:var(--primary-color);font-weight:600}.activites-page .timeline-content{padding:32px 24px;position:relative}.activites-page .timeline-content:before{background:linear-gradient(135deg,var(--border-color) 0,#f1f5f9 100%);border-radius:2px;bottom:0;content:"";left:44px;position:absolute;top:0;width:3px}.activites-page .timeline-item{cursor:pointer;margin-bottom:24px;padding-left:80px;position:relative;transition:all .3s ease}.activites-page .timeline-item.expanded{margin-bottom:32px}.activites-page .timeline-marker{align-items:center;border:3px solid #fff;border-radius:50%;box-shadow:0 4px 12px #00000026;color:#fff;display:flex;height:40px;justify-content:center;left:26px;position:absolute;top:16px;width:40px;z-index:1}.activites-page .timeline-marker.repas{background:linear-gradient(135deg,#10b981,#059669)}.activites-page .timeline-marker.sommeil{background:linear-gradient(135deg,#6366f1,#4f46e5)}.activites-page .timeline-marker.change{background:linear-gradient(135deg,#f59e0b,#d97706)}.activites-page .timeline-marker.medicament{background:linear-gradient(135deg,#ef4444,#dc2626)}.activites-page .timeline-marker.etape{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.activites-page .timeline-marker.photo{background:linear-gradient(135deg,#ec4899,#be185d)}.activites-page .timeline-marker.note{background:linear-gradient(135deg,#6b7280,#4b5563)}.activites-page .activity-card{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);overflow:hidden;padding:24px;position:relative;transition:all .3s ease}.activites-page .timeline-item.expanded .activity-card{box-shadow:var(--shadow-medium)}.activites-page .activity-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.activites-page .activity-title{align-items:center;display:flex;gap:16px}.activites-page .activity-emoji{font-size:28px;line-height:1}.activites-page .activity-title h4{color:var(--text-primary);font-size:20px;font-weight:700;margin:0}.activites-page .activity-actions{align-items:center;display:flex;gap:8px}.activites-page .btn-delete{background:none;border:none;border-radius:4px;color:var(--error-color);cursor:pointer;opacity:.7;padding:4px;transition:all .2s ease}.activites-page .btn-delete:hover{background:#ef44441a;opacity:1}.activites-page .btn-expand{background:none;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;padding:4px;transition:all .2s ease}.activites-page .btn-expand:hover{background:#64748b1a}.activites-page .activity-meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.activites-page .child-tag{align-items:center;border:1px solid;border-radius:16px;display:inline-flex;font-size:12px;font-weight:600;gap:6px;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.activites-page .tag-dot{border-radius:50%;height:8px;width:8px}.activites-page .activity-time{color:var(--text-secondary);font-size:15px;font-weight:600;padding:4px 0}.activites-page .activity-author{color:var(--text-muted);font-size:13px;font-weight:500}.activites-page .activity-details{border-top:1px solid var(--border-color);margin-top:20px;padding-top:20px}.activites-page .detail-section{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-left:4px solid var(--primary-color);border-radius:10px;color:var(--text-secondary);font-size:14px;font-weight:500;margin-bottom:12px;padding:16px}.activites-page .photos-section{margin-bottom:16px}.activites-page .photos-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.activites-page .activity-photo{border:1px solid var(--border-color);border-radius:12px;height:120px;object-fit:cover;transition:all .2s ease;width:100%}.activites-page .activity-photo:hover{box-shadow:0 4px 12px #00000026;transform:scale(1.02)}.activites-page .photo-more{align-items:center;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border:1px solid var(--border-color);border-radius:12px;color:var(--text-muted);display:flex;font-size:14px;font-weight:600;justify-content:center}.activites-page .notes-section{margin-top:16px}.activites-page .notes-content{background:linear-gradient(135deg,#fff5f7,#fef7f0);border-left:4px solid #ff9a9e;border-radius:12px;color:var(--text-secondary);font-size:14px;font-style:italic;line-height:1.6;padding:16px 20px}.activites-page .activity-modal{align-items:center;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.activites-page .modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;bottom:0;left:0;position:absolute;right:0;top:0}.activites-page .modal-content{animation:modalSlideIn .4s cubic-bezier(.34,1.56,.64,1);background:var(--bg-white);border-radius:20px;box-shadow:0 25px 80px #0000004d;max-height:90vh;max-width:700px;overflow:hidden;position:relative;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.8) translateY(40px)}to{opacity:1;transform:scale(1) translateY(0)}}.activites-page .modal-header{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:28px}.activites-page .modal-title-section{align-items:center;display:flex;gap:20px}.activites-page .modal-child-avatar{align-items:center;border-radius:50%;box-shadow:0 6px 20px #0003;color:#fff;display:flex;font-size:20px;font-weight:700;height:56px;justify-content:center;width:56px}.activites-page .modal-title{color:var(--text-primary);font-size:22px;font-weight:700;margin:0 0 4px}.activites-page .modal-subtitle{color:var(--text-muted);font-size:14px;font-weight:500;margin:0}.activites-page .modal-close-btn{align-items:center;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border:none;border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .3s ease;width:44px}.activites-page .modal-close-btn:hover{background:linear-gradient(135deg,#e5e7eb,#d1d5db);color:var(--text-secondary);transform:scale(1.05)}.activites-page .modal-body{max-height:calc(90vh - 140px);overflow-y:auto;padding:28px}.activites-page .alert-close{background:none;border:none;border-radius:4px;color:inherit;cursor:pointer;font-size:18px;margin-left:auto;opacity:.7;padding:4px;transition:opacity .2s}.activites-page .alert-close:hover{opacity:1}@media (max-width:1024px){.activites-page .summary-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media (max-width:768px){.activites-page .header-left{align-items:flex-start;flex-direction:column;gap:16px}.activites-page .date-content{align-items:flex-start;flex-direction:column;gap:12px}.activites-page .date-summary{align-self:stretch;margin-left:0;text-align:center}.activites-page .selector-buttons{flex-direction:column}.activites-page .selector-btn{justify-content:center}.activites-page .timeline-content{padding:24px 16px}.activites-page .timeline-content:before{left:32px}.activites-page .timeline-item{padding-left:70px}.activites-page .timeline-marker{height:36px;left:14px;width:36px}.activites-page .activity-card{padding:20px}.activites-page .activity-title h4{font-size:18px}.activites-page .activity-emoji{font-size:24px}.activites-page .photos-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.activites-page .activity-photo{height:100px}}@media (max-width:480px){.activites-page .activity-meta{flex-direction:column;gap:8px}.activites-page .summary-grid{grid-template-columns:1fr}.activites-page .modal-body,.activites-page .modal-header{padding:20px}.activites-page .modal-title-section{gap:16px}.activites-page .modal-child-avatar{font-size:18px;height:48px;width:48px}}.photos-blocked{color:#ef4444;font-weight:500}.photos-grid{grid-template-columns:repeat(auto-fit,minmax(80px,1fr));max-width:300px}.activity-photo{height:80px;width:80px}.activity-photo.visible{border-color:#10b981;box-shadow:0 2px 4px #10b98133}.activity-photo.blurred{overflow:hidden;position:relative}.activity-photo.blurred .photo-image{filter:blur(8px);opacity:.6}.photo-blur-overlay{background:#00000080;border-radius:6px;font-size:10px;gap:2px}.photo-more{height:80px;width:80px}.more-blocked{align-items:center;background:#ef4444;border-radius:50%;color:#fff;display:flex;height:16px;justify-content:center;position:absolute;right:2px;top:2px;width:16px}.photos-upgrade-hint{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;display:flex;font-size:12px;gap:8px;margin-top:8px;padding:8px 12px}.photos-upgrade-hint span{color:#dc2626;flex:1 1;font-weight:500}.upgrade-link{background:#fff;border:1px solid #dbeafe;border-radius:4px;color:#1d4ed8;font-size:11px;font-weight:600;padding:4px 8px;text-decoration:none}.upgrade-link:hover{background:#dbeafe;text-decoration:none}@media (max-width:768px){.photos-grid{grid-template-columns:repeat(3,1fr);max-width:250px}.activity-photo,.photo-more{height:70px;width:70px}.photo-more{font-size:11px}}.view-all-link small{color:#6b7280;display:block;font-size:12px;font-weight:400;margin-top:2px}.photos-recentes-card .limit-banner{align-items:center;background:linear-gradient(135deg,#fef3c7,#fbbf24 10%,#fef3c7);border:1px solid #f59e0b;border-radius:8px;display:flex;font-size:13px;justify-content:space-between;margin-bottom:16px;padding:8px 12px}.photos-recentes-card .limit-banner span{color:#92400e;font-weight:500}.photos-recentes-card .limit-banner a{color:#3b82f6;font-size:12px;font-weight:600;text-decoration:none}.photos-recentes-card .limit-banner a:hover{text-decoration:underline}.view-all-photos{border-top:1px solid #e5e7eb;margin-top:16px;padding-top:16px;text-align:center}.view-all-photos .view-all-link{color:#3b82f6;display:inline-block;font-weight:500;text-decoration:none}.view-all-photos .view-all-link:hover{text-decoration:underline}.view-all-photos .view-all-link small{color:#6b7280;display:block;font-size:11px;font-style:italic;margin-top:4px}.photo-item .photo-container{aspect-ratio:1;background:#f3f4f6;border-radius:8px;overflow:hidden;position:relative}.photo-item .photo-image{height:100%;object-fit:cover;transition:transform .2s ease;width:100%}.photo-item:hover .photo-image{transform:scale(1.05)}.photo-overlay{align-items:flex-end;background:linear-gradient(180deg,#0000 0,#0000 50%,#000000b3);padding:8px}.photo-info{display:flex;flex-direction:column;gap:2px}.photo-enfant{color:#fff;font-size:12px;font-weight:600}.photo-time{color:#ffffffe6;font-size:11px;gap:4px}.photo-share-blocked,.photo-share-btn{align-items:center;background:#ffffffe6;border:none;border-radius:6px;cursor:pointer;display:flex;height:28px;justify-content:center;transition:all .2s ease;width:28px}.photo-share-btn{color:#3b82f6}.photo-share-btn:hover{background:#fff;transform:scale(1.1)}.photo-share-blocked{color:#6b7280;cursor:not-allowed;opacity:.7}@media (max-width:768px){.photos-recentes-card .limit-banner{flex-direction:column;gap:8px;text-align:center}.view-all-photos .view-all-link{font-size:14px}.photo-overlay{padding:6px}.photo-enfant{font-size:11px}.photo-time{font-size:10px}.activity-photo-container{border-radius:8px;display:inline-block;overflow:hidden;position:relative}.activity-photo-container.blurred .activity-photo{filter:blur(8px);opacity:.7}.photo-blur-overlay{background:#0009;bottom:0;color:#fff;flex-direction:column;font-weight:600;justify-content:center;left:0;position:absolute;right:0;top:0}.photo-blur-overlay,.photo-status-blur{align-items:center;display:flex;font-size:12px;gap:4px}.photo-status-blur{color:#f59e0b;font-weight:500}.photos-upgrade-message{align-items:center;background:#fef3c7;border:1px solid #f59e0b;border-radius:6px;display:flex;font-size:12px;gap:8px;margin-top:8px;padding:8px 12px}.photos-upgrade-message span{color:#92400e;flex:1 1}.upgrade-link-small{color:#3b82f6;font-size:11px;font-weight:600;text-decoration:none}.upgrade-link-small:hover{text-decoration:underline}.photo-more{position:relative}.more-blur-indicator{align-items:center;background:#000000b3;border-radius:50%;color:#fff;display:flex;height:16px;justify-content:center;position:absolute;right:2px;top:2px;width:16px}}.activity-photo-container{border-radius:8px;display:inline-block;height:100px;overflow:hidden;position:relative;width:100%}.activity-photo{border:2px solid #0000;border-radius:6px;height:100%;object-fit:cover;transition:all .2s ease;width:100%}.activity-photo-container.blurred .activity-photo{filter:blur(8px);opacity:.7}.photo-blur-overlay{align-items:center;background:#0009;bottom:0;color:#fff;display:flex;flex-direction:column;font-size:12px;font-weight:600;gap:4px;justify-content:center;left:0;position:absolute;right:0;top:0}.photos-grid{grid-gap:8px;gap:8px;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));max-width:100%}.photo-more{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border:2px dashed #9ca3af;border-radius:6px;color:#6b7280;flex-direction:column;font-size:12px;font-weight:600;height:100px;position:relative;width:100%}.more-blur-indicator,.photo-more{align-items:center;display:flex;justify-content:center}.more-blur-indicator{background:#000000b3;border-radius:50%;color:#fff;height:16px;position:absolute;right:2px;top:2px;width:16px}.photos-upgrade-message{align-items:center;background:#fef3c7;border:1px solid #f59e0b;border-radius:6px;display:flex;font-size:12px;gap:8px;margin-top:8px;padding:8px 12px}.photos-upgrade-message span{color:#92400e;flex:1 1}.upgrade-link-small{color:#3b82f6;font-size:11px;font-weight:600;text-decoration:none}.upgrade-link-small:hover{text-decoration:underline}.photo-status-blur{align-items:center;color:#f59e0b;display:flex;font-size:12px;font-weight:500;gap:4px}.photos-section{background:#ffffff80;border:1px solid #0000001a;border-radius:8px;margin-top:12px;padding:12px}.photos-header{align-items:center;color:#6b7280;display:flex;font-size:13px;gap:8px;margin-bottom:8px}.photos-gallery-link{border-top:1px solid #e5e7eb;margin-top:12px;padding-top:12px}.view-all-link{align-items:center;color:#3b82f6;display:inline-flex;font-size:14px;font-weight:500;gap:8px;text-decoration:none;transition:color .2s ease}.view-all-link:hover{color:#2563eb;text-decoration:underline}@media (max-width:768px){.photos-grid{grid-template-columns:repeat(3,1fr)}.activity-photo-container,.photo-more{height:80px}}@media (max-width:480px){.photos-grid{grid-template-columns:repeat(2,1fr)}}.btn-modify{align-items:center;background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;justify-content:center;margin-right:8px;padding:8px;transition:all .2s ease}.btn-modify:hover{background:#2563eb;transform:translateY(-1px)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.modal-container{background:#fff;border-radius:20px;box-shadow:0 25px 50px -12px #00000040;max-height:85vh;max-width:500px;overflow:auto;padding:28px;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.modal-close-btn{background:#f3f4f6;border:none;border-radius:8px;color:#6b7280;cursor:pointer;padding:8px}.modal-form{display:flex;flex-direction:column;gap:20px}.form-row{display:flex;gap:16px}.form-row.two-columns .form-group{flex:1 1}.form-group label{color:#374151;font-size:14px}.form-group input,.form-group select,.form-group textarea{background:#fafafa;border:2px solid #e5e7eb;border-radius:12px;font-size:15px;padding:12px 16px;transition:all .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f61a;outline:none}.modal-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;margin-top:24px;padding-top:20px}.modal-actions .btn{align-items:center;border:none;border-radius:12px;cursor:pointer;display:flex;flex:1 1;font-weight:600;gap:8px;justify-content:center;padding:14px 24px;transition:all .2s ease}.error-message{background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#ef4444;font-size:14px;padding:12px 16px}:root{--gradient-primary:linear-gradient(135deg,#667eea,#764ba2);--shadow-soft:0 4px 20px #00000014;--shadow-medium:0 8px 25px #0000001f;--border-radius:16px;--border-color:#e2e8f0;--text-primary:#1e293b;--text-secondary:#475569;--text-muted:#64748b;--bg-white:#fff;--bg-light:#f8fafc;--primary-color:#667eea;--success-color:#10b981;--error-color:#ef4444}.messages-container{grid-gap:24px;display:grid;gap:24px;grid-template-columns:400px 1fr;height:calc(100vh - 200px);margin-top:0}.conversations-panel{background:#fff;background:var(--bg-white);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--border-radius);box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;overflow:hidden}.panel-header{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:24px}.panel-header h3{color:#1e293b;color:var(--text-primary);font-size:18px;font-weight:700;margin:0}.connection-status{align-items:center;color:#64748b;color:var(--text-muted);display:flex;font-size:12px;font-weight:500;gap:6px}.connection-status .connected{fill:#10b981;fill:var(--success-color);color:#10b981;color:var(--success-color)}.connection-status .disconnected{fill:#ef4444;fill:var(--error-color);color:#ef4444;color:var(--error-color)}.conversations-list{flex:1 1;overflow-y:auto}.conversation-item{background:#fff;background:var(--bg-white);border-bottom:1px solid #f1f5f9;cursor:pointer;padding:20px 24px;position:relative;transition:all .2s ease}.conversation-item:hover{background:#f8fafc;transform:translateX(2px)}.conversation-item.selected{background:linear-gradient(135deg,#e0e7ff,#ede9fe);border-left:4px solid #667eea;border-left:4px solid var(--primary-color)}.conversation-item.has-unread{background:linear-gradient(135deg,#ecfdf5,#f0fdf4);border-left:4px solid #10b981;border-left:4px solid var(--success-color)}.conversation-item.has-unread:not(.selected){position:relative}.conversation-item.has-unread:not(.selected):before{background:#10b981;background:var(--success-color);border-radius:0 2px 2px 0;bottom:0;content:"";left:0;position:absolute;top:0;width:4px}.conversation-content{align-items:flex-start;display:flex;gap:16px}.enfant-avatar{border:2px solid #fffc;border-radius:50%;box-shadow:0 4px 12px #00000026;flex-shrink:0;font-size:18px;height:48px;position:relative;width:48px}.enfant-avatar,.notification-badge{align-items:center;color:#fff;display:flex;font-weight:700;justify-content:center}.notification-badge{animation:pulse 2s infinite;background:#ef4444;background:var(--error-color);border:2px solid #fff;border-radius:10px;box-shadow:0 2px 8px #ef444466;font-size:10px;height:20px;min-width:20px;position:absolute;right:-6px;top:-6px}.conversation-info{flex:1 1;min-width:0}.conversation-title{align-items:center;color:#1e293b;color:var(--text-primary);display:flex;font-size:16px;font-weight:600;gap:8px;margin-bottom:6px}.unread-dot{animation:pulse 2s infinite;color:#10b981;color:var(--success-color);font-size:24px;line-height:1}.participants-info{align-items:center;color:#64748b;color:var(--text-muted);display:flex;font-size:13px;font-weight:500;gap:6px;margin-bottom:4px}.participants-names{color:#64748b;color:var(--text-muted);font-size:12px;font-weight:400;line-height:1.4}.chat-panel{background:#fff;background:var(--bg-white);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--border-radius);box-shadow:0 4px 20px #00000014;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;overflow:hidden}.chat-header{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color);display:flex;gap:16px;padding:24px}.chat-info{flex:1 1}.chat-title{color:#1e293b;color:var(--text-primary);font-size:18px;font-weight:700;margin:0}.chat-participants{color:#64748b;color:var(--text-muted);font-size:13px;font-weight:500;margin-top:4px}.messages-area{background:linear-gradient(135deg,#fafbff,#f8fafc);flex:1 1;gap:16px;overflow-y:auto;padding:24px}.message,.messages-area{display:flex;flex-direction:column}.message{animation:fadeIn .3s ease-out}.message.my-message{align-items:flex-end}.message.other-message{align-items:flex-start}.message-author{color:#64748b;color:var(--text-muted);font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.message-bubble{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:18px;box-shadow:0 2px 8px #0000001a;max-width:75%;padding:14px 18px;position:relative}.my-message .message-bubble{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.other-message .message-bubble{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #e2e8f0;border:1px solid var(--border-color);color:#1e293b;color:var(--text-primary)}.message-content{word-wrap:break-word;line-height:1.4;margin-bottom:6px}.message-time{font-size:10px;font-weight:500;opacity:.7}.typing-indicator{align-items:center;color:#64748b;color:var(--text-muted);display:flex;font-size:12px;font-style:italic;gap:12px;padding:8px 0}.typing-dots{display:flex;gap:3px}.typing-dots span{animation:typing 1.4s infinite;background:#64748b;background:var(--text-muted);border-radius:50%;height:6px;width:6px}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}.message-input-area{background:linear-gradient(135deg,#f8fafc,#fff);border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color);padding:24px}.message-form{align-items:flex-end;display:flex;gap:12px}.message-input{background:#fff;background:var(--bg-white);border:2px solid #e2e8f0;border:2px solid var(--border-color);border-radius:24px;flex:1 1;font-family:inherit;font-size:14px;outline:none;padding:14px 20px;transition:all .3s ease}.message-input:focus{background:#fafbff;border-color:#667eea;border-color:var(--primary-color);box-shadow:0 0 0 4px #667eea1a}.message-input::placeholder{color:#64748b;color:var(--text-muted)}.send-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;box-shadow:0 4px 12px #667eea66;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;transition:all .3s ease;width:48px}.send-button:hover:not(:disabled){box-shadow:0 6px 20px #667eea80;transform:translateY(-2px) scale(1.05)}.send-button:disabled{background:linear-gradient(135deg,#d1d5db,#9ca3af);box-shadow:0 2px 4px #0000001a;cursor:not-allowed;transform:none}.empty-state{align-items:center;color:#64748b;color:var(--text-muted);display:flex;flex-direction:column;height:100%;justify-content:center;padding:40px}.empty-state-icon{margin-bottom:20px;opacity:.4}.empty-state h3{color:#1e293b;color:var(--text-primary);font-size:20px;margin-bottom:12px}.empty-state p{font-size:14px;line-height:1.5;max-width:320px}@keyframes typing{0%,60%,to{opacity:.5;transform:scale(.8)}30%{opacity:1;transform:scale(1)}}@media (max-width:1024px){.messages-container{grid-template-columns:350px 1fr}}@media (max-width:768px){.messages-container{grid-template-columns:1fr;height:calc(100vh - 160px)}.conversations-panel{max-height:300px}.conversation-item{padding:16px 20px}.enfant-avatar{font-size:16px;height:40px;width:40px}.chat-header,.message-input-area,.messages-area{padding:20px}.message-bubble{max-width:85%;padding:12px 16px}.send-button{height:44px;width:44px}}@media (max-width:480px){.conversations-panel{max-height:250px}.conversation-content{gap:12px}.enfant-avatar{font-size:14px;height:36px;width:36px}.conversation-title{font-size:14px}.participants-info,.participants-names{font-size:12px}.message-bubble{max-width:90%;padding:10px 14px}.message-input{font-size:14px;padding:12px 16px}.send-button{height:40px;width:40px}}.profil-container{background:#f8fafc;margin:0 auto;max-width:1200px;min-height:100vh;padding:24px}.profil-content-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}@media (max-width:1024px){.profil-content-grid{grid-template-columns:1fr}}.dashboard-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 8px 32px #667eea4d;color:#fff;margin-bottom:32px;padding:32px}.header-text h1{font-weight:700}.header-text p{font-size:18px}.header-actions{align-items:center;gap:16px}.profil-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:24px;padding:24px}.profil-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.profil-card-header h3{color:#1e293b;font-size:18px;font-weight:600;margin:0}.profil-hero-content{display:flex;flex-direction:column;gap:24px}.profil-avatar-section{align-items:center;display:flex;gap:16px}.profil-avatar{align-items:center;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border-radius:50%;color:#6366f1;display:flex;height:80px;justify-content:center;width:80px}.profil-user-info h2{color:#1e293b;font-size:24px;font-weight:700;margin:0 0 8px}.profil-user-badges{display:flex;gap:8px}.profil-premium-badge,.profil-role-badge{border-radius:20px;font-size:12px;font-weight:600;padding:4px 12px}.profil-premium-badge{align-items:center;background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;display:flex;gap:4px}.profil-contact-grid{display:flex;flex-direction:column;gap:16px}.profil-contact-item{align-items:center;display:flex;gap:12px}.profil-contact-icon{align-items:center;background:#f1f5f9;border-radius:10px;color:#64748b;display:flex;height:40px;justify-content:center;width:40px}.profil-contact-details{flex:1 1}.profil-contact-label{color:#64748b;font-size:12px;margin-bottom:4px}.profil-contact-value{color:#1e293b;font-size:16px;font-weight:500}.profil-form{display:flex;flex-direction:column;gap:20px}.profil-form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:14px}.form-control{border-radius:10px;font-size:16px;padding:12px 16px;transition:all .2s}.form-control:focus{box-shadow:0 0 0 3px #6366f133}.profil-form-actions{display:flex;gap:12px;justify-content:flex-end}.profil-free-status,.profil-premium-status{align-items:center;display:flex;gap:16px;margin-bottom:20px}.profil-free-icon,.profil-premium-icon{align-items:center;border-radius:12px;display:flex;height:60px;justify-content:center;width:60px}.profil-premium-icon{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.profil-free-icon{background:#e0e7ff;color:#6366f1}.profil-free-info,.profil-premium-info{flex:1 1}.profil-free-info h4,.profil-premium-info h4{font-size:18px;font-weight:600;margin:0 0 4px}.profil-free-info p,.profil-premium-info p{color:#64748b;font-size:14px;margin:0}.profil-renewal-date{align-items:center;color:#64748b;display:flex;font-size:14px;gap:6px;margin-top:8px}.profil-features-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-bottom:16px}.profil-feature,.profil-upgrade-promo{align-items:center;display:flex;font-size:14px;gap:8px}.profil-upgrade-promo{background:#f1f5f9;border-radius:10px;font-weight:500;padding:12px 16px}.profil-stats-period{align-items:center;color:#64748b;cursor:pointer;display:flex;font-size:14px;gap:4px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.stat-card{align-items:center;background:#f8fafc;border-radius:12px;display:flex;gap:12px;padding:16px}.stat-card.enfants{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#4338ca}.stat-card.activites{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857}.stat-card.publications{background:linear-gradient(135deg,#fce7f3,#fbcfe8);color:#be185d}.stat-card.messages{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.stat-icon{align-items:center;background:#ffffff4d;border-radius:10px;display:flex;height:48px;justify-content:center;width:48px}.stat-content{flex:1 1}.stat-number{font-size:24px;font-weight:700;line-height:1;margin-bottom:4px}.stat-label{font-size:14px;font-weight:500;opacity:.9}.toast{align-items:center;animation:slideIn .4s cubic-bezier(.68,-.55,.265,1.55);border-radius:12px;box-shadow:0 10px 40px #00000026;display:flex;font-weight:600;gap:10px;min-width:320px;padding:16px 20px;position:fixed;right:24px;top:24px;z-index:1000}.toast-success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:1px solid #86efac;color:#047857}.toast-error{background:linear-gradient(135deg,#fee2e2,#fecaca);border:1px solid #fca5a5;color:#b91c1c}.toast-close{background:none;border:none;cursor:pointer;font-size:18px;margin-left:auto}@keyframes slideIn{0%{opacity:0;transform:translateX(100%) scale(.8)}to{opacity:1;transform:translateX(0) scale(1)}}.btn{border-radius:10px;padding:12px 20px}.btn-primary{background:linear-gradient(135deg,#4f46e5,#7c3aed)}.btn-primary:hover{box-shadow:0 6px 20px #4f46e566}.btn-secondary{border:1px solid #e0e7ff;color:#4f46e5}.btn-secondary:hover{background:#f5f7ff}@media (max-width:768px){.profil-container{padding:16px}.dashboard-header{padding:24px}.header-content{flex-direction:column;gap:20px;text-align:center}.header-text h1{font-size:24px}.header-text p{font-size:16px}.profil-avatar-section{flex-direction:column;text-align:center}.profil-form-grid{grid-template-columns:1fr}.profil-form-actions{flex-direction:column}.profil-free-status,.profil-premium-status{flex-direction:column;text-align:center}.profil-features-grid,.stats-grid{grid-template-columns:1fr}.toast{left:16px;min-width:auto;right:16px}}.invitations-page{--gradient-primary:linear-gradient(135deg,#667eea,#764ba2);--gradient-premium:linear-gradient(135deg,#ff9a9e,#fecfef);--shadow-soft:0 4px 20px #00000014;--shadow-medium:0 8px 25px #0000001f;--border-radius:16px;--border-color:#e2e8f0;--text-primary:#1e293b;--text-secondary:#475569;--text-muted:#64748b;--bg-white:#fff;--bg-light:#f8fafc;--primary-color:#667eea;--success-color:#10b981;--error-color:#ef4444;--warning-color:#f59e0b}.invitations-page .loading-state{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;justify-content:center;padding:80px 20px;text-align:center}.invitations-page .loading-spinner{animation:pulse 2s infinite;margin-bottom:20px}.invitations-page .loading-spinner svg{opacity:.6}.invitations-page .tabs-container{margin-bottom:32px}.invitations-page .tabs{border-bottom:2px solid var(--border-color);display:flex;gap:8px}.invitations-page .tab{align-items:center;background:none;border:none;border-bottom:3px solid #0000;border-radius:8px 8px 0 0;color:var(--text-muted);cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:8px;padding:16px 24px;transition:all .3s ease}.invitations-page .tab.active,.invitations-page .tab:hover{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:var(--primary-color)}.invitations-page .tab.active{border-bottom-color:var(--primary-color);font-weight:600}.invitations-page .invitations-list{display:flex;flex-direction:column;gap:20px}.invitations-page .invitation-card{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);padding:24px;transition:all .3s ease}.invitations-page .invitation-card:hover{box-shadow:var(--shadow-medium);transform:translateY(-2px)}.invitations-page .invitation-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:20px}.invitations-page .user-section{align-items:center;display:flex;gap:16px}.invitations-page .user-avatar{align-items:center;background:var(--gradient-primary);border-radius:50%;box-shadow:0 4px 12px #667eea4d;color:#fff;display:flex;flex-shrink:0;height:56px;justify-content:center;overflow:hidden;width:56px}.invitations-page .user-avatar img{height:100%;object-fit:cover;width:100%}.invitations-page .avatar-placeholder{font-size:18px;font-weight:700}.invitations-page .user-info{flex:1 1}.invitations-page .user-name{color:var(--text-primary);font-size:18px;font-weight:700;margin:0 0 6px}.invitations-page .user-email,.invitations-page .user-real-name{color:var(--text-muted);font-size:14px;font-weight:500;margin:0 0 6px}.invitations-page .invitation-date{align-items:center;color:var(--text-muted);display:flex;font-size:13px;font-weight:500;gap:6px}.invitations-page .status-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:12px;font-weight:600;gap:6px;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.invitations-page .status-badge.pending{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.invitations-page .status-badge.accepted{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857}.invitations-page .status-badge.refused{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#b91c1c}.invitations-page .status-badge.expired{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#4b5563}.invitations-page .invitation-content{display:flex;flex-direction:column;gap:16px}.invitations-page .invitation-details{display:flex;flex-direction:column;gap:12px}.invitations-page .child-info,.invitations-page .role-info{align-items:center;color:var(--text-secondary);display:flex;font-size:15px;gap:10px}.invitations-page .role-icon{flex-shrink:0;font-size:20px}.invitations-page .role-text{font-weight:500}.invitations-page .child-age{color:var(--text-muted);font-size:13px;font-weight:400}.invitations-page .invitation-message{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-left:4px solid var(--primary-color);border-radius:12px;padding:16px 20px}.invitations-page .invitation-message p{color:var(--text-secondary);font-size:14px;font-style:italic;line-height:1.5;margin:0}.invitations-page .permissions-section{background:linear-gradient(135deg,#fff5f7,#fef7f0);border:1px solid #ff9a9e33;border-radius:12px;padding:16px 20px}.invitations-page .permissions-section h5{color:#ff6b95;font-size:14px;font-weight:700;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.invitations-page .permissions-list{list-style:none;margin:0;padding:0}.invitations-page .permissions-list li{color:var(--text-secondary);font-size:13px;font-weight:500;margin-bottom:4px;padding-left:16px;position:relative}.invitations-page .permissions-list li:before{color:var(--success-color);content:"✓";font-weight:700;left:0;position:absolute;top:0}.invitations-page .invitation-actions{border-top:1px solid var(--border-color);display:flex;gap:12px;margin-top:20px;padding-top:20px}.invitations-page .btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;letter-spacing:.5px;padding:12px 20px;text-transform:uppercase;transition:all .3s ease}.invitations-page .btn-small{font-size:12px;padding:8px 14px}.invitations-page .btn-success{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b98166;color:#fff}.invitations-page .btn-success:hover:not(:disabled){box-shadow:0 6px 20px #10b98180;transform:translateY(-2px)}.invitations-page .btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 12px #ef444466;color:#fff}.invitations-page .btn-danger:hover:not(:disabled){box-shadow:0 6px 20px #ef444480;transform:translateY(-2px)}.invitations-page .btn-secondary{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border:1px solid var(--border-color);color:var(--text-secondary)}.invitations-page .btn-secondary:hover{background:linear-gradient(135deg,#e5e7eb,#d1d5db);transform:translateY(-1px)}.invitations-page .btn:disabled{cursor:not-allowed;opacity:.7;transform:none!important}.invitations-page .response-date{border-top:1px solid var(--border-color);color:var(--text-muted);font-size:12px;font-weight:500;margin-top:16px;padding-top:16px;text-align:center}.invitations-page .empty-state{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;justify-content:center;padding:80px 32px;text-align:center}.invitations-page .empty-state-icon{margin-bottom:24px;opacity:.4}.invitations-page .empty-state h3{color:var(--text-primary);font-size:20px;font-weight:700;margin:0 0 12px}.invitations-page .empty-state p{font-size:15px;line-height:1.6;margin:0 0 8px}.invitations-page .empty-state-hint{font-size:13px;opacity:.8}.invitations-page .spinner{animation:invitations-spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;height:16px;width:16px}.invitations-page .alert-close{background:none;border:none;border-radius:4px;color:inherit;cursor:pointer;font-size:18px;margin-left:auto;opacity:.7;padding:4px;transition:opacity .2s}.invitations-page .alert-close:hover{opacity:1}@keyframes invitations-spin{to{transform:rotate(1turn)}}@keyframes pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}@media (max-width:1024px){.invitations-page .tabs{flex-wrap:wrap}}@media (max-width:768px){.invitations-page .invitation-header{align-items:flex-start;flex-direction:column;gap:16px}.invitations-page .user-section{align-items:flex-start;width:100%}.invitations-page .status-badge{align-self:flex-start}.invitations-page .invitation-actions{flex-direction:column;gap:8px}.invitations-page .invitation-actions .btn{justify-content:center;width:100%}.invitations-page .tabs{flex-direction:column;gap:4px}.invitations-page .tab{border-bottom:none;border:1px solid var(--border-color);border-radius:8px;justify-content:center}.invitations-page .tab.active{background:linear-gradient(135deg,#e0e7ff,#ede9fe);border-color:var(--primary-color)}.invitations-page .invitation-details{gap:10px}.invitations-page .child-info,.invitations-page .role-info{font-size:14px}}@media (max-width:480px){.invitations-page .user-section{align-items:center;flex-direction:column;gap:12px;text-align:center}.invitations-page .user-avatar{height:48px;width:48px}.invitations-page .avatar-placeholder,.invitations-page .user-name{font-size:16px}.invitations-page .invitation-content{gap:12px}.invitations-page .invitation-message,.invitations-page .permissions-section{padding:12px 16px}.invitations-page .empty-state{padding:60px 20px}.invitations-page .empty-state h3{font-size:18px}}*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{min-height:100vh}.container{margin:0 auto;max-width:1200px;padding:0 20px}.layout{display:flex;min-height:100vh}.sidebar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:0 20px 20px 0;box-shadow:0 8px 32px #667eea4d;color:#fff;display:flex;flex-direction:column;overflow:hidden;transition:transform .3s ease;width:280px;z-index:100}.main-content{flex:1 1;overflow-y:auto;padding:20px}.header h1{color:#fff;font-size:24px}.header-actions{display:flex;gap:10px}.nav-menu{list-style:none}.nav-item{margin-bottom:5px}.nav-link{align-items:center;color:#666;display:flex;padding:12px 20px;text-decoration:none;transition:background-color .2s}.nav-link:hover{background-color:#f8f9fa;color:#333}.nav-link.active{background-color:#e0e7ff;border-right:3px solid #6366f1;color:#6366f1}.nav-link svg{height:20px;margin-right:12px;width:20px}.btn{border-radius:6px;font-size:14px;font-weight:500;justify-content:center;padding:8px 16px;transition:all .2s}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:#6366f1}.btn-primary:hover:not(:disabled){background:#4f46e5}.btn-secondary{background:#f1f5f9;border:1px solid #e2e8f0;color:#475569}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-small{font-size:12px;padding:4px 8px}.card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.card-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:16px 20px}.card-title{font-size:18px;font-weight:600;margin:0}.card-body{padding:20px}.form-group{margin-bottom:16px}.form-label{color:#374151;display:block;font-weight:500;margin-bottom:6px}.form-control{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:8px 12px;transition:border-color .2s;width:100%}.form-control:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.form-error{color:#ef4444;font-size:12px;margin-top:4px}.grid{grid-gap:20px;display:grid;gap:20px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.text-center{text-align:center}.text-muted{color:#fff}.text-success{color:#10b981}.text-danger{color:#ef4444}.mb-0{margin-bottom:0}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mt-0{margin-top:0}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.d-flex{display:flex}.align-items-center{align-items:center}.justify-content-between{justify-content:space-between}.gap-2{gap:8px}.gap-4{gap:16px}.spinner{border:2px solid #f3f3f3;border-top-color:#6366f1;margin:0 auto}.alert{border-radius:6px;margin-bottom:16px;padding:12px 16px}.alert-success{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46}.alert-error{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b}.alert-info{background:#dbeafe;border:1px solid #93c5fd;color:#1e40af}.auth-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.auth-card{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;max-width:400px;padding:40px;width:100%}.auth-title{color:#333;font-size:28px;margin-bottom:30px;text-align:center}.auth-link{margin-top:20px;text-align:center}.auth-link a{color:#6366f1;text-decoration:none}.auth-link a:hover{text-decoration:underline}@media (max-width:768px){.layout{flex-direction:column}.sidebar{order:2;width:100%}.main-content{order:1}.grid-2,.grid-3{grid-template-columns:1fr}.auth-card{margin:20px;padding:30px 20px}.layout{background:#f8fafc;display:flex;min-height:100vh}.sidebar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:0 20px 20px 0;box-shadow:0 8px 32px #667eea4d;color:#fff;display:flex;flex-direction:column;overflow:hidden;transition:transform .3s ease;width:280px;z-index:100}.sidebar-header{border-bottom:1px solid #ffffff1a;padding:24px}.header-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.app-title{color:#fff;font-size:1.5rem;font-weight:700;margin:0}.user-info{padding:16px 0}.user-name{font-size:1.1rem;font-weight:600;margin-bottom:4px}.user-role{align-items:center;display:flex;font-size:.85rem;gap:4px;opacity:.85}.crown-icon{color:gold}.nav-menu{flex:1 1;padding:16px}.nav-item{margin-bottom:8px}.nav-link{align-items:center;border-radius:12px;color:#ffffffd9;display:flex;font-weight:500;padding:14px 16px;text-decoration:none;transition:all .2s ease}.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link.active{background:#fff;box-shadow:0 4px 15px #0000001a;color:#667eea}.nav-icon-wrapper{align-items:center;background:#ffffff26;border-radius:10px;display:flex;height:36px;justify-content:center;margin-right:12px;width:36px}.nav-link.active .nav-icon-wrapper{background:#667eea26}.nav-label{font-size:.95rem}.sidebar-footer{border-top:1px solid #ffffff1a;padding:16px}.premium-banner{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:linear-gradient(135deg,#ffd70033,#ffa50033);border:1px solid #ffd7004d;border-radius:12px;margin-bottom:16px;padding:12px}.premium-content{align-items:center;display:flex;gap:10px}.premium-title{font-size:.9rem;font-weight:600}.premium-subtitle{font-size:.8rem;opacity:.9}.restrictions-info{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffc10726;border:1px solid #ffc10740;border-radius:12px;margin-bottom:16px;padding:12px}.restrictions-title{font-size:.9rem;font-weight:600;margin-bottom:6px}.restrictions-details{font-size:.8rem;opacity:.9}.restrictions-details div{margin-bottom:2px}.logout{background:#0000;border:none;color:#ffffffd9;cursor:pointer;text-align:left;width:100%}.logout:hover{background:#ffffff1a;color:#fff}.mobile-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #0000001a;display:none;padding:16px;position:sticky;top:0;z-index:90}.mobile-header-top{align-items:center;display:flex;justify-content:space-between}.menu-toggle{background:#fff3;border:none;border-radius:8px;cursor:pointer;height:40px;justify-content:center;width:40px}.menu-toggle,.mobile-user-info{align-items:center;color:#fff;display:flex}.mobile-user-info{font-weight:500;gap:8px}.menu-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:99}.sidebar{height:100vh;position:fixed;transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main-content{flex:1 1;margin:0 auto;max-width:1200px;padding:24px;width:100%}@media (max-width:768px){.mobile-header{display:block}.sidebar{width:280px}.main-content{padding:16px}}}.premium-page{background:#fafbfc;margin:0 auto;max-width:1200px;min-height:100vh;padding:24px}.hero-section{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:24px;box-shadow:0 20px 60px #667eea4d;color:#fff;margin-bottom:48px;padding:48px}.hero-content{grid-gap:48px;align-items:center;display:grid;gap:48px;grid-template-columns:1fr 400px}.hero-text{text-align:left}.hero-icon{color:#fbbf24;margin-bottom:16px}.hero-text h1{font-size:48px;font-weight:800;line-height:1.2;margin:0 0 16px}.hero-subtitle{font-size:20px;line-height:1.5;margin:0 0 24px;opacity:.9}.current-status{align-items:center;border-radius:25px;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:12px 20px}.current-status.premium{background:#22c55e33;border:1px solid #22c55e4d;color:#10b981}.current-status.free{background:#fff3;border:1px solid #ffffff4d;color:#fff}.pricing-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;box-shadow:0 20px 40px #0000001a;color:#1f2937;padding:32px;position:relative;text-align:center}.pricing-card.featured{border:2px solid #fbbf24}.pricing-header{align-items:center;color:#667eea;display:flex;gap:8px;justify-content:center;margin-bottom:16px}.pricing-header h3{font-size:24px;font-weight:700;margin:0}.badge{background:#fbbf24;border-radius:12px;color:#fff;font-size:12px;font-weight:600;left:50%;padding:4px 16px;position:absolute;top:-12px;transform:translateX(-50%)}.price{align-items:baseline;display:flex;gap:4px;justify-content:center;margin:24px 0}.currency{color:#6b7280;font-size:24px;font-weight:600}.amount{color:#1f2937;font-size:48px;font-weight:800}.period{color:#6b7280;font-size:18px}.trial-info{color:#059669;gap:6px;margin-bottom:24px}.cta-button,.trial-info{align-items:center;display:flex;font-weight:600;justify-content:center}.cta-button{border:none;border-radius:12px;cursor:pointer;font-size:16px;gap:8px;margin-bottom:16px;padding:16px 24px;transition:all .3s;width:100%}.cta-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 15px #667eea66;color:#fff}.cta-button.primary:hover:not(:disabled){box-shadow:0 8px 25px #667eea66;transform:translateY(-2px)}.cta-button.manage{background:#f3f4f6;border:1px solid #d1d5db;color:#374151}.cta-button.large{font-size:18px;padding:20px 32px}.cta-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.guarantee{align-items:center;color:#6b7280;display:flex;font-size:12px;gap:6px;justify-content:center}.current-limits{background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;margin-bottom:48px;padding:40px}.current-limits h2{color:#ef4444;font-size:28px;margin-bottom:32px;text-align:center}.limits-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.limit-item{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:16px;display:flex;gap:16px;padding:24px}.limit-content{flex:1 1}.limit-content h4{color:#1f2937;font-size:16px;margin:0 0 8px}.limit-usage{align-items:baseline;display:flex;gap:4px;margin-bottom:8px}.used{color:#ef4444;font-size:24px;font-weight:700}.separator{color:#6b7280;font-size:18px}.label,.total{color:#6b7280;font-size:14px}.progress-bar{background:#fee2e2;height:8px;width:100%}.progress-fill{background:linear-gradient(90deg,#ef4444,#dc2626);transition:width .3s}.features-comparison{background:#fff;border-radius:20px;box-shadow:0 4px 20px #00000014;margin-bottom:48px;padding:40px}.features-comparison h2{color:#1f2937;font-size:32px;margin-bottom:40px;text-align:center}.comparison-table{grid-gap:1px;background:#e5e7eb;border-radius:12px;display:grid;gap:1px;overflow:hidden}.table-header{background:#f8fafc;color:#1f2937;display:grid;font-weight:700;grid-template-columns:2fr 1fr 1fr}.feature-column,.plan-column{padding:20px}.plan-column.premium{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center}.feature-row{background:#fff;display:grid;grid-template-columns:2fr 1fr 1fr}.feature-info{align-items:center;display:flex;gap:16px;padding:24px}.feature-info h4{color:#1f2937;font-size:16px;margin:0 0 4px}.feature-info p{color:#6b7280;font-size:14px;margin:0}.plan-value{align-items:center;display:flex;font-weight:600;gap:8px;justify-content:center;padding:24px}.plan-value.free{color:#ef4444}.plan-value.premium{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857}.testimonials-section{margin-bottom:48px}.testimonials-section h2{color:#1f2937;font-size:32px;margin-bottom:40px;text-align:center}.testimonials-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.testimonial-card{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:32px}.testimonial-rating{color:#fbbf24;display:flex;gap:4px;margin-bottom:16px}.testimonial-card p{color:#374151;font-size:16px;font-style:italic;line-height:1.6;margin-bottom:20px}.testimonial-author strong{color:#1f2937;font-size:16px}.testimonial-author span{color:#6b7280;display:block;font-size:14px;margin-top:4px}.faq-section{margin-bottom:48px}.faq-section h2{color:#1f2937;font-size:32px;margin-bottom:40px;text-align:center}.faq-list{margin:0 auto;max-width:800px}.faq-item{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014;margin-bottom:16px;padding:32px}.faq-item h4{color:#1f2937;font-size:18px;margin-bottom:12px}.faq-item p{color:#6b7280;line-height:1.6;margin:0}.final-cta{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:24px;box-shadow:0 20px 60px #667eea4d;color:#fff;padding:48px;text-align:center}.cta-content h3{font-size:32px;font-weight:800;margin:16px 0}.cta-content p{font-size:18px;margin-bottom:32px;opacity:.9}.cta-guarantee{align-items:center;display:flex;font-size:14px;gap:8px;justify-content:center;margin-top:16px;opacity:.8}.spinner{border:2px solid #0000}@media (max-width:1024px){.hero-content{gap:32px;grid-template-columns:1fr;text-align:center}.comparison-table{font-size:14px}.feature-info,.plan-value{padding:16px}}@media (max-width:768px){.premium-page{padding:16px}.hero-section{padding:32px 24px}.hero-text h1{font-size:32px}.hero-subtitle{font-size:16px}.comparison-table,.feature-row,.table-header{grid-template-columns:1fr}.plan-column.free,.plan-value.free{display:none}.testimonials-grid{grid-template-columns:1fr}}.historical-limit{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:16px;display:flex;gap:16px;margin-top:24px;padding:20px}.historical-limit h4{color:#1f2937;font-size:16px;margin:0 0 4px}.historical-limit p{color:#6b7280;font-size:14px;margin:0}@media (max-width:768px){.limits-grid{grid-template-columns:1fr}.historical-limit,.limit-item{flex-direction:column;padding:20px;text-align:center}.limit-content h4{margin-top:12px}}.progress-bar{background:#e5e7eb;border-radius:4px;overflow:hidden;position:relative}.progress-fill{background:linear-gradient(90deg,#3b82f6,#2563eb);border-radius:4px;height:100%;transition:width .5s ease-in-out}.feature-info svg{color:#667eea;flex-shrink:0}.testimonial-card{transition:transform .2s ease}.testimonial-card:hover{transform:translateY(-4px)}.pricing-card{transition:transform .3s ease,box-shadow .3s ease}.pricing-card:hover{box-shadow:0 25px 50px #00000026;transform:translateY(-4px)}.cta-button{transition:all .3s cubic-bezier(.4,0,.2,1)}.cta-button:active{transform:scale(.98)}.spinner{animation:spin 1s linear infinite;border-top-color:currentcolor;height:20px;width:20px}.current-status.premium{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.faq-section,.features-comparison,.testimonials-section{margin-bottom:64px}@media (max-width:640px){.hero-section{border-radius:16px;padding:24px 16px}.pricing-card{padding:24px}.amount{font-size:36px}}.premium-page-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:24px}.premium-page-container.loading{align-items:center}.premium-content{max-width:800px;position:relative;width:100%}.celebration-animation{left:50%;pointer-events:none;position:absolute;top:-50px;transform:translateX(-50%)}.sparkle{animation:sparkleFloat 3s ease-in-out infinite;color:#fbbf24;position:absolute}.sparkle-1{animation-delay:0s;left:-30px;top:0}.sparkle-2{animation-delay:.5s;right:-20px;top:10px}.sparkle-3{animation-delay:1s;left:20px;top:-10px}@keyframes sparkleFloat{0%,to{opacity:.5;transform:translateY(0) rotate(0deg)}50%{opacity:1;transform:translateY(-20px) rotate(180deg)}}.spinning{animation:spin 2s linear infinite}.loading-spinner{color:#fff;padding:48px;text-align:center}.loading-spinner h2{font-size:28px;font-weight:700;margin:24px 0 8px}.loading-spinner p{font-size:16px;opacity:.8}.premium-header{color:#fff;margin-bottom:32px;text-align:center}.success-icon{animation:successPulse 2s ease-in-out infinite;color:#10b981;margin-bottom:16px}.cancel-icon{color:#ef4444;margin-bottom:16px}@keyframes successPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.premium-header h1{font-size:40px;font-weight:800;line-height:1.2;margin:0 0 16px}.premium-card{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0003;margin-bottom:32px;padding:40px}.premium-card-header{margin-bottom:32px;text-align:center}.premium-card-header h2{color:#1f2937;font-size:28px;font-weight:700;margin:16px 0 8px}.premium-card-header p{color:#6b7280;font-size:16px;line-height:1.6}.trial-badge{align-items:center;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-radius:20px;color:#047857;display:inline-flex;font-size:14px;font-weight:600;gap:8px;margin-top:16px;padding:8px 16px}.next-steps h3,.unlocked-features h3{color:#1f2937;font-size:20px;font-weight:700;margin-bottom:20px;text-align:center}.features-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.feature-unlocked{align-items:flex-start;background:#f8fafc;border-left:4px solid #10b981;border-radius:12px;display:flex;gap:12px;padding:16px}.feature-check{color:#10b981;flex-shrink:0;margin-top:2px}.feature-content h4{color:#1f2937;font-size:16px;font-weight:600;margin:0 0 4px}.feature-content p{color:#6b7280;font-size:14px;line-height:1.4;margin:0}.benefits-list{margin-bottom:32px}.benefit-item{align-items:center;background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;display:flex;gap:16px;margin-bottom:16px;padding:20px}.benefit-icon{background:#667eea1a;border-radius:10px;color:#667eea;flex-shrink:0;padding:12px}.benefit-content h3{color:#1f2937;font-size:16px;font-weight:600;margin:0 0 4px}.benefit-content p{color:#6b7280;font-size:14px;margin:0}.steps-list{display:flex;flex-direction:column;gap:16px;margin-bottom:32px}.step-item{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:12px;gap:16px;padding:20px}.step-item,.step-number{align-items:center;display:flex}.step-number{background:#667eea;border-radius:50%;color:#fff;flex-shrink:0;font-weight:700;height:32px;justify-content:center;width:32px}.step-content h4{color:#1f2937;font-size:16px;font-weight:600;margin:0 0 4px}.step-content p{color:#6b7280;font-size:14px;margin:0}.premium-actions{display:flex;gap:16px;justify-content:center;margin-top:32px}.btn{font-size:16px;gap:8px;transition:all .3s}.btn.large{font-size:18px;padding:16px 32px}.btn-primary{box-shadow:0 4px 15px #667eea66}.btn-primary:hover{box-shadow:0 8px 25px #667eea66;color:#fff;text-decoration:none;transform:translateY(-2px)}.btn-secondary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;color:#fff}.btn-secondary:hover{background:#ffffff4d;color:#fff;text-decoration:none}.subscription-summary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:16px;color:#fff;margin-bottom:32px;padding:32px}.subscription-summary h3{font-size:20px;font-weight:700;margin-bottom:24px;text-align:center}.summary-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-item{background:#ffffff1a;border-radius:12px;padding:16px;text-align:center}.summary-label{font-size:14px;margin-bottom:8px;opacity:.8}.summary-value{font-size:18px;font-weight:700}.status-active{color:#10b981!important}.help-section,.support-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:16px;color:#fff;padding:32px;text-align:center}.help-section h3,.support-section h3{font-size:20px;font-weight:700;margin-bottom:12px}.help-section p,.support-section p{line-height:1.6;margin-bottom:20px;opacity:.9}.help-link,.support-link{border:1px solid #fbbf24;border-radius:8px;color:#fbbf24;font-weight:600;padding:8px 16px;text-decoration:none;transition:all .3s}.help-link:hover,.support-link:hover{background:#fbbf24;color:#1f2937;text-decoration:none}.help-actions{display:flex;gap:16px;justify-content:center}@media (max-width:768px){.premium-page-container{padding:16px}.premium-card{padding:24px}.premium-header h1{font-size:28px}.premium-subtitle{font-size:16px}.features-grid{gap:16px;grid-template-columns:1fr}.premium-actions{align-items:center;flex-direction:column}.btn{justify-content:center;width:100%}.summary-grid{gap:12px;grid-template-columns:1fr}.help-actions{align-items:center;flex-direction:column}.benefit-item,.step-item{flex-direction:column;text-align:center}}@media (max-width:480px){.premium-page-container{padding:12px}.premium-card{padding:20px}.celebration-animation{display:none}}.photos-gallery-container{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.gallery-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 20px 40px #667eea4d;color:#fff;margin-bottom:30px;overflow:hidden;padding:32px;position:relative}.gallery-header:before{background:radial-gradient(circle,#ffffff1a 0,#0000 70%);content:"";height:200%;left:-50%;position:absolute;top:-50%;transform:rotate(30deg);width:200%;z-index:0}.header-content{justify-content:space-between;position:relative;z-index:2}.header-content,.header-left{align-items:center;display:flex}.header-left{gap:20px}.header-text h1{font-size:32px;font-weight:800;margin:0 0 8px;text-shadow:0 2px 4px #0003}.header-text p{font-size:16px;font-weight:500;margin:0;opacity:.9}.month-selector{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:1px solid #ffffff80;border-radius:16px;box-shadow:0 10px 30px #0000001a;gap:20px;margin-bottom:30px;padding:16px 24px}.month-nav-btn,.month-selector{align-items:center;display:flex;justify-content:center}.month-nav-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;font-size:18px;height:44px;transition:all .3s ease;width:44px}.month-nav-btn:hover:not(:disabled){box-shadow:0 8px 25px #667eea66;transform:translateY(-3px) scale(1.05)}.month-nav-btn:disabled{cursor:not-allowed;opacity:.4;transform:none}.month-display{align-items:center;background:#667eea1a;border-radius:12px;color:#2d3748;display:flex;font-size:18px;font-weight:700;gap:10px;justify-content:center;min-width:200px;padding:8px 20px}.month-display svg{color:#667eea}.historical-limitation-banner{animation:subtle-pulse 3s ease-in-out infinite;background:linear-gradient(135deg,#fff9db,#ffd43b);border:2px solid #fcc419;border-radius:16px;box-shadow:0 10px 30px #fcc41933;margin-bottom:30px;padding:20px}.banner-content{align-items:center;display:flex;gap:15px}.banner-text{color:#5c3c00;flex:1 1}.banner-text strong{display:block;font-size:16px;margin-bottom:6px}.banner-text span{font-size:14px;opacity:.9}@keyframes subtle-pulse{0%,to{box-shadow:0 8px 25px #fcc41933}50%{box-shadow:0 12px 35px #fcc4194d}}.photos-grid-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border-radius:20px;box-shadow:0 15px 35px #0000001a;margin-bottom:40px;padding:30px}.photos-count{background:#667eea1a;border-radius:12px;color:#4a5568;display:inline-block;font-size:16px;font-weight:600;margin:0 auto 25px;padding:12px 20px;text-align:center}.photos-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.photo-item{background:#fff;border-radius:20px;box-shadow:0 10px 25px #0000001a;overflow:hidden;position:relative;transform:translateY(0);transition:all .4s ease}.photo-item:hover{box-shadow:0 20px 40px #00000026;transform:translateY(-8px) scale(1.02)}.photo-container{aspect-ratio:4/3;overflow:hidden;position:relative}.photo-image{cursor:pointer;height:100%;object-fit:cover;transition:transform .5s ease;width:100%}.photo-item:hover .photo-image{transform:scale(1.1)}.photo-overlay{background:linear-gradient(180deg,#0000 0,#0000 60%,#000c);bottom:0;display:flex;flex-direction:column;justify-content:space-between;left:0;opacity:0;padding:15px;position:absolute;right:0;top:0;transition:opacity .3s ease}.photo-item:hover .photo-overlay{opacity:1}.photo-info{align-self:flex-start}.photo-time{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;border-radius:10px;color:#fff;display:flex;font-size:13px;font-weight:500;gap:6px;padding:6px 12px}.photo-actions{align-self:flex-end;display:flex;gap:10px}.photo-action-btn{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border:none;border-radius:10px;box-shadow:0 4px 10px #0000001a;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .3s ease;width:36px}.photo-action-btn:hover:not(.disabled){background:#fff;box-shadow:0 6px 15px #00000026;transform:scale(1.15)}.photo-action-btn.share{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.photo-action-btn.share:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1);transform:scale(1.15)}.photo-action-btn.disabled{background:#6b7280b3;color:#fffc;cursor:not-allowed}.photo-caption{background:#f8fafc;border-top:1px solid #e2e8f0;color:#4a5568;font-size:14px;line-height:1.5;padding:15px 20px}.photo-item.blurred{opacity:.8;transform:scale(.98)}.photo-item.blurred .photo-image{cursor:default;filter:blur(12px)}.blur-overlay{align-items:center;background:#000000b3;bottom:0;color:#fff;display:flex;flex-direction:column;font-weight:700;gap:12px;justify-content:center;left:0;padding:20px;position:absolute;right:0;text-align:center;top:0}.blur-overlay svg{height:32px;opacity:.9;width:32px}.blur-overlay span{font-size:16px;text-shadow:0 2px 4px #0000004d}.photo-placeholder{align-items:center;background:linear-gradient(135deg,#e2e8f0,#cbd5e0);display:flex;height:100%;justify-content:center;width:100%}.photo-placeholder svg{color:#a0aec0;opacity:.7}.empty-state{background:#fff;border-radius:20px;box-shadow:0 10px 30px #00000014;padding:80px 30px;text-align:center}.empty-state svg{color:#cbd5e0;margin-bottom:25px;opacity:.7}.empty-state h3{color:#2d3748;font-size:26px;font-weight:700;margin:0 0 15px}.empty-state p{color:#718096;font-size:17px;line-height:1.6;margin:0 auto;max-width:500px}.fullscreen-modal{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000e6;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:20000}.fullscreen-content{animation:zoomIn .3s ease;cursor:default;max-height:90vh;max-width:90vw;position:relative}.fullscreen-image{border-radius:12px;box-shadow:0 25px 50px #00000080;max-height:80vh;max-width:100%;object-fit:contain}.close-fullscreen{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:44px;justify-content:center;position:absolute;right:0;top:-60px;transition:background .3s;width:44px}.close-fullscreen:hover{background:#ffffff4d;transform:scale(1.1)}.fullscreen-caption{background:#00000080;border-radius:8px;bottom:-50px;color:#fff;font-size:16px;margin:0 20px;opacity:.9;padding:10px;position:absolute;text-align:center}.fullscreen-caption,.share-modal-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);left:0;right:0}.share-modal-overlay{align-items:center;animation:fadeIn .3s ease;background:#000000b3;bottom:0;display:flex;justify-content:center;padding:20px;position:fixed;top:0;z-index:9999}.share-modal{animation:slideUp .4s ease;background:#fff;border-radius:20px;box-shadow:0 30px 60px #0000004d;max-height:80vh;max-width:500px;overflow:auto;width:100%}.share-modal-header{align-items:center;background:linear-gradient(135deg,#f8fafc,#edf2f7);border-bottom:1px solid #e2e8f0;border-radius:20px 20px 0 0;display:flex;justify-content:space-between;padding:25px 30px}.share-modal-header h3{color:#2d3748;font-size:20px;font-weight:700;margin:0}.close-btn{background:none;border:none;border-radius:8px;color:#718096;cursor:pointer;padding:6px;transition:background .2s}.close-btn:hover{background:#edf2f7;color:#4a5568}.share-modal-body{padding:30px}.photo-preview{align-items:center;background:#f8fafc;border-radius:16px;display:flex;gap:20px;margin-bottom:25px;padding:20px}.photo-preview img{border-radius:12px;box-shadow:0 6px 15px #0000001a;height:100px;object-fit:cover;width:100px}.preview-info{display:flex;flex-direction:column;gap:6px;justify-content:center}.preview-info strong{color:#2d3748;font-size:17px;font-weight:600}.preview-info span{color:#718096;font-size:14px}.form-group{margin-bottom:20px}.form-group label{color:#2d3748;display:block;font-weight:600;margin-bottom:8px}.form-group textarea{border:2px solid #e2e8f0;border-radius:12px;box-sizing:border-box;font-family:inherit;font-size:15px;padding:15px;resize:vertical;transition:border-color .3s;width:100%}.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.char-count{color:#a0aec0;font-size:13px;margin-top:6px;text-align:right}.share-modal-footer{background:#f8fafc;border-radius:0 0 20px 20px;border-top:1px solid #e2e8f0;display:flex;gap:15px;justify-content:flex-end;padding:20px 30px}.btn{align-items:center;border:none;border-radius:12px;box-shadow:0 4px 15px #0000001a;cursor:pointer;display:inline-flex;font-size:15px;font-weight:600;gap:10px;padding:12px 24px;text-decoration:none;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 8px 25px #667eea59;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-secondary{background:#fff;border:2px solid #e2e8f0;color:#4a5568}.btn-secondary:hover{background:#f7fafc;border-color:#cbd5e0;box-shadow:0 4px 15px #00000014;transform:translateY(-2px)}.btn-small{font-size:14px;padding:10px 18px}.spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes zoomIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1024px){.photos-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media (max-width:768px){.photos-gallery-container{padding:15px}.gallery-header{padding:25px}.header-content{text-align:center}.header-content,.header-left{flex-direction:column;gap:15px}.header-text h1{font-size:28px}.month-selector{gap:15px;padding:15px 20px}.month-display{font-size:16px;min-width:170px}.photos-grid{gap:20px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.photos-grid-container{padding:20px}.historical-limitation-banner{padding:15px 20px}.banner-content{align-items:flex-start;flex-direction:column;gap:15px}.share-modal{margin:15px}.share-modal-body,.share-modal-footer,.share-modal-header{padding:20px}.photo-preview{flex-direction:column;text-align:center}.photo-preview img{height:80px;margin:0 auto;width:80px}.share-modal-footer{flex-direction:column}.btn{justify-content:center;width:100%}}@media (max-width:480px){.photos-grid{gap:15px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.header-text h1{font-size:24px}.month-selector{gap:10px}.month-nav-btn{height:40px;width:40px}.month-display{font-size:15px;min-width:150px}.empty-state{padding:50px 20px}.empty-state h3{font-size:22px}.empty-state p{font-size:15px}}
/*# sourceMappingURL=main.169ba90a.css.map*/