:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#1a1a1a}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{margin:0;height:100vh;background:linear-gradient(135deg,#e0f2fe,#fce7f3);color:#1a1a1a;overflow-x:hidden;overflow-y:auto}.app-root{height:100vh;position:relative;overflow-y:auto}.app-main{min-height:100vh;padding:1rem;max-width:1200px;margin:0 auto;position:relative}.home-page{position:relative;min-height:calc(100vh - 2rem);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem}.decorations{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1;overflow:hidden}.decoration{position:absolute;font-size:4rem;filter:drop-shadow(0 4px 12px rgba(0,0,0,.15));animation:float 6s ease-in-out infinite;-webkit-user-select:none;user-select:none}.decoration-socks{top:5%;left:3%;font-size:3.5rem;animation-delay:0s;transform:rotate(-10deg)}.decoration-tree-top-left{top:8%;left:2%;font-size:4rem;animation-delay:1s}.decoration-tree-top-right{top:5%;right:3%;font-size:4rem;animation-delay:2s}.decoration-gift-bottom-left{bottom:8%;left:3%;font-size:4rem;animation-delay:.5s}.decoration-snowman{bottom:5%;right:3%;font-size:4rem;animation-delay:1.5s}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(5deg)}}.snow-container{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2;overflow:hidden}.snowflake{position:absolute;top:-10%;font-size:1.2rem;color:#ffffffe6;text-shadow:0 2px 4px rgba(0,0,0,.1);animation:snowFall linear infinite}@keyframes snowFall{0%{transform:translateY(-10vh) translate(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(110vh) translate(30px);opacity:0}}.home-header{text-align:center;margin-bottom:1.5rem;position:relative;z-index:10}.title-container{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}.title-icon-left,.title-icon-right{font-size:3rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.15))}.main-title{font-size:3.5rem;font-weight:900;margin:0;line-height:1.2}.title-amigo{color:#1a1a1a}.title-secreto{color:#22c55e;text-shadow:0 2px 4px rgba(34,197,94,.3)}.title-decoration{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem}.decoration-line{width:40px;height:3px;border-radius:2px}.decoration-line.green{background:#22c55e}.decoration-line.red{background:#ef4444}.decoration-star{font-size:1.2rem}.main-card{background:#fff;border-radius:24px;padding:1.5rem;box-shadow:0 20px 60px #00000026;position:relative;z-index:10;width:100%;max-width:800px}.card-header-section{text-align:center;margin-bottom:1.5rem}.card-title{font-size:1.75rem;font-weight:800;color:#1a1a1a;margin-bottom:.75rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.card-title-icon{font-size:1.8rem}.card-description{font-size:1.1rem;color:#64748b;line-height:1.6}.highlight-sms{color:#ef4444;font-weight:700}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.feature-item{text-align:center}.feature-icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;box-shadow:0 8px 16px #0000001a}.feature-icon-fast{background:linear-gradient(135deg,#f97316,#fb923c);color:#fff}.feature-icon-secure{background:linear-gradient(135deg,#eab308,#facc15);color:#fff}.feature-icon-sms{background:linear-gradient(135deg,#a855f7,#c084fc);color:#fff}.feature-title{font-size:1.1rem;font-weight:700;color:#1a1a1a;margin-bottom:.5rem}.feature-description{font-size:.9rem;color:#64748b}.card-footer-section{display:flex;justify-content:center}.cta-button{display:flex;align-items:center;gap:.75rem;padding:1rem 2.5rem;background:linear-gradient(135deg,#22c55e,#4ade80);color:#fff;border:none;border-radius:16px;font-size:1.1rem;font-weight:700;cursor:pointer;text-decoration:none;box-shadow:0 8px 24px #22c55e66;transition:transform .2s,box-shadow .2s}.cta-button:hover{transform:translateY(-2px);box-shadow:0 12px 32px #22c55e80}.cta-button:active{transform:translateY(0)}.draw-page{position:relative;min-height:calc(100vh - 2rem);padding:1rem}.back-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;font-size:.95rem;font-weight:600;color:#1a1a1a;cursor:pointer;margin-bottom:1rem;position:relative;z-index:10;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.back-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.draw-header{text-align:center;margin-bottom:1.5rem;position:relative;z-index:10}.draw-subtitle{font-size:1.1rem;color:#64748b;margin-top:1rem}.draw-card{max-width:900px;margin:0 auto}.draw-card-header{margin-bottom:1.5rem}.draw-card-title{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:1.5rem;font-weight:800;color:#a855f7;margin-bottom:.5rem}.draw-card-icon{color:#a855f7}.draw-card-star{color:#eab308;font-size:1.2rem}.draw-card-subtitle{text-align:center;color:#64748b;font-size:1rem}.participant-form{margin-bottom:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{display:flex;align-items:center;gap:.5rem;font-size:.95rem;font-weight:600;color:#1a1a1a}.label-icon{color:#a855f7}.form-field input{padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;transition:border-color .2s,box-shadow .2s;background:#fff}.form-field input:focus{outline:none;border-color:#a855f7;box-shadow:0 0 0 3px #a855f71a}.add-button{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 2rem;background:linear-gradient(135deg,#ec4899,#f43f5e);color:#fff;border:none;border-radius:16px;font-size:1.1rem;font-weight:700;cursor:pointer;box-shadow:0 8px 24px #ec489966;transition:transform .2s,box-shadow .2s}.add-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #ec489980}.add-button:active:not(:disabled){transform:translateY(0)}.add-button:disabled{opacity:.5;cursor:not-allowed;background:linear-gradient(135deg,#d1d5db,#9ca3af);box-shadow:none}.add-button span:first-child{font-size:1.5rem;font-weight:300}.participants-section{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #e2e8f0}.participants-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.participants-header h3{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700;color:#1a1a1a}.inline-icon{color:#a855f7}.btn-clear{padding:.5rem 1rem;background:#fee2e2;color:#ef4444;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-clear:hover{background:#fecaca}.participants-list{list-style:none;background:#f8fafc;border-radius:12px;border:2px solid #e2e8f0;overflow:hidden}.participants-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0}.participants-item:last-child{border-bottom:none}.participants-info{display:flex;flex-direction:column;gap:.25rem}.participants-info .name{font-size:1rem;font-weight:600;color:#1a1a1a}.participants-info .phone{font-size:.9rem;color:#64748b}.icon-button{background:transparent;border:none;color:#ef4444;cursor:pointer;padding:.5rem;border-radius:8px;transition:background .2s;display:flex;align-items:center;justify-content:center}.icon-button:hover{background:#fee2e2}.draw-card-footer{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #e2e8f0;display:flex;justify-content:center}.draw-button{display:flex;align-items:center;gap:.75rem;padding:1rem 2.5rem;background:linear-gradient(135deg,#22c55e,#4ade80);color:#fff;border:none;border-radius:16px;font-size:1.1rem;font-weight:700;cursor:pointer;box-shadow:0 8px 24px #22c55e66;transition:transform .2s,box-shadow .2s,opacity .2s}.draw-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #22c55e80}.draw-button:disabled{opacity:.6;cursor:not-allowed}.results-card{margin-top:1.5rem}.results-list{display:flex;flex-direction:column;gap:1rem}.results-item{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1rem;background:#f8fafc;border-radius:12px;font-size:1rem}.results-giver{font-weight:600;color:#1a1a1a}.results-arrow{font-size:1.5rem}.results-receiver{font-weight:600;color:#22c55e}@media(max-width:768px){.app-main{padding:.5rem}.home-page,.draw-page{padding:.5rem;min-height:calc(100vh - 1rem)}.main-title{font-size:2.5rem}.title-icon-left,.title-icon-right{font-size:2rem}.main-card{padding:1.25rem;border-radius:20px}.card-title{font-size:1.5rem}.card-description{font-size:1rem}.features-grid{grid-template-columns:1fr;gap:1.5rem}.form-row{grid-template-columns:1fr;gap:1rem}.decoration{font-size:2.5rem}.decoration-socks{font-size:2rem}.participants-header{flex-direction:column;align-items:flex-start;gap:.75rem}.cta-button,.draw-button{width:100%;justify-content:center}.back-button{margin-bottom:1.5rem}}@media(max-width:480px){.main-title{font-size:2rem}.title-container{gap:.5rem}.title-icon-left,.title-icon-right{font-size:1.5rem}.main-card{padding:1.25rem}.card-title{font-size:1.25rem;flex-wrap:wrap}.decoration{font-size:2rem}}.not-found-page{display:flex;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:2rem}.not-found-page h1{font-size:4rem;font-weight:900;color:#1a1a1a;margin-bottom:1rem}.not-found-page p{font-size:1.2rem;color:#64748b;margin-bottom:2rem}.not-found-page a{display:inline-block;padding:1rem 2rem;background:linear-gradient(135deg,#22c55e,#4ade80);color:#fff;border-radius:12px;font-weight:700;text-decoration:none;box-shadow:0 8px 24px #22c55e66;transition:transform .2s}.not-found-page a:hover{transform:translateY(-2px)}
