:root{--dop-blue: #1e3a8a;--dop-yellow: #fbbf24;--dop-white: #ffffff;--dop-light-gray: #f3f4f6;--dop-dark-gray: #374151;--dop-text: #1f2937}.landing{min-height:100vh;display:flex;flex-direction:column;background-color:var(--dop-white)}.landing-header{background-color:var(--dop-blue);color:var(--dop-white);padding:2rem 1rem;text-align:center}.logo-container{max-width:1200px;margin:0 auto}.brand-title{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;letter-spacing:-.02em}.passport-title{font-size:3rem;font-weight:300;font-style:italic;color:var(--dop-yellow);margin:0}.landing-main{flex:1;max-width:1200px;margin:0 auto;padding:2rem 1rem;width:100%}.hero{text-align:center;padding:3rem 1rem;background-color:var(--dop-light-gray);border-radius:12px;margin-bottom:3rem}.hero-content{max-width:800px;margin:0 auto}.tagline{font-size:2rem;font-style:italic;color:var(--dop-blue);margin-bottom:1rem;font-weight:300}.description{font-size:1.125rem;line-height:1.7;color:var(--dop-text);margin-bottom:2rem}.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn{padding:1rem 2rem;font-size:1.125rem;font-weight:600;border-radius:8px;text-decoration:none;transition:all .3s ease;display:inline-block}.btn-primary:hover{background-color:#f59e0b;transform:translateY(-2px);box-shadow:0 4px 12px #fbbf2466}.btn-secondary{background-color:var(--dop-blue);color:var(--dop-white);border:2px solid var(--dop-blue)}.btn-secondary:hover{background-color:#1e40af;transform:translateY(-2px);box-shadow:0 4px 12px #1e3a8a66}.btn-business{background-color:var(--dop-white);color:var(--dop-blue);border:2px solid var(--dop-yellow)}.btn-business:hover{background-color:var(--dop-yellow);transform:translateY(-2px)}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:3rem}.feature{text-align:center;padding:2rem;background-color:var(--dop-white);border-radius:8px;box-shadow:0 2px 8px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.feature:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature h4{font-size:1.25rem;color:var(--dop-blue);margin-bottom:.5rem}.feature p{color:var(--dop-dark-gray);line-height:1.6}.about{background-color:var(--dop-light-gray);padding:3rem;border-radius:12px;text-align:center;margin-bottom:3rem}.about h3{font-size:2rem;color:var(--dop-blue);margin-bottom:1.5rem}.about p{font-size:1.125rem;line-height:1.7;color:var(--dop-text);max-width:800px;margin:0 auto}.business-cta{background:linear-gradient(135deg,var(--dop-blue) 0%,#1e40af 100%);padding:3rem;border-radius:12px;text-align:center;margin-bottom:3rem}.business-cta-content{max-width:600px;margin:0 auto}.business-cta h3{color:var(--dop-white);font-size:2rem;margin-bottom:1rem}.business-cta p{color:var(--dop-white);font-size:1.125rem;margin-bottom:2rem;opacity:.9}.landing-footer{background-color:var(--dop-blue);color:var(--dop-white);padding:2rem 1rem;text-align:center}.landing-footer p{margin:.5rem 0}.mockup-notice{font-style:italic;color:var(--dop-yellow)}.powered-by{font-size:.875rem;opacity:.8}@media (max-width: 768px){.brand-title{font-size:2rem}.passport-title{font-size:2.5rem}.tagline{font-size:1.5rem}.description{font-size:1rem}.cta-buttons{flex-direction:column;align-items:stretch}.btn{width:100%;max-width:300px;margin:0 auto}.features{grid-template-columns:1fr}.about{padding:2rem 1.5rem}.about h3{font-size:1.5rem}.about p{font-size:1rem}.business-cta{padding:2rem 1.5rem}.business-cta h3{font-size:1.5rem}}:root{--dop-blue: #1e3a8a;--dop-yellow: #fbbf24;--dop-white: #ffffff;--dop-light-gray: #f3f4f6;--dop-dark-gray: #374151;--dop-text: #1f2937;--success: #10b981;--error: #ef4444;--border: #e5e7eb}.customer-app{min-height:100vh;display:flex;flex-direction:column;background-color:var(--dop-light-gray)}.app-nav{background-color:var(--dop-blue);color:var(--dop-white);padding:1rem;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #0000001a}.nav-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.nav-header h1{font-size:1.5rem;font-weight:700}.nav-points{display:flex;align-items:center}.points-badge{background-color:var(--dop-yellow);color:var(--dop-blue);padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:1rem}.nav-links{display:flex;gap:.5rem;overflow-x:auto}.nav-link{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;color:var(--dop-white);text-decoration:none;border-radius:8px;transition:background-color .2s;min-width:60px}.nav-link:hover{background-color:#ffffff1a}.nav-link.active{background-color:#fff3}.nav-icon{font-size:1.5rem}.nav-link span:last-child{font-size:.75rem}.app-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:1.5rem}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--dop-blue) 0%,#1e40af 100%);padding:2rem}.login-container{background:var(--dop-white);border-radius:16px;padding:2.5rem;max-width:400px;width:100%;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2rem;color:var(--dop-blue);margin-bottom:.5rem}.login-header h2{font-size:1.75rem;color:var(--dop-yellow);font-style:italic;font-weight:300;margin-bottom:1rem}.login-header p{color:var(--dop-dark-gray)}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:var(--dop-text)}.form-group input{padding:.75rem;border:2px solid var(--border);border-radius:8px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--dop-blue)}.login-footer{margin-top:2rem;text-align:center;font-size:.875rem;color:var(--dop-dark-gray)}.mockup-notice{font-style:italic;color:var(--dop-yellow);margin-bottom:.5rem}.privacy-note{opacity:.7}.btn-primary,.btn-secondary,.btn-checkin,.btn-redeem,.btn-logout{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background-color:var(--dop-yellow);color:var(--dop-blue)}.btn-primary:hover:not(:disabled){background-color:#f59e0b;transform:translateY(-2px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background-color:var(--dop-white);color:var(--dop-blue);border:2px solid var(--dop-blue)}.btn-secondary:hover{background-color:var(--dop-light-gray)}.btn-checkin{background-color:var(--success);color:var(--dop-white);width:100%;padding:1rem;font-size:1.125rem}.btn-checkin:hover:not(:disabled){background-color:#059669}.btn-redeem{background-color:var(--dop-blue);color:var(--dop-white);width:100%}.btn-redeem:hover:not(:disabled){background-color:#1e40af}.btn-logout{background-color:var(--error);color:var(--dop-white);width:100%}.message{padding:1rem;border-radius:8px;margin:1rem 0;font-weight:500}.message.success{background-color:#d1fae5;color:#065f46;border:1px solid var(--success)}.message.error{background-color:#fee2e2;color:#991b1b;border:1px solid var(--error)}.loading,.error,.empty-state{text-align:center;padding:3rem;color:var(--dop-dark-gray)}.directory-page{background:var(--dop-white);border-radius:12px;padding:2rem;min-height:80vh}.directory-header{margin-bottom:2rem}.directory-header h2{color:var(--dop-blue);margin-bottom:1rem}.search-bar{position:relative;margin-bottom:1.5rem}.search-bar input{width:100%;padding:.75rem 3rem .75rem 1rem;border:2px solid var(--border);border-radius:8px;font-size:1rem}.search-bar input:focus{outline:none;border-color:var(--dop-blue)}.search-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-size:1.25rem}.tabs{display:flex;gap:.5rem;border-bottom:2px solid var(--border);margin-bottom:1.5rem}.tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-weight:600;color:var(--dop-dark-gray);transition:all .2s}.tab:hover{color:var(--dop-blue)}.tab.active{color:var(--dop-blue);border-bottom-color:var(--dop-blue)}.category-filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem}.category-chip{padding:.5rem 1rem;background:var(--dop-light-gray);border:2px solid transparent;border-radius:20px;cursor:pointer;font-size:.875rem;transition:all .2s}.category-chip:hover{background:var(--border)}.category-chip.active{background:var(--dop-blue);color:var(--dop-white);border-color:var(--dop-blue)}.businesses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.business-card{background:var(--dop-white);border:1px solid var(--border);border-radius:12px;padding:1.5rem;text-decoration:none;color:var(--dop-text);transition:all .2s;display:flex;flex-direction:column}.business-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026;border-color:var(--dop-blue)}.business-category{color:var(--dop-blue);font-size:.875rem;font-weight:600;margin-bottom:.5rem}.business-card h3{color:var(--dop-text);font-size:1.25rem;margin-bottom:.5rem}.business-address{color:var(--dop-dark-gray);font-size:.875rem;margin-bottom:.75rem}.business-description{color:var(--dop-dark-gray);font-size:.875rem;line-height:1.5;margin-bottom:1rem;flex:1}.business-footer{display:flex;justify-content:flex-end}.home-page{display:flex;flex-direction:column;gap:2rem}.welcome-section{background:linear-gradient(135deg,var(--dop-blue) 0%,#1e40af 100%);color:var(--dop-white);padding:2rem;border-radius:12px}.welcome-section h2{margin-bottom:1.5rem}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.stat-card{background:#ffffff1a;padding:1.5rem;border-radius:8px;text-align:center}.stat-value{font-size:2.5rem;font-weight:700;color:var(--dop-yellow)}.stat-label{margin-top:.5rem;opacity:.9}.quick-actions{background:var(--dop-white);padding:2rem;border-radius:12px}.quick-actions h3{color:var(--dop-blue);margin-bottom:1rem}.action-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.action-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem;background:var(--dop-light-gray);border-radius:8px;text-decoration:none;color:var(--dop-text);transition:all .2s}.action-btn:hover{background:var(--dop-blue);color:var(--dop-white);transform:translateY(-2px)}.action-icon{font-size:2rem}.home-section{background:var(--dop-white);padding:2rem;border-radius:12px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h3{color:var(--dop-blue)}.see-all{color:var(--dop-blue);text-decoration:none;font-weight:600}.see-all:hover{text-decoration:underline}.deals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.deal-card{background:var(--dop-light-gray);padding:1.5rem;border-radius:8px}.deal-business{color:var(--dop-blue);font-weight:600;font-size:.875rem;margin-bottom:.5rem}.deal-title{margin-bottom:.5rem}.deal-description{color:var(--dop-dark-gray);font-size:.875rem;margin-bottom:.75rem}.deal-badge{background:var(--dop-yellow);color:var(--dop-blue);padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:700}.events-list,.checkins-list{display:flex;flex-direction:column;gap:1rem}.event-card,.checkin-item{display:flex;gap:1rem;padding:1rem;background:var(--dop-light-gray);border-radius:8px}.event-date{background:var(--dop-blue);color:var(--dop-white);padding:.5rem 1rem;border-radius:8px;text-align:center;font-weight:600;min-width:80px}.event-info{flex:1}.event-info h4{margin-bottom:.25rem}.event-location,.event-time{font-size:.875rem;color:var(--dop-dark-gray)}.checkin-icon{background:var(--success);color:var(--dop-white);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.checkin-info{flex:1}.checkin-business{font-weight:600;margin-bottom:.25rem}.checkin-date{font-size:.875rem;color:var(--dop-dark-gray)}.checkin-points{color:var(--success);font-weight:700}@media (max-width: 768px){.app-content{padding:1rem}.nav-header h1{font-size:1.25rem}.points-badge{padding:.375rem .75rem;font-size:.875rem}.businesses-grid{grid-template-columns:1fr}.directory-page{padding:1rem}}.business-portal{min-height:100vh;background-color:var(--dop-light-gray)}.portal-nav{background-color:var(--dop-white);padding:1.5rem;box-shadow:0 2px 8px #0000001a}.portal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.portal-header h1{color:var(--dop-blue);font-size:1.5rem}.btn-logout-small{padding:.5rem 1rem;background-color:var(--error);color:#fff;border:none;border-radius:6px;cursor:pointer}.portal-links{display:flex;gap:1rem;overflow-x:auto}.portal-link{padding:.5rem 1rem;color:var(--dop-text);text-decoration:none;border-radius:6px;transition:background-color .2s}.portal-link:hover{background-color:var(--dop-light-gray)}.portal-content{max-width:1200px;margin:0 auto;padding:2rem}.business-login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--dop-blue) 0%,#1e40af 100%);padding:2rem}.business-login-container{background:#fff;padding:2rem;border-radius:16px;max-width:800px;width:100%}.business-login-container h1{color:var(--dop-blue);margin-bottom:.5rem}.business-select-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin:2rem 0}.business-select-card{padding:1.5rem;background:var(--dop-light-gray);border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s}.business-select-card:hover{border-color:var(--dop-blue);transform:translateY(-2px)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin:2rem 0}.stat-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center}.stat-value{font-size:2.5rem;font-weight:700;color:var(--dop-blue)}.stat-label{color:var(--dop-dark-gray);margin-top:.5rem}.qr-section{background:#fff;padding:2rem;border-radius:12px;margin:2rem 0;text-align:center}.qr-code-image{max-width:300px;margin:1rem 0}.btn-download{padding:.75rem 1.5rem;background:var(--dop-blue);color:#fff;border:none;border-radius:8px;cursor:pointer}.recent-activity{background:#fff;padding:2rem;border-radius:12px;margin:2rem 0}.checkins-table{overflow-x:auto}.checkins-table table{width:100%;border-collapse:collapse}.checkins-table th,.checkins-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border)}.checkins-table th{background-color:var(--dop-light-gray);font-weight:600}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.deal-form,.event-form,.profile-form{background:#fff;padding:2rem;border-radius:12px;margin-bottom:2rem;display:flex;flex-direction:column;gap:1rem}.deal-form input,.deal-form textarea,.event-form input,.event-form textarea,.profile-form input,.profile-form textarea{padding:.75rem;border:2px solid var(--border);border-radius:8px;font-size:1rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end}.deals-list,.events-list{display:flex;flex-direction:column;gap:1rem}.deal-item,.event-item{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.badge{background:var(--dop-yellow);color:var(--dop-blue);padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600}.date-range,.event-time{color:var(--dop-dark-gray);font-size:.875rem;margin-top:.5rem}.event-date{font-weight:600;color:var(--dop-blue);margin-bottom:.5rem}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}
