
	/*
	*  Theme Name: 	Zell/Lurie 2025
	*  Text Domain: 	zl2025
	*  Author: 			Zero Defect Design
	*  Author URI: 	https://zerodefectdesign.com
	*/
	

   /* resets */

   *, *::before, *::after { box-sizing: border-box; }
	* { margin: 0; }
	*:focus { outline: none; } 
   html, body { height: 100%; }
   body { line-height: 1.4; }   
	body > footer { position: sticky; top: 100vh; }
   table { border-collapse: collapse; }
	img, picture, video, canvas, svg { display: block; max-width: 100%; }
   sup, sub { vertical-align: baseline; position: relative; top: -0.4em; }
   sub { top: 0.4em; }
	p, h1, h2, h3, h4, h5, h6 { overflow-wrap: break-word; margin: 0 0 20px 0; padding: 0; break-inside: avoid-page; }
   input, button, textarea, select { font: inherit; }
	textarea { white-space: revert; }

	/* fonts */

	@font-face { font-family: miriam; font-style: normal; font-weight: 400; src: url('fonts/miriam-libre-400.woff2') format('woff2'); }
	@font-face { font-family: miriam; font-style: normal; font-weight: 500; src: url('fonts/miriam-libre-500.woff2') format('woff2'); }
	@font-face { font-family: miriam; font-style: normal; font-weight: 600; src: url('fonts/miriam-libre-600.woff2') format('woff2'); }
	@font-face { font-family: miriam; font-style: normal; font-weight: 700; src: url('fonts/miriam-libre-700.woff2') format('woff2'); }

	@font-face { font-family: kant; font-style: normal; font-weight: 300; src: url('fonts/kantumruy300.woff2') format('woff2'); }
	@font-face { font-family: kant; font-style: italic; font-weight: 300; src: url('fonts/kantumruy300i.woff2') format('woff2'); }
	@font-face { font-family: kant; font-style: normal; font-weight: 400; src: url('fonts/kantumruy400.woff2') format('woff2'); }
	@font-face { font-family: kant; font-style: italic; font-weight: 400; src: url('fonts/kantumruy400i.woff2') format('woff2'); }
	@font-face { font-family: kant; font-style: normal; font-weight: 500; src: url('fonts/kantumruy500.woff2') format('woff2'); }
	@font-face { font-family: kant; font-style: italic; font-weight: 500; src: url('fonts/kantumruy500i.woff2') format('woff2'); }
	@font-face { font-family: kant; font-style: normal; font-weight: 600; src: url('fonts/kantumruy600.woff2') format('woff2'); }
	@font-face { font-family: kant; font-style: italic; font-weight: 600; src: url('fonts/kantumruy600i.woff2') format('woff2'); }

	/* structure and type */
	
	body 
	{ 
		margin: 0; padding-top: 102px; color: #000000; background-color: #FFFFFF; 
		font: 300 20px/1.4 'kant', sans-serif; text-align: center;	
	}
	b, strong { font-weight: 600; }
	.reversed { color: #FFFFFF; }
	h1 { font: 400 42px/1.2 'miriam', sans-serif; letter-spacing: -0.01em; }
	h2 { font: 700 38px/1.2 'miriam', sans-serif; letter-spacing: -0.01em; }
	h2 .subtitle, h2 .light, h2.light, h2.subtitle { font-weight: 300; opacity: 0.4; }
	h3 { font: 700 28px/1.2 'miriam', sans-serif; }
	h3 .subtitle, h3 .light, h3.light, h3.subtitle { font-weight: 400; opacity: 0.6; }
	h4 { font: 700 22px/1.2 'miriam', sans-serif; margin-bottom: 8px; }
	h4 .subtitle, h4 .light, h4.light, h4.subtitle { font-weight: 500; opacity: 0.6; }
	main h4 { margin-bottom: 20px; }
	main div.item h4 { margin-bottom: 8px; }
	h5 { font: 600 20px/1.2 'miriam', sans-serif; margin-bottom: 8px; letter-spacing: .05rem; text-transform: uppercase; }
	h5.breadcrumb { margin-bottom: 20px; }
	h6 { font: 600 16px/1.2 'miriam', sans-serif; margin-bottom: 8px; letter-spacing: .05rem; text-transform: uppercase; color: #8d8d92; }
	.speaker h5 { color: #937d64; margin-bottom: 10px; }
	.speaker h3 { color: #937d64; opacity: 1; }
	.speaker h2 { margin-bottom: 10px; }
	.speaker b, .speaker strong { font-weight: 500; }
	.warm { color: #CC821F; }
	span.light, div.light { opacity: 0.667; }
		
	p.intro { font-size: 110%; font-weight: 400; letter-spacing: -0.02em; }
	.date { font-weight: 600; color: #90b479; }
	.divided { margin-top: 20px; padding-top: 20px; border-top: 3px dotted #8d8d92; }
	.hr { width: 100%; height: 1px; border-bottom: 2px dotted #8d8d92; }
	
	.frame { width: 100%; padding: 50px 75px; max-width: 1400px; margin: 0 auto; text-align: left; }
	.frame .left-half { width: 50%; }
	.cols { display: flex; gap: 50px; flex-wrap: wrap; }
	.cols .col { width: calc(50% - 25px); }
	.dot, .slash { display: inline-block; margin: 0 0.25em; opacity: 0.5; }
	
	main ul, main ol { margin: 0 0 20px 0; }
	main ul li, main ol li { margin: 0 0 10px 0; }
	main ul.tight li, main ol.tight lo { margin-bottom: 2px; }
	
	.zone.shade { background: #e9e8e5; font-weight: 400; }
	.zone.shade a:not(.btn) { font-weight: 600; }
	
	blockquote { margin: 35px 0; padding-top: 35px; border-top: 3px dotted #990000; position: relative; }
	blockquote:before 
	{ 
		position: absolute; top: 0; left: 50%; margin: -20px 0 0 -30px; content: ""; display: block;
		width: 60px; height: 30px; background: #FFFFFF url('images/quotes.svg') center bottom no-repeat; 
		background-size: 20px auto; 
	}			
	blockquote p { font-weight: 300; font-style: italic; font-size: 24px; line-height: 1.4; letter-spacing: -.02rem; }
	blockquote cite { font-style: normal; display: block; text-align: right; font-weight: 400; color: #8d8d92; }
	blockquote cite:before { content: "\2014"; display: inline-block; margin-right: 5px; }
	
	ul.columns { columns: 3; gap: 40px; }
	ul.columns li { margin-bottom: 0px; }
	@media screen and (max-width: 1200px) { ul.columns { columns: 2; } }
	@media screen and (max-width: 800px) { ul.columns { columns: 1; } }
	
	.event-list li { line-height: 1.2; }
	.event-list li .info { display: block; margin-top: 5px; }
	
	/* palette */
	
	.sage { color: #c9d5b5; }
	.reversed .sage { color: #d5eab1; }
	
	/* links and controls */
	
	a { text-decoration: none; color: #74a4ca; }
	p a, li a { font-weight: 600; }
	a[href^="tel:"] { white-space: no-wrap; }
	.reversed a { color: #a1d5ff; }
	a.flip, .flip a { color: #011F5B; }
	a:hover { color: #011F5B; }
	a.flip:hover, .flip a:hover { color: #74a4ca; }
	.reversed a:hover { color: #e1c955; }
	a.btn, .btn, button, a.wp-block-button__link, .wp-element-button
	{ 
		color: #FFFFFF; background-color: #74a4ca; display: inline-block; font-size: 20px; font-weight: 400; line-height: 1; 
		padding: 5px 10px 5px 30px; white-space: nowrap; background-image: url('images/icons/arrow-right.svg');
		background-position: 4px center; background-size: 22px auto; background-repeat: no-repeat;
		text-shadow: none; cursor: pointer; border: 0; border-radius: 0 !important;
	}
	.btn.btn-calendar { background-image: url('images/icons/calendar.svg'); }
	.btn.btn-list { background-image: url('images/icons/list.svg'); }
	a.btn.no-go, .btn.no-go, button.no-go { background-image: none; padding-left: 10px; }
	a.ghostbtn 
	{
		color: #FFFFFF; display: inline-block; font-size: 20px; font-weight: 400; line-height: 1; 
		padding: 4px 9px 4px 30px; white-space: nowrap; border: 1px solid #FFFFFF;
		background: transparent url('images/icons/arrow-right.svg') 4px center no-repeat; 
		background-size: 22px auto; text-shadow: none;
	}
	a.btn:hover, .btn:hover, button:hover, a.ghostbtn:hover, a.wp-block-button__link:hover 
	{ 
		color: #FFFFFF; background-color: #004785; border-color: #004785; 
	}
	a.go 
	{
		margin-left: -2rem; padding-left: 2rem; display: inline-block; 
		background: transparent url('images/icons/arrow-go.svg') left center no-repeat;
		background-size: auto 100%; transition: margin-left 0.2s;
		white-space: nowrap;
	}
	a.go:hover { margin-left: 0; }
	a.tag, span.tag
	{ 
		display: inline-block; margin: 0 5px 0 0; text-decoration: none; padding: 4px 8px 5px 8px; border-radius: 5px;
		color: #FFFFFF; font-size: 16px; line-height: 1; font-weight: 500; border: 0; background-color: #004785;
		white-space: nowrap; text-transform: uppercase;
	}
	a.tag:hover, span.tag:hover { color: #FFFFFF; background-color: #db8c22; }
	
	.controls { float: right; text-align: right; margin: 0 0 0 25px; }
	[modal-url], [modal-content] { cursor: pointer; }
	.wp-block-button { background: none; padding: 0; margin: 0; border-radius: 0; }
	.wp-block-buttons { margin-bottom: 30px; }
	
	
	/* header */
	
	header { position: fixed; z-index: 100; top: 0; left: 0; right: 0; }
	header .topbar { background-color: #FFFFFF; padding: 8px 0; }
	header .navbar { padding: 30px 0; background: linear-gradient(to bottom, #011F5B, #0C4973);	color: #FFFFFF; box-shadow: rgba(0,0,0,0.25) 0 5px 5px;  }
	header .frame { padding-top: 0; padding-bottom: 0; }
	header .nav { display: flex; align-items: center; justify-content: space-between; gap: 25px; }
	header .nav .combined { display: flex; align-items: center; justify-content: flex-end; gap: 25px; }
	header .wharton img { height: 26px; width: auto; }
	header .zl img { height: 42px; width: auto; }
	header #menu
	{ 
		text-align: right; display: flex; justify-content: flex-end; align-items: center; gap: 18px; 
		font: 500 19px/1 'miriam', sans-serif; list-style-type: none; margin: 0; padding: 0;
	}
	header .searchbtn, header .mobilenav { width: 24px; position: relative; top: 3px; }
	header .searchbtn svg, header .mobilenav svg { width: 24px; height: auto; display: inline-block; }
	header a, header span { color: #c2def3; }
	header a:hover, header span:hover { color: #FFFFFF; }
	header span:hover { cursor: pointer; }
	#menu li ul { display: none; position: absolute; z-index: 220; margin: 0px; padding: 0px; list-style-type: none; }
   #menu li:hover ul 
	{ 
		display: block; text-align: left; padding-top: 15px; background: transparent url('images/wedge.svg') 10px 5px no-repeat; 
		background-size: 15px 15px;
	}
	#menu li ul li { display: block; background-color: #82afd3; }
	#menu li ul li a 
	{ 
		display: block; color: #FFFFFF; padding: 4px 8px; 
		font: 400 17px/1.2 'kant', sans-serif;
	}
	#menu li ul li a:hover { background-color: #011f5b; }
	#menu li ul li:first-child { border-top: 5px solid #82afd3; }
	#menu li ul li:last-child { border-bottom: 5px solid #82afd3; }
	
	/* images */
	
	.hero { position: relative; overflow: hidden; width: 100%; height: 30vw; position: relative; }
	.photo-strip { width: 100%; height: 20vw; }
	.hero, .photo-strip, .img { background-position: center center; background-repeat: no-repeat; background-size: cover; }
	.overlay { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(to top, rgba(0,0,0,0.8), rgba(0,0,0,0)) }
	.overlay .frame { padding-bottom: 25px; padding-top: 75px; text-shadow: rgba(0,0,0,0.8) 0 0 10px; }
	.alignright, .wp-block-image .alignright { width: auto; max-width: 33.333%; float: right; margin: 0 0 37.5px 50px; }
	.category-meeting .hero h2 { margin-bottom: 10px; }
	
	/* bottom of page navigation */
	
	#downbar { position: fixed; bottom: 0; left: 0; right: 0; z-index: 50; }
	#downbar .frame { display: flex; justify-content: space-between; align-items: flex-end; padding-top: 0; padding-bottom: 0; }
	#downbar .inner { text-align: left; display: flex; align-items: flex-end; padding-top: 0; padding-bottom: 0; }
	.downtab 
	{ 
		color: #FFFFFF; background-color: #011F5B; border-radius: 10px 10px 0 0; display: inline-block;
		overflow: hidden; position: relative; bottom: 0; 
		cursor: pointer; font-weight: 500; font-size: 18px; line-height: 1;
		box-shadow: 5px 5px 5px rgba(0,0,0,0.2); margin-right: 15px;
	}
	.downtab.offstage { bottom: -60px; }
	.downtab, .downtab .ibox, .downtab .label { transition: 0.1s all ease-out; }
	.downtab.inactive { bottom: -60px; }
	.downtab.totop { background-color: #74a4ca;; margin-right: 0; }
	.downtab:hover { background-color: #db8c22; color: #FFFFFF; }
	.downtab:hover .ibox, .downtab:hover .label { padding-bottom: 14px; }
	.downtab:hover .ibox { background-color: rgba(0,0,0,0.5); color: #FFFFFF; }
	.downtab .ibox { padding: 10px 0; width: 40px; background-color: rgba(0,0,0,0.25); color: #FFCC00; display: inline-block; text-align: center; }
	.downtab .label { padding: 10px 20px 10px 20px; display: inline-block; }
	.downtab.totop .ibox { background-color: transparent; color: #FFFFFF; }
	.downtab svg { width: 0.8em; height: 1em; position: relative; top: 0.2em; display: inline-block; }
	
	/* tables */
   
	table.shade tr:nth-child(even) { background-color: #F3F3F3; }
	table.sort td, table.sort th { padding: 5px; }
   table.sort th 
	{ 
		cursor: pointer; white-space: nowrap; color: #FFFFFF; background-color: rgba(130,175,211,0.75); overflow: hidden; white-space: nowrap; 
		border-right: 4px solid #FFFFFF;
	}
   table.sort th:last-child { border-right: 0; }
	table.sort th:hover { background-color: rgba(130,175,211,1); }
   table.sort th:after { display: inline-block; margin: 0 0 0 7px; width: 24px; height: 22px; content: ''; line-height: 1px; position: relative; top: 5px; }
   th.sorting-asc:after, th.sorting-desc:after { background-position: left bottom; background-repeat: no-repeat; background-size: contain; }
   th.sorting-asc:after { background-image: url('images/icons/sort-asc.svg'); }
   th.sorting-desc:after { background-image: url('images/icons/sort-desc.svg'); }
	
	table.agenda { border-collapse: collapse; }
	table.agenda td { vertical-align: top; padding: 10px 20px 10px 0; border-top: 1px solid rgba(0,0,0,0.2); }
		
	table.agenda td:first-child { white-space: nowrap; font-weight: 500; color: #90b479; line-height: 1; }
	table.agenda td:nth-child(2) {  }
	table.agenda td:last-child { padding-right: 0; }
	table.agenda td h4 { font-size: 20px; }
	table.agenda ul { margin-bottom: 10px; }

	table.agenda td.daydivider:first-child { color: #000000; border-top: 0; }
	
	/* cells */
	
	.cells { display: flex; flex-wrap: wrap; gap: 20px; }
	.cells .cell { width: calc(25% - 15px); }
	.cells.portraits { margin-bottom: 50px; }
	.cells.portraits .cell 
	{ 
		background-color: rgba(0,0,0,0.25);
		aspect-ratio: 2/3; background-position: center center; background-repeat: no-repeat;
		background-size: cover; position: relative;
	}
	.cell .overlay
	{ 
		position: absolute; left: 0; bottom: 0; right; 0; padding: 50px 10px 10px 10px; 
		color: #FFFFFF; background: linear-gradient(to top, rgba(0,0,0,0.8), rgba(0,0,0,0));
	}
	.cell .overlay h4 { font-size: 18px; margin-left: -10px; padding: 5px 10px; line-height: 1; background-color: #000000; display: inline-block; }
	.cell .overlay .info { font-size: 16px; line-height: 1.2; }
	.cells.block { margin-bottom: 30px; }
	.cell[modal-url]:hover, .cell[modal-content]:hover { opacity: 0.9; }
	
	/* working papers */
	
	ul.working-papers { list-style-type: none; margin: 0; padding: 0; }
	ul.working-papers li { margin-bottom: 10px; }
	ul.working-papers a { display: flex; gap: 10px; color: #011F5B; font-weight: 500; }
	ul.working-papers a:hover { color: #74a4ca; }
	ul.working-papers a .pid { white-space: nowrap; }
	ul.working-papers a .light { color: #333333; font-weight: 300; }
	ul.working-papers a .pid .light { color: #000000; }
	#working-paper-controls { display: flex; gap: 20px; margin-bottom: 20px; }
	#working-paper-controls form { width: calc(50% - 10px); }
	#working-paper-controls form select 
	{ 
		width: 100%; border-radius: 0; border: 0; background-color: rgba(130,175,211,0.25); color: #000000; padding: 5px;
		cursor: pointer;
	}
	@media screen and (max-width: 520px)
	{
		#working-paper-controls { flex-wrap: wrap; gap: 10px; }
		#working-paper-controls form { width: 100%; }
	}
	
	/* footer */
	
	footer { background-color: rgba(130,175,211,0.25); font-size: 18px; }
	footer p a { font-weight: 500; color: #004785; opacity: 0.7; }
	footer p a:hover { opacity: 1; }
	footer a.wharton { float: right; display: block; margin: 0 0 30px 30px; }
	footer a.wharton img { width: 200px; height: auto; }
	a.social 
	{ 
		display: inline-block; background-position: center center; width: 32px; height: 32px;
		background-repeat: no-repeat;	background-size: auto 50%; border-radius: 50%; margin-right: 5px;
	}
	a.social-facebook { background-color: #4267B2; background-image: url('images/icons/facebook.svg'); }
	a.social-twitter { background-color: #000000; background-image: url('images/icons/twitter-x.svg'); background-size: auto 45%; }
	a.social:hover { background-color: #DB8C22; }
	footer .socials { margin-bottom: 20px; }
	
	/* audiences */
	
	a.audience, span.audience
	{ 
		display: inline-block; margin: 0 5px 0 0; text-decoration: none; padding: 2px 8px 3px 8px; border-radius: 5px;
		color: #FFFFFF; font-size: 16px; line-height: 1; font-weight: 500; border: 0; background-color: #82AFD3;
		white-space: nowrap;
	}
	a.audience-students, span.audience-students { background-color: #90B479; }
	a.audience-members, span.audience-members { background-color: #DB8C22; }
	a.audience-alumni, span.audience-alumni { background-color: #70587B; }
	a.audience:hover { color: #FFFFFF; text-decoration: none; background-color: #004785; }
	
	/* expanding definition list */
   
	dl.expanding { border-bottom: 1px solid #8d8d92; padding-bottom: 4px; margin-bottom: 30px; }
   dl.expanding dt { padding-top: 8px; margin-top: 6px; border-top: 1px solid #8d8d92; position: relative; cursor: pointer; }
   dl.expanding dd { display: none; padding: 15px 0 15px 30px; }
   dl.expanding dt:after { content: '+'; position: absolute; top: 4px; right: 0px; font-weight: bold; color: #74A4CA; }
   dl.expanding dt.open:after { content: '-'; }
   dl.expanding dt h4 { display: inline; color: #74A4CA; }
   dl.expanding dt:hover h4, dl.expanding dt:hover:after { color: #011F5B; }
	
	/* image + item list */
	
	.image-item { display: flex; align-items: center; gap: 30px; margin-bottom: 30px; }
	.image-item .img
	{ 
		width: 20%; aspect-ratio: 2 / 1; background-position: center center;
		background-size: cover; background-repeat: no-repeat;
		align-self: flex-start;
	}
	.image-item .item { width: calc(80% - 30px); }
	.image-item .item .info { color: #000000; }
	.image-item .audiences { margin-top: 5px; }

	/* home page elements */
	
	.announce, a.announce { display: block; color: #FFFFFF; background-color: #db8c22; font-weight: 500; }
	.announce .frame { padding-top: 10px; padding-bottom: 10px; }
	a.announce:hover { color: #FFFFFF; background-color: #990000; }
	
	.messaging 
	{
		background-position: center bottom; background-repeat: no-repeat; background-size: cover; padding-bottom: 21vw;
	}
	.messaging .frame
	{
		font-family: miriam; color: #FFFFFF; font-size: 2.5vw; line-height: 1.2; font-weight: 400;
	}
	.messaging .scrim { background: linear-gradient(to bottom, rgba(6,143,214,0.9), rgba(6,143,214,0)); }
	@media screen and (min-width: 1400px) { .messaging .frame { font-size: 35px; } }
	@media screen and (max-width: 920px) {	.messaging .frame { font-size: 23px; } }
	@media screen and (max-width: 600px) { .messaging { padding-bottom: 35vw; } }
	
	.zone.student-experience { padding: 25px 0; }
	.zone.student-experience .col:first-child { padding: 25px 0; }
	.zone.become-a-member { background: #d7cab9 url('images/photos/home-members.jpg') center center no-repeat; background-size: cover; }
	.zone.become-a-member .col:last-child { padding: 25px 0; }
	
	/* students landing page */
	
	.zone.students-meetings 
	{
		position: relative; background: #3a3b36 url('images/photos/students-meetings.jpg') center bottom no-repeat; 
		background-size: cover; padding-top: 25px;
	}
	.zone.students-meetings .frame { padding-bottom: 23vw; }
	.zone.students-meetings h3 { color: #fbf158; }
	.zone.students-meetings h3 .subtitle { opacity: 1; }
	.zone.students-meetings p { font-weight: 400; text-shadow: rgba(0,0,0,0.6) 3px 3px 3px; }
	
	.zone.helfand-bluhm { background: #c2def3 url('images/photos/helfand-bluhm-jet.jpg') center 55% no-repeat; background-size: cover; }
	.zone.helfand-bluhm .frame { padding-top: 75px; padding-bottom: 75px; }
	.zone.helfand-bluhm p { font-weight: 400; }

	.zone.students-ballard { background-color: rgba(233,232,229,0.5); padding: 50px 0; }
	.zone.students-schlager { padding: 50px 0; }
	.zone.students-schlager .col:last-child { padding: 75px 0; }
	
	.zone.students-mentor 
	{ 
		background: #c3967f url('images/photos/mentor.jpg') center center no-repeat; background-size: cover; 
		min-height: 22vw; padding: 25px 0; color: #FFFFFF;
	}
	.zone.students-mentor p { font-weight: 400; }
	
	/* alumni : stay in touch */
	
	.stay-in-touch 
	{ 
		display: flex; background: #011f5b url('images/photos/bg-handshake.jpg') center center no-repeat;
		background-size: cover; margin: 20px 0; 
	}
	.stay-in-touch div { padding: 40px; font-weight: 400; }
	.stay-in-touch h3 { white-space: nowrap; color: #a5d7ff; }
	a .stay-in-touch { color: #FFFFFF; }
	@media screen and (max-width: 700px) 
	{ 
		.stay-in-touch { flex-direction: column; } 
		.stay-in-touch h3 { margin-bottom: 0; }
		.stay-in-touch div { padding: 20px; }
		.stay-in-touch div:first-child { padding-bottom: 0; }
	}
			
	
	/* calendar grid */
	
	#yrmo { font: inherit; } 
	.calendar-month { display: flex; gap: 30px; flex-wrap: wrap; margin: 50px 0; }
	.calendar-month > div { width: calc(14.285% - 26px); padding: 15px 0; border-top: 1px solid transparent; }
	.calendar-month .th { font-weight: 600; padding: 0; }
	.calendar-month .blank, .calendar-month .day { border-color: #999999; min-height: 100px; }
	.calendar-month h4 { color: #000000; font-weight: 300; margin: 0 0 15px 0; }
	.calendar-month .item { margin: 0 0 20px 0; line-height: 1.2; font-size: 18px; }
	.calendar-month .item-info { display: block; margin-top: 3px; font-size: 16px; opacity: 0.75; }
	.calendar-month .day.today { border-top: 5px solid #a90533; padding-top: 11px; }
	.calendar-month .day.today h4 { color: #a90533; font-weight: 600; }
	.calendar-month .day b { font-weight: 500; }
	.calendar-month .item-audience { display: block; margin-top: 5px; }
	.calendar-month .audience { font-size: 16px; padding: 3px 8px; margin: 0 2px 4px 0; }
	@media screen and (max-width: 1150px) 
	{ 
		.calendar-month { gap: 10px; } 
		.calendar-month > div { width: calc(14.285% - 9px); }
		.calendar-month .item-title { font-size: 16px; }
	}
	@media screen and (max-width: 850px) 
	{ 
		.calendar-month .no-events, .calendar-month .th { display: none; }
		.calendar-month > div { width: 100%; padding-bottom: 0; }
		.calendar-month .item-title { font-size: 18px; }
	}
	
	/* event list */
	
	.event-list { margin: 25px 0; }
	.event-list td { padding: 15px 0 15px 0; }
	.event-list td h4 { margin-right: 30px; margin-top: 2px; white-space: nowrap; font-size: 23px; font-weight: 500; line-height: 1; }
	.event-list td h4.my { color: #c48fa4; }
	
	.event-item { display: flex; gap: 30px; margin-bottom: 30px; }
	.event-item .event-info { position: relative; top: -3px; } 
	.event-item .item-info { display: block; margin-top: 1px; font-size: 16px; opacity: 0.75; }
	.event-item .item-title { display: inline; margin-right: 5px; position: relative; top: 2px; font-weight: 500; }
	.event-item .item-audience { display: inline-block;  }
	.event-item .audience { font-size: 16px; padding: 3px 8px; margin: 0 2px 4px 0; }
	.event-day { width: 50px; text-align: center; flex-shrink: 0; }
	.event-list td h4.event-day-no { margin-right: 0; margin-bottom: 1px; }
	.event-day-name { text-transform: uppercase; font-size: 15px; }
	@media screen and (max-width: 800px) { .event-list, .event-list td { display: block; } }

	/* mobile navigation */
   
	#mobilemenu 
	{ 
		background-color: #6791ba; color: #FFFFFF; position: fixed; top: -200px; left: 0px; right: 0px; height: 10px; overflow: hidden; 
		transition: all 0.2s ease-in-out; padding-top: 0; z-index: 80;
	}
	#mobilemenu.active { top: 0; height: 100vh; transition: all 0.2s ease-in-out; padding-top: 60px; }
   #mobilemenu a { color: #FFFFFF; display: block; font-size: 20px; line-height: 20px; padding: 10px 25px 10px 0; font-weight: 500; text-decoration: none; }
	
   #mobile-menu { list-style-type: none; margin: 0 8px 0 0; padding: 0px; }
   #mobile-menu > li { border-bottom: 1px solid rgba(255,255,255,0.5); padding-right: 50px; }
   #mobile-menu > li.menu-item-has-children 
   { 
      background: transparent url('images/icons/down.svg') right 9px no-repeat; background-size: 13px auto; 
      cursor: pointer;
   }
   #mobile-menu > li.menu-item-has-children.expanded { background-image: url('images/icons/up.svg'); }
   #mobile-menu > li > ul { display: none; }   
   #mobile-menu > li.expanded > ul { display: block; list-style-type: disc; margin-bottom: 15px; }
	#mobile-menu > li.expanded > ul li::marker { color: rgba(255,255,255,0.33); }
		
   #mobile-menu > li > ul > li a { font-weight: 300; font-size: 18px; line-height: 1; padding: 7px 0px; }  
	#mobile-menu li::marker { color: #000000; }
	
	/* search controls */

	#searchcontrol
	{ 
		background-color: #e9e8e5; color: #000000; position: absolute; top: -200px; left: 0px; right: 0px; height: 10px; overflow: hidden; 
		transition: all 0.2s ease-in-out; padding-top: 0; z-index: 90;
	}
	#searchcontrol.active 
	{ 
		top: 0; height: 100vh; transition: all 0.2s ease-in-out; padding-top: 60px; overflow: scroll; 
		position: fixed;
	}
	body.home #searchcontrol.active { padding-top: 200px; }
	#searchcontrol form, .searchcontrol form { display: flex; gap: 15px; width: 100%; margin-bottom: 30px; }
	#searchcontrol form #s, .searchcontrol form input[type=text]
	{ 
		flex-basis: 50%; flex-grow: 1; background-color: #FFFFFF; border: 0; font-size: 18px; line-height: 1; padding: 4px 6px; 
	}
	.searchcontrol form input[type=text] { background-color: rgba(0,0,0,0.1); }
	#searchcontrol form .btn, .searchcontrol form .btn { flex-grow: 0; margin: 0; }
	
	/* search results */
	
	table.search-results td { padding: 0 20px 10px 0; }
	table.search-results td.result-type, table.search-results .event-day-name { text-transform: uppercase; font-size: 16px; }
	table.search-results td.result-type { padding-top: 1px; }
	table.search-results td.result-listing { padding-right: 0; }
	table.search-results td.result-date { text-align: center; }
	table.search-results td h4 { margin-bottom: 0; }
	@media screen and (max-width: 650px)
   {
		table.search-results td.result-type, table.search-results .event-day-name { font-size: 14px; padding-top: 0; }
		table.search-results td:not(.result-listing) { padding-right: 10px; }
	}
	
	/* standard modal */
	
	#modal 
	{ 
		background-color: #FFFFFF; color: #000000; position: absolute; top: -200px; left: 0px; right: 0px; height: 10px; 
		transition: all 0.2s ease-in-out; padding-top: 0; z-index: 60; overflow: auto;
	}
	#modal.active { top: 0; height: 100vh; transition: all 0.2s ease-in-out; padding-top: 110px; position: fixed; }
	#modal .modalclose {	margin: 0 0 25px 0; text-align: right; color: #74a4ca; cursor: pointer;	}
	#modal .modalclose:hover { color: #011F5B; }
	#modal .modalclose svg { display: inline-block; height: 35px; width: auto; }
	
	/* loading indicator */

	.loading { display: inline-block; width: 100px; height: 100px; }
	.loading:before
	{ 
		content: " "; display: block; width: 80px; height: 80px; margin: 10px; border-radius: 50%;
		border: 8px solid #FFFFFF; border-color: rgba(104,104,104,0.5) rgba(104,104,104,0.0) rgba(104,104,104,0.5) rgba(104,104,104,0.0);
		animation: loadspin 1.2s linear infinite;
	}
	@keyframes loadspin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }

	
	/* wordpress-related */
	
	body.admin-bar { padding-top: 102px; }
	body.admin-bar header { top: 32px; }
	#mobilemenu.active, #searchcontrol.active { padding-top: 92px; }
	@media screen and (max-width: 782px)
	{
		body.admin-bar { padding-top: 96px; }
		body.admin-bar header { top: 46px; }
		#mobilemenu.active, #searchcontrol.active { padding-top: 106px; }
	}
	
   /* mobile switches */
	
   @media screen and (max-width: 1400px)
   {
		header #menu { font-size: 17px; }
	}
	
   @media screen and (min-width: 1151px)
	{
		.mobilenav { display: none; }
		.mobileonly { display: none !important; }
	}
   @media screen and (max-width: 1150px)
   {
		body { font-size: 18px; padding-top: 72px; }
		h1 { font-size: 38px; }
		h2 { font-size: 30px; }
		h3 { font-size: 24px; }
		h4 { font-size: 20px; }
		h5 { font-size: 18px; }
		.frame { padding-left: 35px; padding-right: 35px; }
		header .topbar { display: none; }
		header .navbar { padding: 20px 0; }
		header .zl img { height: 32px; }
		#menu li:not(.search, .mobilenav) { display: none; }
		a.go { margin-left: -0.25em; }
		.cells .cell { width: calc(33.333% - 14px); }
		table.agenda td { display: block; border: 0; padding: 0 0 10px 0; }
		table.agenda td:first-child { border-top: 1px solid rgba(0,0,0,0.2); padding-top: 15px; margin-top: 20px; }
		footer a.wharton img { width: 150px; }
		blockquote p { font-size: 20px; }
		.btn, a.btn, .downtab .label { font-size: 18px; }

   }  
	
   @media screen and (max-width: 650px)
   {
		body { font-size: 16px; padding-top: 50px; }
		h1 { font-size: 34px; }
		h2 { font-size: 26px; }
		h3 { font-size: 22px; }
		h4 { font-size: 18px; }
		h5 { font-size: 16px; }
		header .zl img { height: 24px; }
		header .navbar { padding: 12px 0; }
		/* .frame { padding-left: 15px; padding-right: 15px; } */
		footer { font-size: 16px; }
		footer a.wharton { float: none; display: block; margin: 0 0 20px 0; }
		.hero { min-height: 50vh; }
		.alignright, .wp-block-image .alignright { width: 50%; float: none; margin: 0 0 25px 0; }
			
		.cols .col { width: 100%; }
		.cols .col.img { aspect-ratio: 3 / 2; }
		.cells .cell { width: calc(50% - 10px); }
		.cells.portraits .cell { aspect-ratio: 1 / 2; }
		.cell .overlay h4 { background-color: rgba(0,0,0,0.5); }
		.cell .overlay .info { font-size: 14px; }
		table.attendees td, table.attendees th { font-size: 16px; }
		.zone.become-a-member { background-color: #f1ede7; background-size: 200% auto; background-position: left top; padding-top: 67.68vw; gap: 0; }
		.zone.become-a-member .frame { padding-top: 0; padding-bottom: 0; }
		.zone.become-a-member .frame .cols .col:first-child { display: none; }
		.zone.become-a-member .frame .col:last-child { padding: 15px 0; }
		.zone.student-experience .frame { padding-top: 25px; padding-bottom: 0; }
		.zone.student-experience .cols { gap: 0; }
		.zone.student-experience .cols .col:last-child { order: 1; }
		.zone.student-experience .cols .col:first-child { order: 2; }
		.nomobile { display: none; }
		.zone.students-schlager { padding: 0; }
		.zone.students-schlager .col:last-child { padding: 0; }
		.zone.students-meetings { padding-top: 0; }
		.zone.students-meetings .frame { padding-bottom: 40vw; }
		.zone.students-mentor { padding-top: 33.333vw; padding-bottom: 0; background-position: center 33%; }
		.zone.students-mentor .frame { padding-bottom: 25px; }
		.zone.students-mentor .col:last-child { display: none; }
		.zone.helfand-bluhm .cols { gap: 0; }
		a.go { background-image: none; padding-left: 0; margin-left: 0; white-space: wrap; }
		.btn, a.btn, .downtab .label { font-size: 16px; }
		.downtab .label { padding: 5px 5px; }
		.downtab.totop { display: none; }
		.controls { float: none; text-align: left; margin: 0 0 25px 0; }
	}
   
   /* print */

   @media print
   {
		body { padding: 0; margin: 0; font-size: 11pt; }
		a { color: #000000; }
		header, a.btn, a.ghostbtn, .img { display: none; } 
		.frame { padding-left: 0; padding-right: 0; max-width: auto; margin: 0; }
		.cols .col { width: 100%; }
		footer { background-color: #FFFFFF; border-top: 1px solid #999999; }
		footer .socials { display: none; }
		footer a.wharton img { width: 1.5in; }
		#downbar { display: none; }
		a.audience, span.audience { color: #000000; background-color: #FFFFFF; border: 1px solid #000000; font-weight: 300; font-size: 11pt; }
		.zone, .zone .frame { padding: 0; }
		.reversed { color: #000000; }

		body:before 
		{ 
			display: block; padding: 0 0 0.25in 0; text-transform: uppercase; 
			content: "Zell/Lurie Real Estate Center at Wharton"; text-align: left; 
		}
		
		h2 { font-size: 20pt; }
		h3 { font-size: 18pt; }
		h4, table.agenda td h4 { font-size: 12pt; }
		h5 { font-size: 12pt; }
		
		.hero { height: auto; background: #FFFFFF !important; }
		.hero .overlay { position: relative; background: transparent; }
		.hero .overlay .frame { padding: 0; text-shadow: none; }
		.photo-strip { display: none; }
		
		.cells.portraits .cell { background: #FFFFFF !important; aspect-ratio: auto; }
		.cells.portraits .cell .overlay { position: relative; background: transparent; padding: 0; }
		.cells.portraits .cell .overlay .info { color: #000000; }
		
		table.shade td { border-top: 1px dotted #999999; background: #FFFFFF; padding-left: 0; }
		table.shade th { padding-left: 0; }
		
		/* home page */
		
		body.home .zone, body.student-experience .zone, footer { padding-top: 0.25in; border-top: 1px solid #000000; break-inside: avoid-page; }
		.messaging { background: #FFFFFF; padding-bottom: 0.25in; }
		.messaging .frame { color: #000000; font-size: 18pt; }
		.messaging .scrim { background: transparent; }
		.zone.become-a-member { background: #FFFFFF; }
		.zone.become-a-member .col:last-child, .zone.student-experience .col:first-child { padding: 0; }
		.zone.become-a-member .col:first-child, .zone.student-experience .col:last-child { display: none; }
		.zone.student-experience p { margin: 0; }
		.zone.student-experience p:last-child { display: none; }
		
		/* students landing page */
		
		.zone.students-meetings { background: #FFFFFF; padding: 0; }
		.zone.students-meetings .frame { padding: 0; }
		.zone.students-meetings h3 { color: #000000; }
		.zone.students-meetings p { text-shadow: none; }

		.zone.helfand-bluhm { background: #FFFFFF; }
		.zone.helfand-bluhm .frame { padding: 0; }
		.zone.helfand-bluhm .cols { gap: 0; }
		.zone.helfand-bluhm p { font-weight: inherit; }
		
		.zone.students-ballard { background: #FFFFFF; padding: 0; }
		
		.zone.students-schlager, .zone.students-schlager .col:last-child { padding: 0; }
	
		.zone.students-mentor { background: #FFFFFF; min-height: auto; padding: 0; color: #000000; }
   }
   