.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:var(--spacing-lg);text-align:center;background-color:var(--bg-light);animation:fadeIn .5s ease-out}.login-card{background:var(--bg-white);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid rgba(0,0,0,.03);width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg)}.login-header{margin-bottom:var(--spacing-md)}.login-title{font-size:32px;font-weight:800;color:var(--primary-color);margin-bottom:var(--spacing-xs);letter-spacing:-.5px}.login-subtitle{font-size:16px;color:var(--text-muted);font-weight:500}.login-form{width:100%;display:flex;flex-direction:column;gap:var(--spacing-md)}.login-input-group{display:flex;flex-direction:column;gap:var(--spacing-xs);text-align:left}.login-input{width:100%;text-align:center;font-size:18px;padding:var(--spacing-md);letter-spacing:.5px;background-color:var(--bg-input);border:1px solid transparent;border-radius:var(--radius);color:var(--text-dark);transition:all .2s ease}.login-input:focus{outline:none;background-color:var(--bg-white);border-color:var(--primary-color);box-shadow:0 0 0 3px #00c4b426}.login-input::placeholder{color:var(--text-muted);opacity:.7}.code-input{font-size:24px;letter-spacing:8px;font-family:monospace;font-weight:700}.login-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.btn-block{width:100%;justify-content:center}.btn-text{background:none;border:none;color:var(--primary-color);font-size:14px;font-weight:500;padding:var(--spacing-sm);cursor:pointer;transition:all .2s;border-radius:var(--radius)}.btn-text:hover{color:var(--primary-dark);background-color:var(--bg-light);text-decoration:none}.btn-text:disabled{color:var(--text-muted);cursor:not-allowed;background-color:transparent}.login-footer{margin-top:var(--spacing-lg);font-size:13px;color:var(--text-muted);line-height:1.5}.login-footer strong{color:var(--text-dark);font-weight:600}.login-error{color:var(--error-color);background:#fff3f3;padding:var(--spacing-md);border-radius:var(--radius);font-size:14px;width:100%;border:1px solid var(--error-color);animation:shake .4s ease-in-out;display:flex;align-items:center;justify-content:center}.logout-icon{font-size:64px;color:var(--success-color);margin-bottom:var(--spacing-md);animation:scaleIn .4s cubic-bezier(.175,.885,.32,1.275)}.logout-message{color:var(--text-muted);margin-bottom:var(--spacing-xl);line-height:1.6}.input-hint{font-size:12px;color:var(--text-muted);margin-top:var(--spacing-xs)}.input-hint-error{color:var(--error-color)}.code-expiry{color:var(--primary-color);font-weight:600;font-size:14px;margin-top:var(--spacing-sm)}.code-sent-success{font-size:48px;color:var(--success-color);margin-bottom:var(--spacing-sm);animation:scaleIn .4s cubic-bezier(.175,.885,.32,1.275)}.login-hint-box{background:var(--bg-light);padding:var(--spacing-md);border-radius:var(--radius);margin-bottom:var(--spacing-md);border:1px solid var(--border-color)}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.login-promo{margin-top:var(--spacing-lg);padding:12px 16px;background:linear-gradient(135deg,#00c4b41a,#00a8961a);border-radius:var(--radius);text-align:center;border:1px solid rgba(0,196,180,.2)}.login-promo p{margin:0;font-size:14px;color:var(--text-dark)}.login-promo strong{color:var(--primary-color)}.login-legal-footer{margin-top:auto;padding:20px 16px;text-align:center;font-size:12px;color:var(--text-muted)}.login-legal-footer a{color:var(--text-muted);text-decoration:none}.login-legal-footer a:hover{color:var(--primary-color);text-decoration:underline}.login-legal-footer .separator{margin:0 8px;opacity:.5}.legal-contacts{margin-top:8px;font-size:11px;opacity:.7}.legal-contacts a{color:var(--primary-color)}.legal-page-wrapper{min-height:100vh;background-color:var(--bg-light);color:var(--text-dark);display:flex;flex-direction:column}.legal-container{width:100%;max-width:800px;margin:0 auto;padding:0 var(--spacing-lg)}.legal-header{background-color:var(--bg-white);padding:var(--spacing-md) 0;box-shadow:0 1px 3px #0000000d;position:sticky;top:0;z-index:10}.header-content{display:flex;justify-content:space-between;align-items:center}.logo{font-weight:700;font-size:18px}.nav-link-btn{background:none;border:none;color:var(--primary-color);cursor:pointer;font-size:14px;padding:8px 12px;border-radius:8px;transition:background-color .2s}.nav-link-btn:hover{background-color:#0000000d}.legal-body{flex:1;padding-top:40px;padding-bottom:60px}.document-header{margin-bottom:40px;text-align:center}.document-header h1{font-size:32px;margin-bottom:10px;line-height:1.2}.legal-date{color:var(--text-muted);font-size:14px}.document-content{background-color:var(--bg-white);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:0 2px 12px #0000000a}section{margin-bottom:var(--spacing-xl)}section h2{font-size:20px;margin-bottom:var(--spacing-md);color:var(--text-dark)}section h3{font-size:18px;margin-bottom:var(--spacing-sm);margin-top:var(--spacing-lg);color:var(--text-dark)}section p{margin-bottom:12px;line-height:1.6;font-size:16px}section ul{margin-bottom:16px;padding-left:24px}section li{margin-bottom:8px;line-height:1.5}.legal-footer{background-color:var(--tg-theme-bg-color, #ffffff);padding:24px 0;border-top:1px solid var(--tg-theme-secondary-bg-color, #eee);margin-top:auto}.footer-content{display:flex;flex-direction:column;align-items:center;gap:12px;font-size:14px;color:var(--tg-theme-hint-color, #999);text-align:center}.footer-requisites,.footer-contacts{font-size:13px}.footer-contacts a{color:var(--tg-theme-link-color, #3390ec);text-decoration:none}.footer-contacts a:hover{text-decoration:underline}.footer-links{display:flex;gap:20px}.footer-link{cursor:pointer;transition:color .2s}.footer-link:hover{color:var(--tg-theme-link-color, #3390ec)}.footer-copyright{font-size:12px;opacity:.7}@media(max-width:768px){.document-content{padding:20px;background:transparent;box-shadow:none}.legal-body{padding-top:20px}.document-header h1{font-size:24px}.footer-content{flex-direction:column;align-items:center;text-align:center}}.about-page-wrapper{background:inherit}.about-content{gap:var(--spacing-lg);display:flex;flex-direction:column}.legal-container.about-content{max-width:1200px}.about-hero{text-align:center;padding:40px var(--spacing-lg);margin-bottom:var(--spacing-lg)}.about-hero h1{font-size:36px;font-weight:800;color:var(--primary-color);margin:0 0 16px}.hero-subtitle{font-size:18px;color:var(--text-muted);line-height:1.5;margin:0 auto;max-width:600px}.about-section{background:var(--bg-white);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:0 2px 12px #0000000a}.about-section h2{font-size:24px;font-weight:700;color:var(--text-dark);margin:0 0 24px;text-align:center}.about-section p{font-size:16px;color:var(--text-muted);line-height:1.6;margin:0 0 16px}.features-grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr;gap:var(--spacing-lg)}@media(min-width:768px){.features-grid{grid-template-columns:1fr 1fr}}.features-grid li{display:flex;gap:var(--spacing-md);align-items:flex-start}.features-grid .feature-icon{width:32px;height:32px;min-width:32px;background:#4caf5026;color:var(--success-color);border-radius:50%;display:flex;align-items:center;justify-content:center}.features-grid .feature-icon svg{width:18px;height:18px}.features-grid li strong{display:block;font-size:16px;color:var(--text-dark, #1a1a1a);margin-bottom:6px}.features-grid li div p{font-size:14px;color:var(--text-muted, #888);margin:0;line-height:1.5}.pricing-section{background:var(--bg-white, #fff);color:var(--text-dark, #1a1a1a)}.pricing-section h2{color:var(--text-dark, #1a1a1a)}.pricing-grid-container{display:flex;flex-direction:column;gap:16px}@media(min-width:1200px){.pricing-grid-container{flex-direction:row;align-items:stretch}.pricing-card.trial{flex:1;margin-bottom:0}.pricing-cards{flex:3;display:grid;grid-template-rows:1fr}}.pricing-card{background:#fff;border:1px solid #eee;border-radius:16px;padding:24px;margin-bottom:16px;position:relative;display:flex;flex-direction:column;justify-content:flex-start;box-shadow:0 2px 8px #00000008;transition:transform .2s,box-shadow .2s}.pricing-card:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000000f}.pricing-card.trial{background:#f8f9fa;border:1px solid #e9ecef}.pricing-card.recommended{background:#fff;border:2px solid var(--primary-color, #00c4b4);color:var(--text-dark, #1a1a1a)}.pricing-badge{position:absolute;top:-12px;right:16px;background:var(--primary-color, #00c4b4);color:#fff;font-size:12px;font-weight:700;padding:6px 12px;border-radius:16px;box-shadow:0 2px 4px #00c4b433}.pricing-card h3{font-size:18px;font-weight:700;margin:0 0 12px;color:var(--text-dark, #1a1a1a)}.pricing-price{display:flex;align-items:baseline;gap:8px;margin-bottom:12px;color:var(--text-dark, #1a1a1a)}.pricing-price .price-value{font-size:32px;font-weight:800;white-space:nowrap}.pricing-price .price-period{font-size:16px;opacity:.6;white-space:nowrap}@media(max-width:480px){.pricing-price{flex-wrap:wrap}.pricing-price .price-value{font-size:24px}}.pricing-card p{font-size:14px;color:var(--text-muted, #666);margin:0;opacity:1}.pricing-card.recommended p{color:var(--text-muted, #666)}.pricing-card .savings{display:inline-block;margin-top:12px;background:#e8f5e9;color:#2e7d32;font-size:13px;font-weight:600;padding:6px 12px;border-radius:8px}.pricing-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;grid-auto-rows:1fr}@media(max-width:768px){.pricing-cards{grid-template-columns:1fr 1fr}.pricing-cards .pricing-card:last-child{grid-column:1 / -1}}@media(max-width:480px){.pricing-cards{grid-template-columns:1fr}}.pricing-cards .pricing-card{margin-bottom:0}.pricing-card.lifetime{background:linear-gradient(135deg,#fff8e1,#ffecb3);border:2px solid #ffc107}.pricing-card.lifetime:hover{box-shadow:0 8px 24px #ffc10740}.pricing-badge.lifetime-badge{background:linear-gradient(135deg,#ffc107,#ff9800);box-shadow:0 2px 8px #ffc10766}.pricing-card .savings.lifetime-savings{background:linear-gradient(135deg,#fff3e0,#ffe0b2);color:#e65100;font-weight:700}.telegram-stars-note{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:24px;padding:16px;background:#f8f9fa;border-radius:12px;border:1px solid #e9ecef}.telegram-stars-note .star-icon{font-size:24px;display:flex;color:gold}.telegram-stars-note .star-icon svg{width:24px;height:24px}.telegram-stars-note p{margin:0;font-size:14px;color:var(--text-muted, #666);opacity:1}.steps-list{list-style:none;padding:0;margin:0;counter-reset:step}.steps-list li{display:flex;gap:16px;align-items:flex-start;margin-bottom:24px}.steps-list li:last-child{margin-bottom:0}.step-number{width:36px;height:36px;min-width:36px;background:var(--primary-color, #00c4b4);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700}.steps-list li strong{display:block;font-size:16px;color:var(--text-dark, #1a1a1a);margin-bottom:6px}.steps-list li div p{font-size:14px;color:var(--text-muted, #888);margin:0}.about-section .delivery-note{margin-top:64px!important;padding:16px;background:#00c4b41a;border-radius:12px;font-size:14px;color:var(--text-dark, #1a1a1a);text-align:center}.delivery-note strong{color:var(--primary-color, #00c4b4)}.about-cta{text-align:center;padding:40px 20px;margin-bottom:20px}.cta-btn{width:100%;max-width:320px;padding:18px 32px;font-size:18px;font-weight:700;color:#fff;background:linear-gradient(135deg,#00c4b4,#00a896);border:none;border-radius:16px;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 12px #00c4b44d}.cta-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00c4b466}.cta-btn:active{transform:translateY(0)}.about-cta p{margin:16px 0 0;font-size:14px;color:var(--text-muted, #888)}.screenshots-section{background:var(--bg-white, #fff);overflow:hidden}.carousel-container{position:relative;display:flex;align-items:center;margin:0 -16px}.carousel-track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;padding:8px 0}.carousel-track::-webkit-scrollbar{display:none}.carousel-slide{flex:0 0 100%;scroll-snap-align:center;padding:0 24px;box-sizing:border-box}.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:44px;height:44px;border:none;border-radius:50%;background:var(--bg-white, #fff);box-shadow:0 2px 12px #00000026;cursor:pointer;font-size:24px;font-weight:300;color:var(--text-dark, #1a1a1a);display:flex;align-items:center;justify-content:center;transition:background .2s,opacity .2s,transform .2s}.carousel-arrow:hover:not(.disabled){background:var(--primary-color, #00c4b4);color:#fff;transform:translateY(-50%) scale(1.05)}.carousel-arrow.disabled{opacity:.3;cursor:default}.carousel-arrow-left{left:8px}.carousel-arrow-right{right:8px}@media(max-width:768px){.carousel-arrow{display:none}.carousel-container{margin:0 -12px}.carousel-slide{padding:0 16px}}.carousel-dots{display:flex;justify-content:center;gap:10px;margin-top:20px;padding:8px 0}.carousel-dot{width:10px;height:10px;border:none;border-radius:50%;background:#ddd;cursor:pointer;padding:0;transition:background .2s,transform .2s}.carousel-dot:hover{background:#bbb;transform:scale(1.2)}.carousel-dot.active{background:var(--primary-color, #00c4b4);transform:scale(1.2)}.screenshot-card{display:flex;flex-direction:column;align-items:center;max-width:320px;margin:0 auto}.screenshot-frame{width:100%;background:#f8f9fa;border-radius:16px;padding:12px;box-shadow:0 4px 16px #00000014;transition:transform .2s,box-shadow .2s}.screenshot-frame:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.screenshot-img{width:100%;height:auto;border-radius:12px;display:block}.screenshot-caption{margin:12px 0 0;font-size:14px;font-weight:600;color:var(--text-dark, #1a1a1a);text-align:center}@media(max-width:768px){.about-hero h1{font-size:28px}.hero-subtitle{font-size:16px}.about-section{padding:20px}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{background-color:var(--bg-white);padding:var(--spacing-lg);border-radius:var(--radius);width:90%;max-width:400px;box-shadow:var(--shadow-lg);color:var(--text-dark);animation:slideIn .2s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-dark)}.modal-close-btn{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--text-muted);padding:0;display:flex;align-items:center;justify-content:center}.modal-body{margin-bottom:var(--spacing-lg);font-size:1rem;color:var(--text-dark);line-height:1.5}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md)}.modal-btn{padding:8px 16px;border:none;border-radius:var(--radius);cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s}.modal-btn-cancel{background-color:transparent;color:var(--text-muted)}.modal-btn-cancel:hover{background-color:var(--bg-light)}.modal-btn-confirm{background-color:var(--primary-color);color:#fff}.modal-btn-confirm:hover{background-color:var(--primary-dark)}@keyframes slideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.patient-list-container{padding:var(--spacing-md);max-width:600px;margin:0 auto}.patient-list-container.loading,.patient-list-container.error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;text-align:center;color:var(--text-muted)}.list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.header-title{display:flex;align-items:center;gap:12px}.header-title h2{margin:0;font-size:28px;font-weight:700;color:var(--text-dark)}.search-bar{margin-bottom:var(--spacing-lg)}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-input{width:100%;background-color:var(--bg-white)!important;border:1px solid rgba(0,0,0,.08)!important;box-shadow:var(--shadow-sm);color:var(--text-dark);height:52px;padding:0 52px 0 16px;border-radius:var(--radius);font-size:16px;transition:all .2s ease}.search-input:focus{border-color:var(--primary-color)!important;box-shadow:0 0 0 3px #3390ec26}.search-input::placeholder{color:var(--text-muted);font-weight:400}.search-button{position:absolute;right:6px;top:6px;width:40px;height:40px;padding:0!important;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-muted);border-radius:10px;cursor:pointer;transition:all .2s ease}.search-button:hover{background-color:var(--bg-light);color:var(--primary-color)}.add-patient-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:20px;height:56px;font-size:17px;font-weight:600;border-radius:16px}.patient-card{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;background:#fff;border-radius:16px;margin-bottom:12px;box-shadow:0 2px 8px #0000000a;border:1px solid rgba(0,0,0,.03);transition:transform .2s ease,box-shadow .2s ease}.patient-card:active{transform:scale(.98);background-color:#f5f5f5}.patient-info h3{margin:0 0 4px;font-size:17px;font-weight:600;color:var(--text-dark)}.patient-meta{display:flex;gap:12px;font-size:14px;color:var(--text-muted)}.meta-item{display:flex;align-items:center;gap:4px}.chevron{color:#ccc;display:flex;align-items:center}.spinner{width:40px;height:40px;border:3px solid rgba(0,0,0,.1);border-radius:50%;border-top-color:var(--primary-color);animation:spin 1s ease-in-out infinite;margin-bottom:16px}.patient-form-container{background:var(--bg-white);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);max-width:600px;margin:0 auto;position:relative;animation:slideUp .3s ease-out}.patient-form-header{display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;align-items:center!important;justify-content:space-between!important;margin-bottom:var(--spacing-sm)!important;padding-bottom:var(--spacing-sm)!important;border-bottom:1px solid var(--border-color)}.patient-form-header h2{font-size:24px;font-weight:700;color:var(--text-dark);margin:0;display:flex;align-items:center;gap:12px;flex:1;min-width:0}.patient-form-header h2 svg{color:var(--primary-color)}.btn-close{background:transparent;border:none;color:var(--text-muted);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0;margin-left:16px}.btn-close:hover{background-color:var(--bg-input);color:var(--text-dark)}.patient-form{display:flex;flex-direction:column;gap:var(--spacing-sm)!important}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)!important;margin-bottom:var(--spacing-sm)!important}.form-label{font-size:15px;font-weight:600;color:var(--text-dark);display:flex;align-items:center;gap:4px}.input-icon{position:absolute;left:16px;color:var(--text-muted);display:flex;align-items:center;pointer-events:none}.form-input{width:100%;padding:8px 12px 8px 40px!important;border-radius:12px!important;background-color:var(--bg-input)!important;border:1px solid transparent!important;font-size:15px;transition:all .2s ease}.form-input:focus{background-color:#fff!important;border-color:var(--primary-color)!important;box-shadow:0 0 0 3px #3390ec26}.form-hint{font-size:13px;color:var(--text-muted);margin-top:4px;line-height:1.4}.form-actions{display:flex;flex-direction:column;gap:12px;margin-top:12px}.form-actions button{width:100%;height:52px;font-size:16px;font-weight:600;border-radius:16px;display:flex;align-items:center;justify-content:center;gap:8px}.error-banner{background-color:#ffebee;color:#d32f2f;padding:12px 16px;border-radius:12px;margin-bottom:20px;display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500}.form-error-text{color:#e53935;font-size:12px;margin-top:4px;display:block}.visit-list-card{background:var(--bg-white);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:var(--spacing-md)}.visit-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.list-header h3{font-size:20px;font-weight:700;color:var(--text-dark);margin:0;display:flex;align-items:center;gap:10px}.btn-new-visit{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;height:44px;font-size:15px;font-weight:600;border-radius:var(--radius);margin-bottom:var(--spacing-md)}.visit-card{background:var(--bg-white);border-radius:var(--radius-lg);padding:var(--spacing-md) 20px;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.03);cursor:pointer;transition:all .2s ease;display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.visit-card:active{transform:scale(.98);background-color:var(--bg-light)}.visit-info{display:flex;flex-direction:column;gap:4px}.visit-date{font-size:16px;font-weight:600;color:var(--text-dark);display:flex;align-items:center;gap:10px}.visit-meta{font-size:13px;color:var(--text-muted)}.visit-status{padding:6px 12px;border-radius:var(--radius);font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px}.status-draft{background-color:#fff3e0;color:#ef6c00}.status-final{background-color:#e8f5e9;color:#2e7d32}.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted);background:#f9f9f9;border-radius:16px;border:2px dashed #e0e0e0}.search-bar{position:relative;margin-bottom:12px}.search-icon-wrapper{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);display:flex;align-items:center;pointer-events:none;z-index:1}.visit-list-card .search-input{width:100%;padding:8px 16px 8px 40px;border-radius:10px;border:1px solid transparent;background-color:var(--bg-input);font-size:15px;color:var(--text-dark);transition:all .2s ease;height:40px}.visit-list-card .search-input:focus{background-color:#fff;border-color:var(--primary-color);box-shadow:0 0 0 3px #3390ec26;outline:none}.tooth-map{padding:var(--spacing-lg);background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);width:100%;max-width:100%;border:1px solid rgba(0,0,0,.03)}.tooth-map-svg{display:block;margin:0 auto;width:100%;touch-action:manipulation;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 4px 6px rgba(0,0,0,.05))}.arch-label{font-size:24px;font-weight:700;fill:var(--text-dark);-webkit-user-select:none;user-select:none;opacity:.9}.side-label{font-size:18px;font-weight:600;fill:var(--text-muted);-webkit-user-select:none;user-select:none;opacity:.8}.tooth-shape{fill:var(--bg-white);filter:drop-shadow(0px 2px 2px rgba(0,0,0,.1));transition:all .2s ease}.tooth-number{font-size:13px;fill:var(--text-dark);font-weight:600;pointer-events:none;opacity:.7}.gap-label-small{font-size:13px;fill:var(--text-muted);font-weight:500}.tooth-map-tooltip{position:fixed;background:#212121f2;color:#fff;padding:8px 12px;border-radius:6px;font-size:14px;pointer-events:none;z-index:1000;box-shadow:0 4px 12px #0003;max-width:200px;text-align:center;transform:translate(-50%,-100%);margin-top:-10px;animation:fadeIn .2s ease-out}.tooth-map-tooltip strong{display:block;margin-bottom:4px;color:#fff}.tooth-map-tooltip span{color:var(--border-color);font-size:12px}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,-90%)}to{opacity:1;transform:translate(-50%,-100%)}}.gap{transition:all .2s ease;cursor:pointer;outline:none}.gap:focus{outline:none}.gap:focus-visible .gap-circle{stroke:#0ea5e9;stroke-width:4;filter:drop-shadow(0 0 6px rgba(14,165,233,.6))}.gap:not(.readonly):hover .gap-circle{filter:brightness(1.05) drop-shadow(0 0 4px var(--primary-color));stroke-width:3;cursor:pointer}.gap:not(.readonly):hover .gap-connector{stroke-width:3}.gap:not(.readonly):active .gap-circle{transform:scale(.95)}.gap.selected .gap-circle{filter:drop-shadow(0 4px 12px rgba(14,165,233,.4));transform:scale(1.3);transform-box:fill-box;transform-origin:center;transition:transform .2s cubic-bezier(.175,.885,.32,1.275);z-index:10}.gap.selected .gap-connector{stroke-width:2.5}.gap-circle{transition:all .2s cubic-bezier(.4,0,.2,1)}.gap-hit-area{cursor:pointer}@media(pointer:coarse){.gap-hit-area{r:30}.arch-label{font-size:20px}.side-label{font-size:16px}.tooth-number,.gap-label-small{font-size:11px}}.tooth-map-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-color)}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted)}.legend-circle{width:12px;height:12px;border-radius:50%}.legend-empty{background-color:#f5f5f5;border:2px solid #ccc}.legend-selected{background-color:#0ea5e940;border:2px solid #0ea5e9}.legend-brush-icon,.legend-floss-icon{flex-shrink:0}@media(max-width:768px){.tooth-map{padding:16px;border-radius:6px}.tooth-map-legend{gap:12px;padding:12px;margin-top:16px}.legend-item{font-size:13px}.legend-circle{width:22px;height:22px}}@media(max-width:480px){.tooth-map{padding:12px}.tooth-map-legend{flex-direction:column;gap:10px;padding:10px}.legend-item{justify-content:flex-start;font-size:12px}.legend-circle{width:20px;height:20px}}.tooth-map.linear-layout .tooth-number{font-size:16px;font-weight:700}.tooth-map.linear-layout .gap-label-small{font-size:16px;font-weight:600}.tooth-map.linear-layout .arch-label{font-size:28px;fill:#444}.tooth-map.linear-layout .side-label{font-size:20px;font-weight:700}.zoom-controls{position:absolute;right:10px;top:10px;z-index:100;display:flex;flex-direction:column;gap:6px}.btn-zoom{width:36px;height:36px;border-radius:50%;background:#fff;border:1px solid #ddd;box-shadow:0 2px 6px #0000001a;font-size:18px;font-weight:700;color:#555;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;padding:0}.btn-zoom:hover{background:#f8f9fa;color:var(--primary-color);border-color:var(--primary-color)}.btn-zoom:active{transform:scale(.95);background:#e3f2fd}.custom-select-container{position:relative;width:100%}.custom-select-trigger{width:100%;padding:12px 12px 12px 40px;border-radius:12px;background-color:var(--bg-input, #f5f7fa);border:1px solid transparent;font-size:15px;transition:all .2s ease;color:var(--text-dark, #333);cursor:pointer;display:flex;align-items:center;justify-content:space-between;-webkit-user-select:none;user-select:none;min-height:45px}.custom-select-trigger:focus{outline:none}.custom-select-trigger.open{background-color:var(--bg-white, #fff);border-color:var(--primary-color, #00C4B4);box-shadow:0 0 0 2px #00c4b426;border-bottom-left-radius:0;border-bottom-right-radius:0;z-index:101}.custom-select-icon{position:absolute;left:12px;color:var(--text-muted, #999);display:flex;align-items:center;pointer-events:none}.custom-select-value{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:8px}.custom-select-arrow{color:var(--text-muted, #6c757d);display:flex;align-items:center;transition:transform .2s ease}.custom-select-trigger.open .custom-select-arrow{transform:rotate(180deg)}.custom-select-options{position:absolute;top:100%;left:0;right:0;background-color:var(--bg-white, #fff);border:1px solid var(--border-color, #eef0f2);border-top:none;border-bottom-left-radius:12px;border-bottom-right-radius:12px;box-shadow:var(--shadow-md, 0 8px 24px rgba(0, 0, 0, .08));z-index:100;max-height:250px;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent}.custom-select-options::-webkit-scrollbar{width:6px}.custom-select-options::-webkit-scrollbar-track{background:transparent}.custom-select-options::-webkit-scrollbar-thumb{background-color:#0003;border-radius:3px}.custom-select-options::-webkit-scrollbar-thumb:hover{background-color:#0000004d}.custom-select-option{padding:12px 12px 12px 40px;cursor:pointer;transition:background-color .1s;color:var(--text-dark, #333);font-size:15px}.custom-select-option:hover{background-color:var(--bg-input, #f5f7fa)}.custom-select-option.selected{background-color:#00c4b41a;color:var(--primary-color, #00C4B4);font-weight:500}.brush-picker{background:var(--bg-white);color:var(--text-dark);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-lg);max-width:500px;width:100%;margin:0 auto;position:relative;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.brush-picker.loading{text-align:center;padding:40px;color:var(--text-muted)}.brush-picker-header.compact-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:12px;border-bottom:1px solid var(--border-color)}.brush-picker-header h3{margin:0;color:var(--text-dark);font-size:1.1rem;font-weight:700}.picker-form{display:flex;flex-direction:column;gap:12px}.form-group{display:flex;flex-direction:column;gap:6px}.label-with-help{display:flex;justify-content:space-between;align-items:center;width:100%}.form-group label{font-weight:500;color:var(--text-dark);font-size:.9rem;opacity:.8}.required{color:var(--error-color);margin-left:4px}.help-btn{background:none;border:none;padding:4px;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:color .2s}.help-btn:hover{color:var(--primary-color)}.input-icon{position:absolute;left:12px;color:var(--text-muted, #999);display:flex;align-items:center;pointer-events:none;z-index:1}.form-input{width:100%;padding:12px 12px 12px 40px;border-radius:12px;background-color:var(--bg-input, #f5f7fa);border:1px solid transparent;font-size:15px;transition:all .2s ease;color:var(--text-dark, #333);font-family:inherit;-webkit-appearance:none;appearance:none}.form-input:focus{outline:none;border-color:var(--primary-color, #00C4B4);background-color:var(--bg-white, #fff);box-shadow:0 0 0 2px #00c4b426}.brush-picker select.form-input{appearance:none!important;-webkit-appearance:none!important;-moz-appearance:none!important;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236c757d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e")!important;background-repeat:no-repeat!important;background-position:right 12px center!important;background-size:16px!important;padding-right:40px!important;color:var(--text-dark, #333)!important;background-color:var(--bg-input, #f5f7fa)!important;border:1px solid transparent!important;border-radius:12px!important}select.form-input option{color:var(--text-dark, #333);background-color:var(--bg-white, #fff)}textarea.form-input{resize:vertical;min-height:80px;padding-top:12px}.textarea-icon{top:12px}.segmented-control{display:flex;background:var(--bg-input, #f5f7fa);padding:4px;border-radius:12px;gap:4px}.segmented-control.compact{margin-bottom:0;width:auto}.segment-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;border-radius:10px;border:none;background:transparent;color:var(--text-muted, #666);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.segment-btn.active{background:var(--bg-white, #ffffff);color:var(--primary-color, #00C4B4);box-shadow:var(--shadow-sm, 0 2px 8px rgba(0, 0, 0, .04))}.scroll-wrapper{position:relative;margin:0 -8px}.size-scroll-container{display:flex;gap:8px;overflow-x:auto;padding:4px 8px 12px;scrollbar-width:none;-ms-overflow-style:none}.size-scroll-container::-webkit-scrollbar{display:none}.scroll-fade-hint{position:absolute;top:0;right:0;bottom:12px;width:40px;background:linear-gradient(to right,rgba(255,255,255,0),var(--bg-white, #ffffff));pointer-events:none;z-index:2}.scroll-spacer{min-width:12px}.size-card{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;width:72px;height:auto;min-height:72px;padding:8px 4px;border:1px solid var(--border-color, #eef0f2);border-radius:12px;background-color:var(--bg-input, #f5f7fa);cursor:pointer;transition:all .2s;position:relative}.size-card.active{background-color:var(--bg-white, #fff);border-color:var(--primary-color, #00C4B4);box-shadow:var(--shadow-sm, 0 2px 8px rgba(0, 0, 0, .04));transform:translateY(-2px);z-index:1}.size-details{display:flex;flex-direction:column;align-items:center;line-height:1.2}.size-card .phd-text{font-weight:700;font-size:.9rem;color:var(--text-dark, #333);margin-top:4px}.size-card .iso-text{font-size:.65rem;color:var(--text-muted, #666)}.size-card .series-text{font-size:.6rem;color:var(--text-muted, #666);margin-top:2px;text-align:center;line-height:1;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chips-row{display:flex;gap:8px;flex-wrap:wrap}.chip{padding:8px 12px;border-radius:20px;border:1px solid var(--border-color, #eef0f2);background:transparent;font-size:.85rem;color:var(--text-dark, #333);cursor:pointer;transition:all .2s}.chip.active{background-color:var(--primary-color, #00C4B4);color:#fff;border-color:var(--primary-color, #00C4B4)}.accordion-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:12px 0;background:none;border:none;border-top:1px solid var(--border-color, #eef0f2);color:var(--text-dark, #333);font-weight:500;cursor:pointer;font-size:.95rem}.picker-actions.fixed-bottom{margin-top:16px;display:flex;gap:12px;padding-top:16px;border-top:1px solid var(--border-color, #eef0f2);flex-wrap:wrap}.btn-secondary,.btn-primary,.btn-danger{padding:12px;border-radius:12px;font-weight:600;font-size:1rem;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;flex:1;min-width:0;white-space:nowrap}.btn-secondary{background:var(--bg-input, #f5f7fa);color:var(--text-dark, #333)}.btn-primary{background:var(--primary-color, #00C4B4);color:#fff}.btn-danger.icon-only{background:#f443361a;color:var(--error-color, #f44336);flex:0 0 48px;padding:0}@media(max-width:480px){.brush-picker{padding:12px}.brush-picker-header.compact-header{flex-direction:column;align-items:stretch;gap:12px}.segmented-control.compact{width:100%}.picker-actions.fixed-bottom{gap:8px}.btn-secondary,.btn-primary,.btn-danger{padding:10px 8px;font-size:.9rem}.btn-danger.icon-only{flex:0 0 40px}}@media(max-width:360px){.picker-actions.fixed-bottom{flex-wrap:wrap}.btn-secondary,.btn-primary{flex:1 1 100%}.btn-danger.icon-only{flex:1 1 100%;padding:10px}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.color-dot.large{width:20px;height:20px;border-radius:50%;border:1px solid rgba(0,0,0,.1)}.color-dot-small{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:6px;border:1px solid rgba(0,0,0,.1)}.analogs-list.compact{max-height:150px;overflow-y:auto}.analog-item{padding:6px 0;display:flex;align-items:center;font-size:.9rem;color:var(--text-dark, #333)}.details-content{display:flex;flex-direction:column;gap:12px;padding-bottom:12px}.form-row{display:flex;gap:12px}.flex-grow{flex:1}.iso-help-card{background:var(--bg-input, #f5f7fa);border-radius:12px;padding:12px;margin-bottom:12px;font-size:.9rem;border:1px solid var(--border-color, #eef0f2)}.help-header{display:flex;align-items:center;gap:8px;font-weight:600;margin-bottom:8px;color:var(--primary-color, #00C4B4)}.help-table-container{overflow-x:auto;margin:0 -12px;padding:0 12px;-webkit-overflow-scrolling:touch}.iso-reference-table{width:100%;border-collapse:collapse;font-size:.8rem}.iso-reference-table th{text-align:center;padding:6px 4px;border-bottom:2px solid rgba(0,0,0,.1);color:var(--text-muted, #666);font-weight:600;white-space:nowrap;font-size:.75rem}@media(max-width:400px){.iso-reference-table th,.iso-reference-table td{padding:4px 2px}.iso-reference-table th{font-size:.7rem}.iso-reference-table td{font-size:.75rem}.iso-reference-table .text-small{font-size:.7rem}}.iso-reference-table td{padding:6px 4px;border-bottom:1px solid rgba(0,0,0,.05);color:var(--text-dark, #333);vertical-align:middle}.iso-reference-table tr:last-child td{border-bottom:none}.iso-reference-table .text-center{text-align:center}.iso-reference-table .text-small{font-size:.75rem;color:var(--text-muted, #666)}.iso-reference-table .color-dot-small{width:12px;height:12px;border-radius:50%;border:1px solid rgba(0,0,0,.1)}.visit-form .brush-group-card{background-color:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);margin-bottom:var(--spacing-sm);padding:12px;border:1px solid rgba(0,0,0,.03);border-left:4px solid var(--primary-color);transition:transform .2s ease,box-shadow .2s ease}.visit-form .brush-group-card:hover{box-shadow:var(--shadow-md)}.visit-form .brush-group-card:active{transform:scale(.99)}.visit-form .brush-group-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-color)}.visit-form .brush-info{flex:1;display:flex;flex-direction:column}.visit-form .brush-group-header .brush-info{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:var(--spacing-lg);width:100%}.btn-delete-recommendation{background:#f443361a;color:var(--error-color);border:none;border-radius:var(--radius);padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease;flex-shrink:0;margin-left:12px}.btn-delete-recommendation:hover{background:#f4433633}.btn-delete-recommendation:active{background:#f443364d}.visit-form .brush-name{font-weight:700;font-size:1rem;color:var(--text-dark);margin-bottom:2px}.visit-form .brush-details{font-size:.85rem;color:var(--text-muted);line-height:1.4}.brush-gaps-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.gap-chip{display:inline-flex;align-items:center;padding:6px 12px;background-color:var(--bg-input);border:1px solid transparent;border-radius:var(--radius-pill);font-size:.9rem;font-weight:500;color:var(--text-dark);transition:all .2s ease}.gap-chip:hover{background-color:#e3f2fd;color:var(--primary-color)}.gap-chip:active{background-color:#bbdefb}.visit-form .recommendations-summary h4{margin-bottom:10px;color:var(--text-dark);font-weight:700;font-size:1rem!important}.autosave-indicator{font-size:.8rem;color:var(--text-muted);margin-top:-10px;margin-bottom:10px;text-align:right;font-style:italic}.text-success{color:var(--success-color)}.selection-bar{padding:10px;background:#00c4b41a;border-radius:8px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center;min-height:60px;border-left:4px solid var(--primary-color)}.selection-bar .selection-actions{display:flex;gap:8px}.selection-bar .btn-secondary,.selection-bar .btn-primary{padding:6px 12px;font-size:.9rem}.patient-name{font-size:16px;color:var(--text-muted);margin:4px 0 0;font-weight:500}.form-label{font-size:15px;font-weight:600;color:var(--text-dark);display:flex;align-items:center;gap:4px;margin-bottom:8px}.form-label.required:after{content:"*";color:var(--error-color);margin-left:4px}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:16px;color:var(--text-muted);display:flex;align-items:center;pointer-events:none;z-index:1}.visit-form .form-input{width:100%;padding:8px 12px 8px 40px!important;border-radius:12px!important;background-color:var(--bg-input)!important;border:1px solid transparent!important;font-size:15px;transition:all .2s ease;color:var(--text-dark)}.visit-form .form-input:focus{background-color:#fff!important;border-color:var(--primary-color)!important;box-shadow:0 0 0 3px #3390ec26}textarea.form-input{resize:vertical}.visit-form .tooth-map-header h3{display:flex;align-items:center;gap:8px;font-size:1.1rem!important;margin:0}.visit-form .btn-icon-text{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:12px;font-size:.85rem;font-weight:600;border:1px solid var(--border-color);background:transparent;color:var(--text-dark);transition:all .2s ease}.visit-form .section-description{font-size:.85rem;margin-top:4px;margin-bottom:12px;line-height:1.3;color:var(--text-muted)}.btn-icon-text:hover{background:var(--bg-input)}.btn-icon-text.active{background:#e3f2fd;color:var(--primary-color);border-color:transparent}.btn-primary-soft{background:#e3f2fd;color:var(--primary-color);border:none}.btn-primary-soft:hover{background:#bbdefb}.map-controls{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:16px;background:#f8f9fa;padding:8px 12px;border-radius:12px}.control-label{font-weight:600;color:var(--text-dark);font-size:14px}.segmented-control{display:flex;background:#e9ecef;padding:4px;border-radius:10px;gap:4px}.segment-btn{padding:6px 12px;border-radius:8px;border:none;background:transparent;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.segment-btn.active{background:#fff;color:var(--text-dark);box-shadow:0 2px 4px #0000000d;font-weight:600}.mirror-toggle{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:13px;color:var(--text-muted);-webkit-user-select:none;user-select:none}.mirror-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--primary-color)}.mirror-toggle span{white-space:nowrap}.visit-form{background-color:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:24px;margin-bottom:24px;animation:slideUp .3s ease-out;display:flex;flex-direction:column;gap:8px!important}#visit-edit-form{display:flex;flex-direction:column;gap:8px!important}.visit-form .form-group{display:flex;flex-direction:column;gap:4px!important;margin-bottom:8px!important}.visit-form .form-input,.visit-form input[type=date],.visit-form textarea,.visit-form select{width:100%;padding:8px 12px 8px 40px!important;border-radius:12px!important;background-color:var(--bg-input)!important;border:1px solid transparent!important;font-size:15px;transition:all .2s ease}.visit-form select.form-input,.visit-form select{appearance:none!important;-webkit-appearance:none!important;-moz-appearance:none!important;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236c757d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e")!important;background-repeat:no-repeat!important;background-position:right 12px center!important;background-size:16px!important;padding-right:32px!important;color:var(--text-dark);cursor:pointer}.visit-form select:focus{background-color:#fff!important;border-color:var(--primary-color)!important;box-shadow:0 0 0 3px #3390ec26;outline:none}.visit-form select option{background-color:var(--bg-white);color:var(--text-dark);padding:10px}.form-header{margin-bottom:8px!important;padding-bottom:8px!important;border-bottom:1px solid var(--border-color);display:flex!important;flex-direction:column!important;align-items:flex-start!important;gap:4px!important}.form-header h2{display:flex;align-items:center;gap:12px;margin:0;font-size:24px;color:var(--text-dark)}.patient-name{font-size:20px;font-weight:600;color:var(--text-muted);margin:0}.form-header h2 svg{color:var(--primary-color)}.visit-form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color)}.visit-form-actions .btn-secondary,.visit-form-actions .btn-primary{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .2s ease;flex:1;white-space:nowrap}@media(max-width:768px){.visit-form-actions{flex-direction:row}.visit-form-actions .btn-secondary,.visit-form-actions .btn-primary{width:auto;flex:1}}@media(max-width:480px){.map-controls{flex-direction:column;align-items:flex-start;gap:10px}.map-controls .control-label{margin-bottom:0}.map-controls .segmented-control{width:100%;justify-content:center}.map-controls .segment-btn{flex:1;text-align:center}}.pdf-section{margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color)}.pdf-section-header{margin-bottom:16px}.pdf-section-header h4{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:700;color:var(--text-dark);margin:0}.pdf-section-header h4 svg{color:var(--primary-color)}.pdf-actions{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.btn-generate-pdf{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;font-size:1rem;font-weight:600;border-radius:var(--radius-pill);background:var(--primary-color);color:#fff;border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #3390ec4d}.btn-generate-pdf:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 6px 16px #3390ec66}.btn-generate-pdf:active:not(:disabled){transform:translateY(0)}.btn-generate-pdf:disabled{opacity:.6;cursor:not-allowed;background:#ccc;box-shadow:none}.pdf-hint{font-size:.85rem;color:var(--text-muted);text-align:center;margin:0}.pdf-history{background:var(--bg-input);border-radius:12px;padding:16px}.pdf-history h5{display:flex;align-items:center;gap:6px;font-size:.9rem;font-weight:600;color:var(--text-dark);margin:0 0 12px}.pdf-history h5 svg{color:var(--text-muted)}.pdf-history-list{display:flex;flex-direction:column;gap:8px}.pdf-history-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg-white);border-radius:8px;border:1px solid rgba(0,0,0,.05)}.pdf-history-info{display:flex;flex-direction:column;gap:2px}.pdf-version{font-size:.9rem;font-weight:600;color:var(--text-dark)}.pdf-date{font-size:.8rem;color:var(--text-muted)}.btn-download-pdf{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:#3390ec1a;color:var(--primary-color);border:none;border-radius:50%;cursor:pointer;transition:all .2s ease}.btn-download-pdf:hover:not(:disabled){background:#3390ec33;transform:scale(1.05)}.btn-download-pdf:disabled{opacity:.6;cursor:not-allowed}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-icon{animation:spin 1s linear infinite}.pdf-history-actions{display:flex;gap:8px}.btn-preview-pdf{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:#4caf501a;color:#4caf50;border:none;border-radius:50%;cursor:pointer;transition:all .2s ease}.btn-preview-pdf:hover{background:#4caf5033;transform:scale(1.05)}.pdf-preview-modal{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.pdf-preview-content{background:var(--bg-white);border-radius:16px;width:100%;max-width:900px;height:90vh;max-height:800px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}.pdf-preview-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-white)}.pdf-preview-header h3{margin:0;font-size:1.2rem;font-weight:700;color:var(--primary-color)}.pdf-preview-header-actions{display:flex;gap:12px}.pdf-preview-header-actions .btn-download-pdf,.pdf-preview-header-actions .btn-close-preview{width:40px;height:40px;border-radius:50%;padding:0;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.pdf-preview-header-actions .btn-download-pdf{background:var(--primary-color);color:#fff;box-shadow:0 4px 10px #00c4b44d}.pdf-preview-header-actions .btn-download-pdf:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 6px 14px #00c4b466}.pdf-preview-header-actions .btn-close-preview{background:transparent;color:var(--text-muted);border:1px solid transparent}.pdf-preview-header-actions .btn-close-preview:hover{background:var(--bg-light);color:var(--text-dark);transform:rotate(90deg)}.pdf-preview-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px;color:var(--text-muted);flex:1}.pdf-preview-loading svg{width:32px;height:32px}.pdf-preview-iframe{flex:1;width:100%;border:none;background:#f5f5f5}@media(max-width:768px){.pdf-preview-modal{padding:0}.pdf-preview-content{border-radius:0;height:100vh;max-height:none}.pdf-preview-header{padding:12px 16px}.pdf-preview-header h3{font-size:1rem}}.brush-picker-modal-overlay{position:fixed;inset:0;background-color:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.brush-picker-modal-content{background-color:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out;position:relative}@media(max-width:600px){.brush-picker-modal-overlay{align-items:flex-end;padding:0}.brush-picker-modal-content{border-radius:20px 20px 0 0;max-height:85vh}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.btn-delete-pdf{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:#f443361a;color:var(--error-color, #f44336);border:none;border-radius:50%;cursor:pointer;transition:all .2s ease}.btn-delete-pdf:hover:not(:disabled){background:#f4433633;transform:scale(1.05)}.btn-delete-pdf:disabled{opacity:.6;cursor:not-allowed}.patient-detail{padding:var(--spacing-md);max-width:600px;margin:0 auto}.detail-header{margin-bottom:var(--spacing-md)}.btn-back{display:flex;align-items:center;gap:8px;background:transparent;border:none;color:var(--text-muted);font-size:15px;font-weight:500;padding:8px 0;cursor:pointer;transition:color .2s ease}.btn-back:hover{color:var(--primary-color)}.patient-card-full{background:var(--bg-white);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-soft);margin-bottom:var(--spacing-lg)}.patient-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.patient-detail-title{font-size:28px;font-weight:800;color:var(--text-dark);margin:0;letter-spacing:-.5px}.patient-card-body{display:grid;grid-template-columns:24px auto 1fr;gap:12px;align-items:center}.patient-info{display:contents}.info-icon{color:var(--text-muted);display:flex;align-items:center;justify-content:center}.info-label{color:var(--text-muted)}.info-value{font-weight:500}.btn-edit{display:flex;align-items:center;gap:8px;padding:8px 16px;background-color:var(--bg-input);color:var(--text-dark);border-radius:var(--radius);font-weight:600;font-size:14px;border:none;transition:all .2s ease}.btn-edit:hover{background-color:var(--border-color)}.subscription-card{background:#fff;border-radius:20px;padding:24px;box-shadow:0 4px 20px #0000000d;margin-bottom:24px}.subscription-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.subscription-title{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:700;color:#000;margin:0}.subscription-status{font-size:16px;font-weight:600}.status-expired{color:var(--error-color)}.status-active{color:var(--success-color)}.btn-subscribe{width:100%;background-color:var(--primary-color);color:#fff;border:none;border-radius:12px;padding:14px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s;display:flex;justify-content:center;align-items:center}.btn-subscribe:hover{background-color:var(--primary-dark)}.subscription-history-card{background:var(--bg-white);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-soft)}.subscription-history-card.loading,.subscription-history-card.error,.subscription-history-card.empty{padding:var(--spacing-lg)}.history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg);padding-bottom:0;border-bottom:none}.history-title{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:700;color:var(--text-dark);margin:0}.history-loading,.history-empty{text-align:center;color:var(--text-muted);font-size:14px;padding:12px 0}.history-error{text-align:center;color:var(--error-color);font-size:14px;padding:12px 0}.history-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.history-event{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--radius);background:var(--bg-input);transition:background .2s}.history-event:hover{background:var(--bg-light)}.event-icon{font-size:18px;line-height:1.2;flex-shrink:0}.event-content{flex:1;min-width:0}.event-title{font-size:14px;font-weight:500;color:#333;margin-bottom:4px}.event-details{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:#666}.event-date{color:#999}.event-plan{background:#e8f5f4;color:var(--primary-dark);padding:2px 6px;border-radius:4px}.event-amount{font-weight:500;color:var(--text-dark)}.history-event.event-positive{background:#f0fff4;border-left:3px solid #00a854}.history-event.event-positive .event-title{color:#00a854}.history-event.event-warning{background:#fffbf0;border-left:3px solid #faad14}.history-event.event-warning .event-title{color:#d48806}.history-event.event-negative{background:#fff0f0;border-left:3px solid #dc3545}.history-event.event-negative .event-title{color:#dc3545}.history-toggle{display:block;width:100%;margin-top:12px;padding:10px;background:none;border:1px dashed #ddd;border-radius:8px;color:#00c4b4;font-size:14px;cursor:pointer;transition:all .2s}.history-toggle:hover{background:#f9f9f9;border-color:#00c4b4}.profile-settings{padding:var(--spacing-md);min-height:100vh;background:var(--bg-light)}.profile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px var(--spacing-lg)}.profile-loading .spinner{font-size:32px;margin-bottom:12px}.profile-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.profile-header h2{margin:0;font-size:20px;color:var(--text-dark)}.btn-back{background:none;border:none;color:var(--primary-color);font-size:16px;padding:8px 0;cursor:pointer}.btn-back:hover{color:var(--primary-dark)}.profile-content{display:flex;flex-direction:column;gap:var(--spacing-md)}.profile-card,.profile-subscription-card{background:var(--bg-white);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm)}.profile-card h3,.profile-subscription-card h3{margin:0 0 12px;font-size:16px;font-weight:600;color:var(--text-dark)}.profile-hint{font-size:13px;color:var(--text-muted);margin-bottom:12px;line-height:1.4}.form-group{margin-bottom:12px;position:relative}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-dark);margin-bottom:6px}.form-group input{width:100%;padding:10px 12px;font-size:15px;border:1px solid var(--border-color);border-radius:var(--radius);transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#00c4b4;box-shadow:0 0 0 3px #00c4b41a}.form-group input:disabled{background:#f5f5f5;color:#999}.char-counter{position:absolute;right:12px;bottom:-18px;font-size:11px;color:#999}.profile-error{display:flex;align-items:center;gap:8px;padding:10px;background:#fff0f0;border-radius:8px;color:#c00;font-size:13px;margin-bottom:12px}.profile-success{display:flex;align-items:center;gap:8px;padding:10px;background:#f0fff4;border-radius:8px;color:#00a854;font-size:13px;margin-bottom:12px}.profile-actions{margin-top:16px}.btn-primary{width:100%;padding:12px 20px;font-size:15px;font-weight:500;color:#fff;background:#00c4b4;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.btn-primary:hover:not(:disabled){background:#00a89a}.btn-primary:disabled{background:#ccc;cursor:not-allowed}.compact-preview{background:#fafafa;border:1px solid #eee;border-radius:8px;padding:12px;margin-top:20px;font-size:13px}.compact-preview-label{display:block;font-size:11px;color:#999;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.compact-preview-content{display:flex;flex-direction:column;gap:4px}.preview-row{display:flex;gap:6px}.preview-key{color:#666}.preview-val{font-weight:500;color:#00c4b4}.profile-subscription-card{margin-bottom:12px}.subscription-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.subscription-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:#333;margin:0}.subscription-status{font-size:12px;font-weight:500;padding:2px 8px;border-radius:12px;background:#f5f5f5;line-height:1.5}.subscription-status.status-trial{color:#1890ff;background:#e6f7ff}.subscription-status.status-active{color:#00a854;background:#f6ffed}.subscription-status.status-warning{color:#faad14;background:#fffbe6}.subscription-status.status-expired{color:#dc3545;background:#fff1f0}.subscription-status-block{display:flex;flex-direction:column;gap:8px;padding-bottom:12px;border-bottom:1px solid #f0f0f0;margin-bottom:12px}.subscription-status-block .status-row{display:flex;justify-content:space-between;align-items:center}.subscription-status-block .status-label{font-size:13px;color:#666}.subscription-status-block .status-value{font-size:13px;font-weight:500;color:#333}.subscription-management-section{padding:12px 0;border-bottom:1px solid #f0f0f0}.management-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.management-label{display:block;font-size:13px;font-weight:500;color:#333;margin-bottom:2px}.management-description{font-size:11px;color:#666}.auto-renew-toggle{padding:6px 12px;border-radius:16px;border:1px solid #ddd;background:#f5f5f5;color:#666;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;min-width:50px}.auto-renew-toggle:hover:not(:disabled){border-color:#00c4b4}.auto-renew-toggle.enabled{background:#00c4b4;border-color:#00c4b4;color:#fff}.subscription-actions{display:flex;flex-direction:column;gap:8px;margin-top:12px}.btn-subscribe{width:100%;background-color:#00c4b4;color:#fff;border:none;border-radius:8px;padding:12px;font-size:15px;font-weight:600;cursor:pointer;transition:background-color .2s;display:flex;justify-content:center;align-items:center}.btn-subscribe:hover{background-color:#009e91}.btn-subscription-cancel{width:100%;padding:10px 20px;font-size:13px;font-weight:500;color:#dc3545;background:transparent;border:1px solid #dc3545;border-radius:8px;cursor:pointer;transition:all .2s}.btn-subscription-cancel:hover{background:#fff0f0}.cancel-confirm-dialog{margin-top:12px;padding:12px;background:#fff0f0;border-radius:8px;border:1px solid #ffccc7}.cancel-confirm-title{font-size:14px;font-weight:600;color:#dc3545;margin:0 0 6px}.cancel-confirm-text{font-size:13px;color:#666;margin:0 0 12px;line-height:1.4}.cancel-confirm-actions{display:flex;gap:8px}.btn-cancel-confirm{flex:1;padding:10px;font-size:13px;font-weight:500;color:#fff;background:#dc3545;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.btn-cancel-confirm:hover:not(:disabled){background:#c82333}.btn-cancel-back{flex:1;padding:10px;font-size:13px;font-weight:500;color:#666;background:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;transition:all .2s}.btn-cancel-back:hover:not(:disabled){background:#f5f5f5}.subscription-page{padding:var(--spacing-md);max-width:600px;margin:0 auto;animation:fadeIn .3s ease-in}.subscription-header{text-align:center;margin-bottom:var(--spacing-lg)}.subscription-header h2{margin:0 0 8px;font-size:24px;color:var(--text-dark);font-weight:700}.subscription-header p{margin:0;color:var(--text-muted);font-size:15px}.subscription-status{background:var(--bg-white);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.status-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0}.status-row:not(:last-child){border-bottom:1px solid var(--border-color)}.status-label{color:var(--text-muted);font-size:14px}.status-value{font-weight:600;font-size:14px;color:var(--text-dark)}.status-value.active{color:var(--success-color)}.status-value.trial{color:var(--primary-color)}.status-value.warning{color:var(--warning-color)}.status-value.expired{color:var(--error-color)}.auto-renew-row{align-items:center}.auto-renew-toggle{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-pill);border:2px solid var(--border-color);background:var(--bg-white);color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.auto-renew-toggle:hover:not(:disabled){border-color:var(--primary-color);color:var(--primary-color)}.auto-renew-toggle.enabled{background:var(--success-color);border-color:var(--success-color);color:#fff}.auto-renew-toggle.enabled:hover:not(:disabled){background:#43a047;border-color:#43a047}.auto-renew-toggle:disabled{opacity:.6;cursor:not-allowed}.subscription-management{margin-bottom:var(--spacing-lg)}.subscription-management h3{margin:0 0 12px;font-size:16px;color:var(--text-dark);font-weight:600}.management-card{background:var(--bg-white);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.management-row{display:flex;justify-content:space-between;align-items:center;gap:16px}.management-info{flex:1}.management-label{display:block;font-weight:600;font-size:14px;color:var(--text-dark);margin-bottom:4px}.management-description{display:block;font-size:13px;color:var(--text-muted);line-height:1.4}.plans-section{margin-bottom:var(--spacing-lg)}.plans-section h3{margin:0 0 16px;font-size:18px;color:var(--text-dark);font-weight:600}.plan-cards{display:flex;flex-direction:column;gap:var(--spacing-md)}.plan-card{background:var(--bg-white);border:2px solid transparent;border-radius:var(--radius-lg);padding:var(--spacing-lg);cursor:pointer;transition:all .2s ease;position:relative;box-shadow:var(--shadow-sm)}.plan-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.plan-card.selected{border-color:var(--primary-color);background-color:#f0fcfb}.plan-badge{position:absolute;top:-10px;right:16px;background:var(--success-color);color:#fff;font-size:11px;font-weight:700;padding:4px 10px;border-radius:var(--radius-pill);box-shadow:0 2px 4px #4caf504d;text-transform:uppercase;letter-spacing:.5px}.plan-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.plan-name{font-weight:700;font-size:17px;color:var(--text-dark)}.plan-price{text-align:right;display:flex;align-items:baseline;gap:4px}.price-value{font-size:22px;font-weight:800;color:var(--text-dark);display:flex;align-items:center;gap:6px}.price-value.stars{color:#ffc107}.star-icon{display:flex;align-items:center;color:#ffc107}.price-period{font-size:13px;color:var(--text-muted);font-weight:500}.plan-details{font-size:14px;color:var(--text-muted)}.plan-savings{display:inline-block;background:#e8f5e9;color:var(--success-color);font-size:12px;font-weight:600;padding:4px 8px;border-radius:var(--radius);margin-top:10px}.plan-card.lifetime{background:linear-gradient(135deg,#fff8e1,#ffecb3);border-color:#ffc107}.plan-card.lifetime.selected{border-color:#ff9800;background:linear-gradient(135deg,#fff3e0,#ffe0b2)}.lifetime-badge{background:linear-gradient(135deg,#ffc107,#ff9800);box-shadow:0 2px 8px #ffc10766}.lifetime-savings{background:linear-gradient(135deg,#fff3e0,#ffe0b2);color:#e65100;font-weight:700}.checkout-section{margin-top:var(--spacing-xl)}.auto-renew-notice{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#fff9c4;border:1px solid #fbc02d;border-radius:var(--radius-lg);margin-bottom:var(--spacing-md)}.notice-icon{color:#3390ec;flex-shrink:0;display:flex;margin-top:2px}.notice-text{flex:1}.notice-text strong{display:block;font-size:15px;color:#4e342e;margin-bottom:4px;font-weight:700}.notice-text p{margin:0;font-size:14px;color:#5d4037;line-height:1.4}.checkout-btn{width:100%;padding:16px;background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-pill);font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #00c4b44d}.checkout-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 6px 16px #00c4b466}.checkout-btn:active:not(:disabled){transform:translateY(0)}.checkout-btn:disabled{background:var(--secondary-color);cursor:not-allowed;box-shadow:none;opacity:.7}.checkout-btn.loading{opacity:.8}.checkout-error{margin-top:16px;padding:12px;background:#ffebee;border-radius:var(--radius);color:var(--error-color);font-size:14px;text-align:center;border:1px solid #ffcdd2}.back-btn{display:inline-flex;align-items:center;gap:6px;margin-bottom:var(--spacing-md);padding:8px 12px;background:transparent;border:none;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;border-radius:var(--radius);transition:all .2s}.back-btn:hover{background:var(--bg-white);color:var(--primary-color)}.features-list{margin-top:var(--spacing-lg);padding:var(--spacing-lg);background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.features-list h4{margin:0 0 16px;font-size:15px;color:var(--text-dark);font-weight:600}.features-list ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:12px}.features-list li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--text-dark);line-height:1.4}.feature-icon{color:var(--primary-color);flex-shrink:0;display:flex;margin-top:1px}.payment-info{margin-top:20px;text-align:center;font-size:13px;color:var(--text-muted);line-height:1.5}@media(max-width:480px){.subscription-page{padding:12px}.plan-card{padding:16px}.price-value{font-size:20px}}.cancel-subscription-btn{padding:6px 14px;border-radius:var(--radius-pill);border:2px solid #ff4d4f;background:transparent;color:#ff4d4f;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.cancel-subscription-btn:hover{background:#fff1f0}.email-input-container{margin-bottom:20px;text-align:left}.email-label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:var(--text-color)}.email-input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:16px;transition:border-color .2s;background:var(--bg-white);color:var(--text-color);box-sizing:border-box}.email-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #00c4b41a}.email-input.error{border-color:var(--error-color)}.email-error{margin-top:6px;font-size:13px;color:var(--error-color)}.subscription-banner{display:flex;align-items:center;gap:12px;padding:10px var(--spacing-md);border-radius:var(--radius);margin:12px auto;font-size:13px;line-height:1.4;max-width:1200px;width:calc(100% - 24px);box-shadow:var(--shadow-sm);transition:all .2s ease}.subscription-banner.info{background-color:#e3f2fd;border:1px solid #bbdefb;color:#0d47a1}.subscription-banner.warning{background-color:#fff3e0;border:1px solid #ffe0b2;color:#e65100}.subscription-banner.error{background-color:#ffebee;border:1px solid #ffcdd2;color:#c62828}.banner-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#fff9;border-radius:50%}.banner-content{flex:1;min-width:0}.banner-text{margin:0;font-weight:600;font-size:14px}.banner-subtext{margin:2px 0 0;font-size:12px;opacity:.9}.banner-action{flex-shrink:0;padding:6px 16px;border-radius:var(--radius-pill);border:none;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:0 1px 2px #0000000d}.subscription-banner.info .banner-action{background-color:#1976d2;color:#fff}.subscription-banner.info .banner-action:hover{background-color:#1565c0;transform:translateY(-1px);box-shadow:0 2px 4px #1976d233}.subscription-banner.warning .banner-action{background-color:#f57c00;color:#fff}.subscription-banner.warning .banner-action:hover{background-color:#ef6c00;transform:translateY(-1px);box-shadow:0 2px 4px #f57c0033}.subscription-banner.error .banner-action{background-color:#d32f2f;color:#fff}.subscription-banner.error .banner-action:hover{background-color:#c62828;transform:translateY(-1px);box-shadow:0 2px 4px #d32f2f33}.banner-action:active{transform:translateY(0)}.subscription-banner.compact{padding:6px 10px;margin:4px 8px;font-size:12px;width:auto}.subscription-banner.compact .banner-icon{width:24px;height:24px}.subscription-banner.compact .banner-icon svg{width:14px;height:14px}.subscription-banner.compact .banner-action{padding:4px 10px;font-size:11px}@media(max-width:600px){.subscription-banner{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;gap:8px 12px;align-items:center;padding:12px}.banner-icon{grid-column:1;grid-row:1}.banner-content{grid-column:2;grid-row:1;margin-bottom:0}.banner-action{grid-column:1 / -1;grid-row:2;width:100%;margin-top:4px;padding:8px}}.sync-status-banner{position:sticky;top:0;left:0;right:0;z-index:1000;padding:12px var(--spacing-md);background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:var(--shadow-sm);animation:slideDown .3s ease-out}.sync-status-banner.offline{background:linear-gradient(135deg,#f093fb,#f5576c)}.sync-status-banner.syncing{background:linear-gradient(135deg,#4facfe,#00f2fe)}.sync-status-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:center}.sync-status-message{display:flex;align-items:center;gap:var(--spacing-sm);font-size:14px;font-weight:500}.sync-status-message.error{color:#ffebee}.sync-status-message.success{color:#e8f5e9}.sync-status-icon{font-size:18px;line-height:1}.sync-status-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.sync-retry-button{margin-left:12px;padding:6px 12px;background:#fff3;border:1px solid rgba(255,255,255,.4);border-radius:4px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.sync-retry-button:hover{background:#ffffff4d;border-color:#fff9}.sync-retry-button:active{transform:scale(.95)}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.sync-status-banner{padding:10px 12px}.sync-status-message{font-size:13px}.sync-retry-button{padding:4px 8px;font-size:12px}}.error-boundary-fallback{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--spacing-md);background:var(--bg-light);color:var(--text-dark)}.error-content{text-align:center;max-width:480px;padding:var(--spacing-xl);background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid rgba(0,0,0,.03)}.error-icon{font-size:64px;margin-bottom:var(--spacing-lg);color:var(--text-muted)}.error-content h1{font-size:24px;font-weight:700;color:var(--text-dark);margin:0 0 var(--spacing-sm)}.error-content p{font-size:16px;color:var(--text-muted);line-height:1.5;margin:0 0 var(--spacing-lg)}.error-details{text-align:left;margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--bg-light);border-radius:var(--radius);font-size:12px}.error-details summary{cursor:pointer;color:var(--text-muted);margin-bottom:var(--spacing-sm)}.error-details pre{margin:var(--spacing-sm) 0 0;padding:var(--spacing-sm);background:var(--bg-white);border-radius:var(--spacing-xs);overflow-x:auto;white-space:pre-wrap;word-break:break-word;color:var(--error-color);font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:11px;border:1px solid var(--border-color)}.error-actions{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}.error-btn{padding:12px 24px;font-size:15px;font-weight:600;border:none;border-radius:var(--radius-pill);cursor:pointer;transition:all .2s ease;font-family:inherit}.error-btn:hover{transform:translateY(-1px)}.error-btn:active{transform:translateY(0)}.error-btn.primary{background:var(--primary-color);color:#fff;box-shadow:0 4px 12px #3390ec4d}.error-btn.primary:hover{background:var(--primary-dark);box-shadow:0 6px 16px #3390ec66}.error-btn.secondary{background:transparent;color:var(--text-muted);border:1px solid var(--border-color)}.error-btn.secondary:hover{background:var(--bg-input);color:var(--text-dark);border-color:#d1d5db}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #00C4B4;--primary-dark: #009E91;--secondary-color: #6c757d;--success-color: #4caf50;--error-color: #f44336;--warning-color: #ff9800;--bg-light: #f0f2f5;--bg-white: #ffffff;--bg-input: #f5f7fa;--text-dark: #1a1d21;--text-muted: #6c757d;--border-color: #eef0f2;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 8px 24px rgba(0, 0, 0, .08);--shadow-lg: 0 16px 32px rgba(0, 0, 0, .12);--shadow-soft: 0 4px 20px rgba(0, 0, 0, .05);--radius: 12px;--radius-lg: 20px;--radius-pill: 999px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;background-color:var(--bg-light);color:var(--text-dark)}.card{background:var(--bg-white);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-soft);border:1px solid rgba(0,0,0,.03);margin-bottom:var(--spacing-md);transition:transform .2s ease,box-shadow .2s ease}input[type=text],input[type=date],input[type=number],select,textarea{background-color:var(--bg-input);border:1px solid transparent;border-radius:var(--radius);padding:12px 16px;font-size:16px;width:100%;transition:all .2s ease;color:var(--text-dark)}input:focus,select:focus,textarea:focus{outline:none;background-color:#fff;border-color:var(--primary-color);box-shadow:0 0 0 3px #3390ec26}button{cursor:pointer;font-family:inherit;transition:all .2s ease}.btn-primary{background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-pill);padding:12px 24px;font-weight:600;font-size:15px;box-shadow:0 4px 12px #3390ec4d}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 6px 16px #3390ec66}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:transparent;color:var(--text-muted);border:1px solid var(--border-color);border-radius:var(--radius-pill);padding:11px 23px;font-weight:500}.btn-secondary:hover{background:var(--bg-input);color:var(--text-dark);border-color:#d1d5db}.btn-danger{background:#ffebee;color:#d32f2f;border:1px solid #ffcdd2;border-radius:var(--radius-pill);padding:11px 23px;font-weight:500;transition:all .2s ease}.btn-danger:hover{background:#ffcdd2;color:#b71c1c;border-color:#ef9a9a;transform:translateY(-1px)}.btn-danger:active{transform:translateY(0)}#root{min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app{min-height:100vh;display:flex;flex-direction:column}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--spacing-md);color:var(--text-muted)}.spinner-large{font-size:48px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.app-header{background:var(--bg-white);color:var(--text-dark);padding:var(--spacing-md);box-shadow:var(--shadow-sm);border-bottom:1px solid var(--border-color)}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.header-title{text-align:left}.app-title{font-size:24px;font-weight:700;margin-bottom:4px;color:var(--primary-color)}.app-subtitle{font-size:14px;color:var(--text-muted);font-weight:400}.btn-settings{background:transparent;border:none;color:var(--text-muted);width:40px;height:40px;border-radius:50%;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-settings:hover{background:var(--bg-light);color:var(--primary-color);transform:rotate(30deg)}.btn-settings:active{transform:rotate(30deg) scale(.95)}.app-main{flex:1;padding:var(--spacing-md);max-width:1200px;margin:0 auto;width:100%}.patient-list{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-md)}.list-header h2{font-size:24px;color:var(--text-dark);margin:0}.search-form{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.search-input{flex:1;padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--radius);font-size:16px;transition:all .2s}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3390ec1a}.btn-search{padding:12px 20px;background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius);font-size:20px;cursor:pointer;transition:background .2s}.btn-search:hover{background:var(--primary-dark)}.patient-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-md)}.patient-card{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);cursor:pointer;transition:all .2s;box-shadow:var(--shadow-sm)}.patient-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-color)}.patient-card:active{transform:translateY(0)}.patient-card-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:var(--spacing-md);gap:var(--spacing-sm)}.patient-name{font-size:18px;font-weight:600;color:var(--text-dark);margin:0;flex:1}.consent-badge{background:var(--success-color);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.patient-card-body{display:flex;flex-direction:column;gap:var(--spacing-sm)}.patient-info{display:flex;justify-content:space-between;align-items:center;font-size:14px;gap:var(--spacing-sm)}.info-label{color:var(--text-muted);flex-shrink:0}.info-value{color:var(--text-dark);font-weight:500;text-align:right}.empty-state{text-align:center;padding:var(--spacing-xl);background:var(--bg-white);border-radius:var(--radius-lg);border:2px dashed var(--border-color)}.empty-message{color:var(--text-muted);font-size:16px;margin-bottom:var(--spacing-lg)}.loading,.error{text-align:center;padding:var(--spacing-xl)}.spinner{font-size:18px;color:var(--text-muted)}.error-message{background:#fff3f3;border:1px solid var(--error-color);border-radius:var(--radius);padding:var(--spacing-lg);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.error-icon{font-size:32px}.error-message p{color:var(--error-color);margin:0}.patient-form-container{background:var(--bg-white);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);animation:fadeIn .3s ease-in;max-width:600px;margin:0 auto}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color)}.form-header h2{font-size:22px;margin:0;color:var(--text-dark)}.btn-close{background:transparent;border:none;font-size:24px;color:var(--text-muted);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);transition:all .2s}.btn-close:hover:not(:disabled){background:var(--bg-light);color:var(--text-dark)}.btn-close:disabled{opacity:.5;cursor:not-allowed}.error-banner{background:#fff3f3;border:1px solid var(--error-color);border-radius:var(--radius);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-sm);color:var(--error-color)}.patient-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-label{font-size:14px;font-weight:600;color:var(--text-dark)}.form-label.required:after{content:" *";color:var(--error-color)}.form-input{padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--radius);font-size:16px;transition:all .2s;font-family:inherit}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3390ec1a}.form-input:disabled{background:var(--bg-light);cursor:not-allowed;opacity:.6}.form-hint{font-size:12px;color:var(--text-muted);font-style:italic}.checkbox-label{display:flex;align-items:start;gap:var(--spacing-sm);cursor:pointer;font-size:14px;color:var(--text-dark)}.form-checkbox{width:20px;height:20px;margin-top:2px;cursor:pointer;accent-color:var(--primary-color)}.form-checkbox:disabled{cursor:not-allowed;opacity:.6}.form-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;margin-top:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.btn-primary,.btn-secondary,.btn-retry{padding:12px 24px;border:none;border-radius:var(--radius);font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{background:var(--bg-light);color:var(--text-dark);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:#e9ecef;border-color:var(--secondary-color)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-retry{background:var(--error-color);color:#fff}.btn-retry:hover{background:#d32f2f}@media(max-width:768px){.app-main{padding:var(--spacing-sm)}.patient-grid{grid-template-columns:1fr}.list-header{flex-direction:column;align-items:stretch}.form-actions{flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%}}.patient-detail{animation:fadeIn .3s ease-in}.detail-header{margin-bottom:var(--spacing-lg)}.btn-back{background:transparent;border:1px solid var(--border-color);color:var(--text-dark);padding:10px 16px;border-radius:var(--radius);font-size:14px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:var(--spacing-xs)}.btn-back:hover{background:var(--bg-light);border-color:var(--primary-color);color:var(--primary-color)}.patient-card-full{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm)}.patient-detail-content{margin-top:var(--spacing-lg)}.visit-list{animation:fadeIn .3s ease-in}.visit-list .list-header h3{font-size:20px;color:var(--text-dark);margin:0}.visit-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-md)}.visit-card{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-md);cursor:pointer;transition:all .2s;box-shadow:var(--shadow-sm)}.visit-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-color)}.visit-card:active{transform:translateY(0)}.visit-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);gap:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-color)}.visit-date{font-size:16px;font-weight:600;color:var(--text-dark);margin:0}.visit-status{font-size:12px;padding:4px 8px;border-radius:var(--radius);background:var(--bg-light);color:var(--text-dark);white-space:nowrap}.visit-card-body{display:flex;flex-direction:column;gap:var(--spacing-sm)}.visit-notes{display:flex;flex-direction:column;gap:4px;font-size:14px;margin-bottom:var(--spacing-sm)}.notes-label{font-weight:600;color:var(--text-muted);font-size:12px}.notes-text{color:var(--text-dark);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.visit-info{display:flex;justify-content:space-between;align-items:center;font-size:12px;gap:var(--spacing-sm)}.tooth-map-section{margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:2px solid var(--border-color)}.tooth-map-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm);gap:var(--spacing-md);flex-wrap:wrap}.btn-mass-apply{white-space:nowrap;flex-shrink:0}.saving-indicator{background:#fff3cd;color:#856404;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius);margin-bottom:var(--spacing-md);font-size:14px;text-align:center;border:1px solid #ffeaa7}.info-message{background:#e3f2fd;color:#1976d2;padding:var(--spacing-md);border-radius:var(--radius);margin-top:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-sm);border-left:4px solid var(--primary-color)}.info-icon{font-size:20px;flex-shrink:0}.info-message p{margin:0;font-size:14px}@media(max-width:768px){.brush-picker-overlay{padding:0}.brush-picker-overlay .brush-picker{max-height:100vh;border-radius:0}.recommendation-item{flex-wrap:wrap;gap:var(--spacing-xs)}.gap-label{min-width:auto}.recommendation-details{flex-basis:100%}}
