@import"https://fonts.googleapis.com/css2?family=Cairo:wght@400;700&family=Amiri&family=Tajawal&family=Reem+Kufi&family=Lateef&display=swap";:root{--primary-color: #020055;--primary-hover: #0000AA;--text-color: #020055;--white: #ffffff;--light-bg: #f5f5f5;--border-radius: 10px;--box-shadow: 0 4px 6px rgba(0, 0, 0, .1);--transition: all .3s ease}*{box-sizing:border-box;margin:0;padding:0}body,html{font-family:Cairo,sans-serif;line-height:1.6;direction:rtl}body{background:white;color:var(--text-color);display:flex;flex-direction:column;min-height:100vh}.app{max-width:1200px;margin:0 auto;padding:20px;text-align:center;flex:1 0 auto;display:flex;flex-direction:column}.hero{text-align:center;padding:4rem 2rem;background-color:var(--primary-color);color:#fff;margin-bottom:2rem;border-radius:var(--border-radius)}.hero h1{font-size:2.5rem;margin-bottom:1rem;background-color:var(--primary-color)}.hero p{font-size:1.2rem;max-width:800px;margin:0 auto 1.5rem}.btn-large{padding:15px 30px;font-size:1.1rem;margin-top:20px}.card-creator-section{background-color:#fff;border-radius:var(--border-radius);padding:20px;box-shadow:var(--box-shadow);margin-bottom:30px}.card-creator-section h2{text-align:center;margin-bottom:20px;color:var(--primary-color)}.card-creation-flow{display:flex;flex-direction:column;gap:30px;margin-bottom:30px}.step{position:relative;padding:20px;background-color:var(--light-bg);border-radius:var(--border-radius);box-shadow:var(--box-shadow)}.step-number{position:absolute;top:-15px;right:-15px;width:35px;height:35px;background-color:var(--primary-color);color:#fff;border-radius:50%;display:flex;justify-content:center;align-items:center;font-weight:700;font-size:1.1rem}.step h3{margin-top:0;margin-bottom:15px;color:var(--primary-color)}.card-container{display:flex;justify-content:center;flex-wrap:wrap;gap:20px;margin-bottom:30px}.card{border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--box-shadow);cursor:pointer;transition:var(--transition);border:3px solid transparent}.card:hover{transform:translateY(-5px)}.card.selected{border-color:var(--primary-color);box-shadow:0 0 0 3px #0200554d}.card img{width:100%;height:auto;object-fit:cover;transition:var(--transition)}.customization-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:20px}.option-group{margin-bottom:15px;text-align:right}.option-group label{display:block;margin-bottom:8px;font-weight:700}.option-group select{width:100%;padding:10px;border-radius:var(--border-radius);border:1px solid #ccc;background-color:#fff;font-family:Cairo,sans-serif}.name-input{margin-bottom:20px;text-align:right}.name-input label{display:block;margin-bottom:8px;font-weight:700}.name-input input{width:100%;padding:10px;border-radius:var(--border-radius);border:1px solid #ccc;font-size:1rem;font-family:Cairo,sans-serif}.buttons,.action-buttons{display:flex;justify-content:center;gap:20px;margin-bottom:30px}.btn{padding:10px 20px;border:2px solid transparent;border-radius:5px;cursor:pointer;font-size:1rem;font-weight:700;font-family:Cairo,sans-serif;transition:var(--transition);display:flex;align-items:center;gap:10px}.btn:hover:not(:disabled){transform:translateY(-2px)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--primary-color);color:var(--white)}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);color:var(--white)}.btn-secondary{background-color:transparent;color:var(--primary-color);border-color:var(--primary-color)}.btn-secondary:hover:not(:disabled){background-color:#0200551a;color:var(--primary-hover);border-color:var(--primary-hover)}.btn-accent{background-color:#46a049;color:#fff}.btn-accent:hover:not(:disabled){background-color:#3d8b3d}.btn i{font-size:1.2rem}.preview-section{background-color:#fff;border-radius:var(--border-radius);padding:20px;margin-top:30px;box-shadow:var(--box-shadow);text-align:center}.preview-section h3{margin-top:0;margin-bottom:20px;color:var(--primary-color)}.preview-card{max-width:100%;height:auto;margin:0 auto;display:block;border-radius:var(--border-radius);box-shadow:var(--box-shadow)}.preview-placeholder{background-color:var(--light-bg);width:100%;height:300px;border-radius:var(--border-radius);display:flex;justify-content:center;align-items:center;color:#777;font-size:1.1rem}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px}.spinner{border:4px solid rgba(2,0,85,.1);border-radius:50%;border-top:4px solid var(--primary-color);width:40px;height:40px;animation:spin 1s linear infinite;margin-bottom:15px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.section-header{text-align:center;margin-bottom:28px}.section-header h2{color:var(--primary-color);font-size:1.6rem;margin-bottom:6px}.section-subtitle{color:#666;font-size:.95rem}.hero-cta{display:inline-flex;margin-top:1.2rem}.creator-layout,.creator-layout.has-preview{display:flex;flex-direction:column;gap:28px}@media (min-width: 769px){.creator-layout.has-preview{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}}.steps-column{display:flex;flex-direction:column;gap:24px}.step-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}.step-header .step-number{position:static;flex-shrink:0}.step-header h3{margin:0}.preview-sticky{position:sticky;top:20px;display:flex;flex-direction:column;gap:14px}.preview-title{color:var(--primary-color);font-size:1.1rem;display:flex;align-items:center;gap:8px;justify-content:center}.preview-hint{color:#888;font-size:.85rem;text-align:center}@media (max-width: 768px){.app{padding:12px}.hero{padding:2rem 1.25rem;margin-bottom:1.25rem}.hero h1{font-size:1.6rem;margin-bottom:.6rem}.hero p{font-size:.95rem;margin-bottom:1rem}.section-header{margin-bottom:18px}.section-header h2{font-size:1.3rem}.creator-layout,.creator-layout.has-preview{gap:20px}.steps-column{gap:18px}.card-creator-section{padding:14px;margin-bottom:16px}.step{padding:14px 12px}.step h3{font-size:1rem;margin-bottom:10px}.card-container{gap:12px;margin-bottom:16px}.preview-sticky{position:static;gap:10px}.action-buttons{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:0}.action-buttons .btn{width:100%;justify-content:center}.preview-section{padding:14px;margin-top:18px}}@media (max-width: 480px){.app{padding:8px}.hero{padding:1.5rem 1rem;margin-bottom:1rem}.hero h1{font-size:1.35rem}.hero p{font-size:.88rem}.section-header{margin-bottom:14px}.section-header h2{font-size:1.15rem}.section-subtitle{font-size:.82rem}.creator-layout,.creator-layout.has-preview,.steps-column{gap:14px}.card-creator-section{padding:10px;margin-bottom:12px}.step{padding:12px 10px}.step-number{width:28px;height:28px;font-size:.9rem;top:-12px;right:-12px}.customization-options{grid-template-columns:1fr;gap:12px}.buttons,.action-buttons{flex-direction:column;align-items:stretch;gap:8px;margin-bottom:0}.buttons .btn,.action-buttons .btn{width:100%;justify-content:center;padding:12px 16px}.preview-section{padding:10px;margin-top:14px}.preview-sticky{gap:8px}.preview-hint{font-size:.8rem}}.app{padding:12px}.hero{padding:2rem 1.25rem;margin-bottom:1.25rem}.hero h1{font-size:1.6rem;margin-bottom:.6rem}.hero p{font-size:.95rem;margin-bottom:1rem}.card-creator-section{padding:14px;margin-bottom:16px}.card-creator-section h2{font-size:1.2rem;margin-bottom:14px}.card-creation-flow{gap:18px;margin-bottom:18px}.step{padding:14px 12px}.step h3{font-size:1rem;margin-bottom:10px}.card-container{gap:12px;margin-bottom:16px}.action-buttons{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:0}.action-buttons .btn{width:100%;justify-content:center}.preview-section{padding:14px;margin-top:18px}@media (max-width: 480px){.app{padding:8px}.hero{padding:1.5rem 1rem;margin-bottom:1rem}.hero h1{font-size:1.35rem}.hero p{font-size:.88rem}.card-creator-section{padding:10px;margin-bottom:12px}.card-creation-flow{gap:14px}.step{padding:12px 10px}.step-number{width:28px;height:28px;font-size:.9rem;top:-12px;right:-12px}.customization-options{grid-template-columns:1fr;gap:12px}.buttons,.action-buttons{flex-direction:column;align-items:stretch;gap:8px;margin-bottom:0}.buttons .btn,.action-buttons .btn{width:100%;justify-content:center;padding:12px 16px}.preview-section{padding:10px;margin-top:14px}}.card{width:calc(33.33% - 20px);max-width:400px;min-width:280px;cursor:pointer;border:2px solid transparent;border-radius:10px;overflow:hidden;transition:transform .3s ease,border-color .3s ease;position:relative;margin:10px}.card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border:2px solid transparent;border-radius:10px;transition:border-color .3s ease}.card:hover:before{border-color:#0ff;animation:borderAnimation 1s infinite alternate}@keyframes borderAnimation{0%{border-color:#0ff}to{border-color:#f0f}}.card:hover{transform:scale(1.05)}.card.selected{border-color:#0ff}.card img{width:100%;height:auto;display:block}@media (max-width: 768px){.card{width:90%;max-width:none;margin:10px auto}}@media (max-width: 480px){.card{width:95%;min-width:200px;margin:8px auto}.card img{max-height:300px;object-fit:contain}}.occasion-selector{margin-bottom:20px}.occasion-selector h2{margin-bottom:10px}.occasion-selector select{padding:10px;font-size:16px;border-radius:5px;border:none;background-color:#f0f0f0;color:#333}.customization-options{display:flex;justify-content:center;gap:20px;margin-bottom:20px}.option{display:flex;flex-direction:column;align-items:center}.option label{margin-bottom:5px}.option select{padding:5px;font-size:14px;border-radius:5px;border:none;background-color:#f0f0f0;color:#333}.name-input{margin-bottom:20px;text-align:center;display:flex;flex-direction:column;align-items:center}.name-input label{display:block;margin-bottom:5px;text-align:center}.name-input input{padding:10px;font-size:16px;border-radius:5px;border:none;background-color:#f0f0f0;color:#333;width:100%;max-width:300px;text-align:center}.draggable-preview-wrapper{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%}.draggable-canvas{width:100%;max-width:600px;height:auto;border-radius:12px;box-shadow:0 8px 32px #0000002e;cursor:default;touch-action:none;transition:box-shadow .2s ease;display:block}.draggable-canvas.hovering-text{cursor:grab;box-shadow:0 8px 40px #00000047}.draggable-canvas.dragging{cursor:grabbing;box-shadow:0 12px 48px #00000052}.canvas-placeholder{width:100%;max-width:600px;aspect-ratio:4 / 3;background:linear-gradient(135deg,#f0f0f0,#e0e0e0);border-radius:12px;display:flex;align-items:center;justify-content:center}.canvas-placeholder-spinner{width:40px;height:40px;border:3px solid rgba(0,0,0,.1);border-top-color:#4caf50;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.drag-hint{display:flex;align-items:center;gap:6px;font-size:13px;color:#888;margin:0;-webkit-user-select:none;user-select:none;animation:fadeIn .4s ease}.drag-hint-icon{font-size:15px;color:#4caf50;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.15)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.footer{background-color:#000440;color:#fff;text-align:center;padding:20px 0;margin-top:50px;border-radius:10px}.social-icons{display:flex;justify-content:center;gap:20px;margin-bottom:20px}.social-icons a{color:#fff;text-decoration:none}.social-icons svg{width:24px;height:24px;fill:currentColor;transition:transform .3s ease}.social-icons a:hover svg{transform:scale(1.2)}.navbar{display:flex;justify-content:center;align-items:center;padding:1rem 2rem;background-color:#020055;color:#fff;border-radius:10px;margin-bottom:2rem}.logo{display:flex;align-items:center}.logo-image{height:40px;width:auto;transition:transform .3s ease}.logo-image:hover{transform:scale(1.1)}.nav-links{display:flex;list-style:none}.nav-links li{margin-right:1rem}.nav-links a{color:#fff;text-decoration:none;transition:color .3s ease}.nav-links a:hover{color:#0ff}.nav-links a:focus{outline:2px solid #00FFFF;outline-offset:2px}.hamburger{display:none;flex-direction:column;justify-content:space-around;width:2rem;height:2rem;background:transparent;border:none;cursor:pointer;padding:0;z-index:10}.hamburger span{width:2rem;height:.25rem;background:white;border-radius:10px;transition:all .3s linear;position:relative;transform-origin:1px}.hamburger.open span:nth-child(1){transform:rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0;transform:translate(20px)}.hamburger.open span:nth-child(3){transform:rotate(-45deg)}@media (max-width: 768px){.hamburger{display:flex}.nav-links{position:fixed;right:-100%;top:5rem;flex-direction:column;background-color:#020055;width:100%;text-align:center;transition:.3s;box-shadow:0 10px 27px #0000000d}.nav-links.open{right:0}.nav-links li{margin:2.5rem 0}}import React,{useEffect,useState}from "react"; import "./Toast.css"; export const Toast = ({message,type = "success",duration = 3000}) =>{const [visible,setVisible] = useState(true);useEffect(() => {const timer = setTimeout(() => {setVisible(false);},duration); return () => clearTimeout(timer);},[duration]);if (!visible) return null;return (<div className={`toast toast-${type}`}> <div className="toast-content"> {type === "success" && <i className="fas fa-check-circle"></i>} {type === "error" && <i className="fas fa-exclamation-circle"></i>} {type === "info" && <i className="fas fa-info-circle"></i>} <span>{message}</span> </div> </div>)}; export default Toast;{}
