.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:10px 20px;border:1px solid transparent;border-radius:var(--radius-pill);font-size:.95rem;font-weight:600;cursor:pointer;transition:background-color var(--transition),border-color var(--transition),transform var(--transition),box-shadow var(--transition)}.btn:active{transform:translateY(1px)}.btn:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--block{width:100%}.btn--primary{background-color:var(--color-primary);color:var(--color-on-primary);box-shadow:var(--shadow-sm)}.btn--primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn--primary:active:not(:disabled){background-color:var(--color-primary-active)}.btn--danger{background-color:var(--color-danger);color:#fff}.btn--danger:hover:not(:disabled){background-color:#a5322a}.btn--ghost{background-color:transparent;color:var(--color-text);border-color:var(--color-border)}.btn--ghost:hover:not(:disabled){background-color:var(--color-bg-soft)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay);display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:1000;animation:modal-fade var(--transition)}.modal-card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;padding:var(--space-6);position:relative;animation:modal-pop var(--transition);max-height:90vh;overflow-y:auto}.modal-card--sm{max-width:400px}.modal-card--lg{max-width:720px}.modal-close{position:absolute;top:var(--space-3);right:var(--space-3);width:32px;height:32px;border:none;background:transparent;border-radius:var(--radius-pill);font-size:1.25rem;line-height:1;color:var(--color-text-muted);cursor:pointer;transition:background-color var(--transition)}.modal-close:hover{background:var(--color-bg-soft)}.modal-title{font-size:1.4rem;font-weight:700;margin-bottom:var(--space-5)}@keyframes modal-fade{0%{opacity:0}}@keyframes modal-pop{0%{opacity:0;transform:translateY(8px) scale(.98)}}@media (max-width: 640px){.modal-overlay{padding:var(--space-3);align-items:flex-start}.modal-card{padding:var(--space-5);max-height:calc(100dvh - var(--space-6));margin-top:var(--space-4)}.modal-title{font-size:1.25rem;margin-bottom:var(--space-4);padding-right:var(--space-6)}}.contact-options{display:flex;gap:var(--space-4)}.contact-opt{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);text-align:center;text-decoration:none;padding:var(--space-5) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);transition:border-color var(--transition),background-color var(--transition),transform var(--transition)}.contact-opt:hover{border-color:var(--color-primary);background:var(--color-bg-soft);transform:translateY(-2px)}.contact-icon{display:flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:var(--radius-pill);color:#fff}.contact-icon--mail{background:var(--color-text)}.contact-icon--wa{background:#25d366}.contact-label{font-weight:700;font-size:1rem}.contact-value{font-size:.8rem;color:var(--color-text-muted);word-break:break-all}.logo{font-family:var(--font-display);font-weight:800;letter-spacing:-.02em;color:var(--color-text);line-height:1;-webkit-user-select:none;user-select:none}.logo-accent{color:var(--color-primary)}.logo--sm{font-size:1.1rem}.logo--md{font-size:1.5rem}.logo--lg{font-size:clamp(3.5rem,14vw,9rem)}.tcard{flex:0 0 auto;width:420px;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5);cursor:pointer;transition:transform var(--transition),border-color var(--transition)}.tcard:hover{transform:scale(1.03);border-color:var(--color-primary)}.tcard-title{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.15}.tcard-thumb{flex:1;display:flex;align-items:center;justify-content:center;background:var(--color-bg-soft);border-radius:var(--radius-md);color:var(--color-primary);min-height:180px}.tcard-thumb svg{width:72px;height:72px}.tcard-thumb{overflow:hidden}.tcard-thumb-img{width:100%;height:100%;object-fit:cover}.tcard-info{display:flex;flex-direction:column;gap:var(--space-3);font-size:.9rem;color:var(--color-text-muted)}.tcard-dates{margin:0}.tcard-dates strong{color:var(--color-text)}.tcard-cats{display:flex;flex-direction:column;gap:2px}.tcard-cat{margin:0;font-size:.85rem;line-height:1.35}.tcard-cat-name{font-weight:700;color:var(--color-text)}.tcard-footer{display:flex;align-items:baseline;justify-content:space-between;border-top:1px solid var(--color-border);padding-top:var(--space-4)}.tcard-pairs-label{font-size:.85rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.tcard-pairs-count{font-size:1.25rem;font-weight:700;color:var(--color-text)}.tcard--create{flex:0 0 auto;width:380px;border:2px dashed var(--color-border);box-shadow:none;background:transparent;align-items:center;justify-content:center;gap:var(--space-4);color:var(--color-text-muted);cursor:pointer;transition:transform var(--transition),border-color var(--transition),color var(--transition)}.tcard--create:hover{transform:none;border-color:var(--color-primary);color:var(--color-text)}.tcard-create-plus{width:88px;height:88px;border-radius:var(--radius-pill);background:var(--color-primary);color:var(--color-on-primary);display:flex;align-items:center;justify-content:center;font-size:2.75rem;font-weight:700;line-height:1}.tcard-create-label{font-family:var(--font-display);font-size:1.35rem;font-weight:600}@media (max-width: 640px){.tcard{width:min(420px,85vw);padding:var(--space-5);gap:var(--space-4)}.tcard:hover{transform:none}.tcard-thumb{min-height:140px}.tcard--create{width:100%;min-height:0;padding:var(--space-5);flex-direction:row;gap:var(--space-4)}.tcard-create-plus{width:56px;height:56px;font-size:1.9rem}}.weekday-picker{display:flex;gap:var(--space-2);flex-wrap:wrap}.weekday{min-width:44px;padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);color:var(--color-text-muted);font-size:.85rem;font-weight:600;cursor:pointer;transition:background-color var(--transition),color var(--transition),border-color var(--transition)}.weekday:hover{border-color:var(--color-primary)}.weekday--on{background:var(--color-primary);color:var(--color-on-primary);border-color:var(--color-primary)}.ct{gap:var(--space-5)}.ct-warn{margin:0 0 var(--space-4);padding:var(--space-3) var(--space-4);background:var(--color-bg-soft);border-left:3px solid var(--color-primary);border-radius:var(--radius-sm);font-size:.85rem;color:var(--color-text-muted)}.ct-section{display:flex;flex-direction:column;gap:var(--space-3);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.ct-section--last{border-bottom:none;padding-bottom:0}.ct-section-head{display:flex;align-items:center;justify-content:space-between}.ct-image-drop{display:flex;align-items:center;justify-content:center;width:160px;height:110px;border:2px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);font-weight:600;font-size:.9rem;cursor:pointer;transition:border-color var(--transition),color var(--transition)}.ct-image-drop:hover{border-color:var(--color-primary);color:var(--color-text)}.ct-image-preview{position:relative;width:160px;height:110px}.ct-image-preview img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-md)}.ct-image-preview .ct-remove{position:absolute;top:4px;right:4px;background:var(--color-surface);box-shadow:var(--shadow-sm)}.ct-section-title{font-size:1.05rem;font-weight:700;color:var(--color-text)}.ct-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.ct-grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-3)}.ct-row{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);background:var(--color-bg-soft);border-radius:var(--radius-md)}.ct-row-head{display:flex;align-items:center;gap:var(--space-3)}.ct-row-title-input{flex:1;padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.95rem;font-weight:600;background:var(--color-surface);color:var(--color-text)}.ct-subhead{display:flex;align-items:center;justify-content:space-between;font-size:.8rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.ct-inline{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.ct-inline input[type=date],.ct-inline input[type=time],.ct-inline input[type=text]{padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;background:var(--color-surface);color:var(--color-text)}.ct-code{min-width:150px}.ct-dash{color:var(--color-text-muted)}.ct-mini{display:flex;flex-direction:column;justify-content:flex-end;gap:var(--space-1);font-size:.78rem;font-weight:600;color:var(--color-text-muted);min-width:0}.ct-mini input{width:100%;min-width:0;padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;background:var(--color-surface);color:var(--color-text)}.ct-check{display:flex;align-items:center;gap:var(--space-2);font-size:.875rem;color:var(--color-text-muted);cursor:pointer}.ct-add{border:1px solid var(--color-primary);background:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-pill);padding:6px 14px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background-color var(--transition)}.ct-add:hover{background:var(--color-primary-hover)}.ct-add--sm{padding:4px 10px;font-size:.78rem}.ct-remove{flex:0 0 auto;width:28px;height:28px;border:none;background:transparent;color:var(--color-text-muted);font-size:1.2rem;line-height:1;border-radius:var(--radius-pill);cursor:pointer;transition:background-color var(--transition),color var(--transition)}.ct-remove:hover{background:var(--color-surface);color:var(--color-danger)}.ct-empty{font-size:.875rem;color:var(--color-text-muted);font-style:italic;margin:0}@media (max-width: 640px){.ct-grid-4{grid-template-columns:1fr 1fr}.ct-image-drop,.ct-image-preview{width:100%}.ct-code{min-width:0;flex:1}.ct-inline input[type=date],.ct-inline input[type=time],.ct-inline input[type=text]{flex:1;min-width:0}}@media (max-width: 420px){.ct-grid-2{grid-template-columns:1fr}}.upgrade{display:flex;flex-direction:column;gap:var(--space-4)}.upgrade-msg{margin:0;color:var(--color-text);line-height:1.5}.upgrade-plans{display:flex;gap:var(--space-3)}.upgrade-plan{flex:1;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);background:var(--color-surface);text-align:center}.upgrade-plan-price{font-family:var(--font-display);font-size:1.6rem;font-weight:700}.upgrade-plan-unit{font-size:.9rem;font-weight:600;color:var(--color-text-muted);margin-left:2px}.upgrade-plan-desc{margin-top:var(--space-2);font-size:.85rem;color:var(--color-text-muted);line-height:1.4}.upgrade-cta{margin:0;font-weight:600}.upgrade-contact{display:flex;flex-direction:column;gap:var(--space-2)}.upgrade-contact .btn{text-decoration:none}.dashboard{height:100vh;height:100dvh;display:flex;flex-direction:column;background:var(--color-bg);overflow:hidden}.dash-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6) var(--space-3);border-bottom:2px solid var(--color-text);margin:0 var(--space-6);gap:var(--space-4);flex:0 0 auto}.dash-user{font-family:var(--font-display);font-size:1.4rem;font-weight:700;text-transform:uppercase;letter-spacing:.02em}.dash-plan-badge{margin-left:var(--space-3);padding:2px 10px;border-radius:var(--radius-pill);background:var(--color-bg-soft);border:1px solid var(--color-border);color:var(--color-text-muted);font-family:var(--font-body, inherit);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;vertical-align:middle;white-space:nowrap}.dash-logout{margin-left:var(--space-4)}.dash-header-right{display:flex;align-items:center;gap:var(--space-4)}.dash-profile{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:50%;background:transparent;color:var(--color-text-muted);cursor:pointer;padding:0;transition:color var(--transition),background var(--transition)}.dash-profile:hover{color:var(--color-text);background:var(--color-surface)}.dash-body{flex:1;display:flex;align-items:stretch;gap:var(--space-3);padding:0 var(--space-5);min-height:0}.dash-create-slot{flex:0 0 auto;display:flex;align-items:stretch;padding:var(--space-5) 0 40px}.dash-scroller{flex:1;display:flex;min-width:0}.dash-track{display:flex;gap:var(--space-5);overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;padding:var(--space-5) var(--space-4) 40px;flex:1;scrollbar-width:thin;align-items:stretch}.dash-arrow{flex:0 0 auto;align-self:center;width:24px;border:none;background:transparent;color:var(--color-text-muted);font-size:1.8rem;line-height:1;cursor:pointer;padding:0;transition:color var(--transition)}.dash-arrow:hover{color:var(--color-text)}.dash-state{flex:1;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted)}@media (max-width: 640px){.dash-header{margin:0 var(--space-4);padding:var(--space-3) var(--space-2) var(--space-3);gap:var(--space-2)}.dash-user{font-size:1.1rem;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-header-right{gap:var(--space-2);flex:0 0 auto}.dash-logout{margin-left:0}.dash-body{flex-direction:column;padding:0 var(--space-3);gap:0}.dash-arrow{display:none}.dash-track{padding:var(--space-4) 0 var(--space-5);gap:var(--space-4)}.dash-create-slot{padding:0 0 var(--space-4)}}.home{position:relative;height:100vh;height:100dvh;overflow:hidden;background:var(--color-bg)}.home-header{position:fixed;top:0;right:0;padding:var(--space-4) var(--space-6);z-index:10}.home-stage{height:300vh;height:300dvh;transition:transform 1.3s cubic-bezier(.65,0,.35,1)}.home-hero{height:100vh;height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:relative}.home-title{font-size:clamp(3.5rem,14vw,9rem);font-weight:800;letter-spacing:-.03em;line-height:1;color:var(--color-text)}.home-title .accent{color:var(--color-primary);display:inline-block}.accent--hidden{visibility:hidden}.home-ball{position:fixed;z-index:50;font-family:var(--font-display);font-weight:800;line-height:1;letter-spacing:-.03em;color:var(--color-primary);animation:ball-fall 1.4s .45s forwards}.home-ball-spin{display:inline-block;animation:ball-spin 1.65s .2s linear forwards}@keyframes ball-fall{0%{transform:translateY(0);animation-timing-function:cubic-bezier(.45,0,1,1)}42%{transform:translateY(var(--fall));animation-timing-function:cubic-bezier(0,.5,.4,1)}56%{transform:translateY(calc(var(--fall) - 24vh));animation-timing-function:cubic-bezier(.45,0,1,1)}68%{transform:translateY(var(--fall));animation-timing-function:cubic-bezier(0,.5,.4,1)}79%{transform:translateY(calc(var(--fall) - 12vh));animation-timing-function:cubic-bezier(.45,0,1,1)}to{transform:translateY(calc(var(--fall) + 30vh))}}@keyframes ball-spin{0%{transform:rotate(0)}to{transform:rotate(450deg)}}.home-scroll{position:absolute;bottom:var(--space-8);font-size:2.5rem;line-height:1;color:var(--color-text-muted);animation:home-bounce 1.8s ease-in-out infinite}@keyframes home-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(10px)}}.home-intro{height:100vh;height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:relative;padding:var(--space-6)}.home-intro-cols{display:flex;width:100%}.home-intro-half{flex:1 1 0;display:flex;justify-content:center;padding:0 var(--space-3);transform:translateY(11vh)}.home-intro-block{max-width:640px;text-align:left}.home-intro-title{font-size:clamp(2rem,6vw,3.5rem);font-weight:800;letter-spacing:-.02em;line-height:1.1;color:var(--color-text);min-height:2.2em}.home-intro-text{margin-top:var(--space-5);font-size:clamp(1rem,2.4vw,1.35rem);font-weight:500;line-height:1.6;color:var(--color-text-muted)}.home-intro-kicker{margin-top:var(--space-2);font-family:var(--font-display);font-size:clamp(.72rem,1.2vw,.85rem);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary-active)}.intro-anim{position:relative;width:100%;max-width:640px;aspect-ratio:16 / 9;margin:var(--space-5) 0 0;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);overflow:hidden}.rd{position:absolute;top:0;right:0;bottom:0;left:0}.rd-grid{position:absolute;top:14%;right:9%;bottom:14%;left:9%;display:flex;align-items:center;gap:8px;transition:opacity .35s ease}.rd-grid.is-hidden{opacity:0}.rd-card{flex:1;align-self:stretch;display:flex;flex-direction:column;gap:5px;padding:6px;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:7px;transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease}.rd-card.is-selected{border-color:var(--color-primary);transform:scale(1.06);box-shadow:var(--shadow-md)}.rd-card-thumb{flex:1;min-height:26px;border-radius:4px;background:var(--color-bg-soft)}.rd-card-bar{height:5px;border-radius:3px;background:var(--color-text-muted)}.rd-card-bar--title{background:var(--color-text);width:80%}.rd-card-bar--short{width:55%}.rd-detail{position:absolute;top:12%;right:12%;bottom:12%;left:12%;display:flex;flex-direction:column;gap:7px;padding:10px;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:8px;box-shadow:var(--shadow-sm);animation:rd-pop .35s ease both}.rd-detail-head{height:7px;width:60%;border-radius:4px;background:var(--color-primary)}.rd-cats{flex:1;display:flex;flex-direction:column;justify-content:center;gap:8px}.rd-cat{display:flex;flex-direction:column;gap:4px;opacity:0;transform:translate(-6px);animation:rd-row-in .4s ease forwards}.rd-cat:nth-child(1){animation-delay:.2s}.rd-cat:nth-child(2){animation-delay:.55s}.rd-cat-label{height:6px;width:42%;border-radius:3px;background:var(--color-text)}.rd-table{display:flex;flex-direction:column;gap:3px;padding-left:8px}.rd-trow{display:flex;gap:5px}.rd-trow i{height:5px;border-radius:3px;background:var(--color-text-muted)}.rd-trow i:nth-child(1){flex:3}.rd-trow i:nth-child(2){flex:1.3;background:var(--color-border)}.rd-config{align-self:flex-end;display:flex;align-items:center;gap:5px;padding:5px 9px;border-radius:var(--radius-pill);background:var(--color-primary);transition:transform .15s ease,background .15s ease}.rd-config.is-press{transform:scale(.9);background:var(--color-primary-active)}.rd-config-gear{width:9px;height:9px;border-radius:50%;border:2px solid var(--color-on-primary)}.rd-config-label{width:30px;height:5px;border-radius:3px;background:var(--color-on-primary)}.rd-cursor{position:absolute;width:18px;height:18px;z-index:5;pointer-events:none;transition:left .55s cubic-bezier(.5,0,.3,1),top .55s cubic-bezier(.5,0,.3,1);filter:drop-shadow(0 1px 1px rgba(28,31,26,.25))}.rd-cursor svg{width:100%;height:100%;display:block}.rd-cursor.is-click{animation:rd-click .4s ease}@keyframes rd-click{0%,to{transform:scale(1)}50%{transform:scale(.68)}}@keyframes rd-pop{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}@keyframes rd-row-in{to{opacity:1;transform:translate(0)}}.sd{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.sd-dl{display:flex;flex-direction:column;align-items:center;gap:7px;padding:14px 26px;border:2px dashed var(--color-border);border-radius:var(--radius-md);animation:rd-pop .3s ease both;transition:transform .15s ease,border-color .15s ease,background .15s ease}.sd-dl.is-press{transform:scale(.94);border-color:var(--color-primary);background:var(--color-bg-soft)}.sd-dl-icon{width:26px;height:26px}.sd-dl-label{width:70px;height:6px;border-radius:3px;background:var(--color-text-muted)}.sd-proc{position:absolute;top:22%;right:14%;bottom:22%;left:14%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;animation:rd-pop .3s ease both}.sd-thread{position:absolute;top:50%;left:0;right:0;height:2px;background:repeating-linear-gradient(90deg,var(--color-border) 0 6px,transparent 6px 12px)}.sd-thread-dot{position:absolute;top:50%;width:9px;height:9px;border-radius:50%;background:var(--color-primary);transform:translate(-50%,-50%);animation:sd-run 1.4s linear infinite}.sd-gears{display:flex;align-items:center;gap:2px;z-index:1}.sd-gear{display:block}.sd-gear--a{width:40px;height:40px;animation:sd-spin 2.4s linear infinite}.sd-gear--b{width:28px;height:28px;margin-top:14px;animation:sd-spin 1.8s linear infinite reverse}.sd-calc{display:flex;gap:5px;z-index:1}.sd-calc span{width:7px;height:7px;border-radius:2px;background:var(--color-text-muted);animation:sd-blink 1.2s ease-in-out infinite}.sd-calc span:nth-child(2){animation-delay:.2s}.sd-calc span:nth-child(3){animation-delay:.4s}.sd-calc span:nth-child(4){animation-delay:.6s}.sd-progress{width:70%;height:5px;border-radius:3px;background:var(--color-border);overflow:hidden;z-index:1}.sd-progress i{display:block;height:100%;border-radius:3px;background:var(--color-primary);transform-origin:left center;animation:sd-fill 2.1s ease-out forwards}.sd-file{position:relative;animation:sd-drop .5s cubic-bezier(.45,1.4,.5,1) both}.sd-file-sheet{width:52px;height:auto;display:block}.sd-file-badge{position:absolute;right:-8px;bottom:-6px;width:22px;height:22px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.sd-file-badge svg{width:14px;height:14px}.sd-cursor{position:absolute;left:50%;top:50%;width:18px;height:18px;z-index:5;pointer-events:none;filter:drop-shadow(0 1px 1px rgba(28,31,26,.25));transition:left .5s ease,top .5s ease,opacity .3s ease}.sd-cursor svg{width:100%;height:100%;display:block}.sd-cursor.is-away{opacity:0}.sd-cursor.is-click{animation:rd-click .4s ease}@keyframes sd-spin{to{transform:rotate(360deg)}}@keyframes sd-run{0%{left:4%}to{left:96%}}@keyframes sd-blink{0%,to{opacity:.3;background:var(--color-text-muted)}50%{opacity:1;background:var(--color-primary)}}@keyframes sd-fill{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes sd-drop{0%{opacity:0;transform:translateY(-16px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@media (prefers-reduced-motion: reduce){.rd-cat,.rd-cursor,.rd-detail,.sd-cursor,.sd-gear,.sd-thread-dot,.sd-calc span,.sd-progress i,.sd-file{animation:none}.rd-cat{opacity:1;transform:none}.sd-progress i{transform:scaleX(1)}}.home-court{height:100vh;height:100dvh;position:relative}.court-line{position:absolute;background:var(--color-text);border-radius:2px}.court-line-h{left:0;width:100%;height:42px;transform:scaleX(0);transform-origin:left center;transition:transform 1.2s ease .55s}.court-line-v{left:50%;width:42px;transform:translate(-50%) scaleY(0);transform-origin:center top;transition:transform 1.2s ease .55s}.home-intro .court-line-h{top:22%}.home-intro .court-line-v{top:17%;height:85%}.home-court .court-line-h{top:82%}.home-court .court-line-v{top:0;height:91%}.home-stage.at-intro .home-intro .court-line-h{transform:scaleX(1)}.home-stage.at-intro .home-intro .court-line-v{transform:translate(-50%) scaleY(1)}.home-stage.at-court .home-court .court-line-h{transform:scaleX(1)}.home-stage.at-court .home-court .court-line-v{transform:translate(-50%) scaleY(1)}.home-plans{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;gap:var(--space-6);width:min(95vw,1180px);z-index:5}.plan-col{flex:0 1 340px;display:flex;flex-direction:column;gap:var(--space-3);opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.home-stage.at-court .plan-col{opacity:1;transform:translateY(0)}.plan-card{flex:1;min-height:420px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-8) var(--space-6);display:flex;flex-direction:column;justify-content:space-between;text-align:left}.plan-price{font-family:var(--font-display);font-size:3.4rem;font-weight:800;color:var(--color-text);text-transform:uppercase;line-height:1.05}.plan-price--free{color:var(--color-primary-active)}.plan-unit{font-size:1.4rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;margin-left:2px}.plan-sub{margin-top:-6px;font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--color-text);text-transform:uppercase}.plan-desc{margin-top:var(--space-5);font-size:1rem;font-weight:500;line-height:1.5;color:var(--color-text-muted)}@media (max-width: 640px){.home-header{padding:var(--space-3) var(--space-4)}.court-line-h,.court-line-v{display:none}.home-intro{padding:var(--space-5) var(--space-4)}.home-intro-cols{flex-direction:column;gap:var(--space-5)}.home-intro-half{padding:0;transform:none}.home-intro-block{max-width:none;text-align:center}.home-intro-title{font-size:1.5rem;line-height:1.15;min-height:0}.intro-anim{margin:var(--space-3) auto 0;max-width:min(100%,360px)}.home-plans{position:static;transform:none;width:auto;flex-wrap:nowrap;flex-direction:column;justify-content:center;gap:var(--space-3);min-height:100%;padding:var(--space-5) var(--space-4)}.plan-col{flex:0 0 auto;gap:var(--space-2)}.plan-card{flex-direction:row;align-items:center;justify-content:flex-start;min-height:0;padding:var(--space-4);gap:var(--space-4)}.plan-top{flex:0 0 38%}.plan-price{font-size:2rem}.plan-unit,.plan-sub{font-size:1rem}.plan-desc{flex:1;margin-top:0;font-size:.85rem;line-height:1.35}}.catbox{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.catbox--open{border-color:var(--color-primary)}.catbox-head{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);background:transparent;border:none;cursor:pointer;gap:var(--space-4)}.catbox-head:hover{background:var(--color-bg-soft)}.catbox-name{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--color-text)}.catbox-right{display:flex;align-items:center;gap:var(--space-3)}.catbox-count{font-size:.9rem;color:var(--color-text-muted)}.catbox-chevron{color:var(--color-text-muted);transition:transform var(--transition)}.catbox--open .catbox-chevron{transform:rotate(180deg)}.catbox-body{padding:var(--space-4) var(--space-5) var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.pair-list{max-height:240px;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-2);scrollbar-width:thin}.pair-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);background:var(--color-bg-soft);border-radius:var(--radius-sm);gap:var(--space-3)}.pair-names{font-size:.95rem;color:var(--color-text);display:flex;align-items:center;gap:var(--space-3)}.pair-franjas{display:inline-flex;flex-wrap:wrap;gap:4px}.pair-tag{font-size:.72rem;font-weight:600;color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-pill);padding:1px 8px}.pair-actions{flex:0 0 auto;display:inline-flex;align-items:center;gap:2px}.pair-edit-btn,.pair-del{flex:0 0 auto;width:26px;height:26px;border:none;background:transparent;color:var(--color-text-muted);font-size:1.1rem;line-height:1;border-radius:var(--radius-pill);cursor:pointer;transition:color var(--transition),background-color var(--transition)}.pair-edit-btn:hover{background:var(--color-surface);color:var(--color-text)}.pair-del:hover{background:var(--color-surface);color:var(--color-danger)}.pair-edit{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-3);background:var(--color-bg-soft);border:1px solid var(--color-primary);border-radius:var(--radius-sm)}.pair-edit-actions{display:flex;justify-content:flex-end;gap:var(--space-2)}.pair-edit-cancel{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);border-radius:var(--radius-pill);padding:8px 16px;font-size:.9rem;font-weight:600;cursor:pointer;transition:border-color var(--transition),color var(--transition)}.pair-edit-cancel:hover{border-color:var(--color-text-muted);color:var(--color-text)}.pair-empty{font-size:.875rem;color:var(--color-text-muted);font-style:italic;margin:0}.addpair{display:flex;flex-direction:column;gap:var(--space-3);border-top:1px solid var(--color-border);padding-top:var(--space-4)}.addpair-names{display:flex;gap:var(--space-2);flex-wrap:wrap}.addpair-names input{flex:1;min-width:120px;padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;background:var(--color-surface);color:var(--color-text)}.addpair-franjas{display:flex;flex-direction:column;gap:var(--space-2)}.addpair-label{font-size:.8rem;font-weight:600;color:var(--color-text-muted)}.franja-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.franja-chip{padding:6px 12px;border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);color:var(--color-text-muted);font-size:.8rem;font-weight:600;cursor:pointer;transition:background-color var(--transition),color var(--transition),border-color var(--transition)}.franja-chip:hover{border-color:var(--color-primary)}.franja-chip--on{background:var(--color-primary);color:var(--color-on-primary);border-color:var(--color-primary)}.addpair-btn{flex:0 0 auto;border:1px solid var(--color-primary);background:var(--color-primary);color:var(--color-on-primary);border-radius:var(--radius-pill);padding:8px 16px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background-color var(--transition)}.addpair-btn:hover:not(:disabled){background:var(--color-primary-hover)}.addpair-btn:disabled{opacity:.6;cursor:not-allowed}.dl-btn{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-8) var(--space-6);border:2px dashed var(--color-border);border-radius:var(--radius-lg);background:transparent;color:var(--color-text);font-family:var(--font-display);font-size:1.15rem;font-weight:600;cursor:pointer;transition:border-color var(--transition),background-color var(--transition)}.dl-btn:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-bg-soft)}.dl-btn:disabled{opacity:.6;cursor:not-allowed}.td{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:var(--color-bg)}.td-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border)}.td-back{border:none;background:transparent;color:var(--color-text-muted);font-size:.95rem;font-weight:600;cursor:pointer;padding:var(--space-2) 0;transition:color var(--transition)}.td-back:hover{color:var(--color-text)}.td-header-right{display:flex;align-items:center;gap:var(--space-4)}.td-config{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:color var(--transition),border-color var(--transition),transform var(--transition)}.td-config:hover{color:var(--color-text);border-color:var(--color-primary);transform:rotate(45deg)}.td-main{flex:1;width:100%;padding:var(--space-6) clamp(16px,5vw,64px)}.td-title{font-size:clamp(2rem,6vw,3rem);font-weight:800;letter-spacing:-.02em;color:var(--color-text);margin-bottom:var(--space-6)}.td-categories{display:flex;flex-direction:column;gap:var(--space-3)}.td-state{text-align:center;color:var(--color-text-muted);padding:var(--space-8)}.td-footer{position:sticky;bottom:0;display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:var(--color-surface);border-top:1px solid var(--color-border);box-shadow:0 -4px 16px #1c1f1a0f}.td-footer-right{display:flex;align-items:center;gap:var(--space-4)}.td-footer-error{color:var(--color-danger);font-size:.875rem;max-width:360px}@media (max-width: 640px){.td-header{padding:var(--space-3) var(--space-4)}.td-main{padding:var(--space-5) var(--space-4)}.td-title{margin-bottom:var(--space-5)}.td-footer{padding:var(--space-3) var(--space-4)}.td-footer-error{max-width:none}}:root{--color-bg: #faf9f4;--color-bg-soft: #f2f1e8;--color-surface: #ffffff;--color-primary: #c2e338;--color-primary-hover: #b0d22a;--color-primary-active: #9fbf23;--color-on-primary: #1e2415;--color-text: #26292b;--color-text-muted: #6b6f71;--color-border: #e6e6dd;--color-danger: #c0392b;--color-overlay: rgba(28, 31, 26, .45);--font-display: "Poppins", system-ui, -apple-system, sans-serif;--font-body: "Inter", system-ui, -apple-system, sans-serif;--radius-sm: 8px;--radius-md: 14px;--radius-lg: 24px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(28, 31, 26, .06);--shadow-md: 0 6px 20px rgba(28, 31, 26, .1);--shadow-lg: 0 18px 50px rgba(28, 31, 26, .18);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-8: 48px;--transition: .16s ease}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-body);color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}img{max-width:100%}h1,h2,h3{font-family:var(--font-display);margin:0}button{font-family:inherit}a{color:inherit}.form{display:flex;flex-direction:column;gap:var(--space-4)}.field{display:flex;flex-direction:column;gap:var(--space-2)}.field label{font-size:.85rem;font-weight:600;color:var(--color-text-muted)}.field input{padding:11px 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.95rem;color:var(--color-text);background:var(--color-surface);transition:border-color var(--transition),box-shadow var(--transition)}@media (max-width: 640px){.field input{font-size:16px}}.field input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #c2e33859}.form-error{color:var(--color-danger);font-size:.875rem;margin:0}.form-hint{color:var(--color-text-muted);font-size:.85rem;margin:0}.form-ok{color:var(--color-primary);font-size:.875rem;font-weight:600;margin:0}
