*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:Inter,Arial,sans-serif;background:#f6f3ff;color:#241b3a}a{text-decoration:none;color:inherit}img{max-width:100%}
.auth-body{min-height:100vh;background:linear-gradient(135deg,#fff4ea,#f4edff);display:flex;align-items:center;justify-content:center;padding:20px}.auth-wrap{width:100%;max-width:460px}.auth-card{background:#fff;border-radius:24px;box-shadow:0 12px 40px rgba(76,27,111,.10);padding:24px}.auth-tabs{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}.auth-tabs a{padding:10px 14px;border-radius:999px;background:#f2eefc;color:#6d38a8;font-weight:600}.auth-tabs a.active{background:linear-gradient(135deg,#ff8a00,#7a3cff);color:#fff}.auth-title{margin:0 0 18px 0;font-size:28px}.form-grid{display:grid;gap:10px}.form-grid label{font-size:13px;color:#6c627f;font-weight:700}.form-grid input,.form-grid textarea,.form-grid select{width:100%;padding:14px 16px;border-radius:14px;border:1px solid #ddd3f0;background:#fff;font-size:15px}.btn-primary,.btn-light{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border:none;border-radius:14px;cursor:pointer;font-weight:700;transition:.18s transform,.18s opacity}.btn-primary{background:linear-gradient(135deg,#ff8a00,#7a3cff);color:#fff}.btn-light{background:#f3effe;color:#5d32a1}.btn-primary:hover,.btn-light:hover{transform:translateY(-1px);opacity:.95}.alert{background:#fff4db;border:1px solid #ffd27d;color:#8d5a00;padding:14px 16px;border-radius:14px;margin-bottom:16px}.mini-note{font-size:13px;color:#6d627e;margin-top:12px;line-height:1.6}
.shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.shell-user{grid-template-columns:250px 1fr}.sidebar{background:#24133a;padding:22px;display:flex;flex-direction:column;gap:8px}.brand{color:#fff;font-size:24px;font-weight:800;margin-bottom:10px}.sidebar a{color:#cdbff2;padding:12px 14px;border-radius:14px}.sidebar a.active,.sidebar a:hover{background:linear-gradient(135deg,#ff8a00,#7a3cff);color:#fff}.content{padding:24px}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.topbar h1{margin:0;font-size:30px}.muted{color:#756a88;font-size:14px}.cards-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.stat-card,.panel,.event-card,.ticket-card,.reg-card{background:#fff;border-radius:22px;box-shadow:0 10px 30px rgba(72,34,110,.08)}.stat-card{padding:18px}.stat-card span{display:block;color:#7a6e8e}.stat-card h3{font-size:34px;margin:10px 0 0}.panel{padding:20px}.panel h2{margin-top:0}.list{padding-left:18px;line-height:1.8}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}.item-row{display:flex;justify-content:space-between;gap:14px;align-items:center;border-bottom:1px solid #f0e8fb;padding:12px 0}.item-row:last-child{border-bottom:none}.reg-card{padding:16px;margin-bottom:14px}.reg-top{display:flex;justify-content:space-between;gap:10px;margin-bottom:10px}.reg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:10px}.event-card{padding:20px;display:grid;grid-template-columns:1.2fr .8fr;gap:18px;margin-bottom:16px}.mini-form{display:grid;gap:10px;align-content:start}.ticket-card{display:grid;grid-template-columns:1.2fr .8fr;gap:12px;padding:18px;margin-bottom:12px;border:1px dashed #eadcf7}.ticket-left,.ticket-right{display:flex;flex-direction:column;justify-content:center}.ticket-right{align-items:center}.ticket-badge{display:inline-block;padding:8px 12px;border-radius:999px;background:#fff2e4;color:#ff7a00;font-weight:800;margin-bottom:8px}.action-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.upload-photo-box{background:#fff;border-radius:18px;padding:16px;margin:0 0 16px 0}.print-body{background:#ece7f8;padding:16px}.ticket-print{max-width:980px;margin:0 auto;background:#fff;border-radius:24px;padding:28px;box-shadow:0 10px 30px rgba(72,34,110,.1)}.ticket-head{display:flex;justify-content:space-between;gap:10px;align-items:start}.ticket-grid{display:grid;grid-template-columns:1fr 260px;gap:20px;align-items:center}.data-line{padding:10px 0;border-bottom:1px dashed #ddd}
.certificate-page{max-width:1100px;min-height:760px;margin:0 auto;background:#fff;border-radius:28px;box-shadow:0 12px 32px rgba(72,34,110,.12);overflow:hidden}.certificate-inner{min-height:760px;padding:54px 60px;position:relative;background:rgba(255,255,255,.88)}.cert-heading{text-align:center;font-size:38px;font-weight:800;letter-spacing:2px;color:#5c2f8f}.cert-number{text-align:center;font-size:18px;color:#ff7d00;margin-top:8px;font-weight:700}.cert-subtitle{text-align:center;color:#756a88;margin-top:12px}.recipient-name{text-align:center;font-size:42px;color:#26133d;font-weight:800;margin-top:34px}.cert-text{text-align:center;max-width:760px;margin:18px auto 0;line-height:1.8;font-size:18px}.cert-date{text-align:center;margin-top:18px;color:#5e536f;font-weight:700}.cert-signatures{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:70px}.sign-box{text-align:center}.sign-image-wrap{height:88px;display:flex;align-items:end;justify-content:center}.sign-image{max-height:80px}.sign-placeholder{width:160px;height:2px;background:#444}.sign-name{font-weight:800;margin-top:10px}.sign-title{color:#766a8c;font-size:14px}.cert-qr{position:absolute;right:34px;bottom:24px;text-align:center}.center{text-align:center}.print-actions{display:flex;justify-content:flex-end;max-width:1100px;margin:0 auto 10px}.cert-actions{padding-top:6px}.no-print{display:block}.fade-in{animation:fadeIn .35s ease}@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@media print{.no-print{display:none!important}body{background:#fff}.certificate-page,.ticket-print{box-shadow:none;border-radius:0;margin:0;max-width:none}.print-body{padding:0}.certificate-inner{background:rgba(255,255,255,.92)}}
@media (max-width:980px){.shell,.shell-user{grid-template-columns:1fr}.sidebar{position:sticky;top:0;z-index:20;flex-direction:row;overflow:auto;padding:12px}.brand{display:none}.content{padding:16px}.cards-4,.grid-2,.event-card,.ticket-card,.ticket-grid,.reg-grid,.cert-signatures{grid-template-columns:1fr}.ticket-right,.cert-qr{position:static}.certificate-inner{padding:28px 22px}.recipient-name{font-size:28px}.cert-heading{font-size:28px}}


.uploads-admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:12px 0;}
.upload-preview-card{border:1px solid #ece6fb;border-radius:16px;padding:12px;background:#faf8ff;}
.admin-upload-thumb{display:block;width:100%;max-height:220px;object-fit:cover;border-radius:12px;margin-top:8px;border:1px solid #e7dfff;}
.file-pill{display:inline-block;margin-top:8px;padding:8px 12px;border-radius:999px;background:#f4edff;color:#6c43d6;font-weight:700;font-size:12px;}


.recipient-row{display:grid;grid-template-columns:1fr 190px;gap:24px;align-items:center;max-width:900px;margin:24px auto 0;}
.recipient-main .recipient-name{margin-top:0;text-align:left;}
.recipient-main .cert-text,.recipient-main .cert-date{text-align:left;max-width:none;margin-left:0;margin-right:0;}
.cert-qr-inline{position:static;right:auto;bottom:auto;background:rgba(255,255,255,.82);padding:10px;border-radius:18px;border:1px solid #eee3ff;}
.qr-reader-box{width:100%;max-width:420px;min-height:320px;border:2px dashed #d9c6ff;border-radius:20px;overflow:hidden;background:#faf8ff;margin-top:12px;}
@media (max-width:980px){.recipient-row{grid-template-columns:1fr}.recipient-main .recipient-name,.recipient-main .cert-text,.recipient-main .cert-date{text-align:center}.cert-qr-inline{margin:0 auto;}}


/* patch 2026-03-25 */
.recipient-row{grid-template-columns:1fr 120px;gap:18px;align-items:center;max-width:900px;margin:24px auto 0;}
.recipient-main .recipient-name,.recipient-main .cert-text,.recipient-main .cert-date,.recipient-main .cert-subtitle{text-align:center !important;}
.recipient-main .cert-text,.recipient-main .cert-date{max-width:760px;margin-left:auto !important;margin-right:auto !important;}
.cert-qr-inline{background:transparent !important;padding:0 !important;border:none !important;box-shadow:none !important;}
.cert-qr-inline img{width:100px;height:100px;display:block;margin:0 auto;}
.cert-qr-note{font-size:11px;line-height:1.4;max-width:110px;margin:6px auto 0;}
.sign-placeholder{background:transparent !important;height:0 !important;border:none !important;}
.sign-image-wrap{border-top:none !important;}
.brochure-block{margin-top:10px;}
.brochure-link{display:inline-block;padding:8px 12px;border-radius:999px;background:#f4edff;color:#6c43d6;font-weight:700;}
.brochure-preview{margin-top:10px;max-width:300px;border:1px solid #ece6fb;border-radius:16px;overflow:hidden;background:#faf8ff;}
.brochure-preview img{display:block;width:100%;height:auto;object-fit:cover;}
.brochure-pdf iframe{display:block;width:100%;height:240px;border:none;background:#fff;}
@media (max-width:980px){.recipient-row{grid-template-columns:1fr 100px;}.cert-qr-inline img{width:88px;height:88px;}.brochure-preview{max-width:100%;}}


.cert-inner-tight{padding-top:28px !important;padding-bottom:40px !important;}
.certificate-inner .cert-heading{margin-top:0;}
.certificate-inner .cert-subtitle{margin-top:10px;}
.certificate-inner .recipient-row{margin-top:18px !important;}
.certificate-inner .cert-signatures{margin-top:48px !important;}
