:root{--ios-blue: #007AFF;--ios-green: #34C759;--ios-red: #FF3B30;--ios-orange: #FF9500;--ios-gray-1: #8E8E93;--ios-gray-2: #AEAEB2;--ios-gray-3: #C7C7CC;--ios-gray-4: #D1D1D6;--ios-gray-5: #E5E5EA;--ios-gray-6: #F5F5F7;--ios-separator: rgba(0, 0, 0, .08);--app-bg: #ffffff;--app-text: #1d1d1f;--app-hint: #86868b;--app-link: #007AFF;--app-button: #007AFF;--app-button-text: #ffffff;--app-secondary-bg: #f5f5f7;--card-bg: #ffffff;--card-border: rgba(0, 0, 0, .06);--nav-height: 56px;--safe-bottom: env(safe-area-inset-bottom, 0);--safe-top: env(safe-area-inset-top, 0);--page-padding: 16px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 14px;--radius-xl: 16px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,SF Pro Display,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:17px;line-height:1.47;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--app-text);background:var(--app-bg);color-scheme:light;overflow-x:hidden}.app{min-height:100%;padding-bottom:calc(var(--nav-height) + var(--safe-bottom))}.page{padding:var(--page-padding);padding-top:max(var(--page-padding),var(--safe-top));min-height:100%;max-width:600px;margin:0 auto}.page.chat-screen{padding:0;height:calc(100dvh - var(--nav-height) - var(--safe-bottom));min-height:0;max-width:none;display:flex;flex-direction:column}.page-title{font-size:22px;font-weight:700;letter-spacing:.37px;margin:0 0 24px;color:var(--app-text);line-height:1.18;text-align:center}.ios-group{background:var(--app-secondary-bg);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:24px}.ios-group-item{display:flex;align-items:center;min-height:44px;padding:12px 16px;background:var(--app-bg);border-bottom:.5px solid var(--ios-separator);font-size:17px}.ios-group-item:last-child{border-bottom:none}.ios-group-item:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.ios-group-item:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg)}.ios-group-item:only-child{border-radius:var(--radius-lg)}.nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:#ffffffeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:.5px solid var(--ios-separator);display:flex;align-items:flex-start;justify-content:space-around;z-index:100}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;min-height:var(--nav-height);color:var(--app-hint);text-decoration:none;font-size:10px;font-weight:500;-webkit-tap-highlight-color:transparent;border:none;background:none;cursor:pointer;font-family:inherit;transition:color .2s}.nav-item:active{opacity:.6}.nav-item.active{color:var(--app-link);font-weight:600}.nav-icon{width:28px;height:28px;margin-bottom:4px;display:flex;align-items:center;justify-content:center}.nav-icon img{width:24px;height:24px;object-fit:contain;opacity:.6}.nav-item.active .nav-icon img{opacity:1}.nav-icon--large img{width:34px;height:34px}.nav-icon--badge{position:relative}.nav-unread-badge{position:absolute;top:-6px;right:-8px;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:600;line-height:16px;text-align:center;color:#fff;background:var(--ios-red);border-radius:8px}.btn{display:block;width:100%;padding:14px 20px;margin:0 0 12px;font-size:17px;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;font-family:inherit;-webkit-tap-highlight-color:transparent;background:var(--app-button);color:var(--app-button-text);transition:opacity .15s}.btn:active{opacity:.8}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--app-secondary-bg);color:var(--app-link)}.profile-avatar-wrap{display:flex;justify-content:center;margin-bottom:28px}.profile-header-card{background:var(--app-bg);border-radius:var(--radius-lg);padding:28px 20px;margin-bottom:24px;text-align:center;box-shadow:0 2px 12px #0000000f;border:.5px solid var(--ios-separator)}.profile-header-avatar{width:88px;height:88px;margin:0 auto 16px;border-radius:50%;overflow:hidden;background:var(--app-secondary-bg)}.profile-header-avatar img{width:100%;height:100%;object-fit:cover}.profile-header-avatar .profile-avatar-placeholder{width:100%;height:100%;padding:16px}.profile-header-name{margin:0;font-size:20px;font-weight:600;color:var(--app-text);letter-spacing:.2px}.profile-avatar{width:104px;height:104px;border-radius:50%;object-fit:cover;background:var(--app-secondary-bg);box-shadow:0 2px 12px #00000014}.profile-avatar-placeholder{display:flex;align-items:center;justify-content:center;padding:20px}.profile-avatar-placeholder img{width:100%;height:100%;object-fit:contain;opacity:.4}.profile-avatar-edit .profile-avatar-wrap{margin-bottom:16px}.profile-field{margin-bottom:20px}.profile-field-label{font-size:13px;font-weight:400;color:var(--app-hint);margin-bottom:6px}.wish-form-adult-label{display:flex;align-items:center;gap:8px}.wish-form-adult-text{font-size:16px;font-weight:600;color:var(--app-text)}.profile-field-value{font-size:17px;color:var(--app-text)}.profile-actions{margin-top:28px}.profile-edit-form .profile-field{margin-bottom:24px}.profile-field-error{margin:4px 0 0;font-size:13px;color:var(--ios-red)}.input{width:100%;padding:12px 16px;font-size:17px;font-family:inherit;color:var(--app-text);background:var(--app-secondary-bg);border:none;border-radius:var(--radius-md);-webkit-tap-highlight-color:transparent;transition:box-shadow .2s}.input::placeholder{color:var(--app-hint)}.input:focus{outline:none;box-shadow:0 0 0 2px var(--app-link)}.input-textarea{resize:vertical;min-height:100px}.wish-list{display:flex;flex-direction:column;gap:12px}.wish-card{position:relative;background:var(--app-bg);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 1px 3px #0000000f;border:.5px solid var(--ios-separator)}.wish-card-link{display:flex;align-items:stretch;text-decoration:none;color:inherit;padding:14px 48px 14px 14px;min-height:88px}.wish-card-image-wrap{flex-shrink:0;width:76px;height:76px;border-radius:var(--radius-md);overflow:hidden;background:var(--app-secondary-bg)}.wish-card-image{width:100%;height:100%;object-fit:cover}.wish-card-image-placeholder{background:var(--ios-gray-5)}.wish-card-body{flex:1;min-width:0;margin-left:14px;display:flex;flex-direction:column;justify-content:center}.wish-card-title{font-weight:600;font-size:17px;color:var(--app-text);margin-bottom:4px}.wish-card-link-url{font-size:15px;color:var(--app-link);word-break:break-all;display:block}.wish-card-delete{position:absolute;top:10px;right:10px;width:36px;height:36px;border:none;border-radius:var(--radius-sm);background:var(--app-secondary-bg);color:var(--app-text);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;opacity:.8}.wish-card-delete:active{opacity:.6}.wish-image-edit{margin-top:8px}.wish-image-preview-wrap{margin-bottom:10px;border-radius:var(--radius-md);overflow:hidden;background:var(--app-secondary-bg);max-width:220px}.wish-image-preview{width:100%;height:auto;max-height:180px;object-fit:cover;display:block}.friends-search{margin-bottom:20px}.friends-search .input{border-radius:12px;padding:12px 16px}.friends-section{margin-bottom:28px}.friends-section-title{font-size:13px;font-weight:600;color:var(--app-hint);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding-left:4px}.friend-row{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--app-bg);border-radius:var(--radius-md);margin-bottom:8px;min-height:56px;box-shadow:0 1px 2px #0000000a;border:.5px solid var(--ios-separator)}.friend-row-avatar-wrap{position:relative;flex-shrink:0}.chat-unread-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:600;line-height:18px;text-align:center;color:#fff;background:var(--ios-red);border-radius:9px}.friend-row-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--app-secondary-bg)}.friend-row-avatar img{width:100%;height:100%;object-fit:cover}.friend-row-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:8px}.friend-row-avatar-placeholder img{width:100%;height:100%;object-fit:contain;opacity:.4}.friend-row-name{flex:1;font-weight:500;font-size:17px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-row-actions{display:flex;gap:8px;flex-shrink:0}.friend-row--request{flex-wrap:wrap;align-items:flex-start}.friend-row--request .friend-row-name{flex:1;min-width:0}.friend-row--request .friend-row-actions{flex-basis:100%;margin-top:6px}.friend-row--request .friend-row-actions .friend-row-btn{flex:1;max-width:none}.friend-row--wishlist{align-items:flex-start}.friend-row--wishlist .friend-row-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.friend-row--wishlist .friend-row-name{flex:none}.friend-row--wishlist .friend-row-btn{align-self:flex-start}.friend-row .friend-row-btn,.friend-row .btn.friend-row-btn,.friend-row a.friend-row-btn{flex-shrink:0;width:auto;max-width:none;margin:0;padding:10px 12px;font-size:15px;font-weight:600;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;min-height:48px;border-radius:var(--radius-md);box-sizing:border-box}.friend-wishlist-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding:18px;background:var(--app-secondary-bg);border-radius:var(--radius-lg)}.friend-wishlist-avatar-wrap{flex-shrink:0}.friend-wishlist-avatar{width:68px;height:68px;border-radius:50%;object-fit:cover;background:var(--ios-gray-5)}.friend-wishlist-avatar.placeholder{display:flex;align-items:center;justify-content:center;padding:12px}.friend-wishlist-avatar.placeholder img{width:100%;height:100%;object-fit:contain;opacity:.4}.friend-wishlist-info{min-width:0}.friend-wishlist-name{font-weight:700;font-size:17px;margin-bottom:4px;letter-spacing:.38px}.friend-wishlist-dob{font-size:15px;color:var(--app-hint)}.friend-wishlist-items{display:flex;flex-direction:column;gap:12px}.friend-wish-card{background:var(--app-bg);border-radius:var(--radius-lg);padding:14px;border:.5px solid var(--ios-separator);box-shadow:0 1px 3px #0000000d}.friend-wish-card-main{display:flex;gap:14px;margin-bottom:12px}.friend-wish-card-image-wrap{width:68px;height:68px;border-radius:var(--radius-md);overflow:hidden;flex-shrink:0;background:var(--app-secondary-bg)}.friend-wish-card-image{width:100%;height:100%;object-fit:cover}.friend-wish-card-image.placeholder{width:100%;height:100%}.friend-wish-card-body{flex:1;min-width:0}.friend-wish-card-title{font-weight:600;font-size:17px;margin-bottom:4px}.friend-wish-card-status{font-size:15px;color:var(--app-hint);margin-bottom:4px}.friend-wish-card-link{font-size:15px;color:var(--app-link);word-break:break-all}.friend-wish-card-actions .btn{margin:0;width:100%}.chat-screen{display:flex;flex-direction:column;height:100%;min-height:0;padding:0}.chat-screen-header{display:flex;align-items:center;gap:12px;padding:12px 16px;padding-top:max(12px,var(--safe-top));background:#ffffffeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:.5px solid var(--ios-separator);flex-shrink:0}.chat-screen-back{width:44px;height:44px;border:none;background:none;cursor:pointer;-webkit-tap-highlight-color:transparent;padding:0;display:flex;align-items:center;justify-content:center}.chat-screen-back img{width:24px;height:24px;object-fit:contain;filter:invert(39%) sepia(98%) saturate(2500%) hue-rotate(200deg)}.chat-screen-title{flex:1;margin:0;font-size:17px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;min-height:0;-webkit-overflow-scrolling:touch}.chat-message{display:flex;width:100%}.chat-message-me{justify-content:flex-end}.chat-message-them{justify-content:flex-start}.chat-message-bubble{max-width:80%;padding:12px 16px;border-radius:18px;font-size:16px;line-height:1.4}.chat-message-me .chat-message-bubble{background:var(--app-button);color:var(--app-button-text);border-bottom-right-radius:4px}.chat-message-them .chat-message-bubble{background:var(--app-secondary-bg);color:var(--app-text);border-bottom-left-radius:4px}.chat-message-time{font-size:11px;opacity:.85;margin-top:4px}.chat-form{display:flex;align-items:center;gap:10px;padding:10px 16px;padding-bottom:max(10px,var(--safe-bottom));background:var(--app-bg);border-top:.5px solid var(--ios-separator);flex-shrink:0;min-width:0}.chat-input{flex:1;min-width:0;margin:0;padding:12px 16px;font-size:16px;border-radius:20px}.chat-send-btn{margin:0;flex-shrink:0;padding:12px 16px;font-size:16px;font-weight:600;min-width:0;max-width:110px;white-space:nowrap;border-radius:20px;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;text-align:center}.text-hint{color:var(--app-hint);font-size:15px}.text-error{color:var(--ios-red);font-size:15px}.text-center{text-align:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:200;padding:16px}.modal{background:var(--app-bg);border-radius:var(--radius-lg);padding:24px;max-width:320px;width:100%;box-shadow:0 4px 24px #00000026}.modal-text{margin:0 0 20px;font-size:17px;color:var(--app-text);text-align:center}.modal-actions{display:flex;flex-direction:column;gap:8px}.modal-actions .btn{margin:0}.page--wish-detail{padding:0;max-width:none}.page--wish-detail .page{padding:0}.wish-detail-screen{display:flex;flex-direction:row;align-items:flex-start;height:calc(100dvh - var(--nav-height) - var(--safe-bottom));min-height:0}.wish-detail-back{flex-shrink:0;width:44px;height:44px;margin:max(12px,var(--safe-top)) 0 0 8px;padding:0;border:none;background:none;cursor:pointer;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center}.wish-detail-back img{width:24px;height:24px;object-fit:contain;filter:invert(39%) sepia(98%) saturate(2500%) hue-rotate(200deg)}.wish-detail-content{flex:1;min-width:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:max(24px,var(--safe-top)) var(--page-padding) calc(var(--page-padding) + var(--safe-bottom))}.wish-detail-image-wrap{width:100%;max-width:200px;margin:0 auto 20px;border-radius:var(--radius-lg);overflow:hidden;background:var(--app-secondary-bg)}.wish-detail-image{width:100%;height:auto;display:block;object-fit:contain;object-position:top center}.wish-detail-title{margin:0 0 12px;font-size:22px;font-weight:600;color:var(--app-text);line-height:1.3}.wish-detail-description{margin:0 0 16px;font-size:16px;color:var(--app-text);line-height:1.5;white-space:pre-wrap;word-break:break-word}.wish-detail-link{display:inline-block;margin-bottom:20px;font-size:16px;color:var(--app-link)}.wish-detail-edit-btn{margin-top:8px}
