:root{--color-bg:#f8fafc;--color-bg-elevated:#fff;--color-surface:#fff;--color-surface-muted:#f1f5f9;--color-text:#1f2937;--color-text-secondary:#4b5563;--color-muted:#64748b;--color-border:#e5e7eb;--color-border-light:#e9eef5;--color-primary:#3b82f6;--color-primary-hover:#2563eb;--color-primary-muted:#3b82f61f;--color-primary-ring:#3b82f659;--color-cta:#0ea5e9;--color-cta-hover:#0284c7;--color-success:#10b981;--color-error:#ef4444;--color-warning:#f59e0b;--font-body:"IBM Plex Sans",-apple-system,BlinkMacSystemFont,sans-serif;--font-display:"Fraunces",Georgia,"Times New Roman",serif;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:6px;--radius-md:10px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--shadow-sm:0 1px 3px #0f172a0f;--shadow-md:0 4px 12px #0f172a14;--shadow-lg:0 8px 24px #0f172a1a;--shadow-primary:0 4px 14px #3b82f633;--header-height:70px;--footer-collapsed:60px;--basket-collapsed:48px;--safe-bottom:env(safe-area-inset-bottom,0px);--safe-top:env(safe-area-inset-top,0px);--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px);--page-bottom-spacer:calc(var(--footer-collapsed) + var(--space-8) + var(--safe-bottom));--bp-sm:480px;--bp-md:768px;--bp-lg:1024px;--bp-xl:1200px;--ease-out:cubic-bezier(0.22,1,0.36,1);--duration-fast:150ms;--duration-normal:280ms;--duration-slow:420ms}@media (max-width:768px){:root{--footer-collapsed:0px;--page-bottom-spacer:calc(var(--space-8) + var(--safe-bottom))}}.font-display,h1,h2,h3{font-family:var(--font-display);font-weight:600;letter-spacing:-.02em}.page-root{background-color:var(--color-bg);color:var(--color-text);font-family:var(--font-body);min-height:100%}.section-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-5)}.section-title{border-bottom:2px solid var(--color-primary);color:var(--color-text);font-family:var(--font-display);font-size:1.35rem;font-weight:600;margin:0 0 var(--space-4);padding-bottom:var(--space-3)}.page-bottom-spacer{margin-bottom:var(--page-bottom-spacer)}.page-bottom-spacer-with-basket{margin-bottom:calc(var(--page-bottom-spacer) + var(--basket-collapsed))}.ui-button,a.btn,button:not(.icon-button):not(.menu-toggle){min-height:44px}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{box-shadow:0 0 0 3px var(--color-primary-ring);outline:none}.hero-grain:before{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)'/%3E%3C/svg%3E");content:"";inset:0;opacity:.04;pointer-events:none;position:absolute}.scroll-hint-x{position:relative}.scroll-hint-x:after{background:linear-gradient(to left,var(--color-bg),#0000);bottom:0;content:"";pointer-events:none;position:absolute;right:0;top:0;width:32px}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root,body,html{height:100%;overflow:hidden;overscroll-behavior:none}body{height:100%;padding:var(--safe-top) var(--safe-right) var(--safe-bottom) var(--safe-left);position:fixed;width:100%}.App{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-bg);color:var(--color-text);display:flex;flex-direction:column;font-family:var(--font-body);height:100vh;height:100dvh;overflow:hidden}.app-content{-webkit-overflow-scrolling:touch;flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;z-index:1}.app-loading{color:var(--color-muted)}.app-error,.app-loading{align-items:center;display:flex;height:200px;justify-content:center}.app-error{color:var(--color-error);flex-direction:column;gap:var(--space-4)}@media print{.app-content{flex:1 1;overflow:hidden}}.optimized-image-container{display:inline-block;overflow:hidden;position:relative}.optimized-image{height:auto;max-width:100%;opacity:0;transition:opacity .3s ease-in-out}.optimized-image.loaded{opacity:1}.optimized-image.error{filter:grayscale(100%);opacity:.5}.image-placeholder{align-items:center;background-color:#f3f4f6;border-radius:4px;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0}.loading-spinner{border:3px solid #e5e7eb;border-top-color:#3b82f6;height:32px;width:32px}.image-error{font-size:2rem;left:50%;opacity:.5;position:absolute;top:50%;transform:translate(-50%,-50%)}@media (max-width:768px){.optimized-image-container{width:100%}.optimized-image{height:auto;width:100%}}.landing-hero{align-items:center;background:linear-gradient(180deg,var(--color-bg) 0,var(--color-surface) 60%);color:var(--color-text);display:flex;flex-direction:column;gap:var(--space-4);overflow:hidden;padding:var(--space-3) var(--space-4) var(--space-6);position:relative;text-align:center}.landing-hero.hero-grain:before{opacity:.035}.landing-hero h1{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.25rem);margin:0 1rem .5rem}.landing-hero p{color:var(--color-text-secondary);font-size:clamp(1rem,2.2vw,1.25rem);margin:0 1rem 1.25rem}.landing-hero-image{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:420px;object-fit:cover}.landing-section{margin:0 auto;max-width:1100px;padding:var(--space-3) var(--space-4)}.landing-section:last-of-type{margin-bottom:var(--page-bottom-spacer)}.feature-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(1,minmax(0,1fr))}@media (min-width:768px){.feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:1024px){.feature-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.feature-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-4)}.image-row{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(1,minmax(0,1fr))}@media (min-width:768px){.image-row{grid-template-columns:repeat(3,minmax(0,1fr))}}.image-row img{border:1px solid var(--color-border);border-radius:var(--radius-lg);height:200px;object-fit:cover;width:100%}.cta-buttons{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center}.cta-buttons a,.cta-buttons button{background:var(--color-cta);border:1px solid var(--color-cta);border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:var(--font-body);font-weight:600;min-height:44px;padding:var(--space-3) var(--space-5);text-decoration:none}.cta-buttons a.secondary,.cta-buttons button.secondary{background:var(--color-surface);color:var(--color-cta)}.testimonial{border-left:4px solid var(--color-primary);color:var(--color-text-secondary);padding:0 var(--space-4)}.landing-page-dark{background:var(--color-bg);color:var(--color-text)}.landing-page-dark .landing-hero{background:linear-gradient(180deg,#f8fafc,#fff 70%);color:#1f2937}.landing-page-dark .landing-hero h1{color:#1f2937}.landing-page-dark .landing-hero p{color:#4b5563}.landing-page-dark .landing-hero-image{border:1px solid #e5e7eb;box-shadow:0 10px 30px #00000014}.landing-page-dark .landing-section{background:#f8fafc;color:#1f2937}.landing-page-dark .feature-card{background:#fff;border:1px solid #e5e7eb;box-shadow:0 2px 10px #0000000d;color:#1f2937}.landing-page-dark .feature-card h3{color:#1f2937}.landing-page-dark .feature-card p{color:#4b5563}.landing-page-dark .image-row img{border:1px solid #e5e7eb;box-shadow:0 4px 16px #00000014}.landing-page-dark .cta-buttons a,.landing-page-dark .cta-buttons button{background:#3b82f6;border:1px solid #3b82f6;color:#fff}.landing-page-dark .cta-buttons a.secondary,.landing-page-dark .cta-buttons button.secondary{background:#0000;color:#3b82f6}.landing-page-dark .cta-buttons a:focus-visible,.landing-page-dark .cta-buttons button:focus-visible{box-shadow:0 0 0 3px #3b82f659;outline:none}.landing-page-dark .landing-section:last-of-type{border-top:1px solid #e5e7eb}.latest-reports-section{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}.latest-reports-section.visible{opacity:1;transform:translateY(0)}.latest-reports-loading{padding:2rem;text-align:center}.loading-spinner{color:#4b5563;font-size:1.1rem}.latest-reports-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(2,1fr);margin-left:auto;margin-right:auto;margin-top:2rem;max-width:1400px}.latest-report-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 10px #0000000d;display:flex;flex-direction:column;justify-content:space-between;min-height:200px;padding:1.25rem;transition:all .3s ease}.latest-report-card:hover{background:#f8fafc;border-color:#3b82f6;box-shadow:0 4px 20px #3b82f61a;transform:translateY(-2px)}.latest-report-header{flex-shrink:0;margin-bottom:.75rem}.latest-report-institution-name{-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;color:#1f2937;display:-webkit-box;font-size:1.1rem;font-weight:600;line-height:1.3;margin:0 0 .5rem;overflow:hidden}.latest-report-meta{display:flex;flex-wrap:wrap;gap:1rem}.latest-report-type{background:#3b82f6;border-radius:20px;color:#fff;font-size:.85rem;font-weight:500;padding:.25rem .75rem}.latest-report-location{align-items:center;color:#4b5563;display:flex;font-size:.9rem;gap:.25rem}.latest-report-details{display:flex;flex-direction:column;flex-grow:1;justify-content:center;margin-bottom:.75rem}.latest-report-details>div{color:#4b5563;font-size:.85rem;line-height:1.4;margin-bottom:.25rem}.latest-report-details strong{color:#1f2937;font-weight:600}.latest-report-footer{border-top:1px solid #e5e7eb;flex-shrink:0;padding-top:.75rem;text-align:right}.view-details-link{color:#3b82f6;font-size:.9rem;font-weight:500;transition:color .2s ease}.latest-report-card:hover .view-details-link{color:#60a5fa}.latest-reports-empty{color:#4b5563;padding:3rem 1rem;text-align:center}.latest-reports-empty p{font-size:1.1rem;margin:0}@media (min-width:1200px){.latest-reports-grid{grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(2,1fr);max-width:1600px}}@media (min-width:992px) and (max-width:1199px){.latest-reports-grid{grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(3,1fr);max-width:1200px}.latest-report-card:nth-child(10),.latest-report-card:nth-child(9){grid-column:span 2}}@media (min-width:768px) and (max-width:991px){.latest-reports-grid{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(4,1fr);max-width:900px}.latest-report-card:nth-child(10){grid-column:span 3}}@media (min-width:576px) and (max-width:767px){.latest-reports-grid{gap:1rem;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(5,1fr);max-width:600px}}@media (max-width:575px){.latest-reports-grid{gap:1rem;grid-template-columns:1fr;grid-template-rows:repeat(10,1fr);max-width:400px}}@media (max-width:768px){.latest-report-card{padding:1.25rem}.latest-report-meta{flex-direction:column;gap:.5rem}.latest-report-institution-name{font-size:1.1rem}.latest-report-details>div{font-size:.85rem}}.pricing-features-section{background:#fff;border-bottom:1px solid #e5e7eb;border-top:1px solid #e5e7eb;padding:4rem 2rem}.pricing-features-comparison{background:#f8fafc;border-radius:12px;box-shadow:0 2px 10px #0000000d;display:flex;flex-direction:column;gap:12px;margin:0 auto;max-width:900px;padding:1.5rem}.pricing-features-header{grid-gap:15px;background:#fff;border-bottom:2px solid #e5e7eb;border-radius:8px;color:#1f2937;display:grid;font-size:16px;font-weight:600;gap:15px;grid-template-columns:2fr 1fr 1fr 1fr;margin-bottom:8px;padding:12px 15px}.pricing-features-header-label{text-align:left}.pricing-features-header-free{color:#3b82f6}.pricing-features-header-free,.pricing-features-header-guest,.pricing-features-header-premium{text-align:center}.pricing-features-header-premium{color:#10b981}.pricing-feature-row{grid-gap:15px;align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:grid;gap:15px;grid-template-columns:2fr 1fr 1fr 1fr;padding:12px 15px;transition:all .2s ease}.pricing-feature-row:hover{background:#f8fafc;border-color:#3b82f6}.pricing-feature-label{color:#1f2937;font-size:15px;font-weight:500}.pricing-feature-free,.pricing-feature-guest,.pricing-feature-premium{font-size:18px;font-weight:700;min-width:40px;text-align:center}.pricing-feature-guest{color:#6b7280}.pricing-feature-free{color:#3b82f6}.pricing-feature-premium{color:#10b981}.pricing-cta{margin:0 auto;max-width:600px}@media (max-width:768px){.pricing-features-section{padding:3rem 1rem}.pricing-features-comparison{padding:1rem}.pricing-features-header{gap:8px;grid-template-columns:1fr;padding:10px;text-align:center}.pricing-features-header-label{border-bottom:1px solid #e5e7eb;font-size:18px;margin-bottom:8px;padding-bottom:8px;text-align:center}.pricing-features-header-free,.pricing-features-header-guest,.pricing-features-header-premium{background:#f8fafc;border-radius:6px;display:inline-block;margin:0 4px;padding:4px 12px}.pricing-feature-row{gap:10px;grid-template-columns:1fr;padding:15px 10px;text-align:center}.pricing-feature-label{border-bottom:1px solid #e5e7eb;font-weight:600;margin-bottom:8px;padding-bottom:8px}.pricing-feature-free,.pricing-feature-guest,.pricing-feature-premium{align-items:center;display:flex;gap:8px;justify-self:center}.pricing-feature-guest:before{color:#6b7280;content:"Gæst:";font-size:14px;font-weight:500}.pricing-feature-free:before{color:#3b82f6;content:"Basis:";font-size:14px;font-weight:500}.pricing-feature-premium:before{color:#10b981;content:"Premium:";font-size:14px;font-weight:500}}.user-menu{align-items:center;display:flex;margin-left:auto;position:relative}.user-menu.loading{padding:8px 16px}.loading-text{color:var(--color-muted);font-size:14px}.login-btn{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-hover) 100%);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:14px;font-weight:600;min-height:44px;padding:10px 20px;transition:all .2s ease}.login-btn:hover{box-shadow:var(--shadow-primary);transform:translateY(-1px)}.user-info{font-family:inherit}.user-menu.authenticated:not(.user-menu--sheet) .user-info{align-items:center;background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;display:flex;gap:8px;min-height:44px;padding:8px 12px;transition:all .2s ease}.user-menu.authenticated:not(.user-menu--sheet) .user-info:hover{background:var(--color-primary-muted);border-color:var(--color-primary)}.user-greeting{color:var(--color-text);font-size:14px;font-weight:600}.access-badge{border-radius:var(--radius-full);font-size:12px;font-weight:600;letter-spacing:.5px;padding:2px 8px;text-transform:uppercase}.access-badge.free{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.access-badge.premium{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.dropdown-arrow{color:var(--color-muted);font-size:12px;transition:transform .2s ease}.dropdown-arrow.open,.user-menu.authenticated:not(.user-menu--sheet) .user-info:hover .dropdown-arrow{transform:rotate(180deg)}.user-dropdown{animation:slideDown .15s ease-out;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin-top:8px;min-width:280px;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{background:linear-gradient(135deg,var(--color-bg) 0,var(--color-surface-muted) 100%);border-bottom:1px solid var(--color-border-light);padding:16px}.user-details strong{color:var(--color-text);display:block;font-size:16px;margin-bottom:4px}.user-email{color:var(--color-muted);display:block;font-size:14px;margin-bottom:8px}.access-status{border-radius:var(--radius-full);display:inline-block;font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.access-status.free{background:#d1fae5;color:#065f46}.access-status.premium{background:#fef3c7;color:#92400e}.dropdown-actions{display:flex;flex-direction:column;gap:8px;padding:12px}.profile-btn{background:var(--color-primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:13px;font-weight:600;min-height:44px;padding:10px 16px;transition:all .2s ease}.profile-btn:hover{background:var(--color-primary-hover)}.upgrade-btn{background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:var(--radius-md);color:#fff}.logout-btn,.upgrade-btn{cursor:pointer;font-size:13px;font-weight:600;min-height:44px;padding:10px 16px}.logout-btn{background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text)}.logout-btn:hover{background:var(--color-border-light)}.dropdown-overlay{background:#0000;bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.user-menu--sheet{align-items:stretch;border-top:1px solid var(--color-border);flex-direction:column;gap:var(--space-2);margin-left:0;margin-top:var(--space-2);padding-top:var(--space-4);width:100%}.user-menu-sheet-heading{color:var(--color-muted);font-size:.75rem;font-weight:600;letter-spacing:.06em;margin:0;text-transform:uppercase}.user-menu-sheet-action{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;display:flex;font-family:var(--font-body);font-size:1.05rem;font-weight:600;justify-content:flex-start;min-height:48px;padding:var(--space-3) var(--space-4);text-align:left;width:100%}.user-menu-sheet-action--primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff;justify-content:center}.user-menu-sheet-action--primary:hover{background:var(--color-primary-hover)}.user-menu--sheet .user-info--sheet{align-items:center;-webkit-appearance:none;appearance:none;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;display:flex;font-family:var(--font-body);gap:var(--space-3);justify-content:space-between;margin:0;min-height:48px;padding:var(--space-3) var(--space-4);text-align:left;width:100%}.user-menu--sheet .user-info--sheet:hover,.user-menu--sheet .user-info--sheet[aria-expanded=true]{background:var(--color-primary-muted);border-color:var(--color-primary)}.user-menu--sheet .user-greeting{flex:1 1;font-size:1rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu--sheet .user-dropdown--sheet{animation:none;border:1px solid var(--color-border);box-shadow:none;margin-top:0;min-width:0;position:static;width:100%}.user-menu--sheet .dropdown-actions .logout-btn,.user-menu--sheet .dropdown-actions .profile-btn,.user-menu--sheet .dropdown-actions .upgrade-btn{font-size:1rem;justify-content:center;width:100%}@media (max-width:768px){.user-menu:not(.user-menu--sheet) .user-greeting{display:none}.user-menu:not(.user-menu--sheet) .user-dropdown{min-width:260px;right:-8px}}.ui-button{align-items:center;border:1px solid #0000;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:var(--font-body);font-size:.95rem;font-weight:600;gap:var(--space-2);justify-content:center;min-height:44px;padding:var(--space-3) var(--space-5);text-decoration:none;transition:background-color var(--duration-fast),color var(--duration-fast),border-color var(--duration-fast)}.ui-button--primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.ui-button--primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.ui-button--secondary{background:var(--color-surface);border-color:var(--color-primary);color:var(--color-primary)}.ui-button--secondary:hover{background:var(--color-primary-muted)}.ui-button--ghost{background:#0000;border-color:var(--color-border);color:var(--color-text)}.ui-button--ghost:hover{background:var(--color-surface-muted)}.ui-button:disabled{cursor:not-allowed;opacity:.55}.ui-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-4)}.ui-card--interactive{cursor:pointer}.ui-icon-button{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;display:inline-flex;justify-content:center;min-height:44px;min-width:44px;padding:var(--space-2)}.ui-icon-button:hover{background:var(--color-surface-muted);border-color:var(--color-primary);color:var(--color-primary)}.ui-skeleton{animation:ui-shimmer 1.4s ease-in-out infinite;background:linear-gradient(90deg,var(--color-surface-muted) 0,#e8edf4 50%,var(--color-surface-muted) 100%);background-size:200% 100%;border-radius:var(--radius-md)}.ui-skeleton--text{height:1rem;margin-bottom:var(--space-2)}.ui-skeleton--title{height:1.5rem;margin-bottom:var(--space-3);width:60%}.ui-skeleton--block{height:120px}@keyframes ui-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ui-sheet-backdrop{background:#0f172a66;inset:0;position:fixed;z-index:150}.ui-sheet{background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;bottom:0;box-shadow:var(--shadow-lg);box-sizing:border-box;display:flex;flex-direction:column;left:0;max-height:min(92dvh,calc(100dvh - var(--header-height)));overflow:hidden;padding:var(--space-4) var(--space-5) 0;position:fixed;right:0;z-index:160}.ui-sheet-scroll{-webkit-overflow-scrolling:touch;flex:1 1 auto;min-height:0;overflow-x:hidden;overflow-y:auto;padding-bottom:calc(var(--space-5) + var(--safe-bottom))}.ui-sheet-handle{background:var(--color-border);border-radius:var(--radius-full);height:4px;margin:0 auto var(--space-4);width:40px}.ui-accordion-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-3);overflow:hidden}.ui-accordion-trigger{align-items:center;background:var(--color-surface);border:none;color:var(--color-text);cursor:pointer;display:flex;font-family:var(--font-body);font-size:1rem;font-weight:600;justify-content:space-between;min-height:48px;padding:var(--space-3) var(--space-4);text-align:left;width:100%}.ui-accordion-trigger:hover{background:var(--color-surface-muted)}.ui-accordion-panel{color:var(--color-text-secondary);padding:0 var(--space-4) var(--space-4)}.ui-tabs{-webkit-overflow-scrolling:touch;display:flex;gap:var(--space-2);overflow-x:auto;padding-bottom:var(--space-2);scrollbar-width:none}.ui-tabs::-webkit-scrollbar{display:none}.ui-tab{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-muted);cursor:pointer;flex-shrink:0;font-family:var(--font-body);font-size:.9rem;font-weight:500;min-height:44px;padding:var(--space-2) var(--space-4);position:relative}.ui-tab--active{border-color:var(--color-primary);color:var(--color-primary)}.ui-tab--active,.ui-tab-indicator{background:var(--color-primary-muted)}.ui-tab-indicator{border-radius:var(--radius-full);inset:0;position:absolute;z-index:-1}.app-header{background-color:var(--color-surface);border-bottom:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);flex-shrink:0;padding-top:var(--safe-top);position:-webkit-sticky;position:sticky;top:0;z-index:100}.nav-container{height:var(--header-height);justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 var(--space-5);position:relative;z-index:200}.logo-container,.nav-container{align-items:center;display:flex}.logo-container{gap:var(--space-3)}.app-title{font-family:var(--font-display);font-size:1.25rem;font-weight:600;margin:0}.app-title,.brand-link{color:var(--color-text)}.brand-link{align-items:center;display:flex;gap:var(--space-3);text-decoration:none}.logo{height:44px;object-fit:contain;width:44px}.main-nav--desktop{align-items:center;display:flex;gap:var(--space-2)}.nav-link{align-items:center;-webkit-appearance:none;appearance:none;background:#0000;border:none;border-radius:var(--radius-sm);color:var(--color-muted);display:inline-flex;font-weight:500;min-height:44px;padding:var(--space-2) var(--space-3);position:relative;text-decoration:none;transition:color var(--duration-fast),background-color var(--duration-fast)}.nav-link:hover{background-color:var(--color-surface-muted);color:var(--color-text);text-decoration:none}.nav-link.active{color:var(--color-primary);font-weight:600}.nav-indicator{background:var(--color-primary-muted);border-radius:var(--radius-sm);inset:0;position:absolute;z-index:-1}.main-nav-sheet{box-sizing:border-box;display:flex;flex-direction:column;gap:var(--space-2);min-width:0;width:100%}.nav-link--sheet{border-bottom:1px solid var(--color-border-light);border-radius:0;font-size:1.05rem;justify-content:flex-start;width:100%}.menu-toggle{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;display:none;flex-direction:column;gap:5px;height:44px;justify-content:center;width:44px}.menu-toggle .bar{background:var(--color-text);height:2px;transition:transform .2s ease,opacity .2s ease;width:20px}.menu-toggle.open .bar:first-child{transform:translateY(7px) rotate(45deg)}.menu-toggle.open .bar:nth-child(2){opacity:0}.menu-toggle.open .bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}@media (max-width:768px){.menu-toggle{display:inline-flex}.main-nav--desktop{display:none}.app-title{font-size:1rem}}@media (min-width:769px){.menu-toggle{display:none}}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:200px;padding:var(--space-6)}.loading-container--skeleton{align-items:stretch;margin:0 auto;max-width:400px;width:100%}.loading-spinner{animation:spin 1s linear infinite;border-top:3px solid var(--color-surface-muted);border:3px solid var(--color-surface-muted);border-radius:50%;border-top-color:var(--color-primary);margin-bottom:var(--space-4)}.loading-spinner-small{border-width:2px;height:20px;width:20px}.loading-spinner-medium{height:40px;width:40px}.loading-spinner-large{border-width:4px;height:56px;width:56px}.loading-message{color:var(--color-muted);font-size:1rem;margin:var(--space-4) 0 0;text-align:center}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-overlay{align-items:center;background-color:#f8fafceb;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:9999}.loading-overlay .loading-container{min-height:auto}.not-found-container{align-items:center;background:linear-gradient(135deg,var(--color-bg) 0,var(--color-surface-muted) 100%);display:flex;justify-content:center;min-height:100%;padding:var(--space-5)}.not-found-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:600px;padding:var(--space-10);text-align:center;width:100%}.not-found-icon{color:var(--color-error);margin-bottom:var(--space-5)}.not-found-title{color:var(--color-primary);font-family:var(--font-display);font-size:clamp(4rem,12vw,6rem);font-weight:700;line-height:1;margin:0 0 var(--space-3)}.not-found-subtitle{color:var(--color-text);font-size:clamp(1.25rem,4vw,2rem);font-weight:600;margin:0 0 var(--space-5)}.not-found-description{color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--space-6)}.not-found-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center}.not-found-button{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;font-family:var(--font-body);font-weight:600;min-height:44px;padding:var(--space-3) var(--space-5);text-decoration:none}.not-found-button.primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.not-found-button.primary:hover,.not-found-button.secondary:hover{opacity:.92}.not-found-help{color:var(--color-text-secondary);font-size:.9rem;margin-top:var(--space-6);text-align:left}.not-found-help ul{margin:var(--space-2) 0 0;padding-left:var(--space-5)}.cookie-consent-overlay{align-items:flex-end;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:10000}.cookie-consent-banner{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-height:80vh;max-width:600px;overflow-y:auto;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.cookie-consent-content{padding:0}.cookie-consent-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:1.5rem 1.5rem 0}.cookie-consent-header h3{color:#2c3e50;font-size:1.3rem;font-weight:600;margin:0}.cookie-consent-close{background:none;border:none;color:#6c757d;cursor:pointer;font-size:1.5rem;line-height:1;padding:.25rem;transition:color .2s ease}.cookie-consent-close:hover{color:#495057}.cookie-consent-body{padding:1.5rem}.cookie-consent-body p{color:#495057;font-size:.95rem;line-height:1.6;margin:0 0 1.5rem}.cookie-consent-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.cookie-consent-btn{border:none;border-radius:6px;cursor:pointer;display:inline-block;font-size:.9rem;font-weight:500;min-width:120px;padding:.75rem 1.5rem;text-align:center;text-decoration:none;transition:all .2s ease}.cookie-consent-btn-primary{background:#007bff;color:#fff}.cookie-consent-btn-primary:hover{background:#0056b3;transform:translateY(-1px)}.cookie-consent-btn-secondary{background:#6c757d;color:#fff}.cookie-consent-btn-secondary:hover{background:#545b62;transform:translateY(-1px)}.cookie-consent-btn-outline{background:#0000;border:1px solid #6c757d;color:#6c757d}.cookie-consent-btn-outline:hover{background:#6c757d;color:#fff;transform:translateY(-1px)}.cookie-consent-details{border-top:1px solid #e9ecef;margin-top:1.5rem;padding-top:1.5rem}.cookie-consent-details h4{color:#2c3e50;font-size:1.1rem;font-weight:600;margin:0 0 1rem}.cookie-category{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.cookie-category-header{margin-bottom:.5rem}.cookie-category-label{align-items:center;cursor:pointer;display:flex;margin:0}.cookie-category-checkbox{accent-color:#007bff;height:18px;margin-right:.75rem;width:18px}.cookie-category-checkbox:disabled{cursor:not-allowed;opacity:.6}.cookie-category-title{color:#2c3e50;font-size:1rem;font-weight:600}.cookie-category-description{color:#6c757d;font-size:.9rem;line-height:1.5;margin:.5rem 0 0}.cookie-consent-detail-actions,.cookie-consent-footer{margin-top:1.5rem;text-align:center}.cookie-consent-footer{border-top:1px solid #e9ecef;padding-top:1rem}.cookie-consent-footer p{color:#6c757d;font-size:.85rem;margin:0}.cookie-consent-link{color:#007bff;font-weight:500;text-decoration:none}.cookie-consent-link:hover{text-decoration:underline}@media (max-width:768px){.cookie-consent-overlay{padding:.5rem}.cookie-consent-banner{max-height:90vh}.cookie-consent-header{padding:1rem 1rem 0}.cookie-consent-header h3{font-size:1.2rem}.cookie-consent-body{padding:1rem}.cookie-consent-actions{flex-direction:column;gap:.5rem}.cookie-consent-btn{min-width:auto;width:100%}.cookie-category{padding:.75rem}}@media (max-width:480px){.cookie-consent-overlay{padding:.25rem}.cookie-consent-header{padding:.75rem .75rem 0}.cookie-consent-body{padding:.75rem}.cookie-consent-header h3{font-size:1.1rem}.cookie-consent-btn{font-size:.85rem;padding:.6rem 1rem}}.app-footer{background:linear-gradient(135deg,var(--color-bg) 0,var(--color-surface) 60%,var(--color-surface-muted) 100%);bottom:0;color:var(--color-text);flex-shrink:0;overflow:hidden;padding-bottom:env(safe-area-inset-bottom);position:-webkit-sticky;position:sticky;transition:all .4s cubic-bezier(.4,0,.2,1);z-index:90}.app-footer.collapsed{height:var(--footer-collapsed)}.app-footer.expanded{padding:3rem 0 0}.footer-toggle-container{height:var(--footer-collapsed);left:0;position:absolute;right:0;top:0}.footer-toggle-btn,.footer-toggle-container{align-items:center;display:flex;justify-content:center}.footer-toggle-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffb3;border:1px solid #94a3b84d;border-radius:50%;cursor:pointer;height:32px;opacity:.8;transition:all .3s ease;width:32px}.footer-toggle-btn:hover{background:#eff6fff2;border-color:#3b82f680;box-shadow:0 2px 8px #0000001f;opacity:1;transform:translateY(-2px)}.footer-arrow{color:#64748b;font-size:14px;font-weight:500;line-height:1;transition:transform .3s ease}.footer-arrow.rotated{transform:rotate(180deg)}.footer-container{margin:0 auto;max-width:1200px;padding:0 1rem}.footer-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:2fr 1fr;margin-bottom:2rem;margin-top:60px;transform-origin:top;transition:all .4s cubic-bezier(.4,0,.2,1)}.footer-content.hidden{opacity:0;pointer-events:none;transform:translateY(-20px) scaleY(.8)}.footer-content.visible{opacity:1;pointer-events:auto;transform:translateY(0) scaleY(1)}.footer-section{display:flex;flex-direction:column}.footer-title{color:#1f2937;font-size:1.5rem;font-weight:700;margin:0 0 1rem}.footer-description{color:#4b5563;font-size:.95rem;line-height:1.6;margin:0}.footer-section-title{color:#1f2937;font-size:1.1rem;font-weight:600;margin:0 0 1rem}.footer-links{list-style:none;margin:0;padding:0}.footer-links li{margin-bottom:.5rem}.footer-link{color:#4b5563;display:inline-block;font-size:.9rem;text-decoration:none;transition:color .3s ease}.footer-link:hover{color:#3b82f6;text-decoration:underline}.footer-contact{display:flex;flex-direction:column;gap:.75rem}.footer-contact-item{display:flex;flex-direction:column;font-size:.9rem;gap:.25rem;margin:0}.footer-contact-label{color:#1f2937;font-size:.85rem;font-weight:600}.footer-contact-link{color:#3b82f6;text-decoration:none;transition:color .3s ease}.footer-contact-link:hover{color:#60a5fa;text-decoration:underline}.footer-contact-text{color:#4b5563}.footer-bottom{background:#f8fafce6;border-top:1px solid #e5e7eb;padding:1.5rem 0}.footer-bottom-content{align-items:center;display:flex;flex-direction:column;flex-wrap:wrap;gap:1rem;justify-content:space-between;text-align:center}.footer-copyright{color:#95a5a6;font-size:.85rem;margin:0}.footer-social{display:flex;gap:1rem}.footer-social-link{display:inline-block;font-size:1.2rem;padding:.25rem;text-decoration:none;transition:transform .3s ease}.footer-social-link:hover{transform:translateY(-2px)}@media (max-width:1024px){.footer-content{gap:2rem;grid-template-columns:1fr 1fr}}@media (max-width:768px){.app-footer{display:none}}.footer-sheet{border-top:1px solid var(--color-border);box-sizing:border-box;flex-shrink:0;margin-top:var(--space-4);padding-top:var(--space-4);width:100%}.footer-sheet-title{color:var(--color-text);font-family:var(--font-display);font-size:1.1rem;font-weight:600;margin:0 0 var(--space-2)}.footer-sheet-description{color:var(--color-text-secondary);font-size:.9rem;line-height:1.5;margin:0 0 var(--space-4)}.footer-sheet-copyright{border-top:1px solid var(--color-border-light);color:var(--color-muted);font-size:.8rem;line-height:1.45;margin:0;overflow-wrap:anywhere;padding-top:var(--space-4);word-break:break-word}@media (min-width:769px){.footer-sheet{display:none}}@media (max-width:768px){.app-footer.expanded{padding:2rem 0 0}.footer-content{gap:1.5rem;grid-template-columns:1fr}.footer-bottom-content{flex-direction:column;gap:1rem;text-align:center}}@media (max-width:480px){.footer-container{padding:0 .5rem}.footer-title{font-size:1.3rem}.footer-section-title{font-size:1rem}.footer-description{font-size:.9rem}.footer-contact-item,.footer-link{font-size:.85rem}.footer-copyright{font-size:.8rem}.footer-toggle-btn{height:24px;opacity:.6;width:24px}.footer-arrow{font-size:10px}}.premium-upsell-modal-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2147483647}.premium-upsell-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;margin:auto;max-height:calc(100vh - 80px);max-width:600px;overflow:hidden;position:relative;width:100%}.premium-upsell-modal-content{-webkit-overflow-scrolling:touch;flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;padding:28px 24px 22px}.premium-upsell-modal-close{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;font-size:32px;height:32px;justify-content:center;line-height:1;padding:0;position:absolute;right:15px;top:15px;width:32px;z-index:1}.premium-upsell-modal-close:hover{color:#000}.premium-upsell-modal-title{color:#1a1a1a;font-size:24px;font-weight:700;margin:0 0 14px;text-align:center}.premium-upsell-modal-price{border-bottom:2px solid #e0e0e0;margin-bottom:18px;padding-bottom:14px;text-align:center}.premium-price-amount{color:#10b981;display:inline-block;font-size:40px;font-weight:700}.premium-price-period{color:#666;font-size:18px;margin-left:8px}.premium-upsell-modal-features{margin-bottom:16px}.premium-upsell-modal-features h3{color:#1a1a1a;font-size:18px;margin:0 0 10px}.premium-features-comparison{display:flex;flex-direction:column;gap:8px}.premium-features-header{grid-gap:10px;border-bottom:1px solid #e0e0e0;color:#1a1a1a;display:grid;font-size:15px;font-weight:600;gap:10px;grid-template-columns:1fr 1fr 1fr;margin-bottom:4px;padding:8px 10px}.premium-features-header-label{text-align:left}.premium-features-header-free,.premium-features-header-premium{text-align:center}.premium-feature-row{grid-gap:10px;align-items:center;background:#f9f9f9;border-radius:6px;display:grid;gap:10px;grid-template-columns:1fr 1fr 1fr;padding:8px 10px}.premium-feature-label{color:#333;font-size:15px}.premium-feature-free,.premium-feature-premium{font-size:20px;font-weight:700;min-width:30px;text-align:center}.premium-feature-free{color:#666}.premium-feature-premium{color:#10b981}.premium-upsell-modal-feature-note{background:#fff3cd;border:1px solid #ffc107;border-radius:6px;margin-bottom:14px;padding:15px}.premium-upsell-modal-feature-note p{color:#856404;font-size:14px;margin:0}.premium-upsell-modal-feature-note strong{color:#1a1a1a}.premium-upsell-modal-actions{display:flex;flex-direction:column;gap:12px}.premium-upsell-button{border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;padding:14px 24px;transition:all .2s}.premium-upsell-button-primary{background:#10b981;color:#fff}.premium-upsell-button-primary:hover{background:#059669;box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.premium-upsell-button-secondary{background:#fff;border:2px solid #10b981;color:#10b981}.premium-upsell-button-secondary:hover{background:#f0fdf4}@media (max-width:600px){.premium-upsell-modal{margin:10px;max-height:calc(100vh - 40px);max-width:100%;overflow-y:auto}.premium-upsell-modal-content{padding:24px 16px 16px}.premium-upsell-modal-title{font-size:24px}.premium-price-amount{font-size:36px}.premium-feature-row,.premium-features-header{gap:8px;grid-template-columns:1fr;text-align:center}.premium-feature-free,.premium-feature-premium{justify-self:center}}
/*# sourceMappingURL=main.fa1d21bd.css.map*/