:root{--color-primary:#0aa6b7;--color-primary-dark:#07808d;--color-primary-light:#46c7d5;--color-accent:#c9a96a;--color-accent-light:#e3cfa3;--color-bg:#eef4f5;--color-surface:#fff;--color-surface-alt:#f5f9fa;--color-text:#0f2b30;--color-text-secondary:#5b7378;--color-text-tertiary:#91a7ab;--color-text-inverse:#fff;--color-border:#d9e6e8;--color-border-focus:var(--color-primary);--color-error:#e2574c;--color-error-soft:#fdeceb;--color-success:#2fae7a;--color-btn-primary-bg:var(--color-primary);--color-btn-primary-bg-hover:var(--color-primary-dark);--color-btn-primary-text:#fff;--color-btn-secondary-bg:transparent;--color-btn-secondary-bg-hover:var(--color-hover-surface);--color-btn-secondary-text:var(--color-primary);--color-hover-surface:#0aa6b714;--shadow-soft:0 4px 14px #0f2b3014;--shadow-medium:0 12px 30px #0f2b301f;--shadow-elevated:0 24px 60px #0f2b302e;--shadow-focus:0 0 0 3px #0aa6b72e;--gradient-brand:linear-gradient(150deg, #07808d 0%, #0aa6b7 55%, #46c7d5 100%)}*{box-sizing:border-box}html,body,#root{min-height:100dvh;margin:0;padding:0}body{color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-family:system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif}h1,h2,h3,p{margin:0}a{color:var(--color-primary);text-decoration:none}button{font-family:inherit}.text-field{text-align:left;flex-direction:column;gap:.4rem;margin-bottom:1.1rem;display:flex}.text-field__label{letter-spacing:.01em;color:var(--color-text-secondary);align-items:center;gap:.4rem;font-size:.85rem;font-weight:600;display:flex}.text-field__help{background:var(--color-text-tertiary);width:1rem;height:1rem;color:var(--color-text-inverse);cursor:help;border-radius:50%;justify-content:center;align-items:center;font-size:.65rem;font-weight:700;display:inline-flex}.text-field__input{border:1px solid var(--color-border);background:var(--color-surface-alt);width:100%;color:var(--color-text);border-radius:.75rem;padding:.85rem 1rem;font-family:inherit;font-size:.95rem;transition:border-color .18s,box-shadow .18s,background .18s}.text-field__input::placeholder{color:var(--color-text-tertiary)}.text-field__input:hover{border-color:var(--color-primary-light)}.text-field__input:focus{background:var(--color-surface);border-color:var(--color-border-focus);box-shadow:var(--shadow-focus);outline:none}.text-field__input--error{border-color:var(--color-error);background:var(--color-error-soft)}.text-field__input--error:focus{box-shadow:0 0 0 3px #e2574c2e}.text-field__error{color:var(--color-error);font-size:.78rem}.field{flex-direction:column;gap:.35rem;min-width:0;display:flex}.field__label{color:var(--color-text-secondary);font-size:.82rem;font-weight:600}.field__input{border:1px solid var(--color-border);background:var(--color-surface-alt);height:2.6rem;color:var(--color-text);border-radius:.6rem;padding:0 .85rem;font-family:inherit;font-size:.9rem}.field__input:focus{background:var(--color-surface);border-color:var(--color-primary);box-shadow:var(--shadow-focus);outline:none}.field__input--error{border-color:var(--color-error);background:var(--color-error-soft)}.field__error{color:var(--color-error);font-size:.78rem}.field__hint{color:var(--color-text-secondary);font-size:.78rem}textarea.field__input{resize:vertical;box-sizing:border-box;width:100%;height:auto;min-height:4.75rem;padding:.6rem .85rem;line-height:1.4}.field-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));align-items:start;gap:.9rem 1rem;display:grid}.field--full{grid-column:1/-1}.chip-group{flex-wrap:wrap;gap:.4rem;display:flex}.chip{border:1px solid var(--color-border);background:var(--color-surface-alt);color:var(--color-text-secondary);cursor:pointer;border-radius:1rem;align-items:center;gap:.3rem;padding:.32rem .65rem;font-family:inherit;font-size:.8rem;font-weight:600;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.chip:hover{border-color:var(--color-primary);color:var(--color-text)}.chip--active{background:color-mix(in srgb, var(--color-primary) 14%, transparent);border-color:var(--color-primary);color:var(--color-primary)}.button{letter-spacing:.01em;cursor:pointer;border:1px solid #0000;border-radius:.75rem;justify-content:center;align-items:center;gap:8px;width:100%;padding:.9rem 1.2rem;font-size:.95rem;font-weight:600;transition:background .18s,box-shadow .18s,opacity .18s;display:inline-flex}.button:disabled{opacity:.6;cursor:not-allowed}.button--primary{background:var(--color-btn-primary-bg);color:var(--color-btn-primary-text);box-shadow:var(--shadow-soft)}.button--primary:hover:not(:disabled){background:var(--color-btn-primary-bg-hover);box-shadow:var(--shadow-medium)}.button--secondary{background:var(--color-btn-secondary-bg);border-color:var(--color-border);width:auto;color:var(--color-btn-secondary-text)}.button--secondary:hover:not(:disabled){background:var(--color-btn-secondary-bg-hover)}.tooltip{display:inline-flex;position:relative}.tooltip__bubble{z-index:50;background:var(--color-text);width:max-content;max-width:220px;color:var(--color-text-inverse);box-shadow:var(--shadow-medium);pointer-events:none;border-radius:.5rem;padding:.45rem .6rem;font-size:.75rem;font-weight:500;line-height:1.35;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}.login-page{background:radial-gradient(circle at 15% 15%, #46c7d41f, transparent 45%), radial-gradient(circle at 85% 85%, #c9a96a1a, transparent 45%), var(--color-bg);justify-content:center;align-items:center;min-height:100dvh;padding:clamp(1rem,3vw,2.5rem);display:flex}.login-page__card{background:var(--color-surface);width:100%;max-width:880px;box-shadow:var(--shadow-elevated);border-radius:1.5rem;grid-template-columns:420px 1fr;display:grid;overflow:hidden}.login-page__brand{background:var(--gradient-brand);color:var(--color-text-inverse);flex-direction:column;gap:1.25rem;padding:clamp(2rem,4vw,3rem);display:flex;position:relative;overflow:hidden}.login-page__brand-bg{color:#fff;opacity:.12;pointer-events:none;width:320px;height:320px;position:absolute;bottom:-80px;right:-80px}.login-page__logo{z-index:1;letter-spacing:.02em;align-items:center;gap:.6rem;font-size:1.4rem;font-weight:700;display:flex;position:relative}.login-page__logo-icon{width:1.9rem;height:1.9rem;color:var(--color-accent-light)}.login-page__logo-tag{letter-spacing:.08em;text-transform:uppercase;background:#ffffff2e;border-radius:.5rem;margin-left:.1rem;padding:.1rem .5rem;font-size:.7rem;font-weight:700}.login-page__brand-text{z-index:1;margin-top:auto;position:relative}.login-page__tagline{font-size:clamp(1.6rem,2.5vw,2.25rem);font-weight:700;line-height:1.15}.login-page__description{color:#ffffffd9;max-width:34ch;margin-top:.85rem;font-size:.95rem;line-height:1.6}.login-page__benefits{z-index:1;flex-direction:column;gap:.7rem;margin:auto 0 0;padding:0;list-style:none;display:flex;position:relative}.login-page__benefits li{color:#ffffffeb;padding-left:1.6rem;font-size:.92rem;position:relative}.login-page__benefits li:before{content:"";background:var(--color-accent);border-radius:50%;width:.55rem;height:.55rem;position:absolute;top:.35rem;left:0;box-shadow:0 0 0 4px #c9a96a40}.login-page__panel{background:var(--color-surface);flex-direction:column;justify-content:center;padding:clamp(2rem,4vw,3rem);display:flex}.login-page__header{margin-bottom:1.5rem}.login-page__title{color:var(--color-text);font-size:clamp(1.5rem,2.2vw,1.9rem);font-weight:700}.login-page__subtitle{color:var(--color-text-secondary);margin-top:.4rem;font-size:.92rem}.login-page__form{flex-direction:column;display:flex}.login-page__fields{grid-template-columns:1fr;column-gap:1rem;display:grid}.login-page__error{background:var(--color-error-soft);color:var(--color-error);text-align:center;border-radius:.6rem;margin-bottom:1rem;padding:.65rem .85rem;font-size:.85rem}@media (width<=900px){.login-page{padding:clamp(.75rem,2vw,1.5rem)}.login-page__card{grid-template-columns:1fr;max-width:480px}.login-page__brand{text-align:center;align-items:center;gap:.75rem;padding:1.75rem 1.5rem}.login-page__brand-bg{width:200px;height:200px;bottom:-60px;right:-60px}.login-page__brand-text{margin-top:0}.login-page__tagline{font-size:1.3rem}.login-page__tagline br,.login-page__description,.login-page__benefits{display:none}}.layout{flex-direction:column;height:100dvh;display:flex;overflow:hidden}.layout__overlay{z-index:40;opacity:0;pointer-events:none;background:#0f2b3073;transition:opacity .3s;position:fixed;inset:0}.layout__mobile-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);align-items:center;gap:.75rem;padding:.7rem 1rem;display:none}.layout__hamburger{color:var(--color-text);cursor:pointer;background:0 0;border:none;border-radius:.5rem;justify-content:center;align-items:center;padding:.4rem;display:inline-flex}.layout__mobile-logo{color:var(--color-primary);align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700;display:flex}.layout__mobile-logo-icon{width:1.4rem;height:1.4rem}.layout__content{box-sizing:border-box;flex-direction:column;flex:1;min-height:0;margin-left:264px;padding:clamp(1.25rem,2.5vw,2rem);display:flex;overflow:auto}.sidebar{z-index:50;background:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;width:264px;height:100dvh;padding:1.25rem .9rem;display:flex;position:fixed;top:0;left:0}.sidebar__logo{color:var(--color-primary);align-items:center;gap:.6rem;padding:.5rem .6rem 1.25rem;font-size:1.25rem;font-weight:700;display:flex}.sidebar__logo-icon{width:1.8rem;height:1.8rem}.sidebar__logo-tag{background:color-mix(in srgb, var(--color-primary) 14%, transparent);color:var(--color-primary);letter-spacing:.08em;text-transform:uppercase;border-radius:.45rem;padding:.1rem .45rem;font-size:.62rem;font-weight:700}.sidebar__nav{flex-direction:column;flex:1;gap:.2rem;display:flex;overflow-y:auto}.sidebar__item{width:100%;color:var(--color-text-secondary);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:.7rem;align-items:center;gap:.75rem;padding:.7rem .8rem;font-size:.92rem;font-weight:600;transition:background .18s,color .18s;display:flex}.sidebar__item:hover{background:var(--color-surface-alt);color:var(--color-text)}.sidebar__item--active{background:color-mix(in srgb, var(--color-primary) 12%, transparent);color:var(--color-primary)}.sidebar__item--logout{color:var(--color-error)}.sidebar__item--logout:hover{background:var(--color-error-soft);color:var(--color-error)}.sidebar__item-icon{flex-shrink:0}.sidebar__footer{border-top:1px solid var(--color-border);flex-direction:column;gap:.2rem;margin-top:.75rem;padding-top:.75rem;display:flex}.sidebar__user{color:var(--color-text-tertiary);padding:.2rem .6rem .7rem;font-size:.78rem}@media (width<=1024px){.layout__mobile-header{z-index:30;display:flex;position:sticky;top:0}.layout__content{margin-left:0}.layout__overlay--visible{opacity:1;pointer-events:auto}.sidebar{box-shadow:var(--shadow-elevated);transition:transform .3s;transform:translate(-100%)}.sidebar--open{transform:translate(0)}}.loader-overlay{z-index:2000;background:color-mix(in srgb, var(--color-bg) 82%, transparent);flex-direction:column;justify-content:center;align-items:center;animation:.2s loader-fade;display:flex;position:fixed;inset:0}.tooth-loader{flex-direction:column;align-items:center;gap:1rem;display:flex}.tooth-loader__bg{fill:var(--color-border)}.tooth-loader__fill{fill:var(--color-primary);animation:1.6s ease-in-out infinite tooth-fill;transform:translateY(24px)}.tooth-loader__text{letter-spacing:.02em;color:var(--color-text-secondary);font-size:.9rem;font-weight:600}@keyframes tooth-fill{0%,to{transform:translateY(24px)}50%{transform:translateY(0)}}@keyframes loader-fade{0%{opacity:0}to{opacity:1}}.page{flex-direction:column;flex:1;gap:1.25rem;min-height:0;display:flex}.page__header{flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:flex-end;gap:1rem;display:flex}.page__title{color:var(--color-text);font-size:clamp(1.5rem,2.5vw,2rem);font-weight:700}.page__subtitle{color:var(--color-text-secondary);margin-top:.25rem;font-size:.9rem}.page__head-actions{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.page__new{background:var(--color-primary);color:#fff;cursor:pointer;box-shadow:var(--shadow-soft);border:none;border-radius:.75rem;align-items:center;gap:.45rem;padding:.7rem 1.1rem;font-size:.9rem;font-weight:600;transition:background .18s,box-shadow .18s;display:inline-flex}.page__new:hover{background:var(--color-primary-dark);box-shadow:var(--shadow-medium)}.page__ghost{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-primary);cursor:pointer;border-radius:.75rem;align-items:center;gap:.45rem;padding:.7rem 1.1rem;font-size:.9rem;font-weight:600;transition:background .18s,border-color .18s;display:inline-flex}.page__ghost:hover{background:var(--color-hover-surface);border-color:var(--color-primary)}.page__filters{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:.6rem;display:flex}.filter{height:2.5rem;color:var(--color-text);font-family:inherit;font-size:.88rem}.filter--search{flex:1;align-items:center;min-width:200px;display:inline-flex;position:relative}.filter--search input{border:1px solid var(--color-border);background:var(--color-surface);width:100%;height:2.5rem;color:var(--color-text);border-radius:.7rem;padding:0 .9rem 0 2.3rem;font-family:inherit;font-size:.88rem}.filter--search input:focus{border-color:var(--color-primary);box-shadow:var(--shadow-focus);outline:none}.filter__icon{color:var(--color-text-tertiary);pointer-events:none;position:absolute;left:.8rem}.filter__control{border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;border-radius:.7rem;padding:0 .85rem}.filter__control:focus{border-color:var(--color-primary);box-shadow:var(--shadow-focus);outline:none}.table-card{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-soft);border-radius:1rem;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.table-scroll{flex:1;min-height:0;overflow:auto}.data-table{border-collapse:separate;border-spacing:0;width:100%}.data-table th{z-index:1;background:var(--color-surface);text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-tertiary);box-shadow:inset 0 -1px 0 var(--color-border);white-space:nowrap;padding:.85rem 1.1rem;font-size:.7rem;font-weight:700;position:sticky;top:0}.data-table td{color:var(--color-text);border-bottom:1px solid color-mix(in srgb, var(--color-border) 60%, transparent);white-space:nowrap;vertical-align:middle;padding:.85rem 1.1rem;font-size:.88rem}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background .15s}.data-table tbody tr:hover{background:color-mix(in srgb, var(--color-primary) 5%, transparent)}.data-table__empty{text-align:center;color:var(--color-text-secondary);padding:2.5rem 1rem}.data-table th:last-child,.data-table td:last-child{text-align:right;width:1%;padding-right:.9rem}.cell-name{align-items:center;gap:.6rem;font-weight:600;display:inline-flex}.cell-name__avatar{background:color-mix(in srgb, var(--color-primary) 14%, transparent);width:2rem;height:2rem;color:var(--color-primary);border-radius:.55rem;justify-content:center;align-items:center;display:inline-flex}.cell-code{background:var(--color-surface-alt);border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:.4rem;padding:.15rem .5rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.78rem;display:inline-block}.cell-money{font-variant-numeric:tabular-nums;font-weight:600}.badge{border-radius:1rem;padding:.25rem .7rem;font-size:.74rem;font-weight:600;display:inline-block}.badge--on{background:color-mix(in srgb, var(--color-success) 16%, transparent);color:var(--color-success)}.badge--off{background:color-mix(in srgb, var(--color-error) 14%, transparent);color:var(--color-error)}.badge--accent{background:color-mix(in srgb, var(--color-accent) 22%, transparent);color:var(--color-accent)}.badge--primary{background:color-mix(in srgb, var(--color-primary) 14%, transparent);color:var(--color-primary)}.pagination{border-top:1px solid color-mix(in srgb, var(--color-border) 60%, transparent);background:var(--color-surface);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:.55rem 1rem;display:flex}.pagination__info{color:var(--color-text-tertiary);font-size:.78rem}.pagination__controls{align-items:center;gap:.1rem;display:flex}.pagination__btn,.pagination__page{min-width:2rem;height:2rem;color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:.5rem;justify-content:center;align-items:center;padding:0 .5rem;font-family:inherit;font-size:.82rem;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.pagination__btn:hover:not(:disabled):not(.pagination__page--active),.pagination__page:hover:not(:disabled):not(.pagination__page--active){background:color-mix(in srgb, var(--color-primary) 8%, transparent);color:var(--color-primary)}.pagination__btn:disabled,.pagination__page:disabled{opacity:.35;cursor:not-allowed}.pagination__page--active{background:var(--color-primary);color:var(--color-btn-primary-text);cursor:default;font-weight:600}.pagination__ellipsis{min-width:1.5rem;color:var(--color-text-tertiary);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-weight:600;display:inline-flex}@media (width<=720px){.page__filters{flex-direction:column;align-items:stretch}.filter,.filter--search,.filter__control{width:100%}}.row-menu__trigger{width:2rem;height:2rem;color:var(--color-text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:.5rem;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.row-menu__trigger:hover,.row-menu__trigger[aria-expanded=true]{background:color-mix(in srgb, var(--color-primary) 8%, transparent);color:var(--color-primary)}.row-menu__pop{z-index:1700;background:var(--color-surface);border:1px solid color-mix(in srgb, var(--color-border) 80%, transparent);border-radius:.85rem;flex-direction:column;gap:.1rem;min-width:200px;padding:.35rem;animation:.18s cubic-bezier(.2,.8,.3,1) both row-menu-in;display:flex;position:fixed;box-shadow:0 12px 32px #0f2b301f,0 2px 6px #0f2b300a}.row-menu__item{color:var(--color-text);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:.55rem;align-items:center;gap:.65rem;padding:.55rem .7rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:background .12s,color .12s;display:inline-flex}.row-menu__item svg{color:var(--color-text-tertiary);transition:color .12s}.row-menu__item:hover{background:color-mix(in srgb, var(--color-primary) 8%, transparent);color:var(--color-primary)}.row-menu__item:hover svg{color:var(--color-primary)}.row-menu__item--danger,.row-menu__item--danger svg{color:var(--color-error)}.row-menu__item--danger:hover{background:var(--color-error-soft);color:var(--color-error)}.row-menu__item--danger:hover svg{color:var(--color-error)}@keyframes row-menu-in{0%{opacity:0;transform:translateY(-6px)scale(.97)}to{opacity:1;transform:none}}.appt-modal__header{background:var(--color-surface);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:1rem;padding:1.1rem clamp(1rem,3vw,1.75rem);display:flex}.appt-modal__title{color:var(--color-text);font-size:1.25rem;font-weight:700}.appt-modal__subtitle{color:var(--color-text-secondary);margin-top:.15rem;font-size:.85rem}.appt-modal__close{background:var(--color-surface-alt);width:2.4rem;height:2.4rem;color:var(--color-text-secondary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .18s,color .18s,transform .18s;display:inline-flex}.appt-modal__close:hover{color:var(--color-text);transform:rotate(90deg)}.appt-modal__body{flex:1;padding:clamp(1rem,3vw,1.75rem);overflow-y:auto}.appt-modal__section-title{color:var(--color-text);margin-bottom:1rem;font-size:1rem;font-weight:700}.appt-modal__footer{background:var(--color-surface);border-top:1px solid var(--color-border);justify-content:flex-end;gap:.75rem;padding:1rem clamp(1rem,3vw,1.75rem);display:flex}.appt-modal__cancel{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;border-radius:.7rem;padding:.7rem 1.2rem;font-size:.9rem;font-weight:600}.appt-modal__cancel:hover{background:var(--color-surface-alt);color:var(--color-text)}.appt-modal__save{background:var(--color-primary);color:#fff;cursor:pointer;box-shadow:var(--shadow-soft);border:none;border-radius:.7rem;padding:.7rem 1.4rem;font-size:.9rem;font-weight:600;transition:background .18s,box-shadow .18s,opacity .18s}.appt-modal__save:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--shadow-medium)}.appt-modal__save:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{z-index:2000;background:#0f2b3073;justify-content:center;align-items:center;padding:clamp(.5rem,3vw,2rem);display:flex;position:fixed;inset:0}.modal-overlay--open{animation:.2s both modal-overlay-in}.modal-overlay--open .modal-card{animation:.24s cubic-bezier(.2,.8,.3,1) both modal-card-in}.modal-overlay--closing{animation:.18s both modal-overlay-out}.modal-overlay--closing .modal-card{animation:.18s both modal-card-out}.modal-card{background:var(--color-surface);width:min(720px,100%);max-height:92vh;box-shadow:var(--shadow-elevated);border-radius:1.25rem;flex-direction:column;display:flex;overflow:hidden}.modal-card--sm{width:min(480px,100%)}.modal-card--md{width:min(720px,100%)}.modal-card--lg{width:min(1000px,100%)}@keyframes modal-overlay-in{0%{opacity:0}to{opacity:1}}@keyframes modal-overlay-out{0%{opacity:1}to{opacity:0}}@keyframes modal-card-in{0%{opacity:0;transform:translateY(12px)scale(.99)}to{opacity:1;transform:none}}@keyframes modal-card-out{0%{opacity:1;transform:none}to{opacity:0;transform:translateY(12px)scale(.99)}}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;display:grid}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-soft);border-radius:1rem;align-items:center;gap:1rem;padding:1.25rem;display:flex}.stat-card__icon{background:color-mix(in srgb, var(--color-primary) 12%, transparent);width:3rem;height:3rem;color:var(--color-primary);border-radius:.85rem;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.stat-card__value{color:var(--color-text);font-size:1.6rem;font-weight:800;line-height:1.1}.stat-card__label{color:var(--color-text-secondary);font-size:.85rem}.welcome-card{background:var(--gradient-brand);color:var(--color-text-inverse);box-shadow:var(--shadow-medium);border-radius:1.25rem;padding:clamp(1.5rem,3vw,2.25rem)}.welcome-card__title{font-size:clamp(1.4rem,2.4vw,1.9rem);font-weight:800}.welcome-card__text{color:#ffffffe6;max-width:60ch;margin-top:.5rem;font-size:.95rem;line-height:1.6}.plan-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.plan-card{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-soft);border-radius:1.25rem;flex-direction:column;gap:.9rem;padding:1.5rem;transition:box-shadow .18s,border-color .18s,transform .18s;display:flex;position:relative}.plan-card:hover{box-shadow:var(--shadow-medium);transform:translateY(-2px)}.plan-card--featured{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary), var(--shadow-medium)}.plan-card--inactive{opacity:.6}.plan-card__ribbon{background:color-mix(in srgb, var(--color-accent) 22%, transparent);color:var(--color-accent);border-radius:1rem;align-items:center;gap:.3rem;padding:.2rem .6rem;font-size:.72rem;font-weight:700;display:inline-flex;position:absolute;top:1rem;right:1rem}.plan-card__head{flex-direction:column;gap:.25rem;display:flex}.plan-card__name{color:var(--color-text);font-size:1.2rem;font-weight:800}.plan-card__desc{color:var(--color-text-secondary);min-height:2.4em;font-size:.85rem}.plan-card__price{align-items:baseline;gap:.35rem;display:flex}.plan-card__amount{color:var(--color-primary);font-variant-numeric:tabular-nums;font-size:1.8rem;font-weight:800}.plan-card__period{color:var(--color-text-tertiary);font-size:.85rem}.plan-card__meta{color:var(--color-text-secondary);flex-wrap:wrap;gap:.5rem;font-size:.78rem;display:flex}.plan-card__modules{border-top:1px solid var(--color-border);flex-direction:column;gap:.45rem;margin:0;padding:.5rem 0 0;list-style:none;display:flex}.plan-card__module{color:var(--color-text);align-items:center;gap:.5rem;font-size:.85rem;display:flex}.plan-card__module svg{color:var(--color-success);flex-shrink:0}.plan-card__module-empty{color:var(--color-text-tertiary);font-size:.82rem;font-style:italic}.plan-card__actions{gap:.5rem;margin-top:auto;padding-top:.5rem;display:flex}.plan-card__btn{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-primary);cursor:pointer;border-radius:.7rem;flex:1;justify-content:center;align-items:center;gap:.4rem;padding:.6rem .8rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:background .15s,border-color .15s;display:inline-flex}.plan-card__btn:hover{background:var(--color-hover-surface);border-color:var(--color-primary)}.plan-card__btn--danger{color:var(--color-error)}.plan-card__btn--danger:hover{background:var(--color-error-soft);border-color:var(--color-error)}.module-picker{border:1px solid var(--color-border);background:var(--color-surface-alt);border-radius:.85rem;flex-direction:column;gap:.5rem;max-height:320px;padding:.25rem;display:flex;overflow-y:auto}.module-option{border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;border-radius:.7rem;align-items:center;gap:.75rem;padding:.65rem .8rem;transition:border-color .15s,background .15s;display:flex}.module-option:hover{border-color:var(--color-primary-light)}.module-option--selected{border-color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 7%, var(--color-surface))}.module-option__check{border:1.5px solid var(--color-border);color:#fff;border-radius:.45rem;flex-shrink:0;justify-content:center;align-items:center;width:1.4rem;height:1.4rem;transition:background .15s,border-color .15s;display:inline-flex}.module-option--selected .module-option__check{background:var(--color-primary);border-color:var(--color-primary)}.module-option__info{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.module-option__name{color:var(--color-text);font-size:.9rem;font-weight:600}.module-option__meta{color:var(--color-text-secondary);font-size:.78rem}.module-option__price{color:var(--color-text-secondary);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:.85rem;font-weight:600}.price-summary{background:color-mix(in srgb, var(--color-primary) 8%, transparent);border-radius:.7rem;justify-content:space-between;align-items:baseline;margin-top:.5rem;padding:.75rem .9rem;display:flex}.price-summary__label{color:var(--color-text-secondary);font-size:.85rem}.price-summary__value{color:var(--color-primary);font-variant-numeric:tabular-nums;font-size:1.15rem;font-weight:800}
