:root{color-scheme:light;--bg: #f4f6fb;--surface: #ffffff;--text: #1f2937;--muted: #6b7280;--primary: #3b82f6;--primary-dark: #2563eb;--border: #e5e7eb;--shadow: 0 10px 30px rgba(15, 23, 42, .08)}:root[data-theme=dark]{color-scheme:dark;--bg: #0f172a;--surface: #111827;--text: #e5e7eb;--muted: #9ca3af;--primary: #38bdf8;--primary-dark: #0ea5e9;--border: #1f2937;--shadow: 0 10px 30px rgba(15, 23, 42, .4)}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;position:relative}*{-webkit-tap-highlight-color:transparent}a{color:inherit;text-decoration:none}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-header{padding:20px 24px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:16px}.app-logo-container{display:flex;align-items:center;gap:12px}.app-logo-icon{height:42px;width:auto;object-fit:contain}.app-logo-text{display:block!important;margin:0;font-family:Poppins,sans-serif;font-weight:800;font-size:28px;letter-spacing:2px;color:#fff;-webkit-text-stroke:3px #0b1e4b;text-stroke:3px #0b1e4b;paint-order:stroke fill;-webkit-user-select:none;user-select:none}.logo-gold{color:gold;-webkit-text-stroke:3px #0b1e4b;text-stroke:3px #0b1e4b;paint-order:stroke fill}@media(max-width:767px){.app-logo-icon{height:36px}.app-logo-text{font-size:24px;-webkit-text-stroke:2.5px #0b1e4b;text-stroke:2.5px #0b1e4b}.logo-gold{-webkit-text-stroke:2.5px #0b1e4b;text-stroke:2.5px #0b1e4b}}.app-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;padding:8px 0 max(8px,env(safe-area-inset-bottom));background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -4px 16px #00000014;z-index:999}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px 12px;border-radius:12px;color:var(--muted);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;min-width:60px}.nav-icon{width:24px;height:24px;fill:currentColor;transition:all .3s cubic-bezier(.4,0,.2,1);margin-bottom:4px}.nav-label{font-size:11px;font-weight:600;opacity:.8;transition:all .3s ease}@media(max-width:899px){.nav-label{display:none}.app-nav{box-shadow:none}.nav-item{min-width:48px;padding:10px;transition:color .15s ease}.nav-icon{margin-bottom:0;transition:none}.nav-item:active,.nav-item.router-link-active .nav-icon{transform:none}.nav-item.router-link-active:before{display:none}}.nav-item:active{transform:scale(.92)}.nav-spacer{display:none}.nav-item.router-link-active{color:var(--primary)}.nav-item.router-link-active .nav-icon{transform:translateY(-2px) scale(1.1)}.nav-item.router-link-active .nav-label{opacity:1;font-weight:700}.nav-item.router-link-active:before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%);width:32px;height:3px;background:var(--primary);border-radius:0 0 3px 3px;animation:slideDown .3s ease}@keyframes slideDown{0%{transform:translate(-50%) translateY(-8px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.header-actions{display:flex;align-items:center;gap:10px}.user-info{position:relative}.user-name-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:10px;background:#38bdf814;border:1px solid rgba(56,189,248,.2);font-size:14px;font-weight:600;color:var(--text);cursor:pointer;transition:all .2s}.user-name-btn:hover{background:#38bdf81f;border-color:#38bdf84d}.chevron-icon{width:16px;height:16px;fill:var(--muted);transition:transform .2s}.chevron-icon.rotated{transform:rotate(180deg)}.profile-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 4px 16px #00000026;overflow:hidden;z-index:1000;animation:profileMenuSlide .2s ease-out}@keyframes profileMenuSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.profile-menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:transparent;border:none;color:var(--text);font-size:14px;font-weight:500;text-align:left;cursor:pointer;transition:background .2s;text-decoration:none}.profile-menu-item:hover{background:var(--bg)}.profile-menu-item.danger{color:#dc3545}.profile-menu-item.danger:hover{background:#dc354514}.menu-icon{width:20px;height:20px;fill:currentColor}.header-hint{margin:6px 0 0;font-size:12px;color:var(--muted)}.app-main{padding:20px 16px calc(80px + env(safe-area-inset-bottom));min-height:100vh;isolation:isolate}.no-transition-enter-active,.no-transition-leave-active{transition:none!important}.no-transition-enter-from,.no-transition-leave-to{opacity:1!important;transform:none!important}.slide-left-enter-active,.slide-left-leave-active,.slide-right-enter-active,.slide-right-leave-active{transition:all .3s cubic-bezier(.4,0,.2,1);will-change:transform,opacity}.slide-left-enter-from{opacity:0;transform:translate(30px)}.slide-left-leave-to,.slide-right-enter-from{opacity:0;transform:translate(-30px)}.slide-right-leave-to{opacity:0;transform:translate(30px)}.fade-enter-active,.fade-leave-active{transition:opacity .25s ease}.fade-enter-from,.fade-leave-to{opacity:0}.app-main section{background:transparent;padding:0;border-radius:0;border:none;box-shadow:none;animation:none}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.app-main h2{margin-top:0;font-size:20px;animation:slideInLeft .5s ease-out}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.app-main p{margin-bottom:0;color:var(--muted);line-height:1.6}.settings-block{margin-top:20px;padding:16px;border-radius:14px;border:1px solid var(--border);background:var(--bg)}.settings-block h3{margin:0 0 8px;font-size:18px}.form-row{margin-top:12px;display:flex;flex-direction:column;gap:10px}.input{padding:10px 14px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:14px}.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border-radius:10px;background:#3b82f614;color:var(--primary);border:1px solid rgba(59,130,246,.2);font-weight:600;transition:all .25s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;overflow:hidden}.button-icon-leading{width:18px;height:18px;fill:currentColor;flex-shrink:0}.button-text{white-space:nowrap}.button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#3b82f61a;transform:translate(-50%,-50%);transition:width .6s,height .6s}.button:active:before{width:300px;height:300px}.button:disabled{cursor:not-allowed;opacity:.6}.button:hover{background:#3b82f61f;border-color:#3b82f64d;transform:translateY(-1px);box-shadow:0 2px 8px #3b82f626}.button:active{transform:translateY(0)}.button.ghost{background:transparent;color:var(--text);border:none;box-shadow:none}.button.ghost:hover{background:var(--surface)}@media(max-width:520px){.button-adaptive{padding:10px;min-width:40px}.button-adaptive .button-text{display:none}}.icon-button{width:40px;height:40px;border-radius:12px;border:1px solid var(--border);background:var(--surface);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative}.icon-button:hover{border-color:var(--primary);background:#38bdf814;transform:translateY(-2px) rotate(5deg);box-shadow:0 4px 12px #38bdf833}.icon-button:active{transform:translateY(0) rotate(0)}.icon-button svg{width:20px;height:20px;fill:var(--text);transition:transform .3s ease;display:block;margin:auto}.icon-button:hover svg{transform:scale(1.1)}.hint{margin-top:12px;font-size:13px;color:var(--muted)}.settings-block .button{margin-top:12px}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.settings-header h2{margin:0}.theme-icon-btn{width:44px;height:44px;border-radius:12px;border:2px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.theme-icon-btn svg{width:22px;height:22px;fill:var(--text);transition:transform .3s ease}.theme-icon-btn:hover{border-color:var(--primary);background:#38bdf814;transform:translateY(-2px);box-shadow:0 4px 12px #38bdf833}.theme-icon-btn:hover svg{transform:rotate(20deg) scale(1.1)}.theme-icon-btn:active{transform:translateY(0)}.language-switcher{display:flex;gap:10px;margin-top:16px}.flag-btn{width:56px;height:56px;display:flex;align-items:center;justify-content:center;font-size:32px;border-radius:12px;border:2px solid var(--border);background:var(--surface);cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;z-index:10}.flag-btn:hover{border-color:var(--primary);background:#38bdf80d;transform:translateY(-3px) scale(1.05);box-shadow:0 6px 16px #38bdf833}.flag-btn.active{border-color:var(--primary);border-width:3px;box-shadow:0 4px 16px #38bdf84d;transform:scale(1.1)}.flag-btn:active{transform:scale(.95)}.button-icon{width:20px;height:20px;fill:currentColor;margin-right:8px}.button{display:inline-flex;align-items:center;justify-content:center}.empty-state{text-align:center;padding:40px 20px}.empty-state p{margin-bottom:20px;color:var(--muted)}.partner-container{display:flex;flex-direction:column;gap:24px}.partner-info{display:flex;align-items:center;gap:16px;padding:20px;background:var(--bg);border-radius:12px}.partner-avatar{width:60px;height:60px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;flex-shrink:0}.partner-details h3{margin:0 0 4px;font-size:18px}.paired-since{margin:0;font-size:13px;color:var(--muted)}.chat-container{display:flex;flex-direction:column;gap:16px}.chat-header{display:flex;align-items:center;gap:8px}.chat-container h3{margin:0;font-size:16px}.messages-paused{margin:0;padding:10px 12px;border:1px solid #f59e0b;border-radius:8px;background:#f59e0b1a;color:var(--text);font-size:13px}.info-tooltip{position:relative;cursor:pointer;display:flex;align-items:center}.info-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;font-size:14px;font-weight:700;color:#ff9800;border:1px solid #ff9800;border-radius:50%;transition:all .2s}.info-tooltip:hover .info-icon{background:#ff98001a;transform:scale(1.1)}.tooltip-content{position:absolute;top:300%;left:calc(100% + 8px);transform:translateY(-50%);padding:12px;min-width:250px;max-width:350px;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #00000026;font-size:13px;line-height:1.5;color:var(--text);z-index:100;animation:tooltipFade .2s ease-out}@keyframes tooltipFade{0%{opacity:0;transform:translateY(-50%) translate(-10px)}to{opacity:1;transform:translateY(-50%) translate(0)}}@media(max-width:767px){.tooltip-content{min-width:200px;max-width:280px}}.messages{max-height:400px;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding:16px;background:var(--bg);border:1px solid var(--border);border-radius:12px;scrollbar-width:thin}.message{display:flex;flex-direction:column;gap:4px;max-width:80%;width:fit-content;animation:messageSlide .2s ease-out}@keyframes messageSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.own{align-self:flex-end}.message-header{display:flex;justify-content:space-between;gap:8px;font-size:12px}.message-sender{font-weight:600;color:var(--primary)}.message.own .message-sender{color:var(--text)}.message-time{color:var(--muted)}.message-body{padding:10px 14px;border-radius:12px;background:var(--surface);border:1px solid var(--border);word-wrap:break-word;line-height:1.5}.message.own .message-body{background:var(--primary);color:#fff;border-color:var(--primary)}.message-form{display:flex;gap:10px}.message-form .input{flex:1}.message-form .button{white-space:nowrap}.message-send-icon{width:18px;height:18px;fill:currentColor}.unpair-section{margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}.button-danger{background:#dc354514;color:#dc3545;border-color:#dc354533}.button-danger:hover{background:#dc35451f;border-color:#dc35454d}.button-danger:active{background:#dc354526}.invite-result{margin-top:16px}.invite-link-container{display:flex;gap:10px;margin-top:12px}.invite-link-container .input{flex:1;font-family:monospace;font-size:13px}@media(min-width:900px){.app-shell{display:grid;grid-template-columns:240px 1fr;grid-template-rows:auto 1fr}.app-header{grid-column:1 / -1;padding:24px 32px;align-items:flex-start}.app-nav{position:static;flex-direction:column;align-items:stretch;gap:2px;padding:12px 10px;border-right:1px solid var(--border);border-top:none;box-shadow:none}.nav-item{flex-direction:row;justify-content:flex-start;gap:10px;padding:8px 12px;min-width:auto}.nav-icon{width:22px;height:22px;margin-bottom:0}.nav-label{font-size:14px}.nav-item.router-link-active:before{top:50%;left:-16px;transform:translateY(-50%);width:3px;height:32px;border-radius:0 3px 3px 0}@keyframes slideDown{0%{transform:translateY(-50%) translate(-8px);opacity:0}to{transform:translateY(-50%) translate(0);opacity:1}}.nav-item.router-link-active .nav-icon{transform:none}.nav-spacer{flex:1;display:block}.app-main{padding:16px}.app-main section{padding:28px 32px}.form-row{flex-direction:row;align-items:center}.input{flex:1}}.page-header{display:flex;align-items:center;margin-bottom:20px;gap:16px}.page-header h2{margin:0}.page-header .button{margin-right:auto}.limit-badge{padding:6px 12px;background:var(--surface);border:1px solid var(--border);border-radius:20px;font-size:14px;font-weight:600;color:var(--primary);white-space:nowrap;margin-left:auto}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-top:20px}@media(max-width:767px){.items-grid{grid-template-columns:1fr}}.item-card{padding:20px;background:var(--surface);border:1px solid var(--border);border-radius:12px;transition:transform .2s,box-shadow .2s}.item-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.item-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.item-header h3{margin:0;font-size:18px;flex:1;word-break:break-word}.item-date{font-size:14px;color:var(--muted);white-space:nowrap}.item-meta-tags{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.item-description{margin:0 0 12px;color:var(--muted);font-size:14px;line-height:1.5}.item-meta{margin-bottom:12px;font-size:14px;color:var(--muted)}.item-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.item-author{font-size:13px;color:var(--muted)}.item-actions{display:flex;gap:8px}.status-badge{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;white-space:nowrap}.status-planned{background:#3b82f61a;color:#3b82f6}.status-visited,.status-bought,.status-given{background:#22c55e1a;color:#22c55e}.button-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s}.button-icon svg{width:20px;height:20px;fill:var(--text)}.button-icon:hover{background:var(--bg);transform:scale(1.05)}.button-icon.button-danger:hover{background:#dc35451a;border-color:#dc3545}.button-icon.button-danger:hover svg{fill:#dc3545}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg);border-radius:16px;padding:24px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-content h3{margin:0 0 20px;font-size:20px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:600;color:var(--text)}.form-group .input{width:100%;box-sizing:border-box}.annual-date-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.checkbox-row{display:inline-flex;align-items:center;gap:8px;font-weight:600}.settings-controls-row{display:flex;align-items:center;gap:10px;margin-top:10px}.lang-switch-btn{height:44px;border-radius:12px;border:2px solid var(--border);background:var(--surface);color:var(--text);padding:0 12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.lang-switch-btn:hover{border-color:var(--primary);background:#38bdf814;transform:translateY(-2px);box-shadow:0 4px 12px #38bdf833}.lang-switch-btn:active{transform:translateY(0)}.profile-settings-row{display:flex;align-items:center;gap:10px;margin-top:12px}.preference-group{margin-top:14px}.preference-group h4{margin:0 0 8px;font-size:14px;color:var(--text)}.preference-chips{display:flex;flex-wrap:wrap;gap:8px}.preference-chip{border:1px solid var(--border);border-radius:999px;padding:6px 10px;background:var(--surface);color:var(--text);cursor:pointer;font-size:13px;display:inline-flex;align-items:center;gap:6px}.preference-chip.selected{border-color:var(--primary);background:#3b82f61f;color:var(--primary)}.preference-chip:disabled{opacity:.5;cursor:not-allowed}.chip-icon{font-size:14px;line-height:1}.textarea{resize:vertical;min-height:80px;font-family:inherit;line-height:1.5}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.modal-actions .button{min-width:100px}.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}.empty-state p{margin:0;font-size:16px}.page-preloader{display:grid;gap:12px;animation:fadeIn .2s ease-out}.skeleton-card{border:1px solid var(--border);border-radius:12px;padding:14px;background:var(--surface)}.skeleton-row{display:flex;align-items:center;gap:12px}.skeleton-stack{flex:1;display:grid;gap:10px}.skeleton-circle{width:44px;height:44px;border-radius:50%;background:linear-gradient(90deg,#94a3b824 25%,#94a3b847,#94a3b824 75%);background-size:200% 100%;animation:skeletonShimmer 1.2s infinite linear}.skeleton-line{height:10px;border-radius:8px;margin-bottom:10px;background:linear-gradient(90deg,#94a3b824 25%,#94a3b847,#94a3b824 75%);background-size:200% 100%;animation:skeletonShimmer 1.2s infinite linear}.skeleton-line:last-child{margin-bottom:0}.skeleton-line-full{width:100%}.skeleton-line-lg{width:72%}.skeleton-line-md{width:52%}.skeleton-line-sm{width:36%}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}
