.layout{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;background:#fff!important;border-bottom:1px solid #f0f0f0;padding:0 12px!important;height:56px!important;line-height:56px!important}.app-title{font-size:1rem!important}.user-name-text{display:none}.app-content{padding:12px!important;background:#f5f5f5!important}@media (min-width: 576px){.app-header{padding:0 24px!important;height:64px!important;line-height:64px!important}.app-title{font-size:1.25rem!important}.user-name-text{display:inline}.app-content{padding:24px!important}}.dashboard-container{max-width:1000px;margin:0 auto;padding:0 16px}.dashboard-header{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.dashboard-header h2,.dashboard-header h3{margin:0;font-size:1.25rem}.dashboard-header-actions{display:flex;gap:8px}.dashboard-header-actions .header-btn{flex:1}.dashboard-header-actions .btn-text{display:none}@media (min-width: 576px){.dashboard-container{padding:0 20px}.dashboard-header{flex-direction:row;justify-content:flex-end;align-items:center;margin-bottom:12px}.dashboard-header h2,.dashboard-header h3{font-size:1.5rem}.dashboard-header-actions .header-btn{flex:none}.dashboard-header-actions .btn-text{display:inline}}.months-list{display:flex;flex-direction:column;gap:20px}.month-section{display:flex;flex-direction:column;gap:12px}.month-divider{display:flex;align-items:center;gap:12px;position:sticky;top:0;background-color:#f5f5f5;z-index:10;margin:0 -16px;padding:10px 16px}.month-divider:after{content:"";flex:1;height:2px;background:linear-gradient(to right,#0066cc,transparent)}.month-divider-text{font-size:1.1rem;font-weight:600;color:#06c;white-space:nowrap}@media (min-width: 576px){.months-list{gap:32px}.month-section{gap:20px}.month-divider{gap:16px;margin:0 -20px;padding:12px 20px}.month-divider-text{font-size:1.25rem}}.month-total-footer{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:12px;border-top:1px solid #e8e8e8}.month-total-label{font-size:.85rem;color:#666}.month-total-amount{font-size:1.1rem;font-weight:600;color:#06c}@media (min-width: 576px){.month-total-footer{margin-top:20px;padding-top:16px}.month-total-label{font-size:.9rem}.month-total-amount{font-size:1.25rem}}.empty-state{text-align:center;padding:60px 20px;color:#666;background-color:#fff;border-radius:8px;border:1px dashed #ddd}.subscription-list{display:flex;flex-direction:column;gap:24px}.day-group{display:flex;flex-direction:column;gap:8px}.day-header{flex-shrink:0;display:flex;align-items:center;gap:8px;padding:0}.day-number{font-size:1.25rem;font-weight:600;color:#333;line-height:1}.day-label{font-size:.8rem;color:#666}.day-items{display:flex;flex-direction:column;gap:8px}.subscription-card{background-color:#fff;border-radius:8px;padding:12px;box-shadow:0 1px 3px #0000001a;border-left:4px solid #e0e0e0}.subscription-card.soon{border-left-color:#f59e0b;background-color:#fffbeb}.subscription-main{display:flex;flex-direction:column;gap:8px}.subscription-info{flex:1}.subscription-name{margin:0 0 4px;font-size:1rem;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.subscription-description{color:#666;margin:0 0 6px;font-size:.85rem}.subscription-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:.8rem;color:#666}@media (min-width: 576px){.day-group{flex-direction:row;gap:20px}.day-header{width:80px;flex-direction:column;align-items:center;text-align:center;padding-top:16px}.day-number{font-size:2rem}.day-label{font-size:.85rem;margin-top:4px}.day-items{flex:1;gap:12px}.subscription-card{padding:16px 20px}.subscription-main{flex-direction:row;justify-content:space-between;align-items:flex-start;gap:20px}.subscription-name{font-size:1.1rem;gap:10px}.subscription-description{margin:0 0 8px;font-size:.9rem}.subscription-meta{gap:8px;font-size:.85rem}}.meta-separator{color:#ddd}.category-badge{padding:2px 8px;border-radius:4px;font-size:.8rem;font-weight:500}.category-badge.prive{background-color:#e0f2fe;color:#0369a1}.category-badge.zakelijk{background-color:#f0fdf4;color:#15803d}.subscription-amount{display:flex;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px solid #f0f0f0}.amount{font-size:1.1rem;font-weight:600;color:#333}.tax-mode{font-size:.75rem;color:#666}.subscription-actions{margin-top:10px;padding-top:10px;border-top:1px solid #eee;display:flex;justify-content:flex-end;gap:8px}@media (min-width: 576px){.subscription-amount{display:block;text-align:right;flex-shrink:0;padding-top:0;border-top:none}.amount{display:block;font-size:1.25rem}.tax-mode{display:block;font-size:.8rem}.subscription-actions{margin-top:12px;padding-top:12px}}.btn-small{padding:6px 12px;font-size:.85rem}.badge{padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:500}.badge-soon{background-color:#fef3c7;color:#92400e}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px;border-radius:4px;margin-bottom:20px}.subscription-card-component .subscription-card-content{display:flex;flex-direction:column}.subscription-card-header-mobile{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:4px}.subscription-card-tags-mobile{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.subscription-card-meta-mobile{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding-top:8px;border-top:1px solid #f0f0f0}.subscription-card-actions-mobile{display:flex;justify-content:flex-end;gap:4px;margin-top:8px;padding-top:8px;border-top:1px solid #f0f0f0}.subscription-card-row{display:flex;justify-content:space-between;align-items:center;gap:16px}.subscription-card-info{flex:1;min-width:0}.subscription-card-right{flex-shrink:0}@media (max-width: 575px){.ant-card-body{padding:12px!important}.months-list .ant-card{border-radius:8px}.ant-divider{margin:8px 0!important}}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}*{margin:0;padding:0;box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;min-height:-webkit-fill-available}button,a,[role=button]{touch-action:manipulation}@media (max-width: 575px){input,select,textarea{font-size:16px!important}}
