*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--orange: #FC4C02;--orange-dark: #e04300;--orange-light: #fff0eb;--grey-50: #f8f9fa;--grey-100: #f1f3f5;--grey-200: #e9ecef;--grey-400: #adb5bd;--grey-600: #6c757d;--grey-800: #343a40;--grey-900: #212529;--white: #ffffff;--radius: 10px;--radius-sm: 6px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--transition: .15s ease}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:Inter,system-ui,sans-serif;background:var(--grey-50);color:var(--grey-900);min-height:100dvh}a{color:var(--orange);text-decoration:none}a:hover{text-decoration:underline}.page{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;background-image:url(/bg.webp);background-size:cover;background-position:center;background-repeat:no-repeat}.card{background:#ffffffb8;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.45);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:2.5rem 2rem;width:100%;max-width:440px}.app-header{text-align:center;margin-bottom:2rem}.app-header h1{font-size:2rem;font-weight:700;color:var(--grey-900);letter-spacing:-.5px}.app-header h1 span{color:var(--orange)}.app-header p{margin-top:.5rem;color:var(--grey-600);font-size:.95rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--radius-sm);font-family:inherit;font-size:.95rem;font-weight:600;cursor:pointer;border:none;transition:background var(--transition),transform var(--transition),opacity var(--transition)}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--orange);color:var(--white);width:100%}.btn-primary:hover:not(:disabled){background:var(--orange-dark)}.btn-ghost{background:transparent;color:var(--grey-600);padding:.4rem .75rem;font-size:.85rem;font-weight:500}.btn-ghost:hover{color:var(--grey-900);background:var(--grey-100)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.85rem;font-weight:600;color:var(--grey-800);margin-bottom:.4rem}.form-group input{width:100%;padding:.65rem .9rem;border:1.5px solid var(--grey-200);border-radius:var(--radius-sm);font-family:inherit;font-size:.95rem;color:var(--grey-900);background:var(--white);outline:none;transition:border-color var(--transition)}.form-group input:focus{border-color:var(--orange)}.form-hint{margin-top:.35rem;font-size:.78rem;color:var(--grey-600)}.filter-bar{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.chip{padding:.4rem .9rem;border-radius:99px;border:1.5px solid var(--grey-200);background:var(--white);font-family:inherit;font-size:.82rem;font-weight:500;color:var(--grey-700, #495057);cursor:pointer;transition:all var(--transition)}.chip:hover{border-color:var(--orange);color:var(--orange)}.chip.active{background:var(--orange);border-color:var(--orange);color:var(--white)}.list-screen{display:flex;flex-direction:column;min-height:100dvh}.list-header{background:var(--white);border-bottom:1px solid var(--grey-200);padding:1.25rem 1.25rem .75rem;position:sticky;top:0;z-index:10;box-shadow:var(--shadow-sm)}.list-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.list-header h1{font-size:1.3rem;font-weight:700;color:var(--grey-900)}.list-header h1 span{color:var(--orange)}.filter-section{margin-bottom:.5rem}.filter-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--grey-600);margin-bottom:.35rem}.activity-scroll{flex:1;overflow-y:auto;padding:1rem 1rem 5.5rem}.activity-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:1rem 1rem 1rem 1.1rem;margin-bottom:.75rem;display:flex;align-items:flex-start;gap:.9rem;border:1.5px solid transparent;transition:border-color var(--transition),box-shadow var(--transition);cursor:pointer}.activity-card:hover{border-color:var(--grey-200);box-shadow:var(--shadow-md)}.activity-card.selected{border-color:var(--orange);background:var(--orange-light)}.activity-card.already-done{opacity:.55;cursor:default}.card-checkbox{flex-shrink:0;margin-top:.15rem;width:18px;height:18px;accent-color:var(--orange);cursor:pointer}.card-body{flex:1;min-width:0}.card-name{font-weight:600;font-size:.95rem;color:var(--grey-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-meta{display:flex;align-items:center;gap:.9rem;margin-top:.3rem;flex-wrap:wrap}.card-meta-item{font-size:.8rem;color:var(--grey-600);display:flex;align-items:center;gap:.25rem}.card-stifa{margin-top:.4rem;display:inline-flex;align-items:center;gap:.3rem;background:var(--orange-light);color:var(--orange-dark);border-radius:4px;padding:.15rem .5rem;font-size:.8rem;font-weight:600}.card-stifa.null-stifa{background:var(--grey-100);color:var(--grey-600)}.card-badge{font-size:.7rem;font-weight:600;padding:.15rem .45rem;border-radius:4px;background:var(--grey-200);color:var(--grey-600);white-space:nowrap}.card-badge.done{background:#d1fae5;color:#065f46}.write-bar{position:fixed;bottom:0;left:0;right:0;background:var(--white);border-top:1px solid var(--grey-200);padding:.9rem 1.25rem;display:flex;align-items:center;justify-content:space-between;box-shadow:0 -4px 12px #00000012;z-index:20}.write-bar-info{font-size:.9rem;color:var(--grey-600)}.write-bar-info strong{color:var(--grey-900)}.btn-write{background:var(--orange);color:var(--white);padding:.65rem 1.5rem;border-radius:var(--radius-sm);font-family:inherit;font-size:.9rem;font-weight:600;border:none;cursor:pointer;transition:background var(--transition),transform var(--transition)}.btn-write:hover:not(:disabled){background:var(--orange-dark)}.btn-write:active:not(:disabled){transform:scale(.97)}.btn-write:disabled{opacity:.5;cursor:not-allowed}.footer{text-align:center;padding:1.25rem 1rem;font-size:.85rem;color:var(--white);text-shadow:0 1px 4px rgba(0,0,0,.55)}.footer a{color:var(--white)}.loading-state{text-align:center;padding:3rem 1rem;color:var(--grey-600)}.loading-state .spinner{width:32px;height:32px;border:3px solid var(--grey-200);border-top-color:var(--orange);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:3rem 1rem;color:var(--grey-600)}.empty-state svg{margin-bottom:.75rem;opacity:.35}.error-banner{background:#fee2e2;color:#991b1b;border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.85rem;margin-bottom:1rem}.result-banner{background:var(--grey-50);border-radius:var(--radius-sm);padding:.65rem 1rem;font-size:.82rem;color:var(--grey-800);margin-bottom:.5rem;border-left:3px solid var(--grey-400)}.result-banner.success{border-left-color:#10b981}.result-banner.skip{border-left-color:var(--orange)}.result-banner.error{border-left-color:#ef4444;color:#991b1b}.results-section{padding:1rem}.results-section h2{font-size:1rem;font-weight:600;margin-bottom:.75rem;color:var(--grey-800)}.select-all-row{display:flex;align-items:center;gap:.5rem;padding:.4rem 0 .6rem;font-size:.85rem;font-weight:500;color:var(--grey-700, #495057);cursor:pointer;-webkit-user-select:none;user-select:none}.select-all-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--orange);cursor:pointer}.btn-strava{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;padding:.75rem 1.5rem;border-radius:var(--radius-sm);background:var(--orange);color:var(--white);font-family:inherit;font-size:.95rem;font-weight:600;border:none;cursor:pointer;width:100%;transition:background var(--transition),transform var(--transition)}.btn-strava:hover{background:var(--orange-dark)}.btn-strava:active{transform:scale(.97)}.divider{border:none;border-top:1px solid var(--grey-200);margin:1.5rem 0}.app-shell{display:flex;flex-direction:column;min-height:100dvh}.app-shell-content{flex:1;display:flex;flex-direction:column}.app-nav{display:flex;align-items:center;gap:1rem;padding:0 1.25rem;background:var(--white);border-bottom:1px solid var(--grey-200);position:sticky;top:0;z-index:30;box-shadow:var(--shadow-sm);min-height:52px}.app-nav-title{font-size:1.1rem;font-weight:700;color:var(--grey-900);white-space:nowrap;letter-spacing:-.3px}.app-nav-title span{color:var(--orange)}.app-nav-tabs{display:flex;align-items:stretch;gap:0;flex:1;height:52px}.nav-tab{padding:0 1rem;background:transparent;border:none;border-bottom:2.5px solid transparent;font-family:inherit;font-size:.85rem;font-weight:500;color:var(--grey-600);cursor:pointer;transition:color var(--transition),border-color var(--transition);white-space:nowrap}.nav-tab:hover{color:var(--grey-900)}.nav-tab.active{color:var(--orange);border-bottom-color:var(--orange);font-weight:600}.app-nav-disconnect{margin-left:auto;flex-shrink:0}.insights-page{flex:1;display:flex;align-items:center;justify-content:center;padding:4rem 1rem}.insights-placeholder{font-size:1rem;color:var(--grey-400);font-style:italic}@media(min-width:640px){.list-header{padding:1.25rem 2rem .75rem}.activity-scroll{padding:1.25rem 2rem 5.5rem}.write-bar{padding:.9rem 2rem}.results-section{padding:1.25rem 2rem}.app-nav{padding:0 2rem}}
