*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media (min-width:640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width:768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width:1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width:1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width:1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.visible{visibility:visible}.fixed{position:fixed}.mx-auto{margin-left:auto;margin-right:auto}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}.flex{display:flex}.table{display:table}.h-32{height:8rem}.min-h-screen{min-height:100vh}.w-32{width:8rem}.items-center{align-items:center}.justify-center{justify-content:center}.rounded-3xl{border-radius:1.5rem}.border{border-width:1px}.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-stops))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.from-gray-100{--tw-gradient-from:#f3f4f6 var(--tw-gradient-from-position);--tw-gradient-to:#f3f4f600 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-green-600{--tw-gradient-from:#16a34a var(--tw-gradient-from-position);--tw-gradient-to:#16a34a00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-white{--tw-gradient-to:#fff0 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#fff var(--tw-gradient-via-position),var(--tw-gradient-to)}.to-blue-50{--tw-gradient-to:#eff6ff var(--tw-gradient-to-position)}.to-green-400{--tw-gradient-to:#4ade80 var(--tw-gradient-to-position)}.to-white{--tw-gradient-to:#fff var(--tw-gradient-to-position)}.text-center{text-align:center}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.font-bold{font-weight:700}.text-gray-500{--tw-text-opacity:1;color:#6b7280;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-green-600{--tw-text-opacity:1;color:#16a34a;color:rgb(22 163 74/var(--tw-text-opacity,1))}.text-green-700{--tw-text-opacity:1;color:#15803d;color:rgb(21 128 61/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:#fff;color:rgb(255 255 255/var(--tw-text-opacity,1))}.shadow-2xl{--tw-shadow:0 25px 50px -12px #00000040;--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;overflow-x:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}a,button{-webkit-tap-highlight-color:rgba(0,0,0,.1)}.app,.app-container,.bottom-nav,.card,.header,body,button,input,textarea{transition-duration:.2s;transition-property:background-color,border-color,color,fill,stroke;transition-timing-function:ease-in-out}.comment-section{border-top:1px solid #e0e0e0;margin-top:1rem;padding-top:1rem}.comment-header{margin-bottom:.75rem}.comment-count{color:#666;font-size:13px;font-weight:600}.comment-loading{color:#999;font-size:13px;padding:1rem;text-align:center}.comments-list{margin-bottom:.75rem;max-height:400px;overflow-y:auto}.comment-item{animation:fadeIn .3s ease-in;display:flex;gap:.75rem;margin-bottom:1rem}.comment-avatar,.comment-user-avatar{border-radius:50%;flex-shrink:0;height:32px;overflow:hidden;width:32px}.comment-avatar img,.comment-user-avatar img{height:100%;object-fit:cover;width:100%}.comment-avatar-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:12px;font-weight:600;height:100%;justify-content:center;width:100%}.comment-content{position:relative}.comment-meta{align-items:center;display:flex;gap:.5rem;margin-bottom:.25rem}.comment-author{color:#333;font-size:13px}.comment-time{color:#999;font-size:11px}.comment-text{word-wrap:break-word;color:#555;font-size:13px;margin:0}.comment-delete-btn{background:none;border:none;cursor:pointer;font-size:14px;opacity:0;padding:.25rem;position:absolute;right:0;top:0;transition:opacity .2s}.comment-item:hover .comment-delete-btn{opacity:.6}.comment-delete-btn:hover{opacity:1!important}.comment-form{margin-top:.75rem}.comment-input-wrapper{align-items:center;background:#f5f5f5;border-radius:24px;display:flex;gap:.5rem;padding:.5rem;transition:background .2s}.comment-input-wrapper:focus-within{background:#ebebeb}.comment-input{background:#0000;border:none;flex:1 1;font-size:13px;outline:none;padding:.25rem .5rem}.comment-input::placeholder{color:#999}.comment-submit-btn{align-items:center;background:#58a889;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:32px;justify-content:center;transition:all .2s;width:32px}.comment-submit-btn:hover:not(:disabled){background:#4a8f75;transform:scale(1.05)}.comment-submit-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.5}.comment-submit-btn:active:not(:disabled){transform:scale(.95)}@media (prefers-color-scheme:dark){.comment-section{border-top-color:#333}.comment-author,.comment-count,.comment-text{color:#fff}.comment-time{color:#999}.comment-input-wrapper{background:#2a2a2a}.comment-input-wrapper:focus-within{background:#333}.comment-input{color:#fff}}@media (max-width:768px){.comment-avatar,.comment-submit-btn,.comment-user-avatar{height:28px;width:28px}.comment-submit-btn{font-size:12px}}.share-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.share-modal{background:#fff;background:var(--card-bg,#fff);border-radius:12px;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:500px;overflow:hidden;width:100%}.share-modal-header{align-items:center;border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color,#e0e0e0);display:flex;justify-content:space-between;padding:20px}.share-modal-header h3{color:#333;color:var(--text-primary,#333);font-size:1.25rem;font-weight:600;margin:0}.close-btn{color:#666;color:var(--text-secondary,#666);padding:4px;transition:color .2s}.close-btn:hover{color:#333;color:var(--text-primary,#333)}.share-modal-content{flex:1 1;overflow-y:auto;padding:20px}.loading,.no-members{color:#666;color:var(--text-secondary,#666);padding:40px 20px;text-align:center}.member-selection{margin-bottom:20px}.input-label{display:block;font-size:.95rem;font-weight:500;margin-bottom:8px}.input-label,.member-select{color:#333;color:var(--text-primary,#333)}.member-select{background:#fff;background:var(--input-bg,#fff);border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:8px;cursor:pointer;font-size:1rem;padding:12px;transition:border-color .2s;width:100%}.member-select:focus{border-color:#6366f1;border-color:var(--primary-color,#6366f1);outline:none}.message-input{margin-bottom:20px}.message-textarea{background:#fff;background:var(--input-bg,#fff);border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:8px;color:#333;color:var(--text-primary,#333);font-family:inherit;font-size:1rem;padding:12px;resize:vertical;transition:border-color .2s;width:100%}.message-textarea:focus{border-color:#6366f1;border-color:var(--primary-color,#6366f1);outline:none}.post-preview{background:#f5f5f5;background:var(--bg-secondary,#f5f5f5);border-radius:8px;margin-top:20px;padding:16px}.post-preview h4{color:#666;color:var(--text-secondary,#666);font-size:.9rem;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.preview-content p{color:#333;color:var(--text-primary,#333);line-height:1.5;margin:0 0 12px}.preview-media{border-radius:8px;margin-top:8px;overflow:hidden}.preview-image,.preview-video{display:block;height:auto;max-height:200px;object-fit:cover;width:100%}.share-modal-footer{border-top:1px solid #e0e0e0;border-top:1px solid var(--border-color,#e0e0e0);display:flex;gap:12px;padding:20px}.cancel-btn,.share-btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;padding:12px 24px;transition:all .2s}.cancel-btn{background:#f5f5f5;background:var(--bg-secondary,#f5f5f5);color:#333;color:var(--text-primary,#333)}.cancel-btn:hover{background:#e0e0e0;background:var(--bg-tertiary,#e0e0e0)}.share-btn{background:#6366f1;background:var(--primary-color,#6366f1);color:#fff}.share-btn:hover:not(:disabled){background:#4f46e5;background:var(--primary-hover,#4f46e5)}.share-btn:disabled{cursor:not-allowed;opacity:.5}@media (prefers-color-scheme:dark){.share-modal{background:#1f2937;background:var(--card-bg,#1f2937)}.share-modal-header h3{color:#f9fafb;color:var(--text-primary,#f9fafb)}.close-btn{color:#9ca3af;color:var(--text-secondary,#9ca3af)}.close-btn:hover{color:#f9fafb;color:var(--text-primary,#f9fafb)}.loading,.no-members{color:#9ca3af;color:var(--text-secondary,#9ca3af)}.input-label,.member-select,.message-textarea{color:#f9fafb;color:var(--text-primary,#f9fafb)}.member-select,.message-textarea{background:#374151;background:var(--input-bg,#374151);border-color:#4b5563;border-color:var(--border-color,#4b5563)}.post-preview{background:#374151;background:var(--bg-secondary,#374151)}.post-preview h4{color:#9ca3af;color:var(--text-secondary,#9ca3af)}.cancel-btn,.preview-content p{color:#f9fafb;color:var(--text-primary,#f9fafb)}.cancel-btn{background:#374151;background:var(--bg-secondary,#374151)}.cancel-btn:hover{background:#4b5563;background:var(--bg-tertiary,#4b5563)}}.post-card{background:var(--color-bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow);margin-bottom:var(--spacing-md);padding:var(--spacing-md);transition:all .2s ease}.post-card:hover{box-shadow:var(--shadow-md)}.post-header{justify-content:space-between;margin-bottom:var(--spacing)}.post-author,.post-header{align-items:center;display:flex}.post-author{gap:10px}.post-avatar{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);border-radius:var(--radius-full);color:#fff;display:flex;font-size:var(--font-size-base);font-weight:700;height:44px;justify-content:center;width:44px}.post-author-info{display:flex;flex-direction:column;gap:2px}.post-author-name{color:var(--color-text);font-size:var(--font-size-base);font-weight:600}.post-timestamp{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.post-type-icon{font-size:24px}.post-content{margin-bottom:var(--spacing-md)}.post-emoji{font-size:48px;margin-bottom:var(--spacing);text-align:center}.post-text{color:var(--color-text);font-size:var(--font-size-base);line-height:1.6;margin:0 0 var(--spacing)}.post-image-container{border-radius:var(--radius);margin-top:var(--spacing);overflow:hidden}.post-image{display:block;height:auto;width:100%}.post-stats{border-bottom:1px solid var(--color-border);border-top:1px solid var(--color-border);display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing);padding:var(--spacing) 0}.post-stat{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500}.post-actions{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing)}.post-action-btn{align-items:center;background:var(--color-bg-secondary);border:none;border-radius:var(--radius-lg);color:var(--color-text-secondary);cursor:pointer;display:flex;flex:1 1;font-size:var(--font-size-sm);font-weight:600;gap:6px;justify-content:center;padding:10px 16px;transition:all .2s ease}.post-action-btn:hover{background:var(--color-border);color:var(--color-text)}.post-action-btn.active{color:#ef4444}.action-icon{height:18px;width:18px}.post-comments{border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--spacing);margin-top:var(--spacing);padding-top:var(--spacing)}.post-comment{display:flex;gap:10px}.comment-avatar{align-items:center;background:var(--color-primary-light);border-radius:var(--radius-full);color:#fff;display:flex;flex-shrink:0;font-size:var(--font-size-xs);font-weight:600;height:32px;justify-content:center;width:32px}.comment-content{background:var(--color-bg-secondary);border-radius:var(--radius);flex:1 1;padding:10px 12px}.comment-author{color:var(--color-text);font-size:var(--font-size-sm);font-weight:600;margin-bottom:4px}.comment-text{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.4}.tips-overlay{align-items:center;animation:fadeIn .3s ease;background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;padding:var(--spacing-md);position:fixed;right:0;top:0;z-index:2000}.tips-content{animation:slideUp .4s ease;background:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:0 20px 60px #0000004d;max-width:500px;padding:var(--spacing-2xl);position:relative;width:100%}.tips-close{background:none;border:none;border-radius:var(--radius);cursor:pointer;padding:8px;position:absolute;right:var(--spacing-md);top:var(--spacing-md);transition:background .2s}.tips-close:hover{background:var(--color-bg-hover)}.tips-close-icon{color:var(--color-text-secondary);height:24px;width:24px}.tips-header{margin-bottom:var(--spacing-xl);text-align:center}.tips-bulb-icon{animation:pulse 2s ease-in-out infinite;color:var(--color-primary);height:48px;margin:0 auto var(--spacing-md);width:48px}.tips-header h2{color:var(--color-text);font-size:var(--font-size-2xl);font-weight:700;margin:0}.tip-card{animation:tipSlide .3s ease;background:var(--color-bg);border-radius:var(--radius-lg);display:flex;flex-direction:column;justify-content:center;margin-bottom:var(--spacing-xl);min-height:200px;padding:var(--spacing-xl);text-align:center}@keyframes tipSlide{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.tip-icon{font-size:64px;margin-bottom:var(--spacing-md)}.tip-title{color:var(--color-text);font-size:var(--font-size-xl);font-weight:700;margin:0 0 var(--spacing-sm) 0}.tip-description{color:var(--color-text-secondary);font-size:var(--font-size-base);line-height:1.6;margin:0}.tips-progress{display:flex;gap:8px;justify-content:center;margin-bottom:var(--spacing-lg)}.progress-dot{background:var(--color-border);border-radius:50%;height:8px;transition:all .3s ease;width:8px}.progress-dot.active{background:var(--color-primary);border-radius:4px;width:24px}.progress-dot.completed{background:var(--color-primary);opacity:.5}.tips-actions{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.tips-btn{border:none;border-radius:var(--radius-lg);cursor:pointer;flex:1 1;font-size:var(--font-size-base);font-weight:600;padding:14px 24px;transition:all .2s}.tips-btn-secondary{background:var(--color-bg);color:var(--color-text)}.tips-btn-secondary:hover{background:var(--color-bg-hover)}.tips-btn-primary{background:var(--color-primary);color:#fff}.tips-btn-primary:hover{box-shadow:0 4px 12px #0003;opacity:.9;transform:translateY(-1px)}.tips-skip{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-sm);padding:var(--spacing-sm);transition:color .2s;width:100%}.tips-skip:hover{color:var(--color-text)}.home-page{background:var(--color-bg);min-height:100vh;padding:var(--spacing-md)}.create-post-section{margin-bottom:var(--spacing-md)}.create-post-card{background:var(--color-bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow);padding:var(--spacing-md)}.create-post-header{align-items:center;display:flex;gap:var(--spacing);margin-bottom:var(--spacing)}.create-post-avatar{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);border-radius:var(--radius-full);color:#fff;display:flex;flex-shrink:0;font-size:var(--font-size-base);font-weight:700;height:40px;justify-content:center;width:40px}.create-post-input{background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);flex:1 1;font-size:var(--font-size-base);padding:12px 16px;transition:border-color .2s ease}.create-post-input:focus{border-color:var(--color-primary);outline:none}.create-post-input::placeholder{color:var(--color-text-light)}.create-post-actions{align-items:center;display:flex;gap:var(--spacing-sm);justify-content:flex-end}.create-post-btn{align-items:center;background:var(--color-bg-secondary);border:none;border-radius:var(--radius);color:var(--color-text-secondary);cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s ease;width:40px}.create-post-btn:hover{background:var(--color-border);color:var(--color-text)}.create-icon{height:20px;width:20px}.create-post-submit{align-items:center;background:var(--color-primary);border:none;border-radius:var(--radius-full);color:#fff;cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .2s ease;width:44px}.create-post-submit:hover{background:var(--color-primary-dark);box-shadow:var(--shadow);transform:scale(1.05)}.plus-icon{height:24px;width:24px}.image-preview-container{border-radius:var(--radius);margin:var(--spacing-md) 0;overflow:hidden;position:relative}.image-preview{border-radius:var(--radius);max-height:400px;object-fit:cover;width:100%}.remove-image-btn{align-items:center;background:#000000b3;border:none;border-radius:var(--radius-full);color:#fff;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;position:absolute;right:var(--spacing-sm);top:var(--spacing-sm);transition:background .2s;width:32px}.remove-image-btn:hover{background:#000000e6}.posts-feed{display:flex;flex-direction:column}.create-post-submit:disabled{cursor:not-allowed;opacity:.5}.create-post-submit:disabled:hover{box-shadow:none;transform:none}.empty-feed,.loading-message{color:var(--color-text-secondary);padding:var(--spacing-2xl);text-align:center}.empty-feed p{margin:var(--spacing-sm) 0}.empty-feed p:first-child{color:var(--color-text);font-weight:600}.modal-overlay{animation:fadeIn .2s;background:#00000080}.modal-content{animation:slideUp .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 10px 40px #0003;width:90%}.modal-header{border-bottom:1px solid #e0e0e0;padding:1.5rem}.modal-header h2{color:#333;font-size:20px}.modal-close{align-items:center;background:#f0f0f0;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:18px;height:32px;justify-content:center;transition:all .2s;width:32px}.modal-close:hover{background:#e0e0e0;color:#333}.modal-error{background:#fee;border-left:3px solid #c33;border-radius:8px;color:#c33;font-size:13px;margin:1rem 1.5rem 0;padding:.75rem}.member-edit-form{padding:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{color:#555;font-size:13px;margin-bottom:.5rem}.form-group input,.form-group select{border:1px solid #ddd;border-radius:8px;font-size:14px;padding:.75rem;transition:all .2s;width:100%}.form-group input:focus,.form-group select:focus{border-color:#58a889;box-shadow:0 0 0 3px #58a8891a;outline:none}.form-group input:disabled,.form-group select:disabled{background:#f5f5f5;cursor:not-allowed}.modal-actions{border-top:1px solid #e0e0e0;display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem}.btn-primary,.btn-secondary{border-radius:8px;font-size:14px;padding:.75rem 1.5rem}.btn-primary{background:#58a889}.btn-primary:hover:not(:disabled){background:#4a8f75;transform:translateY(-1px)}.btn-primary:disabled{background:#ccc}.btn-secondary{background:#f0f0f0;color:#666}.btn-secondary:hover:not(:disabled){background:#e0e0e0;color:#333}.btn-secondary:disabled{cursor:not-allowed;opacity:.5}@media (prefers-color-scheme:dark){.modal-content{background:#2a2a2a}.modal-header{border-bottom-color:#444}.modal-header h2{color:#fff}.modal-close{background:#444;color:#ccc}.modal-close:hover{background:#555;color:#fff}.form-group label{color:#ccc}.form-group input,.form-group select{background:#333;border-color:#444;color:#fff}.form-group input:focus,.form-group select:focus{border-color:#58a889}.form-group input:disabled,.form-group select:disabled{background:#222}.modal-actions{border-top-color:#444}.btn-secondary{background:#444;color:#ccc}.btn-secondary:hover:not(:disabled){background:#555;color:#fff}}@media (max-width:768px){.modal-content{max-height:95vh;width:95%}.member-edit-form,.modal-header{padding:1rem}.modal-header h2{font-size:18px}.form-group input,.form-group select{font-size:16px}.btn-primary,.btn-secondary{flex:1 1}}.invite-modal-content{background:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:4px 0 0}.create-invitation-section{background:var(--color-bg);border-radius:var(--radius);margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.create-invitation-btn{align-items:center;background:var(--color-primary);border:none;border-radius:var(--radius);color:#fff;cursor:pointer;display:flex;font-size:var(--font-size-base);font-weight:600;gap:8px;justify-content:center;padding:12px 24px;transition:all .2s;width:100%}.create-invitation-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.create-invitation-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-icon{height:20px;width:20px}.create-invitation-note{color:var(--color-text-secondary);font-size:var(--font-size-xs);margin-top:8px;text-align:center}.spinner{animation:spin 1s linear infinite;border-top:4px solid var(--color-border);border:4px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:40px;margin:0 auto 1rem;width:40px}.loading-state p{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.invitations-list{margin-top:var(--spacing-md)}.invitations-list-title{color:var(--color-text);font-size:var(--font-size-base);font-weight:600;margin:0 0 var(--spacing-md) 0}.invitation-card{background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius);margin-bottom:var(--spacing-md);padding:var(--spacing-md);transition:border-color .2s}.invitation-card:hover{border-color:var(--color-primary)}.invitation-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-sm)}.invitation-code{align-items:center;display:flex;gap:8px}.code-label{color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:500}.code-value{color:var(--color-primary);font-family:monospace;font-size:var(--font-size-sm);font-weight:700;letter-spacing:1px}.invitation-stats{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.uses-count{background:var(--color-bg-card);border-radius:var(--radius-sm);font-weight:600;padding:4px 8px}.invitation-link-container{display:flex;gap:8px;margin-bottom:var(--spacing-sm)}.invitation-link-input{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);flex:1 1;font-family:monospace;font-size:var(--font-size-xs);padding:8px 12px}.invitation-link-input:focus{border-color:var(--color-primary);outline:none}.copy-link-btn{align-items:center;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;display:flex;justify-content:center;padding:8px 12px;transition:all .2s}.copy-link-btn:hover{background:var(--color-primary);border-color:var(--color-primary)}.copy-link-btn:hover .copy-icon{color:#fff}.copy-icon{color:var(--color-text-secondary);height:20px;transition:color .2s;width:20px}.copy-icon.copied{color:#22c55e}.invitation-footer{align-items:center;border-top:1px solid var(--color-border);display:flex;justify-content:space-between;padding-top:var(--spacing-sm)}.expiry-date{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.expiry-date.expiring-soon{color:#f59e0b;font-weight:600}.delete-invitation-btn{background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-xs);padding:4px 12px;transition:all .2s}.delete-invitation-btn:hover{background:#fee;border-color:#c00;color:#c00}.empty-state{padding:2rem 1rem}.empty-icon{font-size:48px;margin-bottom:1rem}.empty-text{color:var(--color-text);font-size:var(--font-size-base);font-weight:600;margin:0 0 4px}.empty-subtext{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}@media (max-width:640px){.invite-modal-content{border-radius:0;max-height:100vh}.invitation-footer,.invitation-header{align-items:flex-start;flex-direction:column;gap:8px}.delete-invitation-btn{align-self:flex-end}}.conest-section{margin-bottom:var(--spacing-2xl)}.section-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:4px}.add-conest-btn{align-items:center;background:var(--color-primary);border:none;border-radius:var(--radius);color:#fff;cursor:pointer;display:flex;font-size:var(--font-size-sm);font-weight:600;gap:8px;padding:10px 20px;transition:all .2s}.add-conest-btn:hover{opacity:.9;transform:translateY(-1px)}.add-conest-btn .plus-icon{height:16px;width:16px}.pending-section{margin-bottom:var(--spacing-lg)}.subsection-title{color:var(--color-text);font-size:var(--font-size-base);font-weight:600;margin:0 0 var(--spacing-md) 0}.conests-list{flex-direction:column}.conest-card,.conests-list{display:flex;gap:var(--spacing-md)}.conest-card{align-items:center;background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md);transition:all .2s}.conest-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow)}.conest-card.active{border-color:#22c55e}.conest-card.pending{border-color:#f59e0b}.conest-icon{align-items:center;background:var(--color-bg);border-radius:var(--radius);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.conest-icon .icon{color:var(--color-primary);height:24px;width:24px}.conest-card.active .conest-icon{background:#dcfce7}.conest-card.active .conest-icon .icon{color:#22c55e}.conest-card.pending .conest-icon{background:#fef3c7}.conest-card.pending .conest-icon .icon{color:#f59e0b}.conest-info{flex:1 1}.conest-name{color:var(--color-text);font-size:var(--font-size-base);font-weight:600;margin:0 0 4px}.status-badge{border-radius:var(--radius-full);display:inline-block;font-size:var(--font-size-xs);font-weight:600;padding:4px 12px}.status-badge.status-accepted{background:#dcfce7;color:#16a34a}.status-badge.status-pending{background:#fef3c7;color:#ca8a04}.status-badge.status-declined{background:#fee;color:#dc2626}.conest-actions{display:flex;gap:8px}.action-btn{align-items:center;border:none;border-radius:var(--radius);cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s;width:40px}.action-btn.accept{background:#dcfce7;color:#16a34a}.action-btn.accept:hover{background:#22c55e;color:#fff}.action-btn.decline{background:#fee;color:#dc2626}.action-btn.decline:hover{background:#dc2626;color:#fff}.action-icon{height:20px;width:20px}.remove-btn{background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-sm);padding:8px 16px;transition:all .2s}.remove-btn:hover{background:#fee;border-color:#dc2626;color:#dc2626}.search-container{display:flex;gap:8px;margin-bottom:var(--spacing-lg)}.search-input{background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);flex:1 1;font-size:var(--font-size-base);padding:12px 16px}.search-input:focus{border-color:var(--color-primary);outline:none}.search-btn{background:var(--color-primary);border:none;border-radius:var(--radius);color:#fff;cursor:pointer;font-size:var(--font-size-base);font-weight:600;padding:12px 24px;transition:all .2s}.search-btn:hover:not(:disabled){opacity:.9}.search-btn:disabled{cursor:not-allowed;opacity:.5}.search-results{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:400px;overflow-y:auto}.search-result-item{align-items:center;background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius);display:flex;justify-content:space-between;padding:var(--spacing-md);transition:border-color .2s}.search-result-item:hover{border-color:var(--color-primary)}.family-name{color:var(--color-text);font-size:var(--font-size-base);font-weight:600;margin:0 0 4px}.family-code{color:var(--color-text-secondary);font-family:monospace;font-size:var(--font-size-xs);margin:0}.invite-btn{border-radius:var(--radius-sm);padding:8px 16px;transition:all .2s}.invite-btn:hover{opacity:.9}.no-results{font-size:var(--font-size-sm)}.loading-state,.no-results{color:var(--color-text-secondary);padding:2rem;text-align:center}.error-banner{background:#fee;border-radius:var(--radius);color:#c00;font-size:var(--font-size-sm);margin-bottom:var(--spacing-md);padding:12px 16px}@media (min-width:768px){.conests-list{display:grid;grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.add-conest-btn span{display:none}.conest-card{flex-wrap:wrap}.conest-actions{justify-content:flex-end;width:100%}}.monnest-page{background:var(--color-bg);min-height:100vh;padding:var(--spacing-md)}.family-card{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);border-radius:var(--radius-md);box-shadow:var(--shadow-md);color:#fff;margin-bottom:var(--spacing-lg);padding:var(--spacing-2xl);text-align:center}.family-icon{font-size:64px;margin-bottom:var(--spacing)}.family-name{font-size:var(--font-size-2xl);font-weight:700;margin:0 0 var(--spacing-sm) 0}.family-description{font-size:var(--font-size-md);margin:0 0 var(--spacing-md) 0;opacity:.95}.family-stats{align-items:center;display:flex;font-size:var(--font-size-sm);font-weight:600;gap:var(--spacing);justify-content:center;opacity:.9}.members-section{margin-bottom:var(--spacing-lg)}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-md)}.section-title{color:var(--color-text);font-size:var(--font-size-xl);font-weight:700;margin:0}.invite-btn{align-items:center;background:var(--color-primary);border:none;border-radius:var(--radius-lg);color:#fff;cursor:pointer;display:flex;font-size:var(--font-size-sm);font-weight:600;gap:6px;padding:10px 16px;transition:all .2s ease}.invite-btn:hover{background:var(--color-primary-dark);box-shadow:var(--shadow);transform:translateY(-1px)}.invite-icon{height:18px;width:18px}.members-list{display:flex;flex-direction:column;gap:var(--spacing)}.member-card{background:var(--color-bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow);display:flex;gap:var(--spacing-md);padding:var(--spacing-md);transition:all .2s ease}.member-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.member-avatar{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);border-radius:var(--radius);color:#fff;display:flex;flex-shrink:0;font-size:var(--font-size-lg);font-weight:700;height:56px;justify-content:center;width:56px}.member-info{display:flex;flex:1 1;flex-direction:column;gap:var(--spacing-sm)}.member-header{align-items:flex-start;display:flex;gap:var(--spacing);justify-content:space-between}.member-name{color:var(--color-text);font-size:var(--font-size-md);font-weight:700;margin:0 0 4px}.member-email{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}.member-badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:700;line-height:1;padding:5px 12px;white-space:nowrap}.member-since{color:var(--color-text-light);font-size:var(--font-size-sm);margin:0}.member-actions{display:flex;gap:var(--spacing-sm)}.member-action-btn{align-items:center;background:var(--color-bg-secondary);border:none;border-radius:var(--radius);color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:var(--font-size-xs);font-weight:600;gap:6px;padding:8px 14px;transition:all .2s ease}.member-action-btn:hover{background:var(--color-border);color:var(--color-text)}.action-icon{height:14px;width:14px}.share-code-btn{align-items:center;background:#fff3;border:2px solid #ffffff4d;border-radius:var(--radius-lg);color:#fff;cursor:pointer;display:inline-flex;font-size:var(--font-size-sm);font-weight:600;gap:8px;margin-top:var(--spacing-md);padding:12px 24px;transition:all .2s ease}.share-code-btn:hover{background:#ffffff4d;border-color:#ffffff80}.share-icon{height:18px;width:18px}.invite-code-box{align-items:center;background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius);display:flex;gap:var(--spacing-sm);padding:var(--spacing-md)}.invite-code{color:var(--color-primary);flex:1 1;font-family:monospace;font-size:var(--font-size-xl);font-weight:700;letter-spacing:2px}.copy-btn{background:var(--color-primary);border:none;border-radius:var(--radius);color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .2s}.copy-btn:hover{opacity:.9;transform:translateY(-1px)}@media (min-width:375px){.family-card{padding:var(--spacing-xl)}}@media (min-width:425px){.member-card{align-items:flex-start;flex-direction:row}.member-avatar{font-size:var(--font-size-xl);height:60px;width:60px}}@media (min-width:768px){.monnest-page{padding:var(--spacing-xl)}.family-icon{font-size:80px}.family-name{font-size:var(--font-size-3xl)}.members-list{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(2,1fr)}.member-actions{flex-direction:row}.member-action-btn{flex:1 1}}@media (min-width:1024px){.members-list{grid-template-columns:repeat(3,1fr)}}@media (hover:none) and (pointer:coarse){.invite-btn,.member-action-btn,.share-code-btn{min-height:44px;padding:12px 20px}.close-btn{min-height:44px;min-width:44px}}@media (max-width:360px){.family-icon{font-size:48px}.family-name{font-size:var(--font-size-xl)}.member-actions{gap:4px}.member-action-btn span{display:none}}.event-card{background:var(--color-bg-card);border-left:4px solid var(--color-primary);border-radius:var(--radius-md);box-shadow:var(--shadow);display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing);padding:var(--spacing-md);transition:all .2s ease}.event-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.event-time{align-items:center;display:flex;flex-direction:column;justify-content:flex-start;min-width:60px}.event-hour{color:var(--color-primary);font-size:var(--font-size-lg);font-weight:700;white-space:nowrap}.event-content{flex:1 1;flex-direction:column}.event-content,.event-header{display:flex;gap:var(--spacing)}.event-header{align-items:flex-start}.event-icon{font-size:28px;line-height:1}.event-info{flex:1 1}.event-title{color:var(--color-text);font-size:var(--font-size-md);font-weight:700;margin:0 0 6px}.event-location{align-items:center;color:var(--color-text-secondary);display:flex;font-size:var(--font-size-sm);gap:6px}.location-icon{color:var(--color-primary-light);height:14px;width:14px}.event-distance{color:var(--color-text-light)}.event-details{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.event-participants{align-items:center;display:flex;gap:8px}.participants-icon{color:var(--color-text-secondary);height:16px;width:16px}.participants-avatars{display:flex;margin-left:-4px}.participant-avatar{align-items:center;background:var(--color-primary-light);border:2px solid var(--color-bg-card);border-radius:var(--radius-full);color:#fff;display:flex;font-size:10px;font-weight:700;height:28px;justify-content:center;margin-left:-8px;width:28px}.participant-avatar:first-child{margin-left:0}.participants-count{font-weight:500}.event-duration,.participants-count{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.event-duration{align-items:center;display:flex;gap:6px}.duration-icon{height:14px;width:14px}.event-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.event-badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:700;line-height:1;padding:4px 10px}.badge-urgent{background:#fee2e2;color:#dc2626}.badge-important{background:#fef3c7;color:#d97706}.badge-normal,.event-tag{background:var(--color-bg-secondary);color:var(--color-text-secondary)}.event-tag{border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;line-height:1;padding:4px 10px}.event-actions{display:flex;gap:var(--spacing-xs);margin-left:auto}.event-action-btn{align-items:center;background:var(--color-bg-secondary);border:none;border-radius:var(--radius);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s;width:32px}.event-action-btn:hover{background:var(--color-border)}.event-delete-btn:hover{background:#fee;color:#c00}.action-icon-small{height:16px;width:16px}.agenda-page{background:var(--color-bg);min-height:100vh;padding:var(--spacing-md)}.agenda-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:var(--spacing-lg)}.agenda-title{color:var(--color-text);font-size:var(--font-size-2xl);font-weight:700;margin:0 0 6px}.agenda-date{color:var(--color-text-secondary);font-size:var(--font-size-base);margin:0;text-transform:capitalize}.agenda-filters{-webkit-overflow-scrolling:touch;display:flex;gap:8px;margin-bottom:var(--spacing-md);overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.agenda-filters::-webkit-scrollbar{display:none}.filter-btn{background:var(--color-bg-card);border-radius:20px;box-shadow:0 2px 4px #0000000d;font-size:var(--font-size-sm);font-weight:600;overflow:hidden;padding:10px 20px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap}.filter-btn:before{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%;z-index:-1}.filter-btn:hover{box-shadow:0 4px 8px #0000001a;color:var(--color-text);transform:translateY(-2px)}.filter-btn.active{box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3);color:#fff;transform:translateY(-2px)}.filter-btn.active:before{opacity:1}.filter-btn:active{transform:translateY(0)}@keyframes ripple{0%{opacity:1;transform:scale(0)}to{opacity:0;transform:scale(4)}}.filter-btn:after{background:#ffffff80;border-radius:100%;content:"";height:5px;left:50%;opacity:0;position:absolute;top:50%;transform:scale(1) translate(-50%,-50%);transform-origin:50% 50%;width:5px}.filter-btn.active:active:after{animation:ripple .6s ease-out}.agenda-tabs{background:var(--color-bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;gap:0;margin-bottom:var(--spacing-lg);padding:4px}.tab-btn{background:#0000;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;flex:1 1;font-size:var(--font-size-sm);font-weight:600;padding:10px 20px;transition:all .2s ease}.tab-btn:hover{color:var(--color-text)}.tab-btn.active{background:var(--color-primary);box-shadow:var(--shadow-sm);color:#fff}.events-list{display:flex;flex-direction:column}.add-event-btn{align-items:center;background:var(--color-primary);border:none;border-radius:var(--radius-full);box-shadow:var(--shadow-md);cursor:pointer;display:flex;height:48px;justify-content:center;transition:all .2s ease;width:48px}.add-event-btn:hover{box-shadow:var(--shadow-lg);transform:scale(1.05)}.add-event-btn .plus-icon{color:#fff;height:24px;width:24px}.modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:var(--spacing-md);position:fixed;right:0;top:0;z-index:1000}.modal-content{background:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--spacing-lg)}.modal-header h2{color:var(--color-text);font-size:var(--font-size-xl);margin:0}.close-btn{background:none;border:none;border-radius:var(--radius);cursor:pointer;padding:8px;transition:background .2s}.close-btn:hover{background:var(--color-bg-hover)}.close-icon{color:var(--color-text-secondary);height:24px;width:24px}.modal-body{padding:var(--spacing-lg)}.form-group{margin-bottom:var(--spacing-md)}.form-group label{color:var(--color-text);display:block;font-size:var(--font-size-sm);font-weight:600;margin-bottom:8px}.form-input{background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:var(--font-size-base);padding:12px 16px;transition:border-color .2s;width:100%}.form-input:focus{border-color:var(--color-primary);outline:none}.modal-footer{border-top:1px solid var(--color-border);display:flex;gap:var(--spacing-sm);padding:var(--spacing-lg)}.btn-primary,.btn-secondary{border:none;border-radius:var(--radius);cursor:pointer;flex:1 1;font-size:var(--font-size-base);font-weight:600;padding:12px 24px;transition:all .2s}.btn-secondary{background:var(--color-bg)}.btn-secondary:hover{background:var(--color-bg-hover)}.btn-primary:hover{opacity:.9}.btn-primary:disabled{cursor:not-allowed;opacity:.5;transform:none}.empty-state{background:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow);padding:var(--spacing-2xl) var(--spacing-md);text-align:center}.empty-icon{font-size:64px;margin-bottom:var(--spacing-md);opacity:.5}.empty-state h3{color:var(--color-text);font-size:var(--font-size-xl);font-weight:700;margin:0 0 var(--spacing-sm) 0}.empty-state p{color:var(--color-text-secondary);font-size:var(--font-size-base);margin:0 0 var(--spacing-lg) 0}.empty-action-btn{align-items:center;background:var(--color-primary);border:none;border-radius:var(--radius-lg);color:#fff;cursor:pointer;display:inline-flex;font-size:var(--font-size-base);font-weight:600;gap:8px;padding:12px 24px;transition:all .2s}.empty-action-btn:hover{box-shadow:var(--shadow-md);opacity:.9;transform:translateY(-2px)}.plus-icon-small{height:20px;width:20px}@media (min-width:768px){.agenda-page{padding:var(--spacing-xl)}.agenda-header{margin-bottom:var(--spacing-xl)}.agenda-title{font-size:var(--font-size-3xl)}.agenda-filters{justify-content:center}.events-list{margin:0 auto;max-width:800px}}@media (min-width:1024px){.modal-content{max-width:600px}}@media (hover:none) and (pointer:coarse){.add-event-btn{height:56px;width:56px}.filter-btn{padding:12px 24px}.filter-btn,.tab-btn{min-height:44px}}@media (max-width:360px){.agenda-header{align-items:flex-start;flex-direction:column;gap:var(--spacing-md)}.add-event-btn{align-self:flex-end}}.activity-card{background:var(--color-bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow);margin-bottom:var(--spacing-md);overflow:hidden;transition:all .2s ease}.activity-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.activity-image{align-items:center;background:linear-gradient(135deg,#e0f2fe,#ddd6fe);display:flex;height:180px;justify-content:center;overflow:hidden;position:relative;width:100%}.activity-image img{height:100%;object-fit:cover;width:100%}.activity-emoji{font-size:80px}.activity-match-badge{background:var(--color-primary);border-radius:var(--radius-full);box-shadow:var(--shadow);color:#fff;font-size:var(--font-size-xs);font-weight:700;padding:6px 12px;position:absolute;right:12px;top:12px}.activity-content{padding:var(--spacing-md)}.activity-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:var(--spacing)}.activity-title{color:var(--color-text);font-size:var(--font-size-lg);font-weight:700;margin:0 0 4px}.activity-category{background:#2d5f5d1a;border-radius:var(--radius-full);color:var(--color-primary);display:inline-block;font-size:var(--font-size-xs);font-weight:600;margin-top:4px;padding:3px 10px}.activity-save-btn{align-items:center;background:var(--color-bg-secondary);border:none;border-radius:var(--radius-full);color:var(--color-text-secondary);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.activity-save-btn:hover{background:var(--color-border);transform:scale(1.1)}.activity-save-btn.saved{color:#ef4444}.save-icon{height:20px;width:20px}.activity-rating{gap:8px;margin-bottom:var(--spacing)}.activity-rating,.rating-stars{align-items:center;display:flex}.rating-stars{gap:4px}.star-icon{fill:#fbbf24;color:#fbbf24;height:16px;width:16px}.rating-value{color:var(--color-text);font-size:var(--font-size-base);font-weight:700}.activity-description,.rating-reviews{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.activity-description{line-height:1.6;margin:0 0 var(--spacing-md) 0}.activity-info{border-bottom:1px solid var(--color-border);border-top:1px solid var(--color-border);display:flex;flex-wrap:wrap;gap:var(--spacing);margin-bottom:var(--spacing-md);padding:var(--spacing) 0}.activity-info-item{align-items:center;color:var(--color-text-secondary);display:flex;font-size:var(--font-size-sm);gap:6px}.info-icon{color:var(--color-primary-light);height:16px;width:16px}.activity-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:var(--spacing-md)}.activity-tag{background:var(--color-bg-secondary);border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:600;padding:6px 12px}.activity-actions{display:flex;gap:var(--spacing-sm)}.activity-btn{align-items:center;border:none;border-radius:var(--radius-lg);cursor:pointer;display:flex;flex:1 1;font-size:var(--font-size-sm);font-weight:700;gap:8px;justify-content:center;padding:12px 20px;transition:all .2s ease}.activity-btn-primary{background:var(--color-primary);color:#fff}.activity-btn-primary:hover{background:var(--color-primary-dark);box-shadow:var(--shadow);transform:translateY(-1px)}.btn-icon{height:18px;width:18px}.activity-links{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.activity-link-btn{align-items:center;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);cursor:pointer;display:flex;flex:1 1;font-size:var(--font-size-sm);font-weight:600;gap:6px;justify-content:center;padding:10px 16px;text-decoration:none;transition:all .2s ease}.activity-link-btn:hover{background:var(--color-primary);border-color:var(--color-primary);box-shadow:var(--shadow-sm);color:#fff;transform:translateY(-1px)}.link-icon{height:16px;width:16px}.discover-page{background:var(--color-bg);min-height:100vh;padding:var(--spacing-md)}.suggestions-box{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:var(--radius-md);box-shadow:var(--shadow);margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.suggestions-header{align-items:center;display:flex;gap:var(--spacing)}.suggestions-icon{align-items:center;background:#fff;border-radius:var(--radius);display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.sparkles-icon{color:var(--color-accent-yellow);height:24px;width:24px}.suggestions-content{flex:1 1}.suggestions-title{color:#78350f;font-size:var(--font-size-md);font-weight:700;margin:0 0 4px}.suggestions-subtitle{color:#92400e;font-size:var(--font-size-sm);line-height:1.4;margin:0}.filter-btn{align-items:center;background:#fff;border:none;border-radius:var(--radius);color:var(--color-text-secondary);cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;transition:all .2s ease;width:40px}.filter-btn:hover{box-shadow:var(--shadow);transform:scale(1.05)}.filter-icon{height:20px;width:20px}.discover-tabs{background:var(--color-bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;gap:0;margin-bottom:var(--spacing-lg);padding:4px}.discover-tab{background:#0000;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;flex:1 1;font-size:var(--font-size-sm);font-weight:600;padding:10px 20px;transition:all .2s ease}.discover-tab:hover{color:var(--color-text)}.discover-tab.active{background:var(--color-primary);box-shadow:var(--shadow-sm);color:#fff}.activities-list{display:flex;flex-direction:column}.empty-activities,.loading-message{color:var(--color-text-secondary);padding:var(--spacing-2xl);text-align:center}.empty-activities p{margin:0}.discover-controls{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.discover-view-toggle{background:#f3f4f6;border-radius:12px;display:flex;gap:.5rem;padding:.25rem;width:-webkit-fit-content;width:fit-content}.discover-view-btn{background:#0000;border:none;border-radius:8px;color:var(--color-text-light);cursor:pointer;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:all .3s ease}.discover-view-btn.active{background:#fff;box-shadow:0 2px 4px #0000001a;color:var(--color-primary)}.discover-view-btn:hover:not(.active){color:var(--color-text)}.activities-map-container{border-radius:12px;margin:1.5rem 0;overflow:hidden}@media (max-width:768px){.discover-controls{gap:.75rem}.discover-view-toggle{justify-content:center;width:100%}.discover-view-btn{flex:1 1;text-align:center}}@media (min-width:768px){.discover-page{padding:var(--spacing-xl)}.suggestions-box{padding:var(--spacing-lg)}.discover-tabs{justify-content:center;margin:0 auto var(--spacing-lg);max-width:600px}.activities-list{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.activities-list{grid-template-columns:repeat(3,1fr)}}@media (hover:none) and (pointer:coarse){.discover-tab,.filter-btn{min-height:44px}}.nestia-page{background:var(--color-bg);display:flex;flex-direction:column;min-height:100vh}.chat-header{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);box-shadow:var(--shadow);color:#fff;gap:var(--spacing);padding:var(--spacing-lg) var(--spacing-md)}.chat-header,.chat-header-icon{align-items:center;display:flex}.chat-header-icon{background:#fff3;border-radius:var(--radius);height:48px;justify-content:center;width:48px}.sparkles-icon{height:28px;width:28px}.chat-title{font-size:var(--font-size-xl);font-weight:700;margin:0 0 4px}.chat-subtitle{font-size:var(--font-size-sm);margin:0;opacity:.9}.messages-container{display:flex;flex:1 1;flex-direction:column;gap:var(--spacing-md);overflow-y:auto;padding:var(--spacing-md)}.message{align-items:flex-end;display:flex;gap:var(--spacing)}.user-message{flex-direction:row-reverse}.assistant-message{flex-direction:row}.message-avatar{align-items:center;border-radius:var(--radius-full);display:flex;flex-shrink:0;font-size:var(--font-size-sm);font-weight:700;height:36px;justify-content:center;width:36px}.assistant-avatar{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);color:#fff}.user-avatar{background:var(--color-bg-secondary);color:var(--color-text)}.message-bubble{border-radius:var(--radius-md);box-shadow:var(--shadow-sm);max-width:75%;padding:12px 16px}.user-message .message-bubble{background:var(--color-primary);border-bottom-right-radius:4px;color:#fff}.assistant-message .message-bubble{background:var(--color-bg-card);border-bottom-left-radius:4px;color:var(--color-text)}.message-content{font-size:var(--font-size-base);line-height:1.5;margin:0}.typing-indicator{align-items:center;display:flex;gap:6px;padding:16px}.typing-indicator span{animation:typing 1.4s infinite;background:var(--color-text-secondary);border-radius:50%;height:8px;width:8px}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-10px)}}.chat-input-container{background:var(--color-bg-card);border-top:1px solid var(--color-border);box-shadow:0 -2px 10px #0000000d;padding:var(--spacing-md)}.chat-input-wrapper{align-items:center;display:flex;gap:var(--spacing-sm);max-width:100%}.chat-input{background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);flex:1 1;font-size:var(--font-size-base);padding:12px 16px;transition:border-color .2s ease}.chat-input:focus{border-color:var(--color-primary);outline:none}.chat-input::placeholder{color:var(--color-text-light)}.send-btn{align-items:center;background:var(--color-primary);border:none;border-radius:var(--radius-full);color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:44px;justify-content:center;transition:all .2s ease;width:44px}.send-btn:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--shadow);transform:scale(1.05)}.send-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.send-icon{height:20px;transform:rotate(45deg);width:20px}@media (min-width:768px){.nestia-page{margin:0 auto;max-width:800px}.chat-header{padding:var(--spacing-xl)}.chat-title{font-size:var(--font-size-3xl)}.messages-container{padding:var(--spacing-xl)}.message-bubble{max-width:70%}}@media (min-width:1024px){.nestia-page{max-width:900px}.message-bubble{max-width:60%}}@media (hover:none) and (pointer:coarse){.send-btn{height:48px;width:48px}.chat-input{min-height:48px}}.auth-page{align-items:center;background:linear-gradient(135deg,#e0f2fe,#ddd6fe);display:flex;justify-content:center;min-height:100vh;padding:var(--spacing-lg)}.auth-container{max-width:480px;width:100%}.auth-card{background:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--spacing-2xl)}.auth-logo{margin-bottom:var(--spacing-lg)}.auth-logo,.logo-icon{display:flex;justify-content:center}.logo-icon{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);color:#fff;font-size:40px;font-weight:800;height:80px;width:80px}.auth-header{margin-bottom:var(--spacing-xl);text-align:center}.auth-header h1{color:var(--color-text);font-size:var(--font-size-3xl);font-weight:700;margin:0 0 var(--spacing-sm) 0}.auth-header p{color:var(--color-text-secondary);font-size:var(--font-size-base);margin:0}.auth-message{border-radius:var(--radius);font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--spacing-md);padding:var(--spacing)}.auth-message.error{background:#fee2e2;border:1px solid #fecaca;color:#dc2626}.auth-message.success{background:#d1fae5;border:1px solid #a7f3d0;color:#059669}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-row{grid-gap:var(--spacing);display:grid;gap:var(--spacing);grid-template-columns:1fr 1fr}.input-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.input-group label{color:var(--color-text);font-size:var(--font-size-sm);font-weight:600}.input-with-icon{align-items:center;display:flex;position:relative}.input-icon{color:var(--color-text-secondary);height:20px;left:14px;pointer-events:none;position:absolute;width:20px}.input-with-icon input{background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:var(--font-size-base);padding:12px 14px 12px 42px;transition:border-color .2s ease;width:100%}.input-with-icon input:focus{border-color:var(--color-primary);outline:none}.auth-button{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);border:none;border-radius:var(--radius-lg);color:#fff;cursor:pointer;font-size:var(--font-size-md);font-weight:700;margin-top:var(--spacing-sm);padding:14px;transition:all .2s ease;width:100%}.auth-button:hover:not(:disabled){box-shadow:var(--shadow-md);transform:translateY(-2px)}.auth-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.forgot-password-link{margin-top:var(--spacing-xs);text-align:right}.link-button{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:var(--font-size-sm);font-weight:500;padding:0;text-decoration:underline}.link-button:hover{color:var(--color-primary-light)}.auth-divider{align-items:center;color:var(--color-text-secondary);display:flex;font-size:var(--font-size-sm);margin:var(--spacing-lg) 0;text-align:center}.auth-divider:after,.auth-divider:before{border-bottom:1px solid var(--color-border);content:"";flex:1 1}.auth-divider span{padding:0 var(--spacing)}.oauth-buttons{flex-direction:column}.oauth-button,.oauth-buttons{display:flex;gap:var(--spacing)}.oauth-button{align-items:center;background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);cursor:pointer;font-size:var(--font-size-base);font-weight:600;justify-content:center;padding:12px;transition:all .2s ease;width:100%}.oauth-button:hover:not(:disabled){border-color:var(--color-primary);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.oauth-button:disabled{cursor:not-allowed;opacity:.6}.oauth-icon{height:20px;width:20px}.oauth-button.google .oauth-icon{color:#4285f4}.auth-toggle{margin-top:var(--spacing-lg);text-align:center}.toggle-button{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:var(--font-size-sm);font-weight:600;padding:var(--spacing-sm);transition:all .2s ease}.toggle-button:hover{text-decoration:underline}.auth-privacy{background:var(--color-bg-secondary);border-radius:var(--radius);margin-top:var(--spacing-lg);padding:var(--spacing);text-align:center}.auth-privacy p{color:var(--color-text-secondary);font-size:var(--font-size-xs);line-height:1.5;margin:0}@media (max-width:640px){.auth-page{padding:var(--spacing)}.auth-card{padding:var(--spacing-lg)}.form-row{grid-template-columns:1fr}.auth-header h1{font-size:var(--font-size-2xl)}}.onboarding-container{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0,var(--color-secondary) 100%);display:flex;justify-content:center;min-height:100vh;padding:2rem 1rem}.onboarding-step{animation:fadeIn .5s ease;background:#fff;border-radius:24px;box-shadow:0 20px 60px #00000026;max-width:500px;padding:3rem 2rem;text-align:center;width:100%}.onboarding-welcome{padding:4rem 2rem}.onboarding-completion{padding:3rem 2rem}.onboarding-progress{color:var(--color-text-light);font-size:.875rem;font-weight:500;margin-bottom:1.5rem}.onboarding-icon{animation:bounce 1s ease infinite;font-size:4rem;margin-bottom:1.5rem}.onboarding-brand{color:var(--color-primary);font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.onboarding-title{color:var(--color-text);font-size:1.75rem;font-weight:700;margin-bottom:.75rem}.onboarding-subtitle{color:var(--color-text);font-size:1.125rem;font-weight:600;margin-bottom:1rem}.onboarding-description{color:var(--color-text-light);font-size:1rem;line-height:1.6;margin-bottom:2rem}.onboarding-form{margin:2rem 0}.onboarding-input{border:2px solid #e5e7eb;border-radius:12px;font-family:inherit;font-size:1rem;padding:1rem 1.5rem;transition:all .3s ease;width:100%}.onboarding-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2d5f5d1a;outline:none}.onboarding-input:disabled{background-color:#f3f4f6;cursor:not-allowed}.onboarding-error{color:#dc2626;font-size:.875rem;margin-top:.5rem;text-align:left}.onboarding-preferences-count{background-color:#f0fdf4;border-radius:12px;color:var(--color-primary);font-size:.875rem;font-weight:600;margin-bottom:1.5rem;padding:.75rem 1rem}.onboarding-preferences-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr);margin-bottom:2rem}.onboarding-preference-btn{background:#fff;border:2px solid #e5e7eb;border-radius:12px;color:var(--color-text);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;padding:1rem;transition:all .3s ease}.onboarding-preference-btn:hover{background-color:#f0fdf4;border-color:var(--color-primary)}.onboarding-preference-btn.selected{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.onboarding-btn-primary{background-color:var(--color-primary);border:none;border-radius:12px;color:#fff;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .3s ease;width:100%}.onboarding-btn-primary:hover:not(:disabled){background-color:var(--color-secondary);box-shadow:0 8px 20px #2d5f5d4d;transform:translateY(-2px)}.onboarding-btn-primary:disabled{cursor:not-allowed;opacity:.5}.onboarding-btn-secondary{background-color:initial;border:2px solid #e5e7eb;border-radius:12px;color:var(--color-text-light);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;padding:.875rem 1.5rem;transition:all .3s ease}.onboarding-btn-secondary:hover{border-color:var(--color-primary);color:var(--color-primary)}.onboarding-actions{display:flex;gap:1rem;margin-top:2rem}.onboarding-actions .onboarding-btn-primary{flex:1 1}.onboarding-summary{background-color:#f9fafb;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.onboarding-summary-item{color:var(--color-text);font-size:.875rem;margin-bottom:.5rem}.onboarding-summary-item:last-child{margin-bottom:0}.onboarding-summary-item strong{color:var(--color-primary);font-weight:600;margin-right:.5rem}.dark-mode .onboarding-step{background:var(--color-bg-dark)}.dark-mode .onboarding-step,.dark-mode .onboarding-subtitle,.dark-mode .onboarding-title{color:var(--color-text-dark)}.dark-mode .onboarding-input,.dark-mode .onboarding-preference-btn{background-color:var(--color-card-dark);border-color:#374151;color:var(--color-text-dark)}.dark-mode .onboarding-preference-btn:hover{background-color:#2d5f5d1a}.dark-mode .onboarding-summary{background-color:#1f2937}@media (max-width:600px){.onboarding-container{padding:1rem .5rem}.onboarding-step{padding:2rem 1.5rem}.onboarding-completion,.onboarding-welcome{padding:2.5rem 1.5rem}.onboarding-icon{font-size:3rem}.onboarding-brand{font-size:2rem}.onboarding-title{font-size:1.5rem}.onboarding-subtitle{font-size:1rem}.onboarding-preferences-grid{grid-template-columns:1fr}}.onboarding-accessibility-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr;margin:1.5rem 0;text-align:left}.onboarding-accessibility-btn{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;padding:1rem 1.5rem;text-align:left;transition:all .3s ease}.onboarding-accessibility-btn:hover{background:#f0fdf4;border-color:var(--color-primary)}.onboarding-accessibility-btn.selected{background:#dcfce7;border-color:var(--color-primary);box-shadow:0 0 0 3px #2d5f5d1a}.accessibility-label{color:var(--color-text);font-size:1rem;font-weight:600;margin-bottom:.25rem}.accessibility-description{color:var(--color-text-light);font-size:.875rem}@media (max-width:640px){.onboarding-accessibility-grid{gap:.75rem}}.notification-bell-container{position:relative}.notification-bell-btn{background:none;border:none;cursor:pointer;font-size:1.5em;padding:8px;position:relative;transition:transform .2s}.notification-bell-btn:hover{transform:scale(1.1)}.notification-badge{background:#e74c3c;border-radius:10px;font-size:.5em;height:18px;min-width:18px;padding:0 5px;right:0;top:0}.notification-overlay{background:#0000004d;bottom:0;left:0;position:fixed;right:0;top:0;z-index:998}.notification-dropdown{animation:dropdown-appear .2s ease;background:#fff;background:var(--color-card-bg,#fff);border-radius:15px;box-shadow:0 10px 40px #0003;max-height:450px;overflow:hidden;position:absolute;right:0;top:calc(100% + 10px);width:320px;z-index:999}@keyframes dropdown-appear{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-header{align-items:center;border-bottom:1px solid #eee;border-bottom:1px solid var(--color-border,#eee);display:flex;justify-content:space-between;padding:15px}.notification-header h3{color:#333;color:var(--color-text,#333);font-size:1.1em;margin:0}.mark-all-read-btn{background:none;border:none;color:#6366f1;color:var(--color-primary,#6366f1);cursor:pointer;font-size:.85em;font-weight:600}.mark-all-read-btn:hover{text-decoration:underline}.notification-list{max-height:380px;overflow-y:auto}.notification-empty,.notification-loading{color:#888;color:var(--color-text-light,#888);padding:30px;text-align:center}.notification-empty .empty-icon{display:block;font-size:2.5em;margin-bottom:10px}.notification-item{align-items:flex-start;border-bottom:1px solid #eee;border-bottom:1px solid var(--color-border,#eee);cursor:pointer;display:flex;gap:12px;padding:12px 15px;transition:background-color .2s}.notification-item:hover{background-color:#f5f5f5;background-color:var(--color-background,#f5f5f5)}.notification-item.unread{background-color:#6366f114}.notification-icon{flex-shrink:0;font-size:1.3em}.notification-content{flex:1 1;min-width:0}.notification-message{word-wrap:break-word;color:#333;color:var(--color-text,#333);font-size:.9em;line-height:1.4;margin:0 0 4px}.notification-time{color:#888;color:var(--color-text-light,#888);font-size:.8em}.unread-dot{background:#6366f1;background:var(--color-primary,#6366f1);border-radius:50%;flex-shrink:0;height:8px;margin-top:8px;width:8px}@media (max-width:400px){.notification-dropdown{right:-10px;width:calc(100vw - 30px)}}.header{background:var(--color-bg-card);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);left:0;padding:12px 16px;position:-webkit-sticky;position:sticky;right:0;top:0;z-index:999}.header-container{justify-content:space-between;margin:0 auto;max-width:600px}.header-container,.header-left{align-items:center;display:flex}.header-left{gap:12px}.header-logo{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);border-radius:12px;display:flex;height:40px;justify-content:center;width:40px}.logo-text{color:#fff;font-size:24px;font-weight:800;line-height:1}.header-title{color:var(--color-text);font-size:18px;font-weight:700;margin:0}.header-right{gap:8px}.header-icon-btn,.header-right{align-items:center;display:flex}.header-icon-btn{background:none;border:none;border-radius:10px;color:var(--color-text-secondary);cursor:pointer;height:36px;justify-content:center;position:relative;transition:all .2s ease;width:36px}.header-icon-btn:hover{background:var(--color-bg-secondary);color:var(--color-text)}.header-icon{height:22px;width:22px}.notification-badge{align-items:center;background:#ef4444;border:2px solid var(--color-bg-card);border-radius:50%;color:#fff;display:flex;font-size:10px;font-weight:700;height:16px;justify-content:center;position:absolute;right:4px;top:4px;width:16px}.user-menu{position:relative}.user-avatar-btn{padding:0!important}.user-avatar-header{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);border-radius:var(--radius-full);color:#fff;display:flex;font-size:var(--font-size-sm);font-weight:700;height:36px;justify-content:center;width:36px}.user-dropdown{animation:fadeIn .2s ease;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:250px;position:absolute;right:0;top:calc(100% + 8px);z-index:1000}.user-dropdown-header{align-items:center;display:flex;gap:var(--spacing);padding:var(--spacing-md)}.user-avatar-large{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);border-radius:var(--radius-full);color:#fff;display:flex;flex-shrink:0;font-size:var(--font-size-md);font-weight:700;height:48px;justify-content:center;width:48px}.user-info{flex:1 1;min-width:0}.user-name{color:var(--color-text);font-size:var(--font-size-base);font-weight:600}.user-email,.user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.dropdown-divider{background:var(--color-border);height:1px;margin:0}.dropdown-item{align-items:center;background:none;border:none;color:var(--color-text);cursor:pointer;display:flex;font-size:var(--font-size-base);font-weight:500;gap:var(--spacing);padding:var(--spacing) var(--spacing-md);text-align:left;transition:all .2s ease;width:100%}.dropdown-item:hover{background:var(--color-bg-secondary)}.dropdown-icon{color:var(--color-text-secondary);height:20px;width:20px}body.dark-mode .header{background:var(--color-bg-card);border-bottom-color:var(--color-border)}body.dark-mode .user-dropdown{background:var(--color-bg-card);border-color:var(--color-border)}.bottom-nav{background:var(--color-bg-card);border-top:1px solid var(--color-border);bottom:0;box-shadow:0 -2px 10px #0000000d;left:0;padding:8px 0;position:fixed;right:0;z-index:1000}.bottom-nav-container{align-items:center;display:flex;justify-content:space-around;margin:0 auto;max-width:600px;padding:0 16px}.bottom-nav-item{align-items:center;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;display:flex;flex-direction:column;gap:4px;justify-content:center;padding:8px 12px;position:relative;transition:all .2s ease}.bottom-nav-item.active,.bottom-nav-item:hover{color:var(--color-primary)}.bottom-nav-icon-wrapper{align-items:center;border-radius:12px;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.bottom-nav-item.active .bottom-nav-icon-wrapper{background:#2d5f5d1a}.bottom-nav-icon{height:24px;width:24px}.bottom-nav-label{font-size:11px;font-weight:600;letter-spacing:-.01em;transition:all .2s ease}.bottom-nav-item.active .bottom-nav-label{color:var(--color-primary)}body.dark-mode .bottom-nav{background:var(--color-bg-card);border-top-color:var(--color-border);box-shadow:0 -2px 10px #0000004d}:root{--color-primary:#2d5f5d;--color-primary-light:#4a8b7a;--color-primary-dark:#1f4442;--color-accent-yellow:#fdb813;--color-accent-orange:#ff8a3d;--color-text:#1f2937;--color-text-secondary:#6b7280;--color-text-light:#9ca3af;--color-bg:#f9fafb;--color-bg-card:#fff;--color-bg-secondary:#f3f4f6;--color-border:#e5e7eb;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 4px 6px -1px #0000001a;--shadow-md:0 10px 15px -3px #0000001a;--shadow-lg:0 20px 25px -5px #0000001a;--radius-sm:8px;--radius:12px;--radius-md:16px;--radius-lg:20px;--radius-xl:24px;--radius-full:9999px;--spacing-xs:4px;--spacing-sm:8px;--spacing:12px;--spacing-md:16px;--spacing-lg:20px;--spacing-xl:24px;--spacing-2xl:32px;--font-size-xs:11px;--font-size-sm:12px;--font-size-base:13px;--font-size-md:14px;--font-size-lg:16px;--font-size-xl:18px;--font-size-2xl:22px;--font-size-3xl:26px}body.dark-mode{--color-text:#f9fafb;--color-text-secondary:#d1d5db;--color-text-light:#9ca3af;--color-bg:#111827;--color-bg-card:#1f2937;--color-bg-secondary:#374151;--color-border:#374151;--shadow-sm:0 1px 2px 0 #0000004d;--shadow:0 4px 6px -1px #00000080;--shadow-md:0 10px 15px -3px #00000080;--shadow-lg:0 20px 25px -5px #00000080}body{background-color:#f9fafb;background-color:var(--color-bg);color:#1f2937;color:var(--color-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:13px;font-size:var(--font-size-base);line-height:1.5;transition:background-color .2s ease,color .2s ease}*{transition-duration:.2s;transition-property:background-color,color,border-color,opacity,transform;transition-timing-function:ease}.theme-changing *{transition:none!important}.page-container,.page-enter{animation:fadeIn .3s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.slide-in-right{animation:slideInRight .3s ease-out}.btn:active,button:active{transform:scale(.95);transition-duration:.1s}.btn-lift:hover,.card-lift:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.pulse{animation:pulse 2s infinite}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-content,.modal-enter{animation:slideUp .3s cubic-bezier(.4,0,.2,1)}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.modal-overlay{animation:fadeInOverlay .2s ease-out}@keyframes scaleUp{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.modal-scale{animation:scaleUp .3s cubic-bezier(.34,1.56,.64,1)}@keyframes pulseBadge{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.notification-badge{animation:pulseBadge 2s infinite}@keyframes shake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-5px)}20%,40%,60%,80%{transform:translateX(5px)}}.shake{animation:shake .5s}.loading-spinner,.spinner{animation:spin 1s linear infinite}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.skeleton{animation:shimmer 2s infinite;background:linear-gradient(90deg,var(--color-bg) 0,var(--color-bg-secondary) 50%,var(--color-bg) 100%);background-size:1000px 100%}@keyframes dotBounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.loading-dots span{animation:dotBounce 1.4s ease-in-out infinite both;background:var(--color-primary);border-radius:50%;display:inline-block;height:8px;margin:0 2px;width:8px}.loading-dots span:first-child{animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.list-item-enter{animation:fadeInUp .4s ease-out backwards}.list-item-enter:first-child{animation-delay:.05s}.list-item-enter:nth-child(2){animation-delay:.1s}.list-item-enter:nth-child(3){animation-delay:.15s}.list-item-enter:nth-child(4){animation-delay:.2s}.list-item-enter:nth-child(5){animation-delay:.25s}@keyframes expandCard{0%{transform:scale(1)}to{transform:scale(1.02)}}.card-expand:hover{animation:expandCard .2s forwards}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.icon-bounce{animation:bounce 2s infinite}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.icon-rotate{animation:rotate 2s linear infinite}html{scroll-behavior:smooth}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (hover:none) and (pointer:coarse){.btn:active,.card:active,button:active{opacity:.7}}.app{display:flex;flex-direction:column}.app,.app-container{background-color:var(--color-bg);min-height:100vh;transition:background-color .3s ease}.app-container{margin:0 auto;max-width:600px;position:relative;width:100%}.main{animation:fadeIn .3s ease-in;flex:1 1;overflow-y:auto;padding-bottom:80px}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-container{min-height:calc(100vh - 80px)}.card,.page-container{padding:var(--spacing-md)}.card{background:var(--color-bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow);margin-bottom:var(--spacing-md);transition:transform .2s ease,box-shadow .2s ease}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn{align-items:center;border:none;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-size:var(--font-size-base);font-weight:600;gap:var(--spacing-sm);padding:10px 20px;transition:all .2s ease}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-dark);box-shadow:var(--shadow);transform:translateY(-1px)}.btn-secondary{background:var(--color-bg-secondary);color:var(--color-text)}.btn-secondary:hover{background:var(--color-border)}input,select,textarea{background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:var(--font-size-base);padding:12px 16px;transition:border-color .2s ease;width:100%}input:focus,select:focus,textarea:focus{border-color:var(--color-primary);outline:none}.avatar{align-items:center;background:var(--color-primary-light);border-radius:var(--radius-full);color:#fff;display:flex;font-size:var(--font-size-base);font-weight:600;height:40px;justify-content:center;width:40px}.avatar-sm{font-size:var(--font-size-sm);height:32px;width:32px}.avatar-lg{font-size:var(--font-size-lg);height:50px;width:50px}.badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--font-size-xs);font-weight:600;line-height:1;padding:4px 12px}.badge-admin,.badge-parent{background:#10b981;color:#fff}.badge-ado{background:#fbbf24;color:#78350f}.badge-urgent{background:#ef4444;color:#fff}.loading-container{align-items:center;background:var(--color-bg);display:flex;flex-direction:column;gap:var(--spacing-md);justify-content:center;min-height:100vh}.loading-spinner{animation:spin .8s linear infinite;border:4px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:50px;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.loading-container p{color:var(--color-text-secondary);font-weight:500}@media (min-width:375px){.app-container{max-width:100%}}@media (min-width:425px){.card,.page-container{padding:var(--spacing-lg)}}@media (min-width:768px){.app-container{max-width:768px}.page-container{padding:var(--spacing-xl)}.btn{font-size:var(--font-size-md);padding:12px 24px}.card{padding:var(--spacing-xl)}.grid-2{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.app-container{max-width:1024px}.grid-3{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(3,1fr)}}@media (min-width:1440px){.app-container{max-width:1200px}}@media (hover:none) and (pointer:coarse){.btn,.clickable,a,button{align-items:center;display:inline-flex;justify-content:center;min-height:44px;min-width:44px}}@supports (padding:max(0px)){.app{padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right))}.main{padding-bottom:max(80px,calc(80px + env(safe-area-inset-bottom)))}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (max-width:640px){.page-container{padding:var(--spacing)}.card{border-radius:var(--radius);margin-bottom:var(--spacing)}.hide-mobile{display:none!important}}.high-contrast{--color-text:#000;--color-text-secondary:#333;--color-bg:#fff;--color-bg-card:#fff;--color-border:#000;--color-primary:#06c;--color-primary-dark:#049}.high-contrast .btn,.high-contrast button{border:2px solid #000;font-weight:700}.simplified-ui *{animation:none!important;transition:none!important}.simplified-ui .gradient{background:var(--color-primary)!important}.visual-indicators{--notification-pulse:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.visual-indicators .alert,.visual-indicators .notification{animation:var(--notification-pulse);border:3px solid var(--color-primary)}.large-touch-targets a,.large-touch-targets button,.large-touch-targets input,.large-touch-targets select{min-height:48px;min-height:var(--touch-target-min,48px);min-width:48px;min-width:var(--touch-target-min,48px);padding:12px 16px}.large-touch-targets .icon-btn{height:56px;width:56px}@font-face{font-display:swap;font-family:OpenDyslexic;font-style:normal;font-weight:400;src:url(https://cdn.jsdelivr.net/npm/open-dyslexic@1.0.3/fonts/OpenDyslexic-Regular.woff2) format("woff2")}@font-face{font-display:swap;font-family:OpenDyslexic;font-style:normal;font-weight:700;src:url(https://cdn.jsdelivr.net/npm/open-dyslexic@1.0.3/fonts/OpenDyslexic-Bold.woff2) format("woff2")}:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}.large-touch-targets :focus-visible{outline-offset:4px;outline-width:4px}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.skip-to-content{background:var(--color-primary);color:#fff;left:0;padding:8px 16px;position:absolute;text-decoration:none;top:-40px;z-index:100}.skip-to-content:focus{top:0}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}